NAME
Form::Tiny::FieldDefinition - definition of a field to be validated
SYNOPSIS
# you usually don't have to do this by hand, see examples in Form::Tiny::Manual
# name is the only required attribute
my $definition = Form::Tiny::FieldDefinition->new(
name => "something",
type => Str,
...
);
DESCRIPTION
This class keeps all the data for a field definition and contains method that handle single field validation.
ATTRIBUTES
Each of the attributes can be accessed by calling its name as a function on Form::Tiny::FieldDefinition object. See Form::Tiny::Manual for more examples.
name
The only required attribute for the constructor.
A string which should specify the hash structure path of the field.
Special characters are:
dot [.], which specifies nesting
star [*], which specifies any number of array elements, but only if it is the only character on level, like a.*.b
They both can be escaped by a backslash \
to lose their special meaning.
required
A field is not required by default (value 0
), which means that its absence does not produce an error.
A field can also be soft required ("soft"
) or hard required ("hard"
or 1
).
Soft required field produce errors only if it is undefined or not present in the input data.
Hard required field also checks if the field is not an empty string.
type
The type attribute is where you can plug in a Type::Tiny type object. It has to be an instance of a class that provider validate and check methods, just like Type::Tiny. This can also be a Form::Tiny form instance.
predicate: has_type
addons
Hash reference for internal use only - readable and writable under the addons
method. If you need additional data for a field definition that will be used in metaclasses (while extending Form::Tiny), put it here.
coerce
Coercions take place just before the validation. By default, values are not coerced. Specifying value 1 will cause the field to use coercions from the type object.
It can also be a code reference which will be called to coerce the value, passing in a field value as its only argument.
adjust
Adjustments take place just after the validation. By default, values are not adjusted. You can specify a code reference which will be called to adjust the value (change the value after the validation).
predicate: is_adjusted
writer: set_adjustment
default
A coderef returning the default value for the field. Will be used when the field is not present in the input at all. Making the field hard-required will make the default value be used in place of undefined / empty value as well.
This coderef will be passed form instance as the only argument and is expected to return a scalar value.
predicate: has_default
writer: set_default
message
If type class error messages are not helpful enough, you can specify your own message string which will be inserted into form errors if the validation for the field fails.
predicate: has_message
data
Custom data for the field. Can be anything and will not be used by Form::Tiny system itself. It should be anything that will help user's own system use the form instance.
writer: set_data
predicate: has_data
METHODS
is_subform
Checks if the field definition's type is a form - whether it mixes in Form::Tiny::Form role.
get_name_path
Parses and returns the name of the field as an object of Form::Tiny::Path class.
hard_required
Checks if the field is hard-required (any of the two values which are allowed for this flag)
validate
Validates a scalar value. Arguments are $parent_form, $field_value
. Returns a boolean, whether the validation passed.