18 declare(strict_types=1);
57 protected function __construct(
string $a_component_name,
int $a_obj_id,
int $a_usr_id)
61 $this->obj_id = $a_obj_id;
62 $this->usr_id = $a_usr_id;
65 $this->ref_id = current($ref_ids);
66 $this->component = $a_component_name;
69 $this->db = $DIC->database();
70 $this->rbacReview = $DIC->rbac()->review();
71 $this->rbacAdmin = $DIC->rbac()->admin();
73 $this->eventHandler = $DIC->event();
79 public static function updateMemberRoles(
int $a_obj_id,
int $a_usr_id,
int $a_role_id,
int $a_status): void
83 $ilDB = $DIC->database();
85 $a_membership_role_type = self::getMembershipRoleType($a_role_id);
86 switch ($a_membership_role_type) {
87 case self::MEMBERSHIP_ADMIN:
88 $update_fields = array(
'admin' => array(
'integer', $a_status ? 1 : 0));
89 $update_string = (
'admin = ' .
$ilDB->quote($a_status ? 1 : 0,
'integer'));
92 case self::MEMBERSHIP_TUTOR:
93 $update_fields = array(
'tutor' => array(
'integer', $a_status ? 1 : 0));
94 $update_string = (
'tutor = ' .
$ilDB->quote($a_status ? 1 : 0,
'integer'));
97 case self::MEMBERSHIP_MEMBER:
99 $current_status = self::lookupStatusByMembershipRoleType($a_obj_id, $a_usr_id, $a_membership_role_type);
102 $new_status = $current_status + 1;
105 $new_status = $current_status - 1;
106 if ($new_status < 0) {
111 $update_fields = array(
'member' => array(
'integer', $new_status));
112 $update_string = (
'member = ' .
$ilDB->quote($new_status,
'integer'));
116 $query =
'SELECT count(*) num FROM obj_members ' .
117 'WHERE obj_id = ' .
$ilDB->quote($a_obj_id,
'integer') .
' ' .
118 'AND usr_id = ' .
$ilDB->quote($a_usr_id,
'integer');
131 'obj_id' => array(
'integer', $a_obj_id),
132 'usr_id' => array(
'integer', $a_usr_id)
137 $query =
'UPDATE obj_members SET ' .
138 $update_string .
' ' .
139 'WHERE obj_id = ' .
$ilDB->quote($a_obj_id,
'integer') .
' ' .
140 'AND usr_id = ' .
$ilDB->quote($a_usr_id,
'integer');
142 $ilDB->manipulate($query);
145 $query =
'DELETE from obj_members ' .
146 'WHERE obj_id = ' .
$ilDB->quote($a_obj_id,
'integer') .
' ' .
147 'AND usr_id = ' .
$ilDB->quote($a_usr_id,
'integer') .
' ' .
148 'AND admin = ' .
$ilDB->quote(0,
'integer') .
' ' .
149 'AND tutor = ' .
$ilDB->quote(0,
'integer') .
' ' .
150 'AND member = ' .
$ilDB->quote(0,
'integer');
151 $ilDB->manipulate($query);
157 switch (substr($title, 0, 8)) {
160 return self::MEMBERSHIP_ADMIN;
163 return self::MEMBERSHIP_TUTOR;
167 return self::MEMBERSHIP_MEMBER;
174 int $a_membership_role_type
178 $ilDB = $DIC->database();
179 $query =
'SELECT * FROM obj_members ' .
180 'WHERE obj_id = ' .
$ilDB->quote($a_obj_id,
'integer') .
' ' .
184 switch ($a_membership_role_type) {
185 case self::MEMBERSHIP_ADMIN:
186 return (
int) $row->admin;
188 case self::MEMBERSHIP_TUTOR:
189 return (
int) $row->tutor;
191 case self::MEMBERSHIP_MEMBER:
192 return (
int) $row->member;
214 return (
bool) ($this->participants_status[$this->
getUserId()][
'blocked'] ??
false);
222 return (
bool) ($this->participants_status[$this->
getUserId()][
'contact'] ??
false);
252 if ($this->numMembers ===
null) {
253 $this->numMembers = $this->rbacReview->getNumberOfAssignedUsers($this->member_roles);
260 $this->roles = $this->rbacReview->getRolesOfRoleFolder($this->ref_id,
false);
261 $this->member_roles = [];
262 foreach ($this->roles as $role_id) {
264 switch (substr($title, 0, 8)) {
266 $this->member_roles[] = $role_id;
268 if ($this->rbacReview->isAssigned($this->getUserId(), $role_id)) {
269 $this->participants =
true;
270 $this->members =
true;
276 if ($this->rbacReview->isAssigned($this->getUserId(), $role_id)) {
277 $this->participants =
true;
278 $this->admins =
true;
284 if ($this->rbacReview->isAssigned($this->getUserId(), $role_id)) {
285 $this->participants =
true;
286 $this->tutors =
true;
292 if ($this->rbacReview->isAssigned($this->getUserId(), $role_id)) {
293 $this->participants =
true;
294 $this->admins =
true;
299 $this->member_roles[] = $role_id;
301 if ($this->rbacReview->isAssigned($this->getUserId(), $role_id)) {
302 $this->participants =
true;
303 $this->members =
true;
309 $this->member_roles[] = $role_id;
310 if ($this->rbacReview->isAssigned($this->getUserId(), $role_id)) {
311 $this->participants =
true;
312 $this->members =
true;
321 $query =
"SELECT * FROM obj_members " .
322 "WHERE obj_id = " . $this->db->quote($this->obj_id,
'integer') .
" " .
323 'AND usr_id = ' . $this->db->quote($this->
getUserId(),
'integer');
325 $res = $this->db->query($query);
326 $this->participants_status = array();
328 $this->participants_status[$this->
getUserId()][
'blocked'] = (bool) $row->blocked;
329 $this->participants_status[$this->getUserId()][
'notification'] = (bool) $row->notification;
330 $this->participants_status[$this->getUserId()][
'passed'] = (bool) $row->passed;
331 $this->participants_status[$this->getUserId()][
'contact'] = (bool) $row->contact;
335 public function add(
int $a_usr_id,
int $a_role): bool
337 if ($this->rbacReview->isAssignedToAtLeastOneGivenRole($a_usr_id, $this->roles)) {
344 $this->admins =
true;
348 $this->tutors =
true;
353 $this->members =
true;
357 $this->rbacAdmin->assignUser($this->role_data[$a_role], $a_usr_id);
365 $this->eventHandler->raise(
369 'obj_id' => $this->obj_id,
370 'usr_id' => $a_usr_id,
377 public function delete(
int $a_usr_id):
void 379 $this->recommended_content_manager->removeObjectRecommendation($a_usr_id, $this->ref_id);
380 foreach ($this->roles as $role_id) {
381 $this->rbacAdmin->deassignUser($role_id, $a_usr_id);
384 $query =
"DELETE FROM obj_members " .
385 "WHERE usr_id = " . $this->db->quote($a_usr_id,
'integer') .
" " .
386 "AND obj_id = " . $this->db->quote($this->obj_id,
'integer');
387 $res = $this->db->manipulate($query);
389 $this->eventHandler->raise(
393 'obj_id' => $this->obj_id,
394 'usr_id' => $a_usr_id
401 $query =
"DELETE FROM il_subscribers " .
402 "WHERE usr_id = " . $this->db->quote($a_usr_id,
'integer') .
" " .
403 "AND obj_id = " . $this->db->quote($this->obj_id,
'integer') .
" ";
404 $res = $this->db->manipulate($query);
416 $this->db->manipulate(
417 'UPDATE obj_members SET ' .
418 'contact = ' . $this->db->quote($a_contact,
'integer') .
' ' .
419 'WHERE obj_id = ' . $this->db->quote($this->obj_id,
'integer') .
' ' .
420 'AND usr_id = ' . $this->db->quote($a_usr_id,
'integer')
422 $this->participants_status[$a_usr_id][
'contact'] = $a_contact;
427 $this->participants_status[$a_usr_id][
'notification'] = $a_notification;
429 $query =
"SELECT * FROM obj_members " .
430 "WHERE obj_id = " . $this->db->quote($this->obj_id,
'integer') .
" " .
431 "AND usr_id = " . $this->db->quote($a_usr_id,
'integer');
432 $res = $this->db->query($query);
433 if (
$res->numRows()) {
434 $query =
"UPDATE obj_members SET " .
435 "notification = " . $this->db->quote((
int) $a_notification,
'integer') .
" " .
436 "WHERE obj_id = " . $this->db->quote($this->obj_id,
'integer') .
" " .
437 "AND usr_id = " . $this->db->quote($a_usr_id,
'integer');
439 $query =
"INSERT INTO obj_members (notification,obj_id,usr_id,passed,blocked) " .
441 $this->db->quote((
int) $a_notification,
'integer') .
", " .
442 $this->db->quote($this->obj_id,
'integer') .
", " .
443 $this->db->quote($a_usr_id,
'integer') .
", " .
444 $this->db->quote(0,
'integer') .
", " .
445 $this->db->quote(0,
'integer') .
446 ") ON DUPLICATE KEY UPDATE notification = VALUES(notification)";
448 $this->db->manipulate($query);
454 $this->type ===
'crs' ?
459 SELECT COUNT(rolesusers.usr_id) cnt 461 FROM object_data rdata 463 LEFT JOIN rbac_ua rolesusers 464 ON rolesusers.rol_id = rdata.obj_id 466 WHERE rdata.obj_id = %s 469 $query .=
' AND ' . $this->db->in(
'rolesusers.usr_id', $a_usr_ids,
true,
'integer');
470 $res = $this->db->queryF($query, array(
'integer'), array($admin_role_id));
473 return $data[
'cnt'] > 0;
__construct(string $a_component_name, int $a_obj_id, int $a_usr_id)
static getMembershipRoleType(int $a_role_id)
updateContact(int $a_usr_id, bool $a_contact)
isContact()
Check if user is contact for current object.
static _getAllReferences(int $id)
get all reference ids for object ID
getComponent()
Get component name Used for event handling.
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
static updateMemberRoles(int $a_obj_id, int $a_usr_id, int $a_role_id, int $a_status)
addRecommendation($a_usr_id)
array $participants_status
updateNotification(int $a_usr_id, bool $a_notification)
add(int $a_usr_id, int $a_role)
static _lookupTitle(int $obj_id)
static lookupStatusByMembershipRoleType(int $a_obj_id, int $a_usr_id, int $a_membership_role_type)
Base class for course and group participant.
static deleteUserEntry(int $a_usr_id, int $a_obj_id)
ilRecommendedContentManager $recommended_content_manager
deleteSubscriber(int $a_usr_id)
ilObjectDataCache $objectDataCache
ilAppEventHandler $eventHandler
checkLastAdmin(array $a_usr_ids)
Class ilRbacAdmin Core functions for role based access control.
static _lookupType(int $id, bool $reference=false)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...