Вход Регистрация
Файл: concrete5.7.5.6/concrete/vendor/zendframework/zend-i18n/src/Validator/DateTime.php
Строк: 303
<?php
/**
 * Zend Framework (http://framework.zend.com/)
 *
 * @link      http://github.com/zendframework/zf2 for the canonical source repository
 * @copyright Copyright (c) 2005-2014 Zend Technologies USA Inc. (http://www.zend.com)
 * @license   http://framework.zend.com/license/new-bsd New BSD License
 */

namespace ZendI18nValidator;

use 
Locale;
use 
IntlDateFormatter;
use 
Traversable;
use 
ZendI18nException as I18nException;
use 
ZendValidatorAbstractValidator;
use 
ZendValidatorException as ValidatorException;

class 
DateTime extends AbstractValidator
{
    const 
INVALID           'datetimeInvalid';
    const 
INVALID_DATETIME  'datetimeInvalidDateTime';

    
/**
     * @var array
     */
    
protected $messageTemplates = array(
        
self::INVALID           => "Invalid type given. String expected",
        
self::INVALID_DATETIME  => "The input does not appear to be a valid datetime",
    );

    
/**
     * Optional locale
     *
     * @var string|null
     */
    
protected $locale;

    
/**
     * @var int
     */
    
protected $dateType;

    
/**
     * @var int
     */
    
protected $timeType;

    
/**
     * Optional timezone
     *
     * @var string
     */
    
protected $timezone;

    
/**
     * @var string
     */
    
protected $pattern;

    
/**
     * @var int
     */
    
protected $calendar;

    
/**
     * @var IntlDateFormatter
     */
    
protected $formatter;

    
/**
     * Is the formatter invalidated
     *
     * Invalidation occurs when immutable properties are changed
     *
     * @var bool
     */
    
protected $invalidateFormatter false;

    
/**
     * Constructor for the Date validator
     *
     * @param array|Traversable $options
     * @throws I18nExceptionExtensionNotLoadedException if ext/intl is not present
     */
    
public function __construct($options = array())
    {
        if (!
extension_loaded('intl')) {
            throw new 
I18nExceptionExtensionNotLoadedException(sprintf(
                
'%s component requires the intl PHP extension',
                
__NAMESPACE__
            
));
        }

        
// Delaying initialization until we know ext/intl is available
        
$this->dateType IntlDateFormatter::NONE;
        
$this->timeType IntlDateFormatter::NONE;
        
$this->calendar IntlDateFormatter::GREGORIAN;

        
parent::__construct($options);

        if (
null === $this->locale) {
            
$this->locale Locale::getDefault();
        }
        if (
null === $this->timezone) {
            
$this->timezone date_default_timezone_get();
        }
    }

    
/**
     * Sets the calendar to be used by the IntlDateFormatter
     *
     * @param int|null $calendar
     * @return DateTime provides fluent interface
     */
    
public function setCalendar($calendar)
    {
        
$this->calendar $calendar;

        return 
$this;
    }

    
/**
     * Returns the calendar to by the IntlDateFormatter
     *
     * @return int
     */
    
public function getCalendar()
    {
        return (
$this->formatter && !$this->invalidateFormatter) ? $this->getIntlDateFormatter()->getCalendar() : $this->calendar;
    }

    
/**
     * Sets the date format to be used by the IntlDateFormatter
     *
     * @param int|null $dateType
     * @return DateTime provides fluent interface
     */
    
public function setDateType($dateType)
    {
        
$this->dateType          $dateType;
        
$this->invalidateFormatter true;

        return 
$this;
    }

    
/**
     * Returns the date format used by the IntlDateFormatter
     *
     * @return int
     */
    
public function getDateType()
    {
        return 
$this->dateType;
    }

    
/**
     * Sets the pattern to be used by the IntlDateFormatter
     *
     * @param string|null $pattern
     * @return DateTime provides fluent interface
     */
    
public function setPattern($pattern)
    {
        
$this->pattern $pattern;

        return 
$this;
    }

    
/**
     * Returns the pattern used by the IntlDateFormatter
     *
     * @return string
     */
    
public function getPattern()
    {
        return (
$this->formatter && !$this->invalidateFormatter) ? $this->getIntlDateFormatter()->getPattern() : $this->pattern;
    }

    
/**
     * Sets the time format to be used by the IntlDateFormatter
     *
     * @param int|null $timeType
     * @return DateTime provides fluent interface
     */
    
public function setTimeType($timeType)
    {
        
$this->timeType          $timeType;
        
$this->invalidateFormatter true;

        return 
$this;
    }

    
/**
     * Returns the time format used by the IntlDateFormatter
     *
     * @return int
     */
    
public function getTimeType()
    {
        return 
$this->timeType;
    }

    
/**
     * Sets the timezone to be used by the IntlDateFormatter
     *
     * @param string|null $timezone
     * @return DateTime provides fluent interface
     */
    
public function setTimezone($timezone)
    {
        
$this->timezone $timezone;

        return 
$this;
    }

    
/**
     * Returns the timezone used by the IntlDateFormatter or the system default if none given
     *
     * @return string
     */
    
public function getTimezone()
    {
        return (
$this->formatter && !$this->invalidateFormatter) ? $this->getIntlDateFormatter()->getTimeZoneId() : $this->timezone;
    }

    
/**
     * Sets the locale to be used by the IntlDateFormatter
     *
     * @param string|null $locale
     * @return DateTime provides fluent interface
     */
    
public function setLocale($locale)
    {
        
$this->locale              $locale;
        
$this->invalidateFormatter true;

        return 
$this;
    }

    
/**
     * Returns the locale used by the IntlDateFormatter or the system default if none given
     *
     * @return string
     */
    
public function getLocale()
    {
        return 
$this->locale;
    }

    
/**
     * Returns true if and only if $value is a floating-point value
     *
     * @param  string                             $value
     * @return bool
     * @throws ValidatorExceptionInvalidArgumentException
     */
    
public function isValid($value)
    {
        if (!
is_string($value)) {
            
$this->error(self::INVALID);

            return 
false;
        }

        
$this->setValue($value);

        
$formatter $this->getIntlDateFormatter();

        if (
intl_is_failure($formatter->getErrorCode())) {
            throw new 
ValidatorExceptionInvalidArgumentException("Invalid locale string given");
        }

        
$position   0;
        
$parsedDate $formatter->parse($value$position);

        if (
intl_is_failure($formatter->getErrorCode())) {
            
$this->error(self::INVALID_DATETIME);

            return 
false;
        }

        if (
$position != strlen($value)) {
            
$this->error(self::INVALID_DATETIME);

            return 
false;
        }

        return 
true;
    }

    
/**
     * Returns a non lenient configured IntlDateFormatter
     *
     * @return IntlDateFormatter
     */
    
protected function getIntlDateFormatter()
    {
        if (
$this->formatter == null || $this->invalidateFormatter) {
            
$this->formatter = new IntlDateFormatter($this->getLocale(), $this->getDateType(), $this->getTimeType(),
                
$this->getTimezone(), $this->getCalendar(), $this->getPattern());

            
$this->formatter->setLenient(false);

            
$this->invalidateFormatter false;
        }

        return 
$this->formatter;
    }
}
Онлайн: 1
Реклама