sedlatschek / laravel-conditional-equals-validation
Additional rules for conditional equals validation
Installs: 2 364
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 5
Requires
- php: ^8.1
- illuminate/contracts: ^9.0|^10.0
Requires (Dev)
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.9
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^7.0|^8.0
- pestphp/pest: ^2.0
- pestphp/pest-plugin-arch: ^2.0
- pestphp/pest-plugin-laravel: ^2.0
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
This package is auto-updated.
Last update: 2024-12-19 09:07:59 UTC
README
This package provides additional validation rules for Laravel projects:
Equals
$request->validate([ 'a' => ['boolean', (new Equals(true))->if('b', false)], 'b' => ['boolean'] ]);
NotEquals
$request->validate([ 'a' => ['string', (new NotEquals('foo'))->ifAnyOf(['b', 'c'], 'bar')], 'b' => ['string'], 'c' => ['string'], ]);
See Usage for all possibilites! Also know that the native method Rule::when
may be a better alternative to this package.
Installation
You can install the package via composer:
composer require sedlatschek/laravel-conditional-equals-validation
Usage
If
Evaluate one other fields value.
$request->validate([ 'a' => ['string', (new Equals('foo'))->if('b', 'bar')], 'b' => ['string'], ]);
IfNot
Evaluate one other fields value.
$request->validate([ 'a' => ['string', (new Equals('foo'))->ifNot('b', 'bar')], 'b' => ['string'], ]);
IfAllOf
Evaluate if all of the given fields match the given value.
$request->validate([ 'a' => ['string', (new Equals('foo'))->ifAllOf(['b', 'c'], 'bar')], 'b' => ['string'], 'c' => ['string'], ]);
Example validation results:
// passes $data = [ 'a' => 'foo', 'b' => 'bar', 'c' => 'bar', ]; // fails $data = [ 'a' => 'x', 'b' => 'bar', 'c' => 'bar', ]; // passes $data = [ 'a' => 'foo', 'b' => 'bar', 'c' => 'x', ];
IfAnyOf
Evaluate if any of the given fields match the given value.
$request->validate([ 'a' => ['string', (new Equals('foo'))->ifAnyOf(['b', 'c'], 'bar')], 'b' => ['string'], 'c' => ['string'], ]);
Example validation results:
// passes $data = [ 'a' => 'foo', 'b' => 'bar', 'c' => 'x', ]; // fails $data = [ 'a' => 'x', 'b' => 'bar', 'c' => 'x', ]; // passes $data = [ 'a' => 'foo', 'b' => 'x', 'c' => 'x', ];
IfNoneOf
Evaluate if none of the given fields match the given value.
$request->validate([ 'a' => ['string', (new Equals('foo'))->ifNoneOf(['b', 'c'], 'bar')], 'b' => ['string'], 'c' => ['string'], ]);
Example validation results:
// passes $data = [ 'a' => 'foo', 'b' => 'x', 'c' => 'x', ]; // fails $data = [ 'a' => 'x', 'b' => 'x', 'c' => 'x', ]; // passes $data = [ 'a' => 'foo', 'b' => 'x', 'c' => 'bar', ];
Combined
All of the above conditions can be chained. The connection between each condition is seen as an and
operator.
$request->validate([ 'a' => ['string', (new Equals('foo'))->if('b', 'bar')->ifAnyOf(['c', 'd'], false)->ifAllOf(['e', 'f', 'g'], 1), 'b' => ['string'], 'c' => ['boolean'], 'd' => ['boolean'], 'e' => ['integer'], 'f' => ['integer'], 'g' => ['integer'], ]);
Example validation results:
// passes $data = [ 'a' => 'foo', 'b' => 'bar', 'c' => true, 'd' => false, 'e' => 1, 'f' => 1, 'g' => 1, ]; // fails $data = [ 'a' => 'x', 'b' => 'bar', 'c' => true, 'd' => false, 'e' => 1, 'f' => 1, 'g' => 1, ]; // passes $data = [ 'a' => 'x', 'b' => 'bar', 'c' => true, 'd' => false, 'e' => 1, 'f' => 1, 'g' => 2, ]; // passes $data = [ 'a' => 'x', 'b' => 'x', 'c' => true, 'd' => false, 'e' => 1, 'f' => 1, 'g' => 1, ]; // passes $data = [ 'a' => 'x', 'b' => 'x', 'c' => true, 'd' => true, 'e' => 1, 'f' => 1, 'g' => 1, ];
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Credits
License
The MIT License (MIT). Please see License File for more information.