Maintenance Mode for WordPress®
Maintenance Mode for WordPress®
A free WordPress® plugin that enables a fully customizable maintenance mode with a dedicated landing page.
Built with the WordPress® core editor, this plugin locks down access to the frontend for non-logged-in users while keeping administrators in control.
Features
- Custom Maintenance Pages: Create and edit maintenance pages using the WordPress block editor.
- Admin-Only Access: Allow logged-in administrators to bypass maintenance mode.
- REST API Control: Restrict REST API access for non-logged-in users during maintenance mode.
- Launch Scheduling: Set an optional launch date for your maintenance mode.
- Customizable Frontend Appearance: Use the built-in block editor to style your maintenance page.
- 503 HTTP Status Code: Ensure search engines recognize your site's temporary downtime.
-
- *
Installation
-
Download the plugin files from the GitHub repository.
-
Upload the plugin to your WordPress® installation via the Plugins > Add New > Upload Plugin menu.
-
Activate the plugin via the Plugins screen in WordPress®.
Usage
1. Enable Maintenance Mode
- Navigate to Maintenance > Settings in your WordPress® admin panel.
- Check the box labeled Enable Maintenance Mode.
2. Set a Maintenance Page
- Go to Maintenance in the WordPress® admin panel.
- Create or select a maintenance page using the block editor.
- Assign the maintenance page in the Maintenance > Settings menu under Maintenance Mode Page.
3. Schedule a Launch Date (Optional)
-
In the Maintenance > Settings menu, enter a date under Launch Date.
-
Save your settings.
If a launch date is specified, maintenance mode will automatically end on that date.
Developer Notes
Actions and Filters
- Actions:
template_redirect
: Restricts frontend access for non-logged-in users when maintenance mode is enabled.rest_api_init
: Blocks REST API access for non-logged-in users during maintenance mode.
- Filters:
the_content
: Used to render the content of the assigned maintenance page.
Code Highlights
- Custom Post Type:
- Maintenance pages are created as a custom post type
maintenance_page
. - They support title and editor fields.
- Maintenance pages are created as a custom post type
- 503 Status Header:
- The plugin sends a
503 Service Unavailable
HTTP status code when maintenance mode is active.
- The plugin sends a
- REST API Restriction:
- Non-logged-in users receive a
403 Forbidden
response when attempting to access the REST API.
- Non-logged-in users receive a
FAQs
Why can't I see the maintenance page?
Make sure you've assigned a published page under Maintenance > Settings > Maintenance Mode Page.
How do I bypass maintenance mode?
Log in to WordPress® as an administrator. Maintenance mode restrictions do not apply to logged-in users.
Will this affect my site's SEO?
No, the plugin sends a 503 Service Unavailable
status code to notify search engines that the downtime is temporary.
Troubleshooting
-
Settings Not Saving:
- Ensure your WordPress installation has sufficient permissions to save plugin options.
-
REST API Issues:
- Check that you are logged in as an administrator if you need REST API access during maintenance mode.
Contributing
- Fork the repository on GitHub.
- Create a feature branch for your changes.
- Submit a pull request for review.
License
This plugin is licensed under the GPL-2.0+ License.
The following is a list of the most recent issues for this plugin.
Hash Verification
ZIP files downloaded via this site have an associated SHA256 hash.
Mac
On Mac, you can use the sha256 command to calculate the hash of a downloaded ZIP file. Open terminal and execute:
sha256 [filename]
Where [filename] is the name of the ZIP file. If the hash matches the one on the website, the ZIP file is genuine.
Linux
On Linux, you can use the sha256sum command to calculate the hash of a downloaded ZIP file. From a shell, execute:
sha256sum [filename]
Where [filename] is the name of the ZIP file. If the hash matches the one on the website, the ZIP file is genuine.
Latest Release
The latest official release is below.
1.0.1
Download 1.0.1bd888c710df34b2c21b9f70bf2b7a94ea118a7f53d2caa04dd2eec71a90c9f5e
Github Repository
This project is located on Github in the repository robertdevore/maintenance-mode-for-wordpress.
Star Support Project