NAME
Data::Verify - versatile data/type verification, validation and testing
SYNOPSIS
use Data::Verify qw(:all); use Error qw(:try);
# EMAIL, URI, IPV4 are standard types
try
{
verify( $cgi->param( 'email' ), EMAIL );
verify( $cgi->param( 'homepage' ) , URI('http') );
verify( $cgi->param( 'serverip' ) , IPV4 );
}
catch Type::Exception with
{
printf "Expected '%s' %s at %s line %s\n", $_->value, $_->type->info, $_->was_file, $_->was_line foreach @_;
};
my $h = Human->new( email => 'j@d.de', firstname => 'john', lastname => 'doe', sex => 'male', countrycode => '123123', age => 12 );
$h->contacts( { lucy => '110', john => '123' } );
my $g = Data::Verify::Guard->new(
types => [ 'Human', 'Others' ],
tests =>
{
email => EMAIL,
firstname => WORD,
lastname => WORD,
sex => GENDER,
countrycode => NUM,
age => NUM,
contacts => sub { my %args = @_; exists $args{lucy} },
}
);
$g->inspect( $h );
DESCRIPTION
This module supports types. Out of the ordinary it supports parameterised types (like databases have i.e. VARCHAR(80) ). When you try to feed a typed variable against some odd data, this module explains what he would have expected. It doesnt support casting (yet).
KEYWORDS
data types, data manipulation, data patterns, user input, tie
TYPES
Data::Verify 0.01_21 supports 28 types:
BOOL - a true or false value
EMAIL - an email address
GENDER - a gender (male|female)
INT - an integer
IPV4 - an IPv4 network address
MYSQL_BLOB - a 'blob' or 'text' with a max length of 65535 (2^16 - 1) cha..
MYSQL_DATE - a date
MYSQL_DATETIME - a date and time combination
MYSQL_ENUM - a member of an enumeration
MYSQL_LONGBLOB - a 'blob' or 'text' with a max length of 4294967295 (2^32 - 1..
MYSQL_LONGTEXT - a 'blob' or 'text' with a max length of 4294967295 (2^32 - 1..
MYSQL_MEDIUMBLOB - a 'blob' or 'text' with a max length of 16777215 (2^24 - 1) ..
MYSQL_MEDIUMTEXT - a 'blob' or 'text' with a max length of 16777215 (2^24 - 1) ..
MYSQL_SET - a set
MYSQL_TEXT - a 'blob' or 'text' with a max length of 65535 (2^16 - 1) cha..
MYSQL_TIME - a time
MYSQL_TIMESTAMP - a timestamp
MYSQL_TINYBLOB - a 'blob' or 'text' with a max length of 255 (2^8 - 1) charac..
MYSQL_TINYTEXT - a 'blob' or 'text' with a max length of 255 (2^8 - 1) charac..
MYSQL_YEAR - a year in 2- or 4-digit format
NUM - a number
QUOTED - a quoted string
REAL - a real
REF - a reference to a single (set of) types
URI - an http uri
VARCHAR - a string with limited length of choice (default 60)
WORD - a word (without spaces)
YESNO - a simple answer (yes|no)
And 3 filters:
chomp - chomps
lc - lower cases
uc - upper cases
NUMERIC TYPES
INT, NUM, REAL
DATE AND TIME TYPES
MYSQL_DATE, MYSQL_DATETIME, MYSQL_TIME, MYSQL_TIMESTAMP, MYSQL_YEAR
STRING (CHARACTERS) TYPES
EMAIL, GENDER, IPV4, MYSQL_BLOB, MYSQL_LONGBLOB, MYSQL_LONGTEXT, MYSQL_MEDIUMBLOB, MYSQL_MEDIUMTEXT, MYSQL_TEXT, MYSQL_TINYBLOB, MYSQL_TINYTEXT, QUOTED, URI, VARCHAR, WORD
OTHER TYPES
MYSQL_ENUM, MYSQL_SET
INTERFACE
FUNCTIONS
verify( $teststring, $type, [ .. ] ) - Verifies a 'value' against a 'type'.
overify( { member => TYPE, .. }, $object, [ .. ] ) - Verifies members of objects against multiple 'types' or CODEREFS.
Data::Verify::Guard
This is something like a Bouncer. He inspect 'objects' their members are of requested type. D::V::G has two parameters and one member.
types Parameter (Array)
If empty isn't selective for special references ( HASH, ARRAY, "CUSTOM", .. ). If is set then "inspect" will fail if the object is not a reference of the listed type.
tests Parameter (Hash)
Keys are the members names (anything that can be called via the $o->member syntax) and the type(s) as value. When a member should match multple types, they should contained in an array reference.
inspect Member
Accepts a blessed reference as a parameter. It returns 0 if a guard test or type constrain will fail, otherwise 1.
TYPE BINDING
typ/untyp/istyp
Example
try { typ MYSQL_ENUM( qw(Murat mo muri) ), \( my $alias );
$alias = 'Murat';
$alias = 'mo';
$alias = 'XXX';
}
catch Type::Exception ::with
{
printf "Expected '%s' %s at %s line %s\n", $_->value, $_->type->info, $_->was_file, $_->was_line foreach @_;
};
Exceptions
Exceptions are implemented via the 'Error' module.
Type::Exception
This is a base class inheriting 'Error'.
Failure::Type
Is a 'Type::Exception' and has following additional members:
bool:
expected - reserved for future use
returned - reserved for future use
string:
was_file - the filename where the exception was thrown
int:
was_line - the line number
ref:
type - the type 'object' used for verification
value - a reference to the data given for verification against the type
Failure::Function (Internal use only)
This exception is thrown in the verification process if a Function (which is a subelement of the verification process) fails.
Is a 'Type::Exception' and has following additional members.
bool:
expected - reserved for future use
returned - reserved for future use
ref:
type - the type 'object' used for verification
Retrieving Type Information
catalog()
returns a static string containing a listing of all know types (and a short information). This may be used to get an overview via:
perl -e "use Data::Verify qw(:all); print catalog()"
testplan( $type )
Returns the entry-objects how the type is verified. This may be used to create a textual description how a type is verified.
foreach my $entry ( testplan( $type ) )
{
printf "\texpecting it %s %s ", $entry->[1] ? 'is' : 'is NOT', strlimit( $entry->[0]->info() );
}
EXPORT
all = (typ untyp istyp verify catalog testplan), map { uc } @types
None by default.
AUTHOR
Murat Ünalan, <murat.uenalan@cpan.org>
SEE ALSO
Data::Types, String::Checker, Regexp::Common, Data::FormValidator, HTML::FormValidator, CGI::FormMagick::Validator, CGI::Validate, Email::Valid, Email::Valid::Loose, Embperl::Form::Validate, Attribute::Types
1 POD Error
The following errors were encountered while parsing the POD:
- Around line 1655:
Non-ASCII character seen before =encoding in 'Ünalan,'. Assuming CP1252