The plugin provides tools to help you do maintenance on your Craft CMS website:
- Display a “Maintenance in progress” overlay in the Control Panel when the site is undergoing scheduled maintenance
- Announce upcoming maintenance on the dashboard and with notification banners
- Leave your users (maintenance related) messages on the dashboard widget
- Access maintenance related info from your templates using the provided template variables
The plugin is available on Packagist and can be installed using Composer. You can also download the latest release and copy the files into craft/plugins/maintenance/.
$ composer require carlcs/craft-maintenance
Set up maintenance announcements or messages from the plugin’s settings page. You can use markdown to add links, or to format the message. To configure scheduled maintenance you have to set a start date in the announcement’s settings and enable “Backend Maintenance” and/or “Frontend Maintenance”.
Create a new “Maintenance Announcements” widget to display all notifications on the users’ Dashboards. Upcoming maintenance will also be announced with a banner notification.
Note: the plugin doesn’t do “content freeze” in a way, that it actually prevents data from being saved or changed in the database. That being said, there are template variables and plugins API provided.
The plugin can be configured from a craft/config/maintenance.php config file or from Settings/Maintenance.
In Settings/Users you can assign user permissions to configure the “Maintenance in progress” overlay or to grant access for individual user groups while frontend maintenance is carried out.
The plugin provides template variables to get the active announcement model, or to check whether the site is currently undergoing maintenance.
Returns whether the Control Panel is currently undergoing maintenance.
{{ isCpMaintenance ? 'Shop closed' : '<a href="/shop">Shop</a>' }}
Returns whether the site is currently undergoing maintenance.
{% set reason = isSiteMaintenance ? 'scheduled' : 'unscheduled' %}
Returns the latest, either currently active or soon to be activated maintenance announcement.
{% set announcement = craft.maintenance.getAnnouncement('2 hours') %}
{% if announcement and announcement.blockSite %}
<span>{{ announcement.message }}</span>
{% endif %}
- Quick set up maintenance via environment variable