Group
Extension

Lemonldap-NG-Common/lib/Lemonldap/NG/Common/AuditLogger/UserLoggerJSON.pm

package Lemonldap::NG::Common::AuditLogger::UserLoggerJSON;

use strict;
use JSON;
use Scalar::Util qw(weaken);

our $VERSION = '2.21.0';

sub new {
    my ( $class, $psgi_or_handler ) = @_;
    my $self = bless {}, $class;

    $self->{userLogger} = $psgi_or_handler->userLogger
      or die 'Missing userLogger';
    weaken $self->{userLogger};
    my $json = JSON->new->canonical;
    $self->{encode} = sub { $json->encode(@_) };
    return $self;
}

sub log {
    my ( $self, $req, %fields ) = @_;

    my $message = $fields{message};
    foreach ( keys %fields ) {
        delete $fields{$_} if ref( $fields{$_} );
    }
    $fields{remote_addr} = $req->address;
    $self->{userLogger}->notice( $self->{encode}->( \%fields ) );
}

1;


Powered by Groonga
Maintained by Kenichi Ishigaki <ishigaki@cpan.org>. If you find anything, submit it on GitHub.