Code Coverage |
||||||||||
Lines |
Functions and Methods |
Classes and Traits |
||||||||
Total | |
100.00% |
27 / 27 |
|
100.00% |
4 / 4 |
CRAP | |
100.00% |
1 / 1 |
Legacy | |
100.00% |
27 / 27 |
|
100.00% |
4 / 4 |
12 | |
100.00% |
1 / 1 |
render | |
100.00% |
3 / 3 |
|
100.00% |
1 / 1 |
2 | |||
report | |
100.00% |
21 / 21 |
|
100.00% |
1 / 1 |
6 | |||
setLogger | |
100.00% |
1 / 1 |
|
100.00% |
1 / 1 |
1 | |||
stripBasePath | |
100.00% |
2 / 2 |
|
100.00% |
1 / 1 |
1 | |||
isCli | n/a |
0 / 0 |
n/a |
0 / 0 |
2 |
1 | <?php |
2 | |
3 | declare(strict_types=1); |
4 | |
5 | namespace Engelsystem\Exceptions\Handlers; |
6 | |
7 | use Engelsystem\Http\Request; |
8 | use ErrorException; |
9 | use Psr\Log\LoggerInterface; |
10 | use Psr\Log\LogLevel; |
11 | use Throwable; |
12 | |
13 | class Legacy implements HandlerInterface |
14 | { |
15 | protected ?LoggerInterface $log = null; |
16 | |
17 | public function render(Request $request, Throwable $e): void |
18 | { |
19 | if ($this->isCli()) { |
20 | return; |
21 | } |
22 | |
23 | echo 'An <del>un</del>expected error occurred. A team of untrained monkeys has been dispatched to fix it.'; |
24 | } |
25 | |
26 | public function report(Throwable $e): void |
27 | { |
28 | $previous = $e->getPrevious(); |
29 | error_log(sprintf( |
30 | '%s: Code: %s, Message: %s, File: %s:%u, Previous: %s, Trace: %s', |
31 | get_class($e), |
32 | $e->getCode(), |
33 | $e->getMessage(), |
34 | $this->stripBasePath($e->getFile()), |
35 | $e->getLine(), |
36 | $previous ? $previous->getMessage() : 'None', |
37 | json_encode($e->getTrace()) |
38 | )); |
39 | |
40 | if (is_null($this->log)) { |
41 | return; |
42 | } |
43 | |
44 | $errorLevels = E_ERROR | E_RECOVERABLE_ERROR | E_PARSE | E_CORE_ERROR | E_COMPILE_ERROR | E_USER_ERROR; |
45 | $logAsError = !$e instanceof ErrorException || $e->getSeverity() & $errorLevels; |
46 | try { |
47 | $this->log->log( |
48 | $logAsError ? LogLevel::CRITICAL : LogLevel::WARNING, |
49 | '', |
50 | ['exception' => $e], |
51 | ); |
52 | } catch (Throwable) { |
53 | } |
54 | } |
55 | |
56 | public function setLogger(LoggerInterface $logger): void |
57 | { |
58 | $this->log = $logger; |
59 | } |
60 | |
61 | protected function stripBasePath(string $path): string |
62 | { |
63 | $basePath = realpath(__DIR__ . '/../../..') . '/'; |
64 | return str_replace($basePath, '', $path); |
65 | } |
66 | |
67 | /** |
68 | * Test if is called from cli |
69 | * @codeCoverageIgnore |
70 | */ |
71 | protected function isCli(): bool |
72 | { |
73 | return PHP_SAPI == 'cli' || PHP_SAPI == 'phpdbg'; |
74 | } |
75 | } |