diff options
author | marcus <marcus@36083f99-b078-4883-b0ff-0f9b5a30f544> | 2008-06-26 16:30:32 +0000 |
---|---|---|
committer | marcus <marcus@36083f99-b078-4883-b0ff-0f9b5a30f544> | 2008-06-26 16:30:32 +0000 |
commit | b2c8624c1069829f815ebfcbaa18d06a27dde34e (patch) | |
tree | 656ed5d5c6ecf2acdfd2412a6e3e5135c4c25cc6 /actions/admin | |
parent | 31c5b57b92b2b2442527cc601eab113e047b0e93 (diff) | |
download | elgg-b2c8624c1069829f815ebfcbaa18d06a27dde34e.tar.gz elgg-b2c8624c1069829f815ebfcbaa18d06a27dde34e.tar.bz2 |
Closes #16: Administration: Reset password functionality on user admin screen
http://trac.elgg.org/elgg/ticket/16
git-svn-id: https://code.elgg.org/elgg/trunk@1150 36083f99-b078-4883-b0ff-0f9b5a30f544
Diffstat (limited to 'actions/admin')
-rw-r--r-- | actions/admin/user/resetpassword.php | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/actions/admin/user/resetpassword.php b/actions/admin/user/resetpassword.php new file mode 100644 index 000000000..f58ae7fa8 --- /dev/null +++ b/actions/admin/user/resetpassword.php @@ -0,0 +1,42 @@ +<?php + /** + * Admin password reset. + * + * @package Elgg + * @subpackage Core + * @license http://www.gnu.org/licenses/old-licenses/gpl-2.0.html GNU Public License version 2 + * @author Marcus Povey + * @copyright Curverider Ltd 2008 + * @link http://elgg.org/ + */ + + require_once(dirname(dirname(dirname(dirname(__FILE__)))) . "/engine/start.php"); + global $CONFIG; + + // block non-admin users + admin_gatekeeper(); + + // Get the user + $guid = get_input('guid'); + $obj = get_entity($guid); + + if ( ($obj instanceof ElggUser) && ($obj->canEdit())) + { + $password = generate_random_cleartext_password(); + + $obj->password = generate_user_password($obj, $password); + + if ($obj->save()) + { + system_message(elgg_echo('admin:user:resetpassword:yes')); + + notify_user($obj->guid, $CONFIG->site->guid, elgg_echo('email:resetpassword:subject'), sprintf(elgg_echo('email:resetpassword:body'), $obj->username, $password), NULL, 'email'); + } else + system_message(elgg_echo('admin:user:resetpassword:no')); + } + else + system_message(elgg_echo('admin:user:resetpassword:no')); + + forward($_SERVER['HTTP_REFERER']); + exit; +?>
\ No newline at end of file |