Package Data | |
---|---|
Maintainer Username: | MisterPhilip |
Maintainer Contact: | philip@misterphilip.com (Philip Lawrence) |
Package Create Date: | 2014-11-29 |
Package Last Update: | 2020-03-15 |
Home Page: | |
Language: | PHP |
License: | MIT |
Last Refreshed: | 2024-11-18 03:03:20 |
Package Statistics | |
---|---|
Total Downloads: | 169,716 |
Monthly Downloads: | 703 |
Daily Downloads: | 7 |
Total Stars: | 120 |
Total Watchers: | 10 |
Total Forks: | 21 |
Total Open Issues: | 0 |
This package is a drop-in replacement for Laravel 5.5 - 5.8's maintenance mode. For Laravel 5.0 - 5.2, please use the 1.0 branch. For Laravel 5.3 - 5.4, support might be released on the 1.1 branch branch, should there be any interest / development help. Features include:
Run the following command to install the latest:
$ composer require "misterphilip/maintenance-mode=1.3.*"
Or, if you prefer installing it manually, within composer.json
add the following line to the end of the require
section:
"misterphilip/maintenance-mode": "1.3.*"
And then run the Composer install command:
$ composer install
Laravel should automatically install the Service Providers, but verify they exist within the config/app.php
file.
If they do not, add MisterPhilip\MaintenanceMode\MaintenanceModeServiceProvider::class,
and
MisterPhilip\MaintenanceMode\MaintenanceCommandServiceProvider::class,
to the end of the
$providers
array in your config/app.php
:
'providers' => [
/*
* Application Service Providers...
*/
App\Providers\AppServiceProvider::class,
App\Providers\EventServiceProvider::class,
App\Providers\RouteServiceProvider::class,
...
MisterPhilip\MaintenanceMode\MaintenanceModeServiceProvider::class,
MisterPhilip\MaintenanceMode\MaintenanceCommandServiceProvider::class,
],
Finally, in app/Http/Kernel.php
replace the current MaintenanceMode Middleware
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
with
\MisterPhilip\MaintenanceMode\Http\Middleware\CheckForMaintenanceMode::class,
Since Laravel 5.3, messages are now allowed in the default artisan down
command, as well as adding an option for the
Retry-After
HTTP header. Because of this it should be noted that the syntax to call the artisan down
command has
changed from the 1.0 branch to better match Laravel's default command.
Additionally, we've changed the
MaintenanceModeEnabled
event to no longer use the info
property, but instead have separate properties for each piece
of information. See more in the events section.
This package overwrites the default artisan down
command, with more options:
$ php artisan down [--message=MESSAGE] [--retry=RETRY] [--view=VIEW] [--allow*=ALLOW]
For example,
$ php artisan down --message="We're currently upgrading our system! Please check back later."
would show users a message of "We're doing some routine maintenance! Be back soon!". If you don't pass in a message, the default "We're currently working on the site, please try again later" will display to the users. Of course this default is configurable via a language string.
You can also change the view that is shown each time you run the artisan down
command via the --view=[VIEW]
option:
$ php artisan down --message="Be back in a few!" --view="errors/maintenance"
And of course you can use the default --retry
option as well:
$ php artisan down --message="Be back in a few!" --view="errors/maintenance" --retry=60
To bring your application back online, run the normal app up command:
$ php artisan up
NOTE: by default, two exemptions enabled, which means that if you run
your development server locally (127.0.0.1) or you have APP_ENV=local
in your .env
file, you will not see the
maintenance page. You can remove these exemptions via the configuration.
This package is a drop-in replacement for the default maintenance mode provided with Laravel 5. This means that you do not have to do any configuration out-of-the-box. However, if you'd like to tweak some of the settings, there are a number of configuration values that are available to make this package a better fit for your application.
Below are the default configuration options and a short description on each. Don't worry, all of this information is within the configuration file too!
view
(string)
--view
optionmaintenancemode::app-down
notification-styles
(boolean)
true
inject.global
(boolean)
true
inject.prefix
(string)
MaintenanceMode
language-path
(string)
maintenancemode::defaults
exempt-ips
(string array)
['127.0.0.1']
exempt-ips-proxy
(boolean)
false
exempt-environments
(string array)
['local']
exemptions
(string array)
'\MisterPhilip\MaintenanceMode\Exemptions\IPWhitelist',
'\MisterPhilip\MaintenanceMode\Exemptions\EnvironmentWhitelist',
If you need to override the default configuration values, run the following command:
$ php artisan vendor:publish --provider="MisterPhilip\MaintenanceMode\MaintenanceModeServiceProvider" --tag="config"
Now you can edit the values at config/maintenancemode.php
.
Exemptions allow for select users to continue to use the application like normal based on a specific set of rules. Each of these rule sets are defined via a class which is then executed against.
By default, an IP whitelist and an application environment whitelist are included with this package to get you off the ground running. Additionally, more examples are provided for various types of exemptions that might be useful to your application.
This exemption allows you to check the user's IP address against a whitelist. This is useful for
always including your office IP(s) so that your staff doesn't see the maintenance page. This is similar
to the allow
option that is offered in Laravel 5.6+ (and is backported to 5.5 with this package), however
the allow
option requires you to pass the IPs every time, vs. this method allows for you to have IPs stored
in the configuration. Both methods can be used with each other, e.g. a static internal network should always be
allowed via the config, while an additional IP for a vendor or remote employee can temporarily be added via the
allow
option.
Configuration values included with this exemption are:
exempt-ips
- An array of IP addresses that will not see the maintenance pageexempt-ips-proxy
- Set to true
if you have IP proxies setupThis exemption allows you to check if the current environment matches against a whitelist. This is useful for local development where you might not want to see the maintenance page.
Configuration values included with this exemption are:
exempt-environments
- An array of environments that will not display the maintenance pageSetting up a new exemption is simple:
MisterPhilip\MaintenanceMode\Exemptions\MaintenanceModeExemption
.
You might consider creating these files in app\Exemptions
or app\Infrastructure\Maintenance
, but
you're free to place them where you want.isExempt
method. This method should return true
if the user should
not see the maintenance page. If this returns false
, it indicates that the user does not match
your ruleset and other exceptions should be checked.exemptions
array in the configuration file.Below is an template to use for a new exemption class SampleExemption
:
<?php namespace App\Exemptions;
use MisterPhilip\MaintenanceMode\Exemptions\MaintenanceModeExemption;
class SampleExemption extends MaintenanceModeExemption
{
/**
* Execute the exemption check
*
* @return bool
*/
public function isExempt()
{
return true; // or false
}
}
There are 2 views included with this package: an "application down" page that replaces the current "Be right back!" page, and a "maintenance notification" which is a notification bar that tells exempted users that the application is in maintenance mode.
You can also publish these views so that you can edit them easily. The command below will publish the views
to resources/views/vendor/maintenancemode/*
. Once published be sure to change the config values (view
)
to point to the new file location.
$ php artisan vendor:publish --provider="MisterPhilip\MaintenanceMode\MaintenanceModeServiceProvider" --tag="views"
The default maintenance page, maintenancemode::app-down
Included is a default view that displays your custom message and a timestamp for your users. To change this page,
update the view
configuration value to point to the new view. The following variables are available for
you to use:
$MaintenanceModeEnabled
- Check to see if the maintenance mode is enabled$MaintenanceModeMessage
- The message that should be displayed to users (either the one passed via
the command call, or the default from the language file)$MaintenanceModeTimestamp
- The timestamp from when the application went into maintenance modeNOTE: If you've changed the inject.prefix
configuration value, you'll need to reflect this change in the
variable names above. For example, if inject.prefix = "Foobar"
, your view variables would be $FoobarEnabled
,
$FoobarMessage
, and $FoobarTimestamp
.
NOTE: By default, these variables are available in all views. To disable this functionality and have it
only inject variables on the maintenance page, change the inject.global
configuration value to false
.
You can also temporarily override the view shown by passing in the --view
option when calling the artisan down
command. E.g. if you wanted to use the default errors/503.blade.php
view, you could call:
$ php artisan down --view="error/503"
The optional maintenance notification, maintenancemode::notification
We've included a maintenance notification for users that want to include a notice to those that are exempt from seeing the maintenance page. We've found that as an admin, it's helpful to know when your application is in maintenance mode in the event that you've forgotten to disable it or it was turned on automatically.
You can enable this notification by placing the following code within your main blade layouts file(s):
@include('maintenancemode::notification')
This package fires an event,
MisterPhilip\MaintenanceMode\Events\MaintenanceModeEnabled
, whenever the application goes down for maintenance,
and MisterPhilip\MaintenanceMode\Events\MaintenanceModeDisabled
when it is brought back up. You can add your own
listeners in your events Service Provider. By default this is located at app/providers/EventServiceProvider.php
.
You can find several example listeners in the events examples, including logging when the
application went down or up, and updating Statuspage via the
checkitonus/php-statuspage-sdk package.
protected $listen = [
'MisterPhilip\MaintenanceMode\Events\MaintenanceModeEnabled' => [
'App\Listeners\UpdateStatusPageMaintenanceStarted',
],
'MisterPhilip\MaintenanceMode\Events\MaintenanceModeDisabled' => [
'App\Listeners\UpdateStatusPageMaintenanceEnded',
],
// ..
];
The original message
, time
the app went down, retry
length, view
, and allowed
are all properties available on both events.