validation.md 8.36 KB
Newer Older
Alexander Makarov committed
1 2 3 4 5 6 7 8 9
Model validation reference
==========================

This guide section doesn't describe how validation works but instead describes all Yii validators and their parameters.
In order to learn model validation basics please refer to [Model, Validation subsection](model.md#Validation).

Standard Yii validators
-----------------------

10
Standard Yii validators could be specified using aliases instead of referring to class names. Here's the list of all
Alexander Mohorev committed
11
validators bundled with Yii with their most useful properties:
12

13
### `boolean`: [[yii\validators\BooleanValidator|BooleanValidator]]
14 15 16 17 18 19 20

Checks if the attribute value is a boolean value.

- `trueValue`, the value representing true status. _(1)_
- `falseValue`, the value representing false status. _(0)_
- `strict`, whether to compare the type of the value and `trueValue`/`falseValue`. _(false)_

21
### `captcha`: [[yii\captcha\CaptchaValidator|CaptchaValidator]]
22 23

Validates that the attribute value is the same as the verification code displayed in the CAPTCHA. Should be used together
24
with [[yii\captcha\CaptchaAction]].
25 26 27 28

- `caseSensitive` whether the comparison is case sensitive. _(false)_
- `captchaAction` the route of the controller action that renders the CAPTCHA image. _('site/captcha')_

29
### `compare`: [[yii\validators\CompareValidator|CompareValidator]]
30 31 32

Compares the specified attribute value with another value and validates if they are equal.

33
- `compareAttribute` the name of the attribute to be compared with. _(currentAttribute_repeat)_
34 35 36
- `compareValue` the constant value to be compared with.
- `operator` the operator for comparison. _('==')_

37
### `date`: [[yii\validators\DateValidator|DateValidator]]
38 39 40

Verifies if the attribute represents a date, time or datetime in a proper format.

41 42
- `format` the date format that the value being validated should follow according to
  [PHP date_create_from_format](http://www.php.net/manual/en/datetime.createfromformat.php). _('Y-m-d')_
43 44
- `timestampAttribute` the name of the attribute to receive the parsing result.

45
### `default`: [[yii\validators\DefaultValueValidator|DefaultValueValidator]]
46 47 48 49 50

Sets the attribute to be the specified default value.

- `value` the default value to be set to the specified attributes.

51
### `double`: [[yii\validators\NumberValidator|NumberValidator]]
52 53 54 55 56 57

Validates that the attribute value is a number.

- `max` limit of the number. _(null)_
- `min` lower limit of the number. _(null)_

58
### `email`: [[yii\validators\EmailValidator|EmailValidator]]
59 60 61 62 63 64 65 66

Validates that the attribute value is a valid email address.

- `allowName` whether to allow name in the email address (e.g. `John Smith <john.smith@example.com>`). _(false)_.
- `checkMX` whether to check the MX record for the email address. _(false)_
- `checkPort` whether to check port 25 for the email address. _(false)_
- `enableIDN` whether validation process should take into account IDN (internationalized domain names). _(false)_

67
### `exist`: [[yii\validators\ExistValidator|ExistValidator]]
68 69 70

Validates that the attribute value exists in a table.

71
- `targetClass` the ActiveRecord class name or alias of the class that should be used to look for the attribute value being
72
  validated. _(ActiveRecord class of the attribute being validated)_
73
- `targetAttribute` the ActiveRecord attribute name that should be used to look for the attribute value being validated.
74 75
  _(name of the attribute being validated)_

76
### `file`: [[yii\validators\FileValidator|FileValidator]]
77 78 79 80 81 82 83 84

Verifies if an attribute is receiving a valid uploaded file.

- `types` a list of file name extensions that are allowed to be uploaded. _(any)_
- `minSize` the minimum number of bytes required for the uploaded file.
- `maxSize` the maximum number of bytes required for the uploaded file.
- `maxFiles` the maximum file count the given attribute can hold. _(1)_

85
### `filter`: [[yii\validators\FilterValidator|FilterValidator]]
86 87 88 89 90 91 92 93

Converts the attribute value according to a filter.

- `filter` PHP callback that defines a filter.

Typically a callback is either the name of PHP function:

```php
Alexander Makarov committed
94
['password', 'filter', 'filter' => 'trim'],
95 96 97 98 99
```

Or an anonymous function:

```php
Alexander Makarov committed
100
['text', 'filter', 'filter' => function ($value) {
101 102
	// here we are removing all swear words from text
	return $newValue;
Alexander Makarov committed
103
}],
104 105
```

106
### `in`: [[yii\validators\RangeValidator|RangeValidator]]
107 108 109 110 111 112 113

Validates that the attribute value is among a list of values.

- `range` list of valid values that the attribute value should be among.
- `strict` whether the comparison is strict (both type and value must be the same). _(false)_
- `not` whether to invert the validation logic. _(false)_

114
### `inline`: [[yii\validators\InlineValidator|InlineValidator]]
115

116 117 118
Uses a custom function to validate the attribute. You need to define a public method in your
model class which will evaluate the validity of the attribute. For example, if an attribute
needs to be divisible by 10. In the rules you would define: `['attributeName', 'myValidationMethod'],`.
119 120 121 122

Then, your own method could look like this:
```php
public function myValidationMethod($attribute) {
Vincent committed
123
    if(($this->$attribute % 10) != 0) {
124 125 126 127 128
         $this->addError($attribute, 'cannot divide value by 10');
    }
}
```

129
### `integer`: [[yii\validators\NumberValidator|NumberValidator]]
130 131 132 133 134 135

Validates that the attribute value is an integer number.

- `max` limit of the number. _(null)_
- `min` lower limit of the number. _(null)_

136
### `match`: [[yii\validators\RegularExpressionValidator|RegularExpressionValidator]]
137 138 139 140 141 142

Validates that the attribute value matches the specified pattern defined by regular expression.

- `pattern` the regular expression to be matched with.
- `not` whether to invert the validation logic. _(false)_

143
### `number`: [[yii\validators\NumberValidator|NumberValidator]]
Vincent committed
144 145 146 147 148 149

Validates that the attribute value is a number.

- `max` limit of the number. _(null)_
- `min` lower limit of the number. _(null)_

150
### `required`: [[yii\validators\RequiredValidator|RequiredValidator]]
151 152 153 154

Validates that the specified attribute does not have null or empty value.

- `requiredValue` the desired value that the attribute must have. _(any)_
155
- `strict` whether the comparison between the attribute value and
156
  [[yii\validators\RequiredValidator::requiredValue|requiredValue]] is strict. _(false)_
157

158
### `safe`: [[yii\validators\SafeValidator|SafeValidator]]
159 160 161

Serves as a dummy validator whose main purpose is to mark the attributes to be safe for massive assignment.

162
### `string`: [[yii\validators\StringValidator|StringValidator]]
163 164 165

Validates that the attribute value is of certain length.

Alexander Makarov committed
166
- `length` specifies the length limit of the value to be validated. Can be `exactly X`, `[min X]`, `[min X, max Y]`.
167 168
- `max`  maximum length. If not set, it means no maximum length limit.
- `min` minimum length. If not set, it means no minimum length limit.
169
- `encoding` the encoding of the string value to be validated. _([[yii\base\Application::charset]])_
170

171
### `unique`: [[yii\validators\UniqueValidator|UniqueValidator]]
172 173 174

Validates that the attribute value is unique in the corresponding database table.

175
- `targetClass` the ActiveRecord class name or alias of the class that should be used to look for the attribute value being
176
  validated. _(ActiveRecord class of the attribute being validated)_
177
- `targetAttribute` the ActiveRecord attribute name that should be used to look for the attribute value being validated.
178 179
  _(name of the attribute being validated)_

180
### `url`: [[yii\validators\UrlValidator|UrlValidator]]
181 182 183

Validates that the attribute value is a valid http or https URL.

Alexander Makarov committed
184
- `validSchemes` list of URI schemes which should be considered valid. _['http', 'https']_
185 186 187 188 189 190 191 192 193 194 195 196 197 198
- `defaultScheme` the default URI scheme. If the input doesn't contain the scheme part, the default scheme will be
  prepended to it. _(null)_
- `enableIDN` whether validation process should take into account IDN (internationalized domain names). _(false)_

Validating values out of model context
--------------------------------------

Sometimes you need to validate a value that is not bound to any model such as email. In Yii `Validator` class has
`validateValue` method that can help you with it. Not all validator classes have it implemented but the ones that can
operate without model do. In our case to validate an email we can do the following:

```php
$email = 'test@example.com';
$validator = new yii\validators\EmailValidator();
Qiang Xue committed
199
if ($validator->validate($email, $error)) {
200 201
	echo 'Email is valid.';
} else {
Qiang Xue committed
202
	echo $error;
203 204
}
```
Alexander Makarov committed
205

Qiang Xue committed
206
TBD: refer to http://www.yiiframework.com/wiki/56/ for the format