trait ConditionAccessResolverTrait

Same name and namespace in other branches
  1. 9 core/lib/Drupal/Core/Condition/ConditionAccessResolverTrait.php \Drupal\Core\Condition\ConditionAccessResolverTrait
  2. 8.9.x core/lib/Drupal/Core/Condition/ConditionAccessResolverTrait.php \Drupal\Core\Condition\ConditionAccessResolverTrait
  3. 10 core/lib/Drupal/Core/Condition/ConditionAccessResolverTrait.php \Drupal\Core\Condition\ConditionAccessResolverTrait

Resolves a set of conditions.

Hierarchy

1 file declares its use of ConditionAccessResolverTrait
BlockAccessControlHandler.php in core/modules/block/src/BlockAccessControlHandler.php

File

core/lib/Drupal/Core/Condition/ConditionAccessResolverTrait.php, line 10

Namespace

Drupal\Core\Condition
View source
trait ConditionAccessResolverTrait {
    
    /**
     * Resolves the given conditions based on the condition logic ('and'/'or').
     *
     * @param \Drupal\Core\Condition\ConditionInterface[] $conditions
     *   A set of conditions.
     * @param string $condition_logic
     *   The logic used to compute access, either 'and' or 'or'.
     *
     * @return bool
     *   Whether these conditions grant or deny access.
     */
    protected function resolveConditions($conditions, $condition_logic) {
        foreach ($conditions as $condition) {
            try {
                $pass = $condition->execute();
            } catch (ContextException $e) {
                // 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';
    }

}

Members

Title Sort descending Modifiers Object type Summary
ConditionAccessResolverTrait::resolveConditions protected function Resolves the given conditions based on the condition logic ('and'/'or').

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