forked from GNUsocial/gnu-social
		
	
		
			
	
	
		
			215 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
		
		
			
		
	
	
			215 lines
		
	
	
		
			6.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| 
								 | 
							
								<?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;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								use Symfony\Component\Validator\Context\ExecutionContextInterface as ExecutionContextInterface2Dot5;
							 | 
						||
| 
								 | 
							
								use Symfony\Component\Validator\Violation\ConstraintViolationBuilderInterface;
							 | 
						||
| 
								 | 
							
								use Symfony\Component\Validator\Violation\LegacyConstraintViolationBuilder;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * Base class for constraint validators.
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @author Bernhard Schussek <bschussek@gmail.com>
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								abstract class ConstraintValidator implements ConstraintValidatorInterface
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Whether to format {@link \DateTime} objects as RFC-3339 dates
							 | 
						||
| 
								 | 
							
								     * ("Y-m-d H:i:s").
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    const PRETTY_DATE = 1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Whether to cast objects with a "__toString()" method to strings.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    const OBJECT_TO_STRING = 2;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * @var ExecutionContextInterface2Dot5
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected $context;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * {@inheritdoc}
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    public function initialize(ExecutionContextInterface $context)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $this->context = $context;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Wrapper for {@link ExecutionContextInterface::buildViolation} that
							 | 
						||
| 
								 | 
							
								     * supports the 2.4 context API.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param string $message    The violation message
							 | 
						||
| 
								 | 
							
								     * @param array  $parameters The message parameters
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @return ConstraintViolationBuilderInterface The violation builder
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @deprecated since version 2.5, to be removed in 3.0.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected function buildViolation($message, array $parameters = array())
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        @trigger_error('The '.__METHOD__.' is deprecated since Symfony 2.5 and will be removed in 3.0.', E_USER_DEPRECATED);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if ($this->context instanceof ExecutionContextInterface2Dot5) {
							 | 
						||
| 
								 | 
							
								            return $this->context->buildViolation($message, $parameters);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return new LegacyConstraintViolationBuilder($this->context, $message, $parameters);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Wrapper for {@link ExecutionContextInterface::buildViolation} that
							 | 
						||
| 
								 | 
							
								     * supports the 2.4 context API.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param ExecutionContextInterface $context    The context to use
							 | 
						||
| 
								 | 
							
								     * @param string                    $message    The violation message
							 | 
						||
| 
								 | 
							
								     * @param array                     $parameters The message parameters
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @return ConstraintViolationBuilderInterface The violation builder
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @deprecated since version 2.5, to be removed in 3.0.
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected function buildViolationInContext(ExecutionContextInterface $context, $message, array $parameters = array())
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        @trigger_error('The '.__METHOD__.' is deprecated since Symfony 2.5 and will be removed in 3.0.', E_USER_DEPRECATED);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if ($context instanceof ExecutionContextInterface2Dot5) {
							 | 
						||
| 
								 | 
							
								            return $context->buildViolation($message, $parameters);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return new LegacyConstraintViolationBuilder($context, $message, $parameters);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Returns a string representation of the type of the value.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * This method should be used if you pass the type of a value as
							 | 
						||
| 
								 | 
							
								     * message parameter to a constraint violation. Note that such
							 | 
						||
| 
								 | 
							
								     * parameters should usually not be included in messages aimed at
							 | 
						||
| 
								 | 
							
								     * non-technical people.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param mixed $value The value to return the type of
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @return string The type of the value
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected function formatTypeOf($value)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        return \is_object($value) ? \get_class($value) : \gettype($value);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Returns a string representation of the value.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * This method returns the equivalent PHP tokens for most scalar types
							 | 
						||
| 
								 | 
							
								     * (i.e. "false" for false, "1" for 1 etc.). Strings are always wrapped
							 | 
						||
| 
								 | 
							
								     * in double quotes ("). Objects, arrays and resources are formatted as
							 | 
						||
| 
								 | 
							
								     * "object", "array" and "resource". If the $format bitmask contains
							 | 
						||
| 
								 | 
							
								     * the PRETTY_DATE bit, then {@link \DateTime} objects will be formatted
							 | 
						||
| 
								 | 
							
								     * as RFC-3339 dates ("Y-m-d H:i:s").
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * Be careful when passing message parameters to a constraint violation
							 | 
						||
| 
								 | 
							
								     * that (may) contain objects, arrays or resources. These parameters
							 | 
						||
| 
								 | 
							
								     * should only be displayed for technical users. Non-technical users
							 | 
						||
| 
								 | 
							
								     * won't know what an "object", "array" or "resource" is and will be
							 | 
						||
| 
								 | 
							
								     * confused by the violation message.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param mixed $value  The value to format as string
							 | 
						||
| 
								 | 
							
								     * @param int   $format A bitwise combination of the format
							 | 
						||
| 
								 | 
							
								     *                      constants in this class
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @return string The string representation of the passed value
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected function formatValue($value, $format = 0)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        $isDateTime = $value instanceof \DateTime || $value instanceof \DateTimeInterface;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (($format & self::PRETTY_DATE) && $isDateTime) {
							 | 
						||
| 
								 | 
							
								            if (class_exists('IntlDateFormatter')) {
							 | 
						||
| 
								 | 
							
								                $locale = \Locale::getDefault();
							 | 
						||
| 
								 | 
							
								                $formatter = new \IntlDateFormatter($locale, \IntlDateFormatter::MEDIUM, \IntlDateFormatter::SHORT);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								                // neither the native nor the stub IntlDateFormatter support
							 | 
						||
| 
								 | 
							
								                // DateTimeImmutable as of yet
							 | 
						||
| 
								 | 
							
								                if (!$value instanceof \DateTime) {
							 | 
						||
| 
								 | 
							
								                    $value = new \DateTime(
							 | 
						||
| 
								 | 
							
								                        $value->format('Y-m-d H:i:s.u e'),
							 | 
						||
| 
								 | 
							
								                        $value->getTimezone()
							 | 
						||
| 
								 | 
							
								                    );
							 | 
						||
| 
								 | 
							
								                }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								                return $formatter->format($value);
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            return $value->format('Y-m-d H:i:s');
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (\is_object($value)) {
							 | 
						||
| 
								 | 
							
								            if (($format & self::OBJECT_TO_STRING) && method_exists($value, '__toString')) {
							 | 
						||
| 
								 | 
							
								                return $value->__toString();
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								            return 'object';
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (\is_array($value)) {
							 | 
						||
| 
								 | 
							
								            return 'array';
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (\is_string($value)) {
							 | 
						||
| 
								 | 
							
								            return '"'.$value.'"';
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (\is_resource($value)) {
							 | 
						||
| 
								 | 
							
								            return 'resource';
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (null === $value) {
							 | 
						||
| 
								 | 
							
								            return 'null';
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (false === $value) {
							 | 
						||
| 
								 | 
							
								            return 'false';
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        if (true === $value) {
							 | 
						||
| 
								 | 
							
								            return 'true';
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return (string) $value;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /**
							 | 
						||
| 
								 | 
							
								     * Returns a string representation of a list of values.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * Each of the values is converted to a string using
							 | 
						||
| 
								 | 
							
								     * {@link formatValue()}. The values are then concatenated with commas.
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @param array $values A list of values
							 | 
						||
| 
								 | 
							
								     * @param int   $format A bitwise combination of the format
							 | 
						||
| 
								 | 
							
								     *                      constants in this class
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @return string The string representation of the value list
							 | 
						||
| 
								 | 
							
								     *
							 | 
						||
| 
								 | 
							
								     * @see formatValue()
							 | 
						||
| 
								 | 
							
								     */
							 | 
						||
| 
								 | 
							
								    protected function formatValues(array $values, $format = 0)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        foreach ($values as $key => $value) {
							 | 
						||
| 
								 | 
							
								            $values[$key] = $this->formatValue($value, $format);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        return implode(', ', $values);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 |