X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-web.git/blobdiff_plain/cabbf7ab8e35de060f6f4e3f75670558ad25d9b5..6d171bbcd3eb2d5d60fc6c4bc9ef12608421d7c1:/code/webcommon.py diff --git a/code/webcommon.py b/code/webcommon.py index 5911787..eaf533c 100644 --- a/code/webcommon.py +++ b/code/webcommon.py @@ -1,7 +1,8 @@ """Exceptions for the web interface.""" import time -from sipb_xen_database import Machine, MachineAccess +from invirt import database +from invirt.database import Machine, MachineAccess class MyException(Exception): """Base class for my exceptions""" @@ -38,11 +39,19 @@ def cachedproperty(func): class State(object): """State for a request""" - def __init__(self, user): + def __init__(self, user, isadmin=False): self.username = user + self.isadmin = isadmin - machines = cachedproperty(lambda self: - Machine.query().join('acl').select_by(user=self.username)) + def getMachines(self): + if self.isadmin: + return Machine.query().join('acl').select_by( + database.or_(MachineAccess.c.user == self.username, + Machine.c.adminable == True)) + else: + return Machine.query().join('acl').select_by(user=self.username) + + machines = cachedproperty(getMachines) xmlist_raw = cachedproperty(lambda self: controls.getList()) xmlist = cachedproperty(lambda self: dict((m, self.xmlist_raw[m.name]) @@ -54,5 +63,3 @@ class State(object): for attr in list(self.__dict__): if attr.startswith('__cache_'): delattr(self, attr) - -state = State(None)