projects
/
invirt/packages/invirt-web.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
rename overlord -> admin mode
[invirt/packages/invirt-web.git]
/
code
/
main.py
diff --git
a/code/main.py
b/code/main.py
index
03d7eb1
..
42a456e
100755
(executable)
--- a/
code/main.py
+++ b/
code/main.py
@@
-34,15
+34,14
@@
if __name__ == '__main__':
import templates
from Cheetah.Template import Template
import templates
from Cheetah.Template import Template
-import sipb_xen_database
-from sipb_xen_database import Machine, CDROM, ctx, connect, MachineAccess, Type, Autoinstall
import validation
import cache_acls
from webcommon import InvalidInput, CodeError, State
import controls
from getafsgroups import getAfsGroupMembers
import validation
import cache_acls
from webcommon import InvalidInput, CodeError, State
import controls
from getafsgroups import getAfsGroupMembers
-import invirt.config
-invirt_config = invirt.config.load()
+from invirt import database
+from invirt.database import Machine, CDROM, ctx, connect, MachineAccess, Type, Autoinstall
+from invirt.config import structs as config
def pathSplit(path):
if path.startswith('/'):
def pathSplit(path):
if path.startswith('/'):
@@
-85,7
+84,8
@@
def makeErrorPre(old, addition):
else:
return '<p>STDERR:</p><pre>' + str(addition) + '</pre>'
else:
return '<p>STDERR:</p><pre>' + str(addition) + '</pre>'
-Template.sipb_xen_database = sipb_xen_database
+Template.database = database
+Template.config = config
Template.helppopup = staticmethod(helppopup)
Template.err = None
Template.helppopup = staticmethod(helppopup)
Template.err = None
@@
-259,8
+259,7
@@
def vnc(username, state, path, fields):
token = base64.urlsafe_b64encode(token)
host = controls.listHost(machine)
if host:
token = base64.urlsafe_b64encode(token)
host = controls.listHost(machine)
if host:
- port = 10003 + [config_host["hostname"] for config_host in invirt_config["hosts"]
- ].index(host)
+ port = 10003 + [h.hostname for h in config.hosts].index(host)
else:
port = 5900 # dummy
else:
port = 5900 # dummy
@@
-284,7
+283,7
@@
def getHostname(nic):
if nic.hostname and '.' in nic.hostname:
return nic.hostname
elif nic.machine:
if nic.hostname and '.' in nic.hostname:
return nic.hostname
elif nic.machine:
- return nic.machine.name + '.xvm.mit.edu'
+ return nic.machine.name + '.' + config.dns.domains[0]
else:
return None
else:
return None
@@
-441,8
+440,8
@@
def helpHandler(username, state, path, fields):
help_mapping = {'ParaVM Console': """
ParaVM machines do not support local console access over VNC. To
access the serial console of these machines, you can SSH with Kerberos
help_mapping = {'ParaVM Console': """
ParaVM machines do not support local console access over VNC. To
access the serial console of these machines, you can SSH with Kerberos
-to console.xvm.mit.edu, using the name of the machine as your
-username.""",
+to console.%s, using the name of the machine as your
+username.""" % config.dns.domains[0],
'HVM/ParaVM': """
HVM machines use the virtualization features of the processor, while
ParaVM machines use Xen's emulation of virtualization features. You
'HVM/ParaVM': """
HVM machines use the virtualization features of the processor, while
ParaVM machines use Xen's emulation of virtualization features. You
@@
-596,14
+595,15
@@
def unauthFront(_, _2, _3, fields):
"""Information for unauth'd users."""
return templates.unauth(searchList=[{'simple' : True}])
"""Information for unauth'd users."""
return templates.unauth(searchList=[{'simple' : True}])
-def overlord(username, state, path, fields):
+def admin(username, state, path, fields):
if path == '':
return ({'Status': '303 See Other',
if path == '':
return ({'Status': '303 See Other',
- 'Location': 'overlord/'},
+ 'Location': 'admin/'},
"You shouldn't see this message.")
if not username in getAfsGroupMembers('system:xvm', 'athena.mit.edu'):
"You shouldn't see this message.")
if not username in getAfsGroupMembers('system:xvm', 'athena.mit.edu'):
- raise InvalidInput('username', username, 'Not an overlord.')
- newstate = State(username, overlord=True)
+ raise InvalidInput('username', username,
+ 'Not in admin group %s.' % 'system:xvm')
+ newstate = State(username, isadmin=True)
newstate.environ = state.environ
return handler(username, newstate, path, fields)
newstate.environ = state.environ
return handler(username, newstate, path, fields)
@@
-619,7
+619,7
@@
mapping = dict(list=listVms,
create=create,
help=helpHandler,
unauth=unauthFront,
create=create,
help=helpHandler,
unauth=unauthFront,
- overlord=overlord,
+ admin=admin,
errortest=throwError)
def printHeaders(headers):
errortest=throwError)
def printHeaders(headers):
@@
-631,13
+631,13
@@
def printHeaders(headers):
def send_error_mail(subject, body):
import subprocess
def send_error_mail(subject, body):
import subprocess
- to = 'xvm@mit.edu'
+ to = config.web.errormail
mail = """To: %s
mail = """To: %s
-From: root@xvm.mit.edu
+From: root@%s
Subject: %s
%s
Subject: %s
%s
-""" % (to, subject, body)
+""" % (to, config.web.hostname, subject, body)
p = subprocess.Popen(['/usr/sbin/sendmail', to], stdin=subprocess.PIPE)
p.stdin.write(mail)
p.stdin.close()
p = subprocess.Popen(['/usr/sbin/sendmail', to], stdin=subprocess.PIPE)
p.stdin.write(mail)
p.stdin.close()
@@
-679,7
+679,7
@@
class App:
def __iter__(self):
start_time = time.time()
def __iter__(self):
start_time = time.time()
- sipb_xen_database.clear_cache()
+ database.clear_cache()
sys.stderr = StringIO()
fields = cgi.FieldStorage(fp=self.environ['wsgi.input'], environ=self.environ)
operation = self.environ.get('PATH_INFO', '')
sys.stderr = StringIO()
fields = cgi.FieldStorage(fp=self.environ['wsgi.input'], environ=self.environ)
operation = self.environ.get('PATH_INFO', '')
@@
-732,7
+732,7
@@
class App:
yield '<pre>%s</pre>' % cgi.escape(str(checkpoint))
def constructor():
yield '<pre>%s</pre>' % cgi.escape(str(checkpoint))
def constructor():
- connect('postgres://sipb-xen@sipb-xen-dev.mit.edu/sipb_xen')
+ connect()
return App
def main():
return App
def main():