admin_ui-8.x-1.x-dev/modules/jsonapi_tables/src/ReadOnlyAccessControlHandler.php
modules/jsonapi_tables/src/ReadOnlyAccessControlHandler.php
<?php
namespace Drupal\jsonapi_tables;
use Drupal\Core\Access\AccessResult;
use Drupal\Core\Access\AccessResultForbidden;
use Drupal\Core\Entity\EntityAccessControlHandler;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Session\AccountInterface;
/**
* Access controller for the Read only entity types.
*
* @see \Drupal\jsonapi_tables\Entity\WatchdogEntity.
*/
class ReadOnlyAccessControlHandler extends EntityAccessControlHandler {
/**
* {@inheritdoc}
*/
protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) {
if ($operation === 'view') {
return AccessResult::allowedIfHasPermission($account, $entity->getEntityType()->getAdminPermission());
}
return $this->getForbiddenAccessResult();
}
/**
* {@inheritdoc}
*/
protected function checkCreateAccess(AccountInterface $account, array $context, $entity_bundle = NULL) {
return $this->getForbiddenAccessResult();
}
/**
* Gets the forbidden access result with a reason.
*
* @return \Drupal\Core\Access\AccessResultForbidden
* The forbidden access result.
*/
protected function getForbiddenAccessResult() {
return AccessResultForbidden::forbidden('Read only entity type: ' . $this->entityTypeId);
}
}
