LaravelPackages.net
Acme Inc.
Toggle sidebar
laracasts/validation

Easy validation for Laravel applications.

190.194
147
1.3
About laracasts/validation

laracasts/validation is a Laravel package for easy validation for laravel applications.. It currently has 147 GitHub stars and 190.194 downloads on Packagist (latest version 1.3). Install it with composer require laracasts/validation. Discover more Laravel packages by laracasts or browse all Laravel packages to compare alternatives.

Last updated

If you are using Laravel 5.0, this package is unnecessary. Instead, leverage the new form request classes to perform your validation.

Install With Composer

"require": {
    "laracasts/validation": "~1.0"
}

And then, if using Laravel (not required), add the service provider to app/config/app.php in the providers array.

'Laracasts\Validation\ValidationServiceProvider'

Usage

Here's an example. Imagine that you need validation for a login form. First, create an object to contain the necessary rules:

<?php namespace MyApp\Forms;

use Laracasts\Validation\FormValidator;

class Login extends FormValidator {

	/**
	 * Validation rules for logging in
	 *
	 * @var array
	 */
	protected $rules = [
		'username' => 'required',
		'password' => 'required'
	];

}

Next, pull this object into your controller (or wherever you perform your validation).

use MyApp\Forms\Login as LoginForm;
use Laracasts\Validation\FormValidationException;

// ...

protected $loginForm;

public function __construct(LoginForm $loginForm)
{
    $this->loginForm = $loginForm;
}

public function store()
{
    $input = Input::all();

    try
    {
        $this->loginForm->validate($input);

        // login user, do whatever, redirect
    }
    catch (FormValidationException $e)
    {
        return Redirect::back()->withInput()->withErrors($e->getErrors());
    }

}

If validation passes, true will be returned. Otherwise, a FormValidationException exception will be thrown. You can either catch that within your controller, or pass it to, for example, global.php for handling. Either works.

The key is that you'll create a dedicated class for each form that you need to validate. For instance, if a user can register for your site, then you'll have a Registration form object. Maybe something like:

<?php namespace MyApp\Forms;

use Laracasts\Validation\FormValidator;

class Registration extends FormValidator {

	/**
	 * Validation rules for registering
	 *
	 * @var array
	 */
	protected $rules = [
		'username' => 'required',
		'email'    => 'required|unique:users',
		'age'      => 'required|integer',
		'gender'   => 'in:male,female',
		'password' => 'required|confirmed'
	];

}

Now, just inject this object into your controller or application service, and call a validate() method on it.

$this->registrationForm->validate(Input::all());

Star History Chart