Edit File by line
/home/zeestwma/richards.../wp-conte.../plugins/litespee.../src
File: vary.cls.php
<?php
[0] Fix | Delete
[1] Fix | Delete
/**
[2] Fix | Delete
* The plugin vary class to manage X-LiteSpeed-Vary
[3] Fix | Delete
*
[4] Fix | Delete
* @since 1.1.3
[5] Fix | Delete
*/
[6] Fix | Delete
[7] Fix | Delete
namespace LiteSpeed;
[8] Fix | Delete
[9] Fix | Delete
defined('WPINC') || exit();
[10] Fix | Delete
[11] Fix | Delete
class Vary extends Root
[12] Fix | Delete
{
[13] Fix | Delete
const X_HEADER = 'X-LiteSpeed-Vary';
[14] Fix | Delete
[15] Fix | Delete
private static $_vary_name = '_lscache_vary'; // this default vary cookie is used for logged in status check
[16] Fix | Delete
private static $_can_change_vary = false; // Currently only AJAX used this
[17] Fix | Delete
[18] Fix | Delete
/**
[19] Fix | Delete
* Adds the actions used for setting up cookies on log in/out.
[20] Fix | Delete
*
[21] Fix | Delete
* Also checks if the database matches the rewrite rule.
[22] Fix | Delete
*
[23] Fix | Delete
* @since 1.0.4
[24] Fix | Delete
*/
[25] Fix | Delete
public function init()
[26] Fix | Delete
{
[27] Fix | Delete
$this->_update_vary_name();
[28] Fix | Delete
}
[29] Fix | Delete
[30] Fix | Delete
/**
[31] Fix | Delete
* Update the default vary name if changed
[32] Fix | Delete
*
[33] Fix | Delete
* @since 4.0
[34] Fix | Delete
*/
[35] Fix | Delete
private function _update_vary_name()
[36] Fix | Delete
{
[37] Fix | Delete
$db_cookie = $this->conf(Base::O_CACHE_LOGIN_COOKIE); // [3.0] todo: check if works in network's sites
[38] Fix | Delete
[39] Fix | Delete
// If no vary set in rewrite rule
[40] Fix | Delete
if (!isset($_SERVER['LSCACHE_VARY_COOKIE'])) {
[41] Fix | Delete
if ($db_cookie) {
[42] Fix | Delete
// Display cookie error msg to admin
[43] Fix | Delete
if (is_multisite() ? is_network_admin() : is_admin()) {
[44] Fix | Delete
Admin_Display::show_error_cookie();
[45] Fix | Delete
}
[46] Fix | Delete
Control::set_nocache('vary cookie setting error');
[47] Fix | Delete
return;
[48] Fix | Delete
}
[49] Fix | Delete
return;
[50] Fix | Delete
}
[51] Fix | Delete
// If db setting does not exist, skip checking db value
[52] Fix | Delete
if (!$db_cookie) {
[53] Fix | Delete
return;
[54] Fix | Delete
}
[55] Fix | Delete
[56] Fix | Delete
// beyond this point, need to make sure db vary setting is in $_SERVER env.
[57] Fix | Delete
$vary_arr = explode(',', $_SERVER['LSCACHE_VARY_COOKIE']);
[58] Fix | Delete
[59] Fix | Delete
if (in_array($db_cookie, $vary_arr)) {
[60] Fix | Delete
self::$_vary_name = $db_cookie;
[61] Fix | Delete
return;
[62] Fix | Delete
}
[63] Fix | Delete
[64] Fix | Delete
if (is_multisite() ? is_network_admin() : is_admin()) {
[65] Fix | Delete
Admin_Display::show_error_cookie();
[66] Fix | Delete
}
[67] Fix | Delete
Control::set_nocache('vary cookie setting lost error');
[68] Fix | Delete
}
[69] Fix | Delete
[70] Fix | Delete
/**
[71] Fix | Delete
* Hooks after user init
[72] Fix | Delete
*
[73] Fix | Delete
* @since 4.0
[74] Fix | Delete
*/
[75] Fix | Delete
public function after_user_init()
[76] Fix | Delete
{
[77] Fix | Delete
// logged in user
[78] Fix | Delete
if (Router::is_logged_in()) {
[79] Fix | Delete
// If not esi, check cache logged-in user setting
[80] Fix | Delete
if (!$this->cls('Router')->esi_enabled()) {
[81] Fix | Delete
// If cache logged-in, then init cacheable to private
[82] Fix | Delete
if ($this->conf(Base::O_CACHE_PRIV)) {
[83] Fix | Delete
add_action('wp_logout', __NAMESPACE__ . '\Purge::purge_on_logout');
[84] Fix | Delete
[85] Fix | Delete
$this->cls('Control')->init_cacheable();
[86] Fix | Delete
Control::set_private('logged in user');
[87] Fix | Delete
}
[88] Fix | Delete
// No cache for logged-in user
[89] Fix | Delete
else {
[90] Fix | Delete
Control::set_nocache('logged in user');
[91] Fix | Delete
}
[92] Fix | Delete
}
[93] Fix | Delete
// ESI is on, can be public cache
[94] Fix | Delete
else {
[95] Fix | Delete
// Need to make sure vary is using group id
[96] Fix | Delete
$this->cls('Control')->init_cacheable();
[97] Fix | Delete
}
[98] Fix | Delete
[99] Fix | Delete
// register logout hook to clear login status
[100] Fix | Delete
add_action('clear_auth_cookie', array($this, 'remove_logged_in'));
[101] Fix | Delete
} else {
[102] Fix | Delete
// Only after vary init, can detect if is Guest mode or not
[103] Fix | Delete
$this->_maybe_guest_mode();
[104] Fix | Delete
[105] Fix | Delete
// Set vary cookie for logging in user, otherwise the user will hit public with vary=0 (guest version)
[106] Fix | Delete
add_action('set_logged_in_cookie', array($this, 'add_logged_in'), 10, 4);
[107] Fix | Delete
add_action('wp_login', __NAMESPACE__ . '\Purge::purge_on_logout');
[108] Fix | Delete
[109] Fix | Delete
$this->cls('Control')->init_cacheable();
[110] Fix | Delete
[111] Fix | Delete
// Check `login page` cacheable setting because they don't go through main WP logic
[112] Fix | Delete
add_action('login_init', array($this->cls('Tag'), 'check_login_cacheable'), 5);
[113] Fix | Delete
[114] Fix | Delete
if (!empty($_GET['litespeed_guest'])) {
[115] Fix | Delete
add_action('wp_loaded', array($this, 'update_guest_vary'), 20);
[116] Fix | Delete
}
[117] Fix | Delete
}
[118] Fix | Delete
[119] Fix | Delete
// Add comment list ESI
[120] Fix | Delete
add_filter('comments_array', array($this, 'check_commenter'));
[121] Fix | Delete
[122] Fix | Delete
// Set vary cookie for commenter.
[123] Fix | Delete
add_action('set_comment_cookies', array($this, 'append_commenter'));
[124] Fix | Delete
[125] Fix | Delete
/**
[126] Fix | Delete
* Don't change for REST call because they don't carry on user info usually
[127] Fix | Delete
* @since 1.6.7
[128] Fix | Delete
*/
[129] Fix | Delete
add_action('rest_api_init', function () {
[130] Fix | Delete
// this hook is fired in `init` hook
[131] Fix | Delete
Debug2::debug('[Vary] Rest API init disabled vary change');
[132] Fix | Delete
add_filter('litespeed_can_change_vary', '__return_false');
[133] Fix | Delete
});
[134] Fix | Delete
}
[135] Fix | Delete
[136] Fix | Delete
/**
[137] Fix | Delete
* Check if is Guest mode or not
[138] Fix | Delete
*
[139] Fix | Delete
* @since 4.0
[140] Fix | Delete
*/
[141] Fix | Delete
private function _maybe_guest_mode()
[142] Fix | Delete
{
[143] Fix | Delete
if (defined('LITESPEED_GUEST')) {
[144] Fix | Delete
Debug2::debug('[Vary] 👒👒 Guest mode ' . (LITESPEED_GUEST ? 'predefined' : 'turned off'));
[145] Fix | Delete
return;
[146] Fix | Delete
}
[147] Fix | Delete
[148] Fix | Delete
if (!$this->conf(Base::O_GUEST)) {
[149] Fix | Delete
return;
[150] Fix | Delete
}
[151] Fix | Delete
[152] Fix | Delete
// If vary is set, then not a guest
[153] Fix | Delete
if (self::has_vary()) {
[154] Fix | Delete
return;
[155] Fix | Delete
}
[156] Fix | Delete
[157] Fix | Delete
// If has admin QS, then no guest
[158] Fix | Delete
if (!empty($_GET[Router::ACTION])) {
[159] Fix | Delete
return;
[160] Fix | Delete
}
[161] Fix | Delete
[162] Fix | Delete
if (defined('DOING_AJAX')) {
[163] Fix | Delete
return;
[164] Fix | Delete
}
[165] Fix | Delete
[166] Fix | Delete
if (defined('DOING_CRON')) {
[167] Fix | Delete
return;
[168] Fix | Delete
}
[169] Fix | Delete
[170] Fix | Delete
// If is the request to update vary, then no guest
[171] Fix | Delete
// Don't need anymore as it is always ajax call
[172] Fix | Delete
// Still keep it in case some WP blocked the lightweight guest vary update script, WP can still update the vary
[173] Fix | Delete
if (!empty($_GET['litespeed_guest'])) {
[174] Fix | Delete
return;
[175] Fix | Delete
}
[176] Fix | Delete
[177] Fix | Delete
/* @ref https://wordpress.org/support/topic/checkout-add-to-cart-executed-twice/ */
[178] Fix | Delete
if (!empty($_GET['litespeed_guest_off'])) {
[179] Fix | Delete
return;
[180] Fix | Delete
}
[181] Fix | Delete
[182] Fix | Delete
Debug2::debug('[Vary] 👒👒 Guest mode');
[183] Fix | Delete
[184] Fix | Delete
!defined('LITESPEED_GUEST') && define('LITESPEED_GUEST', true);
[185] Fix | Delete
[186] Fix | Delete
if ($this->conf(Base::O_GUEST_OPTM)) {
[187] Fix | Delete
!defined('LITESPEED_GUEST_OPTM') && define('LITESPEED_GUEST_OPTM', true);
[188] Fix | Delete
}
[189] Fix | Delete
}
[190] Fix | Delete
[191] Fix | Delete
/**
[192] Fix | Delete
* Update Guest vary
[193] Fix | Delete
*
[194] Fix | Delete
* @since 4.0
[195] Fix | Delete
* @deprecated 4.1 Use independent lightweight guest.vary.php as a replacement
[196] Fix | Delete
*/
[197] Fix | Delete
public function update_guest_vary()
[198] Fix | Delete
{
[199] Fix | Delete
// This process must not be cached
[200] Fix | Delete
!defined('LSCACHE_NO_CACHE') && define('LSCACHE_NO_CACHE', true);
[201] Fix | Delete
[202] Fix | Delete
$_guest = new Lib\Guest();
[203] Fix | Delete
if ($_guest->always_guest() || self::has_vary()) {
[204] Fix | Delete
// If contains vary already, don't reload to avoid infinite loop when parent page having browser cache
[205] Fix | Delete
!defined('LITESPEED_GUEST') && define('LITESPEED_GUEST', true); // Reuse this const to bypass set vary in vary finalize
[206] Fix | Delete
Debug2::debug('[Vary] 🤠🤠 Guest');
[207] Fix | Delete
echo '[]';
[208] Fix | Delete
exit();
[209] Fix | Delete
}
[210] Fix | Delete
[211] Fix | Delete
Debug2::debug('[Vary] Will update guest vary in finalize');
[212] Fix | Delete
[213] Fix | Delete
// return json
[214] Fix | Delete
echo \json_encode(array('reload' => 'yes'));
[215] Fix | Delete
exit();
[216] Fix | Delete
}
[217] Fix | Delete
[218] Fix | Delete
/**
[219] Fix | Delete
* Hooked to the comments_array filter.
[220] Fix | Delete
*
[221] Fix | Delete
* Check if the user accessing the page has the commenter cookie.
[222] Fix | Delete
*
[223] Fix | Delete
* If the user does not want to cache commenters, just check if user is commenter.
[224] Fix | Delete
* Otherwise if the vary cookie is set, unset it. This is so that when the page is cached, the page will appear as if the user was a normal user.
[225] Fix | Delete
* Normal user is defined as not a logged in user and not a commenter.
[226] Fix | Delete
*
[227] Fix | Delete
* @since 1.0.4
[228] Fix | Delete
* @access public
[229] Fix | Delete
* @global type $post
[230] Fix | Delete
* @param array $comments The current comments to output
[231] Fix | Delete
* @return array The comments to output.
[232] Fix | Delete
*/
[233] Fix | Delete
public function check_commenter($comments)
[234] Fix | Delete
{
[235] Fix | Delete
/**
[236] Fix | Delete
* Hook to bypass pending comment check for comment related plugins compatibility
[237] Fix | Delete
* @since 2.9.5
[238] Fix | Delete
*/
[239] Fix | Delete
if (apply_filters('litespeed_vary_check_commenter_pending', true)) {
[240] Fix | Delete
$pending = false;
[241] Fix | Delete
foreach ($comments as $comment) {
[242] Fix | Delete
if (!$comment->comment_approved) {
[243] Fix | Delete
// current user has pending comment
[244] Fix | Delete
$pending = true;
[245] Fix | Delete
break;
[246] Fix | Delete
}
[247] Fix | Delete
}
[248] Fix | Delete
[249] Fix | Delete
// No pending comments, don't need to add private cache
[250] Fix | Delete
if (!$pending) {
[251] Fix | Delete
Debug2::debug('[Vary] No pending comment');
[252] Fix | Delete
$this->remove_commenter();
[253] Fix | Delete
[254] Fix | Delete
// Remove commenter prefilled info if exists, for public cache
[255] Fix | Delete
foreach ($_COOKIE as $cookie_name => $cookie_value) {
[256] Fix | Delete
if (strlen($cookie_name) >= 15 && strpos($cookie_name, 'comment_author_') === 0) {
[257] Fix | Delete
unset($_COOKIE[$cookie_name]);
[258] Fix | Delete
}
[259] Fix | Delete
}
[260] Fix | Delete
[261] Fix | Delete
return $comments;
[262] Fix | Delete
}
[263] Fix | Delete
}
[264] Fix | Delete
[265] Fix | Delete
// Current user/visitor has pending comments
[266] Fix | Delete
// set vary=2 for next time vary lookup
[267] Fix | Delete
$this->add_commenter();
[268] Fix | Delete
[269] Fix | Delete
if ($this->conf(Base::O_CACHE_COMMENTER)) {
[270] Fix | Delete
Control::set_private('existing commenter');
[271] Fix | Delete
} else {
[272] Fix | Delete
Control::set_nocache('existing commenter');
[273] Fix | Delete
}
[274] Fix | Delete
[275] Fix | Delete
return $comments;
[276] Fix | Delete
}
[277] Fix | Delete
[278] Fix | Delete
/**
[279] Fix | Delete
* Check if default vary has a value
[280] Fix | Delete
*
[281] Fix | Delete
* @since 1.1.3
[282] Fix | Delete
* @access public
[283] Fix | Delete
*/
[284] Fix | Delete
public static function has_vary()
[285] Fix | Delete
{
[286] Fix | Delete
if (empty($_COOKIE[self::$_vary_name])) {
[287] Fix | Delete
return false;
[288] Fix | Delete
}
[289] Fix | Delete
return $_COOKIE[self::$_vary_name];
[290] Fix | Delete
}
[291] Fix | Delete
[292] Fix | Delete
/**
[293] Fix | Delete
* Append user status with logged in
[294] Fix | Delete
*
[295] Fix | Delete
* @since 1.1.3
[296] Fix | Delete
* @since 1.6.2 Removed static referral
[297] Fix | Delete
* @access public
[298] Fix | Delete
*/
[299] Fix | Delete
public function add_logged_in($logged_in_cookie = false, $expire = false, $expiration = false, $uid = false)
[300] Fix | Delete
{
[301] Fix | Delete
Debug2::debug('[Vary] add_logged_in');
[302] Fix | Delete
[303] Fix | Delete
/**
[304] Fix | Delete
* NOTE: Run before `$this->_update_default_vary()` to make vary changeable
[305] Fix | Delete
* @since 2.2.2
[306] Fix | Delete
*/
[307] Fix | Delete
self::can_ajax_vary();
[308] Fix | Delete
[309] Fix | Delete
// If the cookie is lost somehow, set it
[310] Fix | Delete
$this->_update_default_vary($uid, $expire);
[311] Fix | Delete
}
[312] Fix | Delete
[313] Fix | Delete
/**
[314] Fix | Delete
* Remove user logged in status
[315] Fix | Delete
*
[316] Fix | Delete
* @since 1.1.3
[317] Fix | Delete
* @since 1.6.2 Removed static referral
[318] Fix | Delete
* @access public
[319] Fix | Delete
*/
[320] Fix | Delete
public function remove_logged_in()
[321] Fix | Delete
{
[322] Fix | Delete
Debug2::debug('[Vary] remove_logged_in');
[323] Fix | Delete
[324] Fix | Delete
/**
[325] Fix | Delete
* NOTE: Run before `$this->_update_default_vary()` to make vary changeable
[326] Fix | Delete
* @since 2.2.2
[327] Fix | Delete
*/
[328] Fix | Delete
self::can_ajax_vary();
[329] Fix | Delete
[330] Fix | Delete
// Force update vary to remove login status
[331] Fix | Delete
$this->_update_default_vary(-1);
[332] Fix | Delete
}
[333] Fix | Delete
[334] Fix | Delete
/**
[335] Fix | Delete
* Allow vary can be changed for ajax calls
[336] Fix | Delete
*
[337] Fix | Delete
* @since 2.2.2
[338] Fix | Delete
* @since 2.6 Changed to static
[339] Fix | Delete
* @access public
[340] Fix | Delete
*/
[341] Fix | Delete
public static function can_ajax_vary()
[342] Fix | Delete
{
[343] Fix | Delete
Debug2::debug('[Vary] _can_change_vary -> true');
[344] Fix | Delete
self::$_can_change_vary = true;
[345] Fix | Delete
}
[346] Fix | Delete
[347] Fix | Delete
/**
[348] Fix | Delete
* Check if can change default vary
[349] Fix | Delete
*
[350] Fix | Delete
* @since 1.6.2
[351] Fix | Delete
* @access private
[352] Fix | Delete
*/
[353] Fix | Delete
private function can_change_vary()
[354] Fix | Delete
{
[355] Fix | Delete
// Don't change for ajax due to ajax not sending webp header
[356] Fix | Delete
if (Router::is_ajax()) {
[357] Fix | Delete
if (!self::$_can_change_vary) {
[358] Fix | Delete
Debug2::debug('[Vary] can_change_vary bypassed due to ajax call');
[359] Fix | Delete
return false;
[360] Fix | Delete
}
[361] Fix | Delete
}
[362] Fix | Delete
[363] Fix | Delete
/**
[364] Fix | Delete
* POST request can set vary to fix #820789 login "loop" guest cache issue
[365] Fix | Delete
* @since 1.6.5
[366] Fix | Delete
*/
[367] Fix | Delete
if (isset($_SERVER['REQUEST_METHOD']) && $_SERVER['REQUEST_METHOD'] !== 'GET' && $_SERVER['REQUEST_METHOD'] !== 'POST') {
[368] Fix | Delete
Debug2::debug('[Vary] can_change_vary bypassed due to method not get/post');
[369] Fix | Delete
return false;
[370] Fix | Delete
}
[371] Fix | Delete
[372] Fix | Delete
/**
[373] Fix | Delete
* Disable vary change if is from crawler
[374] Fix | Delete
* @since 2.9.8 To enable woocommerce cart not empty warm up (@Taba)
[375] Fix | Delete
*/
[376] Fix | Delete
if (!empty($_SERVER['HTTP_USER_AGENT']) && strpos($_SERVER['HTTP_USER_AGENT'], Crawler::FAST_USER_AGENT) === 0) {
[377] Fix | Delete
Debug2::debug('[Vary] can_change_vary bypassed due to crawler');
[378] Fix | Delete
return false;
[379] Fix | Delete
}
[380] Fix | Delete
[381] Fix | Delete
if (!apply_filters('litespeed_can_change_vary', true)) {
[382] Fix | Delete
Debug2::debug('[Vary] can_change_vary bypassed due to litespeed_can_change_vary hook');
[383] Fix | Delete
return false;
[384] Fix | Delete
}
[385] Fix | Delete
[386] Fix | Delete
return true;
[387] Fix | Delete
}
[388] Fix | Delete
[389] Fix | Delete
/**
[390] Fix | Delete
* Update default vary
[391] Fix | Delete
*
[392] Fix | Delete
* @since 1.6.2
[393] Fix | Delete
* @since 1.6.6.1 Add ran check to make it only run once ( No run multiple times due to login process doesn't have valid uid )
[394] Fix | Delete
* @access private
[395] Fix | Delete
*/
[396] Fix | Delete
private function _update_default_vary($uid = false, $expire = false)
[397] Fix | Delete
{
[398] Fix | Delete
// Make sure header output only run once
[399] Fix | Delete
if (!defined('LITESPEED_DID_' . __FUNCTION__)) {
[400] Fix | Delete
define('LITESPEED_DID_' . __FUNCTION__, true);
[401] Fix | Delete
} else {
[402] Fix | Delete
Debug2::debug2('[Vary] _update_default_vary bypassed due to run already');
[403] Fix | Delete
return;
[404] Fix | Delete
}
[405] Fix | Delete
[406] Fix | Delete
// If the cookie is lost somehow, set it
[407] Fix | Delete
$vary = $this->finalize_default_vary($uid);
[408] Fix | Delete
$current_vary = self::has_vary();
[409] Fix | Delete
if ($current_vary !== $vary && $current_vary !== 'commenter' && $this->can_change_vary()) {
[410] Fix | Delete
// $_COOKIE[ self::$_vary_name ] = $vary; // not needed
[411] Fix | Delete
[412] Fix | Delete
// save it
[413] Fix | Delete
if (!$expire) {
[414] Fix | Delete
$expire = time() + 2 * DAY_IN_SECONDS;
[415] Fix | Delete
}
[416] Fix | Delete
$this->_cookie($vary, $expire);
[417] Fix | Delete
Debug2::debug("[Vary] set_cookie ---> $vary");
[418] Fix | Delete
// Control::set_nocache( 'changing default vary' . " $current_vary => $vary" );
[419] Fix | Delete
}
[420] Fix | Delete
}
[421] Fix | Delete
[422] Fix | Delete
/**
[423] Fix | Delete
* Get vary name
[424] Fix | Delete
*
[425] Fix | Delete
* @since 1.9.1
[426] Fix | Delete
* @access public
[427] Fix | Delete
*/
[428] Fix | Delete
public function get_vary_name()
[429] Fix | Delete
{
[430] Fix | Delete
return self::$_vary_name;
[431] Fix | Delete
}
[432] Fix | Delete
[433] Fix | Delete
/**
[434] Fix | Delete
* Check if one user role is in vary group settings
[435] Fix | Delete
*
[436] Fix | Delete
* @since 1.2.0
[437] Fix | Delete
* @since 3.0 Moved here from conf.cls
[438] Fix | Delete
* @access public
[439] Fix | Delete
* @param string $role The user role
[440] Fix | Delete
* @return int The set value if already set
[441] Fix | Delete
*/
[442] Fix | Delete
public function in_vary_group($role)
[443] Fix | Delete
{
[444] Fix | Delete
$group = 0;
[445] Fix | Delete
$vary_groups = $this->conf(Base::O_CACHE_VARY_GROUP);
[446] Fix | Delete
[447] Fix | Delete
$roles = explode(',', $role);
[448] Fix | Delete
if ($found = array_intersect($roles, array_keys($vary_groups))) {
[449] Fix | Delete
$groups = array();
[450] Fix | Delete
foreach ($found as $curr_role) {
[451] Fix | Delete
$groups[] = $vary_groups[$curr_role];
[452] Fix | Delete
}
[453] Fix | Delete
$group = implode(',', array_unique($groups));
[454] Fix | Delete
} elseif (in_array('administrator', $roles)) {
[455] Fix | Delete
$group = 99;
[456] Fix | Delete
}
[457] Fix | Delete
[458] Fix | Delete
if ($group) {
[459] Fix | Delete
Debug2::debug2('[Vary] role in vary_group [group] ' . $group);
[460] Fix | Delete
}
[461] Fix | Delete
[462] Fix | Delete
return $group;
[463] Fix | Delete
}
[464] Fix | Delete
[465] Fix | Delete
/**
[466] Fix | Delete
* Finalize default Vary Cookie
[467] Fix | Delete
*
[468] Fix | Delete
* Get user vary tag based on admin_bar & role
[469] Fix | Delete
*
[470] Fix | Delete
* NOTE: Login process will also call this because it does not call wp hook as normal page loading
[471] Fix | Delete
*
[472] Fix | Delete
* @since 1.6.2
[473] Fix | Delete
* @access public
[474] Fix | Delete
*/
[475] Fix | Delete
public function finalize_default_vary($uid = false)
[476] Fix | Delete
{
[477] Fix | Delete
// Must check this to bypass vary generation for guests
[478] Fix | Delete
// Must check this to avoid Guest page's CSS/JS/CCSS/UCSS get non-guest vary filename
[479] Fix | Delete
if (defined('LITESPEED_GUEST') && LITESPEED_GUEST) {
[480] Fix | Delete
return false;
[481] Fix | Delete
}
[482] Fix | Delete
[483] Fix | Delete
$vary = array();
[484] Fix | Delete
[485] Fix | Delete
if ($this->conf(Base::O_GUEST)) {
[486] Fix | Delete
$vary['guest_mode'] = 1;
[487] Fix | Delete
}
[488] Fix | Delete
[489] Fix | Delete
if (!$uid) {
[490] Fix | Delete
$uid = get_current_user_id();
[491] Fix | Delete
} else {
[492] Fix | Delete
Debug2::debug('[Vary] uid: ' . $uid);
[493] Fix | Delete
}
[494] Fix | Delete
[495] Fix | Delete
// get user's group id
[496] Fix | Delete
$role = Router::get_role($uid);
[497] Fix | Delete
[498] Fix | Delete
if ($uid > 0 && $role) {
[499] Fix | Delete
12
It is recommended that you Edit text format, this type of Fix handles quite a lot in one request
Function