Mercurial > hg > cmmr2012-drupal-site
annotate core/modules/user/src/RoleAccessControlHandler.php @ 5:12f9dff5fda9 tip
Update to Drupal core 8.7.1
author | Chris Cannam |
---|---|
date | Thu, 09 May 2019 15:34:47 +0100 |
parents | c75dbcec494b |
children |
rev | line source |
---|---|
Chris@0 | 1 <?php |
Chris@0 | 2 |
Chris@0 | 3 namespace Drupal\user; |
Chris@0 | 4 |
Chris@0 | 5 use Drupal\Core\Access\AccessResult; |
Chris@0 | 6 use Drupal\Core\Entity\EntityAccessControlHandler; |
Chris@0 | 7 use Drupal\Core\Entity\EntityInterface; |
Chris@0 | 8 use Drupal\Core\Session\AccountInterface; |
Chris@0 | 9 |
Chris@0 | 10 /** |
Chris@0 | 11 * Defines the access control handler for the user role entity type. |
Chris@0 | 12 * |
Chris@0 | 13 * @see \Drupal\user\Entity\Role |
Chris@0 | 14 */ |
Chris@0 | 15 class RoleAccessControlHandler extends EntityAccessControlHandler { |
Chris@0 | 16 |
Chris@0 | 17 /** |
Chris@0 | 18 * {@inheritdoc} |
Chris@0 | 19 */ |
Chris@0 | 20 protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) { |
Chris@0 | 21 switch ($operation) { |
Chris@0 | 22 case 'delete': |
Chris@0 | 23 if ($entity->id() == RoleInterface::ANONYMOUS_ID || $entity->id() == RoleInterface::AUTHENTICATED_ID) { |
Chris@0 | 24 return AccessResult::forbidden(); |
Chris@0 | 25 } |
Chris@0 | 26 |
Chris@0 | 27 default: |
Chris@0 | 28 return parent::checkAccess($entity, $operation, $account); |
Chris@0 | 29 } |
Chris@0 | 30 } |
Chris@0 | 31 |
Chris@0 | 32 } |