273 lines
8.3 KiB
PHP
273 lines
8.3 KiB
PHP
<?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/>.
|
|
|
|
/**
|
|
* External plugin API.
|
|
*
|
|
* @package tool_managertokens
|
|
* @copyright 2017 "Valentin Popov" <info@valentineus.link>
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
|
*/
|
|
|
|
defined("MOODLE_INTERNAL") || die();
|
|
|
|
require_once(__DIR__ . "/locallib.php");
|
|
|
|
/**
|
|
* It checks the ability to activate the token and produces it.
|
|
*
|
|
* @param string $token
|
|
* @return object
|
|
*/
|
|
function tool_managertokens_activate_token($token = "") {
|
|
global $DB;
|
|
|
|
$selectlimited = "limited = 0 OR scope < limited";
|
|
$selecttimelimited = "timelimited = 0 OR (timecreated + timelimited) > " . time();
|
|
$select = "enabled = 1 AND token = '$token' AND ($selectlimited) AND ($selecttimelimited)";
|
|
if ($token = $DB->get_record_select("tool_managertokens_tokens", $select, null, "*", IGNORE_MISSING)) {
|
|
$token->scope = intval($token->scope) + 1;
|
|
$token->timelastuse = time();
|
|
$DB->update_record("tool_managertokens_tokens", $token, false);
|
|
}
|
|
|
|
return $token;
|
|
}
|
|
|
|
/**
|
|
* Toggles the status of an existing token.
|
|
*
|
|
* @param number|string $key
|
|
* @return boolean
|
|
*/
|
|
function tool_managertokens_change_status($key = "") {
|
|
global $DB;
|
|
|
|
$result = false;
|
|
$select = "id = '$key' OR token = '$key'";
|
|
if ($DB->record_exists_select("tool_managertokens_tokens", $select, null)) {
|
|
$enabled = $DB->get_field_select("tool_managertokens_tokens", "enabled", $select, null, IGNORE_MISSING);
|
|
$result = $DB->set_field_select("tool_managertokens_tokens", "enabled", !boolval($enabled), $select, null);
|
|
}
|
|
|
|
return boolval($result);
|
|
}
|
|
|
|
/**
|
|
* Creates a backup copy of the tokens.
|
|
*
|
|
* @return string
|
|
*/
|
|
function tool_managertokens_create_backup() {
|
|
$list = tool_managertokens_get_list(0, 0);
|
|
$archive = base64_encode(gzcompress(serialize($list), 9));
|
|
return $archive;
|
|
}
|
|
|
|
/**
|
|
* Creates an entry in the database.
|
|
*
|
|
* @param object $options
|
|
* @return number
|
|
*/
|
|
function tool_managertokens_create_record($options) {
|
|
global $DB;
|
|
|
|
$token = new stdClass();
|
|
$token->enabled = !empty($options->enabled) ? boolval($options->enabled) : false;
|
|
$token->limited = !empty($options->limited) ? intval($options->limited) : 0;
|
|
$token->targetid = !empty($options->targetid) ? intval($options->targetid) : 0;
|
|
$token->targettype = !empty($options->targettype) ? strval($options->targettype) : "null";
|
|
$token->timelimited = !empty($options->timelimited) ? intval($options->timelimited) : 0;
|
|
$token->token = !empty($options->token) ? strval($options->token) : generate_password(12);
|
|
$token->timecreated = time();
|
|
$token->timemodified = time();
|
|
|
|
if (!empty($options->extendedaction) && !empty($options->extendedoptions)) {
|
|
$token->extendedaction = strval($options->extendedaction);
|
|
$token->extendedoptions = strval($options->extendedoptions);
|
|
}
|
|
|
|
if ($DB->record_exists("tool_managertokens_tokens", array("token" => $token->token))) {
|
|
print_error("duplicatefieldname", "error", null, "token");
|
|
}
|
|
|
|
$recordid = $DB->insert_record("tool_managertokens_tokens", $token, true, false);
|
|
return $recordid;
|
|
}
|
|
|
|
/**
|
|
* Specifies the user for authorization.
|
|
*
|
|
* @param object $token
|
|
*/
|
|
function tool_managertokens_definition_user($token) {
|
|
$user = false;
|
|
|
|
if ($token->targettype == "user") {
|
|
$user = core_user::get_user($token->targetid);
|
|
}
|
|
|
|
return $user;
|
|
}
|
|
|
|
/**
|
|
* Removes all entries in the table.
|
|
* Attention! All current records are deleted!
|
|
*
|
|
* @return boolean
|
|
*/
|
|
function tool_managertokens_delete_all_records() {
|
|
global $DB;
|
|
|
|
$result = $DB->delete_records("tool_managertokens_tokens", null);
|
|
return boolval($result);
|
|
}
|
|
|
|
/**
|
|
* Deletes an entry by an ID or token.
|
|
*
|
|
* @param number|string $key
|
|
* @return boolean
|
|
*/
|
|
function tool_managertokens_delete_record($key = 0) {
|
|
global $DB;
|
|
|
|
$result = false;
|
|
if ($token = tool_managertokens_find_record($key)) {
|
|
$result = $DB->delete_records("tool_managertokens_tokens", array("id" => $token->id));
|
|
}
|
|
|
|
return boolval($result);
|
|
}
|
|
|
|
/**
|
|
* Searches for an id or token.
|
|
*
|
|
* @param number|string $key
|
|
* @return object|boolean
|
|
*/
|
|
function tool_managertokens_find_record($key = 0) {
|
|
global $DB;
|
|
|
|
$select = "id = '$key' OR token = '$key'";
|
|
$token = $DB->get_record_select("tool_managertokens_tokens", $select, null, "*", IGNORE_MISSING);
|
|
return $token;
|
|
}
|
|
|
|
/**
|
|
* Get the entire list of tokens.
|
|
*
|
|
* @param number $limitfrom
|
|
* @param number $limitnum
|
|
* @return array
|
|
*/
|
|
function tool_managertokens_get_list($limitfrom = 0, $limitnum = 0) {
|
|
global $DB;
|
|
|
|
$result = $DB->get_records("tool_managertokens_tokens", null, "id", "*", $limitfrom, $limitnum);
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Performs additional actions for the user.
|
|
*
|
|
* @param object $token
|
|
* @param object $user
|
|
*/
|
|
function tool_managertokens_perform_additional_action($token, $user) {
|
|
global $DB;
|
|
|
|
/* Redirect user */
|
|
if ($token->extendedaction == "redirect") {
|
|
$redirect = new moodle_url($token->extendedoptions);
|
|
redirect($redirect);
|
|
}
|
|
|
|
/* Enroll in the local group */
|
|
if ($token->extendedaction == "group") {
|
|
$groupid = intval($token->extendedoptions);
|
|
if ($DB->record_exists("groups", array("id" => $groupid))) {
|
|
tool_managertokens_enroll_user_for_group($user, $groupid);
|
|
}
|
|
}
|
|
|
|
/* Enroll in the global group */
|
|
if ($token->extendedaction == "cohort") {
|
|
$cohortid = intval($token->extendedoptions);
|
|
if ($DB->record_exists("cohort", array("id" => $cohortid))) {
|
|
tool_managertokens_enroll_user_for_cohort($user, $cohortid);
|
|
}
|
|
}
|
|
|
|
/* Enroll in the global course */
|
|
if ($token->extendedaction == "course") {
|
|
$courseid = intval($token->extendedoptions);
|
|
if ($DB->record_exists("course", array("id" => $courseid))) {
|
|
tool_managertokens_enroll_user_for_course($user, $courseid);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Restores data from a backup.
|
|
* Attention! All current records are deleted!
|
|
*
|
|
* @param string $backup
|
|
*/
|
|
function tool_managertokens_restore_backup($backup = "") {
|
|
global $DB;
|
|
|
|
if ($list = unserialize(gzuncompress(base64_decode($backup)))) {
|
|
tool_managertokens_delete_all_records();
|
|
$DB->insert_records("tool_managertokens_tokens", $list);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Updates the entry in the database.
|
|
*
|
|
* @param object $options
|
|
* @return boolean
|
|
*/
|
|
function tool_managertokens_update_record($options) {
|
|
global $DB;
|
|
|
|
$result = false;
|
|
|
|
if (!isset($options->id)) {
|
|
print_error("missingparam", "error", null, "id");
|
|
}
|
|
|
|
if ($token = $DB->get_record("tool_managertokens_tokens", array("id" => $options->id), "*", IGNORE_MISSING)) {
|
|
$token->enabled = !empty($options->enabled) ? boolval($options->enabled) : false;
|
|
$token->limited = !empty($options->limited) ? intval($options->limited) : $token->limited;
|
|
$token->targetid = !empty($options->targetid) ? intval($options->targetid) : $token->targetid;
|
|
$token->targettype = !empty($options->targettype) ? strval($options->targettype) : $token->targettype;
|
|
$token->timelimited = !empty($options->timelimited) ? intval($options->timelimited) : $token->timelimited;
|
|
$token->token = !empty($options->token) ? strval($options->token) : $token->token;
|
|
$token->timemodified = time();
|
|
|
|
if (!empty($options->extendedaction) && !empty($options->extendedoptions)) {
|
|
$token->extendedaction = strval($options->extendedaction);
|
|
$token->extendedoptions = strval($options->extendedoptions);
|
|
}
|
|
|
|
$result = $DB->update_record("tool_managertokens_tokens", $token, false);
|
|
}
|
|
|
|
return boolval($result);
|
|
} |