diff options
Diffstat (limited to 'actions')
-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 |