Refactoring the library
This commit is contained in:
parent
afd218e1fd
commit
c5115b3121
91
lib.php
91
lib.php
@ -34,11 +34,11 @@ function tool_managertokens_activate_token($token = "") {
|
|||||||
global $DB;
|
global $DB;
|
||||||
|
|
||||||
$select_limited = "limited = 0 OR scope < limited";
|
$select_limited = "limited = 0 OR scope < limited";
|
||||||
$select_timelimited = "timelimited = 0 OR timelimited > " . time();
|
$select_timelimited = "timelimited = 0 OR (timecreated + timelimited) > " . time();
|
||||||
$select = "enabled = 1 AND token = '$token' AND ($select_limited) AND ($select_timelimited)";
|
$select = "enabled = 1 AND token = '$token' AND ($select_limited) AND ($select_timelimited)";
|
||||||
|
|
||||||
if ($token = $DB->get_record_select("tool_managertokens_tokens", $select, null, "*", IGNORE_MISSING)) {
|
if ($token = $DB->get_record_select("tool_managertokens_tokens", $select, null, "*", IGNORE_MISSING)) {
|
||||||
$token->scope = intval($token->scope) + 1;
|
$token = tool_managertokens_standardization_record($token);
|
||||||
|
$token->scope = $token->scope + 1;
|
||||||
$token->timelastuse = time();
|
$token->timelastuse = time();
|
||||||
$DB->update_record("tool_managertokens_tokens", $token, false);
|
$DB->update_record("tool_managertokens_tokens", $token, false);
|
||||||
}
|
}
|
||||||
@ -46,7 +46,16 @@ function tool_managertokens_activate_token($token = "") {
|
|||||||
return $token;
|
return $token;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* function tool_managertokens_create_backup() {} */
|
/**
|
||||||
|
* 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.
|
* Creates an entry in the database.
|
||||||
@ -62,11 +71,11 @@ function tool_managertokens_create_record($options) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!isset($options->targettype)) {
|
if (!isset($options->targettype)) {
|
||||||
print_error("missingparam", "error", "", "targettype");
|
$options->targettype = "user";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!isset($options->token)) {
|
if (!isset($options->token)) {
|
||||||
print_error("missingparam", "error", "", "token");
|
$options->token = generate_password(12);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($DB->record_exists("tool_managertokens_tokens", array("token" => $options->token))) {
|
if ($DB->record_exists("tool_managertokens_tokens", array("token" => $options->token))) {
|
||||||
@ -77,24 +86,24 @@ function tool_managertokens_create_record($options) {
|
|||||||
$token->enabled = false;
|
$token->enabled = false;
|
||||||
$token->timecreated = time();
|
$token->timecreated = time();
|
||||||
$token->targetid = intval($options->targetid);
|
$token->targetid = intval($options->targetid);
|
||||||
$token->targettype = intval($options->targettype);
|
$token->targettype = strval($options->targettype);
|
||||||
$token->timemodified = $token->timecreated;
|
$token->timemodified = $token->timecreated;
|
||||||
$token->token = strval($options->token);
|
$token->token = strval($options->token);
|
||||||
|
|
||||||
if (isset($options->enabled)) {
|
if (!empty($options->enabled)) {
|
||||||
$token->enabled = boolval($options->enabled);
|
$token->enabled = boolval($options->enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($options->extendedaction) && isset($options->extendedoptions)) {
|
if (!empty($options->extendedaction) && !empty($options->extendedoptions)) {
|
||||||
$token->extendedaction = strval($options->extendedaction);
|
$token->extendedaction = strval($options->extendedaction);
|
||||||
$token->extendedoptions = strval($options->extendedoptions);
|
$token->extendedoptions = strval($options->extendedoptions);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($options->limited)) {
|
if (!empty($options->limited)) {
|
||||||
$token->limited = intval($options->limited);
|
$token->limited = intval($options->limited);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (isset($options->timelimited)) {
|
if (!empty($options->timelimited)) {
|
||||||
$token->timelimited = intval($options->timelimited);
|
$token->timelimited = intval($options->timelimited);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -104,11 +113,13 @@ function tool_managertokens_create_record($options) {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Removes all entries in the table.
|
* Removes all entries in the table.
|
||||||
|
* Attention! All current records are deleted!
|
||||||
*
|
*
|
||||||
* @return boolean
|
* @return boolean
|
||||||
*/
|
*/
|
||||||
function tool_managertokens_delete_all_records() {
|
function tool_managertokens_delete_all_records() {
|
||||||
global $DB;
|
global $DB;
|
||||||
|
|
||||||
$result = $DB->delete_records("tool_managertokens_tokens", null);
|
$result = $DB->delete_records("tool_managertokens_tokens", null);
|
||||||
return boolval($result);
|
return boolval($result);
|
||||||
}
|
}
|
||||||
@ -121,20 +132,29 @@ function tool_managertokens_delete_all_records() {
|
|||||||
*/
|
*/
|
||||||
function tool_managertokens_delete_record($key = 0) {
|
function tool_managertokens_delete_record($key = 0) {
|
||||||
global $DB;
|
global $DB;
|
||||||
$select = "id = '$key' OR token = '$key'";
|
|
||||||
$result = $DB->delete_records_select("tool_managertokens_tokens", $select, null);
|
$result = false;
|
||||||
|
if ($token = tool_managertokens_find_record($key)) {
|
||||||
|
$result = $DB->delete_records("tool_managertokens_tokens", array("id" => $token->id));
|
||||||
|
}
|
||||||
|
|
||||||
return boolval($result);
|
return boolval($result);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Searches for an id or token.
|
* Searches for an id or token.
|
||||||
*
|
*
|
||||||
* @param number|string $key
|
* @param number|string $key
|
||||||
|
* @return object|boolean
|
||||||
*/
|
*/
|
||||||
function tool_managertokens_find_record($key = 0) {
|
function tool_managertokens_find_record($key = 0) {
|
||||||
global $DB;
|
global $DB;
|
||||||
|
|
||||||
$select = "id = '$key' OR token = '$key'";
|
$select = "id = '$key' OR token = '$key'";
|
||||||
$token = $DB->get_record_select("tool_managertokens_tokens", $select, null, "*", IGNORE_MISSING);
|
if ($token = $DB->get_record_select("tool_managertokens_tokens", $select, null, "*", IGNORE_MISSING)) {
|
||||||
|
$token = tool_managertokens_standardization_record($token);
|
||||||
|
}
|
||||||
|
|
||||||
return $token;
|
return $token;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -147,11 +167,25 @@ function tool_managertokens_find_record($key = 0) {
|
|||||||
*/
|
*/
|
||||||
function tool_managertokens_get_list($limitfrom = 0, $limitnum = 0) {
|
function tool_managertokens_get_list($limitfrom = 0, $limitnum = 0) {
|
||||||
global $DB;
|
global $DB;
|
||||||
|
|
||||||
$result = $DB->get_records("tool_managertokens_tokens", null, "id", "*", $limitfrom, $limitnum);
|
$result = $DB->get_records("tool_managertokens_tokens", null, "id", "*", $limitfrom, $limitnum);
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* function tool_managertokens_restore_backup($backup = "") {} */
|
/**
|
||||||
|
* 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.
|
* Updates the entry in the database.
|
||||||
@ -205,3 +239,26 @@ function tool_managertokens_update_record($options) {
|
|||||||
|
|
||||||
return boolval($result);
|
return boolval($result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Standardizes the source document.
|
||||||
|
*
|
||||||
|
* @param object $record
|
||||||
|
* @return object
|
||||||
|
*/
|
||||||
|
function tool_managertokens_standardization_record($record) {
|
||||||
|
$record->id = intval($record->id);
|
||||||
|
$record->enabled = boolval($record->enabled);
|
||||||
|
$record->extendedaction = strval($record->extendedaction);
|
||||||
|
$record->extendedoptions = strval($record->extendedoptions);
|
||||||
|
$record->limited = intval($record->limited);
|
||||||
|
$record->scope = intval($record->scope);
|
||||||
|
$record->targetid = intval($record->targetid);
|
||||||
|
$record->targettype = strval($record->targettype);
|
||||||
|
$record->timecreated = intval($record->timecreated);
|
||||||
|
$record->timelastuse = intval($record->timelastuse);
|
||||||
|
$record->timelimited = intval($record->timelimited);
|
||||||
|
$record->timemodified = intval($record->timemodified);
|
||||||
|
$record->token = strval($record->token);
|
||||||
|
return $record;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user