2007-09-10 15:33:01 -05:00
|
|
|
from turbogears.identity.soprovider import *
|
|
|
|
from turbogears.identity.visitor import *
|
|
|
|
import logging
|
2007-09-14 16:19:02 -05:00
|
|
|
import os
|
2007-11-13 10:15:07 -06:00
|
|
|
import ipa.ipaclient
|
|
|
|
from ipaserver import funcs
|
|
|
|
import ipa.config
|
|
|
|
import ipa.group
|
|
|
|
import ipa.user
|
2007-09-10 15:33:01 -05:00
|
|
|
|
|
|
|
log = logging.getLogger("turbogears.identity")
|
|
|
|
|
|
|
|
class IPA_User(object):
|
|
|
|
'''
|
|
|
|
Shell of a User definition. We don't really need much here.
|
|
|
|
'''
|
|
|
|
|
|
|
|
def __init__(self, user_name):
|
|
|
|
self.user_name = user_name
|
2007-11-02 16:41:24 -05:00
|
|
|
(principal, realm) = user_name.split('@')
|
|
|
|
self.display_name = principal
|
2007-09-10 15:33:01 -05:00
|
|
|
self.permissions = None
|
2007-11-13 10:15:07 -06:00
|
|
|
transport = funcs.IPAServer()
|
|
|
|
client = ipa.ipaclient.IPAClient(transport)
|
|
|
|
client.set_krbccache(os.environ["KRB5CCNAME"])
|
|
|
|
try:
|
|
|
|
user = client.get_user_by_principal(user_name, ['dn'])
|
|
|
|
self.groups = []
|
|
|
|
groups = client.get_groups_by_member(user.dn, ['dn', 'cn'])
|
|
|
|
if isinstance(groups, str):
|
|
|
|
groups = [groups]
|
|
|
|
for ginfo in groups:
|
|
|
|
# cn may be multi-valued, add them all just in case
|
|
|
|
cn = ginfo.getValue('cn')
|
|
|
|
if isinstance(cn, str):
|
|
|
|
cn = [cn]
|
|
|
|
for c in cn:
|
|
|
|
self.groups.append(c)
|
|
|
|
except:
|
|
|
|
raise
|
|
|
|
|
2007-09-10 15:33:01 -05:00
|
|
|
return
|
|
|
|
|
|
|
|
class ProxyIdentity(object):
|
|
|
|
def __init__(self, visit_key, user=None):
|
2007-09-20 16:53:23 -05:00
|
|
|
self._user= user
|
2007-09-10 15:33:01 -05:00
|
|
|
self.visit_key= visit_key
|
|
|
|
|
|
|
|
def _get_user(self):
|
|
|
|
try:
|
|
|
|
return self._user
|
|
|
|
except AttributeError:
|
|
|
|
# User hasn't already been set
|
|
|
|
return None
|
|
|
|
user= property(_get_user)
|
|
|
|
|
|
|
|
def _get_user_name(self):
|
2007-09-11 16:45:53 -05:00
|
|
|
if not self._user:
|
2007-09-10 15:33:01 -05:00
|
|
|
return None
|
2007-09-11 16:45:53 -05:00
|
|
|
return self._user.user_name
|
2007-09-10 15:33:01 -05:00
|
|
|
user_name= property(_get_user_name)
|
|
|
|
|
2007-09-11 16:45:53 -05:00
|
|
|
def _get_display_name(self):
|
|
|
|
if not self._user:
|
2007-09-10 15:33:01 -05:00
|
|
|
return None
|
2007-09-11 16:45:53 -05:00
|
|
|
return self._user.display_name
|
|
|
|
display_name= property(_get_display_name)
|
2007-09-10 15:33:01 -05:00
|
|
|
|
|
|
|
def _get_anonymous(self):
|
2007-09-11 16:45:53 -05:00
|
|
|
return not self._user
|
2007-09-10 15:33:01 -05:00
|
|
|
anonymous= property(_get_anonymous)
|
|
|
|
|
|
|
|
def _get_permissions(self):
|
|
|
|
try:
|
|
|
|
return self._permissions
|
|
|
|
except AttributeError:
|
|
|
|
# Permissions haven't been computed yet
|
|
|
|
return None
|
|
|
|
permissions= property(_get_permissions)
|
|
|
|
|
|
|
|
def _get_groups(self):
|
|
|
|
try:
|
2007-11-13 10:15:07 -06:00
|
|
|
return self._user.groups
|
2007-09-10 15:33:01 -05:00
|
|
|
except AttributeError:
|
|
|
|
# Groups haven't been computed yet
|
2007-12-05 14:12:24 -06:00
|
|
|
return []
|
2007-09-10 15:33:01 -05:00
|
|
|
groups= property(_get_groups)
|
|
|
|
|
|
|
|
def logout(self):
|
|
|
|
'''
|
|
|
|
Remove the link between this identity and the visit.
|
|
|
|
'''
|
|
|
|
# Clear the current identity
|
|
|
|
anon= ProxyObjectIdentity(None,None)
|
|
|
|
#XXX if user is None anonymous will be true, no need to set attr.
|
|
|
|
#anon.anonymous= True
|
|
|
|
identity.set_current_identity( anon )
|
|
|
|
|
|
|
|
class ProxyIdentityProvider(SqlObjectIdentityProvider):
|
|
|
|
'''
|
|
|
|
IdentityProvider that uses REMOTE_USER from Apache
|
|
|
|
'''
|
|
|
|
def __init__(self):
|
|
|
|
super(ProxyIdentityProvider, self).__init__()
|
|
|
|
get = turbogears.config.get
|
|
|
|
# We can get any config variables here
|
|
|
|
log.info( "Proxy Identity starting" )
|
|
|
|
|
|
|
|
def create_provider_model(self):
|
|
|
|
pass
|
|
|
|
|
|
|
|
def validate_identity(self, user_name, password, visit_key):
|
2007-11-13 10:15:07 -06:00
|
|
|
try:
|
|
|
|
user = IPA_User(user_name)
|
|
|
|
log.debug( "validate_identity %s" % user_name)
|
|
|
|
return ProxyIdentity(visit_key, user)
|
|
|
|
except:
|
|
|
|
# Something went wrong in fetching the user. Set to
|
|
|
|
# anonymous which will deny access.
|
|
|
|
return ProxyIdentity( None )
|
2007-09-10 15:33:01 -05:00
|
|
|
|
|
|
|
def validate_password(self, user, user_name, password):
|
|
|
|
'''Validation has already occurred in the proxy'''
|
|
|
|
return True
|
|
|
|
|
|
|
|
def load_identity(self, visit_key):
|
|
|
|
try:
|
2007-09-14 16:19:02 -05:00
|
|
|
user_name= cherrypy.request.headers['X-FORWARDED-USER']
|
|
|
|
os.environ["KRB5CCNAME"] = cherrypy.request.headers['X-FORWARDED-KEYTAB']
|
|
|
|
# user_name = "test@FREEIPA.ORG"
|
|
|
|
# os.environ["KRB5CCNAME"] = "FILE:/tmp/krb5cc_500"
|
2007-09-10 15:33:01 -05:00
|
|
|
except KeyError:
|
|
|
|
return None
|
|
|
|
set_login_attempted( True )
|
|
|
|
return self.validate_identity( user_name, None, visit_key )
|
|
|
|
|
|
|
|
def anonymous_identity( self ):
|
|
|
|
'''
|
|
|
|
This shouldn't ever happen in IPA but including it to include the
|
|
|
|
entire identity API.
|
|
|
|
'''
|
|
|
|
return ProxyIdentity( None )
|
|
|
|
|
|
|
|
def authenticated_identity(self, user):
|
|
|
|
'''
|
|
|
|
Constructs Identity object for user that has no associated visit_key.
|
|
|
|
'''
|
|
|
|
return ProxyIdentity(None, user)
|