Issues (88)

src/Rules/Semver.php (1 issue)

1
<?php
2
3
/**
4
 * This file is part of Dimtrovich/Validation.
5
 *
6
 * (c) 2023 Dimitri Sitchet Tomkeu <[email protected]>
7
 *
8
 * For the full copyright and license information, please view
9
 * the LICENSE file that was distributed with this source code.
10
 */
11
12
namespace Dimtrovich\Validation\Rules;
13
14
class Semver extends AbstractRule
15
{
16
    /**
17
     * Check if the given value is a valid version numbers using Semantic Versioning.
18
     *
19
     * @see https://semver.org/
20
     * @credit <a href="https://github.com/Intervention/validation">Intervention/validation - \Intervention\Validation\Rules\Semver</a>
21
     *
22
     * @param mixed $value
23
     */
24
    public function check($value): bool
25
    {
26
        return preg_match('/^(0|[1-9]\d*)\.(0|[1-9]\d*)\.(0|[1-9]\d*)(?:-((?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*)(?:\.(?:0|[1-9]\d*|\d*[a-zA-Z-][0-9a-zA-Z-]*))*))?(?:\+([0-9a-zA-Z-]+(?:\.[0-9a-zA-Z-]+)*))?$/', $value);
0 ignored issues
show
Bug Best Practice introduced by
The expression return preg_match('/^(0|...A-Z-]+)*))?$/', $value) returns the type integer which is incompatible with the type-hinted return boolean.
Loading history...
27
    }
28
}
29