66 lines
1.7 KiB
PHP
66 lines
1.7 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace App\Exceptions;
|
||
|
|
||
|
use Exception;
|
||
|
use Illuminate\Validation\ValidationException;
|
||
|
use Illuminate\Auth\Access\AuthorizationException;
|
||
|
use Illuminate\Database\Eloquent\ModelNotFoundException;
|
||
|
use Laravel\Lumen\Exceptions\Handler as ExceptionHandler;
|
||
|
use Symfony\Component\HttpKernel\Exception\HttpException;
|
||
|
|
||
|
class Handler extends ExceptionHandler
|
||
|
{
|
||
|
/**
|
||
|
* A list of the exception types that should not be reported.
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
protected $dontReport = [
|
||
|
AuthorizationException::class,
|
||
|
HttpException::class,
|
||
|
ModelNotFoundException::class,
|
||
|
ValidationException::class
|
||
|
];
|
||
|
|
||
|
/**
|
||
|
* Report or log an exception.
|
||
|
*
|
||
|
* This is a great spot to send exceptions to Sentry, Bugsnag, etc.
|
||
|
*
|
||
|
* @param \Exception $e
|
||
|
* @return void
|
||
|
*/
|
||
|
public function report(Exception $e)
|
||
|
{
|
||
|
parent::report($e);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Render an exception into an HTTP response.
|
||
|
*
|
||
|
* @param \Illuminate\Http\Request $request
|
||
|
* @param \Exception $e
|
||
|
* @return \Illuminate\Http\Response
|
||
|
*/
|
||
|
public function render($request, Exception $e)
|
||
|
{
|
||
|
if (env('APP_DEBUG') === true) {
|
||
|
return parent::render($request, $e);
|
||
|
} else {
|
||
|
$statusCode = 500;
|
||
|
if ($e instanceof ModelNotFoundException) {
|
||
|
$statusCode = 404;
|
||
|
} elseif ($e instanceof HttpException) {
|
||
|
$statusCode = $e->getStatusCode();
|
||
|
}
|
||
|
return response()->json(array(
|
||
|
'errors' => array(
|
||
|
$e->getMessage(),
|
||
|
)
|
||
|
), $statusCode);
|
||
|
}
|
||
|
|
||
|
}
|
||
|
}
|