AutorÃa | Ultima modificación | Ver Log |
<?php// This file is part of Moodle - http://moodle.org///// Moodle is free software: you can redistribute it and/or modify// it under the terms of the GNU General Public License as published by// the Free Software Foundation, either version 3 of the License, or// (at your option) any later version.//// Moodle is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the// GNU General Public License for more details.//// You should have received a copy of the GNU General Public License// along with Moodle. If not, see <http://www.gnu.org/licenses/>.declare(strict_types=1);namespace enrol_self\form;use core\context\course as context_course;use core\context\system as context_system;use core_form\dynamic_form;use core_text;use html_writer;use moodle_url;/*** Form for entering password for self enrolment** @package enrol_self* @copyright Marina Glancy* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later*/class enrol_form extends dynamic_form {/** @var \stdClass */protected $instance;/** @var \enrol_self_plugin */protected $plugin = null;/*** Returns the enrolment method** @return \enrol_self_plugin*/protected function get_plugin(): \enrol_self_plugin {global $CFG;require_once($CFG->dirroot . '/lib/enrollib.php');if ($this->plugin === null) {$this->plugin = enrol_get_plugin('self');}return $this->plugin;}/*** Returns the instance of the enrolment method** @return \stdClass*/protected function get_instance(): \stdClass {global $DB, $CFG;require_once($CFG->dirroot . '/lib/enrollib.php');if ($this->instance === null) {// Method enrol_get_instances() will also validate that the enrolment method and the instance are enabled.$courseid = $this->optional_param('id', 0, PARAM_INT);$instanceid = $this->optional_param('instance', 0, PARAM_INT);$instances = enrol_get_instances($courseid, true);$this->instance = $instances[$instanceid] ?? null;if (empty($this->instance) || $this->instance->enrol !== 'self') {throw new \moodle_exception('invalidenrolinstance', 'enrol');}}return $this->instance;}#[\Override]public function definition() {global $USER, $OUTPUT, $CFG;$mform = $this->_form;$mform->addElement('password', 'enrolpassword', get_string('password', 'enrol_self'));// Display keyholders - list of users who have 'enrol/self:holdkey' capability.$context = context_course::instance($this->instance->courseid);$userfieldsapi = \core_user\fields::for_userpic();$ufields = $userfieldsapi->get_sql('u', false, '', '', false)->selects;$keyholders = get_users_by_capability($context, 'enrol/self:holdkey', $ufields);$keyholdercount = 0;foreach ($keyholders as $keyholder) {$keyholdercount++;if ($keyholdercount === 1) {$mform->addElement('static', 'keyholder', '', get_string('keyholder', 'enrol_self'));}if ($USER->id == $keyholder->id|| has_capability('moodle/user:viewdetails', context_system::instance())|| has_coursecontact_role($keyholder->id)) {$profileurl = new moodle_url('/user/profile.php', ['id' => $keyholder->id, 'course' => $this->instance->courseid]);$profilelink = html_writer::link($profileurl, fullname($keyholder));} else {$profilelink = fullname($keyholder);}$profilepic = $OUTPUT->user_picture($keyholder, ['size' => 35, 'courseid' => $this->instance->courseid]);$mform->addElement('static', 'keyholder' . $keyholdercount, '', $profilepic . $profilelink);}$mform->addElement('hidden', 'id');$mform->setType('id', PARAM_INT);$mform->addElement('hidden', 'instance');$mform->setType('instance', PARAM_INT);}#[\Override]public function validation($data, $files) {global $DB, $CFG;require_once($CFG->dirroot.'/enrol/self/locallib.php');$errors = parent::validation($data, $files);$instance = $this->get_instance();if ($data['enrolpassword'] !== $instance->password) {if ($instance->customint1) {// Check group enrolment key.if (!enrol_self_check_group_enrolment_key($instance->courseid, $data['enrolpassword'])) {// We can not hint because there are probably multiple passwords.$errors['enrolpassword'] = get_string('passwordinvalid', 'enrol_self');}} else {$plugin = enrol_get_plugin('self');if ($plugin->get_config('showhint')) {$hint = core_text::substr($instance->password, 0, 1);$errors['enrolpassword'] = get_string('passwordinvalidhint', 'enrol_self', $hint);} else {$errors['enrolpassword'] = get_string('passwordinvalid', 'enrol_self');}}}return $errors;}#[\Override]protected function check_access_for_dynamic_submission(): void {global $USER, $CFG;$instance = $this->get_instance();$courseid = $instance->courseid;$course = get_course($courseid);$context = context_course::instance($instance->courseid);if (!\core_course_category::can_view_course_info($course) && !is_enrolled($context, $USER, '', true)) {throw new \moodle_exception('coursehidden', '', $CFG->wwwroot . '/');}if (isguestuser()) {throw new \moodle_exception('noguestaccess', 'enrol');}$canselfenrol = $this->get_plugin()->can_self_enrol($instance);if ($canselfenrol !== true) {throw new \moodle_exception($canselfenrol);}if (!$instance->password) {throw new \moodle_exception('nopassword', 'enrol_self');}}#[\Override]protected function get_context_for_dynamic_submission(): \context {// This form is used for users who are not yet enrolled in the course and do not have access to the course.// For the purpose of permission checks they must be able to access the course category for this course.return context_course::instance($this->get_instance()->courseid)->get_parent_context();}#[\Override]protected function get_page_url_for_dynamic_submission(): moodle_url {$instance = $this->get_instance();return new moodle_url('/enrol/index.php', ['id' => $instance->courseid, 'instance' => $instance->id]);}/*** Process the form submission, used if form was submitted via AJAX** Enrols the user in the course and returns the URL to redirect to** @return string*/public function process_dynamic_submission() {global $CFG, $SESSION;$this->get_plugin()->enrol_self($this->get_instance(), $this->get_data());// Go to the originally requested page.if (!empty($SESSION->wantsurl)) {$destination = $SESSION->wantsurl;unset($SESSION->wantsurl);} else {require_once($CFG->dirroot . '/course/lib.php');$destination = course_get_url($this->get_instance()->courseid);}return $destination;}#[\Override]public function set_data_for_dynamic_submission(): void {$instance = $this->get_instance();$this->set_data(['id' => $instance->courseid, 'instance' => $instance->id]);}}