bm-1.0.x-dev/src/BookingManagerAccessControlHandler.php
src/BookingManagerAccessControlHandler.php
<?php declare(strict_types = 1);
namespace Drupal\bm;
use Drupal\Core\Access\AccessResult;
use Drupal\Core\Entity\EntityAccessControlHandler;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Session\AccountInterface;
/**
* Defines the access control handler for the booking manager entity type.
*
* phpcs:disable Drupal.Arrays.Array.LongLineDeclaration
*
* @see https://www.drupal.org/project/coder/issues/3185082
*/
final class BookingManagerAccessControlHandler extends EntityAccessControlHandler {
/**
* {@inheritdoc}
*/
protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account): AccessResult {
return match($operation) {
'view' => AccessResult::allowedIfHasPermissions($account, ['view bm', 'administer bm types'], 'OR'),
'update' => AccessResult::allowedIfHasPermissions($account, ['edit bm', 'administer bm types'], 'OR'),
'delete' => AccessResult::allowedIfHasPermissions($account, ['delete bm', 'administer bm types'], 'OR'),
default => AccessResult::neutral(),
};
}
/**
* {@inheritdoc}
*/
protected function checkCreateAccess(AccountInterface $account, array $context, $entity_bundle = NULL): AccessResult {
return AccessResult::allowedIfHasPermissions($account, ['create bm', 'administer bm types'], 'OR');
}
}
