NAME

MooseX::Types::Log::Dispatch - Log::Dispatch related constraints and coercions for Moose

SYNOPSIS

package MyFoo;
use MooseX::Types::Log::Dispatch qw(Logger LogLevel);

has logger => (
    isa => Logger,
    is => 'ro',
    coerce => 1,
);

has event_log_level => (
    isa => LogLevel,
    is => 'ro',
);

sub some_event_happened {
  my ($self, $event) = @_;
  $self->logger->log( level => $self->event_log_level, message => "$event happened");
}

my $obj1 = MyFoos->new(
  event_log_level => 'debug',
  logger => [ ['Screen', min_level => 'notice' ] ]
);

## or

my $obj2 = MyFoos->new(
  event_log_level => 'warning',
  logger => { outputs => [ ['Screen', min_level => 'debug' ] ] }
);

$obj1->some_event_happened('zoom'); #nothing prints
$obj2->some_event_happened('zoom'); # 'zoom happened' prints

DESCRIPTION

This module provides Moose TypeConstraints that are believed to be useful when working with Log::Dispatch;

AVAILABLE CONSTRAINTS

Logger

Class type for 'Log::Dispatch' optional coercion will turn dereference a hash reference and pass it to 'new' or treat an array reference as a list of outputs.

LogLevel

A subtype of 'Str', this should be a string that is a valid Log::Dispatch log level like: 0, 1, 2 ,3 ,4 ,5 ,6 ,7, info, debug, notice, warn, warning, err, error, crit, critical, alert, emerg, and emergency

AUTHOR

Guillermo Roditi (groditi) <groditi@cpan.org>

COPYRIGHT AND LICENSE

Copyright (c) 2010 Guillermo Roditi. This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.