Current File : /home/escuelai/public_html/wp-content/plugins/w3-total-cache/ModuleStatus.php
<?php
/**
 * File: ModuleStatus.php
 *
 * @package W3TC
 */

namespace W3TC;

/**
 * Class ModuleStatus
 *
 * phpcs:disable PSR2.Classes.PropertyDeclaration.Underscore
 * phpcs:disable PSR2.Methods.MethodDeclaration.Underscore
 */
class ModuleStatus {
	/**
	 * Opcode Engines
	 *
	 * @var array
	 */
	private $_opcode_engines = array(
		'apc',
		'eaccelerator',
		'xcache',
		'wincache',
	);

	/**
	 * File engines
	 *
	 * @var array
	 */
	private $_file_engines = array(
		'file',
		'file_generic',
	);

	/**
	 * Config
	 *
	 * @var Config
	 */
	private $_config;

	/**
	 * Constructor for initializing the ModuleStatus class.
	 *
	 * @return void
	 */
	public function __construct() {
		$this->_config = Dispatcher::config();
	}

	/**
	 * Checks whether any caching or optimization plugin is enabled.
	 *
	 * @return bool True if any plugin is enabled, false otherwise.
	 */
	public function plugin_is_enabled() {
		return $this->is_enabled( 'pgcache' ) ||
			$this->is_enabled( 'minify' ) ||
			$this->is_enabled( 'dbcache' ) ||
			$this->is_enabled( 'objectcache' ) ||
			$this->is_enabled( 'browsercache' ) ||
			$this->is_enabled( 'cdn' ) ||
			$this->is_enabled( 'cdnfsd' ) ||
			$this->is_enabled( 'varnish' ) ||
			$this->is_enabled( 'newrelic' ) ||
			$this->is_enabled( 'fragmentcache' );
	}

	/**
	 * Checks if a specific module is enabled.
	 *
	 * @param string $module The name of the module to check.
	 *
	 * @return bool True if the module is enabled, false otherwise.
	 */
	public function is_enabled( $module ) {
		return $this->_config->get_boolean( "$module.enabled" );
	}

	/**
	 * Checks if a specific module is running.
	 *
	 * phpcs:disable WordPress.NamingConventions.ValidHookName.UseUnderscores
	 *
	 * @param string $module The name of the module to check.
	 *
	 * @return bool True if the module is running, false otherwise.
	 */
	public function is_running( $module ) {
		return apply_filters( "w3tc_module_is_running-{$module}", $this->is_enabled( $module ) );
	}

	/**
	 * Determines whether Memcached can be emptied.
	 *
	 * @return bool True if Memcached can be emptied, false otherwise.
	 */
	public function can_empty_memcache() {
		return $this->_enabled_module_uses_engine( 'pgcache', 'memcached' ) ||
			$this->_enabled_module_uses_engine( 'dbcache', 'memcached' ) ||
			$this->_enabled_module_uses_engine( 'objectcache', 'memcached' ) ||
			$this->_enabled_module_uses_engine( 'minify', 'memcached' ) ||
			$this->_enabled_module_uses_engine( 'fragmentcache', 'memcached' );
	}

	/**
	 * Determines whether the Opcache can be emptied.
	 *
	 * @return bool True if Opcache can be emptied, false otherwise.
	 */
	public function can_empty_opcode() {
		$o = Dispatcher::component( 'SystemOpCache_Core' );
		return $o->is_enabled();
	}

	/**
	 * Determines whether file-based caches can be emptied.
	 *
	 * @return bool True if file-based caches can be emptied, false otherwise.
	 */
	public function can_empty_file() {
		return $this->_enabled_module_uses_engine( 'pgcache', $this->_file_engines ) ||
			$this->_enabled_module_uses_engine( 'dbcache', $this->_file_engines ) ||
			$this->_enabled_module_uses_engine( 'objectcache', $this->_file_engines ) ||
			$this->_enabled_module_uses_engine( 'minify', $this->_file_engines ) ||
			$this->_enabled_module_uses_engine( 'fragmentcache', $this->_file_engines );
	}

	/**
	 * Determines whether Varnish cache can be emptied.
	 *
	 * @return bool True if Varnish cache can be emptied, false otherwise.
	 */
	public function can_empty_varnish() {
		return $this->_config->get_boolean( 'varnish.enabled' );
	}

	/**
	 * Retrieves the engine used by a specific module.
	 *
	 * @param string $module The name of the module.
	 *
	 * @return string The engine associated with the module.
	 */
	public function get_module_engine( $module ) {
		return $this->_config->get_string( "$module.engine" );
	}

	/**
	 * Checks if an enabled module uses a specific caching engine.
	 *
	 * @param string $module The name of the module.
	 * @param mixed  $engine The engine or an array of engines to check.
	 *
	 * @return bool True if the module uses the specified engine, false otherwise.
	 */
	private function _enabled_module_uses_engine( $module, $engine ) {
		if ( is_array( $engine ) ) {
			return $this->is_enabled( $module ) && in_array( $this->get_module_engine( $module ), $engine, true );
		} else {
			return $this->is_enabled( $module ) && $this->get_module_engine( $module ) === $engine;
		}
	}
}