Passed
Push — master ( c0f6da...b424db )
by Jelmer
04:57
created

ErrorHandlerMiddleware::process()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 13
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 8
CRAP Score 2

Importance

Changes 0
Metric Value
dl 0
loc 13
ccs 8
cts 8
cp 1
rs 9.4285
c 0
b 0
f 0
cc 2
eloc 9
nc 2
nop 2
crap 2
1
<?php declare(strict_types = 1);
2
3
namespace jschreuder\Middle;
4
5
use Psr\Http\Message\ResponseInterface;
6
use Psr\Http\Message\ServerRequestInterface;
7
use Psr\Log\LoggerInterface;
8
9
class ErrorHandlerMiddleware implements HttpMiddlewareInterface
10
{
11
    /** @var  LoggerInterface */
12
    private $logger;
13
14
    /** @var  callable */
15
    private $errorController;
16
17 3
    public function __construct(LoggerInterface $logger, callable $errorController)
18
    {
19 3
        $this->logger = $logger;
20 3
        $this->errorController = $errorController;
21 3
    }
22
23 2
    public function process(ServerRequestInterface $request, DelegateInterface $delegate) : ResponseInterface
24
    {
25
        try {
26 2
            return $delegate->next($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)($exception, $request);
34
        }
35
    }
36
}
37