-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdjangoWsgi.py
94 lines (79 loc) · 3.27 KB
/
djangoWsgi.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
#__BEGIN_LICENSE__
# Copyright (c) 2015, United States Government, as represented by the
# Administrator of the National Aeronautics and Space Administration.
# All rights reserved.
#
# The xGDS platform is licensed under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
# http://www.apache.org/licenses/LICENSE-2.0.
#
# Unless required by applicable law or agreed to in writing, software distributed
# under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
# CONDITIONS OF ANY KIND, either express or implied. See the License for the
# specific language governing permissions and limitations under the License.
#__END_LICENSE__
import os
import sys
import tempfile
import re
# avoid crazy error on mac os
os.environ['PYTHON_EGG_CACHE'] = '/tmp'
def getEnvironmentFromSourceMe(d='.'):
# pick up environment variables from sourceme
fd, varsFile = tempfile.mkstemp('djangoWsgiSourceMe.txt')
os.close(fd)
ret = os.system('bash -c "(source %s/sourceme.sh && printenv > %s)"' % (d, varsFile))
if ret != 0:
varsFile = '%s/vars.txt' % d
print >> sys.stderr, 'djangoWsgi.py: could not auto-generate environment from sourceme.sh, trying to fall back to manually generated file %s' % varsFile
# fallback: user can manually generate vars.txt file by sourcing sourceme.sh and running 'printenv > vars.txt'
varsIn = file(varsFile, 'r')
for line in varsIn:
line = line[:-1] # chop final cr
if '=' not in line or '=()' in line:
continue
var, val = line.split('=', 1)
os.environ[var] = val
varsIn.close()
try:
os.unlink(varsFile)
except OSError:
pass
# set up virtualenv if needed
if 'VIRTUAL_ENV' in os.environ:
activateFile = '%s/bin/activate_this.py' % os.environ['VIRTUAL_ENV']
execfile(activateFile, {'__file__': activateFile})
# add any new entries from PYTHONPATH to Python's sys.path
if 'PYTHONPATH' in os.environ:
envPath = re.sub(':$', '', os.environ['PYTHONPATH'])
sys.path = envPath.split(':') + sys.path
def sendError(start_response, text):
start_response(text, [('Content-type', 'text/html')])
return ["""<html>
<head><title>%s</title></head>
<body><h1>%s</h1></body>
</html>
""" % (text, text)]
def downForMaintenance(environ, start_response):
import stat
import time
d = os.path.dirname(os.path.realpath(__file__))
downFile = os.path.join(d, 'DOWN_FOR_MAINTENANCE')
downMtime = os.stat(downFile)[stat.ST_MTIME]
downTimeString = time.strftime('%Y-%m-%d %H:%M %Z', time.localtime(downMtime))
return sendError(start_response, '503 Down for maintenance since %s' % downTimeString)
thisDir = os.path.dirname(os.path.realpath(__file__))
getEnvironmentFromSourceMe(thisDir)
# do the apache login
import django
django.setup()
from django.conf import settings
from xgds_core.tokenAuth import check_password
# end apache login
if os.path.exists(os.path.join(thisDir, 'DOWN_FOR_MAINTENANCE')):
application = downForMaintenance
else:
#os.environ['DJANGO_SETTINGS_MODULE'] = 'basaltApp.settings'
from django.core.wsgi import get_wsgi_application
application = get_wsgi_application()