mirror of
https://github.com/Respect/Validation.git
synced 2024-06-01 05:12:50 +02:00
66faefd695
After many refactorings, no rules use the previous validation engine. That means we can remove the unused code from the repository and switch from the previous to the new validation engine everywhere. This commit will also soft deprecate the methods "validate()", and "check()" in all the rules and the "assert()" in all rules but the Validator itself. That means using those methods will still be allowed, but static analysis tools might complain. This is a big step toward releasing the next major version, as the code is pretty much the way it should be when I release the next version. There's some documentation to be updated, and I would like to change the behavior of a couple of rules. Signed-off-by: Henrique Moody <henriquemoody@gmail.com>
145 lines
3.4 KiB
PHP
145 lines
3.4 KiB
PHP
<?php
|
|
|
|
/*
|
|
* Copyright (c) Alexandre Gomes Gaigalas <alganet@gmail.com>
|
|
* SPDX-License-Identifier: MIT
|
|
*/
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Respect\Validation;
|
|
|
|
use Respect\Validation\Exceptions\ValidationException;
|
|
use Respect\Validation\Helpers\CanBindEvaluateRule;
|
|
use Respect\Validation\Message\Formatter;
|
|
use Respect\Validation\Message\StandardFormatter;
|
|
use Respect\Validation\Message\StandardRenderer;
|
|
use Respect\Validation\Mixins\StaticValidator;
|
|
use Respect\Validation\Rules\AllOf;
|
|
use Respect\Validation\Rules\Core\Standard;
|
|
|
|
use function count;
|
|
use function current;
|
|
|
|
/**
|
|
* @mixin StaticValidator
|
|
*/
|
|
final class Validator extends Standard
|
|
{
|
|
use CanBindEvaluateRule;
|
|
|
|
/** @var array<Validatable> */
|
|
private array $rules = [];
|
|
|
|
/** @var array<string, mixed> */
|
|
private array $templates = [];
|
|
|
|
public function __construct(
|
|
private readonly Factory $factory,
|
|
private readonly Formatter $formatter,
|
|
) {
|
|
}
|
|
|
|
public static function create(Validatable ...$rules): self
|
|
{
|
|
$validator = new self(
|
|
Factory::getDefaultInstance(),
|
|
new StandardFormatter(
|
|
new StandardRenderer(
|
|
Factory::getDefaultInstance()->getTranslator(),
|
|
Factory::getDefaultInstance()->getParameterProcessor(),
|
|
)
|
|
)
|
|
);
|
|
$validator->rules = $rules;
|
|
|
|
return $validator;
|
|
}
|
|
|
|
public function evaluate(mixed $input): Result
|
|
{
|
|
return $this->bindEvaluate($this->rule(), $this, $input);
|
|
}
|
|
|
|
public function isValid(mixed $input): bool
|
|
{
|
|
return $this->evaluate($input)->isValid;
|
|
}
|
|
|
|
public function assert(mixed $input): void
|
|
{
|
|
$result = $this->evaluate($input);
|
|
if ($result->isValid) {
|
|
return;
|
|
}
|
|
|
|
$templates = $this->templates;
|
|
if (count($templates) === 0 && $this->getTemplate() != null) {
|
|
$templates = ['__self__' => $this->getTemplate()];
|
|
}
|
|
|
|
throw new ValidationException(
|
|
$this->formatter->main($result, $templates),
|
|
$this->formatter->full($result, $templates),
|
|
$this->formatter->array($result, $templates),
|
|
);
|
|
}
|
|
|
|
/** @param array<string, mixed> $templates */
|
|
public function setTemplates(array $templates): self
|
|
{
|
|
$this->templates = $templates;
|
|
|
|
return $this;
|
|
}
|
|
|
|
/** @return array<Validatable> */
|
|
public function getRules(): array
|
|
{
|
|
return $this->rules;
|
|
}
|
|
|
|
/**
|
|
* @deprecated Use {@see isValid()} instead.
|
|
*/
|
|
public function validate(mixed $input): bool
|
|
{
|
|
return $this->evaluate($input)->isValid;
|
|
}
|
|
|
|
/**
|
|
* @deprecated Use {@see assert()} instead.
|
|
*/
|
|
public function check(mixed $input): void
|
|
{
|
|
$this->assert($input);
|
|
}
|
|
|
|
private function rule(): Validatable
|
|
{
|
|
if (count($this->rules) === 1) {
|
|
return current($this->rules);
|
|
}
|
|
|
|
return new AllOf(...$this->rules);
|
|
}
|
|
|
|
/**
|
|
* @param mixed[] $arguments
|
|
*/
|
|
public static function __callStatic(string $ruleName, array $arguments): self
|
|
{
|
|
return self::create()->__call($ruleName, $arguments);
|
|
}
|
|
|
|
/**
|
|
* @param mixed[] $arguments
|
|
*/
|
|
public function __call(string $ruleName, array $arguments): self
|
|
{
|
|
$this->rules[] = $this->factory->rule($ruleName, $arguments);
|
|
|
|
return $this;
|
|
}
|
|
}
|