MDL-28627 remove buggy and obsolete KSES cleaning
[moodle.git] / admin / settings / security.php
blobde44e51835f22b2aa40c028d1f92286520f13ba7
1 <?php
3 if ($hassiteconfig) { // speedup for non-admins, add all caps used on this page
5 // "ip blocker" settingpage
6 $temp = new admin_settingpage('ipblocker', get_string('ipblocker', 'admin'));
7 $temp->add(new admin_setting_configcheckbox('allowbeforeblock', get_string('allowbeforeblock', 'admin'), get_string('allowbeforeblockdesc', 'admin'), 0));
8 $temp->add(new admin_setting_configiplist('allowedip', get_string('allowediplist', 'admin'),
9 get_string('ipblockersyntax', 'admin'), ''));
10 $temp->add(new admin_setting_configiplist('blockedip', get_string('blockediplist', 'admin'),
11 get_string('ipblockersyntax', 'admin'), ''));
12 $ADMIN->add('security', $temp);
14 // "sitepolicies" settingpage
15 $temp = new admin_settingpage('sitepolicies', get_string('sitepolicies', 'admin'));
16 $temp->add(new admin_setting_configcheckbox('protectusernames', get_string('protectusernames', 'admin'), get_string('configprotectusernames', 'admin'), 1));
17 $temp->add(new admin_setting_configcheckbox('forcelogin', get_string('forcelogin', 'admin'), get_string('configforcelogin', 'admin'), 0));
18 $temp->add(new admin_setting_configcheckbox('forceloginforprofiles', get_string('forceloginforprofiles', 'admin'), get_string('configforceloginforprofiles', 'admin'), 1));
19 $temp->add(new admin_setting_configcheckbox('opentogoogle', get_string('opentogoogle', 'admin'), get_string('configopentogoogle', 'admin'), 0));
20 $temp->add(new admin_setting_pickroles('profileroles',
21 get_string('profileroles','admin'),
22 get_string('configprofileroles', 'admin'),
23 array('student', 'teacher', 'editingteacher')));
25 $max_upload_choices = get_max_upload_sizes();
26 // maxbytes set to 0 will allow the maximum server limit for uploads
27 $max_upload_choices[0] = get_string('serverlimit', 'admin');
28 $temp->add(new admin_setting_configselect('maxbytes', get_string('maxbytes', 'admin'), get_string('configmaxbytes', 'admin'), 0, $max_upload_choices));
29 // 100MB
30 $defaultuserquota = 104857600;
31 $params = new stdClass();
32 $params->bytes = $defaultuserquota;
33 $params->displaysize = display_size($defaultuserquota);
34 $temp->add(new admin_setting_configtext('userquota', get_string('userquota', 'admin'), get_string('configuserquota', 'admin', $params), $defaultuserquota));
36 $temp->add(new admin_setting_configcheckbox('allowobjectembed', get_string('allowobjectembed', 'admin'), get_string('configallowobjectembed', 'admin'), 0));
37 $temp->add(new admin_setting_configcheckbox('enabletrusttext', get_string('enabletrusttext', 'admin'), get_string('configenabletrusttext', 'admin'), 0));
38 $temp->add(new admin_setting_configselect('maxeditingtime', get_string('maxeditingtime','admin'), get_string('configmaxeditingtime','admin'), 1800,
39 array(60 => get_string('numminutes', '', 1),
40 300 => get_string('numminutes', '', 5),
41 900 => get_string('numminutes', '', 15),
42 1800 => get_string('numminutes', '', 30),
43 2700 => get_string('numminutes', '', 45),
44 3600 => get_string('numminutes', '', 60))));
45 $temp->add(new admin_setting_configselect('fullnamedisplay', get_string('fullnamedisplay', 'admin'), get_string('configfullnamedisplay', 'admin'),
46 'language', array('language' => get_string('language'),
47 'firstname lastname' => get_string('firstname').' + '.get_string('lastname'),
48 'lastname firstname' => get_string('lastname').' + '.get_string('firstname'),
49 'firstname' => get_string('firstname'))));
50 $temp->add(new admin_setting_configcheckbox('extendedusernamechars', get_string('extendedusernamechars', 'admin'), get_string('configextendedusernamechars', 'admin'), 0));
51 $temp->add(new admin_setting_configtext('sitepolicy', get_string('sitepolicy', 'admin'), get_string('sitepolicy_help', 'admin'), '', PARAM_RAW));
52 $temp->add(new admin_setting_configtext('sitepolicyguest', get_string('sitepolicyguest', 'admin'), get_string('sitepolicyguest_help', 'admin'), (isset($CFG->sitepolicy) ? $CFG->sitepolicy : ''), PARAM_RAW));
53 $temp->add(new admin_setting_configcheckbox('extendedusernamechars', get_string('extendedusernamechars', 'admin'), get_string('configextendedusernamechars', 'admin'), 0));
54 $temp->add(new admin_setting_configcheckbox('keeptagnamecase', get_string('keeptagnamecase','admin'),get_string('configkeeptagnamecase', 'admin'),'1'));
56 $temp->add(new admin_setting_configcheckbox('profilesforenrolledusersonly', get_string('profilesforenrolledusersonly','admin'),get_string('configprofilesforenrolledusersonly', 'admin'),'1'));
58 $temp->add(new admin_setting_configcheckbox('cronclionly', get_string('cronclionly', 'admin'), get_string('configcronclionly', 'admin'), 0));
59 $temp->add(new admin_setting_configpasswordunmask('cronremotepassword', get_string('cronremotepassword', 'admin'), get_string('configcronremotepassword', 'admin'), ''));
61 $temp->add(new admin_setting_configcheckbox('passwordpolicy', get_string('passwordpolicy', 'admin'), get_string('configpasswordpolicy', 'admin'), 1));
62 $temp->add(new admin_setting_configtext('minpasswordlength', get_string('minpasswordlength', 'admin'), get_string('configminpasswordlength', 'admin'), 8, PARAM_INT));
63 $temp->add(new admin_setting_configtext('minpassworddigits', get_string('minpassworddigits', 'admin'), get_string('configminpassworddigits', 'admin'), 1, PARAM_INT));
64 $temp->add(new admin_setting_configtext('minpasswordlower', get_string('minpasswordlower', 'admin'), get_string('configminpasswordlower', 'admin'), 1, PARAM_INT));
65 $temp->add(new admin_setting_configtext('minpasswordupper', get_string('minpasswordupper', 'admin'), get_string('configminpasswordupper', 'admin'), 1, PARAM_INT));
66 $temp->add(new admin_setting_configtext('minpasswordnonalphanum', get_string('minpasswordnonalphanum', 'admin'), get_string('configminpasswordnonalphanum', 'admin'), 1, PARAM_INT));
67 $temp->add(new admin_setting_configtext('maxconsecutiveidentchars', get_string('maxconsecutiveidentchars', 'admin'), get_string('configmaxconsecutiveidentchars', 'admin'), 0, PARAM_INT));
68 $temp->add(new admin_setting_configcheckbox('groupenrolmentkeypolicy', get_string('groupenrolmentkeypolicy', 'admin'), get_string('groupenrolmentkeypolicy_desc', 'admin'), 1));
69 $temp->add(new admin_setting_configcheckbox('disableuserimages', get_string('disableuserimages', 'admin'), get_string('configdisableuserimages', 'admin'), 0));
70 $temp->add(new admin_setting_configcheckbox('emailchangeconfirmation', get_string('emailchangeconfirmation', 'admin'), get_string('configemailchangeconfirmation', 'admin'), 1));
71 $temp->add(new admin_setting_configselect('rememberusername', get_string('rememberusername','admin'), get_string('rememberusername_desc','admin'), 2, array(1=>get_string('yes'), 0=>get_string('no'), 2=>get_string('optional'))));
72 $temp->add(new admin_setting_configcheckbox('strictformsrequired', get_string('strictformsrequired', 'admin'), get_string('configstrictformsrequired', 'admin'), 0));
73 $ADMIN->add('security', $temp);
78 // "httpsecurity" settingpage
79 $temp = new admin_settingpage('httpsecurity', get_string('httpsecurity', 'admin'));
80 $temp->add(new admin_setting_configcheckbox('loginhttps', get_string('loginhttps', 'admin'), get_string('configloginhttps', 'admin'), 0));
81 $temp->add(new admin_setting_configcheckbox('cookiesecure', get_string('cookiesecure', 'admin'), get_string('configcookiesecure', 'admin'), 0));
82 $temp->add(new admin_setting_configcheckbox('cookiehttponly', get_string('cookiehttponly', 'admin'), get_string('configcookiehttponly', 'admin'), 0));
83 $temp->add(new admin_setting_configcheckbox('allowframembedding', get_string('allowframembedding', 'admin'), get_string('allowframembedding_help', 'admin'), 0));
84 $ADMIN->add('security', $temp);
87 // "modulesecurity" settingpage
88 $temp = new admin_settingpage('modulesecurity', get_string('modulesecurity', 'admin'));
89 $temp->add(new admin_setting_configselect('restrictmodulesfor', get_string('restrictmodulesfor', 'admin'), get_string('configrestrictmodulesfor', 'admin'), 'none', array('none' => get_string('nocourses'),
90 'all' => get_string('fulllistofcourses'),
91 'requested' => get_string('requestedcourses'))));
92 $temp->add(new admin_setting_configcheckbox('restrictbydefault', get_string('restrictbydefault', 'admin'), get_string('configrestrictbydefault', 'admin'), 0));
93 $temp->add(new admin_setting_configmultiselect_modules('defaultallowedmodules',
94 get_string('defaultallowedmodules', 'admin'),
95 get_string('configdefaultallowedmodules', 'admin')));
96 $ADMIN->add('security', $temp);
100 // "notifications" settingpage
101 $temp = new admin_settingpage('notifications', get_string('notifications', 'admin'));
102 $temp->add(new admin_setting_configselect('displayloginfailures', get_string('displayloginfailures', 'admin'), get_string('configdisplayloginfailures', 'admin'), '', array('' => get_string('nobody'),
103 'admin' => get_string('administrators'),
104 'teacher' => get_string('administratorsandteachers'),
105 'everybody' => get_string('everybody'))));
106 $temp->add(new admin_setting_users_with_capability('notifyloginfailures', get_string('notifyloginfailures', 'admin'), get_string('confignotifyloginfailures', 'admin'), array(), 'moodle/site:config'));
107 $options = array();
108 for ($i = 1; $i <= 100; $i++) {
109 $options[$i] = $i;
111 $temp->add(new admin_setting_configselect('notifyloginthreshold', get_string('notifyloginthreshold', 'admin'), get_string('confignotifyloginthreshold', 'admin'), '10', $options));
112 $ADMIN->add('security', $temp);
119 // "antivirus" settingpage
120 $temp = new admin_settingpage('antivirus', get_string('antivirus', 'admin'));
121 $temp->add(new admin_setting_configcheckbox('runclamonupload', get_string('runclamavonupload', 'admin'), get_string('configrunclamavonupload', 'admin'), 0));
122 $temp->add(new admin_setting_configexecutable('pathtoclam', get_string('pathtoclam', 'admin'), get_string('configpathtoclam', 'admin'), ''));
123 $temp->add(new admin_setting_configdirectory('quarantinedir', get_string('quarantinedir', 'admin'), get_string('configquarantinedir', 'admin'), ''));
124 $temp->add(new admin_setting_configselect('clamfailureonupload', get_string('clamfailureonupload', 'admin'), get_string('configclamfailureonupload', 'admin'), 'donothing', array('donothing' => get_string('configclamdonothing', 'admin'),
125 'actlikevirus' => get_string('configclamactlikevirus', 'admin'))));
126 $ADMIN->add('security', $temp);
128 } // end of speedup