Mercurial > hg > isophonics-drupal-site
annotate core/modules/user/src/RoleAccessControlHandler.php @ 19:fa3358dc1485 tip
Add ndrum files
author | Chris Cannam |
---|---|
date | Wed, 28 Aug 2019 13:14:47 +0100 |
parents | 4c8ae668cc8c |
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 } |