summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRob Crittenden <rcritten@redhat.com>2008-10-15 09:58:29 -0400
committerRob Crittenden <rcritten@redhat.com>2008-10-15 09:58:29 -0400
commit789a248daa71d5d1377e0dc9f0cd3afe107d4f2a (patch)
tree9aeb50be721ff8187326f4cb8b620ef4dd9d9d9b
parente7937f294445d53396f7fb87d52eb4d4c9b97110 (diff)
downloadfreeipa-789a248daa71d5d1377e0dc9f0cd3afe107d4f2a.tar.gz
freeipa-789a248daa71d5d1377e0dc9f0cd3afe107d4f2a.tar.xz
freeipa-789a248daa71d5d1377e0dc9f0cd3afe107d4f2a.zip
Port user-mod to use ldap update() method
-rw-r--r--ipa_server/plugins/b_ldap.py15
-rw-r--r--ipalib/plugins/f_user.py38
2 files changed, 33 insertions, 20 deletions
diff --git a/ipa_server/plugins/b_ldap.py b/ipa_server/plugins/b_ldap.py
index 84f25245b..26a3495c3 100644
--- a/ipa_server/plugins/b_ldap.py
+++ b/ipa_server/plugins/b_ldap.py
@@ -48,8 +48,7 @@ class ldap(CrudBackend):
self.api.env.basedn,
)
- def find_entry_dn(self, key_attribute, primary_key, attributes=None,
- object_type=None):
+ def find_entry_dn(self, key_attribute, primary_key, object_type=None):
"""
Find an existing entry's dn from an attribute
"""
@@ -73,7 +72,7 @@ class ldap(CrudBackend):
search_base = "%s, %s" % (self.api.env.container_accounts, self.api.env.basedn)
- entry = servercore.get_sub_entry(search_base, filter, attributes)
+ entry = servercore.get_sub_entry(search_base, filter, ['dn', 'objectclass'])
return entry['dn']
@@ -95,6 +94,16 @@ class ldap(CrudBackend):
def retrieve(self, dn, attributes=None):
return servercore.get_entry_by_dn(dn, attributes)
+ def update(self, dn, **kw):
+ result = self.retrieve(dn, ["*"])
+
+ entry = ipaldap.Entry((dn, servercore.convert_scalar_values(result)))
+
+ for k in kw:
+ entry.setValues(k, kw[k])
+
+ return servercore.update_entry(entry.toDict())
+
def delete(self, dn):
return servercore.delete_entry(dn)
diff --git a/ipalib/plugins/f_user.py b/ipalib/plugins/f_user.py
index 79c457353..e95ee3b2f 100644
--- a/ipalib/plugins/f_user.py
+++ b/ipalib/plugins/f_user.py
@@ -205,27 +205,31 @@ api.register(user_del)
class user_mod(crud.Mod):
'Edit an existing user.'
- def execute(self, *args, **kw):
- uid=args[0]
+ def execute(self, uid, **kw):
+ """
+ Execute the user-mod operation.
- # Get the existing user entry
- result = servercore.get_sub_entry("cn=accounts," + servercore.basedn, "uid=%s" % uid, ["*"])
+ The dn should not be passed as a keyword argument as it is constructed
+ by this method.
- user = kw
- dn = result.get('dn')
- del result['dn']
- entry = ipaldap.Entry((dn, servercore.convert_scalar_values(result)))
+ Returns the entry
- for u in user:
- entry.setValues(u, user[u])
+ :param uid: The login name of the user to retrieve.
+ :param kw: Keyword arguments for the other LDAP attributes.
+ """
+ assert 'uid' not in kw
+ assert 'dn' not in kw
+ ldap = self.api.Backend.ldap
+ dn = ldap.find_entry_dn("uid", uid, "posixAccount")
+ return ldap.update(dn, **kw)
- result = servercore.update_entry(entry.toDict())
+ def output_for_cli(self, ret):
+ """
+ Output result of this command to command line interface.
+ """
+ if ret:
+ print "User updated"
- return result
- def forward(self, *args, **kw):
- result = super(crud.Mod, self).forward(*args, **kw)
- if result:
- print "User %s modified" % args[0]
api.register(user_mod)
@@ -269,7 +273,7 @@ class user_show(crud.Get):
:param kw: Not used.
"""
ldap = self.api.Backend.ldap
- dn = ldap.find_entry_dn("uid", uid, ["*"], "posixAccount")
+ dn = ldap.find_entry_dn("uid", uid, "posixAccount")
# FIXME: should kw contain the list of attributes?
return ldap.retrieve(dn)