RoleAccessControlHandler.php

Same filename and directory in other branches
  1. 8.9.x core/modules/user/src/RoleAccessControlHandler.php
  2. 10 core/modules/user/src/RoleAccessControlHandler.php
  3. 11.x core/modules/user/src/RoleAccessControlHandler.php

Namespace

Drupal\user

File

core/modules/user/src/RoleAccessControlHandler.php

View source
<?php

namespace Drupal\user;

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 user role entity type.
 *
 * @see \Drupal\user\Entity\Role
 */
class RoleAccessControlHandler extends EntityAccessControlHandler {
    
    /**
     * {@inheritdoc}
     */
    protected function checkAccess(EntityInterface $entity, $operation, AccountInterface $account) {
        switch ($operation) {
            case 'delete':
                if ($entity->id() == RoleInterface::ANONYMOUS_ID || $entity->id() == RoleInterface::AUTHENTICATED_ID) {
                    return AccessResult::forbidden();
                }
            default:
                return parent::checkAccess($entity, $operation, $account);
        }
    }

}

Classes

Title Deprecated Summary
RoleAccessControlHandler Defines the access control handler for the user role entity type.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.