/
Url.zep
95 lines (84 loc) · 2 KB
/
Url.zep
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
95
/**
* This file is part of the Phalcon Framework.
*
* (c) Phalcon Team <team@phalcon.io>
*
* For the full copyright and license information, please view the LICENSE.txt
* file that was distributed with this source code.
*/
namespace Phalcon\Validation\Validator;
use Phalcon\Messages\Message;
use Phalcon\Validation;
use Phalcon\Validation\AbstractValidator;
/**
* Checks if a value has a url format
*
* ```php
* use Phalcon\Validation;
* use Phalcon\Validation\Validator\Url as UrlValidator;
*
* $validator = new Validation();
*
* $validator->add(
* "url",
* new UrlValidator(
* [
* "message" => ":field must be a url",
* ]
* )
* );
*
* $validator->add(
* [
* "url",
* "homepage",
* ],
* new UrlValidator(
* [
* "message" => [
* "url" => "url must be a url",
* "homepage" => "homepage must be a url",
* ]
* ]
* )
* );
* ```
*/
class Url extends AbstractValidator
{
protected template = "Field :field must be a url";
/**
* Constructor
*
* @param array options = [
* 'message' => '',
* 'template' => '',
* 'allowEmpty' => false,
* 'options' => []
* ]
*/
public function __construct(array! options = [])
{
parent::__construct(options);
}
/**
* Executes the validation
*/
public function validate(<Validation> validation, var field) -> bool
{
var options, result, value;
let value = validation->getValue(field);
if fetch options, this->options["options"] {
let result = filter_var(value, FILTER_VALIDATE_URL, options);
} else {
let result = filter_var(value, FILTER_VALIDATE_URL);
}
if !result {
validation->appendMessage(
this->messageFactory(validation, field)
);
return false;
}
return true;
}
}