NAME
Syccess - Easy Validation Handler
VERSION
version 0.102
SYNOPSIS
use Syccess;
my $syccess = Syccess->new(
fields => [
foo => [ required => 1, length => 4, label => 'PIN Code' ],
bar => [ required => { message => 'You have 5 seconds to comply.' } ],
# if no label is given its made out of the name so 'Bar' in this case
baz => [ length => { min => 2, max => 4 }, label => 'Ramba Zamba' ],
],
);
my $result = $syccess->validate( foo => 1, bar => 1 );
if ($result->success) {
print "Yeah!\n";
}
my $failed = $syccess->validate();
unless ($failed->success) {
for my $message (@{$failed->errors}) {
print $message->message."\n";
}
}
my $traitsful_syccess = Syccess->new(
result_traits => [qw( MyApp::Syccess::ResultRole )],
error_traits => [qw( MyApp::Syccess::ErrorRole )],
field_traits => [qw( MyApp::Syccess::FieldRole )],
fields => [
# ...
],
);
DESCRIPTION
Syccess is developed for SyContent.
Syccess is a simple validation layer, which allows to check a hash of values against a validation definition and give back success or allow to see the error messages of the failure. Syccess is not made for caring about anything else, so for a higher level library you integrate Syccess and not try to extend it. Syccess is not made for giving extra attributes to the fields, the validator should be the key topic here, and it is very easy to make own validators specific for your environment, see Syccess::Validator and Syccess::ValidatorSimple, but you should be aware that most requirements should be covered with Syccess::Validator::Code and Syccess::Validator::Call, as both allow you to use simple validation methods you already may have in your model. This way you don't end up making Syccess specific procedures, that might be harder to maintain.
The complete concept of Syccess is read only, which means, a call to "validate" will produce a Syccess::Result which contains the resulting information, while the Syccess object stays unchanged. A Syccess object contains a Syccess::Field object for every field of your "fields" definition. On this field you have an object for every validator. Be aware that the validators are given as ArrayRef and you can use the same validator several times.
BEHAVIOUR INFO: The validators provided by the Syccess core are all designed to ignore a non existing value, an undefined value or an empty string. If you want that giving those leads to an error, then you must use the required validator of Syccess::Validator::Required. If you need to check against those values, for example you use Syccess::Validator::Code and in some cases an undefined value is valid and sometimes not, then you must make a custom validator, see "custom_validator_namespaces".
ATTRIBUTES
fields
Required ArrayRef containing the definition of the fields for the validation. It always first the name of the field and then an ArrayRef again with the validators. Those will be dispatched to instantiation Syccess::Field to create the fields objects. See more about validators on its attribute at Syccess::Field. You can provide a validator several times, like several regex or several code validators.
validator_namespaces
This attribute is the main namespace collection, where Syccess searches for its validators. Normally you do not set it directly, instead you set "custom_validator_namespaces", else you would remove Syccess::Validator and the SyccessX::Validator, which are automatically added after the "custom_validator_namespaces" by default here.
custom_validator_namespaces
Here you define an ArrayRef of the namespaces that should be used additional to the default ones. For example, if you add validator foo_bar, then Syccess would search first with your custom namespace, for example MyApp::Validator::FooBar, and after that it checks for Syccess::Validator::FooBar and finally SyccessX::Validator::FooBar.
For making custom validator, you must use the Syccess::Validator role, which allows to check over all params given. If you just want to make a simple validator that checks against only the relevant value of the field, then you can use Syccess::ValidatorSimple.
Please use SyccessX::Validator as namespace if you want to upload a new general validator to CPAN.
result_class
The class which is used for the result. Default is Syccess::Result.
error_class
The class which is used for errors. Default is Syccess::Error.
field_class
The class which is used for the fields. Default is Syccess::Field.
result_traits
Traits to be added to the Syccess::Result class. See with_traits at MooX::Traits.
error_traits
Traits to be added to the Syccess::Error class. See with_traits at MooX::Traits.
field_traits
Traits to be added to the Syccess::Field class. See with_traits at MooX::Traits.
errors_args
Here you can give custom attributes which are dispatched to the instantiation of the "error_class" objects.
METHODS
new_with_traits
See MooX::Traits.
field
Get the Syccess::Field for the name given as parameter.
fields
Get all Syccess::Field of the Syccess object.
validate
This is the main function to produce a "result_class" object, which will then hold the result and the errors of the validation process. This function must be called with a Hash (no HashRef yet supported) of the values to check for the validation.
Core Validators
call
Syccess::Validator::Call - Calling a method on an object for validation
code
Syccess::Validator::Code - Using a CodeRef to validate
in
Syccess::Validator::In - Checking if a value is in a given list of values
is_number
Syccess::Validator::IsNumber - Check if the value is a number
length
Syccess::Validator::Length - Check for length of the string, if its specific or min or max values.
regex
Syccess::Validator::Regex - Check the value against a regex
required
Syccess::Validator::Required - Value must be provided, and cant be empty
Label Concept
The system is designed to deliver a validation only, which leaded to the decision to not include the ability to give fields specific attributes. As a consequence out of this, the implementation of a label concept (so a visual representation of the field name in the error message) is done with a special trick, as seen in the "SYNOPSIS", through giving it as just another validator, it will then be consumed as label for the field instead of the load of another validator object.
TODO
One bigger feature planned is adding the ability to stack Syccess objects to allow cascaded parameters for validation. Currently this is not implemented, because, if you integrate Syccess in a bigger context, you will want to control the cascading yourself (in my case SyForm takes the control of this). But I hope I will find later the time to make this possible.
SUPPORT
IRC
Join #sycontent on irc.perl.org. Highlight Getty for fast reaction :).
Repository
http://github.com/SyContent/Syccess
Pull request and additional contributors are welcome
Issue Tracker
http://github.com/SyContent/Syccess/issues
AUTHOR
Torsten Raudssus <torsten@raudss.us>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Torsten Raudssus.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.