respect-validation/library/Rules/OneOf.php
Henrique Moody c80524b457
Method assert() should not have a return value
One this method should throw an exception when the input is not valid,
returning `TRUE` when it succeeds is not really consistent.
2018-01-28 17:38:40 +01:00

69 lines
1.7 KiB
PHP

<?php
/*
* This file is part of Respect/Validation.
*
* (c) Alexandre Gomes Gaigalas <alexandre@gaigalas.net>
*
* For the full copyright and license information, please view the "LICENSE.md"
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Respect\Validation\Rules;
use Respect\Validation\Exceptions\ValidationException;
/**
* @author Bradyn Poulsen <bradyn@bradynpoulsen.com>
* @author Henrique Moody <henriquemoody@gmail.com>
*/
class OneOf extends AbstractComposite
{
public function assert($input): void
{
$validators = $this->getRules();
$exceptions = $this->validateRules($input);
$numRules = count($validators);
$numExceptions = count($exceptions);
if ($numExceptions !== $numRules - 1) {
throw $this->reportError($input)->setRelated($exceptions);
}
}
public function validate($input): bool
{
$rulesPassedCount = 0;
foreach ($this->getRules() as $rule) {
if (!$rule->validate($input)) {
continue;
}
++$rulesPassedCount;
}
return 1 === $rulesPassedCount;
}
public function check($input): void
{
$exceptions = [];
$rulesPassedCount = 0;
foreach ($this->getRules() as $rule) {
try {
$rule->check($input);
++$rulesPassedCount;
} catch (ValidationException $exception) {
$exceptions[] = $exception;
}
}
if (1 === $rulesPassedCount) {
return;
}
throw (array_shift($exceptions) ?: $this->reportError($input));
}
}