Mercurial > hg > cmmr2012-drupal-site
diff core/modules/contact/src/ContactFormAccessControlHandler.php @ 0:c75dbcec494b
Initial commit from drush-created site
author | Chris Cannam |
---|---|
date | Thu, 05 Jul 2018 14:24:15 +0000 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/core/modules/contact/src/ContactFormAccessControlHandler.php Thu Jul 05 14:24:15 2018 +0000 @@ -0,0 +1,34 @@ +<?php + +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::allowedIfHasPermission($account, 'access site-wide contact form')->andIf(AccessResult::allowedIf($entity->id() !== 'personal')); + } + 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::allowedIfHasPermission($account, 'administer contact forms')->andIf(AccessResult::allowedIf($entity->id() !== 'personal')); + } + + return parent::checkAccess($entity, $operation, $account); + } + +}