Search moodle.org's
Developer Documentation

See Release Notes

  • Bug fixes for general core bugs in 4.0.x will end 8 May 2023 (12 months).
  • Bug fixes for security issues in 4.0.x will end 13 November 2023 (18 months).
  • PHP version: minimum PHP 7.3.0 Note: the minimum PHP version has increased since Moodle 3.10. PHP 7.4.x is also supported.
<?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/>.

/**
 * Form class for mybackpack.php
 *
 * @package    core
 * @subpackage badges
 * @copyright  2012 onwards Totara Learning Solutions Ltd {@link http://www.totaralms.com/}
 * @license    http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
 * @author     Yuliya Bozhko <yuliya.bozhko@totaralms.com>
 */

namespace core_badges\form;

defined('MOODLE_INTERNAL') || die();

require_once($CFG->libdir . '/formslib.php');
require_once($CFG->libdir . '/badgeslib.php');

use html_writer;
use moodleform;
use stdClass;

/**
 * Form to edit backpack initial details.
 *
 */
class backpack extends external_backpack {

    /**
     * Defines the form
     */
    public function definition() {
        global $USER, $PAGE, $OUTPUT, $CFG;
        $mform = $this->_form;
        $this->_customdata['userbackpack'] = 1;

        $mform->addElement('html', html_writer::tag('span', '', array('class' => 'notconnected', 'id' => 'connection-error')));
        $mform->addElement('header', 'backpackheader', get_string('backpackconnection', 'badges'));
        $mform->addHelpButton('backpackheader', 'backpackconnection', 'badges');
        $mform->addElement('hidden', 'userid', $USER->id);
        $mform->setType('userid', PARAM_INT);
        $freeze = [];
        if (isset($this->_customdata['email'])) {
            // Email will be passed in when we're in the process of verifying the user's email address,
            // so set the connection status, lock the email field, and provide options to resend the verification
            // email or cancel the verification process entirely and start over.
            $freeze = ['backpackemail'];
            $mform->addElement('hidden', 'password', $this->_customdata['backpackpassword']);
            $mform->setType('password', PARAM_RAW);
            $mform->addElement('hidden', 'externalbackpackid', $this->_customdata['backpackid']);
            $mform->setType('externalbackpackid', PARAM_INT);
            $status = html_writer::tag('span', get_string('backpackemailverificationpending', 'badges'),
                array('class' => 'notconnected', 'id' => 'connection-status'));
        } else {
            $sitebackpacks = badges_get_site_backpacks();
            $choices = [];
            $restrictedoptions = [];
            foreach ($sitebackpacks as $backpack) {
                $choices[$backpack->id] = $backpack->backpackweburl;
                if ($backpack->apiversion == OPEN_BADGES_V2P1) {
                    $restrictedoptions[] = $backpack->id;
                }
            }
            $mform->addElement('select', 'externalbackpackid', get_string('backpackprovider', 'badges'), $choices);
            $mform->setType('externalbackpackid', PARAM_INT);
            $defaultbackpack = badges_get_site_primary_backpack();
            $mform->setDefault('externalbackpackid', $defaultbackpack->id);
            $mform->hideIf('password', 'externalbackpackid', 'in', $restrictedoptions);
            $mform->hideIf('backpackemail', 'externalbackpackid', 'in', $restrictedoptions);

            $status = html_writer::tag('span', get_string('notconnected', 'badges'),
                array('class' => 'notconnected', 'id' => 'connection-status'));
        }
        $mform->addElement('static', 'status', get_string('status'), $status);

        $this->add_auth_fields($this->_customdata['email'] ?? $USER->email, !isset($this->_customdata['email']));

        $mform->setDisableShortforms(false);

        // Freeze any elemnts after definition.
        if ($freeze) {
            $mform->freeze($freeze);
        }
        $this->add_action_buttons();
    }

    /**
     * Override add_action_buttons
     *
     * @param bool $cancel
     * @param null|text $submitlabel
     */
    public function add_action_buttons($cancel = true, $submitlabel = null) {
        $mform = $this->_form;
        if (isset($this->_customdata['email'])) {
            $buttonarray = [];
            $buttonarray[] = &$mform->createElement('submit', 'submitbutton',
                                                    get_string('backpackconnectionresendemail', 'badges'));
            $buttonarray[] = &$mform->createElement('submit', 'revertbutton',
                                                    get_string('backpackconnectioncancelattempt', 'badges'));
            $mform->addGroup($buttonarray, 'buttonar', '', [''], false);
            $mform->closeHeaderBefore('buttonar');
        } else {
            // Email isn't present, so provide an input element to get it and a button to start the verification process.
            parent::add_action_buttons(false, get_string('backpackconnectionconnect', 'badges'));
        }
    }

    /**
     * Validates form data
     */
    public function validation($data, $files) {
< global $CFG; < < $errors = parent::validation($data, $files);
if (badges_open_badges_backpack_api() == OPEN_BADGES_V2P1) {
< return $errors;
> return [];
}
>
// We don't need to verify the email address if we're clearing a pending email verification attempt.
< if (!isset($data['revertbutton'])) {
> if (isset($data['revertbutton'])) { > return []; > } > > $errors = []; > // Email and password can't be blank. > if (empty($data['backpackemail'])) { > $errors['backpackemail'] = get_string('backpackemail_required', 'badges'); > } > if (empty($data['password'])) { > $errors['password'] = get_string('password_required', 'badges'); > } > if (!empty($errors)) { > return $errors; > } > > // Check the given credentials (email and password) are valid for this backpack.
$check = new stdClass(); $check->email = $data['backpackemail']; $check->password = $data['password']; $sitebackpack = badges_get_site_backpack($data['externalbackpackid']); $bp = new \core_badges\backpack_api($sitebackpack, $check); $result = $bp->authenticate(); if ($result === false || !empty($result->error)) {
< $errors['backpackemail'] = get_string('backpackconnectionunexpectedresult', 'badges');
$msg = $bp->get_authentication_error();
< if (!empty($msg)) { < $errors['backpackemail'] .= '<br/><br/>'; < $errors['backpackemail'] .= get_string('backpackconnectionunexpectedmessage', 'badges', $msg); < } < }
> $errors['backpackemail'] = get_string('backpackconnectionunexpectedresult', 'badges', $msg);
} return $errors; } }