The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Object::Remote::Logging::Logger - Format and output a log message

SYNOPSIS

  use Object::Remote::Logging::Logger;
  use Object::Remote::Logging qw( router arg_levels );

  my $app_output = Object::Remote::Logging::Logger->new(
    level_names => arg_levels, format => '%t %s',
    min_level => 'verbose', max_level => 'info',
  );

  #Selector method can return 0 or more logger
  #objects that will receive the messages
  my $selector = sub {
    my ($generating_package, $metadata) = @_;
    return unless $metadata->{exporter} eq 'App::Logging::Subclass';
    return $app_output;
  };

  #true value as second argument causes the selector
  #to be stored with a weak reference
  router->connect($selector, 1);

  #disconnect the selector from the router
  undef($selector);

  #router will hold this logger forever
  #and send it all log messages
  router->connect(Object::Remote::Logging::Logger->new(
    level_names => arg_levels, format => '%s at %f line %i, log level: %l'
    min_level => 'warn', max_level => 'error',
  ));

DESCRIPTION

This class receives log messages from an instance of Object::Remote::Logging::Router, formats them according to configuration, and then outputs them to STDERR. In between the router and the logger is a selector method which inspects the log message metadata and can return 0 or more loggers that should receive the log message.

USAGE

A logger object receives the log messages that are generated and converts them to formatted log entries then displays them to the end user. Each logger has a set of active log levels and will only output a log entry if the log message is at an active log level.

To gain access to the stream of log messages a connection is made to the log router. A logger can directly connect to the router and receive an unfiltered stream of log messages or a selector closure can be used instead. The selector will be executed for each log message with the message metadata and returns a list of 0 or more loggers that should receive the log message. When the selector is executed the first argument is the name of the package that generated the log message and the second argument is a hash reference containing the message metadata.

METADATA

The message metadata is a hash reference with the following keys:

message_level

Name of the log level of the message.

exporter

Package name of the logging API that was used to generate the log message.

caller_package

Name of the package that generated the log message.

method

Name of the method the message was generated inside of.

timestamp

Unix time of the message generation.

pid

Process id of the Perl interpreter the message was generated in.

hostname

Hostname of the system where the message was generated.

filename

Name of the file the message was generated in.

line

Line of the source file the message was generated at.

object_remote

This is a reference to another hash that contains the Object::Remote specific information. The keys are

connection_id

If the log message was generated on a remote Perl interpreter then the Object::Remote::Connection id of that interpreter will be available here.

ATTRIBUTES

level_names

This is a required attribute. Must be an array ref with the list of log level names in it. The list must be ordered with the lowest level as element 0 and the highest level as the last element. There is no default value.

min_level

The lowest log level that will be output by the logger. There is no default value.

max_level

The highest log level that will be output by the logger. The default value is the highest level present in level_names.

format

The printf style format string to use when rendering the log message. The following sequences are significant:

%l

Level name that the log message was generated at.

%s

Log message rendered into a string with a leading space before any additional lines in a multiple line message.

%t

Time the log message was generated rendered into a string. The time value is taken from the Perl interpreter that generated the log message; it is not the time that the logger received the log message on the local interpreter if the log message was forwarded.

%r

Object::Remote connection information rendered into a string.

%c

Package name of the logging API that was used to generate the log message.

%p

Name of the package that generated the log message.

%m

Method name that generated the log message.

%f

Filename that the log message was generated in.

%i

Line number the log message was generated at.

%h

Hostname the log message was generated on.

%P

Process id of the Perl interpreter that generated the log message.

%%

A literal %.

%n

A newline.