Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.3.x will end 7 October 2024 (12 months).
  • Bug fixes for security issues in 4.3.x will end 21 April 2025 (18 months).
  • PHP version: minimum PHP 8.0.0 Note: minimum PHP version has increased since Moodle 4.1. PHP 8.2.x is supported too.
   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   * Display page to a digital minor. Display support contact details.
  19   *
  20   * @package    core
  21   * @subpackage auth
  22   * @copyright  2018 Mihail Geshoski <mihail@moodle.com>
  23   * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
  24   */
  25  
  26  require('../config.php');
  27  require_once($CFG->libdir . '/authlib.php');
  28  
  29  $authplugin = signup_is_enabled();
  30  
  31  if (!$authplugin || !\core_auth\digital_consent::is_age_digital_consent_verification_enabled()) {
  32      // Redirect user if signup or digital age of consent verification is disabled.
  33      redirect(new moodle_url('/'), get_string('verifyagedigitalconsentnotpossible', 'error'));
  34  }
  35  
  36  $PAGE->set_context(context_system::instance());
  37  $PAGE->set_url($CFG->wwwroot.'/login/digital_minor.php');
  38  
  39  if (isloggedin() and !isguestuser()) {
  40      // Prevent signing up when already logged in.
  41      redirect(new moodle_url('/'), get_string('cannotsignup', 'error', fullname($USER)));
  42  }
  43  
  44  $cache = cache::make('core', 'presignup');
  45  $isminor = $cache->get('isminor');
  46  if ($isminor !== 'yes') {
  47      // Redirect when the signup session does not exists, minor check has not been done or the user is not a minor.
  48      redirect(new moodle_url('/login/index.php'));
  49  }
  50  
  51  $PAGE->navbar->add(get_string('login'));
  52  $PAGE->navbar->add(get_string('digitalminor'));
  53  
  54  $PAGE->set_pagelayout('login');
  55  $PAGE->set_title(get_string('digitalminor'));
  56  $sitename = format_string($SITE->fullname);
  57  $PAGE->set_heading($sitename);
  58  
  59  $page = new \core_auth\output\digital_minor_page();
  60  
  61  echo $OUTPUT->header();
  62  echo $OUTPUT->render($page);
  63  echo $OUTPUT->footer();
  64