RecursiveValidator.php

Same filename and directory in other branches
  1. 8.9.x core/lib/Drupal/Core/TypedData/Validation/RecursiveValidator.php
  2. 10 core/lib/Drupal/Core/TypedData/Validation/RecursiveValidator.php
  3. 11.x core/lib/Drupal/Core/TypedData/Validation/RecursiveValidator.php

Namespace

Drupal\Core\TypedData\Validation

File

core/lib/Drupal/Core/TypedData/Validation/RecursiveValidator.php

View source
<?php

namespace Drupal\Core\TypedData\Validation;

use Drupal\Core\TypedData\TypedDataInterface;
use Drupal\Core\TypedData\TypedDataManagerInterface;
use Symfony\Component\Validator\ConstraintValidatorFactoryInterface;
use Symfony\Component\Validator\ConstraintViolationListInterface;
use Symfony\Component\Validator\Context\ExecutionContextFactoryInterface;
use Symfony\Component\Validator\Context\ExecutionContextInterface;
use Symfony\Component\Validator\Mapping\MetadataInterface;
use Symfony\Component\Validator\Validator\ContextualValidatorInterface;
use Symfony\Component\Validator\Validator\ValidatorInterface;

/**
 * Defines a recursive validator for Typed Data.
 *
 * The difference to \Symfony\Component\Validator\Validator\RecursiveValidator
 * is that we just allow to validate typed data objects.
 */
class RecursiveValidator implements ValidatorInterface {
    
    /**
     * @var \Symfony\Component\Validator\Context\ExecutionContextFactoryInterface
     */
    protected $contextFactory;
    
    /**
     * @var \Symfony\Component\Validator\ConstraintValidatorFactoryInterface
     */
    protected $constraintValidatorFactory;
    
    /**
     * @var \Drupal\Core\TypedData\TypedDataManager
     */
    protected $typedDataManager;
    
    /**
     * Creates a new validator.
     *
     * @param \Symfony\Component\Validator\Context\ExecutionContextFactoryInterface $context_factory
     *   The factory for creating new contexts.
     * @param \Symfony\Component\Validator\ConstraintValidatorFactoryInterface $validator_factory
     *   The constraint validator factory.
     * @param \Drupal\Core\TypedData\TypedDataManagerInterface $typed_data_manager
     *   The typed data manager.
     */
    public function __construct(ExecutionContextFactoryInterface $context_factory, ConstraintValidatorFactoryInterface $validator_factory, TypedDataManagerInterface $typed_data_manager) {
        $this->contextFactory = $context_factory;
        $this->constraintValidatorFactory = $validator_factory;
        $this->typedDataManager = $typed_data_manager;
    }
    
    /**
     * {@inheritdoc}
     */
    public function startContext($root = NULL) : ContextualValidatorInterface {
        return new RecursiveContextualValidator($this->contextFactory
            ->createContext($this, $root), $this, $this->constraintValidatorFactory, $this->typedDataManager);
    }
    
    /**
     * {@inheritdoc}
     */
    public function inContext(ExecutionContextInterface $context) : ContextualValidatorInterface {
        return new RecursiveContextualValidator($context, $this, $this->constraintValidatorFactory, $this->typedDataManager);
    }
    
    /**
     * {@inheritdoc}
     *
     * @param \Drupal\Core\TypedData\TypedDataInterface $typed_data
     *   A typed data object containing the value to validate.
     */
    public function getMetadataFor($typed_data) : MetadataInterface {
        if (!$typed_data instanceof TypedDataInterface) {
            throw new \InvalidArgumentException('The passed value must be a typed data object.');
        }
        return new TypedDataMetadata($typed_data);
    }
    
    /**
     * {@inheritdoc}
     */
    public function hasMetadataFor($value) : bool {
        return $value instanceof TypedDataInterface;
    }
    
    /**
     * {@inheritdoc}
     */
    public function validate($value, $constraints = NULL, $groups = NULL) : ConstraintViolationListInterface {
        return $this->startContext($value)
            ->validate($value, $constraints, $groups)
            ->getViolations();
    }
    
    /**
     * {@inheritdoc}
     */
    public function validateProperty($object, $propertyName, $groups = NULL) : ConstraintViolationListInterface {
        return $this->startContext($object)
            ->validateProperty($object, $propertyName, $groups)
            ->getViolations();
    }
    
    /**
     * {@inheritdoc}
     */
    public function validatePropertyValue($objectOrClass, $propertyName, $value, $groups = NULL) : ConstraintViolationListInterface {
        // Just passing a class name is not supported.
        if (!is_object($objectOrClass)) {
            throw new \LogicException('Typed data validation does not support passing the class name only.');
        }
        return $this->startContext($objectOrClass)
            ->validatePropertyValue($objectOrClass, $propertyName, $value, $groups)
            ->getViolations();
    }

}

Classes

Title Deprecated Summary
RecursiveValidator Defines a recursive validator for Typed Data.

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