You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
208 lines
6.3 KiB
208 lines
6.3 KiB
2 years ago
|
<?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/>.
|
||
|
|
||
|
/**
|
||
|
* Expiry Data.
|
||
|
*
|
||
|
* @package tool_dataprivacy
|
||
|
* @copyright 2018 Andrew Nicols <andrew@nicols.co.uk>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
namespace tool_dataprivacy;
|
||
|
|
||
|
use core_privacy\manager;
|
||
|
|
||
|
defined('MOODLE_INTERNAL') || die();
|
||
|
|
||
|
/**
|
||
|
* Expiry Data.
|
||
|
*
|
||
|
* @copyright 2018 Andrew Nicols <andrew@nicols.co.uk>
|
||
|
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later
|
||
|
*/
|
||
|
class expiry_info {
|
||
|
|
||
|
/** @var bool Whether this context is fully expired */
|
||
|
protected $fullyexpired = false;
|
||
|
|
||
|
/** @var bool Whether the default expiry value of this purpose has been reached */
|
||
|
protected $defaultexpiryreached = false;
|
||
|
|
||
|
/** @var bool Whether the default purpose is protected */
|
||
|
protected $defaultprotected = false;
|
||
|
|
||
|
/** @var int[] List of expires roles */
|
||
|
protected $expired = [];
|
||
|
|
||
|
/** @var int[] List of unexpires roles */
|
||
|
protected $unexpired = [];
|
||
|
|
||
|
/** @var int[] List of unexpired roles which are also protected */
|
||
|
protected $protectedroles = [];
|
||
|
|
||
|
/**
|
||
|
* Constructor for the expiry_info class.
|
||
|
*
|
||
|
* @param bool $default Whether the default expiry period for this context has been reached.
|
||
|
* @param bool $defaultprotected Whether the default expiry is protected.
|
||
|
* @param int[] $expired A list of roles in this context which have explicitly expired.
|
||
|
* @param int[] $unexpired A list of roles in this context which have not yet expired.
|
||
|
* @param int[] $protectedroles A list of unexpired roles in this context which are protected.
|
||
|
*/
|
||
|
public function __construct(bool $default, bool $defaultprotected, array $expired, array $unexpired, array $protectedroles) {
|
||
|
$this->defaultexpiryreached = $default;
|
||
|
$this->defaultprotected = $defaultprotected;
|
||
|
$this->expired = $expired;
|
||
|
$this->unexpired = $unexpired;
|
||
|
$this->protectedroles = $protectedroles;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Whether this context has 'fully' expired.
|
||
|
* That is to say that the default retention period has been reached, and that there are no unexpired roles.
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function is_fully_expired() : bool {
|
||
|
return $this->defaultexpiryreached && empty($this->unexpired);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Whether any part of this context has expired.
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function is_any_expired() : bool {
|
||
|
if ($this->is_fully_expired()) {
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
if (!empty($this->get_expired_roles())) {
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
if ($this->is_default_expired()) {
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the list of explicitly expired role IDs.
|
||
|
* Note: This does not list roles which have been expired via the default retention policy being reached.
|
||
|
*
|
||
|
* @return int[]
|
||
|
*/
|
||
|
public function get_expired_roles() : array {
|
||
|
if ($this->is_default_expired()) {
|
||
|
return [];
|
||
|
}
|
||
|
return $this->expired;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Check whether the specified role is explicitly expired.
|
||
|
* Note: This does not list roles which have been expired via the default retention policy being reached.
|
||
|
*
|
||
|
* @param int $roleid
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function is_role_expired(int $roleid) : bool {
|
||
|
return false !== array_search($roleid, $this->expired);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Whether the default retention policy has been reached.
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function is_default_expired() : bool {
|
||
|
return $this->defaultexpiryreached;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Whether the default purpose is protected.
|
||
|
*
|
||
|
* @return bool
|
||
|
*/
|
||
|
public function is_default_protected() : bool {
|
||
|
return $this->defaultprotected;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the list of unexpired role IDs.
|
||
|
*
|
||
|
* @return int[]
|
||
|
*/
|
||
|
public function get_unexpired_roles() : array {
|
||
|
return $this->unexpired;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the list of unexpired protected roles.
|
||
|
*
|
||
|
* @return int[]
|
||
|
*/
|
||
|
public function get_unexpired_protected_roles() : array {
|
||
|
return array_keys(array_filter($this->protectedroles));
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get a list of all overridden roles which are unprotected.
|
||
|
* @return int[]
|
||
|
*/
|
||
|
public function get_unprotected_overridden_roles() : array {
|
||
|
$allroles = array_merge($this->expired, $this->unexpired);
|
||
|
|
||
|
return array_diff($allroles, $this->protectedroles);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Merge this expiry_info object with another belonging to a child context in order to set the 'safest' heritage.
|
||
|
*
|
||
|
* It is not possible to delete any part of a context that is not deleted by a parent.
|
||
|
* So if a course's retention policy has been reached, then only parts where the children have also expired can be
|
||
|
* deleted.
|
||
|
*
|
||
|
* @param expiry_info $child The child record to merge with.
|
||
|
* @return $this
|
||
|
*/
|
||
|
public function merge_with_child(expiry_info $child) : expiry_info {
|
||
|
if ($child->is_fully_expired()) {
|
||
|
return $this;
|
||
|
}
|
||
|
|
||
|
// If the child is not fully expired, then none of the parents can be either.
|
||
|
$this->fullyexpired = false;
|
||
|
|
||
|
// Remove any role in this node which is not expired in the child.
|
||
|
foreach ($this->expired as $key => $roleid) {
|
||
|
if (!$child->is_role_expired($roleid)) {
|
||
|
unset($this->expired[$key]);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
array_merge($this->unexpired, $child->get_unexpired_roles());
|
||
|
|
||
|
if (!$child->is_default_expired()) {
|
||
|
$this->defaultexpiryreached = false;
|
||
|
}
|
||
|
|
||
|
return $this;
|
||
|
}
|
||
|
}
|