You are here

class CallbackValidator in Zircon Profile 8

Same name and namespace in other branches
  1. 8.0 vendor/symfony/validator/Constraints/CallbackValidator.php \Symfony\Component\Validator\Constraints\CallbackValidator

Validator for Callback constraint.

@author Bernhard Schussek <bschussek@gmail.com>

Hierarchy

Expanded class hierarchy of CallbackValidator

1 file declares its use of CallbackValidator
CallbackValidatorTest.php in vendor/symfony/validator/Tests/Constraints/CallbackValidatorTest.php

File

vendor/symfony/validator/Constraints/CallbackValidator.php, line 24

Namespace

Symfony\Component\Validator\Constraints
View source
class CallbackValidator extends ConstraintValidator {

  /**
   * {@inheritdoc}
   */
  public function validate($object, Constraint $constraint) {
    if (!$constraint instanceof Callback) {
      throw new UnexpectedTypeException($constraint, __NAMESPACE__ . '\\Callback');
    }
    if (null !== $constraint->callback && null !== $constraint->methods) {
      throw new ConstraintDefinitionException('The Callback constraint supports either the option "callback" ' . 'or "methods", but not both at the same time.');
    }

    // has to be an array so that we can differentiate between callables
    // and method names
    if (null !== $constraint->methods && !is_array($constraint->methods)) {
      throw new UnexpectedTypeException($constraint->methods, 'array');
    }
    $methods = $constraint->methods ?: array(
      $constraint->callback,
    );
    foreach ($methods as $method) {
      if ($method instanceof \Closure) {
        $method($object, $this->context);
      }
      elseif (is_array($method)) {
        if (!is_callable($method)) {
          if (isset($method[0]) && is_object($method[0])) {
            $method[0] = get_class($method[0]);
          }
          throw new ConstraintDefinitionException(sprintf('%s targeted by Callback constraint is not a valid callable', json_encode($method)));
        }
        call_user_func($method, $object, $this->context);
      }
      elseif (null !== $object) {
        if (!method_exists($object, $method)) {
          throw new ConstraintDefinitionException(sprintf('Method "%s" targeted by Callback constraint does not exist in class %s', $method, get_class($object)));
        }
        $reflMethod = new \ReflectionMethod($object, $method);
        if ($reflMethod
          ->isStatic()) {
          $reflMethod
            ->invoke(null, $object, $this->context);
        }
        else {
          $reflMethod
            ->invoke($object, $this->context);
        }
      }
    }
  }

}

Members

Namesort descending Modifiers Type Description Overrides
CallbackValidator::validate public function Checks if the passed value is valid. Overrides ConstraintValidatorInterface::validate
ConstraintValidator::$context protected property 3
ConstraintValidator::buildViolation Deprecated protected function Wrapper for {@link ExecutionContextInterface::buildViolation} that supports the 2.4 context API.
ConstraintValidator::buildViolationInContext Deprecated protected function Wrapper for {@link ExecutionContextInterface::buildViolation} that supports the 2.4 context API.
ConstraintValidator::formatTypeOf protected function Returns a string representation of the type of the value.
ConstraintValidator::formatValue protected function Returns a string representation of the value.
ConstraintValidator::formatValues protected function Returns a string representation of a list of values.
ConstraintValidator::initialize public function Initializes the constraint validator. Overrides ConstraintValidatorInterface::initialize 1
ConstraintValidator::OBJECT_TO_STRING constant Whether to cast objects with a "__toString()" method to strings.
ConstraintValidator::PRETTY_DATE constant Whether to format {@link \DateTime} objects as RFC-3339 dates ("Y-m-d H:i:s").