Username::check()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 1
dl 0
loc 3
ccs 0
cts 1
cp 0
crap 2
rs 10
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 Username extends AbstractRule
15
{
16
    /**
17
     * Check if the given value is a valid username
18
     *
19
     * Pattern for "valid" username
20
     *  - only alpha-numeric (a-z, A-Z, 0-9), underscore and minus
21
     *  - starts with an letter (alpha)
22
     *  - underscores and minus are not allowed at the beginning or end
23
     *  - multiple underscores and minus are not allowed (-- or _____)
24
     *
25
     * @credit <a href="https://github.com/Intervention/validation">Intervention/validation - \Intervention\Validation\Rules\Username</a>
26
     *
27
     * @param mixed $value
28
     */
29
    public function check($value): bool
30
    {
31
        return preg_match('/^[a-z][a-z0-9]*(?:[_\-][a-z0-9]+)*$/i', $value);
0 ignored issues
show
Bug Best Practice introduced by
The expression return preg_match('/^[a-...a-z0-9]+)*$/i', $value) returns the type integer which is incompatible with the type-hinted return boolean.
Loading history...
32
    }
33
}
34