RequestLoggerMiddleware   A
last analyzed

Complexity

Total Complexity 3

Size/Duplication

Total Lines 27
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 2
Bugs 0 Features 2
Metric Value
eloc 14
c 2
b 0
f 2
dl 0
loc 27
ccs 15
cts 15
cp 1
rs 10
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A process() 0 17 2
A __construct() 0 3 1
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