42 public static function getInstance(
int $a_user_id,
int $a_ref_id): self
44 if (!isset(self::$instances[$a_user_id][$a_ref_id])) {
45 self::$instances[$a_user_id][$a_ref_id] =
new static($a_user_id, $a_ref_id);
47 return self::$instances[$a_user_id][$a_ref_id];
55 $this->context_ids = [];
63 $this->user_id = $a_value;
71 protected function setRefId(
int $a_value): void
73 $this->ref_id = $a_value;
104 ?
int $a_action_sub_id =
null
108 if (array_key_exists($a_context_type, $this->map)) {
109 if (!$a_action_sub_id) {
110 if (in_array($a_action_id, $this->map[$a_context_type][
"actions"])) {
114 if (array_key_exists($a_action_id, $this->map[$a_context_type][
"subactions"]) &&
115 in_array($a_action_sub_id, $this->map[$a_context_type][
"subactions"][$a_action_id])) {
128 trigger_error(
"INVALID permission context - " . $a_context_type .
":" . $a_context_id .
":" . $a_action_id .
":" . $a_action_sub_id, E_USER_WARNING);
141 if (!array_key_exists($a_context_type, $this->context_ids)) {
142 $this->context_ids[$a_context_type] = $this->readContextIds($a_context_type);
144 return (array) $this->context_ids[$a_context_type];
154 ?
int $a_action_sub_id =
null
156 if ($this->isValidContextAndAction($a_context_type, $a_context_id, $a_action_id, $a_action_sub_id)) {
157 return $this->checkPermission($a_context_type, $a_context_id, $a_action_id, $a_action_sub_id);
166 public function hasPermissions(
int $a_context_type,
int $a_context_id, array $a_action_ids): array
170 foreach ($a_action_ids as $action_id) {
171 if (is_array($action_id)) {
172 $action_sub_id = $action_id[1];
173 $action_id = $action_id[0];
175 $res[$action_id][$action_sub_id] = $this->hasPermission($a_context_type, $a_context_id, $action_id, $action_sub_id);
177 $res[$action_id] = $this->hasPermission($a_context_type, $a_context_id, $action_id);
191 ?
int $a_action_sub_id =
null
193 return ($this->checkRBAC() &&
194 $this->checkPlugins($a_context_type, $a_context_id, $a_action_id, $a_action_sub_id));
203 $ilAccess =
$DIC->access();
206 return $ilAccess->checkAccessOfUser($this->getUserId(),
"write",
"", $this->getRefId());
221 ?
int $a_action_sub_id =
null
225 if (!is_array($this->plugins)) {
226 $this->plugins = iterator_to_array($this->getActivePlugins());
229 foreach ($this->plugins as
$plugin) {
230 $a_action_sub_id = is_null($a_action_sub_id)
233 if (!
$plugin->checkPermission($this->getUserId(), $a_context_type, $a_context_id, $a_action_id, $a_action_sub_id)) {
const int SUBACTION_UNDEFINED
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
buildPermissionMap()
Build map of context and actions.
getActivePlugins()
Get active plugins (for current slot)
readContextIds(int $a_context_type)
Get all context ids for context type (from DB, is cached)
getValidContextIds(int $a_context_type)
Get context ids for context type (uses cache)
hasPermission(int $a_context_type, int $a_context_id, int $a_action_id, ?int $a_action_sub_id=null)
Check permission.
isValidContextAndAction(int $a_context_type, int $a_context_id, int $a_action_id, ?int $a_action_sub_id=null)
Check if given combination of context and action is valid.
checkRBAC()
Check permission against RBAC.
checkPermission(int $a_context_type, int $a_context_id, int $a_action_id, ?int $a_action_sub_id=null)
Check permission (helper: rbac, plugins)
reset()
Reset (internal caches)
static getInstance(int $a_user_id, int $a_ref_id)
__construct(int $a_user_id, int $a_ref_id)
hasPermissions(int $a_context_type, int $a_context_id, array $a_action_ids)
Check permissions.
checkPlugins(int $a_context_type, int $a_context_id, int $a_action_id, ?int $a_action_sub_id=null)
Check permission against plugins.
return['delivery_method'=> 'php',]
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
if(!file_exists('../ilias.ini.php'))