Passed
Push — master ( 473b48...eb1314 )
by Jelmer
01:55
created

ErrorHandlerMiddleware   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 22
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
eloc 13
dl 0
loc 22
ccs 11
cts 11
cp 1
rs 10
c 0
b 0
f 0
wmc 3

2 Methods

Rating   Name   Duplication   Size   Complexity  
A process() 0 11 2
A __construct() 0 4 1
1
<?php declare(strict_types = 1);
2
3
namespace jschreuder\Middle\ServerMiddleware;
4
5
use jschreuder\Middle\Controller\ControllerInterface;
6
use Psr\Http\Message\ResponseInterface;
7
use Psr\Http\Message\ServerRequestInterface;
8
use Psr\Http\Server\MiddlewareInterface;
9
use Psr\Http\Server\RequestHandlerInterface;
10
use Psr\Log\LoggerInterface;
11
12
final class ErrorHandlerMiddleware implements MiddlewareInterface
13
{
14
    private LoggerInterface $logger;
15
    private ControllerInterface $errorController;
16
17 3
    public function __construct(LoggerInterface $logger, ControllerInterface $errorController)
18
    {
19 3
        $this->logger = $logger;
20 3
        $this->errorController = $errorController;
21
    }
22
23 2
    public function process(ServerRequestInterface $request, RequestHandlerInterface $requestHandler): ResponseInterface
24
    {
25
        try {
26 2
            return $requestHandler->handle($request);
27 1
        } catch (\Throwable $exception) {
28 1
            $this->logger->alert($exception->getMessage(), [
29 1
                'line' => $exception->getLine(),
30 1
                'file' => $exception->getFile(),
31 1
                'backtrace' => $exception->getTrace()
32
            ]);
33 1
            return $this->errorController->execute($request->withAttribute('error', $exception));
34
        }
35
    }
36
}
37