Edit File by line
/home/zeestwma/richards.../wp-conte.../plugins/elemento.../includes
File: maintenance-mode.php
<?php
[0] Fix | Delete
namespace Elementor;
[1] Fix | Delete
[2] Fix | Delete
use Elementor\TemplateLibrary\Source_Local;
[3] Fix | Delete
[4] Fix | Delete
if ( ! defined( 'ABSPATH' ) ) {
[5] Fix | Delete
exit; // Exit if accessed directly.
[6] Fix | Delete
}
[7] Fix | Delete
[8] Fix | Delete
/**
[9] Fix | Delete
* Elementor maintenance mode.
[10] Fix | Delete
*
[11] Fix | Delete
* Elementor maintenance mode handler class is responsible for the Elementor
[12] Fix | Delete
* "Maintenance Mode" and the "Coming Soon" features.
[13] Fix | Delete
*
[14] Fix | Delete
* @since 1.4.0
[15] Fix | Delete
*/
[16] Fix | Delete
class Maintenance_Mode {
[17] Fix | Delete
[18] Fix | Delete
/**
[19] Fix | Delete
* The options prefix.
[20] Fix | Delete
*/
[21] Fix | Delete
const OPTION_PREFIX = 'elementor_maintenance_mode_';
[22] Fix | Delete
[23] Fix | Delete
/**
[24] Fix | Delete
* The maintenance mode.
[25] Fix | Delete
*/
[26] Fix | Delete
const MODE_MAINTENANCE = 'maintenance';
[27] Fix | Delete
[28] Fix | Delete
/**
[29] Fix | Delete
* The coming soon mode.
[30] Fix | Delete
*/
[31] Fix | Delete
const MODE_COMING_SOON = 'coming_soon';
[32] Fix | Delete
[33] Fix | Delete
/**
[34] Fix | Delete
* Get elementor option.
[35] Fix | Delete
*
[36] Fix | Delete
* Retrieve elementor option from the database.
[37] Fix | Delete
*
[38] Fix | Delete
* @since 1.4.0
[39] Fix | Delete
* @access public
[40] Fix | Delete
* @static
[41] Fix | Delete
*
[42] Fix | Delete
* @param string $option Option name. Expected to not be SQL-escaped.
[43] Fix | Delete
* @param mixed $default_value Optional. Default value to return if the option
[44] Fix | Delete
* does not exist. Default is false.
[45] Fix | Delete
*
[46] Fix | Delete
* @return bool False if value was not updated and true if value was updated.
[47] Fix | Delete
*/
[48] Fix | Delete
public static function get( $option, $default_value = false ) {
[49] Fix | Delete
return get_option( self::OPTION_PREFIX . $option, $default_value );
[50] Fix | Delete
}
[51] Fix | Delete
[52] Fix | Delete
/**
[53] Fix | Delete
* Set elementor option.
[54] Fix | Delete
*
[55] Fix | Delete
* Update elementor option in the database.
[56] Fix | Delete
*
[57] Fix | Delete
* @since 1.4.0
[58] Fix | Delete
* @access public
[59] Fix | Delete
* @static
[60] Fix | Delete
*
[61] Fix | Delete
* @param string $option Option name. Expected to not be SQL-escaped.
[62] Fix | Delete
* @param mixed $value Option value. Must be serializable if non-scalar.
[63] Fix | Delete
* Expected to not be SQL-escaped.
[64] Fix | Delete
*
[65] Fix | Delete
* @return bool False if value was not updated and true if value was updated.
[66] Fix | Delete
*/
[67] Fix | Delete
public static function set( $option, $value ) {
[68] Fix | Delete
return update_option( self::OPTION_PREFIX . $option, $value );
[69] Fix | Delete
}
[70] Fix | Delete
[71] Fix | Delete
/**
[72] Fix | Delete
* Body class.
[73] Fix | Delete
*
[74] Fix | Delete
* Add "Maintenance Mode" CSS classes to the body tag.
[75] Fix | Delete
*
[76] Fix | Delete
* Fired by `body_class` filter.
[77] Fix | Delete
*
[78] Fix | Delete
* @since 1.4.0
[79] Fix | Delete
* @access public
[80] Fix | Delete
*
[81] Fix | Delete
* @param array $classes An array of body classes.
[82] Fix | Delete
*
[83] Fix | Delete
* @return array An array of body classes.
[84] Fix | Delete
*/
[85] Fix | Delete
public function body_class( $classes ) {
[86] Fix | Delete
$classes[] = 'elementor-maintenance-mode';
[87] Fix | Delete
[88] Fix | Delete
return $classes;
[89] Fix | Delete
}
[90] Fix | Delete
[91] Fix | Delete
/**
[92] Fix | Delete
* Template redirect.
[93] Fix | Delete
*
[94] Fix | Delete
* Redirect to the "Maintenance Mode" template.
[95] Fix | Delete
*
[96] Fix | Delete
* Fired by `template_redirect` action.
[97] Fix | Delete
*
[98] Fix | Delete
* @since 1.4.0
[99] Fix | Delete
* @access public
[100] Fix | Delete
*/
[101] Fix | Delete
public function template_redirect() {
[102] Fix | Delete
if ( Plugin::$instance->preview->is_preview_mode() ) {
[103] Fix | Delete
return;
[104] Fix | Delete
}
[105] Fix | Delete
[106] Fix | Delete
$user = wp_get_current_user();
[107] Fix | Delete
[108] Fix | Delete
$exclude_mode = self::get( 'exclude_mode', [] );
[109] Fix | Delete
[110] Fix | Delete
$is_login_page = false;
[111] Fix | Delete
[112] Fix | Delete
/**
[113] Fix | Delete
* Is login page
[114] Fix | Delete
*
[115] Fix | Delete
* Filters whether the maintenance mode displaying the login page or a regular page.
[116] Fix | Delete
*
[117] Fix | Delete
* @since 1.0.4
[118] Fix | Delete
*
[119] Fix | Delete
* @param bool $is_login_page Whether its a login page.
[120] Fix | Delete
*/
[121] Fix | Delete
$is_login_page = apply_filters( 'elementor/maintenance_mode/is_login_page', $is_login_page );
[122] Fix | Delete
[123] Fix | Delete
if ( $is_login_page ) {
[124] Fix | Delete
return;
[125] Fix | Delete
}
[126] Fix | Delete
[127] Fix | Delete
if ( 'logged_in' === $exclude_mode && is_user_logged_in() ) {
[128] Fix | Delete
return;
[129] Fix | Delete
}
[130] Fix | Delete
[131] Fix | Delete
if ( 'custom' === $exclude_mode ) {
[132] Fix | Delete
$exclude_roles = self::get( 'exclude_roles', [] );
[133] Fix | Delete
$user_roles = $user->roles;
[134] Fix | Delete
[135] Fix | Delete
if ( is_multisite() && is_super_admin() ) {
[136] Fix | Delete
$user_roles[] = 'super_admin';
[137] Fix | Delete
}
[138] Fix | Delete
[139] Fix | Delete
$compare_roles = array_intersect( $user_roles, $exclude_roles );
[140] Fix | Delete
[141] Fix | Delete
if ( ! empty( $compare_roles ) ) {
[142] Fix | Delete
return;
[143] Fix | Delete
}
[144] Fix | Delete
}
[145] Fix | Delete
[146] Fix | Delete
add_filter( 'body_class', [ $this, 'body_class' ] );
[147] Fix | Delete
[148] Fix | Delete
if ( 'maintenance' === self::get( 'mode' ) ) {
[149] Fix | Delete
$protocol = wp_get_server_protocol();
[150] Fix | Delete
header( "$protocol 503 Service Unavailable", true, 503 );
[151] Fix | Delete
header( 'Content-Type: text/html; charset=utf-8' );
[152] Fix | Delete
header( 'Retry-After: 600' );
[153] Fix | Delete
}
[154] Fix | Delete
[155] Fix | Delete
// Setup global post for Elementor\frontend so `_has_elementor_in_page = true`.
[156] Fix | Delete
$GLOBALS['post'] = get_post( self::get( 'template_id' ) ); // phpcs:ignore WordPress.WP.GlobalVariablesOverride.Prohibited
[157] Fix | Delete
[158] Fix | Delete
// Set the template as `$wp_query->current_object` for `wp_title` and etc.
[159] Fix | Delete
query_posts( [
[160] Fix | Delete
'p' => self::get( 'template_id' ),
[161] Fix | Delete
'post_type' => Source_Local::CPT,
[162] Fix | Delete
] );
[163] Fix | Delete
}
[164] Fix | Delete
[165] Fix | Delete
/**
[166] Fix | Delete
* Register settings fields.
[167] Fix | Delete
*
[168] Fix | Delete
* Adds new "Maintenance Mode" settings fields to Elementor admin page.
[169] Fix | Delete
*
[170] Fix | Delete
* The method need to receive the an instance of the Tools settings page
[171] Fix | Delete
* to add the new maintenance mode functionality.
[172] Fix | Delete
*
[173] Fix | Delete
* Fired by `elementor/admin/after_create_settings/{$page_id}` action.
[174] Fix | Delete
*
[175] Fix | Delete
* @since 1.4.0
[176] Fix | Delete
* @access public
[177] Fix | Delete
*
[178] Fix | Delete
* @param Tools $tools An instance of the Tools settings page.
[179] Fix | Delete
*/
[180] Fix | Delete
public function register_settings_fields( Tools $tools ) {
[181] Fix | Delete
$templates = Plugin::$instance->templates_manager->get_source( 'local' )->get_items( [
[182] Fix | Delete
'type' => 'page',
[183] Fix | Delete
] );
[184] Fix | Delete
[185] Fix | Delete
$templates_options = [];
[186] Fix | Delete
[187] Fix | Delete
foreach ( $templates as $template ) {
[188] Fix | Delete
$templates_options[ $template['template_id'] ] = esc_html( $template['title'] );
[189] Fix | Delete
}
[190] Fix | Delete
[191] Fix | Delete
ob_start();
[192] Fix | Delete
[193] Fix | Delete
$this->print_template_description();
[194] Fix | Delete
[195] Fix | Delete
$template_description = ob_get_clean();
[196] Fix | Delete
[197] Fix | Delete
$tools->add_tab(
[198] Fix | Delete
'maintenance_mode', [
[199] Fix | Delete
'label' => esc_html__( 'Maintenance Mode', 'elementor' ),
[200] Fix | Delete
'sections' => [
[201] Fix | Delete
'maintenance_mode' => [
[202] Fix | Delete
'callback' => function() {
[203] Fix | Delete
echo '<h2>' . esc_html__( 'Maintenance Mode', 'elementor' ) . '</h2>';
[204] Fix | Delete
echo '<p>' . esc_html__( 'Set your entire website as MAINTENANCE MODE, meaning the site is offline temporarily for maintenance, or set it as COMING SOON mode, meaning the site is offline until it is ready to be launched.', 'elementor' ) . '</p>';
[205] Fix | Delete
},
[206] Fix | Delete
'fields' => [
[207] Fix | Delete
'maintenance_mode_mode' => [
[208] Fix | Delete
'label' => esc_html__( 'Choose Mode', 'elementor' ),
[209] Fix | Delete
'field_args' => [
[210] Fix | Delete
'type' => 'select',
[211] Fix | Delete
'std' => '',
[212] Fix | Delete
'options' => [
[213] Fix | Delete
'' => esc_html__( 'Disabled', 'elementor' ),
[214] Fix | Delete
self::MODE_COMING_SOON => esc_html__( 'Coming Soon', 'elementor' ),
[215] Fix | Delete
self::MODE_MAINTENANCE => esc_html__( 'Maintenance', 'elementor' ),
[216] Fix | Delete
],
[217] Fix | Delete
'desc' => '<div class="elementor-maintenance-mode-description" data-value="" style="display: none">' .
[218] Fix | Delete
esc_html__( 'Choose between Coming Soon mode (returning HTTP 200 code) or Maintenance Mode (returning HTTP 503 code).', 'elementor' ) .
[219] Fix | Delete
'</div>' .
[220] Fix | Delete
'<div class="elementor-maintenance-mode-description" data-value="maintenance" style="display: none">' .
[221] Fix | Delete
esc_html__( 'Maintenance Mode returns HTTP 503 code, so search engines know to come back a short time later. It is not recommended to use this mode for more than a couple of days.', 'elementor' ) .
[222] Fix | Delete
'</div>' .
[223] Fix | Delete
'<div class="elementor-maintenance-mode-description" data-value="coming_soon" style="display: none">' .
[224] Fix | Delete
esc_html__( 'Coming Soon returns HTTP 200 code, meaning the site is ready to be indexed.', 'elementor' ) .
[225] Fix | Delete
'</div>',
[226] Fix | Delete
],
[227] Fix | Delete
],
[228] Fix | Delete
'maintenance_mode_exclude_mode' => [
[229] Fix | Delete
'label' => esc_html__( 'Who Can Access', 'elementor' ),
[230] Fix | Delete
'field_args' => [
[231] Fix | Delete
'class' => 'elementor-default-hide',
[232] Fix | Delete
'type' => 'select',
[233] Fix | Delete
'std' => 'logged_in',
[234] Fix | Delete
'options' => [
[235] Fix | Delete
'logged_in' => esc_html__( 'Logged In', 'elementor' ),
[236] Fix | Delete
'custom' => esc_html__( 'Custom', 'elementor' ),
[237] Fix | Delete
],
[238] Fix | Delete
],
[239] Fix | Delete
],
[240] Fix | Delete
'maintenance_mode_exclude_roles' => [
[241] Fix | Delete
'label' => esc_html__( 'Roles', 'elementor' ),
[242] Fix | Delete
'field_args' => [
[243] Fix | Delete
'class' => 'elementor-default-hide',
[244] Fix | Delete
'type' => 'checkbox_list_roles',
[245] Fix | Delete
],
[246] Fix | Delete
'setting_args' => [ __NAMESPACE__ . '\Settings_Validations', 'checkbox_list' ],
[247] Fix | Delete
],
[248] Fix | Delete
'maintenance_mode_template_id' => [
[249] Fix | Delete
'label' => esc_html__( 'Choose Template', 'elementor' ),
[250] Fix | Delete
'field_args' => [
[251] Fix | Delete
'class' => 'elementor-default-hide',
[252] Fix | Delete
'type' => 'select',
[253] Fix | Delete
'std' => '',
[254] Fix | Delete
'show_select' => true,
[255] Fix | Delete
'options' => $templates_options,
[256] Fix | Delete
'desc' => $template_description,
[257] Fix | Delete
],
[258] Fix | Delete
],
[259] Fix | Delete
],
[260] Fix | Delete
],
[261] Fix | Delete
],
[262] Fix | Delete
]
[263] Fix | Delete
);
[264] Fix | Delete
}
[265] Fix | Delete
[266] Fix | Delete
/**
[267] Fix | Delete
* Add menu in admin bar.
[268] Fix | Delete
*
[269] Fix | Delete
* Adds "Maintenance Mode" items to the WordPress admin bar.
[270] Fix | Delete
*
[271] Fix | Delete
* Fired by `admin_bar_menu` filter.
[272] Fix | Delete
*
[273] Fix | Delete
* @since 1.4.0
[274] Fix | Delete
* @access public
[275] Fix | Delete
*
[276] Fix | Delete
* @param \WP_Admin_Bar $wp_admin_bar WP_Admin_Bar instance, passed by reference.
[277] Fix | Delete
*/
[278] Fix | Delete
public function add_menu_in_admin_bar( \WP_Admin_Bar $wp_admin_bar ) {
[279] Fix | Delete
$wp_admin_bar->add_node( [
[280] Fix | Delete
'id' => 'elementor-maintenance-on',
[281] Fix | Delete
'title' => esc_html__( 'Maintenance Mode ON', 'elementor' ),
[282] Fix | Delete
'href' => Tools::get_url() . '#tab-maintenance_mode',
[283] Fix | Delete
] );
[284] Fix | Delete
[285] Fix | Delete
$document = Plugin::$instance->documents->get( self::get( 'template_id' ) );
[286] Fix | Delete
[287] Fix | Delete
$wp_admin_bar->add_node( [
[288] Fix | Delete
'id' => 'elementor-maintenance-edit',
[289] Fix | Delete
'parent' => 'elementor-maintenance-on',
[290] Fix | Delete
'title' => esc_html__( 'Edit Template', 'elementor' ),
[291] Fix | Delete
'href' => $document ? $document->get_edit_url() : '',
[292] Fix | Delete
] );
[293] Fix | Delete
}
[294] Fix | Delete
[295] Fix | Delete
/**
[296] Fix | Delete
* Print style.
[297] Fix | Delete
*
[298] Fix | Delete
* Adds custom CSS to the HEAD html tag. The CSS that emphasise the maintenance
[299] Fix | Delete
* mode with red colors.
[300] Fix | Delete
*
[301] Fix | Delete
* Fired by `admin_head` and `wp_head` filters.
[302] Fix | Delete
*
[303] Fix | Delete
* @since 1.4.0
[304] Fix | Delete
* @access public
[305] Fix | Delete
*/
[306] Fix | Delete
public function print_style() {
[307] Fix | Delete
?>
[308] Fix | Delete
<style>#wp-admin-bar-elementor-maintenance-on > a { background-color: #dc3232; }
[309] Fix | Delete
#wp-admin-bar-elementor-maintenance-on > .ab-item:before { content: "\f160"; top: 2px; }</style>
[310] Fix | Delete
<?php
[311] Fix | Delete
}
[312] Fix | Delete
[313] Fix | Delete
public function on_update_mode( $old_value, $value ) {
[314] Fix | Delete
if ( $old_value !== $value ) {
[315] Fix | Delete
do_action( 'elementor/maintenance_mode/mode_changed', $old_value, $value );
[316] Fix | Delete
}
[317] Fix | Delete
}
[318] Fix | Delete
[319] Fix | Delete
/**
[320] Fix | Delete
* Maintenance mode constructor.
[321] Fix | Delete
*
[322] Fix | Delete
* Initializing Elementor maintenance mode.
[323] Fix | Delete
*
[324] Fix | Delete
* @since 1.4.0
[325] Fix | Delete
* @access public
[326] Fix | Delete
*/
[327] Fix | Delete
public function __construct() {
[328] Fix | Delete
add_action( 'update_option_elementor_maintenance_mode_mode', [ $this, 'on_update_mode' ], 10, 2 );
[329] Fix | Delete
[330] Fix | Delete
$is_enabled = (bool) self::get( 'mode' ) && (bool) self::get( 'template_id' );
[331] Fix | Delete
[332] Fix | Delete
if ( is_admin() ) {
[333] Fix | Delete
$page_id = Tools::PAGE_ID;
[334] Fix | Delete
add_action( "elementor/admin/after_create_settings/{$page_id}", [ $this, 'register_settings_fields' ] );
[335] Fix | Delete
}
[336] Fix | Delete
[337] Fix | Delete
if ( ! $is_enabled ) {
[338] Fix | Delete
return;
[339] Fix | Delete
}
[340] Fix | Delete
[341] Fix | Delete
add_action( 'admin_bar_menu', [ $this, 'add_menu_in_admin_bar' ], 300 );
[342] Fix | Delete
add_action( 'admin_head', [ $this, 'print_style' ] );
[343] Fix | Delete
add_action( 'wp_head', [ $this, 'print_style' ] );
[344] Fix | Delete
[345] Fix | Delete
// Priority = 11 that is *after* WP default filter `redirect_canonical` in order to avoid redirection loop.
[346] Fix | Delete
add_action( 'template_redirect', [ $this, 'template_redirect' ], 11 );
[347] Fix | Delete
}
[348] Fix | Delete
[349] Fix | Delete
/**
[350] Fix | Delete
* Print Template Description
[351] Fix | Delete
*
[352] Fix | Delete
* Prints the template description
[353] Fix | Delete
*
[354] Fix | Delete
* @since 2.2.0
[355] Fix | Delete
* @access private
[356] Fix | Delete
*/
[357] Fix | Delete
private function print_template_description() {
[358] Fix | Delete
$template_id = self::get( 'template_id' );
[359] Fix | Delete
[360] Fix | Delete
$edit_url = '';
[361] Fix | Delete
[362] Fix | Delete
if ( $template_id && get_post( $template_id ) ) {
[363] Fix | Delete
$edit_url = Plugin::$instance->documents->get( $template_id )->get_edit_url();
[364] Fix | Delete
}
[365] Fix | Delete
[366] Fix | Delete
?>
[367] Fix | Delete
<a target="_blank" class="elementor-edit-template" style="display: none" href="<?php echo esc_url( $edit_url ); ?>"><?php echo esc_html__( 'Edit Template', 'elementor' ); ?></a>
[368] Fix | Delete
<div class="elementor-maintenance-mode-error"><?php echo esc_html__( 'To enable maintenance mode you have to set a template for the maintenance mode page.', 'elementor' ); ?></div>
[369] Fix | Delete
<div class="elementor-maintenance-mode-error">
[370] Fix | Delete
<?php
[371] Fix | Delete
printf(
[372] Fix | Delete
/* translators: %1$s Link open tag, %2$s: Link close tag. */
[373] Fix | Delete
esc_html__( 'Select one or go ahead and %1$screate one%2$s now.', 'elementor' ),
[374] Fix | Delete
'<a target="_blank" href="' . esc_url( admin_url( 'post-new.php?post_type=' . Source_Local::CPT ) ) . '">',
[375] Fix | Delete
'</a>'
[376] Fix | Delete
);
[377] Fix | Delete
?>
[378] Fix | Delete
</div>
[379] Fix | Delete
<?php
[380] Fix | Delete
}
[381] Fix | Delete
}
[382] Fix | Delete
[383] Fix | Delete
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function