From 010fb65bfd766acf7b728abfba67bc55993b5ddc Mon Sep 17 00:00:00 2001 From: Rob Crittenden Date: Fri, 2 Nov 2007 17:41:24 -0400 Subject: define Self-Service as editting your own record. This has the side-effect of removing the realm from Loggin in as. This can be changed by using user_name instead of display_name in master.kid. --- ipa-server/ipa-gui/ipagui/proxyprovider.py | 3 ++- ipa-server/ipa-gui/ipagui/subcontrollers/user.py | 13 +++++++++++-- ipa-server/ipa-gui/ipagui/templates/master.kid | 2 +- 3 files changed, 14 insertions(+), 4 deletions(-) diff --git a/ipa-server/ipa-gui/ipagui/proxyprovider.py b/ipa-server/ipa-gui/ipagui/proxyprovider.py index 22aff0c7..e8ef6983 100644 --- a/ipa-server/ipa-gui/ipagui/proxyprovider.py +++ b/ipa-server/ipa-gui/ipagui/proxyprovider.py @@ -12,7 +12,8 @@ class IPA_User(object): def __init__(self, user_name): self.user_name = user_name - self.display_name = user_name + (principal, realm) = user_name.split('@') + self.display_name = principal self.permissions = None self.groups = None return diff --git a/ipa-server/ipa-gui/ipagui/subcontrollers/user.py b/ipa-server/ipa-gui/ipagui/subcontrollers/user.py index 1ff86055..d328052b 100644 --- a/ipa-server/ipa-gui/ipagui/subcontrollers/user.py +++ b/ipa-server/ipa-gui/ipagui/subcontrollers/user.py @@ -241,7 +241,7 @@ class UserController(IPAController): @expose("ipagui.templates.useredit") @identity.require(identity.not_anonymous()) - def edit(self, uid, tg_errors=None): + def edit(self, uid=None, principal=None, tg_errors=None): """Displays the edit user form""" if tg_errors: turbogears.flash("There were validation errors.
" + @@ -250,7 +250,14 @@ class UserController(IPAController): client = self.get_ipaclient() try: - user = client.get_user_by_uid(uid, user_fields) + if uid is not None: + user = client.get_user_by_uid(uid, user_fields) + elif principal is not None: + principal = principal + "@" + ipa.config.config.default_realm + user = client.get_user_by_principal(principal, user_fields) + else: + turbogears.flash("User edit failed: No uid or principal provided") + raise turbogears.redirect('/') user_dict = user.toDict() # Edit shouldn't fill in the password field. if user_dict.has_key('userpassword'): @@ -291,6 +298,8 @@ class UserController(IPAController): return dict(form=user_edit_form, user=user_dict, user_groups=user_groups_dicts) except ipaerror.IPAError, e: + if uid is None: + uid = principal turbogears.flash("User edit failed: " + str(e)) raise turbogears.redirect('/user/show', uid=uid) diff --git a/ipa-server/ipa-gui/ipagui/templates/master.kid b/ipa-server/ipa-gui/ipagui/templates/master.kid index 990a989e..fd527a27 100644 --- a/ipa-server/ipa-gui/ipagui/templates/master.kid +++ b/ipa-server/ipa-gui/ipagui/templates/master.kid @@ -79,7 +79,7 @@