NAME

Valiant::Filter - A role to define the Filter interface.

SYNOPSIS

package MySpecialFilter;

use Moo;
with 'Valiant::Validator';

sub filter {
  my ($self, $class, $attrs) = @_;
  # Do something with $attrs, possibly with $self
  return $attrs;
}

DESCRIPTION

This is a base role for defining a filter. This should be a class that defines a filter method. Here's a more detailed example that shows using a custom filter with a filterable object:

package Local::Test::Filter::Truncate;

use Moo;
with 'Valiant::Filters';

has max_length => (is=>'ro', required=>1);

sub filter {
  my ($self, $class, $attrs) = @_;
  foreach my $key (keys %{$attrs}) {
    my $current_value = $attrs->{$key};
    my $new_value = substr( $current_value, 0, $self->max_length );
    $attrs->{$key} = $new_value;
  }
  return $attrs;
}

package Local::Test::User;

use Moo;
use Valiant::Filters;

has [qw(first_name last_nane)] => (is=>'ro', required=>1);

filters_with 'Truncate', max_length=>25;

my $user = Local::Test::User->new(
  first_name => 'averyveryveryveryverylooooooooonnngFIRSTname',
  last_name => 'averyveryveryveryverylooooooooonnngLASTname',
);

print $user->first_name; #averyveryveryveryverylooo
print $user->last_name; #averyveryveryveryverylooo

A Filter receives all the arguments passed to new and runs before the object is created. It gets the following three arguments: $self, which is the instance of the Filter which is associated with the filterable class, $class, which is the name of the class upon which the filter is running and $attrs which is a hashref of the arguments passed to new. $attrs is always a hashref and has been normalized as such. ALso $attrs contains everything passed to new even things that are not valid for the $class.

A Filter is created once when the class uses it and exists for the full life cycle of the filterable object.

Generally you would write a filter class like this when you want a filter that can be applied to all the incoming arguments or when the filter itself is dependent on all the arguments. For writing filters that are applied to individual attributes you should create a subclass of Valiant::Filter::Each.

PREPACKAGED FILTER CLASSES

The following attribute filter classes are shipped with Valiant. Please see the package POD for usage details (this is only a sparse summary)

Collapse

Collapse all whitespace in a string to a single space. See Valiant::Filter::Collapse for details.

Flatten

Flatten an arrayref or hashref to a string. See Valiant::Filter::Flatten for details.

HtmlEscape

Basic HTML escaping on a string. See Valiant::Filter::HtmlEscape for details.

Lower

Lowercase a string. See Valiant::Filter::Trim for details.

Title

'title' cases a string (all first letters up cased). See Valiant::Filter::Title for details.

ToArray

Given a string force to a single element array (do nothing if its already an array. See Valiant::Filter::ToArray for details.

Trim

Trims whitespace from the start and/or end of the attribute string.

See Valiant::Filter::Trim for details.

UcFirst

Uppercases the first letter of a string

See Valiant::Filter::UcFirst for details.

Upper

Upcase a string. See Valiant::Filter::Upper for details.

With

Use a subroutine reference to provide filtering.

See Valiant::Filter::With for details.

Special Validators

The following validators are not considered for end users but have documentation you might find useful in furthering your knowledge of Valiant: Valiant::Filter::Collection, Valiant::Filter::Each.

SEE ALSO

Valiant, Valiant::Filter::Each.

AUTHOR

See Valiant

COPYRIGHT & LICENSE

See Valiant