user_bulk_forcepasswordchange.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. /**
  3. * script for bulk user force password change
  4. */
  5. require_once('../../config.php');
  6. require_once('lib.php');
  7. require_once($CFG->libdir.'/adminlib.php');
  8. $confirm = optional_param('confirm', 0, PARAM_BOOL);
  9. require_login();
  10. admin_externalpage_setup('userbulk');
  11. require_capability('moodle/user:update', context_system::instance());
  12. $return = $CFG->wwwroot.'/'.$CFG->admin.'/user/user_bulk.php';
  13. if (empty($SESSION->bulk_users)) {
  14. redirect($return);
  15. }
  16. echo $OUTPUT->header();
  17. if ($confirm and confirm_sesskey()) {
  18. // only force password change if user may actually change the password
  19. $authsavailable = get_enabled_auth_plugins();
  20. $changeable = array();
  21. foreach($authsavailable as $authplugin) {
  22. if (!$auth = get_auth_plugin($authplugin)) {
  23. continue;
  24. }
  25. if ($auth->is_internal() and $auth->can_change_password()) {
  26. $changeable[$authplugin] = true;
  27. }
  28. }
  29. $parts = array_chunk($SESSION->bulk_users, 300);
  30. foreach ($parts as $users) {
  31. list($in, $params) = $DB->get_in_or_equal($users);
  32. $rs = $DB->get_recordset_select('user', "id $in", $params);
  33. foreach ($rs as $user) {
  34. if (!empty($changeable[$user->auth])) {
  35. set_user_preference('auth_forcepasswordchange', 1, $user->id);
  36. unset($SESSION->bulk_users[$user->id]);
  37. } else {
  38. echo $OUTPUT->notification(get_string('forcepasswordchangenot', '', fullname($user, true)));
  39. }
  40. }
  41. $rs->close();
  42. }
  43. echo $OUTPUT->notification(get_string('changessaved'), 'notifysuccess');
  44. echo $OUTPUT->continue_button($return);
  45. } else {
  46. list($in, $params) = $DB->get_in_or_equal($SESSION->bulk_users);
  47. $userlist = $DB->get_records_select_menu('user', "id $in", $params, 'fullname', 'id,'.$DB->sql_fullname().' AS fullname', 0, MAX_BULK_USERS);
  48. $usernames = implode(', ', $userlist);
  49. if (count($SESSION->bulk_users) > MAX_BULK_USERS) {
  50. $usernames .= ', ...';
  51. }
  52. echo $OUTPUT->heading(get_string('confirmation', 'admin'));
  53. $formcontinue = new single_button(new moodle_url('/admin/user/user_bulk_forcepasswordchange.php', array('confirm' => 1)), get_string('yes'));
  54. $formcancel = new single_button(new moodle_url('/admin/user/user_bulk.php'), get_string('no'), 'get');
  55. echo $OUTPUT->confirm(get_string('forcepasswordchangecheckfull', '', $usernames), $formcontinue, $formcancel);
  56. }
  57. echo $OUTPUT->footer();