EntityAccessControlHandler::processAccessHookResults

protected EntityAccessControlHandler::processAccessHookResults(array $access)

We grant access to the entity if both of these conditions are met:

  • No modules say to deny access.
  • At least one module says to grant access.

Parameters

\Drupal\Core\Access\AccessResultInterface[] $access: An array of access results of the fired access hook.

Return value

\Drupal\Core\Access\AccessResultInterface The combined result of the various access checks' results. All their cacheability metadata is merged as well.

See also

\Drupal\Core\Access\AccessResultInterface::orIf()

File

core/lib/Drupal/Core/Entity/EntityAccessControlHandler.php, line 113

Class

EntityAccessControlHandler
Defines a default implementation for entity access control handler.

Namespace

Drupal\Core\Entity

Code

protected function processAccessHookResults(array $access) {
  // No results means no opinion.
  if (empty($access)) {
    return AccessResult::neutral();
  }

  /** @var \Drupal\Core\Access\AccessResultInterface $result */
  $result = array_shift($access);
  foreach ($access as $other) {
    $result = $result->orIf($other);
  }
  return $result;
}
doc_Drupal
2016-10-29 09:04:30
Comments
Leave a Comment

Please login to continue.