libdir.'/adminlib.php'); $adminroot = admin_get_root(); admin_externalpage_setup('userauthentication', $adminroot); $auth = optional_param('auth', '', PARAM_SAFEDIR); $focus = ''; /// If data submitted, then process and store. if ($config = data_submitted()) { if (!confirm_sesskey()) { error(get_string('confirmsesskeybad', 'error')); } $config = (array)$config; // extract and sanitize the auth key explicitly $modules = get_list_of_plugins("auth"); if (in_array($config['auth'], $modules)) { $auth = $config['auth']; } else { notify("Error defining the authentication method"); } // load the auth plugin library require_once("{$CFG->dirroot}/auth/$auth/lib.php"); $err = array(); if (function_exists('auth_validate_form')) { auth_validate_form($config, $err); } if (count($err) == 0) { foreach ($config as $name => $value) { if (preg_match('/^pluginconfig_(.+?)$/', $name, $matches)) { $plugin = "auth/$auth"; $name = $matches[1]; if (! set_config($name, $value, $plugin)) { notify("Problem saving config $name as $value for plugin $plugin"); } } else { // normal handling for if (! set_config($name, $value)) { notify("Problem saving config $name as $value"); } } } redirect("auth.php?sesskey=$USER->sesskey", get_string("changessaved"), 1); exit; } else { foreach ($err as $key => $value) { $focus = "form.$key"; } } } /// Otherwise fill and print the form. if (empty($config)) { $config = $CFG; } $modules = get_list_of_plugins("auth"); $options = array(); foreach ($modules as $module) { $options[$module] = get_string("auth_$module"."title", "auth"); } asort($options); if (!empty($auth) && in_array($auth, $modules)) { } else { $auth = $config->auth; } // changepassword link replaced by individual auth setting if (!empty($config->changepassword)) { if (empty($config->{'auth_'.$auth.'_changepasswordurl'})) { $config->{'auth_'.$auth.'_changepasswordurl'} = $config->changepassword; } set_config('changepassword',''); } $auth = clean_param($auth,PARAM_SAFEDIR); require_once("$CFG->dirroot/auth/$auth/lib.php"); //just to make sure that current authentication functions are loaded if (! isset($config->guestloginbutton)) { $config->guestloginbutton = 1; } if (! isset($config->alternateloginurl)) { $config->alternateloginurl = ''; } if (! isset($config->auth_instructions)) { $config->auth_instructions = ""; } if (! isset($config->changepassword)) { $config->changepassword = ""; } if (! isset($config->{'auth_'.$auth.'_changepasswordurl'})) { $config->{'auth_'.$auth.'_changepasswordurl'} = ''; } if (! isset($config->{'auth_'.$auth.'_changepasswordhelp'})) { $config->{'auth_'.$auth.'_changepasswordhelp'} = ''; } $user_fields = array("firstname", "lastname", "email", "phone1", "phone2", "department", "address", "city", "country", "description", "idnumber", "lang"); $guestoptions[0] = get_string("hide"); $guestoptions[1] = get_string("show"); $createoptions[0] = get_string("no"); $createoptions[1] = get_string("yes"); $stradministration = get_string("administration"); $strauthentication = get_string("authentication"); $strauthenticationoptions = get_string("authenticationoptions","auth"); $strsettings = get_string("settings"); $strusers = get_string("users"); admin_externalpage_print_header($adminroot); echo "
"; echo "
framename}\" name=\"authmenu\" method=\"post\" action=\"auth.php\">"; echo "sesskey."\" />"; print_string("chooseauthmethod","auth"); echo '  '; choose_from_menu ($options, "auth", $auth, "","document.location='auth.php?sesskey=$USER->sesskey&auth='+document.authmenu.auth.options[document.authmenu.auth.selectedIndex].value", ""); echo "

"; print_simple_box_start("center", "100%"); print_heading($options[$auth]); print_simple_box_start("center", "60%", '', 5, 'informationbox'); print_string("auth_$auth"."description", "auth"); print_simple_box_end(); echo "
"; print_heading($strsettings); echo ""; require_once("$CFG->dirroot/auth/$auth/config.html"); $CFG->pagepath = 'auth/' . $auth; echo ''; if ($auth != "email" and $auth != "none" and $auth != "manual") { // display box for URL to change password. NB now on a per-method basis (multiple auth) echo ""; echo ""; echo ""; echo ""; // display textbox for lost password help. NB now on a per-method basis (multiple auth) echo ""; echo ""; echo ""; echo ""; } echo ""; echo ""; echo ""; echo ""; if (function_exists('auth_user_create')){ echo ""; echo ""; echo ""; echo ""; } /// An alternate url for the login form. It means we can use login forms that are integrated /// into non-moodle pages echo ''; echo ''; echo ''; echo ''; echo ''; echo '
'; print_heading(get_string('auth_common_settings', 'auth')); echo '
"; print_string("changepassword", "auth"); echo ":"; $passurl = $config->{'auth_'.$auth.'_changepasswordurl'}; echo ""; echo ""; print_string("auth_changepasswordurl_expl","auth",$auth); echo "
"; print_string("auth_changepasswordhelp", "auth"); echo ":"; $passhelp = $config->{'auth_'.$auth.'_changepasswordhelp'}; echo "\n"; echo ""; print_string("auth_changepasswordhelp_expl","auth",$auth); echo "
"; print_string("guestloginbutton", "auth"); echo ":"; choose_from_menu($guestoptions, "guestloginbutton", $config->guestloginbutton, ""); echo ""; print_string("showguestlogin","auth"); echo "
"; print_string("auth_user_create", "auth"); echo ":"; choose_from_menu($createoptions, "auth_user_create", $config->auth_user_create, ""); echo ""; print_string("auth_user_creation","auth"); echo "
'; print_string('alternateloginurl', 'auth'); echo ''; echo ''; echo ''; print_string('alternatelogin', 'auth', htmlspecialchars($CFG->wwwroot.'/login/index.php')); echo '
'; echo '

'; echo ''; print_simple_box_end(); admin_externalpage_print_footer($adminroot); exit; /// Functions ///////////////////////////////////////////////////////////////// // // Good enough for most auth plugins // but some may want a custom one if they are offering // other options // Note: pluginconfig_ fields have special handling. function print_auth_lock_options ($auth, $user_fields, $helptext, $retrieveopts, $updateopts) { echo ''; if ($retrieveopts) { print_heading(get_string('auth_data_mapping', 'auth')); } else { print_heading(get_string('auth_fieldlocks', 'auth')); } echo ''; $lockoptions = array ('unlocked' => get_string('unlocked', 'auth'), 'unlockedifempty' => get_string('unlockedifempty', 'auth'), 'locked' => get_string('locked', 'auth')); $updatelocaloptions = array('oncreate' => get_string('update_oncreate', 'auth'), 'onlogin' => get_string('update_onlogin', 'auth')); $updateextoptions = array('0' => get_string('update_never', 'auth'), '1' => get_string('update_onupdate', 'auth')); $pluginconfig = get_config("auth/$auth"); // helptext is on a field with rowspan if (empty($helptext)) { $helptext = ' '; } foreach ($user_fields as $field) { // Define some vars we'll work with if(empty($pluginconfig->{"field_map_$field"})) { $pluginconfig->{"field_map_$field"} = ''; } if(empty($pluginconfig->{"field_updatelocal_$field"})) { $pluginconfig->{"field_updatelocal_$field"} = ''; } if (empty($pluginconfig->{"field_updateremote_$field"})) { $pluginconfig->{"field_updateremote_$field"} = ''; } if (empty($pluginconfig->{"field_lock_$field"})) { $pluginconfig->{"field_lock_$field"} = ''; } // define the fieldname we display to the user $fieldname = $field; if ($fieldname === 'lang') { $fieldname = get_string('language'); } elseif (preg_match('/^(.+?)(\d+)$/', $fieldname, $matches)) { $fieldname = get_string($matches[1]) . ' ' . $matches[2]; } else { $fieldname = get_string($fieldname); } echo ''; echo $fieldname; echo ''; if ($retrieveopts) { $varname = 'field_map_' . $field; echo "$varname}\">"; echo '
'; echo get_string('auth_updatelocal', 'auth') . '  '; choose_from_menu($updatelocaloptions, "pluginconfig_field_updatelocal_{$field}", $pluginconfig->{"field_updatelocal_$field"}, ""); echo '
'; if ($updateopts) { echo get_string('auth_updateremote', 'auth') . '  '; '  '; choose_from_menu($updateextoptions, "pluginconfig_field_updateremote_{$field}", $pluginconfig->{"field_updateremote_$field"}, ""); echo '
'; } echo get_string('auth_fieldlock', 'auth') . '  '; choose_from_menu($lockoptions, "pluginconfig_field_lock_{$field}", $pluginconfig->{"field_lock_$field"}, ""); echo '
'; } else { choose_from_menu($lockoptions, "pluginconfig_field_lock_{$field}", $pluginconfig->{"field_lock_$field"}, ""); } echo ''; if (!empty($helptext)) { echo '' . $helptext . ''; $helptext = ''; } echo ''; } } ?>