3 namespace Drupal\user\Access;
5 use Drupal\Core\Access\AccessResult;
6 use Drupal\Core\Routing\Access\AccessInterface;
7 use Drupal\Core\Session\AccountInterface;
8 use Symfony\Component\Routing\Route;
11 * Determines access to routes based on permissions defined via
12 * $module.permissions.yml files.
14 class PermissionAccessCheck implements AccessInterface {
19 * @param \Symfony\Component\Routing\Route $route
20 * The route to check against.
21 * @param \Drupal\Core\Session\AccountInterface $account
22 * The currently logged in account.
24 * @return \Drupal\Core\Access\AccessResultInterface
27 public function access(Route $route, AccountInterface $account) {
28 $permission = $route->getRequirement('_permission');
30 if ($permission === NULL) {
31 return AccessResult::neutral();
34 // Allow to conjunct the permissions with OR ('+') or AND (',').
35 $split = explode(',', $permission);
36 if (count($split) > 1) {
37 return AccessResult::allowedIfHasPermissions($account, $split, 'AND');
40 $split = explode('+', $permission);
41 return AccessResult::allowedIfHasPermissions($account, $split, 'OR');