Either run
php composer.phar require --prefer-dist brussens/yii2-maintenance-mode "*"
or add
"brussens/yii2-maintenance-mode": "*"
to the require section of your composer.json
file.
Add to your config file:
'bootstrap' => [
'brussens\maintenance\Maintenance'
],
...
'container' => [
'singletons' => [
'brussens\maintenance\Maintenance' => [
'class' => 'brussens\maintenance\Maintenance',
// Route to action
'route' => 'maintenance/index',
// Filters. Read Filters for more info.
'filters' => [
[
'class' => 'brussens\maintenance\filters\RouteFilter',
'routes' => [
'debug/default/toolbar',
'debug/default/view',
'site/login',
]
]
],
// HTTP Status Code
'statusCode' => 503,
//Retry-After header
'retryAfter' => 120 // or Wed, 21 Oct 2015 07:28:00 GMT for example
],
'brussens\maintenance\StateInterface' => [
'class' => 'brussens\maintenance\states\FileState',
// optional: use different filename for controlling maintenance state:
// 'fileName' => 'myfile.ext',
// optional: use different directory for controlling maintenance state:
// 'directory' => '@mypath',
]
]
]
You can use filters for allow excepts:
'container' => [
'singletons' => [
'brussens\maintenance\Maintenance' => [
'class' => 'brussens\maintenance\Maintenance',
// Route to action
'route' => 'maintenance/index',
// Filters. Read Filters for more info.
'filters' => [
//Allowed routes filter. Your can allow debug panel routes.
[
'class' => 'brussens\maintenance\filters\RouteFilter',
'routes' => [
'debug/default/toolbar',
'debug/default/view',
'site/login',
]
],
// Allowed roles filter
[
'class' => 'brussens\maintenance\filters\RoleFilter',
'roles' => [
'administrator',
]
],
// Allowed IP addresses filter
[
'class' => 'brussens\maintenance\filters\IpFilter',
'ips' => [
'127.0.0.1',
]
],
//Allowed user names
[
'class' => 'brussens\maintenance\filters\UserFilter',
'checkedAttribute' => 'username',
'users' => [
'BrusSENS',
],
]
],
]
]
]
You can create custom filter:
class MyCustomFilter extends Filter
{
public $time;
/**
* @return bool
*/
public function isAllowed()
{
return (bool) $this->time > 3600;
}
}
Add to your console or common config file:
'container' => [
'singletons' => [
'brussens\maintenance\StateInterface' => [
'class' => 'brussens\maintenance\states\FileState',
// optional: use different filename for controlling maintenance state:
// 'fileName' => 'myfile.ext',
// optional: use different directory for controlling maintenance state:
// 'directory' => '@mypath',
]
]
],
'controllerMap' => [
'maintenance' => [
'class' => 'brussens\maintenance\commands\MaintenanceController',
],
],
Now you can set mode by command:
php yii maintenance/enable
php yii maintenance/disable
Add to your console or common config file:
'controllerMap' => [
'migrate' => [
'class' => 'yii\console\controllers\MigrateController',
'migrationNamespaces' => [
'brussens\maintenance\migrations',
],
],
],
And Execute the migrations.
Add to your web or common config file:
'modules' => [
'maintenance' => [
'class' => 'brussens\maintenance\Module',
// optional: change the display format for the dates
'dateFormat' => 'dd/MM/yyyy',
// optional: change the attribute used to display the user
'userDisplayAttribute' => 'firstname',
]
],
You can now access the page to add a new maintenance window from the route /maintenance
.