Jan Dittberner
7c4d25da43
* provide an XMLRPC server start script (bin/gvaserver) (addresses #5) * encapsulate XMLRPC visible code in gnuviechadmin.xmlrpc.XMLRPCFacade * start implementation of authkit compatible Users implementation gnuviechadmin.xmlrpc.users.GVAUsers (addresses #17) git-svn-id: file:///home/www/usr01/svn/gnuviechadmin/trunk@256 a67ec6bc-e5d5-0310-a910-815c51eb3124
87 lines
2.6 KiB
Python
87 lines
2.6 KiB
Python
# -*- python -*-
|
|
# -*- coding: utf-8 -*-
|
|
from authkit.users import Users, AuthKitNoSuchUserError
|
|
import logging
|
|
|
|
log = logging.getLogger(__name__)
|
|
|
|
class UserProvider(Users):
|
|
def _get_user(self, username, password, role):
|
|
return {
|
|
'username' : username,
|
|
'group' : None,
|
|
'password' : password,
|
|
'roles' : [role]
|
|
}
|
|
|
|
class ClientUserProvider(UserProvider):
|
|
def user(self, username):
|
|
print 'checking %s' % username
|
|
if username == 'dummy':
|
|
return self._get_user(username, username, 'client')
|
|
return AuthKitNoSuchUserError()
|
|
|
|
def list_roles(self):
|
|
return ['client']
|
|
|
|
class MailuserUserProvider(UserProvider):
|
|
def user(self, username):
|
|
raise AuthKitNoSuchUserError()
|
|
|
|
def list_roles(self):
|
|
return ['mailuser']
|
|
|
|
class SysuserUserProvider(UserProvider):
|
|
def user(self, username):
|
|
raise AuthKitNoSuchUserError()
|
|
|
|
def list_roles(self):
|
|
return ['sysuser']
|
|
|
|
class GVAUsers(Users):
|
|
def __init__(self, data, userproviders = [], encrypt = None):
|
|
"""Initialize the GVAXMLRPCUsers instance."""
|
|
Users.__init__(self, data, encrypt)
|
|
self.userproviders = [prov(self.data) for prov in userproviders]
|
|
|
|
def list_roles(self):
|
|
"""Returns a lowercase list of all role names ordered
|
|
alphabetically."""
|
|
roles = []
|
|
for prov in self.userproviders:
|
|
for role in prov.list_roles():
|
|
if not role in roles:
|
|
roles.append(role)
|
|
roles.sort()
|
|
return roles
|
|
|
|
def role_exists(self, role):
|
|
"""Returns ``True`` if the role exists, ``False``
|
|
otherwise. Roles are case insensitive."""
|
|
for prov in self.userproviders:
|
|
if prov.role_exists(role):
|
|
return True
|
|
return False
|
|
|
|
def user(self, username):
|
|
"""Returns a dictionary in the following format:
|
|
|
|
.. code-block :: Python
|
|
|
|
{
|
|
'username': username,
|
|
'group': group,
|
|
'password': password,
|
|
'roles': [role1,role2,role3... etc]
|
|
}
|
|
|
|
The role names are ordered alphabetically
|
|
Raises an exception if the user doesn't exist."""
|
|
for prov in self.userproviders:
|
|
try:
|
|
return prov.user(username)
|
|
except Exception, e:
|
|
print e
|
|
log.debug("Backend %s didn't find user %s" % (backend,
|
|
username))
|
|
raise AuthKitNoSuchUserError()
|