NAME

Validator::Custom::Ext::Mojolicious - Validator for Mojolicious

VERSION

Version 0.0101

SYNOPSIS

package YourApp;
use base 'Mojolicious';

use Validator::Custom::Ext::Mojolicious;

__PACKAGE__->attr(validator => sub { Validator::Custom::Ext::Mojolicious->new });

sub startup {
    my $self = shift;
    
    $self->validator->validator_class('Validator::Custom::HTMLForm');
    
    $self->validator->validation_rules(
        'create#default' => [
            title => [
                [{length => [0, 255]}, 'Title is too long']
            ],
            brash => [
                ['not_blank', 'Select brach'],
                [{'in_array' => [qw/bash cpp c-sharp css delphi diff groovy java javascript perl
                                    php plain python ruby scala sql vb xml invaid/]},
                 'Brash is invalid']
            ],
            content => [
                [ 'not_blank',           "Input content"],
                [ {length => [0, 4096]}, "Content is too long"]
            ]
        ],
        'example#welcome' => [
            # ...
        ]
    );
    
    # Something else
    
});

package YourApp::Create;
use base 'Mojolicious::Controller';

sub default { 
    my $self = shift;
    
    # Validate
    my $vresult = $self->app->validator->validate($self);
    
    unless ($vresult->is_valid) {
       # Someting 
    }
}

Attributes

validator_class

$v->validator_class('Validator::Custom::HTMLForm');

This class must be Validator::Custom subclass like Validator::Custom::HTMLForm.

You can also set object, not class

my $vc = Validator::Custom::HTMLForm->new(error_stock => 0);
$v->validator_class($vc);

validation_rules

You can set validation rules correspond to controller and action pair. Constoller and action must be join '#'.

$v->validation_rules({
    'create#default' => [
        title => [
            [{length => [0, 255]}, 'title is too long']
        ],
        brash => [
            ['not_blank', 'brash must exists'],
            [{'in_array' => [qw/bash cpp/]}, 
             'brash select is invalid']
        ],
        content => [
            [ 'not_blank',         'Content must be exists'],
            [ {length => [0, 4096]}, 'Conten is too long']
        ]
    ],
    'action#controller' =>[
            # ...
    ]
});

Validation rule is explained Validator::Custom documentation.

Methods

Validator::Custom::Ext::Mojolicious inherits all methods from Object::Simple::Base and implements the following new ones.

validate

Validate received data

my $vresult = $v->validate($c);

This method receive Mojolicious::Controller object. and validate request parameters. and return validation rusult. This result is Validator::Custom::Result object.

Author

Yuki Kimoto, <kimoto.yuki at gmail.com>

Copyright & License

Copyright 2009 Yuki Kimoto, all rights reserved.

This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.