4 * Allows admin to edit all auth plugin settings.
6 * JH: copied and Hax0rd from admin/enrol.php and admin/filters.php
10 require_once('../config.php');
11 require_once($CFG->libdir
.'/adminlib.php');
12 require_once($CFG->libdir
.'/tablelib.php');
16 $returnurl = new moodle_url('/admin/settings.php', array('section'=>'manageauths'));
18 $PAGE->set_url($returnurl);
20 $action = optional_param('action', '', PARAM_ALPHANUMEXT
);
21 $auth = optional_param('auth', '', PARAM_PLUGIN
);
23 get_enabled_auth_plugins(true); // fix the list of enabled auths
24 if (empty($CFG->auth
)) {
25 $authsenabled = array();
27 $authsenabled = explode(',', $CFG->auth
);
30 if (!empty($auth) and !exists_auth_plugin($auth)) {
31 print_error('pluginnotinstalled', 'auth', $returnurl, $auth);
34 ////////////////////////////////////////////////////////////////////////////////
37 if (!confirm_sesskey()) {
43 // remove from enabled list
44 $key = array_search($auth, $authsenabled);
46 unset($authsenabled[$key]);
47 $value = implode(',', $authsenabled);
48 add_to_config_log('auth', $CFG->auth
, $value, 'core');
49 set_config('auth', $value);
52 if ($auth == $CFG->registerauth
) {
53 set_config('registerauth', '');
55 \core\session\manager
::gc(); // Remove stale sessions.
56 core_plugin_manager
::reset_caches();
60 // add to enabled list
61 if (!in_array($auth, $authsenabled)) {
62 $authsenabled[] = $auth;
63 $authsenabled = array_unique($authsenabled);
64 $value = implode(',', $authsenabled);
65 add_to_config_log('auth', $CFG->auth
, $value, 'core');
66 set_config('auth', $value);
69 \core\session\manager
::gc(); // Remove stale sessions.
70 core_plugin_manager
::reset_caches();
74 $key = array_search($auth, $authsenabled);
75 // check auth plugin is valid
77 print_error('pluginnotenabled', 'auth', $returnurl, $auth);
80 if ($key < (count($authsenabled) - 1)) {
81 $fsave = $authsenabled[$key];
82 $authsenabled[$key] = $authsenabled[$key +
1];
83 $authsenabled[$key +
1] = $fsave;
84 $value = implode(',', $authsenabled);
85 add_to_config_log('auth', $CFG->auth
, $value, 'core');
86 set_config('auth', $value);
91 $key = array_search($auth, $authsenabled);
92 // check auth is valid
94 print_error('pluginnotenabled', 'auth', $returnurl, $auth);
98 $fsave = $authsenabled[$key];
99 $authsenabled[$key] = $authsenabled[$key - 1];
100 $authsenabled[$key - 1] = $fsave;
101 $value = implode(',', $authsenabled);
102 add_to_config_log('auth', $CFG->auth
, $value, 'core');
103 set_config('auth', $value);
111 redirect($returnurl);