function ConditionAccessResolverTrait::resolveConditions
Same name in other branches
- 9 core/lib/Drupal/Core/Condition/ConditionAccessResolverTrait.php \Drupal\Core\Condition\ConditionAccessResolverTrait::resolveConditions()
- 8.9.x core/lib/Drupal/Core/Condition/ConditionAccessResolverTrait.php \Drupal\Core\Condition\ConditionAccessResolverTrait::resolveConditions()
- 10 core/lib/Drupal/Core/Condition/ConditionAccessResolverTrait.php \Drupal\Core\Condition\ConditionAccessResolverTrait::resolveConditions()
Resolves the given conditions based on the condition logic ('and'/'or').
Parameters
\Drupal\Core\Condition\ConditionInterface[] $conditions: A set of conditions.
string $condition_logic: The logic used to compute access, either 'and' or 'or'.
Return value
bool Whether these conditions grant or deny access.
1 call to ConditionAccessResolverTrait::resolveConditions()
- BlockAccessControlHandler::checkAccess in core/
modules/ block/ src/ BlockAccessControlHandler.php - Performs access checks.
File
-
core/
lib/ Drupal/ Core/ Condition/ ConditionAccessResolverTrait.php, line 23
Class
- ConditionAccessResolverTrait
- Resolves a set of conditions.
Namespace
Drupal\Core\ConditionCode
protected function resolveConditions($conditions, $condition_logic) {
foreach ($conditions as $condition) {
try {
$pass = $condition->execute();
} catch (ContextException) {
// If a condition is missing context and is not negated, consider that a
// fail.
$pass = $condition->isNegated();
}
// If a condition fails and all conditions were needed, deny access.
if (!$pass && $condition_logic == 'and') {
return FALSE;
}
elseif ($pass && $condition_logic == 'or') {
return TRUE;
}
}
// Return TRUE if logic was 'and', meaning all rules passed.
// Return FALSE if logic was 'or', meaning no rule passed.
return $condition_logic == 'and';
}
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.