Current File : /home/escuelai/public_html/wp-content/plugins/w3-total-cache/Cdn_Page.php |
<?php
/**
* File: Cdn_Page.php
*
* @package W3TC
*/
namespace W3TC;
/**
* Class Cdn_Page
*
* phpcs:disable PSR2.Classes.PropertyDeclaration.Underscore
* phpcs:disable WordPress.PHP.NoSilencedErrors.Discouraged
*/
class Cdn_Page extends Base_Page_Settings {
/**
* Current page.
*
* @var string
*/
protected $_page = 'w3tc_cdn';
/**
* Displays the CDN settings page.
*
* This method retrieves the CDN-related configuration settings and checks if the CDN is enabled and authorized.
* It also checks if the engine supports mirroring and purging, as well as whether minification and browser cache
* settings are enabled. The necessary settings are then passed to the view for rendering the CDN options page.
*
* @return void
*/
public function view() {
$config = Dispatcher::config();
$cdn_engine = $config->get_string( 'cdn.engine' );
$cdn_enabled = $config->get_boolean( 'cdn.enabled' );
$cdnfsd_engine = $config->get_string( 'cdnfsd.engine' );
$cdnfsd_enabled = $config->get_boolean( 'cdnfsd.enabled' );
$cdn_mirror = Cdn_Util::is_engine_mirror( $cdn_engine );
$cdn_mirror_purge_all = Cdn_Util::can_purge_all( $cdn_engine );
$cdn_common = Dispatcher::component( 'Cdn_Core' );
$cdn = $cdn_common->get_cdn();
$cdn_supports_header = W3TC_CDN_HEADER_MIRRORING === $cdn->headers_support();
$minify_enabled = (
$config->get_boolean( 'minify.enabled' ) &&
Util_Rule::can_check_rules() &&
$config->get_boolean( 'minify.rewrite' ) &&
( ! $config->get_boolean( 'minify.auto' ) || Cdn_Util::is_engine_mirror( $config->get_string( 'cdn.engine' ) ) )
);
$cookie_domain = $this->get_cookie_domain();
$set_cookie_domain = $this->is_cookie_domain_enabled();
// Required for Update Media Query String button.
$browsercache_enabled = $config->get_boolean( 'browsercache.enabled' );
$browsercache_update_media_qs = ( $config->get_boolean( 'browsercache.cssjs.replace' ) || $config->get_boolean( 'browsercache.other.replace' ) );
// Get CDN and CDN FSD status.
$cdn_core = new Cdn_Core();
$is_cdn_authorized = $cdn_core->is_cdn_authorized();
$is_cdnfsd_authorized = $cdn_core->is_cdnfsd_authorized();
include W3TC_INC_DIR . '/options/cdn.php';
}
/**
* Retrieves the domain for the site's cookie.
*
* This method retrieves the domain of the site where the cookie will be set, typically used to determine the
* correct domain for cookies. It first attempts to parse the site URL from the WordPress settings, and if that
* fails, it uses the HTTP_HOST from the server.
*
* @return string The domain name of the site for cookies.
*/
public function get_cookie_domain() {
$site_url = get_option( 'siteurl' );
$parse_url = @wp_parse_url( $site_url );
if ( $parse_url && ! empty( $parse_url['host'] ) ) {
return $parse_url['host'];
}
return isset( $_SERVER['HTTP_HOST'] ) ? sanitize_text_field( wp_unslash( $_SERVER['HTTP_HOST'] ) ) : '';
}
/**
* Checks if the cookie domain is enabled.
*
* This method compares the site's cookie domain to the value defined in the `COOKIE_DOMAIN` constant.
* It returns true if the `COOKIE_DOMAIN` constant is defined and matches the site's cookie domain.
*
* @return bool True if the cookie domain is enabled, false otherwise.
*/
public function is_cookie_domain_enabled() {
$cookie_domain = $this->get_cookie_domain();
return defined( 'COOKIE_DOMAIN' ) && COOKIE_DOMAIN === $cookie_domain;
}
}