diff options
author | Tim Almdal <tnalmdal@shaw.ca> | 2009-04-03 17:33:07 +0000 |
---|---|---|
committer | Tim Almdal <tnalmdal@shaw.ca> | 2009-04-03 17:33:07 +0000 |
commit | 9ed0dd51bf6c4d43195f56ca8e88db04b5fc5df4 (patch) | |
tree | e71a6089cffa967e9859967a2b903bcfbe7d64e9 /modules/user/controllers/users.php | |
parent | d35a0cdb610fc646c329b9622fcb05a4948c3ba2 (diff) |
Fix for ticket #201.
1) create common update function so processing consistent between the
user edit and admin edit.
2) created common private helper function to build the user edit form
the same way.
So a user can now change their user name if the new one doesn't exist.
Diffstat (limited to 'modules/user/controllers/users.php')
-rw-r--r-- | modules/user/controllers/users.php | 21 |
1 files changed, 6 insertions, 15 deletions
diff --git a/modules/user/controllers/users.php b/modules/user/controllers/users.php index eb49b5b1..55970ded 100644 --- a/modules/user/controllers/users.php +++ b/modules/user/controllers/users.php @@ -26,21 +26,12 @@ class Users_Controller extends REST_Controller { } $form = user::get_edit_form($user); - $form->edit_user->password->rules("-required"); - if ($form->validate()) { - // @todo: allow the user to change their name - $user->full_name = $form->edit_user->full_name->value; - if ($form->edit_user->password->value) { - $user->password = $form->edit_user->password->value; - } - $user->email = $form->edit_user->email->value; - $user->url = $form->edit_user->url->value; - if ($form->edit_user->locale) { - $desired_locale = $form->edit_user->locale->value; - $user->locale = $desired_locale == "none" ? null : $desired_locale; - } - $user->save(); - + $valid = $form->validate(); + if ($valid) { + $valid = user::update($user, $form); + } + + if ($valid) { print json_encode( array("result" => "success", "resource" => url::site("users/{$user->id}"))); |