19declare(strict_types=1);
60 $this->db =
$DIC->database();
74 $q =
"SELECT DISTINCT(obj_id) obj_id FROM object_data " .
76 "AND type IN('role','rolt')" .
78 $r = $this->db->query(
$q);
80 return (
int) $row->obj_id;
101 foreach ($roles as $role) {
102 $id = (
int) $role[
"obj_id"];
104 $parent_roles[
$id] = $role;
106 if (!array_key_exists($role[
'obj_id'], $role_hierarchy)) {
126 $tree =
$DIC->repositoryTree();
128 $pathIds = $tree->getPathId($a_endnode_id);
145 $query =
"SELECT * FROM object_data " .
146 "JOIN rbac_fa ON obj_id = rol_id " .
148 "AND object_data.obj_id = rbac_fa.rol_id " .
149 "AND rbac_fa.parent = " . $this->db->quote($a_ref_id,
'integer') .
" ";
151 $res = $this->db->query($query);
152 while ($row = $this->db->fetchAssoc(
$res)) {
153 $row[
"desc"] = $row[
"description"];
154 $row[
"user_id"] = (
int) $row[
"owner"];
155 $row[
'obj_id'] = (
int) $row[
'obj_id'];
156 $row[
'rol_id'] = (
int) $row[
'rol_id'];
157 $row[
'parent'] = (
int) $row[
'parent'];
169 bool $a_templates =
false,
170 bool $a_internal_roles =
false,
171 string $title_filter =
''
186 bool $a_templates =
false,
187 bool $a_internal_roles =
false,
188 string $title_filter =
''
190 $where = $this->__setTemplateFilter($a_templates);
191 $query =
"SELECT * FROM object_data " .
192 "JOIN rbac_fa ON obj_id = rol_id " .
194 "AND rbac_fa.assign = 'y' ";
196 if (strlen($title_filter)) {
197 $query .= (
' AND ' . $this->db->like(
203 $res = $this->db->query($query);
205 while ($row = $this->db->fetchAssoc(
$res)) {
206 $row[
"description"] = (string) $row[
"description"];
207 $row[
"desc"] = $row[
"description"];
208 $row[
"user_id"] = (
int) $row[
"owner"];
209 $row[
'obj_id'] = (
int) $row[
'obj_id'];
210 $row[
'parent'] = (
int) $row[
'parent'];
211 yield $this->setRoleTypeAndProtection($row);
224 $tree =
$DIC->repositoryTree();
225 $query =
'SELECT rol_id FROM rbac_fa fa ' .
226 'JOIN tree t1 ON t1.child = fa.parent ' .
227 'JOIN object_data obd ON fa.rol_id = obd.obj_id ' .
228 'WHERE assign = ' . $this->db->quote(
'y',
'text') .
' ' .
229 'AND obd.type = ' . $this->db->quote(
'role',
'text') .
' ' .
230 'AND t1.child IN (' .
231 $tree->getSubTreeQuery(
$ref_id, [
'child']) .
' ' .
234 $res = $this->db->query($query);
238 $role_list[] = (
int) $row->rol_id;
248 $query =
"SELECT fa.*, rd.* " .
249 "FROM object_data rd " .
250 "JOIN rbac_fa fa ON rd.obj_id = fa.rol_id " .
251 "WHERE fa.assign = 'y' " .
252 "AND fa.parent = " . $this->db->quote($a_ref_id,
'integer') .
" ";
254 $res = $this->db->query($query);
256 while ($row = $this->db->fetchAssoc(
$res)) {
257 $row[
'rol_id'] = (
int) $row[
'rol_id'];
258 $row[
'obj_id'] = (
int) $row[
'obj_id'];
260 $roles_data[] = $row;
272 $where =
"WHERE " . $this->db->in(
'object_data.type', [
'role',
'rolt'],
false,
'text') .
" ";
274 $where =
"WHERE " . $this->db->in(
'object_data.type', [
'role'],
false,
'text') .
" ";
288 foreach ($a_role_list as $key => $val) {
289 $a_role_list[$key] = $this->setRoleTypeAndProtection($val);
296 $role_list_entry[
'role_type'] = $this->buildRoleType($role_list_entry);
297 $role_list_entry[
'protected'] = $this->buildProtectionByStringValue($role_list_entry[
'protected']);
298 return $role_list_entry;
303 if ($role_list_entry[
'type'] ===
'rolt') {
307 if ($role_list_entry[
'assign'] !==
'y') {
320 if ($value ===
'y') {
332 $query =
'select count(distinct(ua.usr_id)) as num from rbac_ua ua ' .
333 'join object_data on ua.usr_id = obj_id ' .
334 'join usr_data ud on ua.usr_id = ud.usr_id ' .
335 'where ' . $this->db->in(
'rol_id', $a_roles,
false,
'integer');
337 $res = $this->db->query($query);
338 if (
$res->numRows() > 0) {
340 return isset($row->num) && is_numeric($row->num) ? (
int) $row->num : 0;
351 if (isset(self::$assigned_users_cache[$a_rol_id])) {
352 return self::$assigned_users_cache[$a_rol_id];
356 $query =
"SELECT usr_id FROM rbac_ua WHERE rol_id= " . $this->db->quote($a_rol_id,
'integer');
357 $res = $this->db->query($query);
358 while ($row = $this->db->fetchAssoc(
$res)) {
359 $result_arr[] = (
int) $row[
"usr_id"];
361 self::$assigned_users_cache[$a_rol_id] = $result_arr;
368 public function isAssigned(
int $a_usr_id,
int $a_role_id): bool
370 if (isset(self::$is_assigned_cache[$a_role_id][$a_usr_id])) {
371 return self::$is_assigned_cache[$a_role_id][$a_usr_id];
374 $this->db->setLimit(1, 0);
375 $query =
"SELECT usr_id FROM rbac_ua WHERE " .
376 "rol_id= " . $this->db->quote($a_role_id,
'integer') .
" " .
378 $res = $this->db->query($query);
379 $is_assigned =
$res->numRows() == 1;
380 self::$is_assigned_cache[$a_role_id][$a_usr_id] = $is_assigned;
396 $this->db =
$DIC[
'ilDB'];
398 $this->db->setLimit(1, 0);
399 $query =
"SELECT usr_id FROM rbac_ua WHERE " .
400 $this->db->in(
'rol_id', $a_role_ids,
false,
'integer') .
402 $res = $this->db->query($query);
404 return $this->db->numRows(
$res) == 1;
413 $query =
"SELECT rol_id FROM rbac_ua WHERE usr_id = " . $this->db->quote($a_usr_id,
'integer');
415 $res = $this->db->query($query);
417 while ($row = $this->db->fetchObject(
$res)) {
418 $role_arr[] = (
int) $row->rol_id;
429 $query =
"SELECT ua.rol_id FROM rbac_ua ua " .
430 "JOIN rbac_fa fa ON ua.rol_id = fa.rol_id " .
431 "WHERE usr_id = " . $this->db->quote($a_usr_id,
'integer') .
' ' .
435 $res = $this->db->query($query);
437 while ($row = $this->db->fetchObject(
$res)) {
438 $role_arr[] = (
int) $row->rol_id;
454 $query =
"SELECT * FROM rbac_fa " .
455 "WHERE rol_id = " . $this->db->quote($a_rol_id,
'integer') .
" " .
456 "AND parent = " . $this->db->quote($a_ref_id,
'integer') .
" ";
457 $res = $this->db->query($query);
458 while ($row = $this->db->fetchObject(
$res)) {
459 return $row->assign ==
'y';
466 $query =
"SELECT * FROM rbac_fa WHERE rol_id = " . $this->db->quote($a_role_id,
'integer') .
' ' .
467 "AND assign = " . $this->db->quote(
'y',
'text');
468 $res = $this->db->query($query);
469 return $res->numRows() > 1;
485 $where =
" AND assign ='y'";
488 $query =
"SELECT DISTINCT parent FROM rbac_fa " .
489 "WHERE rol_id = " . $this->db->quote($a_rol_id,
'integer') .
" " . $where .
" ";
491 $res = $this->db->query($query);
493 while ($row = $this->db->fetchObject(
$res)) {
494 $folders[] = (
int) $row->parent;
506 if ($a_assignable_only ===
true) {
507 $and =
'AND assign = ' . $this->db->quote(
'y',
'text');
509 $query =
"SELECT rol_id FROM rbac_fa " .
510 "WHERE parent = " . $this->db->quote($a_ref_id,
'integer') .
" " .
513 $res = $this->db->query($query);
516 while ($row = $this->db->fetchObject(
$res)) {
517 $role_ids[] = (
int) $row->rol_id;
532 if ($a_nonassignable ===
false) {
533 $and =
" AND assign='y'";
536 $query =
"SELECT rol_id FROM rbac_fa " .
537 "WHERE parent = " . $this->db->quote($a_ref_id,
'integer') .
" " .
540 $res = $this->db->query($query);
542 while ($row = $this->db->fetchObject(
$res)) {
543 $rol_id[] = (
int) $row->rol_id;
566 foreach ($this->getRolesOfRoleFolder($a_ref_id) as $role_id) {
567 if ($this->isAssignable($role_id, $a_ref_id)) {
568 $lroles[] = $role_id;
581 foreach ($this->getRolesOfRoleFolder($a_ref_id) as $role_id) {
582 $lroles[] = $role_id;
594 foreach ($this->getRolesOfRoleFolder(
ROLE_FOLDER_ID,
false) as $role_id) {
595 $ga[] = [
'obj_id' => $role_id,
596 'role_type' =>
'global'
609 foreach ($this->getGlobalRoles() as $role_id) {
612 'obj_id' => $role_id,
613 'role_type' =>
'global'
625 $query =
'SELECT * FROM rbac_fa ' .
626 'WHERE rol_id = ' . $this->db->quote($a_role_id,
'integer') .
' ' .
627 'AND parent = ' . $this->db->quote($a_parent_id,
'integer');
628 $res = $this->db->query($query);
629 return (
bool)
$res->numRows();
638 $query =
'SELECT * FROM rbac_operations ORDER BY ops_id ';
639 $res = $this->db->query($query);
641 while ($row = $this->db->fetchObject(
$res)) {
642 $ops[] = [
'ops_id' => (
int) $row->ops_id,
643 'operation' => $row->operation,
644 'description' => $row->description
656 $query =
'SELECT * FROM rbac_operations WHERE ops_id = ' . $this->db->quote($ops_id,
'integer');
657 $res = $this->db->query($query);
659 while ($row = $this->db->fetchObject(
$res)) {
660 $ops = [
'ops_id' => (
int) $row->ops_id,
661 'operation' => $row->operation,
662 'description' => $row->description
678 $query =
"SELECT ops_id,type FROM rbac_templates " .
679 "WHERE rol_id = " . $this->db->quote($a_rol_id,
'integer') .
" " .
680 "AND parent = " . $this->db->quote($a_parent,
'integer');
681 $res = $this->db->query($query);
684 while ($row = $this->db->fetchObject(
$res)) {
685 $ops_arr[$row->type][] = (
int) $row->ops_id;
695 $query =
'SELECT * FROM rbac_pa ' .
696 'WHERE ref_id = ' . $this->db->quote($a_ref_id,
'integer') .
' ' .
697 'AND rol_id = ' . $this->db->quote($a_role_id,
'integer') .
' ';
699 $res = $this->db->query($query);
703 $row[
'ops_id'] ===
':' ? [] : unserialize($row[
'ops_id'], [
'allowed_classes' =>
false])
718 if ($a_parent == 0) {
722 $query =
"SELECT ops_id FROM rbac_templates " .
723 "WHERE type =" . $this->db->quote($a_type,
'text') .
" " .
724 "AND rol_id = " . $this->db->quote($a_rol_id,
'integer') .
" " .
725 "AND parent = " . $this->db->quote($a_parent,
'integer');
726 $res = $this->db->query($query);
727 while ($row = $this->db->fetchObject(
$res)) {
728 $ops_arr[] = $row->ops_id;
738 $query =
"SELECT ops_id FROM rbac_pa " .
739 "WHERE rol_id = " . $this->db->quote($a_role_id,
'integer') .
" " .
740 "AND ref_id = " . $this->db->quote($a_ref_id,
'integer') .
" ";
742 $res = $this->db->query($query);
744 while ($row = $this->db->fetchObject(
$res)) {
745 if ($row->ops_id !==
':') {
748 unserialize($row->ops_id, [
'allowed_classes' =>
false])
762 $query =
'SELECT ta.ops_id FROM rbac_ta ta JOIN rbac_operations o ON ta.ops_id = o.ops_id ' .
763 'WHERE typ_id = ' . $this->db->quote($a_typ_id,
'integer') .
' ' .
766 $res = $this->db->query($query);
768 while ($row = $this->db->fetchObject(
$res)) {
769 $ops_id[] = (
int) $row->ops_id;
780 $query =
"SELECT * FROM object_data WHERE type = 'typ' AND title = " . $this->db->quote($a_type,
'text') .
" ";
781 $res = $this->db->query($query);
783 return $this->getOperationsOnType((
int) $row->obj_id);
794 if ($a_class !=
'create') {
795 $condition =
"AND class != " . $this->db->quote(
'create',
'text');
797 $condition =
"AND class = " . $this->db->quote(
'create',
'text');
800 $query =
"SELECT ro.ops_id FROM rbac_operations ro " .
801 "JOIN rbac_ta rt ON ro.ops_id = rt.ops_id " .
802 "JOIN object_data od ON rt.typ_id = od.obj_id " .
803 "WHERE type = " . $this->db->quote(
'typ',
'text') .
" " .
804 "AND title = " . $this->db->quote($a_type,
'text') .
" " .
806 "ORDER BY op_order ";
808 $res = $this->db->query($query);
811 $ops[] = (
int) $row->ops_id;
823 $query =
'SELECT parent p FROM rbac_fa ' .
824 'WHERE assign = ' . $this->db->quote(
'n',
'text') .
' ' .
825 'AND rol_id = ' . $this->db->quote($a_rol_id,
'integer') .
' ';
827 if ($a_filter !== []) {
828 $query .= (
'AND ' . $this->db->in(
'parent', (array) $a_filter,
false,
'integer'));
831 $res = $this->db->query($query);
834 $parent[] = (
int) $row->p;
846 $r = $this->db->query(
$q);
851 '%s::isDeleted(): Role folder with ref_id %s not found!',
858 return $row->tree < 0;
866 return in_array($a_role_id, $this->getGlobalRoles());
872 public function getRolesByFilter(
int $a_filter = 0,
int $a_user_id = 0,
string $title_filter =
''): Generator
876 case self::FILTER_ALL:
877 return yield
from $this->getAssignableRolesGenerator(
true,
true, $title_filter);
879 case self::FILTER_ALL_GLOBAL:
880 $where =
'WHERE ' . $this->db->in(
'rbac_fa.rol_id', $this->getGlobalRoles(),
false,
'integer') .
' ';
883 case self::FILTER_ALL_LOCAL:
884 case self::FILTER_INTERNAL:
885 case self::FILTER_NOT_INTERNAL:
886 $where =
'WHERE ' . $this->db->in(
'rbac_fa.rol_id', $this->getGlobalRoles(),
true,
'integer');
889 case self::FILTER_TEMPLATES:
890 $where =
"WHERE object_data.type = 'rolt'";
900 $where =
'WHERE ' . $this->db->in(
902 $this->assignedRoles($a_user_id),
909 $query =
"SELECT * FROM object_data " .
910 "JOIN rbac_fa ON obj_id = rol_id " .
912 "AND rbac_fa.assign = " . $this->db->quote($assign,
'text') .
" ";
914 if (strlen($title_filter)) {
915 $query .= (
' AND ' . $this->db->like(
918 '%' . $title_filter .
'%'
922 $res = $this->db->query($query);
923 while ($row = $this->db->fetchAssoc(
$res)) {
924 $row[
'title'] = $row[
'title'] ??
'';
925 $prefix = str_starts_with($row[
'title'],
"il_");
928 if ($a_filter == 4 && !$prefix) {
933 if ($a_filter == 5 && $prefix) {
937 $row[
'description'] = $row[
'description'] ??
'';
938 $row[
"desc"] = $row[
"description"];
939 $row[
"user_id"] = (
int) $row[
"owner"];
940 $row[
'obj_id'] = (
int) $row[
'obj_id'];
941 $row[
'rol_id'] = (
int) $row[
'rol_id'];
942 $row[
'parent'] = (
int) $row[
'parent'];
944 yield $this->setRoleTypeAndProtection($row);
950 $q =
"SELECT obj_id FROM object_data " .
951 "WHERE title=" . $this->db->quote($a_type,
'text') .
" AND type='typ'";
952 $r = $this->db->query(
$q);
954 return (
int) $row->obj_id;
970 if ($operations === []) {
974 $query =
'SELECT ops_id FROM rbac_operations ' .
975 'WHERE ' .
$ilDB->in(
'operation', $operations,
false,
'text');
979 while ($row =
$ilDB->fetchObject(
$res)) {
980 $ops_ids[] = (
int) $row->ops_id;
995 if (!is_array(self::$_opsCache)) {
996 self::$_opsCache = [];
998 $q =
"SELECT ops_id, operation FROM rbac_operations";
1001 self::$_opsCache[$row->operation] = (
int) $row->ops_id;
1006 if (array_key_exists($a_operation, self::$_opsCache)) {
1007 return self::$_opsCache[$a_operation];
1024 foreach ($a_type_arr as $type) {
1025 $operations[] = (
'create_' . $type);
1028 if ($operations === []) {
1032 $query =
'SELECT ops_id, operation FROM rbac_operations ' .
1033 'WHERE ' .
$ilDB->in(
'operation', $operations,
false,
'text');
1038 while ($row =
$ilDB->fetchObject(
$res)) {
1039 $type_arr = explode(
'_', $row->operation);
1040 $type = $type_arr[1];
1042 $ops_ids[$type] = (
int) $row->ops_id;
1052 $query =
'SELECT protected FROM rbac_fa ' .
1054 $res = $this->db->query($query);
1056 if ($row->protected ===
'y') {
1065 $query =
'SELECT blocked from rbac_fa ' .
1066 'WHERE rol_id = ' . $this->db->quote($a_role_id,
'integer') .
' ' .
1067 'AND parent = ' . $this->db->quote($a_ref_id,
'integer');
1068 $res = $this->db->query($query);
1070 return (
bool) $row->blocked;
1083 $tree =
$DIC[
'tree'];
1085 if ($this->isBlockedAtPosition($a_role_id, $a_ref_id)) {
1088 $query =
'SELECT parent from rbac_fa ' .
1089 'WHERE rol_id = ' . $this->db->quote($a_role_id,
'integer') .
' ' .
1090 'AND blocked = ' . $this->db->quote(1,
'integer');
1091 $res = $this->db->query($query);
1095 $parent_ids[] = (
int) $row->parent;
1098 foreach ($parent_ids as $parent_id) {
1099 if ($tree->isGrandChild($parent_id, $a_ref_id)) {
1112 $rbacsystem =
$DIC->rbac()->system();
1113 $ilUser =
$DIC->user();
1114 if (in_array(
SYSTEM_ROLE_ID, $this->assignedRoles($ilUser->getId()))) {
1117 $leveladmin =
false;
1119 foreach ($a_role_hierarchy as $role_id => $rolf_id) {
1120 if ($leveladmin ==
true) {
1121 $a_parent_roles[$role_id][
'protected'] =
false;
1125 if ($a_parent_roles[$role_id][
'protected'] ==
true) {
1126 $arr_lvl_roles_user = array_intersect(
1127 $this->assignedRoles($ilUser->getId()),
1128 array_keys($a_role_hierarchy, $rolf_id)
1131 foreach ($arr_lvl_roles_user as $lvl_role_id) {
1133 $rolf = $a_parent_roles[$role_id][
'parent'];
1134 if ($rbacsystem->checkPermission($rolf, $lvl_role_id,
'edit_permission')) {
1135 $a_parent_roles[$role_id][
'protected'] =
false;
1140 return $a_parent_roles;
1155 'SELECT * FROM rbac_operations ' .
1156 'JOIN rbac_ta ON rbac_operations.ops_id = rbac_ta.ops_id ' .
1157 'JOIN object_data ON rbac_ta.typ_id = object_data.obj_id ' .
1158 'WHERE object_data.title = %s ' .
1159 'AND object_data.type = %s ' .
1160 'ORDER BY op_order ASC',
1161 $ilDB->quote($a_type,
'text'),
1162 $ilDB->quote(
'typ',
'text')
1165 $query =
'SELECT * FROM rbac_operations ORDER BY op_order ASC';
1168 while ($row =
$ilDB->fetchAssoc(
$res)) {
1170 "ops_id" => (
int) $row[
'ops_id'],
1171 "operation" => $row[
'operation'],
1172 "desc" => $row[
'description'],
1173 "class" => $row[
'class'],
1174 "order" => (
int) $row[
'op_order']
1186 foreach ($a_ops_arr as $ops) {
1187 $arr[$ops[
'class']][] = [
'ops_id' => (
int) $ops[
'ops_id'],
1188 'name' => $ops[
'operation']
1201 static $obj_cache = [];
1203 if (isset($obj_cache[$a_role_id]) && $obj_cache[$a_role_id]) {
1204 return $obj_cache[$a_role_id];
1207 $query =
'SELECT obr.obj_id FROM rbac_fa rfa ' .
1208 'JOIN object_reference obr ON rfa.parent = obr.ref_id ' .
1209 'WHERE assign = ' . $this->db->quote(
'y',
'text') .
' ' .
1210 'AND rol_id = ' . $this->db->quote($a_role_id,
'integer') .
' ' .
1211 'AND deleted IS NULL';
1213 $res = $this->db->query($query);
1214 $obj_cache[$a_role_id] = 0;
1215 while ($row = $this->db->fetchObject(
$res)) {
1216 $obj_cache[$a_role_id] = (
int) $row->obj_id;
1218 return $obj_cache[$a_role_id];
1223 $query =
'SELECT parent p_ref FROM rbac_fa ' .
1224 'WHERE rol_id = ' . $this->db->quote($a_role_id,
'integer') .
' ' .
1225 'AND assign = ' . $this->db->quote(
'y',
'text');
1227 $res = $this->db->query($query);
1229 return (
int) $row->p_ref;
1239 $rolf_list = $this->getFoldersAssignedToRole($a_role_id,
false);
1241 if ($rolf_list !== []) {
1242 foreach ($rolf_list as $rolf) {
1244 if (!$this->isDeleted($rolf)) {
1255 $where = $this->__setTemplateFilter($use_templates);
1256 $query =
"SELECT * FROM object_data " .
1257 "JOIN rbac_fa ON object_data.obj_id = rbac_fa.rol_id " .
1259 "AND rbac_fa.assign = 'y' " .
1260 'AND ' . $this->db->in(
'object_data.obj_id', $role_ids,
false,
'integer');
1262 $res = $this->db->query($query);
1264 while ($row = $this->db->fetchAssoc(
$res)) {
1265 $row[
"desc"] = $row[
"description"];
1266 $row[
"user_id"] = (
int) $row[
"owner"];
1267 $role_list[] = $row;
1269 return $this->__setRoleType($role_list);
1280 $this->db =
$DIC[
'ilDB'];
1282 $query =
'SELECT ta.typ_id, obj.title, ops.ops_id, ops.operation FROM rbac_ta ta ' .
1283 'JOIN object_data obj ON obj.obj_id = ta.typ_id ' .
1284 'JOIN rbac_operations ops ON ops.ops_id = ta.ops_id ';
1285 $res = $this->db->query($query);
1289 while ($row = $this->db->fetchObject(
$res)) {
1297 return array_values(
$info);
1305 if (!$this->isAssignable($a_role_id, $a_rolf_id)) {
1323 return substr($title, 0, 3) ==
'il_';
1326 public function getParentOfRole(
int $role_id, ?
int $object_ref =
null): ?
int
1330 $tree =
$DIC[
'tree'];
1333 return $this->getRoleFolderOfRole($role_id);
1337 $path_ids = $tree->getPathId($object_ref);
1340 while (
$ref_id = array_pop($path_ids)) {
1341 $roles = $this->getRoleListByObject(
$ref_id,
false);
1342 foreach ($roles as $role) {
1343 if ((
int) $role[
'obj_id'] === $role_id) {
1356 $and = (
'AND assign = ' . $this->db->quote(
'y',
'text'));
1361 $query =
'SELECT * FROM rbac_fa ' .
1362 'WHERE rol_id = ' . $this->db->quote($a_role_id,
'integer') .
' ' .
1364 $res = $this->db->query($query);
1366 return (
int) $row->parent;
1377 $query =
"SELECT ops_id FROM rbac_pa JOIN rbac_ua " .
1378 "ON (rbac_pa.rol_id = rbac_ua.rol_id) " .
1379 "WHERE rbac_ua.usr_id = " . $this->db->quote($a_user_id,
'integer') .
" " .
1380 "AND rbac_pa.ref_id = " . $this->db->quote($a_ref_id,
'integer') .
" ";
1382 $res = $this->db->query($query);
1384 while ($row = $this->db->fetchObject(
$res)) {
1385 $ops = unserialize($row->ops_id, [
'allowed_classes' =>
false]);
1386 $all_ops = array_merge($all_ops, $ops);
1388 $all_ops = array_unique($all_ops);
1390 $set = $this->db->query(
"SELECT operation FROM rbac_operations " .
1391 " WHERE " . $this->db->in(
"ops_id", $all_ops,
false,
"integer"));
1393 while ($rec = $this->db->fetchAssoc($set)) {
1394 $perms[] = $rec[
"operation"];
1397 return array_values(array_filter($perms));
1405 self::$is_assigned_cache[$a_role_id][$a_user_id] = $a_value;
1410 return self::$is_assigned_cache[$a_role_id][$a_user_id];
1418 self::$is_assigned_cache = [];
1419 self::$assigned_users_cache = [];
1430 "SELECT ops_id" . PHP_EOL
1431 .
"FROM rbac_operations" . PHP_EOL
1432 .
"WHERE operation = " .
$ilDB->quote($operation,
"text") . PHP_EOL
1441 return (
int) $row[
"ops_id"] ??
null;
1452 "SELECT typ_id" . PHP_EOL
1453 .
"FROM rbac_ta" . PHP_EOL
1454 .
"WHERE typ_id = " .
$ilDB->quote($type_id,
"integer") . PHP_EOL
1455 .
"AND ops_id = " .
$ilDB->quote($ops_id,
"integer") . PHP_EOL
1458 return (
bool)
$ilDB->numRows(
$ilDB->query($sql));
$id
plugin.php for ilComponentBuildPluginInfoObjectiveTest::testAddPlugins
static getLogger(string $a_component_id)
Get component logger.
Component logger with individual log levels by component id.
static _getAssignUsersStatus(int $a_role_id)
static _lookupType(int $id, bool $reference=false)
static _lookupTitle(int $obj_id)
class ilRbacReview Contains Review functions of core Rbac.
getAssignableRoles(bool $a_templates=false, bool $a_internal_roles=false, string $title_filter='')
Returns a list of all assignable roles.
buildRoleType(array $role_list_entry)
getAssignableRolesGenerator(bool $a_templates=false, bool $a_internal_roles=false, string $title_filter='')
getTypeId(string $a_type)
isDeleted(int $a_node_id)
Checks if a rolefolder is set as deleted (negative tree_id)
static array $assigned_users_cache
getAssignedCacheEntry(int $a_role_id, int $a_user_id)
static _getOperationIdsByName(array $operations)
get ops_id's by name.
getRolesForIDs(array $role_ids, bool $use_templates)
hasMultipleAssignments(int $a_role_id)
isBlockedAtPosition(int $a_role_id, int $a_ref_id)
isRoleDeleted(int $a_role_id)
return if role is only attached to deleted role folders
getObjectReferenceOfRole(int $a_role_id)
__getParentRoles(array $a_path, bool $a_templates)
Note: This function performs faster than the new getParentRoles function, because it uses database in...
__setRoleType(array $a_role_list)
computes role type in role list array: global: roles in ROLE_FOLDER_ID local: assignable roles in oth...
assignedRoles(int $a_usr_id)
get all assigned roles to a given user
getAssignableRolesInSubtree(int $ref_id)
Returns a list of assignable roles in a subtree of the repository.
getGlobalRoles()
get only 'global' roles
const FILTER_NOT_INTERNAL
static lookupCreateOperationIds(array $a_type_arr)
Lookup operation ids.
getObjectsWithStopedInheritance(int $a_rol_id, array $a_filter=[])
get all objects in which the inheritance of role with role_id was stopped the function returns all re...
static _getCustomRBACOperationId(string $operation, ?\ilDBInterface $ilDB=null)
isProtected(int $a_ref_id, int $a_role_id)
ref_id not used yet.
isBlockedInUpperContext(int $a_role_id, int $a_ref_id)
Check if role is blocked in upper context.
getAllOperationsOfRole(int $a_rol_id, int $a_parent=0)
get all possible operations of a specific role The ref_id of the role folder (parent object) is neces...
setRoleTypeAndProtection(array $role_list_entry)
getAssignableChildRoles(int $a_ref_id)
Get all assignable roles directly under a specific node.
static _groupOperationsByClass(array $a_ops_arr)
getRolesOfObject(int $a_ref_id, bool $a_assignable_only=false)
Get roles of object.
getParentRoleIds(int $a_endnode_id, bool $a_templates=false)
Get an array of parent role ids of all parent roles, if last parameter is set true you get also all p...
roleExists(string $a_title, int $a_id=0)
Checks if a role already exists.
clearCaches()
Clear assigned users caches.
__setProtectedStatus(array $a_parent_roles, array $a_role_hierarchy, int $a_ref_id)
assignedUsers(int $a_rol_id)
get all assigned users to a given role
isAssignedToAtLeastOneGivenRole(int $a_usr_id, array $a_role_ids)
check if a specific user is assigned to at least one of the given role ids.
static _isRBACOperation(int $type_id, int $ops_id, ?\ilDBInterface $ilDB=null)
getUserPermissionsOnObject(int $a_user_id, int $a_ref_id)
Get all user permissions on an object.
getRoleFolderOfRole(int $a_role_id)
isAssigned(int $a_usr_id, int $a_role_id)
check if a specific user is assigned to specific role
getFoldersAssignedToRole(int $a_rol_id, bool $a_assignable=false)
Returns an array of objects assigned to a role.
getGlobalAssignableRoles()
get only 'global' roles (with flag 'assign_users')
getRolesOfRoleFolder(int $a_ref_id, bool $a_nonassignable=true)
get all roles of a role folder including linked local roles that are created due to stopped inheritan...
buildProtectionByStringValue(string $value)
isSystemGeneratedRole(int $a_role_id)
Check if the role is system generate role or role template.
__setTemplateFilter(bool $a_templates)
get roles and templates or only roles; returns string for where clause
getOperationsOfRole(int $a_rol_id, string $a_type, int $a_parent=0)
get all possible operations of a specific role The ref_id of the role folder (parent object) is neces...
getNumberOfAssignedUsers(array $a_roles)
Get the number of assigned users to roles (not properly deleted user accounts are not counted)
isRoleAssignedToObject(int $a_role_id, int $a_parent_id)
Check if role is assigned to an object.
assignedGlobalRoles(int $a_usr_id)
Get assigned global roles for an user.
getLocalPolicies(int $a_ref_id)
Get all roles with local policies.
isAssignable(int $a_rol_id, int $a_ref_id)
Check if its possible to assign users.
getRoleListByObject(int $a_ref_id, bool $a_templates=false)
Returns a list of roles in an container.
static array $is_assigned_cache
getOperationsOnTypeString(string $a_type)
all possible operations of a type
getOperation(int $ops_id)
get one operation by operation id
getGlobalRolesArray()
get only 'global' roles
getRolesByFilter(int $a_filter=0, int $a_user_id=0, string $title_filter='')
setAssignedCacheEntry(int $a_role_id, int $a_user_id, bool $a_value)
set entry of assigned_chache
getOperationsByTypeAndClass(string $a_type, string $a_class)
Get operations by type and class.
getOperationAssignment()
get operation assignments
getActiveOperationsOfRole(int $a_ref_id, int $a_role_id)
__construct()
Constructor @access public.
isGlobalRole(int $a_role_id)
Check if role is a global role.
getRoleOperationsOnObject(int $a_role_id, int $a_ref_id)
getObjectOfRole(int $a_role_id)
Get object id of objects a role is assigned to.
getOperations()
get all possible operations
getLocalRoles(int $a_ref_id)
Get local roles of object.
getOperationsOnType(int $a_typ_id)
all possible operations of a type
static _getOperationIdByName(string $a_operation)
get operation id by name of operation
static _getOperationList(string $a_type='')
get operation list by object type
isDeleteable(int $a_role_id, int $a_rolf_id)
Check if role is deleteable at a specific position.
return['delivery_method'=> 'php',]
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...