RequestLoggerMiddleware   A
last analyzed

Complexity

Total Complexity 2

Size/Duplication

Total Lines 23
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

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

2 Methods

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