2019-05-20 07:37:41 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace App\Exceptions;
|
|
|
|
|
2020-10-12 08:05:33 +02:00
|
|
|
use Throwable;
|
2020-01-26 16:04:26 +01:00
|
|
|
use Illuminate\Http\Response;
|
2019-05-20 07:37:41 +02:00
|
|
|
use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
|
2019-05-24 14:44:41 +02:00
|
|
|
use Illuminate\Database\Eloquent\ModelNotFoundException as ModelNotFoundException;
|
2019-05-26 16:44:46 +02:00
|
|
|
use Illuminate\Validation\ValidationException as ValidationException;
|
|
|
|
use Symfony\Component\HttpKernel\Exception\HttpException;
|
2019-05-20 07:37:41 +02:00
|
|
|
|
|
|
|
class Handler extends ExceptionHandler
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* A list of the exception types that are not reported.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $dontReport = [
|
|
|
|
//
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A list of the inputs that are never flashed for validation exceptions.
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $dontFlash = [
|
|
|
|
'password',
|
|
|
|
'password_confirmation',
|
|
|
|
];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Report or log an exception.
|
|
|
|
*
|
2020-10-12 08:05:33 +02:00
|
|
|
* @param \Throwable $exception
|
2019-05-20 07:37:41 +02:00
|
|
|
* @return void
|
|
|
|
*/
|
2020-10-12 08:05:33 +02:00
|
|
|
public function report(Throwable $exception)
|
2019-05-20 07:37:41 +02:00
|
|
|
{
|
|
|
|
parent::report($exception);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Render an exception into an HTTP response.
|
|
|
|
*
|
|
|
|
* @param \Illuminate\Http\Request $request
|
2020-10-12 08:05:33 +02:00
|
|
|
* @param \Throwable $exception
|
2019-05-20 07:37:41 +02:00
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
*/
|
2020-10-12 08:05:33 +02:00
|
|
|
public function render($request, Throwable $exception)
|
2020-01-27 21:13:21 +01:00
|
|
|
{
|
2020-01-27 16:53:26 +01:00
|
|
|
if ( $request->wantsJson() ) {
|
|
|
|
|
|
|
|
return $this->handleApiException($request, $exception);
|
|
|
|
|
|
|
|
} else {
|
2019-05-26 16:44:46 +02:00
|
|
|
|
2020-01-27 16:53:26 +01:00
|
|
|
return parent::render($request, $exception);
|
2019-05-24 14:44:41 +02:00
|
|
|
}
|
2019-05-20 07:37:41 +02:00
|
|
|
}
|
2019-05-26 16:44:46 +02:00
|
|
|
|
2020-01-27 16:53:26 +01:00
|
|
|
|
2019-05-26 16:44:46 +02:00
|
|
|
/**
|
2020-01-27 16:53:26 +01:00
|
|
|
* Render an exception into an HTTP response.
|
2019-05-26 16:44:46 +02:00
|
|
|
*
|
2020-01-27 16:53:26 +01:00
|
|
|
* @param \Illuminate\Http\Request $request
|
2020-10-12 08:05:33 +02:00
|
|
|
* @param \Throwable $exception
|
2020-01-27 16:53:26 +01:00
|
|
|
* @return \Illuminate\Http\JsonResponse
|
2019-05-26 16:44:46 +02:00
|
|
|
*/
|
2020-10-12 08:05:33 +02:00
|
|
|
private function handleApiException($request, Throwable $exception)
|
2019-05-26 16:44:46 +02:00
|
|
|
{
|
2020-01-27 21:13:21 +01:00
|
|
|
$debug = [
|
|
|
|
'exception' => get_class($exception),
|
|
|
|
'trace' => $exception->getTrace(),
|
|
|
|
];
|
|
|
|
|
2020-01-27 16:53:26 +01:00
|
|
|
$exception = $this->prepareException($exception);
|
|
|
|
|
|
|
|
if ($exception instanceof \Illuminate\Http\Exception\HttpResponseException) {
|
|
|
|
$exception = $exception->getResponse();
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($exception instanceof \Illuminate\Auth\AuthenticationException) {
|
|
|
|
$exception = $this->unauthenticated($request, $exception);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($exception instanceof \Illuminate\Validation\ValidationException) {
|
|
|
|
$exception = $this->convertValidationExceptionToResponse($exception, $request);
|
|
|
|
}
|
|
|
|
|
2020-01-27 21:13:21 +01:00
|
|
|
return $this->customApiResponse($exception, $debug);
|
2020-01-27 16:53:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set a specific response payload for commons http error codes
|
|
|
|
*
|
2020-10-12 08:05:33 +02:00
|
|
|
* @param \Throwable $exception
|
2020-01-27 16:53:26 +01:00
|
|
|
* @return \Illuminate\Http\JsonResponse
|
|
|
|
*/
|
2020-01-27 21:13:21 +01:00
|
|
|
private function customApiResponse($exception, $debug)
|
2020-01-27 16:53:26 +01:00
|
|
|
{
|
2020-03-08 20:16:56 +01:00
|
|
|
$statusCode = 500;
|
|
|
|
|
2020-01-27 16:53:26 +01:00
|
|
|
if (method_exists($exception, 'getStatusCode')) {
|
|
|
|
$statusCode = $exception->getStatusCode();
|
|
|
|
}
|
|
|
|
|
|
|
|
$response = [];
|
|
|
|
$response['status_code'] = $statusCode;
|
|
|
|
|
|
|
|
switch ($statusCode) {
|
|
|
|
case 401:
|
|
|
|
$response['message'] = 'Unauthorized';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 404:
|
|
|
|
$response['message'] = 'Not Found';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 405:
|
|
|
|
$response['message'] = 'Method Not Allowed';
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 422:
|
|
|
|
$response['message'] = $exception->original['message'];
|
|
|
|
$response['errors'] = $exception->original['errors'];
|
|
|
|
break;
|
|
|
|
|
|
|
|
default:
|
2020-11-14 18:36:44 +01:00
|
|
|
$response['message'] = ($statusCode >= 500) ? 'Whoops, looks like something went wrong :(' : $exception->getMessage();
|
2020-01-27 16:53:26 +01:00
|
|
|
|
2020-03-24 13:24:33 +01:00
|
|
|
if (config('app.debug')) {
|
2020-03-04 12:37:36 +01:00
|
|
|
$response['originalMessage'] = $exception->getMessage();
|
2020-01-27 21:43:34 +01:00
|
|
|
$response['debug'] = $debug;
|
|
|
|
}
|
2020-01-27 16:53:26 +01:00
|
|
|
|
2020-01-27 21:43:34 +01:00
|
|
|
break;
|
2020-01-27 16:53:26 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return response()->json($response, $statusCode);
|
2019-05-26 16:44:46 +02:00
|
|
|
}
|
2019-05-20 07:37:41 +02:00
|
|
|
}
|