mirror of
https://github.com/moodle/moodle.git
synced 2025-08-05 00:46:50 +02:00
Merge branch 'MDL-69632-master-adminserversettings' of git://github.com/mudrd8mz/moodle into master
This commit is contained in:
commit
aa69bc8e4e
1 changed files with 437 additions and 328 deletions
|
@ -1,33 +1,57 @@
|
||||||
<?php
|
<?php
|
||||||
|
// This file is part of Moodle - https://moodle.org/
|
||||||
|
//
|
||||||
|
// Moodle is free software: you can redistribute it and/or modify
|
||||||
|
// it under the terms of the GNU General Public License as published by
|
||||||
|
// the Free Software Foundation, either version 3 of the License, or
|
||||||
|
// (at your option) any later version.
|
||||||
|
//
|
||||||
|
// Moodle is distributed in the hope that it will be useful,
|
||||||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
// GNU General Public License for more details.
|
||||||
|
//
|
||||||
|
// You should have received a copy of the GNU General Public License
|
||||||
|
// along with Moodle. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
// This file defines settingpages and externalpages under the "server" category
|
/**
|
||||||
|
* Defines settingpages and externalpages under the "server" category.
|
||||||
|
*
|
||||||
|
* @package core
|
||||||
|
* @category admin
|
||||||
|
* @copyright 2006 Martin Dougiamas
|
||||||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||||||
|
*/
|
||||||
|
|
||||||
if ($hassiteconfig) { // speedup for non-admins, add all caps used on this page
|
defined('MOODLE_INTERNAL') || die();
|
||||||
|
|
||||||
// "systempaths" settingpage
|
if ($hassiteconfig) {
|
||||||
|
// System paths.
|
||||||
$temp = new admin_settingpage('systempaths', new lang_string('systempaths', 'admin'));
|
$temp = new admin_settingpage('systempaths', new lang_string('systempaths', 'admin'));
|
||||||
$temp->add(new admin_setting_configexecutable('pathtophp', new lang_string('pathtophp', 'admin'),
|
$temp->add(new admin_setting_configexecutable('pathtophp', new lang_string('pathtophp', 'admin'),
|
||||||
new lang_string('configpathtophp', 'admin'), ''));
|
new lang_string('configpathtophp', 'admin'), ''));
|
||||||
$temp->add(new admin_setting_configexecutable('pathtodu', new lang_string('pathtodu', 'admin'), new lang_string('configpathtodu', 'admin'), ''));
|
$temp->add(new admin_setting_configexecutable('pathtodu', new lang_string('pathtodu', 'admin'),
|
||||||
$temp->add(new admin_setting_configexecutable('aspellpath', new lang_string('aspellpath', 'admin'), new lang_string('edhelpaspellpath'), ''));
|
new lang_string('configpathtodu', 'admin'), ''));
|
||||||
$temp->add(new admin_setting_configexecutable('pathtodot', new lang_string('pathtodot', 'admin'), new lang_string('pathtodot_help', 'admin'), ''));
|
$temp->add(new admin_setting_configexecutable('aspellpath', new lang_string('aspellpath', 'admin'),
|
||||||
$temp->add(new admin_setting_configexecutable('pathtogs', new lang_string('pathtogs', 'admin'), new lang_string('pathtogs_help', 'admin'), '/usr/bin/gs'));
|
new lang_string('edhelpaspellpath'), ''));
|
||||||
|
$temp->add(new admin_setting_configexecutable('pathtodot', new lang_string('pathtodot', 'admin'),
|
||||||
|
new lang_string('pathtodot_help', 'admin'), ''));
|
||||||
|
$temp->add(new admin_setting_configexecutable('pathtogs', new lang_string('pathtogs', 'admin'),
|
||||||
|
new lang_string('pathtogs_help', 'admin'), '/usr/bin/gs'));
|
||||||
$temp->add(new admin_setting_configexecutable('pathtopython', new lang_string('pathtopython', 'admin'),
|
$temp->add(new admin_setting_configexecutable('pathtopython', new lang_string('pathtopython', 'admin'),
|
||||||
new lang_string('pathtopythondesc', 'admin'), ''));
|
new lang_string('pathtopythondesc', 'admin'), ''));
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
|
|
||||||
|
// Support contact.
|
||||||
|
|
||||||
// "supportcontact" settingpage
|
|
||||||
$temp = new admin_settingpage('supportcontact', new lang_string('supportcontact', 'admin'));
|
$temp = new admin_settingpage('supportcontact', new lang_string('supportcontact', 'admin'));
|
||||||
$primaryadmin = get_admin();
|
$primaryadmin = get_admin();
|
||||||
if ($primaryadmin) {
|
if ($primaryadmin) {
|
||||||
$primaryadminemail = $primaryadmin->email;
|
$primaryadminemail = $primaryadmin->email;
|
||||||
$primaryadminname = fullname($primaryadmin, true);
|
$primaryadminname = fullname($primaryadmin, true);
|
||||||
} else {
|
} else {
|
||||||
// no defaults during installation - admin user must be created first
|
// No defaults during installation - admin user must be created first.
|
||||||
$primaryadminemail = NULL;
|
$primaryadminemail = null;
|
||||||
$primaryadminname = NULL;
|
$primaryadminname = null;
|
||||||
}
|
}
|
||||||
$temp->add(new admin_setting_configtext('supportname', new lang_string('supportname', 'admin'),
|
$temp->add(new admin_setting_configtext('supportname', new lang_string('supportname', 'admin'),
|
||||||
new lang_string('configsupportname', 'admin'), $primaryadminname, PARAM_NOTAGS));
|
new lang_string('configsupportname', 'admin'), $primaryadminname, PARAM_NOTAGS));
|
||||||
|
@ -35,28 +59,34 @@ $setting = new admin_setting_configtext('supportemail', new lang_string('support
|
||||||
new lang_string('configsupportemail', 'admin'), $primaryadminemail, PARAM_EMAIL);
|
new lang_string('configsupportemail', 'admin'), $primaryadminemail, PARAM_EMAIL);
|
||||||
$setting->set_force_ltr(true);
|
$setting->set_force_ltr(true);
|
||||||
$temp->add($setting);
|
$temp->add($setting);
|
||||||
$temp->add(new admin_setting_configtext('supportpage', new lang_string('supportpage', 'admin'), new lang_string('configsupportpage', 'admin'), '', PARAM_URL));
|
$temp->add(new admin_setting_configtext('supportpage', new lang_string('supportpage', 'admin'),
|
||||||
|
new lang_string('configsupportpage', 'admin'), '', PARAM_URL));
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
|
|
||||||
|
// Session handling.
|
||||||
// "sessionhandling" settingpage
|
|
||||||
$temp = new admin_settingpage('sessionhandling', new lang_string('sessionhandling', 'admin'));
|
$temp = new admin_settingpage('sessionhandling', new lang_string('sessionhandling', 'admin'));
|
||||||
if (empty($CFG->session_handler_class) and $DB->session_lock_supported()) {
|
if (empty($CFG->session_handler_class) and $DB->session_lock_supported()) {
|
||||||
$temp->add(new admin_setting_configcheckbox('dbsessions', new lang_string('dbsessions', 'admin'), new lang_string('configdbsessions', 'admin'), 0));
|
$temp->add(new admin_setting_configcheckbox('dbsessions', new lang_string('dbsessions', 'admin'),
|
||||||
|
new lang_string('configdbsessions', 'admin'), 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
$temp->add(new admin_setting_configduration('sessiontimeout', new lang_string('sessiontimeout', 'admin'),
|
$temp->add(new admin_setting_configduration('sessiontimeout', new lang_string('sessiontimeout', 'admin'),
|
||||||
new lang_string('configsessiontimeout', 'admin'), 8 * 60 * 60));
|
new lang_string('configsessiontimeout', 'admin'), 8 * 60 * 60));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configtext('sessioncookie', new lang_string('sessioncookie', 'admin'), new lang_string('configsessioncookie', 'admin'), '', PARAM_ALPHANUM));
|
$temp->add(new admin_setting_configtext('sessioncookie', new lang_string('sessioncookie', 'admin'),
|
||||||
$temp->add(new admin_setting_configtext('sessioncookiepath', new lang_string('sessioncookiepath', 'admin'), new lang_string('configsessioncookiepath', 'admin'), '', PARAM_RAW));
|
new lang_string('configsessioncookie', 'admin'), '', PARAM_ALPHANUM));
|
||||||
$temp->add(new admin_setting_configtext('sessioncookiedomain', new lang_string('sessioncookiedomain', 'admin'), new lang_string('configsessioncookiedomain', 'admin'), '', PARAM_RAW, 50));
|
$temp->add(new admin_setting_configtext('sessioncookiepath', new lang_string('sessioncookiepath', 'admin'),
|
||||||
|
new lang_string('configsessioncookiepath', 'admin'), '', PARAM_RAW));
|
||||||
|
$temp->add(new admin_setting_configtext('sessioncookiedomain', new lang_string('sessioncookiedomain', 'admin'),
|
||||||
|
new lang_string('configsessioncookiedomain', 'admin'), '', PARAM_RAW, 50));
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
|
|
||||||
|
// Statistics.
|
||||||
// "stats" settingpage
|
|
||||||
$temp = new admin_settingpage('stats', new lang_string('stats'), 'moodle/site:config', empty($CFG->enablestats));
|
$temp = new admin_settingpage('stats', new lang_string('stats'), 'moodle/site:config', empty($CFG->enablestats));
|
||||||
$temp->add(new admin_setting_configselect('statsfirstrun', new lang_string('statsfirstrun', 'admin'), new lang_string('configstatsfirstrun', 'admin'), 'none', array('none' => new lang_string('none'),
|
$temp->add(new admin_setting_configselect('statsfirstrun', new lang_string('statsfirstrun', 'admin'),
|
||||||
|
new lang_string('configstatsfirstrun', 'admin'), 'none',
|
||||||
|
[
|
||||||
|
'none' => new lang_string('none'),
|
||||||
60 * 60 * 24 * 7 => new lang_string('numweeks', 'moodle', 1),
|
60 * 60 * 24 * 7 => new lang_string('numweeks', 'moodle', 1),
|
||||||
60 * 60 * 24 * 14 => new lang_string('numweeks', 'moodle', 2),
|
60 * 60 * 24 * 14 => new lang_string('numweeks', 'moodle', 2),
|
||||||
60 * 60 * 24 * 21 => new lang_string('numweeks', 'moodle', 3),
|
60 * 60 * 24 * 21 => new lang_string('numweeks', 'moodle', 3),
|
||||||
|
@ -66,8 +96,13 @@ $temp->add(new admin_setting_configselect('statsfirstrun', new lang_string('stat
|
||||||
60 * 60 * 24 * 112 => new lang_string('nummonths', 'moodle', 4),
|
60 * 60 * 24 * 112 => new lang_string('nummonths', 'moodle', 4),
|
||||||
60 * 60 * 24 * 140 => new lang_string('nummonths', 'moodle', 5),
|
60 * 60 * 24 * 140 => new lang_string('nummonths', 'moodle', 5),
|
||||||
60 * 60 * 24 * 168 => new lang_string('nummonths', 'moodle', 6),
|
60 * 60 * 24 * 168 => new lang_string('nummonths', 'moodle', 6),
|
||||||
'all' => new lang_string('all') )));
|
'all' => new lang_string('all')
|
||||||
$temp->add(new admin_setting_configselect('statsmaxruntime', new lang_string('statsmaxruntime', 'admin'), new lang_string('configstatsmaxruntime3', 'admin'), 0, array(0 => new lang_string('untilcomplete'),
|
]
|
||||||
|
));
|
||||||
|
$temp->add(new admin_setting_configselect('statsmaxruntime', new lang_string('statsmaxruntime', 'admin'),
|
||||||
|
new lang_string('configstatsmaxruntime3', 'admin'), 0,
|
||||||
|
[
|
||||||
|
0 => new lang_string('untilcomplete'),
|
||||||
60 * 30 => '10 ' . new lang_string('minutes'),
|
60 * 30 => '10 ' . new lang_string('minutes'),
|
||||||
60 * 30 => '30 ' . new lang_string('minutes'),
|
60 * 30 => '30 ' . new lang_string('minutes'),
|
||||||
60 * 60 => '1 ' . new lang_string('hour'),
|
60 * 60 => '1 ' . new lang_string('hour'),
|
||||||
|
@ -77,49 +112,66 @@ $temp->add(new admin_setting_configselect('statsmaxruntime', new lang_string('st
|
||||||
60 * 60 * 5 => '5 ' . new lang_string('hours'),
|
60 * 60 * 5 => '5 ' . new lang_string('hours'),
|
||||||
60 * 60 * 6 => '6 ' . new lang_string('hours'),
|
60 * 60 * 6 => '6 ' . new lang_string('hours'),
|
||||||
60 * 60 * 7 => '7 ' . new lang_string('hours'),
|
60 * 60 * 7 => '7 ' . new lang_string('hours'),
|
||||||
60*60*8 => '8 '.new lang_string('hours') )));
|
60 * 60 * 8 => '8 ' . new lang_string('hours'),
|
||||||
$temp->add(new admin_setting_configtext('statsruntimedays', new lang_string('statsruntimedays', 'admin'), new lang_string('configstatsruntimedays', 'admin'), 31, PARAM_INT));
|
]
|
||||||
$temp->add(new admin_setting_configtext('statsuserthreshold', new lang_string('statsuserthreshold', 'admin'), new lang_string('configstatsuserthreshold', 'admin'), 0, PARAM_INT));
|
));
|
||||||
|
$temp->add(new admin_setting_configtext('statsruntimedays', new lang_string('statsruntimedays', 'admin'),
|
||||||
|
new lang_string('configstatsruntimedays', 'admin'), 31, PARAM_INT));
|
||||||
|
$temp->add(new admin_setting_configtext('statsuserthreshold', new lang_string('statsuserthreshold', 'admin'),
|
||||||
|
new lang_string('configstatsuserthreshold', 'admin'), 0, PARAM_INT));
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
|
|
||||||
|
// HTTP.
|
||||||
// "http" settingpage
|
|
||||||
$temp = new admin_settingpage('http', new lang_string('http', 'admin'));
|
$temp = new admin_settingpage('http', new lang_string('http', 'admin'));
|
||||||
$temp->add(new admin_setting_configcheckbox('slasharguments', new lang_string('slasharguments', 'admin'), new lang_string('configslasharguments', 'admin'), 1));
|
$temp->add(new admin_setting_configcheckbox('slasharguments', new lang_string('slasharguments', 'admin'),
|
||||||
|
new lang_string('configslasharguments', 'admin'), 1));
|
||||||
$temp->add(new admin_setting_heading('reverseproxy', new lang_string('reverseproxy', 'admin'), '', ''));
|
$temp->add(new admin_setting_heading('reverseproxy', new lang_string('reverseproxy', 'admin'), '', ''));
|
||||||
$options = array(
|
$options = [
|
||||||
0 => 'HTTP_CLIENT_IP, HTTP_X_FORWARDED_FOR, REMOTE_ADDR',
|
0 => 'HTTP_CLIENT_IP, HTTP_X_FORWARDED_FOR, REMOTE_ADDR',
|
||||||
GETREMOTEADDR_SKIP_HTTP_CLIENT_IP => 'HTTP_X_FORWARDED_FOR, REMOTE_ADDR',
|
GETREMOTEADDR_SKIP_HTTP_CLIENT_IP => 'HTTP_X_FORWARDED_FOR, REMOTE_ADDR',
|
||||||
GETREMOTEADDR_SKIP_HTTP_X_FORWARDED_FOR => 'HTTP_CLIENT, REMOTE_ADDR',
|
GETREMOTEADDR_SKIP_HTTP_X_FORWARDED_FOR => 'HTTP_CLIENT, REMOTE_ADDR',
|
||||||
GETREMOTEADDR_SKIP_HTTP_X_FORWARDED_FOR|GETREMOTEADDR_SKIP_HTTP_CLIENT_IP => 'REMOTE_ADDR');
|
GETREMOTEADDR_SKIP_HTTP_X_FORWARDED_FOR | GETREMOTEADDR_SKIP_HTTP_CLIENT_IP => 'REMOTE_ADDR'
|
||||||
|
];
|
||||||
$temp->add(new admin_setting_configselect('getremoteaddrconf', new lang_string('getremoteaddrconf', 'admin'),
|
$temp->add(new admin_setting_configselect('getremoteaddrconf', new lang_string('getremoteaddrconf', 'admin'),
|
||||||
new lang_string('configgetremoteaddrconf', 'admin'),
|
new lang_string('configgetremoteaddrconf', 'admin'),
|
||||||
GETREMOTEADDR_SKIP_DEFAULT, $options));
|
GETREMOTEADDR_SKIP_HTTP_X_FORWARDED_FOR | GETREMOTEADDR_SKIP_HTTP_CLIENT_IP, $options));
|
||||||
$temp->add(new admin_setting_configtext('reverseproxyignore', new lang_string('reverseproxyignore', 'admin'), new lang_string('configreverseproxyignore', 'admin'), ''));
|
$temp->add(new admin_setting_configtext('reverseproxyignore', new lang_string('reverseproxyignore', 'admin'),
|
||||||
|
new lang_string('configreverseproxyignore', 'admin'), ''));
|
||||||
|
|
||||||
$temp->add(new admin_setting_heading('webproxy', new lang_string('webproxy', 'admin'), new lang_string('webproxyinfo', 'admin')));
|
$temp->add(new admin_setting_heading('webproxy', new lang_string('webproxy', 'admin'),
|
||||||
$temp->add(new admin_setting_configtext('proxyhost', new lang_string('proxyhost', 'admin'), new lang_string('configproxyhost', 'admin'), '', PARAM_HOST));
|
new lang_string('webproxyinfo', 'admin')));
|
||||||
$temp->add(new admin_setting_configtext('proxyport', new lang_string('proxyport', 'admin'), new lang_string('configproxyport', 'admin'), 0, PARAM_INT));
|
$temp->add(new admin_setting_configtext('proxyhost', new lang_string('proxyhost', 'admin'),
|
||||||
$options = array('HTTP'=>'HTTP');
|
new lang_string('configproxyhost', 'admin'), '', PARAM_HOST));
|
||||||
|
$temp->add(new admin_setting_configtext('proxyport', new lang_string('proxyport', 'admin'),
|
||||||
|
new lang_string('configproxyport', 'admin'), 0, PARAM_INT));
|
||||||
|
$options = ['HTTP' => 'HTTP'];
|
||||||
if (defined('CURLPROXY_SOCKS5')) {
|
if (defined('CURLPROXY_SOCKS5')) {
|
||||||
$options['SOCKS5'] = 'SOCKS5';
|
$options['SOCKS5'] = 'SOCKS5';
|
||||||
}
|
}
|
||||||
$temp->add(new admin_setting_configselect('proxytype', new lang_string('proxytype', 'admin'), new lang_string('configproxytype','admin'), 'HTTP', $options));
|
$temp->add(new admin_setting_configselect('proxytype', new lang_string('proxytype', 'admin'),
|
||||||
$temp->add(new admin_setting_configtext('proxyuser', new lang_string('proxyuser', 'admin'), new lang_string('configproxyuser', 'admin'), ''));
|
new lang_string('configproxytype', 'admin'), 'HTTP', $options));
|
||||||
$temp->add(new admin_setting_configpasswordunmask('proxypassword', new lang_string('proxypassword', 'admin'), new lang_string('configproxypassword', 'admin'), ''));
|
$temp->add(new admin_setting_configtext('proxyuser', new lang_string('proxyuser', 'admin'),
|
||||||
$temp->add(new admin_setting_configtext('proxybypass', new lang_string('proxybypass', 'admin'), new lang_string('configproxybypass', 'admin'), 'localhost, 127.0.0.1'));
|
new lang_string('configproxyuser', 'admin'), ''));
|
||||||
|
$temp->add(new admin_setting_configpasswordunmask('proxypassword', new lang_string('proxypassword', 'admin'),
|
||||||
|
new lang_string('configproxypassword', 'admin'), ''));
|
||||||
|
$temp->add(new admin_setting_configtext('proxybypass', new lang_string('proxybypass', 'admin'),
|
||||||
|
new lang_string('configproxybypass', 'admin'), 'localhost, 127.0.0.1'));
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
|
|
||||||
$temp = new admin_settingpage('maintenancemode', new lang_string('sitemaintenancemode', 'admin'));
|
$temp = new admin_settingpage('maintenancemode', new lang_string('sitemaintenancemode', 'admin'));
|
||||||
$options = array(0=>new lang_string('disable'), 1=>new lang_string('enable'));
|
$options = [0 => new lang_string('disable'), 1 => new lang_string('enable')];
|
||||||
$temp->add(new admin_setting_configselect('maintenance_enabled', new lang_string('sitemaintenancemode', 'admin'),
|
$temp->add(new admin_setting_configselect('maintenance_enabled', new lang_string('sitemaintenancemode', 'admin'),
|
||||||
new lang_string('helpsitemaintenance', 'admin'), 0, $options));
|
new lang_string('helpsitemaintenance', 'admin'), 0, $options));
|
||||||
$temp->add(new admin_setting_confightmleditor('maintenance_message', new lang_string('optionalmaintenancemessage', 'admin'),
|
$temp->add(new admin_setting_confightmleditor('maintenance_message', new lang_string('optionalmaintenancemessage', 'admin'),
|
||||||
'', ''));
|
'', ''));
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
|
|
||||||
|
// Cleanup.
|
||||||
$temp = new admin_settingpage('cleanup', new lang_string('cleanup', 'admin'));
|
$temp = new admin_settingpage('cleanup', new lang_string('cleanup', 'admin'));
|
||||||
$temp->add(new admin_setting_configselect('deleteunconfirmed', new lang_string('deleteunconfirmed', 'admin'), new lang_string('configdeleteunconfirmed', 'admin'), 168, array(0 => new lang_string('never'),
|
$temp->add(new admin_setting_configselect('deleteunconfirmed', new lang_string('deleteunconfirmed', 'admin'),
|
||||||
|
new lang_string('configdeleteunconfirmed', 'admin'), 168,
|
||||||
|
[
|
||||||
|
0 => new lang_string('never'),
|
||||||
168 => new lang_string('numdays', '', 7),
|
168 => new lang_string('numdays', '', 7),
|
||||||
144 => new lang_string('numdays', '', 6),
|
144 => new lang_string('numdays', '', 6),
|
||||||
120 => new lang_string('numdays', '', 5),
|
120 => new lang_string('numdays', '', 5),
|
||||||
|
@ -129,23 +181,31 @@ $temp->add(new admin_setting_configselect('deleteunconfirmed', new lang_string('
|
||||||
24 => new lang_string('numdays', '', 1),
|
24 => new lang_string('numdays', '', 1),
|
||||||
12 => new lang_string('numhours', '', 12),
|
12 => new lang_string('numhours', '', 12),
|
||||||
6 => new lang_string('numhours', '', 6),
|
6 => new lang_string('numhours', '', 6),
|
||||||
1 => new lang_string('numhours', '', 1))));
|
1 => new lang_string('numhours', '', 1),
|
||||||
|
]
|
||||||
|
));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configselect('deleteincompleteusers', new lang_string('deleteincompleteusers', 'admin'), new lang_string('configdeleteincompleteusers', 'admin'), 0, array(0 => new lang_string('never'),
|
$temp->add(new admin_setting_configselect('deleteincompleteusers', new lang_string('deleteincompleteusers', 'admin'),
|
||||||
|
new lang_string('configdeleteincompleteusers', 'admin'), 0,
|
||||||
|
[
|
||||||
|
0 => new lang_string('never'),
|
||||||
168 => new lang_string('numdays', '', 7),
|
168 => new lang_string('numdays', '', 7),
|
||||||
144 => new lang_string('numdays', '', 6),
|
144 => new lang_string('numdays', '', 6),
|
||||||
120 => new lang_string('numdays', '', 5),
|
120 => new lang_string('numdays', '', 5),
|
||||||
96 => new lang_string('numdays', '', 4),
|
96 => new lang_string('numdays', '', 4),
|
||||||
72 => new lang_string('numdays', '', 3),
|
72 => new lang_string('numdays', '', 3),
|
||||||
48 => new lang_string('numdays', '', 2),
|
48 => new lang_string('numdays', '', 2),
|
||||||
24 => new lang_string('numdays', '', 1))));
|
24 => new lang_string('numdays', '', 1),
|
||||||
|
]
|
||||||
|
));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configcheckbox('disablegradehistory', new lang_string('disablegradehistory', 'grades'),
|
$temp->add(new admin_setting_configcheckbox('disablegradehistory', new lang_string('disablegradehistory', 'grades'),
|
||||||
new lang_string('disablegradehistory_help', 'grades'), 0));
|
new lang_string('disablegradehistory_help', 'grades'), 0));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configselect('gradehistorylifetime', new lang_string('gradehistorylifetime', 'grades'),
|
$temp->add(new admin_setting_configselect('gradehistorylifetime', new lang_string('gradehistorylifetime', 'grades'),
|
||||||
new lang_string('gradehistorylifetime_help', 'grades'), 0, array(0 => new lang_string('neverdeletehistory', 'grades'),
|
new lang_string('gradehistorylifetime_help', 'grades'), 0,
|
||||||
|
[
|
||||||
|
0 => new lang_string('neverdeletehistory', 'grades'),
|
||||||
1000 => new lang_string('numdays', '', 1000),
|
1000 => new lang_string('numdays', '', 1000),
|
||||||
365 => new lang_string('numdays', '', 365),
|
365 => new lang_string('numdays', '', 365),
|
||||||
180 => new lang_string('numdays', '', 180),
|
180 => new lang_string('numdays', '', 180),
|
||||||
|
@ -153,10 +213,13 @@ $temp->add(new admin_setting_configselect('gradehistorylifetime', new lang_strin
|
||||||
120 => new lang_string('numdays', '', 120),
|
120 => new lang_string('numdays', '', 120),
|
||||||
90 => new lang_string('numdays', '', 90),
|
90 => new lang_string('numdays', '', 90),
|
||||||
60 => new lang_string('numdays', '', 60),
|
60 => new lang_string('numdays', '', 60),
|
||||||
30 => new lang_string('numdays', '', 30))));
|
30 => new lang_string('numdays', '', 30),
|
||||||
|
]
|
||||||
|
));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configselect('tempdatafoldercleanup', new lang_string('tempdatafoldercleanup', 'admin'),
|
$temp->add(new admin_setting_configselect('tempdatafoldercleanup', new lang_string('tempdatafoldercleanup', 'admin'),
|
||||||
new lang_string('configtempdatafoldercleanup', 'admin'), 168, array(
|
new lang_string('configtempdatafoldercleanup', 'admin'), 168,
|
||||||
|
[
|
||||||
1 => new lang_string('numhours', '', 1),
|
1 => new lang_string('numhours', '', 1),
|
||||||
3 => new lang_string('numhours', '', 3),
|
3 => new lang_string('numhours', '', 3),
|
||||||
6 => new lang_string('numhours', '', 6),
|
6 => new lang_string('numhours', '', 6),
|
||||||
|
@ -166,7 +229,8 @@ $temp->add(new admin_setting_configselect('tempdatafoldercleanup', new lang_stri
|
||||||
24 => new lang_string('numhours', '', 24),
|
24 => new lang_string('numhours', '', 24),
|
||||||
48 => new lang_string('numdays', '', 2),
|
48 => new lang_string('numdays', '', 2),
|
||||||
168 => new lang_string('numdays', '', 7),
|
168 => new lang_string('numdays', '', 7),
|
||||||
)));
|
]
|
||||||
|
));
|
||||||
|
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
|
|
||||||
|
@ -175,23 +239,30 @@ $ADMIN->add('server', $temp);
|
||||||
new lang_string('filescleanupperiod_help', 'admin'),
|
new lang_string('filescleanupperiod_help', 'admin'),
|
||||||
86400));
|
86400));
|
||||||
|
|
||||||
$ADMIN->add('server', new admin_externalpage('environment', new lang_string('environment','admin'), "$CFG->wwwroot/$CFG->admin/environment.php"));
|
// Environment.
|
||||||
$ADMIN->add('server', new admin_externalpage('phpinfo', new lang_string('phpinfo'), "$CFG->wwwroot/$CFG->admin/phpinfo.php"));
|
$ADMIN->add('server', new admin_externalpage('environment', new lang_string('environment', 'admin'),
|
||||||
|
"{$CFG->wwwroot}/{$CFG->admin}/environment.php"));
|
||||||
|
|
||||||
|
// PHP info.
|
||||||
|
$ADMIN->add('server', new admin_externalpage('phpinfo', new lang_string('phpinfo'),
|
||||||
|
"{$CFG->wwwroot}/{$CFG->admin}/phpinfo.php"));
|
||||||
|
|
||||||
|
// Test outgoing mail configuration (hidden, accessed via direct link from the settings page).
|
||||||
$ADMIN->add('server', new admin_externalpage('testoutgoingmailconf', new lang_string('testoutgoingmailconf', 'admin'),
|
$ADMIN->add('server', new admin_externalpage('testoutgoingmailconf', new lang_string('testoutgoingmailconf', 'admin'),
|
||||||
new moodle_url("$CFG->wwwroot/$CFG->admin/testoutgoingmailconf.php"), 'moodle/site:config', true));
|
new moodle_url('/admin/testoutgoingmailconf.php'), 'moodle/site:config', true));
|
||||||
|
|
||||||
|
// Performance.
|
||||||
// "performance" settingpage
|
|
||||||
$temp = new admin_settingpage('performance', new lang_string('performance', 'admin'));
|
$temp = new admin_settingpage('performance', new lang_string('performance', 'admin'));
|
||||||
|
|
||||||
// Memory limit options for large administration tasks.
|
// Memory limit options for large administration tasks.
|
||||||
$memoryoptions = array(
|
$memoryoptions = [
|
||||||
'64M' => '64M',
|
'64M' => '64M',
|
||||||
'128M' => '128M',
|
'128M' => '128M',
|
||||||
'256M' => '256M',
|
'256M' => '256M',
|
||||||
'512M' => '512M',
|
'512M' => '512M',
|
||||||
'1024M' => '1024M',
|
'1024M' => '1024M',
|
||||||
'2048M' => '2048M');
|
'2048M' => '2048M',
|
||||||
|
];
|
||||||
|
|
||||||
// Allow larger memory usage for 64-bit sites only.
|
// Allow larger memory usage for 64-bit sites only.
|
||||||
if (PHP_INT_SIZE === 8) {
|
if (PHP_INT_SIZE === 8) {
|
||||||
|
@ -200,8 +271,8 @@ if (PHP_INT_SIZE === 8) {
|
||||||
}
|
}
|
||||||
|
|
||||||
$temp->add(new admin_setting_configselect('extramemorylimit', new lang_string('extramemorylimit', 'admin'),
|
$temp->add(new admin_setting_configselect('extramemorylimit', new lang_string('extramemorylimit', 'admin'),
|
||||||
new lang_string('configextramemorylimit', 'admin'), '512M',
|
new lang_string('configextramemorylimit', 'admin'), '512M', $memoryoptions));
|
||||||
$memoryoptions));
|
|
||||||
$temp->add(new admin_setting_configtext('maxtimelimit', new lang_string('maxtimelimit', 'admin'),
|
$temp->add(new admin_setting_configtext('maxtimelimit', new lang_string('maxtimelimit', 'admin'),
|
||||||
new lang_string('maxtimelimit_desc', 'admin'), 0, PARAM_INT));
|
new lang_string('maxtimelimit_desc', 'admin'), 0, PARAM_INT));
|
||||||
|
|
||||||
|
@ -213,8 +284,10 @@ $temp->add(new admin_setting_configtext('curltimeoutkbitrate', new lang_string('
|
||||||
|
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
|
|
||||||
|
// Tasks.
|
||||||
$ADMIN->add('server', new admin_category('taskconfig', new lang_string('taskadmintitle', 'admin')));
|
$ADMIN->add('server', new admin_category('taskconfig', new lang_string('taskadmintitle', 'admin')));
|
||||||
|
|
||||||
|
// Task processing.
|
||||||
$temp = new admin_settingpage('taskprocessing', new lang_string('taskprocessing', 'admin'));
|
$temp = new admin_settingpage('taskprocessing', new lang_string('taskprocessing', 'admin'));
|
||||||
|
|
||||||
$setting = new admin_setting_configcheckbox(
|
$setting = new admin_setting_configcheckbox(
|
||||||
|
@ -265,6 +338,7 @@ $temp->add(
|
||||||
);
|
);
|
||||||
$ADMIN->add('taskconfig', $temp);
|
$ADMIN->add('taskconfig', $temp);
|
||||||
|
|
||||||
|
// Task log configuration.
|
||||||
$temp = new admin_settingpage('tasklogging', new lang_string('tasklogging', 'admin'));
|
$temp = new admin_settingpage('tasklogging', new lang_string('tasklogging', 'admin'));
|
||||||
$temp->add(
|
$temp->add(
|
||||||
new admin_setting_configselect(
|
new admin_setting_configselect(
|
||||||
|
@ -310,6 +384,7 @@ if (\core\task\logmanager::uses_standard_settings()) {
|
||||||
}
|
}
|
||||||
$ADMIN->add('taskconfig', $temp);
|
$ADMIN->add('taskconfig', $temp);
|
||||||
|
|
||||||
|
// Task logs.
|
||||||
if (\core\task\logmanager::uses_standard_settings()) {
|
if (\core\task\logmanager::uses_standard_settings()) {
|
||||||
$ADMIN->add('taskconfig', new admin_externalpage(
|
$ADMIN->add('taskconfig', new admin_externalpage(
|
||||||
'tasklogs',
|
'tasklogs',
|
||||||
|
@ -318,85 +393,119 @@ if (\core\task\logmanager::uses_standard_settings()) {
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
// E-mail settings.
|
// Email.
|
||||||
$ADMIN->add('server', new admin_category('email', new lang_string('categoryemail', 'admin')));
|
$ADMIN->add('server', new admin_category('email', new lang_string('categoryemail', 'admin')));
|
||||||
|
|
||||||
|
// Outgoing mail configuration.
|
||||||
$temp = new admin_settingpage('outgoingmailconfig', new lang_string('outgoingmailconfig', 'admin'));
|
$temp = new admin_settingpage('outgoingmailconfig', new lang_string('outgoingmailconfig', 'admin'));
|
||||||
|
|
||||||
$temp->add(new admin_setting_heading('smtpheading', new lang_string('smtp', 'admin'),
|
$temp->add(new admin_setting_heading('smtpheading', new lang_string('smtp', 'admin'),
|
||||||
new lang_string('smtpdetail', 'admin')));
|
new lang_string('smtpdetail', 'admin')));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configtext('smtphosts', new lang_string('smtphosts', 'admin'),
|
$temp->add(new admin_setting_configtext('smtphosts', new lang_string('smtphosts', 'admin'),
|
||||||
new lang_string('configsmtphosts', 'admin'), '', PARAM_RAW));
|
new lang_string('configsmtphosts', 'admin'), '', PARAM_RAW));
|
||||||
$options = array('' => new lang_string('none', 'admin'), 'ssl' => 'SSL', 'tls' => 'TLS');
|
|
||||||
|
$options = [
|
||||||
|
'' => new lang_string('none', 'admin'),
|
||||||
|
'ssl' => 'SSL',
|
||||||
|
'tls' => 'TLS',
|
||||||
|
];
|
||||||
|
|
||||||
$temp->add(new admin_setting_configselect('smtpsecure', new lang_string('smtpsecure', 'admin'),
|
$temp->add(new admin_setting_configselect('smtpsecure', new lang_string('smtpsecure', 'admin'),
|
||||||
new lang_string('configsmtpsecure', 'admin'), '', $options));
|
new lang_string('configsmtpsecure', 'admin'), '', $options));
|
||||||
$authtypeoptions = array('LOGIN' => 'LOGIN', 'PLAIN' => 'PLAIN', 'NTLM' => 'NTLM', 'CRAM-MD5' => 'CRAM-MD5');
|
|
||||||
|
$authtypeoptions = [
|
||||||
|
'LOGIN' => 'LOGIN',
|
||||||
|
'PLAIN' => 'PLAIN',
|
||||||
|
'NTLM' => 'NTLM',
|
||||||
|
'CRAM-MD5' => 'CRAM-MD5',
|
||||||
|
];
|
||||||
|
|
||||||
$temp->add(new admin_setting_configselect('smtpauthtype', new lang_string('smtpauthtype', 'admin'),
|
$temp->add(new admin_setting_configselect('smtpauthtype', new lang_string('smtpauthtype', 'admin'),
|
||||||
new lang_string('configsmtpauthtype', 'admin'), 'LOGIN', $authtypeoptions));
|
new lang_string('configsmtpauthtype', 'admin'), 'LOGIN', $authtypeoptions));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configtext('smtpuser', new lang_string('smtpuser', 'admin'),
|
$temp->add(new admin_setting_configtext('smtpuser', new lang_string('smtpuser', 'admin'),
|
||||||
new lang_string('configsmtpuser', 'admin'), '', PARAM_NOTAGS));
|
new lang_string('configsmtpuser', 'admin'), '', PARAM_NOTAGS));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configpasswordunmask('smtppass', new lang_string('smtppass', 'admin'),
|
$temp->add(new admin_setting_configpasswordunmask('smtppass', new lang_string('smtppass', 'admin'),
|
||||||
new lang_string('configsmtpuser', 'admin'), ''));
|
new lang_string('configsmtpuser', 'admin'), ''));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configtext('smtpmaxbulk', new lang_string('smtpmaxbulk', 'admin'),
|
$temp->add(new admin_setting_configtext('smtpmaxbulk', new lang_string('smtpmaxbulk', 'admin'),
|
||||||
new lang_string('configsmtpmaxbulk', 'admin'), 1, PARAM_INT));
|
new lang_string('configsmtpmaxbulk', 'admin'), 1, PARAM_INT));
|
||||||
|
|
||||||
$temp->add(new admin_setting_heading('noreplydomainheading', new lang_string('noreplydomain', 'admin'),
|
$temp->add(new admin_setting_heading('noreplydomainheading', new lang_string('noreplydomain', 'admin'),
|
||||||
new lang_string('noreplydomaindetail', 'admin')));
|
new lang_string('noreplydomaindetail', 'admin')));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configtext('noreplyaddress', new lang_string('noreplyaddress', 'admin'),
|
$temp->add(new admin_setting_configtext('noreplyaddress', new lang_string('noreplyaddress', 'admin'),
|
||||||
new lang_string('confignoreplyaddress', 'admin'), 'noreply@' . get_host_from_url($CFG->wwwroot), PARAM_EMAIL));
|
new lang_string('confignoreplyaddress', 'admin'), 'noreply@' . get_host_from_url($CFG->wwwroot), PARAM_EMAIL));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configtextarea('allowedemaildomains',
|
$temp->add(new admin_setting_configtextarea('allowedemaildomains',
|
||||||
new lang_string('allowedemaildomains', 'admin'),
|
new lang_string('allowedemaildomains', 'admin'),
|
||||||
new lang_string('configallowedemaildomains', 'admin'),
|
new lang_string('configallowedemaildomains', 'admin'),
|
||||||
''));
|
''));
|
||||||
|
|
||||||
$url = new moodle_url('/admin/testoutgoingmailconf.php');
|
$url = new moodle_url('/admin/testoutgoingmailconf.php');
|
||||||
$link = html_writer::link($url, get_string('testoutgoingmailconf', 'admin'));
|
$link = html_writer::link($url, get_string('testoutgoingmailconf', 'admin'));
|
||||||
$temp->add(new admin_setting_heading('testoutgoinmailc', new lang_string('testoutgoingmailconf', 'admin'),
|
$temp->add(new admin_setting_heading('testoutgoinmailc', new lang_string('testoutgoingmailconf', 'admin'),
|
||||||
new lang_string('testoutgoingmaildetail', 'admin', $link)));
|
new lang_string('testoutgoingmaildetail', 'admin', $link)));
|
||||||
|
|
||||||
$temp->add(new admin_setting_heading('emaildoesnotfit', new lang_string('doesnotfit', 'admin'),
|
$temp->add(new admin_setting_heading('emaildoesnotfit', new lang_string('doesnotfit', 'admin'),
|
||||||
new lang_string('doesnotfitdetail', 'admin')));
|
new lang_string('doesnotfitdetail', 'admin')));
|
||||||
|
|
||||||
$charsets = get_list_of_charsets();
|
$charsets = get_list_of_charsets();
|
||||||
unset($charsets['UTF-8']); // Not needed here.
|
unset($charsets['UTF-8']);
|
||||||
$options = array();
|
$options = [
|
||||||
$options['0'] = 'UTF-8';
|
'0' => 'UTF-8',
|
||||||
|
];
|
||||||
$options = array_merge($options, $charsets);
|
$options = array_merge($options, $charsets);
|
||||||
$temp->add(new admin_setting_configselect('sitemailcharset', new lang_string('sitemailcharset', 'admin'),
|
$temp->add(new admin_setting_configselect('sitemailcharset', new lang_string('sitemailcharset', 'admin'),
|
||||||
new lang_string('configsitemailcharset', 'admin'), '0', $options));
|
new lang_string('configsitemailcharset', 'admin'), '0', $options));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configcheckbox('allowusermailcharset', new lang_string('allowusermailcharset', 'admin'),
|
$temp->add(new admin_setting_configcheckbox('allowusermailcharset', new lang_string('allowusermailcharset', 'admin'),
|
||||||
new lang_string('configallowusermailcharset', 'admin'), 0));
|
new lang_string('configallowusermailcharset', 'admin'), 0));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configcheckbox('allowattachments', new lang_string('allowattachments', 'admin'),
|
$temp->add(new admin_setting_configcheckbox('allowattachments', new lang_string('allowattachments', 'admin'),
|
||||||
new lang_string('configallowattachments', 'admin'), 1));
|
new lang_string('configallowattachments', 'admin'), 1));
|
||||||
$options = array('LF' => 'LF', 'CRLF' => 'CRLF');
|
|
||||||
|
$options = [
|
||||||
|
'LF' => 'LF',
|
||||||
|
'CRLF' => 'CRLF',
|
||||||
|
];
|
||||||
$temp->add(new admin_setting_configselect('mailnewline', new lang_string('mailnewline', 'admin'),
|
$temp->add(new admin_setting_configselect('mailnewline', new lang_string('mailnewline', 'admin'),
|
||||||
new lang_string('configmailnewline', 'admin'), 'LF', $options));
|
new lang_string('configmailnewline', 'admin'), 'LF', $options));
|
||||||
|
|
||||||
$choices = array(new lang_string('never', 'admin'),
|
$choices = [
|
||||||
|
new lang_string('never', 'admin'),
|
||||||
new lang_string('always', 'admin'),
|
new lang_string('always', 'admin'),
|
||||||
new lang_string('onlynoreply', 'admin'));
|
new lang_string('onlynoreply', 'admin'),
|
||||||
|
];
|
||||||
$temp->add(new admin_setting_configselect('emailfromvia', new lang_string('emailfromvia', 'admin'),
|
$temp->add(new admin_setting_configselect('emailfromvia', new lang_string('emailfromvia', 'admin'),
|
||||||
new lang_string('configemailfromvia', 'admin'), 1, $choices));
|
new lang_string('configemailfromvia', 'admin'), 1, $choices));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configtext('emailsubjectprefix', new lang_string('emailsubjectprefix', 'admin'),
|
$temp->add(new admin_setting_configtext('emailsubjectprefix', new lang_string('emailsubjectprefix', 'admin'),
|
||||||
new lang_string('configemailsubjectprefix', 'admin'), '', PARAM_RAW));
|
new lang_string('configemailsubjectprefix', 'admin'), '', PARAM_RAW));
|
||||||
|
|
||||||
$temp->add(new admin_setting_configtextarea('emailheaders', new lang_string('emailheaders', 'admin'),
|
$temp->add(new admin_setting_configtextarea('emailheaders', new lang_string('emailheaders', 'admin'),
|
||||||
new lang_string('configemailheaders', 'admin'), '', PARAM_RAW, '50', '3'));
|
new lang_string('configemailheaders', 'admin'), '', PARAM_RAW, '50', '3'));
|
||||||
|
|
||||||
$ADMIN->add('email', $temp);
|
$ADMIN->add('email', $temp);
|
||||||
|
|
||||||
// "update notifications" settingpage
|
// Update notifications.
|
||||||
if (empty($CFG->disableupdatenotifications)) {
|
if (empty($CFG->disableupdatenotifications)) {
|
||||||
$temp = new admin_settingpage('updatenotifications', new lang_string('updatenotifications', 'core_admin'));
|
$temp = new admin_settingpage('updatenotifications', new lang_string('updatenotifications', 'core_admin'));
|
||||||
$temp->add(new admin_setting_configcheckbox('updateautocheck', new lang_string('updateautocheck', 'core_admin'),
|
$temp->add(new admin_setting_configcheckbox('updateautocheck', new lang_string('updateautocheck', 'core_admin'),
|
||||||
new lang_string('updateautocheck_desc', 'core_admin'), 1));
|
new lang_string('updateautocheck_desc', 'core_admin'), 1));
|
||||||
$temp->add(new admin_setting_configselect('updateminmaturity', new lang_string('updateminmaturity', 'core_admin'),
|
$temp->add(new admin_setting_configselect('updateminmaturity', new lang_string('updateminmaturity', 'core_admin'),
|
||||||
new lang_string('updateminmaturity_desc', 'core_admin'), MATURITY_STABLE,
|
new lang_string('updateminmaturity_desc', 'core_admin'), MATURITY_STABLE,
|
||||||
array(
|
[
|
||||||
MATURITY_ALPHA => new lang_string('maturity'.MATURITY_ALPHA, 'core_admin'),
|
MATURITY_ALPHA => new lang_string('maturity'.MATURITY_ALPHA, 'core_admin'),
|
||||||
MATURITY_BETA => new lang_string('maturity'.MATURITY_BETA, 'core_admin'),
|
MATURITY_BETA => new lang_string('maturity'.MATURITY_BETA, 'core_admin'),
|
||||||
MATURITY_RC => new lang_string('maturity'.MATURITY_RC, 'core_admin'),
|
MATURITY_RC => new lang_string('maturity'.MATURITY_RC, 'core_admin'),
|
||||||
MATURITY_STABLE => new lang_string('maturity'.MATURITY_STABLE, 'core_admin'),
|
MATURITY_STABLE => new lang_string('maturity'.MATURITY_STABLE, 'core_admin'),
|
||||||
)));
|
]
|
||||||
|
));
|
||||||
$temp->add(new admin_setting_configcheckbox('updatenotifybuilds', new lang_string('updatenotifybuilds', 'core_admin'),
|
$temp->add(new admin_setting_configcheckbox('updatenotifybuilds', new lang_string('updatenotifybuilds', 'core_admin'),
|
||||||
new lang_string('updatenotifybuilds_desc', 'core_admin'), 0));
|
new lang_string('updatenotifybuilds_desc', 'core_admin'), 0));
|
||||||
$ADMIN->add('server', $temp);
|
$ADMIN->add('server', $temp);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
} // end of speedup
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue