forked from utopia-php/http
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathBoolean.php
More file actions
94 lines (82 loc) · 1.77 KB
/
Boolean.php
File metadata and controls
94 lines (82 loc) · 1.77 KB
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
89
90
91
92
93
94
<?php
namespace Utopia\Http\Validator;
use Utopia\Http\Validator;
/**
* Bool
*
* Validate that an variable is a boolean value
*/
class Boolean extends Validator
{
/**
* @var bool
*/
protected bool $loose = false;
/**
* Pass true to accept true and false strings and integers 0 and 1 as valid boolean 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 boolean';
}
/**
* 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_BOOLEAN;
}
/**
* Is valid
*
* Validation will pass when $value has a boolean value.
*
* @param mixed $value
* @return bool
*/
public function isValid($value): bool
{
if ($this->loose && ($value === 'true' || $value === 'false')) { // Accept strings
return true;
}
if ($this->loose && ($value === '1' || $value === '0')) { // Accept numeric strings
return true;
}
if ($this->loose && ($value === 1 || $value === 0)) { // Accept integers
return true;
}
if (\is_bool($value)) {
return true;
}
return false;
}
}