/wp-content/plugins/wp-cache/wp-cache-phase2.php
PHP | 328 lines | 288 code | 23 blank | 17 comment | 30 complexity | 47ffedbd2cfcad286c15bb040619b4e8 MD5 | raw file
- <?php
- /** Diable here because PHP4.3 does not make the global
- Serious bug?
- $mutex_filename = 'wp_cache_mutex.lock';
- $new_cache = false;
- */
- function wp_cache_phase2() {
- global $cache_filename, $cache_acceptable_files, $wp_cache_meta_object;
- wp_cache_mutex_init();
- if(function_exists('add_action')) {
- // Post ID is received
- add_action('publish_post', 'wp_cache_post_change', 0);
- add_action('edit_post', 'wp_cache_post_change', 0);
- add_action('delete_post', 'wp_cache_post_change', 0);
- add_action('publish_phone', 'wp_cache_post_change', 0);
- // Coment ID is received
- add_action('trackback_post', 'wp_cache_get_postid_from_comment', 0);
- add_action('pingback_post', 'wp_cache_get_postid_from_comment', 0);
- add_action('comment_post', 'wp_cache_get_postid_from_comment', 0);
- add_action('edit_comment', 'wp_cache_get_postid_from_comment', 0);
- add_action('wp_set_comment_status', 'wp_cache_get_postid_from_comment', 0);
- // No post_id is available
- add_action('delete_comment', 'wp_cache_no_postid', 0);
- add_action('switch_theme', 'wp_cache_no_postid', 0);
- }
- //$script = basename($_SERVER['SCRIPT_NAME']);
- if( $_SERVER["REQUEST_METHOD"] == 'POST' || get_settings('gzipcompression'))
- return;
- $script = basename($_SERVER['PHP_SELF']);
- if (!in_array($script, $cache_acceptable_files) &&
- wp_cache_is_rejected($_SERVER["REQUEST_URI"]))
- return;
- if (wp_cache_user_agent_is_rejected()) return;
- $wp_cache_meta_object = new CacheMeta;
- ob_start('wp_cache_ob_callback');
- register_shutdown_function('wp_cache_shutdown_callback');
- }
- function wp_cache_get_response_headers() {
- if(function_exists('apache_response_headers')) {
- $headers = apache_response_headers();
- } else if(function_exists('headers_list')) {
- $headers = array();
- foreach(headers_list() as $hdr) {
- list($header_name, $header_value) = explode(': ', $hdr, 2);
- $headers[$header_name] = $header_value;
- }
- } else
- $headers = null;
- return $headers;
- }
- function wp_cache_is_rejected($uri) {
- global $cache_rejected_uri;
- if (strstr($uri, '/wp-admin/'))
- return true; //we don't allow cacheing wp-admin for security
- foreach ($cache_rejected_uri as $expr) {
- if (strlen($expr) > 0 && strstr($uri, $expr))
- return true;
- }
- return false;
- }
- function wp_cache_user_agent_is_rejected() {
- global $cache_rejected_user_agent;
- if (!function_exists('apache_request_headers')) return false;
- $headers = apache_request_headers();
- if (!isset($headers["User-Agent"])) return false;
- foreach ($cache_rejected_user_agent as $expr) {
- if (strlen($expr) > 0 && stristr($headers["User-Agent"], $expr))
- return true;
- }
- return false;
- }
- function wp_cache_mutex_init() {
- global $use_flock, $mutex, $cache_path, $mutex_filename, $sem_id;
- if(!is_bool($use_flock)) {
- if(function_exists('sem_get'))
- $use_flock = false;
- else
- $use_flock = true;
- }
- if ($use_flock)
- $mutex = fopen($cache_path . $mutex_filename, 'w');
- else
- $mutex = sem_get($sem_id, 1, 0644 | IPC_CREAT, 1);
- }
- function wp_cache_writers_entry() {
- global $use_flock, $mutex, $cache_path, $mutex_filename;
- if ($use_flock)
- flock($mutex, LOCK_EX);
- else
- sem_acquire($mutex);
- }
- function wp_cache_writers_exit() {
- global $use_flock, $mutex, $cache_path, $mutex_filename;
- if ($use_flock)
- flock($mutex, LOCK_UN);
- else
- sem_release($mutex);
- }
- function wp_cache_ob_callback($buffer) {
- global $cache_path, $cache_filename, $meta_file, $wp_start_time;
- global $new_cache, $wp_cache_meta_object, $file_expired, $blog_id;
- /* Mode paranoic, check for closing tags
- * we avoid caching incomplete files */
- if (is_404() || !preg_match('/(<\/html>|<\/rss>|<\/feed>)/i',$buffer) ) {
- $new_cache = false;
- return $buffer;
- }
- $duration = wp_cache_microtime_diff($wp_start_time, microtime());
- $duration = sprintf("%0.3f", $duration);
- $buffer .= "\n<!-- Dynamic Page Served (once) in $duration seconds -->\n";
- wp_cache_writers_entry();
- $mtime = @filemtime($cache_path . $cache_filename);
- /* Return if:
- the file didn't exist before but it does exist now (another connection created)
- OR
- the file was expired and its mtime is less than 5 seconds
- */
- if( !((!$file_expired && $mtime) || ($mtime && $file_expired && (time() - $mtime) < 5)) ) {
- $fr = fopen($cache_path . $cache_filename, 'w');
- if (!$fr)
- $buffer = "Couldn't write to: " . $cache_path . $cache_filename . "\n";
- if (preg_match('/<!--mclude|<!--mfunc/', $buffer)) { //Dynamic content
- $store = preg_replace('|<!--mclude (.*?)-->(.*?)<!--/mclude-->|is',
- "<!--mclude-->\n<?php include_once('" . ABSPATH . "$1'); ?>\n<!--/mclude-->", $buffer);
- $store = preg_replace('|<!--mfunc (.*?)-->(.*?)<!--/mfunc-->|is',
- "<!--mfunc-->\n<?php $1 ;?>\n<!--/mfunc-->", $store);
- $wp_cache_meta_object->dynamic = true;
- /* Clean function calls in tag */
- $buffer = preg_replace('|<!--mclude (.*?)-->|is', '<!--mclude-->', $buffer);
- $buffer = preg_replace('|<!--mfunc (.*?)-->|is', '<!--mfunc-->', $buffer);
- fputs($fr, $store);
- } else {
- fputs($fr, $buffer);
- }
- $new_cache = true;
- fclose($fr);
- }
- wp_cache_writers_exit();
- return $buffer;
- }
- function wp_cache_phase2_clean_cache($file_prefix) {
- global $cache_path;
- wp_cache_writers_entry();
- if ( ($handle = opendir( $cache_path )) ) {
- while ( false !== ($file = readdir($handle))) {
- if ( preg_match("/^$file_prefix/", $file) ) {
- unlink($cache_path . $file);
- }
- }
- closedir($handle);
- }
- wp_cache_writers_exit();
- }
- function wp_cache_phase2_clean_expired($file_prefix) {
- global $cache_path, $cache_max_time;
- clearstatcache();
- wp_cache_writers_entry();
- $now = time();
- if ( ($handle = opendir( $cache_path )) ) {
- while ( false !== ($file = readdir($handle))) {
- if ( preg_match("/^$file_prefix/", $file) &&
- (filemtime($cache_path . $file) + $cache_max_time) <= $now ) {
- unlink($cache_path . $file);
- }
- }
- closedir($handle);
- }
- wp_cache_writers_exit();
- }
- function wp_cache_shutdown_callback() {
- global $cache_path, $cache_max_time, $file_expired, $file_prefix, $meta_file, $new_cache;
- global $wp_cache_meta_object, $known_headers, $blog_id;
- $wp_cache_meta_object->uri = $_SERVER["SERVER_NAME"].preg_replace('/[ <>\'\"\r\n\t\(\)]/', '', $_SERVER['REQUEST_URI']); // To avoid XSS attacs
- $wp_cache_meta_object->blog_id=$blog_id;
- $wp_cache_meta_object->post = wp_cache_post_id();
- $response = wp_cache_get_response_headers();
- $wp_cache_meta_object->headers = array();
- foreach ($known_headers as $key) {
- if(isset($response{$key})) {
- array_push($wp_cache_meta_object->headers, "$key: " . $response{$key});
- }
- }
- /* Not used because it gives problems with some
- * PHP installations
- if (!$response{'Content-Length'}) {
- // WP does not set content size
- $content_size = ob_get_length();
- @header("Content-Length: $content_size");
- array_push($wp_cache_meta_object->headers, "Content-Length: $content_size");
- }
- */
- if (!$response{'Last-Modified'}) {
- $value = gmdate('D, d M Y H:i:s') . ' GMT';
- /* Dont send this the first time */
- /* @header('Last-Modified: ' . $value); */
- array_push($wp_cache_meta_object->headers, "Last-Modified: $value");
- }
- if (!$response{'Content-Type'} && !$response{'Content-type'}) {
- $value = "text/html; charset=" . get_settings('blog_charset');
- @header("Content-Type: $value");
- array_push($wp_cache_meta_object->headers, "Content-Type: $value");
- }
- ob_end_flush();
- if ($new_cache) {
- $serial = serialize($wp_cache_meta_object);
- wp_cache_writers_entry();
- $fr = fopen($cache_path . $meta_file, 'w');
- fputs($fr, $serial);
- fclose($fr);
- wp_cache_writers_exit();
- }
- if ($file_expired == false) {
- return;
- }
- // we delete expired files
- flush(); //Ensure we send data to the client
- wp_cache_phase2_clean_expired($file_prefix);
- }
- function wp_cache_no_postid($id) {
- return wp_cache_post_change(wp_cache_post_id());
- }
- function wp_cache_get_postid_from_comment($comment_id) {
- $comment = get_commentdata($comment_id, 1, true);
- $postid = $comment['comment_post_ID'];
- // Do nothing if comment is not moderated
- // http://ocaoimh.ie/2006/12/05/caching-wordpress-with-wp-cache-in-a-spam-filled-world
- if( !preg_match('/wp-admin\//', $_SERVER['REQUEST_URI']) && $comment['comment_approved'] != 1 )
- return $post_id;
- // We must check it up again due to WP bugs calling two different actions
- // for delete, for example both wp_set_comment_status and delete_comment
- // are called when deleting a comment
- if ($postid > 0)
- return wp_cache_post_change($postid);
- else
- return wp_cache_post_change(wp_cache_post_id());
- }
- function wp_cache_post_change($post_id) {
- global $file_prefix;
- global $cache_path;
- global $blog_id;
- static $last_processed = -1;
- // Avoid cleaning twice the same pages
- if ($post_id == $last_processed) return $post_id;
- $last_processed = $post_id;
- $meta = new CacheMeta;
- $matches = array();
- wp_cache_writers_entry();
- if ( ($handle = opendir( $cache_path )) ) {
- while ( false !== ($file = readdir($handle))) {
- if ( preg_match("/^($file_prefix.*)\.meta/", $file, $matches) ) {
- $meta_pathname = $cache_path . $file;
- $content_pathname = $cache_path . $matches[1] . ".html";
- $meta = unserialize(@file_get_contents($meta_pathname));
- if ($post_id > 0 && $meta) {
- if ($meta->blog_id == $blog_id && (!$meta->post || $meta->post == $post_id) ) {
- unlink($meta_pathname);
- unlink($content_pathname);
- }
- } elseif ($meta->blog_id == $blog_id) {
- unlink($meta_pathname);
- unlink($content_pathname);
- }
- }
- }
- closedir($handle);
- }
- wp_cache_writers_exit();
- return $post_id;
- }
- function wp_cache_microtime_diff($a, $b) {
- list($a_dec, $a_sec) = explode(' ', $a);
- list($b_dec, $b_sec) = explode(' ', $b);
- return $b_sec - $a_sec + $b_dec - $a_dec;
- }
- function wp_cache_post_id() {
- global $posts, $comment_post_ID, $post_ID;
- // We try hard all options. More frequent first.
- if ($post_ID > 0 ) return $post_ID;
- if ($comment_post_ID > 0 ) return $comment_post_ID;
- if (is_single() || is_page()) return $posts[0]->ID;
- if ($_GET['p'] > 0) return $_GET['p'];
- if ($_POST['p'] > 0) return $_POST['p'];
- return 0;
- }
- ?>