We could not synchronize checks via GitHub's checks API since Scrutinizer's GitHub App is not installed for this repository.
Total Complexity | 9 |
Total Lines | 43 |
Duplicated Lines | 0 % |
Coverage | 94.74% |
Changes | 0 |
1 | <?php |
||
20 | abstract class AbstractFilterRule extends AbstractRule |
||
21 | { |
||
22 | public $additionalChars = ''; |
||
23 | |||
24 | abstract protected function validateClean($input); |
||
25 | |||
26 | 29 | public function __construct($additionalChars = '') |
|
27 | { |
||
28 | 29 | if (!is_string($additionalChars)) { |
|
29 | 1 | throw new ComponentException('Invalid list of additional characters to be loaded'); |
|
30 | } |
||
31 | |||
32 | 28 | $this->additionalChars .= $additionalChars; |
|
33 | 28 | } |
|
34 | |||
35 | 22 | protected function filter($input) |
|
38 | } |
||
39 | |||
40 | 25 | public function validate($input): bool |
|
41 | { |
||
42 | 25 | if (!is_scalar($input)) { |
|
43 | 3 | return false; |
|
44 | } |
||
45 | |||
46 | 25 | $stringInput = $this->toString($input); |
|
47 | 25 | if ('' === $stringInput) { |
|
48 | 4 | return false; |
|
49 | } |
||
50 | |||
51 | 22 | $cleanInput = $this->filter($stringInput); |
|
52 | |||
53 | 22 | return '' === $cleanInput || $this->validateClean($cleanInput); |
|
54 | } |
||
55 | |||
56 | 25 | private function toString($input): string |
|
63 | } |
||
64 | } |
||
65 |