for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
We could not synchronize checks via GitHub's checks API since Scrutinizer's GitHub App is not installed for this repository.
Install GitHub App
<?php
/*
* This file is part of Respect/Validation.
*
* (c) Alexandre Gomes Gaigalas <[email protected]>
* 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\Helpers;
/**
* Helper to handle date/time.
* @author Henrique Moody <[email protected]>
trait CanValidateDateTime
{
* Finds whether a value is a valid date/time in a specific format.
* @param string $format
* @param string $value
* @return bool
private function isDateTime(string $format, string $value): bool
$exceptionalFormats = [
'c' => 'Y-m-d\TH:i:sP',
'r' => 'D, d M Y H:i:s O',
];
$info = date_parse_from_format($exceptionalFormats[$format] ?? $format, $value);
if (!$this->isDateTimeParsable($info)) {
return false;
}
if ($this->isDateFormat($format)) {
return $this->isDateInformation($info);
return true;
private function isDateTimeParsable(array $info)
return 0 === $info['error_count'] && 0 === $info['warning_count'];
private function isDateFormat(string $format): bool
return preg_match('/[djSFmMnYy]/', $format) > 0;
private function isDateInformation(array $info)
if ($info['day']) {
return checkdate((int) $info['month'], $info['day'], (int) $info['year']);
return checkdate($info['month'] ?: 1, $info['day'] ?: 1, $info['year'] ?: 1);