There is no license information available for the latest version (dev-master) of this package.

Installs: 16 744

Dependents: 1

Suggesters: 0

Stars: 220

Watchers: 14

Forks: 63

Open Issues: 27

dev-master 2014-09-22 23:13 UTC


This package takes care of the model validation process for you. Rather than manually going through the tedious Validator::make(...) process, just save the model, and this package will handle the rest.


Install the package through Composer.

    "require": {
        "laravel/framework": "4.0.*",
        "way/database": "dev-master"

Then, rather than extending Eloquent from your model, extend Way\Database\Model, like so:


class Dog extends Way\Database\Model {


Alternatively, edit app/config/app.php, and add a new item to the aliases array:

'Model' => 'Way\Database\Model'

Now, your models can simply extend Model.


class Dog extends Model {



This package hooks into Eloquent's save event, and automatically validates the model's current attributes against the rules that you have set for your model.

Here's an example of setting validation rules for the model:


class Dog extends Model {
    protected static $rules = [
        'name' => 'required'

    //Use this for custom messages
    protected static $messages = [
        'name.required' => 'My custom message for :attribute required'

Now, simply save the model as you normally would, and let the package worry about the validation. If it fails, then the model's save method will return false.

Here's an example of storing a new dog.

public function store()
    $dog = new Dog(Input::all());

    if ($dog->save())
        return Redirect::route('dogs.index');

    return Redirect::back()->withInput()->withErrors($dog->getErrors());

If using Eloquent's static create method, you can use the hasErrors() methods to determine if validation errors exist.

$dog = Dog::create(Input::all());

if ($dog->hasErrors()) ...

That's it! Have fun.