/protected/extensions/doctrine/vendors/Symfony/Component/Validator/Constraints/TimeValidator.php
PHP | 59 lines | 27 code | 11 blank | 21 comment | 7 complexity | 158080ba0ffb99fd20d2831b90e9bc0b MD5 | raw file
Possible License(s): BSD-2-Clause, LGPL-2.1, BSD-3-Clause
- <?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;
- /**
- * @api
- */
- class TimeValidator extends ConstraintValidator
- {
- const PATTERN = '/^(0[0-9]|1[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$/';
- /**
- * Checks if the passed value is valid.
- *
- * @param mixed $value The value that should be validated
- * @param Constraint $constraint The constraint for the validation
- *
- * @return Boolean Whether or not the value is valid
- *
- * @api
- */
- public function isValid($value, Constraint $constraint)
- {
- if (null === $value || '' === $value) {
- return true;
- }
- if ($value instanceof \DateTime) {
- return true;
- }
- if (!is_scalar($value) && !(is_object($value) && method_exists($value, '__toString'))) {
- throw new UnexpectedTypeException($value, 'string');
- }
- $value = (string) $value;
- if (!preg_match(static::PATTERN, $value)) {
- $this->setMessage($constraint->message, array('{{ value }}' => $value));
- return false;
- }
- return true;
- }
- }