NAME
DBIx::Class::QueryLog::Tee - Log to multiple QueryLogs at a time
VERSION
version 0.001000
SYNOPSIS
my $ql = DBIx::Class:::QueryLog->new;
$schema->storage->debugobj(
DBIx::Class:::QueryLog::Tee->new(
loggers => {
'1-original' => $schema->storage->debugobj,
'2-current' => $ql,
},
),
);
Now all queries should be logged to both loggers.
DESCRIPTION
Sometimes you want to see what queries you are running without having to look at database logs or the console that your app is running on (if it even is running on a console.) But what if you want to add tooling to, eg, count queries per web request, and also see the queries being run on the console? This module solves that problem.
Fundamentally it has a HashRef of logger objects, and passes all of the logging commands through, in the order of the keys. So if you need a logger to be first, make sure it has the "earliest" key.
METHODS
new
Optionally takes a loggers
hashref. The values must each be a "LOGGER".
add_logger
Takes a name and a "LOGGER". Throws an exception if there is already a logger with the passed name.
remove_logger
Takes a name. Throws an exception if there is no logger with the passed name.
replace_logger
Takes a name and a "LOGGER". Will replace a logger with the same name, or just add it if there wasn't already one there.
LOGGER
A logger is defined as an object that has the following methods:
txn_begin txn_commit txn_rollback
svp_begin svp_release svp_rollback
query_start query_end
AUTHOR
Arthur Axel "fREW" Schmidt <frioux+cpan@gmail.com>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Arthur Axel "fREW" Schmidt.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.