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 400] [Versions 39 and 401] [Versions 39 and 402] [Versions 39 and 403]

   1  <?php
   2  // This file is part of Moodle - http://moodle.org/
   3  //
   4  // Moodle is free software: you can redistribute it and/or modify
   5  // it under the terms of the GNU General Public License as published by
   6  // the Free Software Foundation, either version 3 of the License, or
   7  // (at your option) any later version.
   8  //
   9  // Moodle is distributed in the hope that it will be useful,
  10  // but WITHOUT ANY WARRANTY; without even the implied warranty of
  11  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
  12  // GNU General Public License for more details.
  13  //
  14  // You should have received a copy of the GNU General Public License
  15  // along with Moodle.  If not, see <http://www.gnu.org/licenses/>.
  16  
  17  /**
  18   * Login renderable.
  19   *
  20   * @package    core_auth
  21   * @copyright  2016 Frédéric Massart - FMCorz.net
  22   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  23   */
  24  
  25  namespace core_auth\output;
  26  defined('MOODLE_INTERNAL') || die();
  27  
  28  require_once($CFG->libdir . '/externallib.php');
  29  
  30  use context_system;
  31  use help_icon;
  32  use moodle_url;
  33  use renderable;
  34  use renderer_base;
  35  use stdClass;
  36  use templatable;
  37  
  38  /**
  39   * Login renderable class.
  40   *
  41   * @package    core_auth
  42   * @copyright  2016 Frédéric Massart - FMCorz.net
  43   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  44   */
  45  class login implements renderable, templatable {
  46  
  47      /** @var bool Whether to auto focus the form fields. */
  48      public $autofocusform;
  49      /** @var bool Whether we can login as guest. */
  50      public $canloginasguest;
  51      /** @var bool Whether we can login by e-mail. */
  52      public $canloginbyemail;
  53      /** @var bool Whether we can sign-up. */
  54      public $cansignup;
  55      /** @var help_icon The cookies help icon. */
  56      public $cookieshelpicon;
  57      /** @var string The error message, if any. */
  58      public $error;
  59      /** @var moodle_url Forgot password URL. */
  60      public $forgotpasswordurl;
  61      /** @var array Additional identify providers, contains the keys 'url', 'name' and 'icon'. */
  62      public $identityproviders;
  63      /** @var string Login instructions, if any. */
  64      public $instructions;
  65      /** @var moodle_url The form action login URL. */
  66      public $loginurl;
  67      /** @var bool Whether the username should be remembered. */
  68      public $rememberusername;
  69      /** @var moodle_url The sign-up URL. */
  70      public $signupurl;
  71      /** @var string The user name to pre-fill the form with. */
  72      public $username;
  73      /** @var string The csrf token to limit login to requests that come from the login form. */
  74      public $logintoken;
  75      /** @var string Maintenance message, if Maintenance is enabled. */
  76      public $maintenance;
  77  
  78      /**
  79       * Constructor.
  80       *
  81       * @param array $authsequence The enabled sequence of authentication plugins.
  82       * @param string $username The username to display.
  83       */
  84      public function __construct(array $authsequence, $username = '') {
  85          global $CFG;
  86  
  87          $this->username = $username;
  88  
  89          $this->canloginasguest = $CFG->guestloginbutton and !isguestuser();
  90          $this->canloginbyemail = !empty($CFG->authloginviaemail);
  91          $this->cansignup = $CFG->registerauth == 'email' || !empty($CFG->registerauth);
  92          if ($CFG->rememberusername == 0) {
  93              $this->cookieshelpicon = new help_icon('cookiesenabledonlysession', 'core');
  94              $this->rememberusername = false;
  95          } else {
  96              $this->cookieshelpicon = new help_icon('cookiesenabled', 'core');
  97              $this->rememberusername = true;
  98          }
  99  
 100          $this->autofocusform = !empty($CFG->loginpageautofocus);
 101  
 102          $this->forgotpasswordurl = new moodle_url('/login/forgot_password.php');
 103          $this->loginurl = new moodle_url('/login/index.php');
 104          $this->signupurl = new moodle_url('/login/signup.php');
 105  
 106          // Authentication instructions.
 107          $this->instructions = $CFG->auth_instructions;
 108          if (is_enabled_auth('none')) {
 109              $this->instructions = get_string('loginstepsnone');
 110          } else if ($CFG->registerauth == 'email' && empty($this->instructions)) {
 111              $this->instructions = get_string('loginsteps', 'core', 'signup.php');
 112          }
 113  
 114          if ($CFG->maintenance_enabled == true && !empty($CFG->maintenance_message)) {
 115              $this->maintenance = $CFG->maintenance_message;
 116          }
 117  
 118          // Identity providers.
 119          $this->identityproviders = \auth_plugin_base::get_identity_providers($authsequence);
 120          $this->logintoken = \core\session\manager::get_login_token();
 121      }
 122  
 123      /**
 124       * Set the error message.
 125       *
 126       * @param string $error The error message.
 127       */
 128      public function set_error($error) {
 129          $this->error = $error;
 130      }
 131  
 132      public function export_for_template(renderer_base $output) {
 133  
 134          $identityproviders = \auth_plugin_base::prepare_identity_providers_for_output($this->identityproviders, $output);
 135  
 136          $data = new stdClass();
 137          $data->autofocusform = $this->autofocusform;
 138          $data->canloginasguest = $this->canloginasguest;
 139          $data->canloginbyemail = $this->canloginbyemail;
 140          $data->cansignup = $this->cansignup;
 141          $data->cookieshelpicon = $this->cookieshelpicon->export_for_template($output);
 142          $data->error = $this->error;
 143          $data->forgotpasswordurl = $this->forgotpasswordurl->out(false);
 144          $data->hasidentityproviders = !empty($this->identityproviders);
 145          $data->hasinstructions = !empty($this->instructions) || $this->cansignup;
 146          $data->identityproviders = $identityproviders;
 147          list($data->instructions, $data->instructionsformat) = external_format_text($this->instructions, FORMAT_MOODLE,
 148              context_system::instance()->id);
 149          $data->loginurl = $this->loginurl->out(false);
 150          $data->rememberusername = $this->rememberusername;
 151          $data->signupurl = $this->signupurl->out(false);
 152          $data->username = $this->username;
 153          $data->logintoken = $this->logintoken;
 154          $data->maintenance = format_text($this->maintenance, FORMAT_MOODLE);
 155  
 156          return $data;
 157      }
 158  }