NAME
MooX::Role::Validatable - Role to add validation to a class
SYNOPSIS
package MyClass;
use Moo;
with 'MooX::Role::Validatable';
has 'attr1' => (is => 'lazy');
sub _build_attr1 {
my $self = shift;
# Note initialization errors
$self->add_errors( {
message => 'Error: blabla',
message_to_client => 'Something is wrong!'
} ) if 'blabla';
}
sub _validate_some_other_errors { # _validate_*
my $self = shift;
my @errors;
push @errors, {
message => '...',
message_to_client => '...',
};
return @errors;
}
## use
my $ex = MyClass->new();
if (not $ex->initialized_correctly) {
my @errors = $ex->all_init_errors();
...; # We didn't even start with good data.
}
if (not $ex->confirm_validity) { # does not pass those _validate_*
my @errors = $ex->all_errors();
...;
}
DESCRIPTION
MooX::Role::Validatable is a Moo/Moose role which provides a standard way to add validation to a class.
METHODS
initialized_correctly
no error when init the object (no add_errors is called)
add_errors
$self->add_errors(...)
add errors on those lazy attributes or sub BUILD
confirm_validity
run all those _validate_* messages and returns true if no error found.
all_errors
An array of the errors currently noted. combined with all_init_errors and all_validation_errors
all errors including below methods are instance of error_class, default to MooX::Role::Validatable::Error
all_init_errors
all errors on init
all_validation_errors
all errors on validation
all_errors_by_severity
order by severity
primary_validation_error
the first error of all_errors_by_severity
validation_methods
A list of all validation methods available on this object. This can be auto-generated from all methods which begin with "_validate_" which is especially helpful in devleoping new validations.
You may wish to set this list directly on the object, if you create and validate a lot of static objects.
error_class
default to MooX::Role::Validatable::Error, override by
has '+error_class' => (is => 'ro', default => sub { 'My::Validatable::Error' });
# or
->new(error_class => 'My::Validatable::Error');
AUTHOR
Binary.com <fayland@binary.com>
COPYRIGHT
Copyright 2014- Binary.com
LICENSE
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.