RequestLoggerMiddleware::__construct()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 1
eloc 1
c 1
b 0
f 1
nc 1
nop 1
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Antidot\Logger\Application\Http\Middleware;
6
7
use Psr\Http\Message\ResponseInterface;
8
use Psr\Http\Message\ServerRequestInterface;
9
use Psr\Http\Server\MiddlewareInterface;
10
use Psr\Http\Server\RequestHandlerInterface;
11
use Psr\Log\LoggerInterface;
12
use function get_class;
13
use function json_encode;
14
use function sprintf;
15
16
class RequestLoggerMiddleware implements MiddlewareInterface
17
{
18
    private const UNEXPECTED_REQUEST_MESSAGE = 'Unexpected error occurred during %s request message serialization.';
19
    private LoggerInterface $logger;
20
21 1
    public function __construct(LoggerInterface $logger)
22
    {
23 1
        $this->logger = $logger;
24 1
    }
25
26 1
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
27
    {
28 1
        $message = json_encode([
29 1
            'method' => $request->getMethod(),
30 1
            'target' => $request->getRequestTarget(),
31 1
            'headers' => $request->getHeaders(),
32 1
            'query-string' => $request->getQueryParams(),
33 1
            'body' => (string)$request->getBody()
34
        ]);
35
36 1
        $this->logger->debug(
37 1
            $message
38 1
                ? $message
39 1
                : sprintf(self::UNEXPECTED_REQUEST_MESSAGE, get_class($request))
40
        );
41
42 1
        return $handler->handle($request);
43
    }
44
}
45