aboutsummaryrefslogtreecommitdiff
path: root/actions/admin
diff options
context:
space:
mode:
authormarcus <marcus@36083f99-b078-4883-b0ff-0f9b5a30f544>2008-06-26 16:30:32 +0000
committermarcus <marcus@36083f99-b078-4883-b0ff-0f9b5a30f544>2008-06-26 16:30:32 +0000
commitb2c8624c1069829f815ebfcbaa18d06a27dde34e (patch)
tree656ed5d5c6ecf2acdfd2412a6e3e5135c4c25cc6 /actions/admin
parent31c5b57b92b2b2442527cc601eab113e047b0e93 (diff)
downloadelgg-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.php42
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