ExceptionLoggerMiddleware::__construct()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

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 0
cts 2
cp 0
crap 2
rs 10
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
use Throwable;
14
use function json_encode;
15
use function React\Promise\resolve;
16
17
use const JSON_THROW_ON_ERROR;
18
19
class ExceptionLoggerMiddleware implements MiddlewareInterface
20
{
21
    private LoggerInterface $logger;
22
23
    public function __construct(LoggerInterface $logger)
24
    {
25
        $this->logger = $logger;
26
    }
27
28
    public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
29
    {
30
31
        return new PromiseResponse(resolve($request)
32
            ->then(function (ServerRequestInterface $request) use ($handler) {
33
                try {
34
                    return $handler->handle($request);
35
                } catch (Throwable $exception) {
36
                    $this->logger->error(json_encode([
37
                        'message' => $exception->getMessage(),
38
                        'code' => $exception->getCode(),
39
                        'file' => $exception->getFile(),
40
                        'line' => $exception->getLine()
41
                    ], JSON_THROW_ON_ERROR));
42
43
                    throw $exception;
44
                }
45
            }));
46
    }
47
}
48