Wordpress - Redirect Visitors to a Temporary Maintenance Page
WordPress has an embedded feature for handling maintenance mode.
When you upgrade a plugin, or WordPress core from WP dashboard, WordPress enters maintenance mode: it tries to load a file named maintenance.php
located in the content folder (usually /wp-content
), and if that file is not there, WP shows a default message.
I suggest you use that file, in this way you'll be consistent for your manually-triggered maintenance and for WordPress-handled maintenance.
How To
First of all create the
maintenance.php
file and put there the content you want. For styling I suggest you put CSS in the file itself, using<style>
tag; generally this is not good advice, but in this case it gives you the ability of using the file for WordPress-handled maintenance mode, when no theme is loaded (and the theme may be upgrading, so not reliable).Save the file just created in content folder (usually
/wp-content
).In your
functions.php
put:add_action( 'wp_loaded', function() { global $pagenow; if( defined( 'IN_MAINTENANCE' ) && IN_MAINTENANCE && $pagenow !== 'wp-login.php' && ! is_user_logged_in() ) { header( 'HTTP/1.1 Service Unavailable', true, 503 ); header( 'Content-Type: text/html; charset=utf-8' ); header( 'Retry-After: 3600' ); if ( file_exists( WP_CONTENT_DIR . '/maintenance.php' ) ) { require_once( WP_CONTENT_DIR . '/maintenance.php' ); } die(); } });
This code will check a constant (see next point) and if user is not logged in, load the file created at point #1 and exit.
If you want to allow only users with specific capabilities, use
current_user_can('capability_to_allow')
instead ofis_user_logged_in()
. See Codex for more info.Maybe you can add to
maintenance.php
a link to login page; in this way a non-logged user can click it without having to manually enter the login URL in the address bar.If you are using a theme developed by a 3rd party, use a child theme; in this way you will be able to safely update the theme without losing your changes.
When you want to enable maintenance mode, open your
wp_config.php
and put there:define('IN_MAINTENANCE', true);
After that, when you are ready to make your site public again, just remove that line or change
true
tofalse
for easier re-enabling.
The previous answer is complete and well written. Anyhow if you are like me and you want to have everything in one place you can drop the following lines in the function.php
file and create a maintenance.php
file in your theme directory.
This is especially useful if your Git repository points just to the theme directory.
add_action( 'wp_loaded', function()
{
global $pagenow;
// - - - - - - - - - - - - - - - - - - - - - -
// Turn on/off you Maintenance Mode (true/false)
define('IN_MAINTENANCE', true);
// - - - - - - - - - - - - - - - - - - - - - -
if(
defined( 'IN_MAINTENANCE' )
&& IN_MAINTENANCE
&& $pagenow !== 'wp-login.php'
&& ! is_user_logged_in()
) {
header('HTTP/1.1 503 Service Temporarily Unavailable');
header( 'Content-Type: text/html; charset=utf-8' );
if ( file_exists( get_template_directory() . '/maintenance.php' ) ) {
require_once( get_template_directory() . '/maintenance.php' );
}
die();
}
});
NOTES
I changed the header to header('HTTP/1.1 503 Service Temporarily Unavailable');
as the one above didn't work for me.