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.
<?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/>.

< /** < * License manager helper class. < * < * @package tool_licensemanager < * @copyright 2019 Tom Dickman <tomdickman@catalyst-au.net> < * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later < */
namespace tool_licensemanager; use moodle_url;
< defined('MOODLE_INTERNAL') || die();
/** * License manager helper class. * * @package tool_licensemanager * @copyright 2019 Tom Dickman <tomdickman@catalyst-au.net> * @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ class helper { /** * Moodle relative path to the licenses manager. */ const MANAGER_PATH = '/admin/tool/licensemanager/index.php'; /** * Get the URL for viewing the license manager interface. * * @return \moodle_url */ public static function get_licensemanager_url() : moodle_url {
< global $CFG; < < $url = new moodle_url($CFG->wwwroot . self::MANAGER_PATH, < ['sesskey' => sesskey()]); < < return $url;
> return new moodle_url(self::MANAGER_PATH);
} /** * Get the URL for endpoint enabling a license. * * @param string $licenseshortname the shortname of license to enable. * * @return \moodle_url */ public static function get_enable_license_url(string $licenseshortname) : moodle_url { $url = new moodle_url(self::MANAGER_PATH, ['action' => manager::ACTION_ENABLE, 'license' => $licenseshortname, 'sesskey' => sesskey()]); return $url; } /** * Get the URL for endpoint disabling a license. * * @param string $licenseshortname the shortname of license to disable. * * @return \moodle_url */ public static function get_disable_license_url(string $licenseshortname) : moodle_url { $url = new moodle_url(self::MANAGER_PATH, ['action' => manager::ACTION_DISABLE, 'license' => $licenseshortname, 'sesskey' => sesskey()]); return $url; } /** * Get the URL endpoint to create a new license. * * @return \moodle_url */ public static function get_create_license_url() : moodle_url {
< $url = new moodle_url(self::MANAGER_PATH, < ['action' => manager::ACTION_CREATE, 'sesskey' => sesskey()]); <
> $url = self::get_licensemanager_url(); > $url->params(['action' => manager::ACTION_CREATE]);
return $url; } /** * Get the URL endpoint to update an existing license. * * @param string $licenseshortname the shortname of license to update. * * @return \moodle_url */ public static function get_update_license_url(string $licenseshortname) : moodle_url {
< $url = new moodle_url(self::MANAGER_PATH, < ['action' => manager::ACTION_UPDATE, 'license' => $licenseshortname, 'sesskey' => sesskey()]); <
> $url = self::get_licensemanager_url(); > $url->params(['action' => manager::ACTION_UPDATE, 'license' => $licenseshortname]);
return $url; } /** * Get the URL endpoint to move a license up order. * * @param string $licenseshortname the shortname of license to move up. * * @return \moodle_url */ public static function get_moveup_license_url(string $licenseshortname) : moodle_url { $url = new moodle_url(self::MANAGER_PATH, ['action' => manager::ACTION_MOVE_UP, 'license' => $licenseshortname, 'sesskey' => sesskey()]); return $url; } /** * Get the URL endpoint to move a license down order. * * @param string $licenseshortname the shortname of license to move down. * * @return \moodle_url */ public static function get_movedown_license_url(string $licenseshortname) : moodle_url { $url = new moodle_url(self::MANAGER_PATH, ['action' => manager::ACTION_MOVE_DOWN, 'license' => $licenseshortname, 'sesskey' => sesskey()]); return $url; } /** * Convert a license version number string to a UNIX epoch. * * @param string $version * * @return int $epoch */ public static function convert_version_to_epoch(string $version) : int { $date = substr($version, 0, 8); $epoch = strtotime($date); return $epoch; } }