| 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); | |
| } | |
| } |