package Plack::Middleware::LogDispatch; use strict; use parent qw(Plack::Middleware); use Plack::Util::Accessor qw(logger); use Carp (); sub prepare_app { my $self = shift; unless ($self->logger) { Carp::croak "logger is not defined"; } } sub call { my($self, $env) = @_; $env->{'psgix.logger'} = sub { my $args = shift; $args->{level} = 'critical' if $args->{level} eq 'fatal'; if ( ref $args->{message} && ref $args->{message} ne 'CODE' ) { $args->{message} .= q{}; } $self->logger->log(%$args); }; $self->app->($env); } 1; __END__ =head1 NAME Plack::Middleware::LogDispatch - Uses Log::Dispatch to configure logger =head1 SYNOPSIS use Log::Dispatch; my $logger = Log::Dispatch->new; $logger->add( Log::Dispatch::File->new(...) ); $logger->add( Log::Dispatch::DesktopNotification->new(...) ); builder { enable "LogDispatch", logger => $logger; $app; } # use with Log::Dispatch::Config use Log::Dispatch::Config; Log::Dispatch::Config->configure('/path/to/log.conf'); builder { enable "LogDispatch", logger => Log::Dispatch::Config->instance; ... } =head1 DESCRIPTION LogDispatch is a L component that allows you to use L to configure the logging object, C. =head1 CONFIGURATION =over 4 =item logger L object to send logs to. Required. =back =head1 AUTHOR Tatsuhiko Miyagawa =head1 SEE ALSO L L =cut