iframe_consent-1.0.x-dev/src/IframeConsentDomainAccessControlHandler.php
src/IframeConsentDomainAccessControlHandler.php
<?php
declare(strict_types=1);
namespace Drupal\iframe_consent;
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 domains entity type.
*
* phpcs:disable Drupal.Arrays.Array.LongLineDeclaration
*
* @see https://www.drupal.org/project/coder/issues/3185082
*/
final class IframeConsentDomainAccessControlHandler extends EntityAccessControlHandler {
/**
* {@inheritdoc}
*/
protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account): AccessResult {
if ($account->hasPermission($this->entityType->getAdminPermission())) {
return AccessResult::allowed()->cachePerPermissions();
}
return match($operation) {
'view' => AccessResult::allowedIfHasPermission($account, 'view iframe_consent_domains'),
'update' => AccessResult::allowedIfHasPermission($account, 'edit iframe_consent_domains'),
'delete' => AccessResult::allowedIfHasPermission($account, 'delete iframe_consent_domains'),
default => AccessResult::neutral(),
};
}
/**
* {@inheritdoc}
*/
protected function checkCreateAccess(AccountInterface $account, array $context, $entity_bundle = NULL): AccessResult {
return AccessResult::allowedIfHasPermissions($account, ['create iframe_consent_domains', 'administer iframe_consent_domains'], 'OR');
}
}
