summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
3983bef)
This way all identification data about the user can be managed in
a single place and be erased/replaced at login time.
Signed-off-by: Simo Sorce <simo@redhat.com>
class UserSession(object):
def __init__(self):
class UserSession(object):
def __init__(self):
- self.user = cherrypy.session.get('user', None)
+ self.user = self.get_data('user', 'name')
def _debug(self, fact):
if cherrypy.config.get('debug', False):
def _debug(self, fact):
if cherrypy.config.get('debug', False):
return
# REMOTE_USER changed, replace user
return
# REMOTE_USER changed, replace user
- cherrypy.session['user'] = username
- cherrypy.session.save()
+ self.nuke_data('user')
+ self.save_data('user', 'name', username)
cherrypy.log('LOGIN SUCCESSFUL: %s', username)
cherrypy.log('LOGIN SUCCESSFUL: %s', username)
return None
return cherrypy.session[facility][name]
return None
return cherrypy.session[facility][name]
- def nuke_data(self, facility, name):
+ def nuke_data(self, facility, name=None):
if facility not in cherrypy.session:
return
if facility not in cherrypy.session:
return
- if name not in cherrypy.session[facility]:
- return
- cherrypy.session[facility][name] = None
- del cherrypy.session[facility][name]
+ if name:
+ if name not in cherrypy.session[facility]:
+ return
+ cherrypy.session[facility][name] = None
+ del cherrypy.session[facility][name]
+ self._debug('Nuked session data named [%s:%s]' % (facility, name))
+ else:
+ del cherrypy.session[facility]
+ self._debug('Nuked session facility [%s]' % (facility,))
- self._debug('Nuked session data named [%s:%s]' % (facility, name))