Search moodle.org's
Developer Documentation

See Release Notes
Long Term Support Release

  • Bug fixes for general core bugs in 3.9.x will end* 10 May 2021 (12 months).
  • Bug fixes for security issues in 3.9.x will end* 8 May 2023 (36 months).
  • PHP version: minimum PHP 7.2.0 Note: minimum PHP version has increased since Moodle 3.8. PHP 7.3.x and 7.4.x are supported too.

Differences Between: [Versions 39 and 311] [Versions 39 and 400] [Versions 39 and 401]

   1  <?php
   2  /**
   3   * Edit configuration for an individual auth plugin
   4   */
   5  
   6  require_once '../config.php';
   7  require_once $CFG->libdir.'/adminlib.php';
   8  
   9  $auth = required_param('auth', PARAM_PLUGIN);
  10  $PAGE->set_pagetype('admin-auth-' . $auth);
  11  
  12  admin_externalpage_setup('authsetting'.$auth);
  13  
  14  $authplugin = get_auth_plugin($auth);
  15  $err = array();
  16  
  17  $returnurl = "$CFG->wwwroot/$CFG->admin/settings.php?section=manageauths";
  18  
  19  debugging("Use of config.html files in authentication plugins have been deprecated. " .
  20            " Please migrate your plugin to use the admin settings API", DEBUG_DEVELOPER);
  21  
  22  // save configuration changes
  23  if ($frm = data_submitted() and confirm_sesskey()) {
  24  
  25      $authplugin->validate_form($frm, $err);
  26  
  27      if (count($err) == 0) {
  28  
  29          // save plugin config
  30          if ($authplugin->process_config($frm)) {
  31  
  32              // save field lock configuration
  33              foreach ($frm as $name => $value) {
  34                  if (preg_match('/^lockconfig_(.+?)$/', $name, $matches)) {
  35                      $plugin = "auth/$auth";
  36                      $name   = $matches[1];
  37                      set_config($name, $value, $plugin);
  38                  }
  39              }
  40              redirect($returnurl);
  41              exit;
  42          }
  43      } else {
  44          foreach ($err as $key => $value) {
  45              $focus = "form.$key";
  46          }
  47      }
  48  } else {
  49      $frmlegacystyle = get_config('auth/'.$auth);
  50      $frmnewstyle    = get_config('auth_'.$auth);
  51      $frm = (object)array_merge((array)$frmlegacystyle, (array)$frmnewstyle);
  52  }
  53  
  54  $user_fields = $authplugin->userfields;
  55  //$user_fields = array("firstname", "lastname", "email", "phone1", "phone2", "institution", "department", "address", "city", "country", "description", "idnumber", "lang");
  56  
  57  /// Get the auth title (from core or own auth lang files)
  58      $authtitle = $authplugin->get_title();
  59  /// Get the auth descriptions (from core or own auth lang files)
  60      $authdescription = $authplugin->get_description();
  61  
  62  // output configuration form
  63  echo $OUTPUT->header();
  64  
  65  // choose an authentication method
  66  echo "<form id=\"authmenu\" method=\"post\" action=\"auth_config.php\">\n";
  67  echo "<div>\n";
  68  echo "<input type=\"hidden\" name=\"sesskey\" value=\"".sesskey()."\" />\n";
  69  echo "<input type=\"hidden\" name=\"auth\" value=\"".$auth."\" />\n";
  70  
  71  // auth plugin description
  72  echo $OUTPUT->box_start();
  73  echo $OUTPUT->heading($authtitle);
  74  echo $OUTPUT->box_start('informationbox');
  75  echo $authdescription;
  76  echo $OUTPUT->box_end();
  77  echo "<hr />\n";
  78  $authplugin->config_form($frm, $err, $user_fields);
  79  echo $OUTPUT->box_end();
  80  echo '<p style="text-align: center"><input type="submit" value="' . get_string("savechanges") . "\" /></p>\n";
  81  echo "</div>\n";
  82  echo "</form>\n";
  83  
  84  $PAGE->requires->string_for_js('unmaskpassword', 'core_form');
  85  $PAGE->requires->yui_module('moodle-auth-passwordunmask', 'M.auth.passwordunmask');
  86  
  87  echo $OUTPUT->footer();
  88  exit;
  89  
  90  /// Functions /////////////////////////////////////////////////////////////////
  91  
  92  
  93  /**
  94   * auth field locking
  95   * Good enough for most auth plugins
  96   * but some may want a custom one if they are offering
  97   * other options
  98   * Note: lockconfig_ fields have special handling.
  99   *
 100   * @param string $auth authentication plugin shortname
 101   * @param array $user_fields user profile fields
 102   * @param string $helptext help text to be displayed at top of form
 103   * @param boolean $retrieveopts Map fields or lock only.
 104   * @param boolean $updateopts Allow remote updates
 105   * @param array $customfields list of custom profile fields
 106   * @deprecated since Moodle 3.3
 107   */
 108  function print_auth_lock_options($auth, $user_fields, $helptext, $retrieveopts, $updateopts, $customfields = array()) {
 109      global $DB, $OUTPUT;
 110      debugging("The function 'print_auth_lock_options' has been deprecated, " .
 111                "Please migrate your code to use the admin settings API and use the function 'display_auth_lock_options' instead. ",
 112                DEBUG_DEVELOPER);
 113  
 114      echo '<tr><td colspan="3">';
 115      if ($retrieveopts) {
 116          echo $OUTPUT->heading(get_string('auth_data_mapping', 'auth'));
 117      } else {
 118          echo $OUTPUT->heading(get_string('auth_fieldlocks', 'auth'));
 119      }
 120      echo '</td></tr>';
 121  
 122      $lockoptions = array ('unlocked'        => get_string('unlocked', 'auth'),
 123                            'unlockedifempty' => get_string('unlockedifempty', 'auth'),
 124                            'locked'          => get_string('locked', 'auth'));
 125      $updatelocaloptions = array('oncreate'  => get_string('update_oncreate', 'auth'),
 126                                  'onlogin'   => get_string('update_onlogin', 'auth'));
 127      $updateextoptions = array('0'  => get_string('update_never', 'auth'),
 128                                '1'   => get_string('update_onupdate', 'auth'));
 129  
 130      $pluginconfig = get_config("auth/$auth");
 131  
 132      // Helptext is on a field with rowspan.
 133      if (empty($helptext)) {
 134          $helptext = '&nbsp;';
 135      }
 136  
 137      // If we have custom fields then merge them with user fields.
 138      if (!empty($customfields)) {
 139          $user_fields = array_merge($user_fields, $customfields);
 140      }
 141  
 142      if (!empty($customfields)) {
 143          $customfieldname = $DB->get_records('user_info_field', null, '', 'shortname, name');
 144      }
 145      foreach ($user_fields as $field) {
 146          // Define some vars we'll work with.
 147          if (!isset($pluginconfig->{"field_map_$field"})) {
 148              $pluginconfig->{"field_map_$field"} = '';
 149          }
 150          if (!isset($pluginconfig->{"field_updatelocal_$field"})) {
 151              $pluginconfig->{"field_updatelocal_$field"} = '';
 152          }
 153          if (!isset($pluginconfig->{"field_updateremote_$field"})) {
 154              $pluginconfig->{"field_updateremote_$field"} = '';
 155          }
 156          if (!isset($pluginconfig->{"field_lock_$field"})) {
 157              $pluginconfig->{"field_lock_$field"} = '';
 158          }
 159  
 160          // Define the fieldname we display to the  user.
 161          $fieldname = $field;
 162          if ($fieldname === 'lang') {
 163              $fieldname = get_string('language');
 164          } elseif (!empty($customfields) && in_array($field, $customfields)) {
 165              // If custom field then pick name from database.
 166              $fieldshortname = str_replace('profile_field_', '', $fieldname);
 167              $fieldname = $customfieldname[$fieldshortname]->name;
 168              if (core_text::strlen($fieldshortname) > 67) {
 169                  // If custom profile field name is longer than 67 characters we will not be able to store the setting
 170                  // such as 'field_updateremote_profile_field_NOTSOSHORTSHORTNAME' in the database because the character
 171                  // limit for the setting name is 100.
 172                  continue;
 173              }
 174          } elseif ($fieldname == 'url') {
 175              $fieldname = get_string('webpage');
 176          } else {
 177              $fieldname = get_string($fieldname);
 178          }
 179          if ($retrieveopts) {
 180              $varname = 'field_map_' . $field;
 181  
 182              echo '<tr valign="top"><td align="right">';
 183              echo '<label for="lockconfig_'.$varname.'">'.$fieldname.'</label>';
 184              echo '</td><td>';
 185  
 186              echo "<input id=\"lockconfig_{$varname}\" name=\"lockconfig_{$varname}\" type=\"text\" size=\"30\" value=\"{$pluginconfig->$varname}\" />";
 187              echo '<div style="text-align: right">';
 188              echo '<label for="menulockconfig_field_updatelocal_'.$field.'">'.get_string('auth_updatelocal', 'auth') . '</label>&nbsp;';
 189              echo html_writer::select($updatelocaloptions, "lockconfig_field_updatelocal_{$field}", $pluginconfig->{"field_updatelocal_$field"}, false);
 190              echo '<br />';
 191              if ($updateopts) {
 192                  echo '<label for="menulockconfig_field_updateremote_'.$field.'">'.get_string('auth_updateremote', 'auth') . '</label>&nbsp;';
 193                  echo html_writer::select($updateextoptions, "lockconfig_field_updateremote_{$field}", $pluginconfig->{"field_updateremote_$field"}, false);
 194                  echo '<br />';
 195              }
 196              echo '<label for="menulockconfig_field_lock_'.$field.'">'.get_string('auth_fieldlock', 'auth') . '</label>&nbsp;';
 197              echo html_writer::select($lockoptions, "lockconfig_field_lock_{$field}", $pluginconfig->{"field_lock_$field"}, false);
 198              echo '</div>';
 199          } else {
 200              echo '<tr valign="top"><td align="right">';
 201              echo '<label for="menulockconfig_field_lock_'.$field.'">'.$fieldname.'</label>';
 202              echo '</td><td>';
 203              echo html_writer::select($lockoptions, "lockconfig_field_lock_{$field}", $pluginconfig->{"field_lock_$field"}, false);
 204          }
 205          echo '</td>';
 206          if (!empty($helptext)) {
 207              echo '<td rowspan="' . count($user_fields) . '">' . $helptext . '</td>';
 208              $helptext = '';
 209          }
 210          echo '</tr>';
 211      }
 212  }