/admin/settings/security.php

https://github.com/jarednipper/HSU-common-code · PHP · 123 lines · 92 code · 25 blank · 6 comment · 3 complexity · 234c149a1ddb7f41e04013ca39a82d90 MD5 · raw file

  1. <?php // $Id: security.php,v 1.21.2.15 2010/03/19 07:58:52 skodak Exp $
  2. if ($hassiteconfig) { // speedup for non-admins, add all caps used on this page
  3. // "sitepolicies" settingpage
  4. $temp = new admin_settingpage('sitepolicies', get_string('sitepolicies', 'admin'));
  5. $temp->add(new admin_setting_configcheckbox('protectusernames', get_string('protectusernames', 'admin'), get_string('configprotectusernames', 'admin'), 1));
  6. $temp->add(new admin_setting_configcheckbox('forcelogin', get_string('forcelogin', 'admin'), get_string('configforcelogin', 'admin'), 0));
  7. $temp->add(new admin_setting_configcheckbox('forceloginforprofiles', get_string('forceloginforprofiles', 'admin'), get_string('configforceloginforprofiles', 'admin'), 1));
  8. $temp->add(new admin_setting_configcheckbox('opentogoogle', get_string('opentogoogle', 'admin'), get_string('configopentogoogle', 'admin'), 0));
  9. $max_upload_choices = get_max_upload_sizes();
  10. // maxbytes set to 0 will allow the maxium server lmit for uploads
  11. $max_upload_choices[0] = get_string('serverlimit', 'admin');
  12. $temp->add(new admin_setting_configselect('maxbytes', get_string('maxbytes', 'admin'), get_string('configmaxbytes', 'admin'), 0, $max_upload_choices));
  13. $temp->add(new admin_setting_configcheckbox('messaging', get_string('messaging', 'admin'), get_string('configmessaging','admin'), 1));
  14. $temp->add(new admin_setting_configcheckbox('allowobjectembed', get_string('allowobjectembed', 'admin'), get_string('configallowobjectembed', 'admin'), 0));
  15. $temp->add(new admin_setting_configcheckbox('enabletrusttext', get_string('enabletrusttext', 'admin'), get_string('configenabletrusttext', 'admin'), 0));
  16. $temp->add(new admin_setting_configselect('maxeditingtime', get_string('maxeditingtime','admin'), get_string('configmaxeditingtime','admin'), 1800,
  17. array(60 => get_string('numminutes', '', 1),
  18. 300 => get_string('numminutes', '', 5),
  19. 900 => get_string('numminutes', '', 15),
  20. 1800 => get_string('numminutes', '', 30),
  21. 2700 => get_string('numminutes', '', 45),
  22. 3600 => get_string('numminutes', '', 60))));
  23. $temp->add(new admin_setting_configselect('fullnamedisplay', get_string('fullnamedisplay', 'admin'), get_string('configfullnamedisplay', 'admin'),
  24. 'language', array('language' => get_string('language'),
  25. 'firstname lastname' => get_string('firstname').' + '.get_string('lastname'),
  26. 'lastname firstname' => get_string('lastname').' + '.get_string('firstname'),
  27. 'firstname' => get_string('firstname'))));
  28. $temp->add(new admin_setting_configcheckbox('extendedusernamechars', get_string('extendedusernamechars', 'admin'), get_string('configextendedusernamechars', 'admin'), 0));
  29. $temp->add(new admin_setting_configtext('sitepolicy', get_string('sitepolicy', 'admin'), get_string('configsitepolicy', 'admin'), '', PARAM_RAW));
  30. $temp->add(new admin_setting_configselect('bloglevel', get_string('bloglevel', 'admin'), get_string('configbloglevel', 'admin'), 4, array(5 => get_string('worldblogs','blog'),
  31. 4 => get_string('siteblogs','blog'),
  32. 3 => get_string('courseblogs','blog'),
  33. 2 => get_string('groupblogs','blog'),
  34. 1 => get_string('personalblogs','blog'),
  35. 0 => get_string('disableblogs','blog'))));
  36. $temp->add(new admin_setting_configcheckbox('usetags', get_string('usetags','admin'),get_string('configusetags', 'admin'),'1'));
  37. $temp->add(new admin_setting_configcheckbox('keeptagnamecase', get_string('keeptagnamecase','admin'),get_string('configkeeptagnamecase', 'admin'),'1'));
  38. $temp->add(new admin_setting_configcheckbox('profilesforenrolledusersonly', get_string('profilesforenrolledusersonly','admin'),get_string('configprofilesforenrolledusersonly', 'admin'),'1'));
  39. $temp->add(new admin_setting_configcheckbox('cronclionly', get_string('cronclionly', 'admin'), get_string('configcronclionly', 'admin'), 0));
  40. $temp->add(new admin_setting_configpasswordunmask('cronremotepassword', get_string('cronremotepassword', 'admin'), get_string('configcronremotepassword', 'admin'), ''));
  41. $temp->add(new admin_setting_configcheckbox('passwordpolicy', get_string('passwordpolicy', 'admin'), get_string('configpasswordpolicy', 'admin'), 1));
  42. $temp->add(new admin_setting_configtext('minpasswordlength', get_string('minpasswordlength', 'admin'), get_string('configminpasswordlength', 'admin'), 8, PARAM_INT));
  43. $temp->add(new admin_setting_configtext('minpassworddigits', get_string('minpassworddigits', 'admin'), get_string('configminpassworddigits', 'admin'), 1, PARAM_INT));
  44. $temp->add(new admin_setting_configtext('minpasswordlower', get_string('minpasswordlower', 'admin'), get_string('configminpasswordlower', 'admin'), 1, PARAM_INT));
  45. $temp->add(new admin_setting_configtext('minpasswordupper', get_string('minpasswordupper', 'admin'), get_string('configminpasswordupper', 'admin'), 1, PARAM_INT));
  46. $temp->add(new admin_setting_configtext('minpasswordnonalphanum', get_string('minpasswordnonalphanum', 'admin'), get_string('configminpasswordnonalphanum', 'admin'), 1, PARAM_INT));
  47. $temp->add(new admin_setting_configcheckbox('disableuserimages', get_string('disableuserimages', 'admin'), get_string('configdisableuserimages', 'admin'), 0));
  48. $temp->add(new admin_setting_configcheckbox('emailchangeconfirmation', get_string('emailchangeconfirmation', 'admin'), get_string('configemailchangeconfirmation', 'admin'), 1));
  49. $temp->add(new admin_setting_configcheckbox('enablenotes', get_string('enablenotes', 'notes'), get_string('configenablenotes', 'notes'), 1));
  50. $ADMIN->add('security', $temp);
  51. // "httpsecurity" settingpage
  52. $temp = new admin_settingpage('httpsecurity', get_string('httpsecurity', 'admin'));
  53. $temp->add(new admin_setting_configcheckbox('loginhttps', get_string('loginhttps', 'admin'), get_string('configloginhttps', 'admin'), 0));
  54. $temp->add(new admin_setting_configcheckbox('cookiesecure', get_string('cookiesecure', 'admin'), get_string('configcookiesecure', 'admin'), 0));
  55. $temp->add(new admin_setting_configcheckbox('cookiehttponly', get_string('cookiehttponly', 'admin'), get_string('configcookiehttponly', 'admin'), 0));
  56. $temp->add(new admin_setting_configcheckbox('regenloginsession', get_string('regenloginsession', 'admin'), get_string('configregenloginsession', 'admin'), 1));
  57. $temp->add(new admin_setting_configtext('excludeoldflashclients', get_string('excludeoldflashclients', 'admin'), get_string('configexcludeoldflashclients', 'admin'), '10.0.12', PARAM_TEXT));
  58. $ADMIN->add('security', $temp);
  59. // "modulesecurity" settingpage
  60. $temp = new admin_settingpage('modulesecurity', get_string('modulesecurity', 'admin'));
  61. $temp->add(new admin_setting_configselect('restrictmodulesfor', get_string('restrictmodulesfor', 'admin'), get_string('configrestrictmodulesfor', 'admin'), 'none', array('none' => get_string('nocourses'),
  62. 'all' => get_string('fulllistofcourses'),
  63. 'requested' => get_string('requestedcourses'))));
  64. $temp->add(new admin_setting_configcheckbox('restrictbydefault', get_string('restrictbydefault', 'admin'), get_string('configrestrictbydefault', 'admin'), 0));
  65. if (!$options = get_records("modules")) {
  66. $options = array();
  67. }
  68. $options2 = array();
  69. foreach ($options as $option) {
  70. $options2[$option->id] = $option->name;
  71. }
  72. $temp->add(new admin_setting_configmultiselect('defaultallowedmodules', get_string('defaultallowedmodules', 'admin'), get_string('configdefaultallowedmodules', 'admin'), array(), $options2));
  73. $ADMIN->add('security', $temp);
  74. // "notifications" settingpage
  75. $temp = new admin_settingpage('notifications', get_string('notifications', 'admin'));
  76. $temp->add(new admin_setting_configselect('displayloginfailures', get_string('displayloginfailures', 'admin'), get_string('configdisplayloginfailures', 'admin'), '', array('' => get_string('nobody'),
  77. 'admin' => get_string('administrators'),
  78. 'teacher' => get_string('administratorsandteachers'),
  79. 'everybody' => get_string('everybody'))));
  80. $temp->add(new admin_setting_configselect('notifyloginfailures', get_string('notifyloginfailures', 'admin'), get_string('confignotifyloginfailures', 'admin'), '', array('' => get_string('nobody'),
  81. 'mainadmin' => get_string('administrator'),
  82. 'alladmins' => get_string('administratorsall'))));
  83. $options = array();
  84. for ($i = 1; $i <= 100; $i++) {
  85. $options[$i] = $i;
  86. }
  87. $temp->add(new admin_setting_configselect('notifyloginthreshold', get_string('notifyloginthreshold', 'admin'), get_string('confignotifyloginthreshold', 'admin'), '10', $options));
  88. $ADMIN->add('security', $temp);
  89. // "antivirus" settingpage
  90. $temp = new admin_settingpage('antivirus', get_string('antivirus', 'admin'));
  91. $temp->add(new admin_setting_configcheckbox('runclamonupload', get_string('runclamavonupload', 'admin'), get_string('configrunclamavonupload', 'admin'), 0));
  92. $temp->add(new admin_setting_configexecutable('pathtoclam', get_string('pathtoclam', 'admin'), get_string('configpathtoclam', 'admin'), ''));
  93. $temp->add(new admin_setting_configdirectory('quarantinedir', get_string('quarantinedir', 'admin'), get_string('configquarantinedir', 'admin'), ''));
  94. $temp->add(new admin_setting_configselect('clamfailureonupload', get_string('clamfailureonupload', 'admin'), get_string('configclamfailureonupload', 'admin'), 'donothing', array('donothing' => get_string('configclamdonothing', 'admin'),
  95. 'actlikevirus' => get_string('configclamactlikevirus', 'admin'))));
  96. $ADMIN->add('security', $temp);
  97. } // end of speedup
  98. ?>