NAME
DBIx::Class::Valiant::Validator::SetSize - Verify a DBIC related resultset
SYNOPSIS
package Example::Schema::Result::Person;
use base 'Example::Schema::Result';
__PACKAGE__->load_components(qw/
Valiant::Result
Core
/);
__PACKAGE__->table("person");
__PACKAGE__->add_columns(
id => { data_type => 'bigint', is_nullable => 0, is_auto_increment => 1 },
username => { data_type => 'varchar', is_nullable => 0, size => 48 },
first_name => { data_type => 'varchar', is_nullable => 0, size => 24 },
last_name => { data_type => 'varchar', is_nullable => 0, size => 48 },
password => {
data_type => 'varchar',
is_nullable => 0,
size => 64,
},
);
__PACKAGE__->has_many(
credit_cards =>
'Example::Schema::Result::CreditCard',
{ 'foreign.person_id' => 'self.id' }
);
__PACKAGE__->validates(
credit_cards => (
set_size=>+{ skip_if_empty=>1, min=>2, max=>4 },
)
);
DESCRIPTION
Validations on related resultsets. This constrains minimum / maximum sizes on the set and permits optional sets (where the min/max is only applied when the set has entries).
ATTRIBUTES
This validator supports the following attributes:
skip_if_empty
Allows you to skip validations if the resultset is empty (has zero rows). Useful if you want to do validations only if there are rows found, such as when you have an optional relationship. Defaults to false.
min
max
The minimum or maximum number of rows that the resultset can contain. Optional (but I suspect you'd set at least one otherwise why bother with this constraint?
too_few_msg
too_many_msg
Error messages associated with the 'min' or 'max' constraints. Defaults to 'too_few' or 'too_many' translation tags.
SHORTCUT FORM
This validator supports the follow shortcut forms:
validates attribute => ( result_set => [1,4], ... );
Which is the same as:
validates attribute => (
result_set => {
min => 1,
max => 4,
}
);
GLOBAL PARAMETERS
This validator supports all the standard shared parameters: if
, unless
, message
, strict
, allow_undef
, allow_blank
.
SEE ALSO
Valiant, Valiant::Validator, Valiant::Validator::Each.
AUTHOR
See Valiant
COPYRIGHT & LICENSE
See Valiant