Date   A
last analyzed

Complexity

Total Complexity 5

Size/Duplication

Total Lines 40
Duplicated Lines 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
wmc 5
eloc 11
c 1
b 0
f 0
dl 0
loc 40
rs 10

3 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 3 1
A validate() 0 7 3
A getErrorMessage() 0 6 1
1
<?php
2
3
/**
4
 * Platine Validator
5
 *
6
 * Platine Validator is a simple, extensible validation library with support for filtering
7
 *
8
 * This content is released under the MIT License (MIT)
9
 *
10
 * Copyright (c) 2020 Platine Validator
11
 *
12
 * Permission is hereby granted, free of charge, to any person obtaining a copy
13
 * of this software and associated documentation files (the "Software"), to deal
14
 * in the Software without restriction, including without limitation the rights
15
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
16
 * copies of the Software, and to permit persons to whom the Software is
17
 * furnished to do so, subject to the following conditions:
18
 *
19
 * The above copyright notice and this permission notice shall be included in all
20
 * copies or substantial portions of the Software.
21
 *
22
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
23
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
24
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
25
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
26
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
27
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
28
 * SOFTWARE.
29
 */
30
31
/**
32
 *  @file Date.php
33
 *
34
 *  Field value must contain a valid date
35
 *
36
 *  @package    Platine\Validator\Rule
37
 *  @author Platine Developers Team
38
 *  @copyright  Copyright (c) 2020
39
 *  @license    http://opensource.org/licenses/MIT  MIT License
40
 *  @link   https://www.platine-php.com
41
 *  @version 1.0.0
42
 *  @filesource
43
 */
44
45
declare(strict_types=1);
46
47
namespace Platine\Validator\Rule;
48
49
use Platine\Validator\RuleInterface;
50
use Platine\Validator\Validator;
51
52
/**
53
 * @class Date
54
 * @package Platine\Validator\Rule
55
 */
56
class Date implements RuleInterface
57
{
58
    /**
59
     * The date format to validate
60
     * @var string
61
     */
62
    protected string $format;
63
64
    /**
65
     * Constructor
66
     * @param string $format the date format
67
     */
68
    public function __construct(string $format)
69
    {
70
        $this->format = $format;
71
    }
72
73
    /**
74
     * {@inheritdoc}
75
     * @see RuleInterface
76
     */
77
    public function validate(string $field, mixed $value, Validator $validator): bool
78
    {
79
        if (empty($value)) {
80
            return true;
81
        }
82
        $dateValue = date_create_from_format($this->format, (string) $value);
83
        return $dateValue !== false && $dateValue->format($this->format) === (string) $value;
84
    }
85
86
    /**
87
     * {@inheritdoc}
88
     * @see RuleInterface
89
     */
90
    public function getErrorMessage(string $field, mixed $value, Validator $validator): string
91
    {
92
        return $validator->translate(
93
            '%s must contain a correct date format [%s]!',
94
            $validator->getLabel($field),
95
            $this->format
96
        );
97
    }
98
}
99