# NAME
FormValidator::Lite - lightweight form validation library
# SYNOPSIS
    use FormValidator::Lite;
    FormValidator::Lite->load_constraints(qw/Japanese/);
    my $q = CGI->new();
    my $validator = FormValidator::Lite->new($q);
    $validator->load_function_message('en');
    my $res = $validator->check(
        name => [qw/NOT_NULL/],
        name_kana => [qw/NOT_NULL KATAKANA/],
        {mails => [qw/mail1 mail2/]} => ['DUPLICATION'],
    );
    if ( ..... return_true_if_error() ..... ) {
        $validator->set_error('login_id' => 'DUPLICATION');
    }
    if ($validator->has_error) {
        ...
    }
    # in your template
    
    ? for my $msg ($validator->get_error_messages) {
        - = $msg ?>? }
# DESCRIPTION
FormValidator::Lite is a simple, fast implementation for form validation.
IT'S IN BETA QUALITY. API MAY CHANGE IN THE FUTURE.
# HOW TO WRITE YOUR OWN CONSTRAINTS
Create your own constraint package as such :
    package MyApp::Validator::Constraint;
    use strict;
    use warnings;
    use FormValidator::Lite::Constraint;
    
    rule 'IS_EVEN' => sub {
        return $_ % 2 ? 0 : 1;
    };
    
    rule 'IS_GREATER_THAN' => sub {
        my ($min) = @_;
        return $_ >= $min;
    }
    alias 'IS_GREATER_THAN' => 'IS_BIGGER_THAN';
    
    1;
And in your controller :
    use FormValidator::Lite qw("+MyApp::Validator::Constraint");
    
    my $validator = FormValidator::Lite->new(...);
    $validator->set_message_data(...);
    $validator->check(
        some_param => [ 'UINT', 'IS_EVEN', ['IS_GREATER_THAN' => 42] ],
    );
When defining a rule keep in mind that the value for the parameter comes from
`$_` and the additional arguments defined in your validation
specifications come from `@_`.
# METHODS
- my $validator = FormValidator::Lite->new($q);
    Create a new instance.
    The constructor takes a mandatory argument `$q` that is a query-like 
    object such as Apache::Request, CGI.pm, Plack::Request. The object MUST have
    a `$q->param` method.
    **EXPERIMENTAL: ** You can pass the hash value for `$q`.
- $validator->query()
- $validator->query($query)
    Getter/Setter for the query attribute.
- $validator->check(@specs\_array)
    Validate the query against a set of specifications defined in the
    `@specs_array` argument. In the most common case, the array is a sequence
    of pairs : the first item is the parameter name and the second item is an
    array reference with a list of constraint rules to apply on the query's value
    for the parameter.
        my $res = $validator->check(
            name      => [qw/NOT_NULL/],
            name_kana => [qw/NOT_NULL KATAKANA/],
            {mails => [qw/mail1 mail2/]} => ['DUPLICATION'],
        );
    In the above example _name_ is a parameter. _NOT\_NULL_, _KATAKANA_ and
    _DUPLICATION_ are the names of the constraints.
- $validator->is\_error($key)
    Return true value if there is an error for the `$key` parameter.
- $validator->is\_valid()
    Return true value if `$validator` didn't detect any error.
    This is the same as `!$validator->has_error()`.
- $validator->has\_error()
    Return true value if `$validator` detects error.
    This is the same as `!$validator->is_valid()`.
- $validator->set\_error($param, $rule\_name)
    Manually set a new error for the parameter named `$param`. The rule's name
    is `$rule_name`.
- $validator->errors()
    Return all the errors as a hash reference where the keys are the parameters
    and the values are a hash reference with the failing constraints.
        {
            'foo' => { 'NOT_NULL' => 1, 'INT' => 1 },
            'bar' => { 'EMAIL' => 1, },
        }
- $validator->load\_constraints($name)
        $validator->load_constraints("DATE", "Email");
        # or load your own constraints
        $validator->load_constraints("+MyApp::FormValidator::Lite::Constraint");
    You can also load the constraints during import :
        use FormValidator::Lite qw/Date Email/;
    Load constraint components named `"FormValidator::Lite::Constraint::${name}"`.
    By default, You can use only constraints defined by [FormValidator::Lite::Constraint::Default](https://metacpan.org/pod/FormValidator::Lite::Constraint::Default).
- $validator->load\_function\_message($lang)
        $validator->load_function_message('ja');
    Load function message file.
    Currently, [FormValidator::Lite::Messages::ja](https://metacpan.org/pod/FormValidator::Lite::Messages::ja) and
    [FormValidator::Lite::Messages::en](https://metacpan.org/pod/FormValidator::Lite::Messages::en) are available.
- $validator->set\_param\_message($param => $message, ...)
        $validator->set_param_message(
            name => 'Your Name',
        );
    Add a message-friendly description for the parameter.
- $validator->set\_message("$param.$func" => $message)
        $v->set_message('zip.jzip' => 'Please input correct zip number.');
    Set an error message for a given $param and $func pair.
- $validator->set\_message\_data({ message => $msg, param => $param, function => $function })
        $v->set_message_data(YAML::Load(<<'...'));
        ---
        message:
          zip.jzip: Please input correct zip number.
        param:
          name: Your Name
        function:
          not_null: "[_1] is empty"
          hiragana: "[_1] is not Hiragana"
        ...
    Set the error message map. In the 'function' and 'message' sections,
    `[_1]` will be replaced by `build_message` with the description of
    the failing parameter provided in the 'param' section.
- `$validator->build_message($tmpl, @args)`
    replace \[\_1\] in `$tmpl` by `@args`.
    Setup error message map.
- `$validator->set_message("$param.$func" => $message)`
        $v->set_message('zip.jzip' => 'Please input correct zip number.');
    Note that it will void any previous calls to `load_function_message`,
    `set_message` or `set_param_message`.
- my @errors = $validator->get\_error\_messages()
- my $errors = $validator->get\_error\_messages()
    Get all the error messages for the query. This method returns an array in list
    context and an array reference otherwise.
- my $msg = $validator->get\_error\_message($param => $func)
    Generate the error message for parameter `$param` and function
    `$func`.
- my @msgs = $validator->get\_error\_messages\_from\_param($param)
    Get all the error messages for the parameter `$param`.
# WHY NOT FormValidator::Simple?
Yes, I know. This module is very similar with FV::S.
But, FormValidator::Simple is too heavy for me.
FormValidator::Lite is fast!
    Perl: 5.010000
    FVS: 0.23
    FVL: 0.02
                            Rate FormValidator::Simple   FormValidator::Lite
    FormValidator::Simple  353/s                    --                  -75%
    FormValidator::Lite   1429/s                  304%                    --
# AUTHOR
Tokuhiro Matsuno <tokuhirom AAJKLFJEF@ gmail.com>
# THANKS TO
craftworks
nekokak
tomi-ru
# SEE ALSO
[FormValidator::Simple](https://metacpan.org/pod/FormValidator::Simple), [Data::FormValidator](https://metacpan.org/pod/Data::FormValidator), [HTML::FormFu](https://metacpan.org/pod/HTML::FormFu)
# LICENSE
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.