SILENT KILLERPanel

Current Path: > > usr > src > litespeed-wp-plugin > > > 7.2 > > litespeed-cache > src


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //usr/src/litespeed-wp-plugin///7.2//litespeed-cache/src

NameTypeSizeLast ModifiedActions
cdn Directory - -
data_structure Directory - -
activation.cls.php File 15423 bytes June 18 2025 22:15:22.
admin-display.cls.php File 36599 bytes June 18 2025 22:15:22.
admin-settings.cls.php File 11212 bytes June 18 2025 22:15:22.
admin.cls.php File 4574 bytes June 18 2025 22:15:22.
api.cls.php File 11798 bytes June 18 2025 22:15:22.
avatar.cls.php File 6267 bytes June 18 2025 22:15:22.
base.cls.php File 33542 bytes June 18 2025 22:15:22.
cdn.cls.php File 13540 bytes June 18 2025 22:15:22.
cloud.cls.php File 55588 bytes June 18 2025 22:15:22.
conf.cls.php File 17804 bytes June 18 2025 22:15:22.
control.cls.php File 21759 bytes June 18 2025 22:15:22.
core.cls.php File 20642 bytes June 18 2025 22:15:22.
crawler-map.cls.php File 15248 bytes June 18 2025 22:15:22.
crawler.cls.php File 42711 bytes June 18 2025 22:15:22.
css.cls.php File 15617 bytes June 18 2025 22:15:22.
data.cls.php File 18413 bytes June 18 2025 22:15:22.
data.upgrade.func.php File 23945 bytes June 18 2025 22:15:22.
db-optm.cls.php File 10401 bytes June 18 2025 22:15:22.
debug2.cls.php File 13485 bytes June 18 2025 22:15:22.
doc.cls.php File 4846 bytes June 18 2025 22:15:22.
error.cls.php File 7667 bytes June 18 2025 22:15:22.
esi.cls.php File 27818 bytes June 18 2025 22:15:22.
file.cls.php File 10779 bytes June 18 2025 22:15:22.
gui.cls.php File 28443 bytes June 18 2025 22:15:22.
health.cls.php File 2971 bytes June 18 2025 22:15:22.
htaccess.cls.php File 24709 bytes June 18 2025 22:15:22.
img-optm.cls.php File 66840 bytes June 18 2025 22:15:22.
import.cls.php File 4280 bytes June 18 2025 22:15:22.
import.preset.cls.php File 5613 bytes June 18 2025 22:15:22.
lang.cls.php File 15271 bytes June 18 2025 22:15:22.
localization.cls.php File 3502 bytes June 18 2025 22:15:22.
media.cls.php File 33973 bytes June 18 2025 22:15:22.
metabox.cls.php File 4364 bytes June 18 2025 22:15:22.
object-cache.cls.php File 16883 bytes June 18 2025 22:15:22.
object.lib.php File 34951 bytes June 18 2025 22:15:22.
optimize.cls.php File 38083 bytes June 18 2025 22:15:22.
optimizer.cls.php File 9714 bytes June 18 2025 22:15:22.
placeholder.cls.php File 14600 bytes June 18 2025 22:15:22.
purge.cls.php File 31587 bytes June 18 2025 22:15:22.
report.cls.php File 6338 bytes June 18 2025 22:15:22.
rest.cls.php File 7699 bytes June 18 2025 22:15:22.
root.cls.php File 13149 bytes June 18 2025 22:15:22.
router.cls.php File 20422 bytes June 18 2025 22:15:22.
str.cls.php File 2513 bytes June 18 2025 22:15:22.
tag.cls.php File 9497 bytes June 18 2025 22:15:22.
task.cls.php File 6283 bytes June 18 2025 22:15:22.
tool.cls.php File 3491 bytes June 18 2025 22:15:22.
ucss.cls.php File 14657 bytes June 18 2025 22:15:22.
utility.cls.php File 21319 bytes June 18 2025 22:15:22.
vary.cls.php File 20659 bytes June 18 2025 22:15:22.
vpi.cls.php File 7435 bytes June 18 2025 22:15:22.

Reading File: //usr/src/litespeed-wp-plugin///7.2//litespeed-cache/src/avatar.cls.php

<?php

/**
 * The avatar cache class
 *
 * @since       3.0
 * @package     LiteSpeed
 * @subpackage  LiteSpeed/inc
 * @author      LiteSpeed Technologies <info@litespeedtech.com>
 */

namespace LiteSpeed;

defined('WPINC') || exit();

class Avatar extends Base {

	const TYPE_GENERATE = 'generate';

	private $_conf_cache_ttl;
	private $_tb;

	private $_avatar_realtime_gen_dict = array();
	protected $_summary;

	/**
	 * Init
	 *
	 * @since  1.4
	 */
	public function __construct() {
		if (!$this->conf(self::O_DISCUSS_AVATAR_CACHE)) {
			return;
		}

		Debug2::debug2('[Avatar] init');

		$this->_tb = $this->cls('Data')->tb('avatar');

		$this->_conf_cache_ttl = $this->conf(self::O_DISCUSS_AVATAR_CACHE_TTL);

		add_filter('get_avatar_url', array( $this, 'crawl_avatar' ));

		$this->_summary = self::get_summary();
	}

	/**
	 * Check if need db table or not
	 *
	 * @since 3.0
	 * @access public
	 */
	public function need_db() {
		if ($this->conf(self::O_DISCUSS_AVATAR_CACHE)) {
			return true;
		}

		return false;
	}
	/**
	 * Get gravatar URL from DB and regenerate
	 *
	 * @since  3.0
	 * @access public
	 */
	public function serve_static( $md5 ) {
		global $wpdb;

		Debug2::debug('[Avatar] is avatar request');

		if (strlen($md5) !== 32) {
			Debug2::debug('[Avatar] wrong md5 ' . $md5);
			return;
		}

		$q   = "SELECT url FROM `$this->_tb` WHERE md5=%s";
		$url = $wpdb->get_var($wpdb->prepare($q, $md5));

		if (!$url) {
			Debug2::debug('[Avatar] no matched url for md5 ' . $md5);
			return;
		}

		$url = $this->_generate($url);

		wp_redirect($url);
		exit();
	}

	/**
	 * Localize gravatar
	 *
	 * @since  3.0
	 * @access public
	 */
	public function crawl_avatar( $url ) {
		if (!$url) {
			return $url;
		}

		// Check if its already in dict or not
		if (!empty($this->_avatar_realtime_gen_dict[$url])) {
			Debug2::debug2('[Avatar] already in dict [url] ' . $url);

			return $this->_avatar_realtime_gen_dict[$url];
		}

		$realpath = $this->_realpath($url);
		if (file_exists($realpath) && time() - filemtime($realpath) <= $this->_conf_cache_ttl) {
			Debug2::debug2('[Avatar] cache file exists [url] ' . $url);
			return $this->_rewrite($url, filemtime($realpath));
		}

		if (!strpos($url, 'gravatar.com')) {
			return $url;
		}

		// Send request
		if (!empty($this->_summary['curr_request']) && time() - $this->_summary['curr_request'] < 300) {
			Debug2::debug2('[Avatar] Bypass generating due to interval limit [url] ' . $url);
			return $url;
		}

		// Generate immediately
		$this->_avatar_realtime_gen_dict[$url] = $this->_generate($url);

		return $this->_avatar_realtime_gen_dict[$url];
	}

	/**
	 * Read last time generated info
	 *
	 * @since  3.0
	 * @access public
	 */
	public function queue_count() {
		global $wpdb;

		// If var not exists, mean table not exists // todo: not true
		if (!$this->_tb) {
			return false;
		}

		$q = "SELECT COUNT(*) FROM `$this->_tb` WHERE dateline<" . (time() - $this->_conf_cache_ttl);
		return $wpdb->get_var($q);
	}

	/**
	 * Get the final URL of local avatar
	 *
	 * Check from db also
	 *
	 * @since  3.0
	 */
	private function _rewrite( $url, $time = null ) {
		return LITESPEED_STATIC_URL . '/avatar/' . $this->_filepath($url) . ($time ? '?ver=' . $time : '');
	}

	/**
	 * Generate realpath of the cache file
	 *
	 * @since  3.0
	 * @access private
	 */
	private function _realpath( $url ) {
		return LITESPEED_STATIC_DIR . '/avatar/' . $this->_filepath($url);
	}

	/**
	 * Get filepath
	 *
	 * @since  4.0
	 */
	private function _filepath( $url ) {
		$filename = md5($url) . '.jpg';
		if (is_multisite()) {
			$filename = get_current_blog_id() . '/' . $filename;
		}
		return $filename;
	}

	/**
	 * Cron generation
	 *
	 * @since  3.0
	 * @access public
	 */
	public static function cron( $force = false ) {
		global $wpdb;

		$_instance = self::cls();
		if (!$_instance->queue_count()) {
			Debug2::debug('[Avatar] no queue');
			return;
		}

		// For cron, need to check request interval too
		if (!$force) {
			if (!empty($_instance->_summary['curr_request']) && time() - $_instance->_summary['curr_request'] < 300) {
				Debug2::debug('[Avatar] curr_request too close');
				return;
			}
		}

		$q = "SELECT url FROM `$_instance->_tb` WHERE dateline < %d ORDER BY id DESC LIMIT %d";
		$q = $wpdb->prepare($q, array( time() - $_instance->_conf_cache_ttl, apply_filters('litespeed_avatar_limit', 30) ));

		$list = $wpdb->get_results($q);
		Debug2::debug('[Avatar] cron job [count] ' . count($list));

		foreach ($list as $v) {
			Debug2::debug('[Avatar] cron job [url] ' . $v->url);

			$_instance->_generate($v->url);
		}
	}

	/**
	 * Remote generator
	 *
	 * @since  3.0
	 * @access private
	 */
	private function _generate( $url ) {
		global $wpdb;

		// Record the data

		$file = $this->_realpath($url);

		// Update request status
		self::save_summary(array( 'curr_request' => time() ));

		// Generate
		$this->_maybe_mk_cache_folder('avatar');

		$response = wp_safe_remote_get($url, array(
			'timeout' => 180,
			'stream' => true,
			'filename' => $file,
		));

		Debug2::debug('[Avatar] _generate [url] ' . $url);

		// Parse response data
		if (is_wp_error($response)) {
			$error_message = $response->get_error_message();
			file_exists($file) && unlink($file);
			Debug2::debug('[Avatar] failed to get: ' . $error_message);
			return $url;
		}

		// Save summary data
		self::save_summary(array(
			'last_spent' => time() - $this->_summary['curr_request'],
			'last_request' => $this->_summary['curr_request'],
			'curr_request' => 0,
		));

		// Update DB
		$md5     = md5($url);
		$q       = "UPDATE `$this->_tb` SET dateline=%d WHERE md5=%s";
		$existed = $wpdb->query($wpdb->prepare($q, array( time(), $md5 )));
		if (!$existed) {
			$q = "INSERT INTO `$this->_tb` SET url=%s, md5=%s, dateline=%d";
			$wpdb->query($wpdb->prepare($q, array( $url, $md5, time() )));
		}

		Debug2::debug('[Avatar] saved avatar ' . $file);

		return $this->_rewrite($url);
	}

	/**
	 * Handle all request actions from main cls
	 *
	 * @since  3.0
	 * @access public
	 */
	public function handler() {
		$type = Router::verify_type();

		switch ($type) {
			case self::TYPE_GENERATE:
            self::cron(true);
				break;

			default:
				break;
		}

		Admin::redirect();
	}
}

SILENT KILLER Tool