203 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			203 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
namespace W3TC;
 | 
						|
 | 
						|
 | 
						|
 | 
						|
/**
 | 
						|
 * class Root_Environment
 | 
						|
 */
 | 
						|
class Root_Environment {
 | 
						|
	/**
 | 
						|
	 * Fixes environment
 | 
						|
	 *
 | 
						|
	 * @param Config  $config
 | 
						|
	 * @throws Util_Environment_Exceptions
 | 
						|
	 */
 | 
						|
	function fix_in_wpadmin( $config, $force_all_checks = false ) {
 | 
						|
		$exs = new Util_Environment_Exceptions();
 | 
						|
		$fix_on_event = false;
 | 
						|
		if ( Util_Environment::is_wpmu() && Util_Environment::blog_id() != 0 ) {
 | 
						|
			if ( get_transient( 'w3tc_config_changes' ) != ( $md5_string = $config->get_md5() ) ) {
 | 
						|
				$fix_on_event = true;
 | 
						|
				set_transient( 'w3tc_config_changes', $md5_string, 3600 );
 | 
						|
			}
 | 
						|
		}
 | 
						|
		// call plugin-related handlers
 | 
						|
		foreach ( $this->get_handlers() as $h ) {
 | 
						|
			try {
 | 
						|
				$h->fix_on_wpadmin_request( $config, $force_all_checks );
 | 
						|
				if ( $fix_on_event ) {
 | 
						|
					$this->fix_on_event( $config, 'admin_request' );
 | 
						|
				}
 | 
						|
			} catch ( Util_Environment_Exceptions $ex ) {
 | 
						|
				$exs->push( $ex );
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		try {
 | 
						|
			do_action( 'w3tc_environment_fix_on_wpadmin_request',
 | 
						|
				$config, $force_all_checks );
 | 
						|
		} catch ( Util_Environment_Exceptions $ex ) {
 | 
						|
			$exs->push( $ex );
 | 
						|
		}
 | 
						|
 | 
						|
		if ( count( $exs->exceptions() ) > 0 )
 | 
						|
			throw $exs;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Fixes environment once event occurs
 | 
						|
	 *
 | 
						|
	 * @throws Util_Environment_Exceptions
 | 
						|
	 */
 | 
						|
	public function fix_on_event( $config, $event, $old_config = null ) {
 | 
						|
		$exs = new Util_Environment_Exceptions();
 | 
						|
 | 
						|
		// call plugin-related handlers
 | 
						|
		foreach ( $this->get_handlers() as $h ) {
 | 
						|
			try {
 | 
						|
				$h->fix_on_event( $config, $event );
 | 
						|
			} catch ( Util_Environment_Exceptions $ex ) {
 | 
						|
				$exs->push( $ex );
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		try {
 | 
						|
			do_action( 'w3tc_environment_fix_on_event',
 | 
						|
				$config, $event );
 | 
						|
		} catch ( Util_Environment_Exceptions $ex ) {
 | 
						|
			$exs->push( $ex );
 | 
						|
		}
 | 
						|
 | 
						|
		if ( count( $exs->exceptions() ) > 0 )
 | 
						|
			throw $exs;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Fixes environment after plugin deactivation
 | 
						|
	 *
 | 
						|
	 * @param Config  $config
 | 
						|
	 * @throws Util_Environment_Exceptions
 | 
						|
	 */
 | 
						|
	public function fix_after_deactivation() {
 | 
						|
		$exs = new Util_Environment_Exceptions();
 | 
						|
 | 
						|
		// call plugin-related handlers
 | 
						|
		foreach ( $this->get_handlers() as $h ) {
 | 
						|
			try {
 | 
						|
				$h->fix_after_deactivation();
 | 
						|
			} catch ( Util_Environment_Exceptions $ex ) {
 | 
						|
				$exs->push( $ex );
 | 
						|
			}
 | 
						|
		}
 | 
						|
 | 
						|
		try {
 | 
						|
			do_action( 'w3tc_environment_fix_after_deactivation' );
 | 
						|
		} catch ( Util_Environment_Exceptions $ex ) {
 | 
						|
			$exs->push( $ex );
 | 
						|
		}
 | 
						|
 | 
						|
		if ( count( $exs->exceptions() ) > 0 )
 | 
						|
			throw $exs;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Returns an array[filename]=rules of rules for .htaccess or nginx files
 | 
						|
	 *
 | 
						|
	 * @param Config  $config
 | 
						|
	 * @return array
 | 
						|
	 */
 | 
						|
	public function get_required_rules( $config ) {
 | 
						|
		$required_rules = array();
 | 
						|
		foreach ( $this->get_handlers() as $h ) {
 | 
						|
			$required_rules_current = $h->get_required_rules( $config );
 | 
						|
 | 
						|
			if ( !is_null( $required_rules_current ) )
 | 
						|
				$required_rules = array_merge( $required_rules, $required_rules_current );
 | 
						|
		}
 | 
						|
 | 
						|
		$required_rules = apply_filters( 'w3tc_environment_get_required_rules',
 | 
						|
			$required_rules, $config );
 | 
						|
 | 
						|
 | 
						|
		$rewrite_rules_descriptors = array();
 | 
						|
 | 
						|
		foreach ( $required_rules as $descriptor ) {
 | 
						|
			$filename = $descriptor['filename'];
 | 
						|
 | 
						|
			if ( isset( $rewrite_rules_descriptors[$filename] ) )
 | 
						|
				$content = $rewrite_rules_descriptors[$filename]['content'];
 | 
						|
			else
 | 
						|
				$content = array();
 | 
						|
 | 
						|
			if ( !isset( $descriptor['position'] ) )
 | 
						|
				$content[] = $descriptor['content'];
 | 
						|
			else {
 | 
						|
				$position = $descriptor['position'];
 | 
						|
 | 
						|
				if ( isset( $content[$position] ) )
 | 
						|
					$content[$position] .= $descriptor['content'];
 | 
						|
				else
 | 
						|
					$content[$position] = $descriptor['content'];
 | 
						|
			}
 | 
						|
 | 
						|
			$rewrite_rules_descriptors[$filename] = array(
 | 
						|
				'filename' => $filename,
 | 
						|
				'content' => $content
 | 
						|
			);
 | 
						|
		}
 | 
						|
 | 
						|
		$rewrite_rules_descriptors_out = array();
 | 
						|
		foreach ( $rewrite_rules_descriptors as $filename => $descriptor ) {
 | 
						|
			$rewrite_rules_descriptors_out[$filename] = array(
 | 
						|
				'filename' => $filename,
 | 
						|
				'content' => implode( '', $descriptor['content'] )
 | 
						|
			);
 | 
						|
		}
 | 
						|
		ksort( $rewrite_rules_descriptors_out );
 | 
						|
		return $rewrite_rules_descriptors_out;
 | 
						|
	}
 | 
						|
 | 
						|
	/**
 | 
						|
	 * Returns plugin-related environment handlers
 | 
						|
	 *
 | 
						|
	 * @param Config  $config
 | 
						|
	 * @return array
 | 
						|
	 */
 | 
						|
	private function get_handlers() {
 | 
						|
		$a = array(
 | 
						|
			new Generic_Environment(),
 | 
						|
			new Minify_Environment(),
 | 
						|
			new PgCache_Environment(),
 | 
						|
			new BrowserCache_Environment(),
 | 
						|
			new ObjectCache_Environment(),
 | 
						|
			new DbCache_Environment(),
 | 
						|
			new Cdn_Environment(),
 | 
						|
			new Extension_ImageService_Environment(),
 | 
						|
		);
 | 
						|
 | 
						|
		return $a;
 | 
						|
	}
 | 
						|
 | 
						|
	public function get_other_instructions( $config ) {
 | 
						|
		$instructions_descriptors = array();
 | 
						|
 | 
						|
		foreach ( $this->get_handlers() as $h ) {
 | 
						|
			if ( method_exists( $h, 'get_instructions' ) ) {
 | 
						|
				$instructions = $h->get_instructions( $config );
 | 
						|
				if ( !is_null( $instructions ) ) {
 | 
						|
					foreach ( $instructions as $descriptor ) {
 | 
						|
						$area = $descriptor['area'];
 | 
						|
						$instructions_descriptors[$area][] = array(
 | 
						|
							'title' => $descriptor['title'],
 | 
						|
							'content' => $descriptor['content']
 | 
						|
						);
 | 
						|
					}
 | 
						|
				}
 | 
						|
			}
 | 
						|
 | 
						|
		}
 | 
						|
		return $instructions_descriptors;
 | 
						|
	}
 | 
						|
}
 |