brickx / laravel-filament-maintenance
Simple plugin to toggle maintenance mode from Filament
Installs: 11 404
Dependents: 1
Suggesters: 0
Security: 0
Stars: 15
Watchers: 2
Forks: 2
Open Issues: 0
Requires
- php: ^8.1
- blade-ui-kit/blade-icons: ^1.5
- filament/filament: ^2.17
- filament/notifications: ^2.17
- illuminate/contracts: ^9.0|^10.0
- livewire/livewire: ^2.10
- spatie/laravel-package-tools: ^1.15
Requires (Dev)
- laravel/pint: ^1.10
- nunomaduro/collision: ^7.9
- orchestra/testbench: ^8.5
- pestphp/pest: ^2.6
- pestphp/pest-plugin-arch: ^2.2
- pestphp/pest-plugin-laravel: ^2.0
- pestphp/pest-plugin-livewire: ^2.0
- spatie/laravel-ray: ^1.32
README
⚠️ IMPORTANT
This repository has been archived, as a newer version for Filament v3 can be found here: Maintenance Switch.
I'll try my best to make this new repository compatible with Filament v2 as well, but I can't guarantee when that will happen. Feel free to use this archived version in the meantime.
This plugin allows you to easily toggle maintenance mode from your Filament Admin Panel. You can also set a secret token to bypass the maintenance mode.
Requirements
This plugin was developed for Filament v2, and will soon be archived.
If you're using Filament v3, please check out the new repository for the plugin: brickx/maintenance-switch.
Installation
You can install the package via composer:
composer require brickx/laravel-filament-maintenance
You can publish the config file with:
php artisan vendor:publish --tag="filament-maintenance-config"
This is the contents of the published config file:
return [ 'secret' => null, 'refresh' => false, 'permissions' => false, 'role' => false, 'tiny_toggle' => false, ];
You can publish the translations with:
php artisan vendor:publish --tag="filament-maintenance-translations"
Optionally, you can publish the views using:
php artisan vendor:publish --tag="filament-maintenance-views"
Setup
An optional step (but highly recommended) is to modify the App\Http\Middleware\PreventRequestsDuringMaintenance
class to add the following code:
use Illuminate\Foundation\Http\MaintenanceModeBypassCookie; use Illuminate\Http\RedirectResponse; ... protected function bypassResponse(string $secret) : RedirectResponse { return redirect('admin')->withCookie( MaintenanceModeBypassCookie::create($secret) ); }
This is because Laravel's default maintenance middleware will redirect to the /
route, which feels weird for the user. Of course, you can redirect to any URL you want.
Usage
The plugin will add a toggle button to your Filament Admin Panel, right before the search bar.
Clicking it will trigger the php artisan down
command if the website is live, and the php artisan up
command otherwise.
Secret Token
You can set a secret token in the config file. If you do so, you will be able to bypass the maintenance mode by visiting the following URL: https://your-domain.test/{secret}
.
If the secret
key is set to null
, a random one will be generated on the fly each time the maintenance mode is activated.
Refresh Interval
If you want to instruct browsers to refresh pages after a certain amount of time, you can set the refresh
key in the config file.
When set to false
, no Refresh
HTTP header will be sent. You can specify an integer to define the number of seconds before reloading pages under maintenance mode.
Visibility
By default, any logged-in user will be able to toggle the maintenance mode.
If you want to restrict maintenance mode toggling to certain users, you can set the permissions
key in the config file.
The plugin will use Laravel's default authorization system to check for permissions, via the can
method on the User model. It will also work well with Spatie's Laravel Permission package.
Todo
- Fix toggle button styling not properly updating when maintenance mode is disabled.
- Improve the UX by directly adding the maintenance cookie from the Livewire component (instead of redirecting to the matching URL).
Changelog
Please see CHANGELOG for more information on what has changed recently.
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.