Sindbad~EG File Manager
<?php
/**
* File: PgCache_Flush.php
*
* @package W3TC
*/
namespace W3TC;
/**
* Class PgCache_Plugin_Admin
*
* W3 PgCache plugin - administrative interface
*
* phpcs:disable PSR2.Classes.PropertyDeclaration.Underscore
*/
class PgCache_Plugin_Admin {
/**
* Config
*
* @var Config
*/
private $_config = null;
/**
* Initializes the plugin configuration.
*
* @return void
*/
public function __construct() {
$this->_config = Dispatcher::config();
}
/**
* Runs the plugin by registering various filters and actions.
*
* @return void
*/
public function run() {
add_filter( 'w3tc_save_options', array( $this, 'w3tc_save_options' ) );
$config_labels = new PgCache_ConfigLabels();
add_filter( 'w3tc_config_labels', array( $config_labels, 'config_labels' ) );
if ( $this->_config->get_boolean( 'pgcache.enabled' ) ) {
add_filter( 'w3tc_errors', array( $this, 'w3tc_errors' ) );
add_filter( 'w3tc_usage_statistics_summary_from_history', array( $this, 'w3tc_usage_statistics_summary_from_history' ), 10, 2 );
}
// Cache groups.
add_action(
'w3tc_config_ui_save-w3tc_cachegroups',
array(
'\W3TC\CacheGroups_Plugin_Admin',
'w3tc_config_ui_save_w3tc_cachegroups',
),
10,
1
);
}
/**
* Cleans up the cache either locally or in a cluster.
*
* @return void
*/
public function cleanup() {
// We check to see if we're dealing with a cluster.
$config = Dispatcher::config();
$is_cluster = $config->get_boolean( 'cluster.messagebus.enabled' );
// If we are, we notify the subscribers. If not, we just cleanup in here.
if ( $is_cluster ) {
$this->cleanup_cluster();
} else {
$this->cleanup_local();
}
}
/**
* Cleans up the cache in a cluster environment.
*
* @return void
*/
public function cleanup_cluster() {
$sns_client = Dispatcher::component( 'Enterprise_CacheFlush_MakeSnsEvent' );
$sns_client->pgcache_cleanup();
}
/**
* Cleans up the cache in a local environment.
*
* @return void
*/
public function cleanup_local() {
$engine = $this->_config->get_string( 'pgcache.engine' );
switch ( $engine ) {
case 'file':
$w3_cache_file_cleaner = new Cache_File_Cleaner(
array(
'cache_dir' => Util_Environment::cache_blog_dir( 'page' ),
'clean_timelimit' => $this->_config->get_integer( 'timelimit.cache_gc' ),
)
);
$w3_cache_file_cleaner->clean();
break;
case 'file_generic':
if ( 0 === Util_Environment::blog_id() ) {
$flush_dir = W3TC_CACHE_PAGE_ENHANCED_DIR;
} else {
$flush_dir = W3TC_CACHE_PAGE_ENHANCED_DIR . '/' . Util_Environment::host();
}
$w3_cache_file_cleaner_generic = new Cache_File_Cleaner_Generic(
array(
'exclude' => array(
'.htaccess',
),
'cache_dir' => $flush_dir,
'expire' => $this->_config->get_integer( 'pgcache.lifetime' ),
'clean_timelimit' => $this->_config->get_integer( 'timelimit.cache_gc' ),
)
);
$w3_cache_file_cleaner_generic->clean();
break;
}
}
/**
* Primes the cache based on a sitemap or other criteria.
*
* @param int|null $start The starting point for priming, or null to use the default.
* @param int|null $limit The limit for how many pages to prime, or null for the default limit.
* @param callable|null $log_callback A callback function for logging progress, or null to disable logging.
*
* @return void
*/
public function prime( $start = null, $limit = null, $log_callback = null ) {
if ( is_null( $start ) ) {
$start = get_option( 'w3tc_pgcache_prime_offset' );
}
if ( $start < 0 ) {
$start = 0;
}
$interval = $this->_config->get_integer( 'pgcache.prime.interval' );
if ( is_null( $limit ) ) {
$limit = $this->_config->get_integer( 'pgcache.prime.limit' );
}
if ( $limit < 1 ) {
$limit = 1;
}
$sitemap = $this->_config->get_string( 'pgcache.prime.sitemap' );
if ( ! is_null( $log_callback ) ) {
$log_callback(
'Priming from sitemap ' . $sitemap . ' entries ' . ( $start + 1 ) . '..' . ( $start + $limit )
);
}
// Parse XML sitemap.
$urls = $this->parse_sitemap( $sitemap );
// Queue URLs.
$queue = array_slice( $urls, $start, $limit );
if ( count( $urls ) > ( $start + $limit ) ) {
$next_offset = $start + $limit;
} else {
$next_offset = 0;
}
update_option( 'w3tc_pgcache_prime_offset', $next_offset, false );
// Make HTTP requests and prime cache.
// Use 'WordPress' since by default we use W3TC-powered by which blocks caching.
foreach ( $queue as $url ) {
Util_Http::get( $url, array( 'user-agent' => 'WordPress' ) );
if ( ! is_null( $log_callback ) ) {
$log_callback( 'Priming ' . $url );
}
}
}
/**
* Parses a sitemap URL and returns the list of URLs contained in it.
*
* @param string $url The URL of the sitemap to parse.
*
* @return array The list of URLs parsed from the sitemap.
*/
public function parse_sitemap( $url ) {
if ( ! Util_Environment::is_url( $url ) ) {
$url = home_url( $url );
}
$urls = array( $url );
$response = Util_Http::get( $url );
if ( ! is_wp_error( $response ) && 200 === $response['response']['code'] ) {
$url_matches = null;
$sitemap_matches = null;
if ( preg_match_all( '~<!--.*?-->(*SKIP)(*FAIL)|<sitemap>(.*?)</sitemap>~is', $response['body'], $sitemap_matches ) ) {
$loc_matches = null;
foreach ( $sitemap_matches[1] as $sitemap_match ) {
if ( preg_match( '~<loc>(.*?)</loc>~is', $sitemap_match, $loc_matches ) ) {
$loc = trim( $loc_matches[1] );
if ( $loc ) {
$urls = array_merge( $urls, $this->parse_sitemap( $loc ) );
}
}
}
} elseif ( preg_match_all( '~<!--.*?-->(*SKIP)(*FAIL)|<url>(.*?)</url>~is', $response['body'], $url_matches ) ) {
$locs = array();
$loc_matches = null;
$priority_matches = null;
foreach ( $url_matches[1] as $url_match ) {
$loc = '';
$priority = 0.5;
if ( preg_match( '~<loc>(.*?)</loc>~is', $url_match, $loc_matches ) ) {
$loc = trim( $loc_matches[1] );
}
if ( preg_match( '~<priority>(.*?)</priority>~is', $url_match, $priority_matches ) ) {
$priority = (float) trim( $priority_matches[1] );
}
if ( $loc && $priority ) {
$locs[ $loc ] = $priority;
}
}
arsort( $locs );
$urls = array_merge( $urls, array_keys( $locs ) );
} elseif ( preg_match_all( '~<!--.*?-->(*SKIP)(*FAIL)|<rss[^>]*>(.*?)</rss>~is', $response['body'], $sitemap_matches ) ) {
// rss feed format.
if ( preg_match_all( '~<link[^>]*>(.*?)</link>~is', $response['body'], $url_matches ) ) {
foreach ( $url_matches[1] as $url_match ) {
$url = trim( $url_match );
$cdata_matches = null;
if ( preg_match( '~<!\[CDATA\[(.*)\]\]>~is', $url, $cdata_matches ) ) {
$url = $cdata_matches[1];
}
$urls[] = $url;
}
}
}
}
return $urls;
}
/**
* Primes the cache for a given post ID by making HTTP requests for each associated URL.
*
* @param int $post_id The post ID for which to prime the cache.
*
* @return bool True on success, false on failure.
*/
public function prime_post( $post_id ) {
$post_urls = Util_PageUrls::get_post_urls( $post_id );
// Make HTTP requests and prime cache.
foreach ( $post_urls as $url ) {
$result = Util_Http::get( $url, array( 'user-agent' => 'WordPress' ) );
if ( is_wp_error( $result ) ) {
return false;
}
}
return true;
}
/**
* Saves configuration options and triggers actions based on changes.
*
* @param array $data The configuration data containing both new and old configurations.
*
* @return array The updated configuration data.
*/
public function w3tc_save_options( $data ) {
$new_config = $data['new_config'];
$old_config = $data['old_config'];
if ( $new_config->get_boolean( 'pgcache.cache.feed' ) ) {
$new_config->set( 'pgcache.cache.nginx_handle_xml', true );
}
if (
(
! $new_config->get_boolean( 'pgcache.cache.home' ) &&
$old_config->get_boolean( 'pgcache.cache.home' )
) ||
(
$new_config->get_boolean( 'pgcache.reject.front_page' ) &&
! $old_config->get_boolean( 'pgcache.reject.front_page' )
) ||
(
! $new_config->get_boolean( 'pgcache.cache.feed' ) &&
$old_config->get_boolean( 'pgcache.cache.feed' )
) ||
(
! $new_config->get_boolean( 'pgcache.cache.query' ) &&
$old_config->get_boolean( 'pgcache.cache.query' )
) ||
(
! $new_config->get_boolean( 'pgcache.cache.ssl' ) &&
$old_config->get_boolean( 'pgcache.cache.ssl' )
)
) {
$state = Dispatcher::config_state();
$state->set( 'common.show_note.flush_posts_needed', true );
$state->save();
}
// Schedule purge if enabled.
if ( $new_config->get_boolean( 'pgcache.enabled' ) && $new_config->get_boolean( 'pgcache.wp_cron' ) ) {
$new_wp_cron_time = $new_config->get_integer( 'pgcache.wp_cron_time' );
$old_wp_cron_time = $old_config ? $old_config->get_integer( 'pgcache.wp_cron_time' ) : -1;
$new_wp_cron_interval = $new_config->get_string( 'pgcache.wp_cron_interval' );
$old_wp_cron_interval = $old_config ? $old_config->get_string( 'pgcache.wp_cron_interval' ) : -1;
$schedule_needs_update = $new_wp_cron_time !== $old_wp_cron_time || $new_wp_cron_interval !== $old_wp_cron_interval;
// Clear the scheduled hook if a change in time or interval is detected.
if ( wp_next_scheduled( 'w3tc_pgcache_purge_wpcron' ) && $schedule_needs_update ) {
wp_clear_scheduled_hook( 'w3tc_pgcache_purge_wpcron' );
}
// Schedule if no existing cron event or settings have changed.
if ( ! wp_next_scheduled( 'w3tc_pgcache_purge_wpcron' ) || $schedule_needs_update ) {
$scheduled_timestamp_server = Util_Environment::get_cron_schedule_time( $new_wp_cron_time );
wp_schedule_event( $scheduled_timestamp_server, $new_wp_cron_interval, 'w3tc_pgcache_purge_wpcron' );
}
} elseif ( wp_next_scheduled( 'w3tc_pgcache_purge_wpcron' ) ) {
wp_clear_scheduled_hook( 'w3tc_pgcache_purge_wpcron' );
}
return $data;
}
/**
* Checks and reports any errors related to the page cache engine (e.g., Memcached).
*
* @param array $errors The array of errors to append to.
*
* @return array The updated array of errors.
*/
public function w3tc_errors( $errors ) {
$c = Dispatcher::config();
if ( 'memcached' === $c->get_string( 'pgcache.engine' ) ) {
$memcached_servers = $c->get_array( 'pgcache.memcached.servers' );
$memcached_binary_protocol = $c->get_boolean( 'pgcache.memcached.binary_protocol' );
$memcached_username = $c->get_string( 'pgcache.memcached.username' );
$memcached_password = $c->get_string( 'pgcache.memcached.password' );
if (
! Util_Installed::is_memcache_available(
$memcached_servers,
$memcached_binary_protocol,
$memcached_username,
$memcached_password
)
) {
if ( ! isset( $errors['memcache_not_responding.details'] ) ) {
$errors['memcache_not_responding.details'] = array();
}
$errors['memcache_not_responding.details'][] = sprintf(
// Translators: 1 memcached servers.
__(
'Page Cache: %1$s.',
'w3-total-cache'
),
implode( ', ', $memcached_servers )
);
}
}
return $errors;
}
/**
* Summarizes usage statistics from historical data, including cache size and request hits.
*
* @param array $summary The summary data to update.
* @param array $history The historical usage data to process.
*
* @return array The updated summary with additional page cache statistics.
*/
public function w3tc_usage_statistics_summary_from_history( $summary, $history ) {
// total size.
$g = Dispatcher::component( 'PgCache_ContentGrabber' );
$pagecache = array();
$e = $this->_config->get_string( 'pgcache.engine' );
$pagecache['engine_name'] = Cache::engine_name( $e );
$file_generic = ( 'file_generic' === $e );
// build metrics in php block.
if ( ! isset( $summary['php'] ) ) {
$summary['php'] = array();
}
Util_UsageStatistics::sum_by_prefix_positive( $summary['php'], $history, 'php_requests_pagecache' );
// need to return cache size.
if ( $file_generic ) {
list( $v, $should_count ) = Util_UsageStatistics::get_or_init_size_transient(
'w3tc_ustats_pagecache_size',
$summary
);
if ( $should_count ) {
$size = $g->get_cache_stats_size( $summary['timeout_time'] );
$v['size_used'] = Util_UsageStatistics::bytes_to_size2( $size, 'bytes' );
$v['items'] = Util_UsageStatistics::integer2( $size, 'items' );
set_transient( 'w3tc_ustats_pagecache_size', $v, 55 );
}
if ( isset( $v['size_used'] ) ) {
$pagecache['size_used'] = $v['size_used'];
$pagecache['items'] = $v['items'];
}
if ( isset( $summary['access_log'] ) ) {
$pagecache['requests'] = $summary['access_log']['dynamic_requests_total_v'];
$pagecache['requests_hit'] = $pagecache['requests'] - $summary['php']['php_requests_v'];
if ( $pagecache['requests_hit'] < 0 ) {
$pagecache['requests_hit'] = 0;
}
}
} else {
// all request counts data available.
$pagecache['requests'] = isset( $summary['php']['php_requests_v'] ) ? $summary['php']['php_requests_v'] : 0;
$pagecache['requests_hit'] = isset( $summary['php']['php_requests_pagecache_hit'] ) ? $summary['php']['php_requests_pagecache_hit'] : 0;
$requests_time_ms = Util_UsageStatistics::sum( $history, 'pagecache_requests_time_10ms' ) * 10;
$php_requests = Util_UsageStatistics::sum( $history, 'php_requests' );
if ( $php_requests > 0 ) {
$pagecache['request_time_ms'] = Util_UsageStatistics::integer( $requests_time_ms / $php_requests );
}
}
if ( 'memcached' === $e ) {
$pagecache['size_percent'] = $summary['memcached']['size_percent'];
}
if ( isset( $pagecache['requests_hit'] ) ) {
$pagecache['requests_hit_rate'] = Util_UsageStatistics::percent(
$pagecache['requests_hit'],
$pagecache['requests']
);
}
if ( ! isset( $summary['php']['php_requests_pagecache_hit'] ) ) {
$summary['php']['php_requests_pagecache_hit'] = 0;
}
if ( isset( $summary['php']['php_requests_v'] ) ) {
$v = $summary['php']['php_requests_v'] - $summary['php']['php_requests_pagecache_hit'];
if ( $v < 0 ) {
$v = 0;
}
$summary['php']['php_requests_pagecache_miss'] = $v;
}
if ( isset( $pagecache['requests'] ) ) {
$pagecache['requests_per_second'] = Util_UsageStatistics::value_per_period_seconds(
$pagecache['requests'],
$summary
);
}
$summary['pagecache'] = $pagecache;
return $summary;
}
}
Sindbad File Manager Version 1.0, Coded By Sindbad EG ~ The Terrorists