X-Git-Url: http://git.cascardo.info/?p=cascardo%2Fipsilon.git;a=blobdiff_plain;f=ipsilon%2Futil%2Fuser.py;h=9dc0d65e13073c719721a39362d4c1615a3a9246;hp=84f181897336a53a819e79524edbcef90363e6d6;hb=f7b6d96d284f78b8ee94d252b37e874dc32baf2b;hpb=71edd1146556eecb9f9375da46313e94bf82874c diff --git a/ipsilon/util/user.py b/ipsilon/util/user.py index 84f1818..9dc0d65 100755 --- a/ipsilon/util/user.py +++ b/ipsilon/util/user.py @@ -102,6 +102,7 @@ class User(object): class UserSession(Log): def __init__(self): self.user = self.get_data('user', 'name') + self.userattrs = self.get_user_attrs() def get_user(self): return User(self.user) @@ -112,7 +113,7 @@ class UserSession(Log): else: self.nuke_data('user') - def login(self, username): + def login(self, username, userattrs=None): if self.user == username: return @@ -121,6 +122,11 @@ class UserSession(Log): self.save_data('user', 'name', username) self.user = username + # Save additional data provided by the login manager + self.nuke_data('userattrs') + if userattrs: + self.save_user_attrs(userattrs) + cherrypy.log('LOGIN SUCCESSFUL: %s' % username) def logout(self, user): @@ -134,6 +140,18 @@ class UserSession(Log): # Destroy current session in all cases cherrypy.lib.sessions.expire() + def get_user_attrs(self): + userattrs = dict() + if 'userattrs' in cherrypy.session: + userattrs = cherrypy.session['userattrs'] + return userattrs + + def save_user_attrs(self, userattrs): + cherrypy.session['userattrs'] = userattrs + cherrypy.session.save() + self._debug('Saved user attrs') + self.userattrs = userattrs + def save_data(self, facility, name, data): """ Save named data in the session so it can be retrieved later """ if facility not in cherrypy.session: