This package provides single page applications with a visual representation of exceptions similar to traditional
Laravel applications. This is accomplished by temporarily storing the output of the rendered exception in a file. When
the client receives an error, you can use the included render-exception.js
service to open up an iframe to display
the rendered exception in the browser.
You can install the package via composer:
composer require stanbridge/visual-exceptions
You can publish the config file with:
php artisan vendor:publish --provider="Stanbridge\VisualException\VisualExceptionServiceProvider" --tag="config"
This is the contents of the published config file:
return [
/*
|--------------------------------------------------------------------------
| Master Switch
|--------------------------------------------------------------------------
|
| This option may be used to completely disable visual exceptions.
|
*/
'enabled' => env('VISUAL_EXCEPTIONS_ENABLED', env('APP_DEBUG')),
/*
|--------------------------------------------------------------------------
| Path
|--------------------------------------------------------------------------
|
| This is the URI path where visual exceptions will be accessible from.
|
*/
'path' => env('VISUAL_EXCEPTIONS_PATH', 'api/visual-exceptions'),
/*
|--------------------------------------------------------------------------
| Storage
|--------------------------------------------------------------------------
|
| This is where the temporary exception output will be stored.
|
*/
'storage' => 'visual-exceptions/latest.html',
/*
|--------------------------------------------------------------------------
| Clear on Retrieve
|--------------------------------------------------------------------------
|
| Use this option to clear the exception file after retrieving it.
|
*/
'clear_on_retrieve' => env('VISUAL_EXCEPTIONS_CLEAR', true),
/*
|--------------------------------------------------------------------------
| Middleware
|--------------------------------------------------------------------------
|
| Set middleware on the route.
|
*/
'middleware' => ['api'],
];
In your app/Exceptions/Handler.php
, capture the rendered exception with the following:
use \Illuminate\Support\Facades\Config;
use Stanbridge\VisualException\VisualException;
public function render($request, Throwable $exception)
{
$render = $this->prepareResponse($request, $exception);
if (Config::get('visual-exceptions.enabled')) {
VisualException::capture($render);
}
return $render;
}
php artisan vendor:publish --provider="Stanbridge\VisualException\VisualExceptionServiceProvider" --tag=assets
Copy the render-exception.js
file from the published assets into your single page application.
Import the library and use the retrieveLastError()
method. Here is an example using an axios interceptor:
import axios from 'axios';
import VisualException from 'path/to/render-exception.js';
axios.interceptors.response.use(response => response, error => {
if (error.response.status >= 500) {
VisualException.retrieveLastError();
}
});
The code in render-exception.js
comes from Livewire. Thanks to
Caleb Porzio and Jonathan Reinink
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
If you discover any security related issues, please email [email protected] instead of using the issue tracker.
The MIT License (MIT). Please see License File for more information.