ILIAS  trunk Revision v11.0_alpha-1713-gd8962da2f67
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilObjEmployeeTalkAccess.php
Go to the documentation of this file.
1 <?php
2 
19 declare(strict_types=1);
20 
27 
29 {
30  private static ?self $instance = null;
33  private IlOrgUnitPositionAccess $orgUnitAccess;
37 
38  public static function getInstance(): self
39  {
40  if (is_null(self::$instance)) {
41  self::$instance = new ilObjEmployeeTalkAccess();
42  }
43 
44  return self::$instance;
45  }
46 
47  public function __construct()
48  {
49  $this->container = $GLOBALS['DIC'];
50 
53  $this->orgUnitAccess = new ilOrgUnitPositionAccess($this->container->access());
54  $this->talkPositionSettings = $this->set->getObjectPositionSettingsByType(ilObjEmployeeTalk::TYPE);
55  $this->seriesSettingsRepository = new IliasDBEmployeeTalkSeriesRepository($this->container->user(), $this->container->database());
56  }
57 
70  public static function _getCommands(): array
71  {
72  $commands = [
73  [
74  'permission' => 'read',
75  'cmd' => ControlFlowCommand::DEFAULT,
76  'lang_var' => 'show',
77  'default' => true,
78  ]
79  ];
80 
81  return $commands;
82  }
83 
84  public static function _isOffline($obj_id): bool
85  {
86  return false;
87  }
88 
89  public static function _checkGoto($target): bool
90  {
91  $access = new self();
92 
93  $t_arr = explode('_', $target);
94  if ($t_arr[0] !== 'etal' || ((int) $t_arr[1]) <= 0) {
95  return false;
96  }
97  if ($access->canRead(intval($t_arr[1]))) {
98  return true;
99  }
100 
101  return false;
102  }
103 
115  public function canCreate(?ilObjUser $talkParticipant = null): bool
116  {
117  try {
118  $currentUserId = $this->getCurrentUsersId();
119 
120  // Root has always full access
121  if ($currentUserId === 6) {
122  return true;
123  }
124 
125  // Talks are never editable if the position rights are not active, because the talks don't use RBAC
126  if (!$this->talkPositionSettings->isActive()) {
127  return false;
128  }
129 
130  $positions = $this->ua->getPositionsOfUserId($currentUserId);
131 
132  // If we don't have a user just check if the current user has the right in any position to create a new talk
133  if ($talkParticipant === null) {
134  foreach ($positions as $position) {
135  // Check if the position has any relevant position rights
136  $permissionSet = ilOrgUnitPermissionQueries::getTemplateSetForContextName(ilObjEmployeeTalk::TYPE, strval($position->getId() ?? 0));
137  $isAbleToExecuteOperation = array_reduce($permissionSet->getOperations(), function (bool $prev, ilOrgUnitOperation $it) {
138  return $prev || $it->getOperationString() === EmployeeTalkPositionAccessLevel::CREATE;
139  }, false);
140 
141  // If the position has no rights check the next one
142  if (!$isAbleToExecuteOperation) {
143  continue;
144  }
145 
146  return true;
147  }
148 
149  // The current user was not in a position with create etal position rights
150  return false;
151  }
152 
153  // Validate authority and position rights over the given participant
154  return $this->hasAuthorityAndOperationPermissionOverUser($talkParticipant, EmployeeTalkPositionAccessLevel::CREATE);
155  } catch (\Exception $ex) {
156  return false;
157  }
158  }
159 
160  public function hasPermissionToReadUnownedTalksOfUser(int $userId): bool
161  {
162  try {
163  return $this->hasAuthorityAndOperationPermissionOverUser(new ilObjUser($userId), EmployeeTalkPositionAccessLevel::VIEW);
164  } catch (\Exception $ex) {
165  return false;
166  }
167  }
168 
169  public function canRead(int $refId): bool
170  {
171  return $this->isPermittedToExecuteOperation($refId, EmployeeTalkPositionAccessLevel::VIEW);
172  }
173 
174  public function canEditTalkLockStatus(int $refId): bool
175  {
176  $currentUserId = $this->getCurrentUsersId();
177 
178  // Root has always full access
179  if ($currentUserId === 6) {
180  return true;
181  }
182 
183  $talk = new ilObjEmployeeTalk($refId);
184  return $talk->getOwner() === $currentUserId;
185  }
186 
191  public function canEdit(int $refId): bool
192  {
193  return $this->isPermittedToExecuteOperation($refId, EmployeeTalkPositionAccessLevel::EDIT);
194  }
195 
200  public function canDelete(int $refId): bool
201  {
202  $talk = new ilObjEmployeeTalk($refId);
203  $user = $this->getCurrentUsersId();
204  if ($user === $talk->getOwner()) {
205  return true;
206  }
207  // global admins can delete
208  if ($this->container->rbac()->review()->isAssigned(
209  $user,
211  )) {
212  return true;
213  }
214  return false;
215  }
216 
217  private function isPermittedToExecuteOperation(int $refId, string $operation): bool
218  {
219  $currentUserId = $this->getCurrentUsersId();
220 
221  // Root has always full access
222  if ($currentUserId === 6) {
223  return true;
224  }
225 
226  // Talks are never editable if the position rights are not active, because the talks don't use RBAC
227  if (!$this->talkPositionSettings->isActive()) {
228  return false;
229  }
230 
231  $talk = new ilObjEmployeeTalk($refId);
232  $series = $talk->getParent();
233  $hasAuthority = $this->hasAuthorityAndOperationPermissionOverUser(new ilObjUser($talk->getData()->getEmployee()), $operation);
234  $data = $talk->getData();
235  $seriesSettings = $this->seriesSettingsRepository->readEmployeeTalkSerieSettings($series->getId());
236  $canExecuteOperation = $this->orgUnitAccess->checkPositionAccess($operation, $refId);
237  $isOwner = $talk->getOwner() === $currentUserId;
238 
239  if ($isOwner) {
240  return true;
241  }
242 
243  if ($currentUserId === $data->getEmployee()) {
244  // The Employee can never edit their own talks
245  if ($operation !== EmployeeTalkPositionAccessLevel::VIEW) {
246  return false;
247  }
248 
249  // The Employee can always read their own talks
250  return true;
251  }
252 
253  //Only owner can edit talks with enabled write lock
254  if ($seriesSettings->isLockedEditing() && $operation === EmployeeTalkPositionAccessLevel::EDIT) {
255  return false;
256  }
257 
258  // Has no authority over the employee
259  if (!$hasAuthority) {
260  return false;
261  }
262 
263  // Has Authority and is permitted to execute the given permission
264  if ($canExecuteOperation) {
265  return true;
266  }
267 
268  // Has authority but no permission
269  return false;
270  }
271 
277  public function isTalkReadonlyByCurrentUser(int $ref_id): bool
278  {
279  return !$this->canEdit($ref_id);
280  }
281 
285  private function getCurrentUsersId(): int
286  {
287  return $this->container->user()->getId();
288  }
289 
290  private function hasAuthorityAndOperationPermissionOverUser(ilObjUser $user, string $operation): bool
291  {
292  $myStaffAccess = ilMyStaffAccess::getInstance();
293  $currentUserId = $this->getCurrentUsersId();
294  $userId = $user->getId();
295 
299  $managedOrgUnitUsersOfUserByPosition = $myStaffAccess->getUsersForUserPerPosition($currentUserId);
300 
301  foreach ($managedOrgUnitUsersOfUserByPosition as $position => $managedOrgUnitUserByPosition) {
302  // Check if the position has any relevant position rights
304  $isAbleToExecuteOperation = array_reduce($permissionSet->getOperations(), function (bool $prev, ilOrgUnitOperation $it) use ($operation) {
305  return $prev || $it->getOperationString() === $operation;
306  }, false);
307 
308  if (!$isAbleToExecuteOperation) {
309  continue;
310  }
311 
312  foreach ($managedOrgUnitUserByPosition as $managedOrgUnitUser) {
313  if (intval($managedOrgUnitUser) === $userId) {
314  return true;
315  }
316  }
317  }
318 
319  return false;
320  }
321 }
ilOrgUnitObjectTypePositionSetting $talkPositionSettings
ilOrgUnitUserAssignmentQueries $ua
IlOrgUnitPositionAccess $orgUnitAccess
const SYSTEM_ROLE_ID
Definition: constants.php:29
isPermittedToExecuteOperation(int $refId, string $operation)
static getTemplateSetForContextName(string $context_name, string $position_id, bool $editable=false)
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
$refId
Definition: xapitoken.php:58
IliasDBEmployeeTalkSeriesRepository $seriesSettingsRepository
Customizing of pimple-DIC for ILIAS.
Definition: Container.php:35
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
canCreate(?ilObjUser $talkParticipant=null)
Checks if the user is allowed to create a new talks series.
$ref_id
Definition: ltiauth.php:65
$GLOBALS["DIC"]
Definition: wac.php:53
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...