PageRenderTime 47ms CodeModel.GetById 23ms RepoModel.GetById 1ms app.codeStats 0ms

/admin/settings/users.php

https://github.com/nadavkav/Moodle-RTL--Shenkar-Translation-Team-
PHP | 181 lines | 144 code | 28 blank | 9 comment | 23 complexity | 982d5b64a40c8031b81fc1ed72211057 MD5 | raw file
  1. <?php // $Id: users.php,v 1.26.2.18 2010/04/10 15:11:49 iarenaza Exp $
  2. // This file defines settingpages and externalpages under the "users" category
  3. $ADMIN->add('users', new admin_category('authsettings', get_string('authentication','admin')));
  4. $ADMIN->add('users', new admin_category('accounts', get_string('accounts', 'admin')));
  5. $ADMIN->add('users', new admin_category('roles', get_string('permissions', 'role')));
  6. if ($hassiteconfig
  7. or has_capability('moodle/site:uploadusers', $systemcontext)
  8. or has_capability('moodle/user:create', $systemcontext)
  9. or has_capability('moodle/user:update', $systemcontext)
  10. or has_capability('moodle/user:delete', $systemcontext)
  11. or has_capability('moodle/role:manage', $systemcontext)
  12. or has_capability('moodle/role:assign', $systemcontext)) { // speedup for non-admins, add all caps used on this page
  13. $temp = new admin_settingpage('manageauths', get_string('authsettings', 'admin'));
  14. $temp->add(new admin_setting_manageauths());
  15. $temp->add(new admin_setting_heading('manageauthscommonheading', get_string('commonsettings', 'admin'), ''));
  16. $temp->add(new admin_setting_special_registerauth());
  17. $temp->add(new admin_setting_configselect('guestloginbutton', get_string('guestloginbutton', 'auth'),
  18. get_string('showguestlogin', 'auth'), '1', array('0'=>get_string('hide'), '1'=>get_string('show'))));
  19. $temp->add(new admin_setting_configtext('alternateloginurl', get_string('alternateloginurl', 'auth'),
  20. get_string('alternatelogin', 'auth', htmlspecialchars($CFG->wwwroot.'/login/index.php')), ''));
  21. $temp->add(new admin_setting_configtext('forgottenpasswordurl', get_string('forgottenpasswordurl', 'auth'),
  22. get_string('forgottenpassword', 'auth'), ''));
  23. $temp->add(new admin_setting_confightmltextarea('auth_instructions', get_string('instructions', 'auth'),
  24. get_string('authinstructions', 'auth'), ''));
  25. $temp->add(new admin_setting_configtext('allowemailaddresses', get_string('allowemailaddresses', 'admin'), get_string('configallowemailaddresses', 'admin'), '', PARAM_NOTAGS));
  26. $temp->add(new admin_setting_configtext('denyemailaddresses', get_string('denyemailaddresses', 'admin'), get_string('configdenyemailaddresses', 'admin'), '', PARAM_NOTAGS));
  27. $temp->add(new admin_setting_configcheckbox('verifychangedemail', get_string('verifychangedemail', 'admin'), get_string('configverifychangedemail', 'admin'), 1));
  28. $temp->add(new admin_setting_configtext('recaptchapublickey', get_string('recaptchapublickey', 'admin'), get_string('configrecaptchapublickey', 'admin'), '', PARAM_NOTAGS));
  29. $temp->add(new admin_setting_configtext('recaptchaprivatekey', get_string('recaptchaprivatekey', 'admin'), get_string('configrecaptchaprivatekey', 'admin'), '', PARAM_NOTAGS));
  30. $ADMIN->add('authsettings', $temp);
  31. if ($auths = get_list_of_plugins('auth')) {
  32. $authsenabled = get_enabled_auth_plugins();
  33. $authbyname = array();
  34. foreach ($auths as $auth) {
  35. $strauthname = auth_get_plugin_title($auth);
  36. $authbyname[$strauthname] = $auth;
  37. }
  38. ksort($authbyname);
  39. foreach ($authbyname as $strauthname=>$authname) {
  40. if (file_exists($CFG->dirroot.'/auth/'.$authname.'/settings.php')) {
  41. // do not show disabled auths in tree, keep only settings link on manage page
  42. $settings = new admin_settingpage('authsetting'.$authname, $strauthname, 'moodle/site:config', !in_array($authname, $authsenabled));
  43. if ($ADMIN->fulltree) {
  44. include($CFG->dirroot.'/auth/'.$authname.'/settings.php');
  45. }
  46. // TODO: finish implementation of common settings - locking, etc.
  47. $ADMIN->add('authsettings', $settings);
  48. } else {
  49. $ADMIN->add('authsettings', new admin_externalpage('authsetting'.$authname, $strauthname, "$CFG->wwwroot/$CFG->admin/auth_config.php?auth=$authname", 'moodle/site:config', !in_array($authname, $authsenabled)));
  50. }
  51. }
  52. }
  53. if(empty($CFG->loginhttps)) {
  54. $securewwwroot = $CFG->wwwroot;
  55. } else {
  56. $securewwwroot = str_replace('http:','https:',$CFG->wwwroot);
  57. }
  58. // stuff under the "accounts" subcategory
  59. $ADMIN->add('accounts', new admin_externalpage('editusers', get_string('userlist','admin'), "$CFG->wwwroot/$CFG->admin/user.php", array('moodle/user:update', 'moodle/user:delete')));
  60. $ADMIN->add('accounts', new admin_externalpage('userbulk', get_string('userbulk','admin'), "$CFG->wwwroot/$CFG->admin/user/user_bulk.php", array('moodle/user:update', 'moodle/user:delete')));
  61. $ADMIN->add('accounts', new admin_externalpage('addnewuser', get_string('addnewuser'), "$securewwwroot/user/editadvanced.php?id=-1", 'moodle/user:create'));
  62. $ADMIN->add('accounts', new admin_externalpage('uploadusers', get_string('uploadusers'), "$CFG->wwwroot/$CFG->admin/uploaduser.php", 'moodle/site:uploadusers'));
  63. $ADMIN->add('accounts', new admin_externalpage('uploadpictures', get_string('uploadpictures','admin'), "$CFG->wwwroot/$CFG->admin/uploadpicture.php", 'moodle/site:uploadusers'));
  64. $ADMIN->add('accounts', new admin_externalpage('profilefields', get_string('profilefields','admin'), "$CFG->wwwroot/user/profile/index.php", 'moodle/site:config'));
  65. // stuff under the "roles" subcategory
  66. $ADMIN->add('roles', new admin_externalpage('defineroles', get_string('defineroles', 'role'), "$CFG->wwwroot/$CFG->admin/roles/manage.php", 'moodle/role:manage'));
  67. $ADMIN->add('roles', new admin_externalpage('assignroles', get_string('assignglobalroles', 'role'), "$CFG->wwwroot/$CFG->admin/roles/assign.php?contextid=".$systemcontext->id, 'moodle/role:assign'));
  68. // "userpolicies" settingpage
  69. $temp = new admin_settingpage('userpolicies', get_string('userpolicies', 'admin'));
  70. if ($ADMIN->fulltree) {
  71. if (!empty($CFG->rolesactive)) {
  72. $context = get_context_instance(CONTEXT_SYSTEM);
  73. if (!$guestrole = get_guest_role()) {
  74. $guestrole->id = 0;
  75. }
  76. if ($studentroles = get_roles_with_capability('moodle/legacy:student', CAP_ALLOW)) {
  77. $studentrole = array_shift($studentroles); /// Take the first one
  78. } else {
  79. $studentrole->id = 0;
  80. }
  81. if ($userroles = get_roles_with_capability('moodle/legacy:user', CAP_ALLOW)) {
  82. $userrole = array_shift($userroles); /// Take the first one
  83. } else {
  84. $userrole->id = 0;
  85. }
  86. if (empty($CFG->creatornewroleid)) {
  87. if ($teacherroles = get_roles_with_capability('moodle/legacy:editingteacher', CAP_ALLOW, $context)) {
  88. $teachereditrole = array_shift($teacherroles);
  89. set_config('creatornewroleid', $teachereditrole->id);
  90. } else {
  91. set_config('creatornewroleid', 0);
  92. }
  93. }
  94. if (!$guestroles = get_roles_with_capability('moodle/legacy:guest', CAP_ALLOW)) {
  95. $guestroles = array();
  96. $defaultguestid = null;
  97. } else {
  98. $defaultguestid = reset($guestroles);
  99. $defaultguestid = $defaultguestid->id;
  100. }
  101. // we must not use assignable roles here:
  102. // 1/ unsetting roles as assignable for admin might bork the settings!
  103. // 2/ default user role should not be assignable anyway
  104. $allroles = array();
  105. $nonguestroles = array();
  106. if ($roles = get_all_roles()) {
  107. foreach ($roles as $role) {
  108. $rolename = strip_tags(format_string($role->name, true));
  109. $allroles[$role->id] = $rolename;
  110. if (!isset($guestroles[$role->id])) {
  111. $nonguestroles[$role->id] = $rolename;
  112. }
  113. }
  114. }
  115. $temp->add(new admin_setting_configselect('notloggedinroleid', get_string('notloggedinroleid', 'admin'),
  116. get_string('confignotloggedinroleid', 'admin'), $defaultguestid, $allroles ));
  117. $temp->add(new admin_setting_configselect('guestroleid', get_string('guestroleid', 'admin'),
  118. get_string('configguestroleid', 'admin'), $defaultguestid, $allroles));
  119. $temp->add(new admin_setting_configselect('defaultuserroleid', get_string('defaultuserroleid', 'admin'),
  120. get_string('configdefaultuserroleid', 'admin'), $userrole->id, $nonguestroles)); // guest role here breaks a lot of stuff
  121. }
  122. $temp->add(new admin_setting_configcheckbox('nodefaultuserrolelists', get_string('nodefaultuserrolelists', 'admin'), get_string('confignodefaultuserrolelists', 'admin'), 0));
  123. if (!empty($CFG->rolesactive)) {
  124. $temp->add(new admin_setting_configselect('defaultcourseroleid', get_string('defaultcourseroleid', 'admin'),
  125. get_string('configdefaultcourseroleid', 'admin'), $studentrole->id, $allroles));
  126. $temp->add(new admin_setting_configselect('creatornewroleid', get_string('creatornewroleid', 'admin'),
  127. get_string('configcreatornewroleid', 'admin'), $CFG->creatornewroleid, $allroles));
  128. }
  129. $temp->add(new admin_setting_configcheckbox('autologinguests', get_string('autologinguests', 'admin'), get_string('configautologinguests', 'admin'), 0));
  130. if (!empty($CFG->rolesactive)) {
  131. $temp->add(new admin_setting_configmultiselect('nonmetacoursesyncroleids', get_string('nonmetacoursesyncroleids', 'admin'),
  132. get_string('confignonmetacoursesyncroleids', 'admin'), array(), $allroles));
  133. }
  134. $temp->add(new admin_setting_configmultiselect('hiddenuserfields', get_string('hiddenuserfields', 'admin'),
  135. get_string('confighiddenuserfields', 'admin'), array(),
  136. array('description' => get_string('description'),
  137. 'city' => get_string('city'),
  138. 'country' => get_string('country'),
  139. 'webpage' => get_string('webpage'),
  140. 'icqnumber' => get_string('icqnumber'),
  141. 'skypeid' => get_string('skypeid'),
  142. 'yahooid' => get_string('yahooid'),
  143. 'aimid' => get_string('aimid'),
  144. 'msnid' => get_string('msnid'),
  145. 'firstaccess' => get_string('firstaccess'),
  146. 'lastaccess' => get_string('lastaccess'),
  147. 'mycourses' => get_string('mycourses'),
  148. 'groups' => get_string('groups'))));
  149. }
  150. $temp->add(new admin_setting_configcheckbox('allowuserswitchrolestheycantassign', get_string('allowuserswitchrolestheycantassign', 'admin'), get_string('configallowuserswitchrolestheycantassign', 'admin'), 0));
  151. $ADMIN->add('roles', $temp);
  152. } // end of speedup
  153. ?>