Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 1 |
CRAP | |
0.00% |
0 / 13 |
DateFormatAccessControlHandler | |
0.00% |
0 / 1 |
|
0.00% |
0 / 1 |
20 | |
0.00% |
0 / 13 |
checkAccess | |
0.00% |
0 / 1 |
20 | |
0.00% |
0 / 13 |
<?php | |
/** | |
* @file | |
* Contains \Drupal\system\DateFormatAccessControlHandler. | |
*/ | |
namespace Drupal\system; | |
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 date format entity type. | |
* | |
* @see \Drupal\system\Entity\DateFormat | |
*/ | |
class DateFormatAccessControlHandler extends EntityAccessControlHandler { | |
/** | |
* {@inheritdoc} | |
*/ | |
protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) { | |
// There are no restrictions on viewing a date format. | |
if ($operation == 'view') { | |
return AccessResult::allowed(); | |
} | |
// Locked date formats cannot be updated or deleted. | |
elseif (in_array($operation, array('update', 'delete'))) { | |
if ($entity->isLocked()) { | |
return AccessResult::forbidden()->cacheUntilEntityChanges($entity); | |
} | |
else { | |
return parent::checkAccess($entity, $operation, $account)->cacheUntilEntityChanges($entity); | |
} | |
} | |
return parent::checkAccess($entity, $operation, $account); | |
} | |
} |