Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
0.00% |
0 / 1 |
CRAP | |
0.00% |
0 / 8 |
ContactFormAccessControlHandler | |
0.00% |
0 / 1 |
|
0.00% |
0 / 1 |
42 | |
0.00% |
0 / 8 |
checkAccess | |
0.00% |
0 / 1 |
42 | |
0.00% |
0 / 8 |
<?php | |
/** | |
* @file | |
* Contains \Drupal\contact\ContactFormAccessControlHandler. | |
*/ | |
namespace Drupal\contact; | |
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 contact form entity type. | |
* | |
* @see \Drupal\contact\Entity\ContactForm. | |
*/ | |
class ContactFormAccessControlHandler extends EntityAccessControlHandler { | |
/** | |
* {@inheritdoc} | |
*/ | |
protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) { | |
if ($operation == 'view') { | |
// Do not allow access personal form via site-wide route. | |
return AccessResult::allowedIf($account->hasPermission('access site-wide contact form') && $entity->id() !== 'personal')->cachePerPermissions(); | |
} | |
elseif ($operation == 'delete' || $operation == 'update') { | |
// Do not allow the 'personal' form to be deleted, as it's used for | |
// the personal contact form. | |
return AccessResult::allowedIf($account->hasPermission('administer contact forms') && $entity->id() !== 'personal')->cachePerPermissions(); | |
} | |
return parent::checkAccess($entity, $operation, $account); | |
} | |
} |