Completed
Push — master ( 121fac...aa6513 )
by Harry Osmar
06:34 queued 03:36
created

Validate.php ➔ valid_phone_number()   A

Complexity

Conditions 2
Paths 4

Size

Total Lines 14
Code Lines 8

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 6
CRAP Score 2

Importance

Changes 0
Metric Value
cc 2
eloc 8
nc 4
nop 2
dl 0
loc 14
ccs 6
cts 6
cp 1
crap 2
rs 9.4285
c 0
b 0
f 0
1
<?php
2
3
namespace PluginSimpleValidate\helper\Validate;
4
5
use libphonenumber\NumberParseException;
6
use libphonenumber\PhoneNumber;
7
use libphonenumber\PhoneNumberUtil;
8
use PluginSimpleValidate\BaseAbstract\Field;
9
use PluginSimpleValidate\Exception\InvalidTypeParameter;
10
use function PluginSimpleValidate\helper\Cleaner\get_length;
11
use function PluginSimpleValidate\helper\Cleaner\is_valid_type_for_length;
12
use function PluginSimpleValidate\helper\Cleaner\trim_doubled_space;
13
14
if (! function_exists('is_true')) {
15
    function is_true($value)
16
    {
17 1
        return $value === true;
18
    }
19
}
20
21
if (! function_exists('is_number')) {
22
    function is_number($value)
23
    {
24
        return is_numeric($value);
25
    }
26
}
27
28
if (! function_exists('is_required')) {
29
    function is_required($value)
30
    {
31 4
        return !empty(trim_doubled_space($value));
32
    }
33
}
34
35
if (! function_exists('is_valid_email')) {
36
    function is_valid_email($value)
37
    {
38 3
        return preg_match('/^([a-z0-9\+_\-]+)(\.[a-z0-9\+_\-]+)*@([a-z0-9\-]+\.)+[a-z]{2,6}$/ix', $value);
39
    }
40
}
41
42
if (! function_exists('is_alpha')) {
43
    function is_alpha($value)
44
    {
45
        return preg_match("/^([a-z])+$/i", $value);
46
    }
47
}
48
49
if (! function_exists('is_alpha_or_numeric')) {
50
    function is_alpha_or_numeric($value)
51
    {
52 1
        return preg_match("/^([a-z0-9])+$/i", $value);
53
    }
54
}
55
56
if (! function_exists('is_decimal')) {
57
    function is_decimal($value)
58
    {
59
        return preg_match('/^[\-+]?[0-9]+\.[0-9]+$/', $value);
60
    }
61
}
62
63
if (! function_exists('is_integer')) {
64
    function is_integer($value)
65
    {
66
        return preg_match('/^[\-+]?[0-9]+$/', $value);
67
    }
68
}
69
70
if (! function_exists('is_natural')) {
71
    function is_natural($value)
72
    {
73
        return preg_match('/^[0-9]+$/', $value);
74
    }
75
}
76
77
if (! function_exists('is_natural_no_zero')) {
78
    function is_natural_no_zero($value)
79
    {
80
        return preg_match('/^[1-9]+[0]*$/', $value);
81
    }
82
}
83
84
if (! function_exists('is_equal')) {
85
    function is_equal($value, array $args)
86
    {
87 1
        return $value === $args[Field::VAR_MATCH];
88
    }
89
}
90
91
if (! function_exists('less_than')) {
92
    function less_than($value, array $args)
93
    {
94 1
        return $value < $args[Field::VAR_LIMIT];
95
    }
96
}
97
98
if (! function_exists('greater_than')) {
99
    function greater_than($value, array $args)
100
    {
101
        return $value > $args[Field::VAR_LIMIT];
102
    }
103
}
104
105
if (! function_exists('less_or_equal_than')) {
106
    function less_or_equal_than($value, array $args)
107
    {
108
        return $value <= $args[Field::VAR_LIMIT];
109
    }
110
}
111
112
if (! function_exists('greater_or_equal_than')) {
113
    function greater_or_equal_than($value, array $args)
114
    {
115
        return $value >= $args[Field::VAR_LIMIT];
116
    }
117
}
118
119
if (! function_exists('between')) {
120
    function between($value, array $args)
121
    {
122 1
        return $value < $args[Field::VAR_UPPER_LIMIT] && $value > $args[Field::VAR_LOWER_LIMIT];
123
    }
124
}
125
126
if (! function_exists('between_or_equal')) {
127
    function between_or_equal($value, array $args)
128
    {
129
        return $value <= $args[Field::VAR_UPPER_LIMIT] && $value >= $args[Field::VAR_LOWER_LIMIT];
130
    }
131
}
132
133 View Code Duplication
if (! function_exists('length')) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
134
    function length($value, array $args)
135
    {
136
        return run_length_rule(
137
            $value,
138
            get_length($value) === $args[Field::VAR_LIMIT]
139
        );
140
    }
141
}
142
143 View Code Duplication
if (! function_exists('length_less_than')) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
144
    function length_less_than($value, array $args)
145
    {
146
        return run_length_rule(
147
            $value,
148
            get_length($value) < $args[Field::VAR_LIMIT]
149
        );
150
    }
151
}
152
153 View Code Duplication
if (! function_exists('length_greater_than')) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
154
    function length_greater_than($value, array $args)
155
    {
156 1
        return run_length_rule(
157 1
            $value,
158 1
            get_length($value) > $args[Field::VAR_LIMIT]
159
        );
160
    }
161
}
162
163 View Code Duplication
if (! function_exists('length_less_or_equal_than')) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
164
    function length_less_or_equal_than($value, array $args)
165
    {
166
        return run_length_rule(
167
            $value,
168
            get_length($value) <= $args[Field::VAR_LIMIT]
169
        );
170
    }
171
}
172
173 View Code Duplication
if (! function_exists('length_greater_or_equal_than')) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
174
    function length_greater_or_equal_than($value, array $args)
175
    {
176
        return run_length_rule(
177
            $value,
178
            get_length($value) >= $args[Field::VAR_LIMIT]
179
        );
180
    }
181
}
182
183 View Code Duplication
if (! function_exists('length_between')) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
184
    function length_between($value, array $args)
185
    {
186
        return run_length_rule(
187
            $value,
188
            get_length($value) < $args[Field::VAR_UPPER_LIMIT] && get_length($value) > $args[Field::VAR_LOWER_LIMIT]
189
        );
190
    }
191
}
192
193
194 View Code Duplication
if (! function_exists('length_between_or_equal')) {
0 ignored issues
show
Duplication introduced by
This code seems to be duplicated across your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
195
    function length_between_or_equal($value, array $args)
196
    {
197
        return run_length_rule(
198
            $value,
199
            get_length($value) <= $args[Field::VAR_UPPER_LIMIT] && get_length($value) >= $args[Field::VAR_LOWER_LIMIT]
200
        );
201
    }
202
}
203
204
if (! function_exists('valid_phone_number')) {
205
    function valid_phone_number($value, array $args)
206
    {
207
        try {
208 1
            $phoneUtil = PhoneNumberUtil::getInstance();
209
210
            /** @var PhoneNumber $phoneNumber */
211 1
            $phoneNumberProto = $phoneUtil->parse($value, $args[Field::VAR_REGION]);
212 1
            return $phoneUtil->isValidNumber(
213 1
                $phoneNumberProto
214
            );
215 1
        } catch (NumberParseException $exception) {
216 1
            return false;
217
        }
218
    }
219
}
220
221
if (! function_exists('run_length_rule')) {
222
    function run_length_rule($value, $result) {
223 1
        if (!is_valid_type_for_length($value)) {
224
            throw new InvalidTypeParameter('Invalid parameter type');
225
        }
226
227 1
        return $result;
228
    }
229
}