Passed
Push — master ( b3f945...fcf496 )
by Jelmer
04:58
created

ErrorHandlerMiddleware   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 28
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 4

Test Coverage

Coverage 100%

Importance

Changes 0
Metric Value
wmc 3
lcom 1
cbo 4
dl 0
loc 28
ccs 12
cts 12
cp 1
rs 10
c 0
b 0
f 0

2 Methods

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