RequestLoggerMiddleware::process()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 14
Code Lines 11

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

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