2008-07-19 21:03:15 -05:00
# Authors:
# Jason Gerard DeRose <jderose@redhat.com>
#
# Copyright (C) 2008 Red Hat
# see file 'COPYING' for use and warranty information
#
# This program is free software; you can redistribute it and/or
# modify it under the terms of the GNU General Public License as
# published by the Free Software Foundation; version 2 only
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
"""
2008-10-01 17:10:41 -05:00
Frontend plugins for user ( Identity ) .
2008-07-19 21:03:15 -05:00
"""
2008-09-23 19:01:29 -05:00
from ipalib import frontend
2008-09-24 22:58:42 -05:00
from ipalib import crud
2008-09-24 19:42:38 -05:00
from ipalib . frontend import Param
2008-08-25 18:35:29 -05:00
from ipalib import api
2008-10-04 00:50:59 -05:00
from ipa_server import servercore
from ipa_server import ipaldap
import ldap
2008-07-20 20:44:59 -05:00
2008-09-29 10:41:30 -05:00
# Command to get the idea how plugins will interact with api.env
class envtest ( frontend . Command ) :
' Show current environment. '
def run ( * args , * * kw ) :
print " "
print " Environment variables: "
for var in api . env :
val = api . env [ var ]
2008-10-03 10:08:37 -05:00
if var is ' server ' :
2008-09-29 10:41:30 -05:00
print " "
print " Servers: "
2008-10-03 10:08:37 -05:00
for item in api . env . server :
2008-09-29 10:41:30 -05:00
print " %s " % item
print " "
else :
print " %s : %s " % ( var , val )
api . register ( envtest )
2008-07-20 20:44:59 -05:00
2008-10-01 17:10:41 -05:00
class user ( frontend . Object ) :
"""
User object .
"""
takes_params = (
' givenname ' ,
' sn ' ,
Param ( ' uid ' ,
primary_key = True ,
default_from = lambda givenname , sn : givenname [ 0 ] + sn ,
normalize = lambda value : value . lower ( ) ,
) ,
Param ( ' krbprincipalname ' ,
default_from = lambda uid : ' %s @EXAMPLE.COM ' % uid ,
) ,
Param ( ' homedirectory ' ,
default_from = lambda uid : ' /home/ %s ' % uid ,
)
)
api . register ( user )
2008-09-24 22:58:42 -05:00
class user_add ( crud . Add ) :
2008-09-04 00:18:14 -05:00
' Add a new user. '
2008-09-25 22:53:53 -05:00
def execute ( self , * args , * * kw ) :
2008-10-04 00:50:59 -05:00
""" args[0] = uid of the user to add
kw { container } is the location in the DIT to add the user , not
required
kw otherwise contains all the attributes
"""
# FIXME: ug, really?
if not kw . get ( ' container ' ) :
user_container = servercore . DefaultUserContainer
else :
user_container = kw [ ' container ' ]
del kw [ ' container ' ]
user = kw
if not isinstance ( user , dict ) :
# FIXME, need proper error
raise SyntaxError
user [ ' uid ' ] = args [ 0 ]
2008-10-07 01:10:15 -05:00
if not servercore . is_user_unique ( user [ ' uid ' ] ) :
# FIXME, specific error
raise SyntaxError ( " user already exists " )
if servercore . uid_too_long ( user [ ' uid ' ] ) :
# FIXME, specific error
raise SyntaxError ( " uid is too long " )
2008-10-04 00:50:59 -05:00
# dn is set here, not by the user
try :
del user [ ' dn ' ]
except KeyError :
pass
# No need to set empty fields, and they can cause issues when they
# get to LDAP, like:
# TypeError: ('expected a string in the list', None)
for k in user . keys ( ) :
if not user [ k ] or len ( user [ k ] ) == 0 or ( isinstance ( user [ k ] , list ) and len ( user [ k ] ) == 1 and ' ' in user [ k ] ) :
del user [ k ]
dn = " uid= %s , %s , %s " % ( ldap . dn . escape_dn_chars ( user [ ' uid ' ] ) ,
user_container , servercore . basedn )
entry = ipaldap . Entry ( dn )
2008-10-04 04:17:11 -05:00
# Get our configuration
config = servercore . get_ipa_config ( )
2008-10-04 00:50:59 -05:00
# Let us add in some missing attributes
2008-10-04 04:17:11 -05:00
if user . get ( ' homedirectory ' ) is None :
user [ ' homedirectory ' ] = ' %s / %s ' % ( config . get ( ' ipahomesrootdir ' ) , user . get ( ' uid ' ) )
user [ ' homedirectory ' ] = user [ ' homedirectory ' ] . replace ( ' // ' , ' / ' )
user [ ' homedirectory ' ] = user [ ' homedirectory ' ] . rstrip ( ' / ' )
if user . get ( ' loginshell ' ) is None :
user [ ' loginshell ' ] = config . get ( ' ipadefaultloginshell ' )
2008-10-04 00:50:59 -05:00
if user . get ( ' gecos ' ) is None :
user [ ' gecos ' ] = user [ ' uid ' ]
2008-10-04 04:17:11 -05:00
# If uidnumber is blank the the FDS dna_plugin will automatically
# assign the next value. So we don't have to do anything with it.
group_dn = " cn= %s , %s , %s " % ( config . get ( ' ipadefaultprimarygroup ' ) , servercore . DefaultGroupContainer , servercore . basedn )
try :
default_group = servercore . get_entry_by_dn ( group_dn , [ ' dn ' , ' gidNumber ' ] )
if default_group :
user [ ' gidnumber ' ] = default_group . get ( ' gidnumber ' )
# except ipaerror.exception_for(ipaerror.LDAP_DATABASE_ERROR), e:
# raise ipaerror.gen_exception(ipaerror.LDAP_DATABASE_ERROR, message=None, nested_exception=e.detail)
# except ipaerror.exception_for(ipaerror.LDAP_NOT_FOUND):
# # Fake an LDAP error so we can return something useful to the user
# raise ipaerror.gen_exception(ipaerror.LDAP_NOT_FOUND, "The default group for new users, '%s', cannot be found." % config.get('ipadefaultprimarygroup'))
except Exception , e :
# FIXME
raise e
2008-10-04 00:50:59 -05:00
if user . get ( ' krbprincipalname ' ) is None :
user [ ' krbprincipalname ' ] = " %s @ %s " % ( user . get ( ' uid ' ) , self . realm )
# FIXME. This is a hack so we can request separate First and Last
# name in the GUI.
if user . get ( ' cn ' ) is None :
user [ ' cn ' ] = " %s %s " % ( user . get ( ' givenname ' ) ,
user . get ( ' sn ' ) )
# some required objectclasses
2008-10-04 04:17:11 -05:00
entry . setValues ( ' objectClass ' , ( config . get ( ' ipauserobjectclasses ' ) ) )
# entry.setValues('objectClass', ['top', 'person', 'organizationalPerson', 'inetOrgPerson', 'inetUser', 'posixAccount', 'krbPrincipalAux'])
2008-10-04 00:50:59 -05:00
# fill in our new entry with everything sent by the user
for u in user :
entry . setValues ( u , user [ u ] )
2008-10-07 01:10:15 -05:00
result = servercore . add_entry ( entry )
2008-10-04 00:50:59 -05:00
return result
2008-10-07 01:10:15 -05:00
def forward ( self , * args , * * kw ) :
result = super ( crud . Add , self ) . forward ( * args , * * kw )
if result != False :
2008-10-07 03:31:22 -05:00
print " User %s added " % args [ 0 ]
2008-10-04 00:50:59 -05:00
2008-08-05 17:21:57 -05:00
api . register ( user_add )
2008-07-19 21:03:15 -05:00
2008-10-01 17:10:41 -05:00
2008-09-24 22:58:42 -05:00
class user_del ( crud . Del ) :
2008-09-04 00:18:14 -05:00
' Delete an existing user. '
2008-08-05 17:21:57 -05:00
api . register ( user_del )
2008-07-19 21:03:15 -05:00
2008-10-01 17:10:41 -05:00
2008-09-24 22:58:42 -05:00
class user_mod ( crud . Mod ) :
2008-09-04 00:18:14 -05:00
' Edit an existing user. '
2008-10-07 03:31:22 -05:00
def execute ( self , * args , * * kw ) :
uid = args [ 0 ]
result = servercore . get_sub_entry ( servercore . basedn , " uid= %s " % uid , [ " * " ] )
user = kw
dn = result . get ( ' dn ' )
del result [ ' dn ' ]
entry = ipaldap . Entry ( ( dn , servercore . convert_scalar_values ( result ) ) )
for u in user :
entry . setValues ( u , user [ u ] )
result = servercore . update_entry ( entry . toDict ( ) )
return result
def forward ( self , * args , * * kw ) :
result = super ( crud . Mod , self ) . forward ( * args , * * kw )
if result != False :
print " User %s modified " % args [ 0 ]
2008-08-05 17:21:57 -05:00
api . register ( user_mod )
2008-07-19 21:03:15 -05:00
2008-10-01 17:10:41 -05:00
2008-09-24 22:58:42 -05:00
class user_find ( crud . Find ) :
2008-09-04 04:22:18 -05:00
' Search the users. '
2008-10-04 00:50:59 -05:00
def execute ( self , * args , * * kw ) :
uid = args [ 0 ]
2008-10-07 05:15:34 -05:00
result = servercore . find_users ( uid , [ " * " ] )
2008-10-04 00:50:59 -05:00
return result
def forward ( self , * args , * * kw ) :
2008-10-07 05:15:34 -05:00
users = super ( crud . Find , self ) . forward ( * args , * * kw )
counter = users [ 0 ]
users = users [ 1 : ]
if counter == 0 :
print " No entries found for " , args [ 0 ]
return
elif counter == - 1 :
print " These results are truncated. "
print " Please refine your search and try again. "
for u in users :
for a in u . keys ( ) :
print " %s : %s " % ( a , u [ a ] )
2008-08-05 17:21:57 -05:00
api . register ( user_find )
2008-07-19 21:03:15 -05:00
2008-10-01 17:10:41 -05:00
2008-09-24 22:58:42 -05:00
class user_show ( crud . Get ) :
' Examine an existing user. '
2008-10-07 05:15:34 -05:00
def execute ( self , * args , * * kw ) :
uid = args [ 0 ]
result = servercore . get_user_by_uid ( uid , [ " * " ] )
return result
def forward ( self , * args , * * kw ) :
result = super ( crud . Get , self ) . forward ( * args , * * kw )
for a in result :
print a , " : " , result [ a ]
2008-09-24 22:58:42 -05:00
api . register ( user_show )