public function EventEnrollmentEntityDeleteAction::access in Open Social 10.3.x
Same name and namespace in other branches
- 8.9 modules/social_features/social_event/modules/social_event_managers/src/Plugin/Action/EventEnrollmentEntityDeleteAction.php \Drupal\social_event_managers\Plugin\Action\EventEnrollmentEntityDeleteAction::access()
- 8.5 modules/social_features/social_event/modules/social_event_managers/src/Plugin/Action/EventEnrollmentEntityDeleteAction.php \Drupal\social_event_managers\Plugin\Action\EventEnrollmentEntityDeleteAction::access()
- 8.6 modules/social_features/social_event/modules/social_event_managers/src/Plugin/Action/EventEnrollmentEntityDeleteAction.php \Drupal\social_event_managers\Plugin\Action\EventEnrollmentEntityDeleteAction::access()
- 8.7 modules/social_features/social_event/modules/social_event_managers/src/Plugin/Action/EventEnrollmentEntityDeleteAction.php \Drupal\social_event_managers\Plugin\Action\EventEnrollmentEntityDeleteAction::access()
- 8.8 modules/social_features/social_event/modules/social_event_managers/src/Plugin/Action/EventEnrollmentEntityDeleteAction.php \Drupal\social_event_managers\Plugin\Action\EventEnrollmentEntityDeleteAction::access()
- 10.0.x modules/social_features/social_event/modules/social_event_managers/src/Plugin/Action/EventEnrollmentEntityDeleteAction.php \Drupal\social_event_managers\Plugin\Action\EventEnrollmentEntityDeleteAction::access()
- 10.1.x modules/social_features/social_event/modules/social_event_managers/src/Plugin/Action/EventEnrollmentEntityDeleteAction.php \Drupal\social_event_managers\Plugin\Action\EventEnrollmentEntityDeleteAction::access()
- 10.2.x modules/social_features/social_event/modules/social_event_managers/src/Plugin/Action/EventEnrollmentEntityDeleteAction.php \Drupal\social_event_managers\Plugin\Action\EventEnrollmentEntityDeleteAction::access()
Checks object access.
Parameters
mixed $object: The object to execute the action on.
\Drupal\Core\Session\AccountInterface $account: (optional) The user for which to check access, or NULL to check access for the current user. Defaults to NULL.
bool $return_as_object: (optional) Defaults to FALSE.
Return value
bool|\Drupal\Core\Access\AccessResultInterface The access result. Returns a boolean if $return_as_object is FALSE (this is the default) and otherwise an AccessResultInterface object. When a boolean is returned, the result of AccessInterface::isAllowed() is returned, i.e. TRUE means access is explicitly allowed, FALSE means access is either explicitly forbidden or "no opinion".
Overrides ActionInterface::access
File
- modules/
social_features/ social_event/ modules/ social_event_managers/ src/ Plugin/ Action/ EventEnrollmentEntityDeleteAction.php, line 35
Class
- EventEnrollmentEntityDeleteAction
- Delete event enrollment entity action.
Namespace
Drupal\social_event_managers\Plugin\ActionCode
public function access($object, AccountInterface $account = NULL, $return_as_object = FALSE) {
$access = AccessResult::forbidden();
if ($object instanceof EventEnrollmentInterface) {
$access = $object
->access('delete', $account, TRUE);
$event_id = $object
->getFieldValue('field_event', 'target_id');
$node = \Drupal::entityTypeManager()
->getStorage('node')
->load($event_id);
// Also Event organizers can do this.
if ($node instanceof NodeInterface && social_event_manager_or_organizer($node)) {
$access = AccessResult::allowedIf($object instanceof EventEnrollmentInterface);
}
}
return $return_as_object ? $access : $access
->isAllowed();
}