NAME Mojolicious::Plugin::Log::Any - Use other loggers in a Mojolicious application SYNOPSIS package MyApp; use Mojo::Base 'Mojolicious'; sub startup { my $self = shift; # Log::Any (default) use Log::Any::Adapter {category => 'MyApp', message_separator => ' '}, 'Syslog'; $self->plugin('Log::Any'); # Log::Contextual use Log::Contextual::WarnLogger; use Log::Contextual -logger => Log::Contextual::WarnLogger->new({env_prefix => 'MYAPP'}); $self->plugin('Log::Any' => {logger => 'Log::Contextual}); # Log::Dispatch use Log::Dispatch; my $logger = Log::Dispatch->new(outputs => ['File::Locked', min_level => 'warning', filename => '/path/to/file.log', mode => 'append', newline => 1, callbacks => sub { my %p = @_; '[' . localtime() . '] ' . $p{message} }, ]); $self->plugin('Log::Any' => {logger => $logger}); # Log::Dispatchouli use Log::Dispatchouli; my $logger = Log::Dispatchouli->new({ident => 'MyApp', facility => 'daemon', to_file => 1}); $self->plugin('Log::Any' => {logger => $logger}); # Log::Log4perl use Log::Log4perl; Log::Log4perl->init($self->home->child('log.conf')->to_string); $self->plugin('Log::Any' => {logger => 'Log::Log4perl'}); } # or in a Mojolicious::Lite app use Mojolicious::Lite; use Log::Any::Adapter {category => 'Mojolicious::Lite'}, File => app->home->child('myapp.log'), log_level => 'info'; plugin 'Log::Any'; DESCRIPTION Mojolicious::Plugin::Log::Any is a Mojolicious plugin that redirects the application logger to pass its log messages to an external logging framework using "attach_logger" in Mojo::Log::Role::AttachLogger. By default, Log::Any is used, but a different framework or object may be specified. For Log::Any or Log::Log4perl, log messages are dispatched with a category of the application class name, which is Mojolicious::Lite for lite applications. The default behavior of the Mojo::Log object to filter messages by level, keep history, prepend a timestamp, and write log messages to a file or STDERR will be suppressed, by setting the application log level to debug (the lowest level) and removing the default "message" in Mojo::Log handler. It is expected that the logging framework output handler will be configured to handle these details as necessary. If you want to customize how the logging framework is attached, use Mojo::Log::Role::AttachLogger directly. METHODS Mojolicious::Plugin::Log::Any inherits all methods from Mojolicious::Plugin and implements the following new ones. register $plugin->register(Mojolicious->new); $plugin->register(Mojolicious->new, {logger => $logger}); Register logger in Mojolicious application. Takes the following options: logger Logging framework or object to pass log messages to, of a type recognized by "attach_logger" in Mojo::Log::Role::AttachLogger. Defaults to Log::Any. category Passed through to "attach_logger" in Mojo::Log::Role::AttachLogger. Defaults to the application name. prepend_level Passed through to "attach_logger" in Mojo::Log::Role::AttachLogger. message_separator Passed through to "attach_logger" in Mojo::Log::Role::AttachLogger. BUGS Report any issues on the public bugtracker. AUTHOR Dan Book <dbook@cpan.org> COPYRIGHT AND LICENSE This software is Copyright (c) 2017 by Dan Book. This is free software, licensed under: The Artistic License 2.0 (GPL Compatible) SEE ALSO Mojo::Log, Mojo::Log::Role::AttachLogger