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

namespace W3TC;

/**
 * Class Dispatcher
 *
 * Interplugin communication
 *
 * phpcs:disable WordPress.PHP.NoSilencedErrors.Discouraged
 * phpcs:disable WordPress.WP.AlternativeFunctions
 */
class Dispatcher {
	/**
	 * Instances
	 *
	 * @var array
	 */
	private static $instances = array();

	/**
	 * Retrieves a component instance by class name.
	 *
	 * @param string $class_name The class name of the component to retrieve.
	 *
	 * @return object The requested component instance.
	 */
	public static function component( $class_name ) {
		if ( ! isset( self::$instances[ $class_name ] ) ) {
			$full_class                     = '\\W3TC\\' . $class_name;
			self::$instances[ $class_name ] = new $full_class();
		}

		$v = self::$instances[ $class_name ]; // Don't return reference.
		return $v;
	}

	/**
	 * Retrieves the configuration component.
	 *
	 * @return object The configuration component instance.
	 */
	public static function config() {
		return self::component( 'Config' );
	}

	/**
	 * Resets the configuration component.
	 *
	 * @return void
	 */
	public static function reset_config() {
		unset( self::$instances['Config'] );
	}

	/**
	 * Retrieves the master configuration instance.
	 *
	 * @return object The master configuration instance.
	 */
	public static function config_master() {
		static $config_master = null;

		if ( is_null( $config_master ) ) {
			$config_master = new Config( 0 );
		}

		return $config_master;
	}

	/**
	 * Retrieves the state-specific configuration instance.
	 *
	 * @return object The state-specific configuration instance.
	 */
	public static function config_state() {
		if ( Util_Environment::blog_id() <= 0 ) {
			return self::config_state_master();
		}

		static $config_state = null;

		if ( is_null( $config_state ) ) {
			$config_state = new ConfigState( false );
		}

		return $config_state;
	}

	/**
	 * Retrieves the master state configuration instance.
	 *
	 * @return object The master state configuration instance.
	 */
	public static function config_state_master() {
		static $config_state = null;

		if ( is_null( $config_state ) ) {
			$config_state = new ConfigState( true );
		}

		return $config_state;
	}

	/**
	 * Retrieves the configuration state note instance.
	 *
	 * @return object The configuration state note instance.
	 */
	public static function config_state_note() {
		static $o = null;

		if ( is_null( $o ) ) {
			$o = new ConfigStateNote( self::config_state_master(), self::config_state() );
		}

		return $o;
	}

	/**
	 * Checks if a given URL has been uploaded to the CDN.
	 *
	 * @param string $url The URL to check.
	 *
	 * @return bool True if the URL is uploaded to the CDN, false otherwise.
	 */
	public static function is_url_cdn_uploaded( $url ) {
		$minify_enabled = self::config()->get_boolean( 'minify.enabled' );
		if ( $minify_enabled ) {
			$minify = self::component( 'Minify_MinifiedFileRequestHandler' );
			$data   = $minify->get_url_custom_data( $url );
			if ( is_array( $data ) && isset( $data['cdn.status'] ) && 'uploaded' === $data['cdn.status'] ) {
				return true;
			}
		}
		// supported only for minify-based urls, futher is not needed now.
		return false;
	}

	/**
	 * Creates a file for CDN processing.
	 *
	 * @param string $filename The name of the file to create.
	 *
	 * @return void
	 */
	public static function create_file_for_cdn( $filename ) {
		$minify_enabled = self::config()->get_boolean( 'minify.enabled' );
		if ( $minify_enabled ) {
			$minify_document_root = Util_Environment::cache_blog_dir( 'minify' ) . '/';

			if ( ! substr( $filename, 0, strlen( $minify_document_root ) ) === $minify_document_root ) {
				// unexpected file name.
				return;
			}

			$short_filename = substr( $filename, strlen( $minify_document_root ) );
			$minify         = self::component( 'Minify_MinifiedFileRequestHandler' );

			$data = $minify->process( $short_filename, true );

			if ( ! file_exists( $filename ) && isset( $data['content'] ) ) {
				if ( ! file_exists( dirname( $filename ) ) ) {
					Util_File::mkdir_from_safe( dirname( $filename ), W3TC_CACHE_DIR );
				}
			}
			@file_put_contents( $filename, $data['content'] );
		}
	}

	/**
	 * Marks a file as uploaded to the CDN.
	 *
	 * @param string $file_name The name of the file.
	 *
	 * @return void
	 */
	public static function on_cdn_file_upload( $file_name ) {
		$minify_enabled = self::config()->get_boolean( 'minify.enabled' );
		if ( $minify_enabled ) {
			$minify_document_root = Util_Environment::cache_blog_dir( 'minify' ) . '/';

			if ( ! substr( $file_name, 0, strlen( $minify_document_root ) ) === $minify_document_root ) {
				// unexpected file name.
				return;
			}

			$short_file_name = substr( $file_name, strlen( $minify_document_root ) );
			$minify          = self::component( 'Minify_MinifiedFileRequestHandler' );
			$minify->set_file_custom_data( $short_file_name, array( 'cdn.status' => 'uploaded' ) );
		}
	}

	/**
	 * Generates Nginx rules for a browser cache section.
	 *
	 * @todo change to filters, like litespeed does
	 *
	 * @param object $config               The configuration object.
	 * @param string $section              The specific section for which to generate rules.
	 * @param bool   $extra_add_headers_set Whether additional headers are included.
	 *
	 * @return array The generated Nginx rules.
	 */
	public static function nginx_rules_for_browsercache_section( $config, $section, $extra_add_headers_set = false ) {
		$rules = array(
			'other'      => array(),
			'add_header' => array(),
		);
		if ( $config->get_boolean( 'browsercache.enabled' ) ) {
			$o     = new BrowserCache_Environment_Nginx( $config );
			$rules = $o->section_rules( $section, $extra_add_headers_set );
		}

		if ( ! empty( $rules['add_header'] ) && $config->get_boolean( 'cdn.enabled' ) ) {
			$o    = new Cdn_Environment_Nginx( $config );
			$rule = $o->generate_canonical();

			if ( ! empty( $rule ) ) {
				$rules['add_header'][] = $rule;
			}
		}

		return array_merge( $rules['other'], $rules['add_header'] );
	}

	/**
	 * Retrieves the minify filename requested.
	 *
	 * @param object $config The configuration object.
	 * @param string $file   The file name.
	 *
	 * @return string The processed file name.
	 */
	public static function requested_minify_filename( $config, $file ) {
		// browsercache may alter filestructure, allow it to remove its uniqualizator.
		if ( $config->get_boolean( 'browsercache.enabled' ) &&
			$config->get_boolean( 'browsercache.rewrite' ) ) {
			if ( preg_match( '~(.+)\.([0-9a-z]+)(\.[^.]+)$~', $file, $m ) ) {
				$file = $m[1] . $m[3];
			}
		}
		return $file;
	}

	/**
	 * Retrieves the cache instance for usage statistics.
	 *
	 * @return object The cache instance for usage statistics.
	 */
	public static function get_usage_statistics_cache() {
		static $cache = null;
		if ( is_null( $cache ) ) {
			$c             = self::config();
			$engine_config = null;
			if ( $c->getf_boolean( 'objectcache.enabled' ) ) {
				$provider = self::component( 'ObjectCache_WpObjectCache_Regular' );
			} elseif ( $c->get_boolean( 'dbcache.enabled' ) ) {
				$provider = self::component( 'DbCache_Core' );
			} elseif ( $c->get_boolean( 'pgcache.enabled' ) ) {
				$provider = self::component( 'PgCache_ContentGrabber' );
			} elseif ( $c->get_boolean( 'minify.enabled' ) ) {
				$provider = self::component( 'Minify_Core' );
			} else {
				$engine_config = array( 'engine' => 'file' );
			}

			if ( is_null( $engine_config ) ) {
				$engine_config = $provider->get_usage_statistics_cache_config();
			}

			$engine_config['module']  = 'stats';
			$engine_config['blog_id'] = 0;   // count wpmu-wide stats.

			if ( 'file' === $engine_config['engine'] ) {
				$engine_config['cache_dir'] = Util_Environment::cache_dir( 'stats' );
			}

			$cache = Cache::instance( $engine_config['engine'], $engine_config );
		}

		return $cache;
	}

	/**
	 * Applies usage statistics metrics before initialization and exits.
	 *
	 * @param callable $metrics_function The metrics function to apply.
	 *
	 * @return void
	 */
	public static function usage_statistics_apply_before_init_and_exit( $metrics_function ) {
		$c = self::config();
		if ( ! $c->get_boolean( 'stats.enabled' ) ) {
			exit();
		}

		$core = self::component( 'UsageStatistics_Core' );
		$core->apply_metrics_before_init_and_exit( $metrics_function );
	}
}