48 lines
1.4 KiB
PHP
48 lines
1.4 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Drupal\zencrm_entities;
|
||
|
|
||
|
use Drupal\Core\Entity\EntityAccessControlHandler;
|
||
|
use Drupal\Core\Entity\EntityInterface;
|
||
|
use Drupal\Core\Session\AccountInterface;
|
||
|
use Drupal\Core\Access\AccessResult;
|
||
|
|
||
|
/**
|
||
|
* Access controller for the Person entity.
|
||
|
*
|
||
|
* @see \Drupal\zencrm_entities\Entity\Person.
|
||
|
*/
|
||
|
class PersonAccessControlHandler extends EntityAccessControlHandler {
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) {
|
||
|
/** @var \Drupal\zencrm_entities\Entity\PersonInterface $entity */
|
||
|
switch ($operation) {
|
||
|
case 'view':
|
||
|
if (!$entity->isPublished()) {
|
||
|
return AccessResult::allowedIfHasPermission($account, 'view unpublished person entities');
|
||
|
}
|
||
|
return AccessResult::allowedIfHasPermission($account, 'view published person entities');
|
||
|
|
||
|
case 'update':
|
||
|
return AccessResult::allowedIfHasPermission($account, 'edit person entities');
|
||
|
|
||
|
case 'delete':
|
||
|
return AccessResult::allowedIfHasPermission($account, 'delete person entities');
|
||
|
}
|
||
|
|
||
|
// Unknown operation, no opinion.
|
||
|
return AccessResult::neutral();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* {@inheritdoc}
|
||
|
*/
|
||
|
protected function checkCreateAccess(AccountInterface $account, array $context, $entity_bundle = NULL) {
|
||
|
return AccessResult::allowedIfHasPermission($account, 'add person entities');
|
||
|
}
|
||
|
|
||
|
}
|