bezhansalleh / filament-exceptions
A Simple & Beautiful Pluggable Exception Viewer for FilamentPHP's Admin Panel
Fund package maintenance!
bezhanSalleh
Installs: 170 065
Dependents: 14
Suggesters: 0
Security: 0
Stars: 190
Watchers: 3
Forks: 30
Open Issues: 0
Language:Blade
pkg:composer/bezhansalleh/filament-exceptions
Requires
- php: ^8.2
- bezhansalleh/filament-plugin-essentials: ^1.0
- filament/filament: ^4.0
- illuminate/contracts: ^11.28|^12.0
- illuminate/support: ^11.28|^12.0
- spatie/laravel-package-tools: ^1.9
Requires (Dev)
- larastan/larastan: ^3.8
- laravel/pint: ^1.0
- nunomaduro/collision: ^7.0|^8.0
- orchestra/testbench: ^10.6
- pestphp/pest: ^2.0|^3.0
- pestphp/pest-plugin-laravel: ^2.0|^3.0
- pestphp/pest-plugin-livewire: ^3.0
- pestphp/pest-plugin-type-coverage: ^3.5
- phpstan/extension-installer: ^1.4
- phpstan/phpstan: ^2.1
- phpstan/phpstan-deprecation-rules: ^2.0
- phpstan/phpstan-phpunit: ^2.0
- phpunit/phpunit: ^10.1|^11.0
- rector/rector: ^2.1
- spatie/laravel-ray: ^1.40
README
Exception Viewer
A Simple & Beautiful Exception Viewer for FilamentPHP's Admin Panel
Version Compatibility:
- Filament 4.x → use version 4.x
- Filament 3.x → use version 3.x
- Filament 2.x → use version 1.x
Installation
- You can install the package via composer:
composer require bezhansalleh/filament-exceptions
- Publish and run the migration via:
php artisan exceptions:install
- Register the plugin for the Filament Panel
public function panel(Panel $panel): Panel { return $panel ->plugins([ \BezhanSalleh\FilamentExceptions\FilamentExceptionsPlugin::make() ]); }
That's it! The package automatically registers itself with Laravel's exception handler and starts recording exceptions.
Important
The plugin follows Filament's theming rules. So, to use the plugin create a custom theme if you haven't already, and add the following line to your theme.css file:
@source '../../../../vendor/bezhansalleh/filament-exceptions/resources/views/**/*.blade.php';
Now build your theme using:
npm run build
Recording Control
By default, exceptions are recorded automatically. You can control this behavior in your AppServiceProvider's boot() method:
Stop/Start Recording
use BezhanSalleh\FilamentExceptions\FilamentExceptions; public function boot(): void { // Stop recording exceptions FilamentExceptions::stopRecording(); // Resume recording FilamentExceptions::startRecording(); // Check if recording is active FilamentExceptions::isRecording(); }
Conditional Recording
Use recordUsing() to define custom logic for when exceptions should be recorded:
use BezhanSalleh\FilamentExceptions\FilamentExceptions; public function boot(): void { // Only record in production FilamentExceptions::recordUsing(fn () => app()->isProduction()); // Skip specific exception types FilamentExceptions::recordUsing(function (Throwable $e) { return ! $e instanceof \Illuminate\Validation\ValidationException && ! $e instanceof \Illuminate\Auth\AuthenticationException; }); // Combine multiple conditions FilamentExceptions::recordUsing(function (Throwable $e) { if (! app()->isProduction()) { return false; } // Skip 4xx HTTP exceptions if ($e instanceof \Symfony\Component\HttpKernel\Exception\HttpException && $e->getStatusCode() < 500) { return false; } return true; }); }
Configuration Options
When registering the FilamentExceptions plugin, you can chain various methods to customize its behavior. Here are all available configuration options:
Navigation
FilamentExceptionsPlugin::make() ->navigationBadge(bool | Closure $condition = true) ->navigationBadgeColor(string | array | Closure $color) ->navigationGroup(string | Closure | null $group) ->navigationParentItem(string | Closure | null $item) ->navigationIcon(string | Closure | null $icon) ->activeNavigationIcon(string | Closure | null $icon) ->navigationLabel(string | Closure | null $label) ->navigationSort(int | Closure | null $sort) ->registerNavigation(bool | Closure $shouldRegisterNavigation) ->subNavigationPosition(SubNavigationPosition | Closure $position)
Labels and Search
FilamentExceptionsPlugin::make() ->modelLabel(string | Closure | null $label) ->pluralModelLabel(string | Closure | null $label) ->titleCaseModelLabel(bool | Closure $condition = true) ->globallySearchable(bool | Closure $condition = true)
Mass Pruning Settings
FilamentExceptionsPlugin::make() ->modelPruneInterval(Carbon $interval)
Note This requires laravel scheduler to be setup and configured in order to work. You can see how to do that here Running The Scheduler
Tenancy Configuration
FilamentExceptionsPlugin::make() ->scopeToTenant(bool | Closure $condition = true) ->tenantOwnershipRelationshipName(string | Closure | null $ownershipRelationshipName) ->tenantRelationshipName(string | Closure | null $relationshipName)
General Configuration
FilamentExceptionsPlugin::make() ->cluster(string | Closure | null $cluster) ->slug(string | Closure | null $slug)
Example usage:
return $panel ->plugins([ FilamentExceptionsPlugin::make() ->navigationLabel('Error Logs') ->navigationIcon('heroicon-o-bug-ant') ->navigationBadge() ->navigationGroup('System') ->modelPruneInterval(now()->subDays(7)) ]);
Custom Exception Model
- Extend the base model as follow:
<?php namespace App\Models; use BezhanSalleh\FilamentExceptions\Models\Exception as BaseException; class MyCustomException extends BaseException { ... }
- Then, in a service provider's
boot()method for instanceAppServiceProvider:
use App\Models\MyCustomException; use BezhanSalleh\FilamentExceptions\FilamentExceptions; ... public function boot() { FilamentExceptions::model(MyCustomException::class); } ...
Translations
Publish the translations with
php artisan vendor:publish --tag=filament-exceptions-translations
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.