NAME Kelp::Module::ValidateTiny - Validate parameters in a Kelp Route Handler VERSION Version 0.01 SYNOPSIS use Kelp::Module::ValidateTiny; # inside your Kelp config file { modules => [ qw{SomeModule Validate::Tiny} ], modules_init => { ... , # :all will import everything # no need to list MyApp here 'Validate::Tiny' => { subs => [ qw{is_required is_required_id} ], into => [ qw{MyApp::OtherRouteClass} ], } } } ... #inside a Kelp route my $vt_rules = { fields => [...], filters => [...], checks => [...], }; my $result = $self->validate($vt_rules) # $result is a Validate::Tiny object # process $result ... # render the template form.tt if validation fails # $errors and valid values are automatically passed, # to the template, but you can optionally pass some # more data to that template my $result = $self->validate($rules, on_error => 'form.tt', data => { message => 'You could try something else' }, ); # If validation fails, $result is an instance of # Validate::Tiny::PlackResponse and has a response # method that can be sent return $result->response unless $result->success # All data is valid here. # use $result->data DESCRIPTION Kelp::Module::ValidateTiny adds Validate::Tiny's validator to your Kelp application. METHODS validate This is the only method decorating $self. You can call it in three ways: First you can pass it just a valid Validate::Tiny $rules hash reference. It will return a Validate::Tiny object and you can call all the usual V::T methods on it. my $result = $self->validate($rules); # $result is now a Validate::Tiny object Second you can pass it a name ('on_error') and value (a template filename) pair. If your data passed the validation, the return value is the usual V::T object. However, if validation fails, the validate method returns an object that has a "response" method in addition to all the Validate::Tiny methods. my $result = $self->validate( $rules, on_error => 'form' ); return $result->response unless $result->success # form.tt rendered ... # Your data was valid here ... # Return some other response Note that calling $result->response if your validations succeeded is a fatal error. The template (form.tt in the code above) is rendered with a hashref that contains the key-value pairs of valid parameters plus a key "error" that points to another hashref with names of invalid parameters as keys and the corresponding error messages as values. So if your parameters were {id => 41, lang => 'Perl', version => '5.10'} and id was found to be invalid with your rules/checks, then the template 'form.tt' renderer is passed the following hashref: { lang => 'Perl', version => '5.10', error { id => 'The answer is 42, not 41', } } This can be useful with a construct like "[% error.name || name %]" in your template. Third, you can pass some additional values that will be passed "as is"" to the on_fail template $self->validate($rules, on_error => 'form.tt', data => { message => 'You could try something else next time!' }, ); Here the caller passes an additional key data so that your "on_error" template renderer gets the following hash ref { lang => 'Perl', version => '5.10', error { id => 'The answer is 42, not 41', }, message => 'You could try something else next time!' } AUTHOR Gurunandan R. Bhat <gbhat@pobox.com> COPYRIGHT Copyright 2013- Gurunandan R. Bhat LICENSE This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. SEE ALSO Kelp, Kelp::Module, Validate::Tiny