Current File : /home/escuelai/public_html/wp-content/plugins/w3-total-cache/Mobile_Referrer.php |
<?php
/**
* File: Mobile_Referrer.php
*
* @package W3TC
*/
namespace W3TC;
// W3TC Referrer detection.
define( 'W3TC_REFERRER_COOKIE_NAME', 'w3tc_referrer' );
/**
* Class Mobile_Referrer
*/
class Mobile_Referrer extends Mobile_Base {
/**
* Constructs the Mobile_Referrer object.
*
* Initializes the parent class with specific group and referrer settings.
*
* @return void
*/
public function __construct() {
parent::__construct( 'referrer.rgroups', 'referrers' );
}
/**
* Retrieves the HTTP referrer from cookies or the server.
*
* If enabled groups are present, attempts to get the HTTP referrer from a cookie or the server.
* Sets or clears cookies based on conditions.
*
* @return string The sanitized HTTP referrer or an empty string if not available.
*/
public function get_http_referrer() {
$http_referrer = '';
if ( $this->has_enabled_groups() ) {
if ( isset( $_COOKIE[ W3TC_REFERRER_COOKIE_NAME ] ) ) {
$http_referrer = htmlspecialchars( $_COOKIE[ W3TC_REFERRER_COOKIE_NAME ] ); // phpcs:ignore
} elseif ( isset( $_SERVER['HTTP_REFERER'] ) ) {
$http_referrer = filter_var( $_SERVER['HTTP_REFERER'], FILTER_SANITIZE_URL ); // phpcs:ignore
setcookie( W3TC_REFERRER_COOKIE_NAME, $http_referrer, 0, '/' /* not defined yet Util_Environment::network_home_url_uri()*/ );
}
} elseif ( isset( $_COOKIE[ W3TC_REFERRER_COOKIE_NAME ] ) ) {
setcookie( W3TC_REFERRER_COOKIE_NAME, '', 1 );
}
return $http_referrer;
}
/**
* Verifies if the HTTP referrer matches a specified group comparison value.
*
* Uses a static reference to store the HTTP referrer for efficient reuse.
* Matches the referrer against a regular expression provided in `$group_compare_value`.
*
* @param string $group_compare_value The regex pattern to compare against the HTTP referrer.
*
* @return bool True if the referrer matches the provided pattern, false otherwise.
*/
public function group_verifier( $group_compare_value ) {
static $http_referrer = null;
if ( is_null( $http_referrer ) ) {
$http_referrer = $this->get_http_referrer();
}
return $http_referrer && preg_match( '~' . $group_compare_value . '~i', $http_referrer );
}
/**
* Retrieves the group HTTP referrer.
*
* This method acts as a wrapper for `get_http_referrer`.
*
* @return string The sanitized HTTP referrer.
*/
public function do_get_group() {
return $this->get_http_referrer();
}
}