Home

Awesome

Validation

Build Status Total Downloads License

Extra validation providers and rules for CakePHP 3

Install

Using Composer:

composer require gourmet/validation:~1.0

This plugin does not require to be loaded in bootstrap as it only uses autoloaded classes.

Usage

In any table's validationDefault() method:

public function validationDefault(Validator $validator)
{
    $validator
        ->provider('respect', new \Gourmet\Validation\Validation\RespectProvider())
        ->provider('iso', new \Gourmet\Validation\Validation\IsoCodesProvider())

        ->add('country_code', 'valid', [
            'provider' => 'respect',
            'rule' => 'countryCode',
        ])

        ->add('zip_code_by_country_code', 'valid', [
            'rule' => function($value, $context) {
                $provider = $context['providers']['respect'];
                $country = $context['data']['country_code'];
                return $provider->__call('postalCode', [$value, $country]);
            }
        ])

        ->add('zip_code_by_country', 'valid', [
            'rule' => function($value, $context) {
                $provider = $context['providers']['iso'];
                $country = $context['data']['country'];
                return $provider->__call('zip_code', [$value, $country]);
            }
        ])

        ->add('book_code', 'valid', [
            'provider' => 'iso',
            'rule' => 'isbn10'
        ])
}

For more, check out the supported validation methods for each of the official libraries the providers proxy:

Patches & Features

Bugs & Feedback

http://github.com/gourmet/validation/issues

License

Copyright (c) 2015, Jad Bitar and licensed under The MIT License.