Jobs monitor
Monitor your queues from a panel
Author:
Baptiste Bouillot
Documentation
This is a package to monitor background jobs for FilamentPHP. It is inspired by Laravel Horizon and is compatible with all drivers.


#Installation
Check your filamentPHP version before installing:
| Version | FilamentPHP | PHP |
|---|---|---|
| 1.* | 2.* | 8.1 |
| 2.* | 3.* | >= 8.1 |
| 3.* | 4.* | >= 8.1 |
| 4.* | 5.* | >= 8.2 |
Install the package via composer:
composer require croustibat/filament-jobs-monitor
Publish and run the migrations using:
php artisan vendor:publish --tag="filament-jobs-monitor-migrations"
php artisan migrate
#Usage
#Configuration
The global plugin config can be published using the command below:
php artisan vendor:publish --tag="filament-jobs-monitor-config"
This is the content of the published config file:
return [
'resources' => [
'enabled' => true,
'label' => 'Job',
'plural_label' => 'Jobs',
'navigation_group' => 'Settings',
'navigation_icon' => 'heroicon-o-cpu-chip',
'navigation_sort' => null,
'navigation_count_badge' => false,
'resource' => Croustibat\FilamentJobsMonitor\Resources\QueueMonitorResource::class,
'cluster' => null,
'sub_navigation_position' => null, // SubNavigationPosition::Top or ::Sidebar
],
'pruning' => [
'enabled' => true,
'retention_days' => 7,
],
'queues' => [
'default'
],
'tenancy' => [
'enabled' => false,
'model' => null, // e.g., App\Models\Tenant::class
'column' => 'tenant_id',
],
];
NOTE: Since there isn't a universal way to retrieve all used queues, it's necessary to define them to obtain all pending jobs.
#Extending Model
Sometimes it's useful to extend the model to add some custom methods. You can do it by extending the model by creating your own model :
$ php artisan make:model MyQueueMonitor
Then you can extend the model by adding your own methods :
<?php
namespace App\Models;
use \Croustibat\FilamentJobsMonitor\Models\QueueMonitor as CroustibatQueueMonitor;
class MyQueueMonitor extends CroustibatQueueMonitor {}
#Multi-Tenancy Support
This plugin supports multi-tenancy for applications using Filament's built-in tenant functionality. When enabled, job monitors are automatically filtered by the current tenant.
Features:
- Automatically associates jobs with tenants based on a
tenantIdproperty in your job class - Filters the job monitor list to show only jobs for the current tenant
- Filters pending jobs and failed jobs by tenant (via payload inspection)
- Backwards compatible - disabled by default
Configuration:
Enable multi-tenancy in your published config file:
'tenancy' => [
'enabled' => true,
'model' => App\Models\Tenant::class, // Your tenant model
'column' => 'tenant_id', // Column name in queue_monitors table
],
Migration:
If you enable tenancy after initial installation, re-publish and run the migration to add the tenant_id column:
php artisan vendor:publish --tag="filament-jobs-monitor-migrations" --force
php artisan migrate
Job Requirements:
For jobs to be associated with a tenant, they must have a public tenantId property:
class MyTenantJob implements ShouldQueue
{
use Dispatchable, InteractsWithQueue, Queueable, SerializesModels;
public function __construct(
public int $tenantId, // Required for multi-tenancy
// ... other properties
) {}
}
When dispatching the job, pass the current tenant ID:
MyTenantJob::dispatch(
tenantId: Filament::getTenant()->id,
// ... other arguments
);
See examples/TenantAwareExportJob.php for a complete example.
#Using Filament Panels
If you are using Filament Panels, you can register the Plugin to your Panel configuration. This will register the plugin's resources as well as allow you to set configuration using optional chainable methods.
For example in your app/Providers/Filament/AdminPanelProvider.php file:
<?php
use \Croustibat\FilamentJobsMonitor\FilamentJobsMonitorPlugin;
...
public function panel(Panel $panel): Panel
{
return $panel
->plugins([
FilamentJobsMonitorPlugin::make()
]);
}
#Usage
Just run a Background Job and go to the route /admin/queue-monitors to see the jobs.
#Example
Go to example folder to see a Job example file.
Then you can call your Job with the following code:
public static function table(Table $table): Table
{
return $table
// rest of your code
...
->bulkActions([
BulkAction::make('export-jobs')
->label('Background Export')
->icon('heroicon-o-cog')
->action(function (Collection $records) {
UsersCsvExportJob::dispatch($records, 'users.csv');
Notification::make()
->title('Export is ready')
->body('Your export is ready. You can download it from the exports page.')
->success()
->seconds(5)
->icon('heroicon-o-inbox-in')
->send();
})
])
}
#Enabling navigation
// AdminPanelProvider.php
->plugins([
// ...
FilamentJobsMonitorPlugin::make()
->enableNavigation(),
])
Or you can use a closure to enable navigation only for specific users:
// AdminPanelProvider.php
->plugins([
// ...
FilamentJobsMonitorPlugin::make()
->enableNavigation(
fn () => auth()->user()->can('view_queue_job') || auth()->user()->can('view_any_queue_job)'),
),
])
#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.
The author
Baptiste is a full-stack developer from Nantes, FR. He's CTO @Dernier Cri, a web & mobile development agency.
From the same author
Featured Plugins
A selection of plugins curated by the Filament team
Custom Dashboards
Let your users build and share their own dashboards with a drag-and-drop interface. Define your data sources in PHP and let them do the rest.
Filament
Data Lens
Advanced Data Visualization for Laravel Filament - a premium reporting solution enabling custom column creation, sophisticated filtering, and enterprise-grade data insights within admin panels.
Padmission
Advanced Tables (formerly Filter Sets)
Supercharge your tables with powerful features like user-customizable views, quick filters, multi-column sorting, advanced table searching, convenient view management, and more. Compatible with Resource Panel Tables, Relation Managers, Table Widgets, and Table Builder!
Kenneth Sese