You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
105 lines
2.9 KiB
105 lines
2.9 KiB
<?php
|
|
|
|
/**
|
|
* Allows admin to edit all auth plugin settings.
|
|
*
|
|
* JH: copied and Hax0rd from admin/enrol.php and admin/filters.php
|
|
*
|
|
*/
|
|
|
|
require_once('../config.php');
|
|
require_once($CFG->libdir.'/adminlib.php');
|
|
require_once($CFG->libdir.'/tablelib.php');
|
|
|
|
require_login();
|
|
require_capability('moodle/site:config', context_system::instance());
|
|
|
|
$returnurl = new moodle_url('/admin/settings.php', array('section'=>'manageauths'));
|
|
|
|
$PAGE->set_url($returnurl);
|
|
|
|
$action = optional_param('action', '', PARAM_ALPHANUMEXT);
|
|
$auth = optional_param('auth', '', PARAM_PLUGIN);
|
|
|
|
get_enabled_auth_plugins(true); // fix the list of enabled auths
|
|
if (empty($CFG->auth)) {
|
|
$authsenabled = array();
|
|
} else {
|
|
$authsenabled = explode(',', $CFG->auth);
|
|
}
|
|
|
|
if (!empty($auth) and !exists_auth_plugin($auth)) {
|
|
print_error('pluginnotinstalled', 'auth', $returnurl, $auth);
|
|
}
|
|
|
|
////////////////////////////////////////////////////////////////////////////////
|
|
// process actions
|
|
|
|
if (!confirm_sesskey()) {
|
|
redirect($returnurl);
|
|
}
|
|
|
|
switch ($action) {
|
|
case 'disable':
|
|
// remove from enabled list
|
|
$key = array_search($auth, $authsenabled);
|
|
if ($key !== false) {
|
|
unset($authsenabled[$key]);
|
|
set_config('auth', implode(',', $authsenabled));
|
|
}
|
|
|
|
if ($auth == $CFG->registerauth) {
|
|
set_config('registerauth', '');
|
|
}
|
|
\core\session\manager::gc(); // Remove stale sessions.
|
|
core_plugin_manager::reset_caches();
|
|
break;
|
|
|
|
case 'enable':
|
|
// add to enabled list
|
|
if (!in_array($auth, $authsenabled)) {
|
|
$authsenabled[] = $auth;
|
|
$authsenabled = array_unique($authsenabled);
|
|
set_config('auth', implode(',', $authsenabled));
|
|
}
|
|
\core\session\manager::gc(); // Remove stale sessions.
|
|
core_plugin_manager::reset_caches();
|
|
break;
|
|
|
|
case 'down':
|
|
$key = array_search($auth, $authsenabled);
|
|
// check auth plugin is valid
|
|
if ($key === false) {
|
|
print_error('pluginnotenabled', 'auth', $returnurl, $auth);
|
|
}
|
|
// move down the list
|
|
if ($key < (count($authsenabled) - 1)) {
|
|
$fsave = $authsenabled[$key];
|
|
$authsenabled[$key] = $authsenabled[$key + 1];
|
|
$authsenabled[$key + 1] = $fsave;
|
|
set_config('auth', implode(',', $authsenabled));
|
|
}
|
|
break;
|
|
|
|
case 'up':
|
|
$key = array_search($auth, $authsenabled);
|
|
// check auth is valid
|
|
if ($key === false) {
|
|
print_error('pluginnotenabled', 'auth', $returnurl, $auth);
|
|
}
|
|
// move up the list
|
|
if ($key >= 1) {
|
|
$fsave = $authsenabled[$key];
|
|
$authsenabled[$key] = $authsenabled[$key - 1];
|
|
$authsenabled[$key - 1] = $fsave;
|
|
set_config('auth', implode(',', $authsenabled));
|
|
}
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
redirect($returnurl);
|
|
|
|
|
|
|