-
Notifications
You must be signed in to change notification settings - Fork 34
/
Copy pathFloatValidator.php
executable file
·88 lines (79 loc) · 1.54 KB
/
FloatValidator.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
<?php
namespace Utopia\Http\Validator;
use Utopia\Http\Validator;
/**
* Float
*
* Validate that an variable is a float
*/
class FloatValidator extends Validator
{
/**
* @var bool
*/
protected bool $loose = false;
/**
* Pass true to accept float strings as valid float values
* This option is good for validating query string params.
*
* @param bool $loose
*/
public function __construct(bool $loose = false)
{
$this->loose = $loose;
}
/**
* Get Description
*
* Returns validator description
*
* @return string
*/
public function getDescription(): string
{
return 'Value must be a valid float';
}
/**
* Is array
*
* Function will return true if object is array.
*
* @return bool
*/
public function isArray(): bool
{
return false;
}
/**
* Get Type
*
* Returns validator type.
*
* @return string
*/
public function getType(): string
{
return self::TYPE_FLOAT;
}
/**
* Is valid
*
* Validation will pass when $value is float.
*
* @param mixed $value
* @return bool
*/
public function isValid(mixed $value): bool
{
if ($this->loose) {
if (!\is_numeric($value)) {
return false;
}
$value = $value + 0;
}
if (!\is_float($value) && !\is_int($value)) {
return false;
}
return true;
}
}