52 lines
1.3 KiB
PHP
52 lines
1.3 KiB
PHP
<?php
|
|
|
|
namespace Engelsystem\Exceptions\Handlers;
|
|
|
|
use Engelsystem\Http\Request;
|
|
use Psr\Log\LoggerInterface;
|
|
use Throwable;
|
|
|
|
class Legacy implements HandlerInterface
|
|
{
|
|
protected ?LoggerInterface $log = null;
|
|
|
|
public function render(Request $request, Throwable $e): void
|
|
{
|
|
echo 'An <del>un</del>expected error occurred. A team of untrained monkeys has been dispatched to fix it.';
|
|
}
|
|
|
|
public function report(Throwable $e): void
|
|
{
|
|
$previous = $e->getPrevious();
|
|
error_log(sprintf(
|
|
'Exception: Code: %s, Message: %s, File: %s:%u, Previous: %s, Trace: %s',
|
|
$e->getCode(),
|
|
$e->getMessage(),
|
|
$this->stripBasePath($e->getFile()),
|
|
$e->getLine(),
|
|
$previous ? $previous->getMessage() : 'None',
|
|
json_encode($e->getTrace(), PHP_SAPI == 'cli' ? JSON_PRETTY_PRINT : 0)
|
|
));
|
|
|
|
if (is_null($this->log)) {
|
|
return;
|
|
}
|
|
|
|
try {
|
|
$this->log->critical('', ['exception' => $e]);
|
|
} catch (Throwable $e) {
|
|
}
|
|
}
|
|
|
|
public function setLogger(LoggerInterface $logger): void
|
|
{
|
|
$this->log = $logger;
|
|
}
|
|
|
|
protected function stripBasePath(string $path): string
|
|
{
|
|
$basePath = realpath(__DIR__ . '/../../..') . '/';
|
|
return str_replace($basePath, '', $path);
|
|
}
|
|
}
|