Skip to content

Instantly share code, notes, and snippets.

@dvigne
Created March 11, 2017 17:10
Show Gist options
  • Save dvigne/a8d3de8a2a64e887d30dcb8bf9dddd5c to your computer and use it in GitHub Desktop.
Save dvigne/a8d3de8a2a64e887d30dcb8bf9dddd5c to your computer and use it in GitHub Desktop.
Log Errors To Rollbar and Laravel.log File
<?php
namespace App\Exceptions;
use Exception;
use Illuminate\Auth\AuthenticationException;
use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
use Auth;
use Log;
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,
\Symfony\Component\Console\Exception\CommandNotFoundException::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)
{
if($this->shouldReport($exception)) {
if (Auth::check()) {
Log::error($exception, [
'person' => ['id' => Auth::user()->id, 'username' => Auth::user()->first . " " . Auth::user()->last, 'email' => Auth::user()->email]
]);
}
else {
Log::error($exception);
}
}
return 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');
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment