From 30fcbca159e7650a9a365d07d6f050961ae72e5d Mon Sep 17 00:00:00 2001 From: Mohammad Alavi Date: Fri, 15 Apr 2022 12:08:27 +0430 Subject: [PATCH] feat: improve exception handling --- .../Exceptions/Handlers/ExceptionsHandler.php | 50 +++++++++++++------ 1 file changed, 34 insertions(+), 16 deletions(-) diff --git a/app/Ship/Exceptions/Handlers/ExceptionsHandler.php b/app/Ship/Exceptions/Handlers/ExceptionsHandler.php index 7ad18cff6..0835b7103 100644 --- a/app/Ship/Exceptions/Handlers/ExceptionsHandler.php +++ b/app/Ship/Exceptions/Handlers/ExceptionsHandler.php @@ -3,7 +3,12 @@ namespace App\Ship\Exceptions\Handlers; use Apiato\Core\Abstracts\Exceptions\Exception as CoreException; +use Apiato\Core\Exceptions\AuthenticationException; use Apiato\Core\Exceptions\Handlers\ExceptionsHandler as CoreExceptionsHandler; +use App\Ship\Exceptions\NotFoundException; +use Illuminate\Http\JsonResponse; +use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException; +use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; use Throwable; /** @@ -44,23 +49,36 @@ public function register(): void }); $this->renderable(function (CoreException $e) { - if (config('app.debug')) { - $response = [ - 'message' => $e->getMessage(), - 'errors' => $e->getErrors(), - 'exception' => static::class, - 'file' => $e->getFile(), - 'line' => $e->getLine(), - 'trace' => $e->getTrace(), - ]; - } else { - $response = [ - 'message' => $e->getMessage(), - 'errors' => $e->getErrors(), - ]; - } + return $this->buildResponse($e); + }); + + $this->renderable(function (NotFoundHttpException $e) { + return $this->buildResponse(new NotFoundException()); + }); - return response()->json($response, $e->getCode()); + $this->renderable(function (AccessDeniedHttpException $e) { + return $this->buildResponse(new AuthenticationException()); }); } + + private function buildResponse(CoreException $e): JsonResponse + { + if (config('app.debug')) { + $response = [ + 'message' => $e->getMessage(), + 'errors' => $e->getErrors(), + 'exception' => get_class($e), + 'file' => $e->getFile(), + 'line' => $e->getLine(), + 'trace' => $e->getTrace(), + ]; + } else { + $response = [ + 'message' => $e->getMessage(), + 'errors' => $e->getErrors(), + ]; + } + + return response()->json($response, (int)$e->getCode()); + } }