mirror of
https://github.com/moodle/moodle.git
synced 2025-04-13 20:42:22 +02:00
MDL-62574 core_privacy: Check the contextlist for real contexts.
There are situations when contexts will be deleted in the provider. The context list is not updated and so we have introduced a try catch.
This commit is contained in:
parent
50e48a8f2d
commit
c84cb13cd4
@ -79,12 +79,20 @@ abstract class contextlist_base implements
|
||||
* Get the complete list of context objects that relate to this
|
||||
* request.
|
||||
*
|
||||
* @return \contect[]
|
||||
* @return \context[]
|
||||
*/
|
||||
public function get_contexts() : array {
|
||||
$contexts = [];
|
||||
foreach ($this->contextids as $contextid) {
|
||||
$contexts[] = \context::instance_by_id($contextid);
|
||||
// It is possible that this context has been deleted and we now have subsequent calls being made with this
|
||||
// contextlist. Exceptions here will stop the further processing of this component and that is why we are
|
||||
// doing a try catch.
|
||||
try {
|
||||
$contexts[] = \context::instance_by_id($contextid);
|
||||
} catch (\Exception $e) {
|
||||
// Remove this context.
|
||||
unset($this->contextids[$this->iteratorposition]);
|
||||
}
|
||||
}
|
||||
|
||||
return $contexts;
|
||||
@ -114,7 +122,25 @@ abstract class contextlist_base implements
|
||||
* @return \context
|
||||
*/
|
||||
public function current() {
|
||||
return \context::instance_by_id($this->contextids[$this->iteratorposition]);
|
||||
// It is possible that this context has been deleted and we now have subsequent calls being made with this
|
||||
// contextlist. Exceptions here will stop the further processing of this component and that is why we are
|
||||
// doing a try catch.
|
||||
try {
|
||||
$context = \context::instance_by_id($this->contextids[$this->iteratorposition]);
|
||||
} catch (\Exception $e) {
|
||||
// Remove this context.
|
||||
unset($this->contextids[$this->iteratorposition]);
|
||||
// Check to see if there are any more contexts left.
|
||||
if ($this->count()) {
|
||||
// Move the pointer to the next record and try again.
|
||||
$this->next();
|
||||
$context = $this->current();
|
||||
} else {
|
||||
// There are no more context ids left.
|
||||
return;
|
||||
}
|
||||
}
|
||||
return $context;
|
||||
}
|
||||
|
||||
/**
|
||||
|
Loading…
x
Reference in New Issue
Block a user