芝麻web文件管理V1.00
编辑当前文件:/home2/sdektunc/.trash/cepali/privacy/classes/local/request/userlist_base.php
. /** * Base implementation of a userlist. * * @package core_privacy * @copyright 2018 Andrew Nicols
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ namespace core_privacy\local\request; defined('MOODLE_INTERNAL') || die(); /** * Base implementation of a userlist used to store a set of users. * * @copyright 2018 Andrew Nicols
* @license http://www.gnu.org/copyleft/gpl.html GNU GPL v3 or later */ abstract class userlist_base implements // Implement an Iterator to fetch the Context objects. \Iterator, // Implement the Countable interface to allow the number of returned results to be queried easily. \Countable { /** * @var array List of user IDs. * * Note: this must not be updated using set_userids only as this * ensures uniqueness. */ private $userids = []; /** * @var string component the frankenstyle component name. */ protected $component = ''; /** * @var int Current position of the iterator. */ protected $iteratorposition = 0; /** @var \context The context that this userlist belongs to */ protected $context; /** * Constructor to create a new userlist. * * @param \context $context * @param string $component */ public function __construct(\context $context, string $component) { $this->context = $context; $this->set_component($component); } /** * Set the userids. * * @param array $userids The list of users. * @return $this */ protected function set_userids(array $userids) : userlist_base { $this->userids = array_values(array_unique($userids)); return $this; } /** * Add a set of additional userids. * * @param array $userids The list of users. * @return $this */ protected function add_userids(array $userids) : userlist_base { $this->set_userids(array_merge($this->get_userids(), $userids)); return $this; } /** * Get the list of user IDs that relate to this request. * * @return int[] */ public function get_userids() : array { return $this->userids; } /** * Get the complete list of user objects that relate to this request. * * @return \stdClass[] */ public function get_users() : array { $users = []; foreach ($this->userids as $userid) { if ($user = \core_user::get_user($userid)) { $users[] = $user; } } return $users; } /** * Sets the component for this userlist. * * @param string $component the frankenstyle component name. * @return $this */ protected function set_component($component) : userlist_base { $this->component = $component; return $this; } /** * Get the name of the component to which this userlist belongs. * * @return string the component name associated with this userlist. */ public function get_component() : string { return $this->component; } /** * Return the current user. * * @return \user */ public function current() { $user = \core_user::get_user($this->userids[$this->iteratorposition]); if (false === $user) { // This user was not found. unset($this->userids[$this->iteratorposition]); // Check to see if there are any more users left. if ($this->count()) { // Move the pointer to the next record and try again. $this->next(); $user = $this->current(); } else { // There are no more context ids left. return; } } return $user; } /** * Return the key of the current element. * * @return mixed */ public function key() { return $this->iteratorposition; } /** * Move to the next user in the list. */ public function next() { ++$this->iteratorposition; } /** * Check if the current position is valid. * * @return bool */ public function valid() { return isset($this->userids[$this->iteratorposition]) && $this->current(); } /** * Rewind to the first found user. * * The list of users is uniqued during the rewind. * The rewind is called at the start of most iterations. */ public function rewind() { $this->iteratorposition = 0; } /** * Return the number of users. */ public function count() { return count($this->userids); } /** * Get the context for this userlist * * @return \context */ public function get_context() : \context { return $this->context; } }