Initial Drupal 11 with DDEV setup
This commit is contained in:
82
vendor/symfony/validator/Constraints/WeekValidator.php
vendored
Normal file
82
vendor/symfony/validator/Constraints/WeekValidator.php
vendored
Normal file
@ -0,0 +1,82 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Validator\Constraints;
|
||||
|
||||
use Symfony\Component\Validator\Constraint;
|
||||
use Symfony\Component\Validator\ConstraintValidator;
|
||||
use Symfony\Component\Validator\Exception\UnexpectedTypeException;
|
||||
use Symfony\Component\Validator\Exception\UnexpectedValueException;
|
||||
|
||||
/**
|
||||
* @author Alexandre Daubois <alex.daubois@gmail.com>
|
||||
*/
|
||||
final class WeekValidator extends ConstraintValidator
|
||||
{
|
||||
public function validate(mixed $value, Constraint $constraint): void
|
||||
{
|
||||
if (!$constraint instanceof Week) {
|
||||
throw new UnexpectedTypeException($constraint, Week::class);
|
||||
}
|
||||
|
||||
if (null === $value) {
|
||||
return;
|
||||
}
|
||||
|
||||
if (!\is_string($value) && !$value instanceof \Stringable) {
|
||||
throw new UnexpectedValueException($value, 'string');
|
||||
}
|
||||
|
||||
if (!preg_match('/^\d{4}-W(0[1-9]|[1-4][0-9]|5[0-3])$/D', $value)) {
|
||||
$this->context->buildViolation($constraint->invalidFormatMessage)
|
||||
->setCode(Week::INVALID_FORMAT_ERROR)
|
||||
->addViolation();
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
[$year, $weekNumber] = explode('-W', $value, 2);
|
||||
$weeksInYear = (int) date('W', mktime(0, 0, 0, 12, 28, $year));
|
||||
|
||||
if ($weekNumber > $weeksInYear) {
|
||||
$this->context->buildViolation($constraint->invalidWeekNumberMessage)
|
||||
->setCode(Week::INVALID_WEEK_NUMBER_ERROR)
|
||||
->setParameter('{{ value }}', $value)
|
||||
->addViolation();
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
if ($constraint->min) {
|
||||
[$minYear, $minWeekNumber] = explode('-W', $constraint->min, 2);
|
||||
if ($year < $minYear || ($year === $minYear && $weekNumber < $minWeekNumber)) {
|
||||
$this->context->buildViolation($constraint->tooLowMessage)
|
||||
->setCode(Week::TOO_LOW_ERROR)
|
||||
->setInvalidValue($value)
|
||||
->setParameter('{{ min }}', $constraint->min)
|
||||
->addViolation();
|
||||
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if ($constraint->max) {
|
||||
[$maxYear, $maxWeekNumber] = explode('-W', $constraint->max, 2);
|
||||
if ($year > $maxYear || ($year === $maxYear && $weekNumber > $maxWeekNumber)) {
|
||||
$this->context->buildViolation($constraint->tooHighMessage)
|
||||
->setCode(Week::TOO_HIGH_ERROR)
|
||||
->setInvalidValue($value)
|
||||
->setParameter('{{ max }}', $constraint->max)
|
||||
->addViolation();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user