NAME
Plack::Middleware::PeriAHS::LogAccess - Log request
VERSION
This document describes version 0.61 of Plack::Middleware::PeriAHS::LogAccess (from Perl distribution Perinci-Access-HTTP-Server), released on 2017-07-10.
SYNOPSIS
# In app.psgi
use Plack::Builder;
builder {
enable "PeriAHS::LogAccess", dest => "/path/to/api-access.log";
}
DESCRIPTION
This middleware forwards the request to given app and logs request. Only requests which have executed action (has $env->{'periahs.start_action_time'} set) will be logged.
The log looks like this (all in one line):
[20/Aug/2011:22:05:38 +0000] [127.0.0.1] [tcp:80] [libby] call
/MyModule/my_func [args 14 {"name":"val"}] [resp 12 [200,"OK",1]]
2.123ms 5.947ms
The second last field ("2.123ms") is time spent executing the Riap action (in this case, calling the subroutine), and the last field ("5.947ms") is time spent for the whole HTTP request (from client connect until HTTP response is sent).
This middleware should be put outermost (first) to be able to record request starting time more accurately.
CONFIGURATION
dest => STR or OBJ
Either a string (path to log file) or an object which support <syswrite()> (like IO::Handle) or
write()
(like IO::Handle or File::Write::Rotate) orlog
(like Log::Dispatch::Output). If object supportslog
, it will be called like a Log::Dispatch::Output object, i.e. $obj->log(level=>'info', message=>"Log line ...\n"). Otherwise it will be called with the log line as the single argument.max_args_len => INT (default 1000)
Maximum number of characters of args to log. Args will be JSON-encoded and truncated to this value if too long. In the log file it will be printed as:
[args <LENGTH> <ARGS>]
max_resp_len => INT (default 1000)
Maximum number of characters of sub response to log. Response will be JSON-encoded and truncated to this value if too long. In the log file it will be printed as:
[resp <LENGTH> <ARGS>]
HOMEPAGE
Please visit the project's homepage at https://metacpan.org/release/Perinci-Access-HTTP-Server.
SOURCE
Source repository is at https://github.com/perlancar/perl-Perinci-Access-HTTP-Server.
BUGS
Please report any bugs or feature requests on the bugtracker website https://rt.cpan.org/Public/Dist/Display.html?Name=Perinci-Access-HTTP-Server
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
AUTHOR
perlancar <perlancar@cpan.org>
COPYRIGHT AND LICENSE
This software is copyright (c) 2017, 2015, 2014, 2013, 2012, 2011 by perlancar@cpan.org.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.