81 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			81 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Pterodactyl\Exceptions;
 | |
| 
 | |
| use Log;
 | |
| 
 | |
| use Exception;
 | |
| use DisplayException;
 | |
| use DisplayValidationException;
 | |
| use AccountNotFoundException;
 | |
| 
 | |
| use Illuminate\Auth\AuthenticationException;
 | |
| use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
 | |
| 
 | |
| class Handler extends ExceptionHandler
 | |
| {
 | |
|     /**
 | |
|      * A list of the exception types that should not be reported.
 | |
|      *
 | |
|      * @var array
 | |
|      */
 | |
|     protected $dontReport = [
 | |
|         \Illuminate\Auth\AuthenticationException::class,
 | |
|         \Illuminate\Auth\Access\AuthorizationException::class,
 | |
|         \Symfony\Component\HttpKernel\Exception\HttpException::class,
 | |
|         \Illuminate\Database\Eloquent\ModelNotFoundException::class,
 | |
|         \Illuminate\Session\TokenMismatchException::class,
 | |
|         \Illuminate\Validation\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 $exception)
 | |
|     {
 | |
|         return parent::report($exception);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Render an exception into an HTTP response.
 | |
|      *
 | |
|      * @param  \Illuminate\Http\Request  $request
 | |
|      * @param  \Exception  $e
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     public function render($request, Exception $exception)
 | |
|     {
 | |
|         if ($request->isXmlHttpRequest() || $request->ajax() || $request->is('remote/*')) {
 | |
|             $response = response()->json([
 | |
|                 'error' => ($exception instanceof DisplayException) ? $exception->getMessage() : 'An unhandled error occured while attempting to process this request.'
 | |
|             ], 500);
 | |
| 
 | |
|             // parent::render() will log it, we are bypassing it in this case.
 | |
|             Log::error($exception);
 | |
|         }
 | |
| 
 | |
|         return (isset($response)) ? $response : parent::render($request, $exception);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Convert an authentication exception into an unauthenticated response.
 | |
|      *
 | |
|      * @param  \Illuminate\Http\Request  $request
 | |
|      * @param  \Illuminate\Auth\AuthenticationException  $exception
 | |
|      * @return \Illuminate\Http\Response
 | |
|      */
 | |
|     protected function unauthenticated($request, AuthenticationException $exception)
 | |
|     {
 | |
|         if ($request->expectsJson()) {
 | |
|             return response()->json(['error' => 'Unauthenticated.'], 401);
 | |
|         }
 | |
|         return redirect()->guest('/auth/login');
 | |
|     }
 | |
| 
 | |
| }
 | 
