Str   A
last analyzed

Complexity

Total Complexity 4

Size/Duplication

Total Lines 54
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 14
dl 0
loc 54
ccs 10
cts 10
cp 1
rs 10
c 0
b 0
f 0
wmc 4

3 Methods

Rating   Name   Duplication   Size   Complexity  
A concreteValidate() 0 8 2
A validate() 0 5 1
A getMessage() 0 3 1
1
<?php
2
3
/**
4
 * Linna Filter
5
 *
6
 * @author Sebastian Rapetti <[email protected]>
7
 * @copyright (c) 2018, Sebastian Rapetti
8
 * @license http://opensource.org/licenses/MIT MIT License
9
 */
10
declare(strict_types=1);
11
12
namespace Linna\Filter\Rules;
13
14
/**
15
 * Check if provided value is a string.
16
 *
17
 */
18
class Str extends AbstractString implements RuleSanitizeInterface, RuleValidateInterface
19
{
20
    /**
21
     * @var array Rule properties
22
     */
23
    public static $config = [
24
        'full_class' => __CLASS__,
25
        'alias' => ['string', 'str', 's'],
26
        'args_count' => 0,
27
        'args_type' => []
28
    ];
29
30
    /**
31
     * @var string Error message
32
     */
33
    private $message = '';
34
35
    /**
36
     * Validate.
37
     *
38
     * @return bool
39
     */
40 10
    public function validate(): bool
41
    {
42 10
        $args = \func_get_args();
43
44 10
        return $this->concreteValidate($args[0]);
45
    }
46
47
    /**
48
     * Concrete validate.
49
     *
50
     * @param mixed $received
51
     *
52
     * @return bool
53
     */
54 10
    private function concreteValidate($received): bool
55
    {
56 10
        if (!\is_string($received)) {
57 6
            $this->message = "Received value is not a string";
58 6
            return true;
59
        }
60
61 4
        return false;
62
    }
63
64
    /**
65
     * Return error message.
66
     *
67
     * @return string Error message
68
     */
69 1
    public function getMessage(): string
70
    {
71 1
        return $this->message;
72
    }
73
}
74