NAME
Net::DRI::Logging - Logging Operations for Net::DRI
SYNOPSIS
This module is never used directly, only its subclasses are used. See the subclasses documentation: Net::DRI::Logging::Files, Net::DRI::Logging::Null and Net::DRI::Logging::Stderr. See also Net::DRI documentation and its logging()
method.
DESCRIPTION
This is the superclass of all logging modules (under the Net::DRI::Logging::* namespace).
EXAMPLES
See Net::DRI documentation.
SUBROUTINES/METHODS
This is mostly a pure virtual superclass. All subclasses should have the following methods:
- new()
-
a ref hash is passed with some keys ; besides keys specifically related to the logging class used, some keys are (or should be) understood by all clases.
They are:
- level
-
current level of logging (no messages below this level would be dumped), between: debug info notice warning error critical alert emergency ; default: warning
It can be changed anytime later by using the level() method
- xml_indent
-
0 or 1 depending if you want your XML strings to be dumped as a long line (0) or indented for humans (1) ; default: 0
- encoding
-
if needed, name of encoding to use to convert data stream ; default: UTF-8
- sanitize_data
-
an optional ref hash to know which part of logged data should be replaced to ensure confidentiality; for now it works only for EPP, with the hash key "session_password" and a true value, then content of <pw> and <newPW> are replaced by a string of * in logging data
- name()
-
returns the name as string of the logging modules
- setup_channel(SOURCE,TYPE,DATA)
-
prepare for a new channel of data comming from SOURCE (package name), of TYPE ; DATA is a ref hash of additional parameter, such as filenames, etc.
- output(LEVEL,TYPE,DATA1,DATA2,...)
-
add data to channel type TYPE at level LEVEL ('debug', 'info', 'notice', etc.) ; DATA is a ref hash with all data to log or a simple string (the message) ; the logging module should know what to do with it and how to format it (which may depend on the TYPE attribute, which itself is tied to the SOURCE attribute of
setup_channel()
).
DIAGNOSTICS
None.
CONFIGURATION AND ENVIRONMENT
See the new()
method.
DEPENDENCIES
This module has to be used inside the Net::DRI framework and needs the following components:
INCOMPATIBILITIES
None.
BUGS AND LIMITATIONS
No known bugs. Please report problems to author (see below) or use CPAN RT system. Patches are welcome.
The interface could be later changed to suit Log::Log4Perl or other Perl standard logging modules, if needed.
Other subclasses should be created to cater for other logging destinations (such as a RDBMS).
Net::DRI expects these logging modules to be non-blocking and returning immediately.
This logging framework is currently only used by Net::DRI::Transport::Socket, it should get applied to other transports and other internal parts of Net::DRI.
When LocalStorage do appear inside Net::DRI, logging should probably use it (TODO).
SUPPORT
For now, support questions should be sent to:
<netdri@dotandco.com>
Please also see the SUPPORT file in the distribution.
SEE ALSO
<http://www.dotandco.com/services/software/Net-DRI/>
AUTHOR
Patrick Mevzek, <netdri@dotandco.com>
LICENSE AND COPYRIGHT
Copyright (c) 2009-2010,2012 Patrick Mevzek <netdri@dotandco.com>. All rights reserved.
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
See the LICENSE file that comes with this distribution for more details.