X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-web.git/blobdiff_plain/eae4f70e8b3a04e5aed98885a03577646071f0bc..542183dd43e3d9c9260b2ce1313126b7f6535f6c:/code/main.py diff --git a/code/main.py b/code/main.py index 00a79ae..5de084e 100755 --- a/code/main.py +++ b/code/main.py @@ -55,6 +55,15 @@ class InvirtWeb(View): self._cp_config['tools.mako.imports'] = ['from invirt.config import structs as config', 'from invirt import database'] + def __getattr__(self, name): + if name in ("admin", "overlord"): + if not cherrypy.request.login in getAfsGroupMembers(config.adminacl, config.authz[0].cell): + raise InvalidInput('username', cherrypy.request.login, + 'Not in admin group %s.' % config.adminacl) + cherrypy.request.state = State(cherrypy.request.login, isadmin=True) + return self + else: + return super(InvirtWeb, self).__getattr__(name) @cherrypy.expose @cherrypy.tools.mako(filename="/list.mako") @@ -182,6 +191,11 @@ console will suffer artifacts. return {'request': cherrypy.request, 'kwargs': kwargs} helloworld._cp_config['tools.require_login.on'] = False + @cherrypy.expose + def errortest(self): + """Throw an error, to test the error-tracing mechanisms.""" + raise RuntimeError("test of the emergency broadcast system") + class MachineView(View): # This is hairy. Fix when CherryPy 3.2 is out. (rename to # _cp_dispatch, and parse the argument as a list instead of @@ -640,28 +654,9 @@ def unauthFront(_, _2, _3, fields): return templates.unauth(searchList=[{'simple' : True, 'hostname' : socket.getfqdn()}]) -def admin(username, state, path, fields): - if path == '': - return ({'Status': '303 See Other', - 'Location': 'admin/'}, - "You shouldn't see this message.") - if not username in getAfsGroupMembers(config.adminacl, 'athena.mit.edu'): - raise InvalidInput('username', username, - 'Not in admin group %s.' % config.adminacl) - newstate = State(username, isadmin=True) - newstate.environ = state.environ - return handler(username, newstate, path, fields) - -def throwError(_, __, ___, ____): - """Throw an error, to test the error-tracing mechanisms.""" - raise RuntimeError("test of the emergency broadcast system") - mapping = dict( modify=modify, - unauth=unauthFront, - admin=admin, - overlord=admin, - errortest=throwError) + unauth=unauthFront) def printHeaders(headers): """Print a dictionary as HTTP headers."""