Last active
July 14, 2018 03:18
-
-
Save xxRockOnxx/bc39d6b6fce05b79b29c21905596c01e to your computer and use it in GitHub Desktop.
[Laravel] Custom Error Page based on route (Public and Admin error page)
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<?php | |
namespace App\Exceptions; | |
use Exception; | |
use Illuminate\Auth\AuthenticationException; | |
// Don't forget to add this line as it is used by renderHttpException() | |
use Symfony\Component\HttpKernel\Exception\HttpException; | |
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 $exception | |
* @return void | |
*/ | |
public function report(Exception $exception) | |
{ | |
parent::report($exception); | |
} | |
/** | |
* Render an exception into an HTTP response. | |
* | |
* @param \Illuminate\Http\Request $request | |
* @param \Exception $exception | |
* @return \Illuminate\Http\Response | |
*/ | |
public function render($request, Exception $exception) | |
{ | |
return 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('login'); | |
} | |
/** | |
* Override default method. | |
* To have separate error page for admin and public area. | |
*/ | |
protected function renderHttpException(HttpException $e) | |
{ | |
$status = $e->getStatusCode(); | |
if (view()->exists($this->getViewName($status))) { | |
return response()->view($this->getViewName($status), ['exception' => $e], $status, $e->getHeaders()); | |
} else { | |
return $this->convertExceptionToResponse($e); | |
} | |
} | |
/** | |
* Determine what view to show based on route | |
* | |
* @param int $status | |
* @return string | |
*/ | |
protected function getViewName($status) | |
{ | |
if (request()->is('admin/*')) { | |
return "errors.admin.{$status}"; | |
} | |
return "errors.{$status}"; | |
} | |
} |
Thank you.
This is very helpful !
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Thank you verry much !