Adicionando um CustomHandler para ser utilizado nas aplicações
Esse custom handler permite capturar corretamente exceções não tratadas no código.production
parent
e12ca5942d
commit
e7efe707a6
@ -0,0 +1,64 @@
|
||||
<?php
|
||||
|
||||
namespace Ae3\LaravelLogsLayer\app\Exceptions;
|
||||
|
||||
use Ae3\LaravelLogsLayer\app\Enums\LogsLevelsEnum;
|
||||
use Exception;
|
||||
use Ae3\LaravelLogsLayer\app\Traits\LogTrait;
|
||||
use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Http\Response;
|
||||
|
||||
class CustomExceptionHandler extends ExceptionHandler
|
||||
{
|
||||
use LogTrait;
|
||||
|
||||
/**
|
||||
* A list of the inputs that are never flashed for validation exceptions.
|
||||
*
|
||||
* @var array
|
||||
*/
|
||||
protected $dontFlash = [
|
||||
'password',
|
||||
'password_confirmation',
|
||||
];
|
||||
|
||||
/**
|
||||
* Report or log an exception.
|
||||
*
|
||||
* @param Exception $exception
|
||||
* @return void
|
||||
* @throws InvalidArgumentException
|
||||
*/
|
||||
public function report(Exception $exception)
|
||||
{
|
||||
$level = $this->getExceptionLevel($exception);
|
||||
$this->logException(__METHOD__, $exception, $level);
|
||||
}
|
||||
|
||||
/**
|
||||
* Render an exception into an HTTP response.
|
||||
*
|
||||
* @param Request $request
|
||||
* @param Exception $exception
|
||||
* @return Response
|
||||
*/
|
||||
public function render($request, Exception $exception): Response
|
||||
{
|
||||
return parent::render($request, $exception);
|
||||
}
|
||||
|
||||
/**
|
||||
* @param Exception $exception
|
||||
* @return string
|
||||
*/
|
||||
protected function getExceptionLevel(Exception $exception): string
|
||||
{
|
||||
if (method_exists($exception, 'getLevel')) {
|
||||
return mb_strtolower($exception->getLevel());
|
||||
}
|
||||
|
||||
return LogsLevelsEnum::ERROR;
|
||||
}
|
||||
|
||||
}
|
Loading…
Reference in New Issue