NAME
Log::Log4perl::Appender::DBIx::Class - appender for DBIx::Class
SYNOPSIS
my $dbic_appender = Log::Log4perl::Appender->new(
'Log::Log4perl::Appender::DBIx::Class',
schema => $schema,
class => 'Message',
);
$log->add_appender($dbic_appender);
$log->error('Hello!');
DESCRIPTION
This is a specialized Log4perl appender that allows you to log to with DBIx::Class. Each appender can use a different (or the same) class and each column is configurable.
PARAMETERS
These can be supplied to Appender's new
method.
- schema
-
The schema object or class to use. If a class is passed instead of an object, connect will be called with the connect_info passes as connection args.
- class
-
The resultset class to use for logging. Defaults to 'Log'.
- category_column
-
The column in which to store the Log4perl category. Defaults to 'category'.
- connect_info
-
Argument passed to connect if an unconnected schema was passed.
- level_column
-
The column in which to store the Log4perl level. Defaults to 'level'.
- message_column
-
The column in which to store the Log4perl message. Defaults to 'message'. In case you are wondering (I was), this column WILL received the formatted message as defined by the appender's layout.
- other_columns
-
This parameter allows you to pass in an arrayref of arbitrary column names. At the time the row is created, this arrayref will be iterated over and any column names will be set:
foreach my $col (@{ $self->{column_names}}) { $row->$col($self->{$col}); }
This allows you to specificy arbitrary options when you create the appender and have the logged in any rows created. An example is in order:
my $appender = Log::Log4perl::Appender->new( 'Log::Log4perl::Appender::DBIx::Class', schema => $schema, class => 'Message', user => 'someuser', other_columns => [qw(user)] );
This will cause any Message objects that are logged to have their
user
column set to 'someuser'.
AUTHOR
Cory G Watson <gphat@cpan.org>
CONTRIBUTORS
Arthur Axel "fREW" Schmidt
SEE ALSO
LICENSE
This library is free software, you can redistribute it and/or modify it under the same terms as Perl itself.