wp_cache_serve_cache_file()WPSCache 1.0

No Hooks.

Return

null. Nothing (null).

Usage

wp_cache_serve_cache_file();

wp_cache_serve_cache_file() code WPSCache 1.12.4

function wp_cache_serve_cache_file() {
	global $key, $blogcacheid, $wp_cache_request_uri, $file_prefix, $blog_cache_dir, $meta_file, $cache_file, $cache_filename, $meta_pathname, $wp_cache_gzip_encoding, $meta;
	global $cache_compression, $wp_cache_slash_check, $wp_supercache_304, $wp_cache_home_path, $wp_cache_no_cache_for_get;
	global $wp_cache_disable_utf8, $wp_cache_mfunc_enabled, $wpsc_served_header;

	if ( wpsc_is_backend() ) {
		wp_cache_debug( 'Not serving wp-admin requests.', 5 );
		return false;
	}

	if ( $wp_cache_no_cache_for_get && wpsc_is_get_query() ) {
		wp_cache_debug( 'Non empty GET request. Caching disabled on settings page. ' . wpsc_dump_get_request(), 1 );
		return false;
	}

	if ( defined( 'WPSC_SERVE_DISABLED' ) ) {
		wp_cache_debug( 'wp_cache_serve_cache_file: WPSC_SERVE_DISABLED defined. Not serving cached files.' );
		return false;
	}

	if ( wpsc_get_accept_header() !== 'text/html' ) {
		wp_cache_debug( 'wp_cache_serve_cache_file: visitor does not accept text/html. Not serving cached file.' );
		return false;
	}

	extract( wp_super_cache_init() ); // $key, $cache_filename, $meta_file, $cache_file, $meta_pathname

	// Look for wp-cache file + meta file for the current URL
	// If we can't find them, we will look for supercache html files. These files don't have any meta data
	// which is why the code below does more work setting up the headers, etc.
	if (
		! defined( 'WPSC_SUPERCACHE_ONLY' ) &&
		(
			( $cache_file && file_exists( $cache_file ) ) ||
			file_exists( get_current_url_supercache_dir() . 'meta-' . $cache_filename )
		)
	) {
		if ( file_exists( get_current_url_supercache_dir() . 'meta-' . $cache_filename ) ) {
			$cache_file    = get_current_url_supercache_dir() . $cache_filename;
			$meta_pathname = get_current_url_supercache_dir() . 'meta-' . $cache_filename;
		} elseif ( ! file_exists( $cache_file ) ) {
			wp_cache_debug( 'wp_cache_serve_cache_file: found cache file but then it disappeared!' );
			return false;
		}

		if ( ! $meta_pathname ) {
			wp_cache_debug( 'wp_cache_serve_cache_file: meta pathname is empty. Could not load wp-cache meta file.' );
			return true;
		}

		wp_cache_debug( "wp-cache file exists: $cache_file", 5 );
		if ( ! ( $meta = json_decode( wp_cache_get_legacy_cache( $meta_pathname ), true ) ) ) {
			wp_cache_debug( "couldn't load wp-cache meta file", 5 );
			return true;
		}
		if ( is_array( $meta ) == false ) {
			wp_cache_debug( "meta array corrupt, deleting $meta_pathname and $cache_file", 1 );
			@unlink( $meta_pathname );
			@unlink( $cache_file );
			return true;
		}
	} else { // no wp-cache file, look for a supercache file
		global $wpsc_save_headers;
		global $cache_max_time;
		// last chance, check if a supercache file exists. Just in case .htaccess rules don't work on this host
		$file = get_current_url_supercache_dir() . supercache_filename();
		if ( false == file_exists( $file ) ) {
			wp_cache_debug( "No Super Cache file found for current URL: $file" );
			return false;
		} elseif ( wpsc_is_get_query() ) {
			wp_cache_debug( 'GET array not empty. Cannot serve a supercache file. ' . wpsc_dump_get_request() );
			return false;
		} elseif ( wp_cache_get_cookies_values() != '' ) {
			wp_cache_debug( 'Cookies found. Cannot serve a supercache file. ' . wp_cache_get_cookies_values() );
			return false;
		} elseif ( wpsc_get_accept_header() !== 'text/html' ) {
			wp_cache_debug( 'Accept header is not text/html. Cannot serve supercache file.' . wp_cache_get_cookies_values() );
			return false;
		} elseif ( isset( $wpsc_save_headers ) && $wpsc_save_headers ) {
			wp_cache_debug( 'Saving headers. Cannot serve a supercache file.' );
			return false;
		} elseif ( $cache_max_time > 0 && ( filemtime( $file ) + $cache_max_time ) < time() ) {
			wp_cache_debug( sprintf( 'Cache has expired and is older than %d seconds old.', $cache_max_time ) );
			return false;
		}

		if ( isset( $wp_cache_mfunc_enabled ) == false ) {
			$wp_cache_mfunc_enabled = 0;
		}

		if ( false == isset( $wp_cache_home_path ) ) {
			$wp_cache_home_path = '/';
		}

		// make sure ending slashes are ok
		if ( $wp_cache_request_uri == $wp_cache_home_path || ( $wp_cache_slash_check && substr( $wp_cache_request_uri, -1 ) == '/' ) || ( $wp_cache_slash_check == 0 && substr( $wp_cache_request_uri, -1 ) != '/' ) ) {

			if ( $wp_cache_mfunc_enabled == 0 ) {
				// get data from file
				if ( $wp_cache_gzip_encoding ) {
					if ( file_exists( $file . '.gz' ) ) {
						$cachefiledata = file_get_contents( $file . '.gz' );
						wp_cache_debug( "Fetched gzip static page data from supercache file using PHP. File: $file.gz" );
					} else {
						$cachefiledata = gzencode( file_get_contents( $file ), 6, FORCE_GZIP );
						wp_cache_debug( "Fetched static page data from supercache file using PHP and gzipped it. File: $file" );
					}
				} else {
					$cachefiledata = file_get_contents( $file );
					wp_cache_debug( "Fetched static page data from supercache file using PHP. File: $file" );
				}
			} else {
				// get dynamic data from filtered file
				$cachefiledata = do_cacheaction( 'wpsc_cachedata', file_get_contents( $file ) );
				if ( $wp_cache_gzip_encoding ) {
					$cachefiledata = gzencode( $cachefiledata, 6, FORCE_GZIP );
					wp_cache_debug( "Fetched dynamic page data from supercache file using PHP and gzipped it. File: $file" );
				} else {
					wp_cache_debug( "Fetched dynamic page data from supercache file using PHP. File: $file" );
				}
			}

			if ( isset( $wp_cache_disable_utf8 ) == false || $wp_cache_disable_utf8 == 0 ) {
				header( 'Content-type: text/html; charset=UTF-8' );
			}

			if ( defined( 'WPSC_VARY_HEADER' ) ) {
				if ( WPSC_VARY_HEADER != '' ) {
					header( 'Vary: ' . WPSC_VARY_HEADER );
				}
			} else {
				header( 'Vary: Accept-Encoding, Cookie' );
			}
			if ( defined( 'WPSC_CACHE_CONTROL_HEADER' ) ) {
				if ( WPSC_CACHE_CONTROL_HEADER != '' ) {
					header( 'Cache-Control: ' . WPSC_CACHE_CONTROL_HEADER );
				}
			} else {
				header( 'Cache-Control: max-age=3, must-revalidate' );
			}
			$size = ( function_exists( 'mb_strlen' ) && function_exists( 'is_utf8_charset' ) ) ? mb_strlen( $cachefiledata, '8bit' ) : strlen( $cachefiledata );
			if ( $wp_cache_gzip_encoding ) {
				if ( isset( $wpsc_served_header ) && $wpsc_served_header ) {
					header( 'X-WP-Super-Cache: Served supercache gzip file from PHP' );
				}
				header( 'Content-Encoding: ' . $wp_cache_gzip_encoding );
				header( 'Content-Length: ' . $size );
			} elseif ( $wp_supercache_304 ) {
				if ( isset( $wpsc_served_header ) && $wpsc_served_header ) {
					header( 'X-WP-Super-Cache: Served supercache 304 file from PHP' );
				}
				header( 'Content-Length: ' . $size );
			} elseif ( isset( $wpsc_served_header ) && $wpsc_served_header ) {
				header( 'X-WP-Super-Cache: Served supercache file from PHP' );
			}

			// don't try to match modified dates if using dynamic code.
			if ( $wp_cache_mfunc_enabled == 0 && $wp_supercache_304 ) {
				wp_cache_debug( 'wp_cache_serve_cache_file: checking age of cached vs served files.' );
				$headers         = apache_request_headers();
				$remote_mod_time = isset( $headers['If-Modified-Since'] ) ? $headers['If-Modified-Since'] : null;

				if ( $remote_mod_time === null && isset( $_SERVER['HTTP_IF_MODIFIED_SINCE'] ) ) {
					$remote_mod_time = $_SERVER['HTTP_IF_MODIFIED_SINCE'];
				}

				$local_mod_time = gmdate( 'D, d M Y H:i:s', filemtime( $file ) ) . ' GMT';
				if ( $remote_mod_time !== null && $remote_mod_time == $local_mod_time ) {
					wp_cache_debug( 'wp_cache_serve_cache_file: Send 304 Not Modified header.' );
					header( $_SERVER['SERVER_PROTOCOL'] . ' 304 Not Modified' );
					exit();
				} else {
					wp_cache_debug( 'wp_cache_serve_cache_file: 304 browser caching not possible as timestamps differ.' );
				}
				header( 'Last-Modified: ' . $local_mod_time );
			}
			echo $cachefiledata;
			exit();
		} else {
			wp_cache_debug( 'No wp-cache file exists. Must generate a new one.' );
			return false;
		}
	}

	$cache_file = do_cacheaction( 'wp_cache_served_cache_file', $cache_file );
	// Sometimes the gzip headers are lost. Make sure html returned isn't compressed!
	$do_not_serve_gzip_data = true;
	if ( $cache_compression && $wp_cache_gzip_encoding ) {
		if ( ! in_array( 'Content-Encoding: ' . $wp_cache_gzip_encoding, $meta['headers'], true ) ) {
			wp_cache_debug( 'GZIP headers not found. Force uncompressed output.' );
		} else {
			$do_not_serve_gzip_data = false;
			if ( isset( $meta['dynamic'] ) ) {
				unset( $meta['headers']['Content-Length'] ); // this is set later after the output data is compressed
			}
			wp_cache_debug( 'GZIP headers found. Serving compressed output.' );
		}
	}

	foreach ( $meta['headers'] as $t => $header ) {
		// godaddy fix, via http://blog.gneu.org/2008/05/wp-supercache-on-godaddy/ and http://www.littleredrails.com/blog/2007/09/08/using-wp-cache-on-godaddy-500-error/
		if ( strpos( $header, 'Last-Modified:' ) === false ) {
			header( $header );
			wp_cache_debug( 'Sending Header: ' . $header );
		}
	}
	if ( isset( $wpsc_served_header ) && $wpsc_served_header ) {
		header( 'X-WP-Super-Cache: Served WPCache cache file' );
	}
	if ( isset( $meta['dynamic'] ) ) {
		wp_cache_debug( 'Serving wp-cache dynamic file', 5 );
		if ( $do_not_serve_gzip_data ) {
			// attempt to uncompress the cached file just in case it's gzipped
			$cache        = wp_cache_get_legacy_cache( $cache_file );
			$uncompressed = @gzuncompress( $cache );
			if ( $uncompressed ) {
				wp_cache_debug( 'Uncompressed gzipped cache from wp-cache: ' . $cache_file );
				$cache = $uncompressed;
				unset( $uncompressed );
			}
			$cache = do_cacheaction( 'wpsc_cachedata', $cache );
		} else {
			wp_cache_debug( 'Compressed cache data from wp-cache: ' . $cache_file );
			$cache = gzencode(
				do_cacheaction(
					'wpsc_cachedata',
					wp_cache_get_legacy_cache( $cache_file )
				),
				6,
				FORCE_GZIP
			);
			$size  = ( function_exists( 'mb_strlen' ) && function_exists( 'is_utf8_charset' ) ) ? mb_strlen( $cache, '8bit' ) : strlen( $cache );
			wp_cache_debug( 'Sending Header: Content-Length: ' . $size );
			header( 'Content-Length: ' . $size );
		}
	} elseif ( $do_not_serve_gzip_data ) {
		$cache        = wp_cache_get_legacy_cache( $cache_file );
		$uncompressed = @gzuncompress( $cache ); // phpcs:ignore WordPress.PHP.NoSilencedErrors.Discouraged -- there is a small chance the cache isn't gzipped despite being configured to be.
		if ( $uncompressed ) {
			$cache = $uncompressed;
			unset( $uncompressed );
			wp_cache_debug( 'Uncompressed gzipped cache data from wp-cache file: ' . $cache_file );
		} else {
			wp_cache_debug( 'Sending already uncompressed cache file from wp-cache to browser: ' . $cache_file );
		}
	} else {
		wp_cache_debug( 'Sending wp-cache file to browser: ' . $cache_file );
		$cache = wp_cache_get_legacy_cache( $cache_file );
	}
	// phpcs:ignore WordPress.Security.EscapeOutput.OutputNotEscaped -- this is the cached version of the current page. It will have been escaped already.
	echo $cache;
	wp_cache_debug( 'exit request', 5 );
	die();
}