jedrzej / validator-extended-syntax
Laravel 4/5 package that adds validator negation to Laravel's validation module
Installs: 10 472
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 3
Forks: 0
Open Issues: 2
Requires
Requires (Dev)
- codeception/codeception: 2.0.*
- codeception/specify: *
- mockery/mockery: ^0.9.4
This package is auto-updated.
Last update: 2024-10-25 23:16:16 UTC
README
This package extends Laravel's validation syntax with the following:
- aliasing validation rule configurations
- negating validation rules
- using automatically replaced placeholders
Composer install
Add the following line to composer.json
file in your project:
"jedrzej/validator-extended-syntax": "0.0.3"
or run the following in the commandline in your project's root folder:
composer require "jedrzej/validator-extended-syntax" "0.0.3"
Usage
In order to extend validator syntax, you need to register ValidationServiceProvider
in your config/app.php
:
'providers' => [ ... /* * Custom proviers */ 'Jedrzej\Validation\ValidationServiceProvider' ];
Aliasing validation rules
It is possible to alias often used rule configuration to allow for reuse. This is an alternative to writing custom validation rules.
// validate if string is a hex calue Validator::alias('hex', 'regex:/^[0-9a-fA-F]+$/'); $rules = [ 'value' => 'hex' ]; $validator = Validator::make($data, $rules); // passing arguments to aliases // validate number is a positive integer no larger than 100 Validator::alias('positive_limited', 'between:1,?'); $rules = [ 'value' => 'positive_limited:100' ]; $validator = Validator::make($data, $rules); // record exists with is_active flag set Validator::alias('active_exists', 'exists:?,?,is_active,1'); $rules = [ 'user_id' => 'active_exists:users,id' ]; $validator = Validator::make($data, $rules);
Negating validation results
When defining validation rules, you can negate chosen rule by prepending its name with exclamation mark. Negated validation rules will fail when not negated rule would pass and vice versa.
$rules = ['string' => 'min:3']; //validate if string is at least 3 characters long $data = ['string' => 'abcde']; $result = Validator::make($data, $rules)->passes(); // TRUE $rules = ['string' => 'min:3']; $data = ['string' => 'ab']; $result = Validator::make($data, $rules)->passes(); // FALSE $rules = ['string' => '!min:3']; $data = ['string' => 'abcde']; $result = Validator::make($data, $rules)->passes(); // FALSE $rules = ['string' => '!min:3']; $data = ['string' => 'ab']; $result = Validator::make($data, $rules)->passes(); // TRUE
Placeholders in validation rules
If validation of one field needs to use the value of another field as parameter, you can use a {{parameter_name}}
placeholder in rule definition instead of parameter value.
Value of corresponding field will be passed to validator instead of the placeholder. If the corresponding value is missing in
validated data set, the value will be taken from Config. If it's missing in config, NULL
will be used.
$rules = [ 'user_id' => 'exists:users,id' 'email' => 'unique:users,email,{{user_id}}', 'age' => 'min:{{app.min_age}} ];