DateTime   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 25
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 9
dl 0
loc 25
ccs 8
cts 8
cp 1
rs 10
c 1
b 0
f 0
wmc 5

2 Methods

Rating   Name   Duplication   Size   Complexity  
A isValid() 0 11 4
A getInvalidDetails() 0 3 1
1
<?php
2
3
/*
4
 * This file is part of the Valdi package.
5
 *
6
 * (c) Philip Lehmann-Böhm <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace Valdi\Validator;
13
14
/**
15
 * Validator for date time with an optional given format.
16
 * For the format, see:
17
 * http://php.net/manual/en/datetime.createfromformat.php
18
 */
19
class DateTime implements ValidatorInterface
20
{
21
22
    /**
23
     * {@inheritdoc}
24
     */
25 2
    public function isValid($value, array $parameters)
26
    {
27 2
        $format = 'Y-m-d H:i:s';
28 2
        if (count($parameters) > 0) {
29 1
            $format = $parameters[0];
30
        }
31 2
        if (in_array($value, ['', null], true)) {
32 2
            return true;
33
        }
34
        $dateTime = \DateTime::createFromFormat($format, $value);
35
        return $dateTime && $dateTime->format($format) === $value;
36
    }
37
38 1
    /**
39
     * {@inheritdoc}
40 1
     */
41
    public function getInvalidDetails()
42
    {
43
        return 'dateTime';
44
    }
45
}
46