1.7.0 alpha
This commit is contained in:
parent
49c4da89f9
commit
0356107ea7
5 changed files with 69 additions and 119 deletions
23
readme.txt
23
readme.txt
|
@ -4,7 +4,7 @@ Donate link: https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_i
|
||||||
Tags: cache, page cache, full page cache, nginx, memcached, apc, speed
|
Tags: cache, page cache, full page cache, nginx, memcached, apc, speed
|
||||||
Requires at least: 3.0
|
Requires at least: 3.0
|
||||||
Tested up to: 4.0
|
Tested up to: 4.0
|
||||||
Stable tag: 1.6.4
|
Stable tag: 1.7.0
|
||||||
License: GPLv3
|
License: GPLv3
|
||||||
License URI: http://www.gnu.org/licenses/gpl-3.0.html
|
License URI: http://www.gnu.org/licenses/gpl-3.0.html
|
||||||
|
|
||||||
|
@ -34,17 +34,21 @@ It can be configured to join forces with [NGiNX](http://NGiNX.org "NGiNX")'s bui
|
||||||
* talkative log for [WP_DEBUG](http://codex.wordpress.org/WP_DEBUG "WP_DEBUG")
|
* talkative log for [WP_DEBUG](http://codex.wordpress.org/WP_DEBUG "WP_DEBUG")
|
||||||
* multiple memcached upstream support
|
* multiple memcached upstream support
|
||||||
* precache ( manually or by timed by wp-cron )
|
* precache ( manually or by timed by wp-cron )
|
||||||
|
* varying expiration time for posts, taxonomies and home
|
||||||
|
|
||||||
|
|
||||||
Many thanks for donations, contributors, supporters, testers & bug reporters:
|
Many thanks for donations, contributors, supporters, testers & bug reporters:
|
||||||
|
|
||||||
* [Harold Kyle](https://github.com/haroldkyle "Harold Kyle")
|
* [Harold Kyle](https://github.com/haroldkyle)
|
||||||
* [Eric Gilette](http://www.ericgillette.com/ "Eric Gilette")
|
* [Eric Gilette](http://www.ericgillette.com/)
|
||||||
* [doconeill](http://wordpress.org/support/profile/doconeill "doconeill")
|
* [doconeill](http://wordpress.org/support/profile/doconeill)
|
||||||
* [Mark Costlow](mailto:cheeks@swcp.com "Mark Costlow")
|
* Mark Costlow
|
||||||
* [Jason Miller](mailto:jason@redconfetti.com "Jason Miller")
|
* Jason Miller
|
||||||
* [Dave Clark](https://github.com/dkcwd "Dave Clark")
|
* [Dave Clark](https://github.com/dkcwd "Dave Clark")
|
||||||
* Miguel Clara
|
* Miguel Clara
|
||||||
* [plescheff](https://github.com/plescheff)
|
* [plescheff](https://github.com/plescheff)
|
||||||
|
* [CotswoldPhoto](http://wordpress.org/support/profile/cotswoldphoto)
|
||||||
|
* [tamagokun](https://github.com/tamagokun)
|
||||||
|
|
||||||
== Installation ==
|
== Installation ==
|
||||||
|
|
||||||
|
@ -106,6 +110,13 @@ Version numbering logic:
|
||||||
* every .B version indicates new features.
|
* every .B version indicates new features.
|
||||||
* every ..C indicates bugfixes for A.B version.
|
* every ..C indicates bugfixes for A.B version.
|
||||||
|
|
||||||
|
= 1.7.0 =
|
||||||
|
*2014-09-19*
|
||||||
|
|
||||||
|
* **dropped Xcache support**, the reasons behind this is the outstandingly terrible documentation of Xcache
|
||||||
|
* added varying expiration time options
|
||||||
|
|
||||||
|
|
||||||
= 1.6.4 =
|
= 1.6.4 =
|
||||||
*2014-09-12*
|
*2014-09-12*
|
||||||
|
|
||||||
|
|
|
@ -52,6 +52,7 @@ elseif ( !empty ( $wp_ffpc_config[ $_SERVER['HTTP_HOST'] ] ) )
|
||||||
else
|
else
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
/* check for cookies that will make us not cache the content, like logged in WordPress cookie */
|
||||||
if ( isset($wp_ffpc_config['nocache_cookies']) && !empty($wp_ffpc_config['nocache_cookies']) ) {
|
if ( isset($wp_ffpc_config['nocache_cookies']) && !empty($wp_ffpc_config['nocache_cookies']) ) {
|
||||||
$nocache_cookies = array_map('trim',explode(",", $wp_ffpc_config['nocache_cookies'] ) );
|
$nocache_cookies = array_map('trim',explode(",", $wp_ffpc_config['nocache_cookies'] ) );
|
||||||
|
|
||||||
|
|
|
@ -160,9 +160,21 @@ class WP_FFPC_Backend {
|
||||||
/* log the current action */
|
/* log the current action */
|
||||||
$this->log ( sprintf( __translate__( 'set %s expiration time: %s', $this->plugin_constant ), $key, $this->options['expire'] ) );
|
$this->log ( sprintf( __translate__( 'set %s expiration time: %s', $this->plugin_constant ), $key, $this->options['expire'] ) );
|
||||||
|
|
||||||
|
/* expiration time based is based on type from now on */
|
||||||
|
/* fallback */
|
||||||
|
$expire = $this->options['expire'];
|
||||||
|
|
||||||
|
if ( is_home() || is_feed() )
|
||||||
|
$expire = $this->options['expire_home'];
|
||||||
|
elseif ( is_tax() || is_category() || is_tag() || is_archive() )
|
||||||
|
$expire = $this->options['expire_taxonomy'];
|
||||||
|
|
||||||
|
if ( empty($expire) )
|
||||||
|
return false;
|
||||||
|
|
||||||
/* proxy to internal function */
|
/* proxy to internal function */
|
||||||
$internal = $this->proxy( 'set' );
|
$internal = $this->proxy( 'set' );
|
||||||
$result = $this->$internal( $key, $data );
|
$result = $this->$internal( $key, $data, $expire );
|
||||||
|
|
||||||
/* check result validity */
|
/* check result validity */
|
||||||
if ( $result === false )
|
if ( $result === false )
|
||||||
|
@ -171,6 +183,11 @@ class WP_FFPC_Backend {
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public function clear_ng ( $new_status, $old_status, $post ) {
|
||||||
|
$this->clear ( $post->ID );
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* public get function, transparent proxy to internal function based on backend
|
* public get function, transparent proxy to internal function based on backend
|
||||||
*
|
*
|
||||||
|
@ -512,8 +529,8 @@ class WP_FFPC_Backend {
|
||||||
*
|
*
|
||||||
* @return boolean APC store outcome
|
* @return boolean APC store outcome
|
||||||
*/
|
*/
|
||||||
private function apc_set ( &$key, &$data ) {
|
private function apc_set ( &$key, &$data, &$expire ) {
|
||||||
return apc_store( $key , $data , $this->options['expire'] );
|
return apc_store( $key , $data , $expire );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -598,8 +615,8 @@ class WP_FFPC_Backend {
|
||||||
*
|
*
|
||||||
* @return boolean APC store outcome
|
* @return boolean APC store outcome
|
||||||
*/
|
*/
|
||||||
private function apcu_set ( &$key, &$data ) {
|
private function apcu_set ( &$key, &$data, &$expire ) {
|
||||||
return apcu_store( $key , $data , $this->options['expire'] );
|
return apcu_store( $key , $data , $expire );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -636,106 +653,6 @@ class WP_FFPC_Backend {
|
||||||
|
|
||||||
/*********************** END APC FUNCTIONS ***********************/
|
/*********************** END APC FUNCTIONS ***********************/
|
||||||
|
|
||||||
/*********************** XCACHE FUNCTIONS ***********************/
|
|
||||||
/**
|
|
||||||
* init apc backend: test APC availability and set alive status
|
|
||||||
*/
|
|
||||||
private function xcache_init () {
|
|
||||||
/* verify apc functions exist, apc extension is loaded */
|
|
||||||
if ( ! function_exists( 'xcache_info' ) ) {
|
|
||||||
$this->log ( __translate__('XCACHE extension missing', $this->plugin_constant ) );
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
$xcache_admin = ini_get ( 'xcache.admin.user' );
|
|
||||||
$xcache_pass = ini_get ( 'xcache.admin.pass' );
|
|
||||||
|
|
||||||
if ( empty( $xcache_admin ) || empty( $xcache_pass ) ) {
|
|
||||||
$this->log ( __translate__('XCACHE xcache.admin.user or xcache.admin.pass is not set in php.ini. Please set them, otherwise the use cache part of xcache is not accessible.', $this->plugin_constant ) );
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* verify apc is working */
|
|
||||||
$info = xcache_info();
|
|
||||||
if ( !empty( $info )) {
|
|
||||||
$this->log ( __translate__('backend OK', $this->plugin_constant ) );
|
|
||||||
$this->alive = true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* health checker for Xcache
|
|
||||||
*
|
|
||||||
* @return boolean Aliveness status
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
private function xcache_status () {
|
|
||||||
$this->status = true;
|
|
||||||
return $this->alive;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* get function for APC backend
|
|
||||||
*
|
|
||||||
* @param string $key Key to get values for
|
|
||||||
*
|
|
||||||
* @return mixed Fetched data based on key
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
private function xcache_get ( &$key ) {
|
|
||||||
if ( xcache_isset ( $key ) )
|
|
||||||
return xcache_get( $key );
|
|
||||||
else
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Set function for APC backend
|
|
||||||
*
|
|
||||||
* @param string $key Key to set with
|
|
||||||
* @param mixed $data Data to set
|
|
||||||
*
|
|
||||||
* @return boolean APC store outcome
|
|
||||||
*/
|
|
||||||
private function xcache_set ( &$key, &$data ) {
|
|
||||||
return xcache_set( $key , $data , $this->options['expire'] );
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Flushes APC user entry storage
|
|
||||||
*
|
|
||||||
* @return boolean APC flush outcome status
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
private function xcache_flush ( ) {
|
|
||||||
return xcache_clear_cache(XC_TYPE_VAR);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Removes entry from APC or flushes APC user entry storage
|
|
||||||
*
|
|
||||||
* @param mixed $keys Keys to clear, string or array
|
|
||||||
*/
|
|
||||||
private function xcache_clear ( &$keys ) {
|
|
||||||
/* make an array if only one string is present, easier processing */
|
|
||||||
if ( !is_array ( $keys ) )
|
|
||||||
$keys = array ( $keys => true );
|
|
||||||
|
|
||||||
foreach ( $keys as $key => $dummy ) {
|
|
||||||
if ( ! xcache_unset ( $key ) ) {
|
|
||||||
$this->log ( sprintf( __translate__( 'Failed to delete XCACHE entry: %s', $this->plugin_constant ), $key ), LOG_WARNING );
|
|
||||||
//throw new Exception ( __translate__('Deleting APC entry failed with key ', $this->plugin_constant ) . $key );
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$this->log ( sprintf( __translate__( 'XCACHE entry delete: %s', $this->plugin_constant ), $key ) );
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*********************** END XCACHE FUNCTIONS ***********************/
|
|
||||||
|
|
||||||
|
|
||||||
/*********************** MEMCACHED FUNCTIONS ***********************/
|
/*********************** MEMCACHED FUNCTIONS ***********************/
|
||||||
/**
|
/**
|
||||||
* init memcached backend
|
* init memcached backend
|
||||||
|
@ -845,8 +762,8 @@ class WP_FFPC_Backend {
|
||||||
* @param mixed $data Data to set
|
* @param mixed $data Data to set
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private function memcached_set ( &$key, &$data ) {
|
private function memcached_set ( &$key, &$data, &$expire ) {
|
||||||
$result = $this->connection->set ( $key, $data , $this->options['expire'] );
|
$result = $this->connection->set ( $key, $data , $expire );
|
||||||
|
|
||||||
/* if storing failed, log the error code */
|
/* if storing failed, log the error code */
|
||||||
if ( $result === false ) {
|
if ( $result === false ) {
|
||||||
|
@ -979,8 +896,8 @@ class WP_FFPC_Backend {
|
||||||
* @param mixed $data Data to set
|
* @param mixed $data Data to set
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
private function memcache_set ( &$key, &$data ) {
|
private function memcache_set ( &$key, &$data, &$expire ) {
|
||||||
$result = $this->connection->set ( $key, $data , 0 , $this->options['expire'] );
|
$result = $this->connection->set ( $key, $data , 0 , $expire );
|
||||||
return $result;
|
return $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -180,6 +180,8 @@ class WP_FFPC extends PluginAbstract {
|
||||||
$post_types = get_post_types( );
|
$post_types = get_post_types( );
|
||||||
|
|
||||||
/* cache invalidation hooks */
|
/* cache invalidation hooks */
|
||||||
|
add_action( 'transition_post_status', array( &$this->backend , 'clear_ng' ), 10, 3 );
|
||||||
|
/*
|
||||||
foreach ( $post_types as $post_type ) {
|
foreach ( $post_types as $post_type ) {
|
||||||
add_action( 'new_to_publish_' .$post_type , array( &$this->backend , 'clear' ), 0 );
|
add_action( 'new_to_publish_' .$post_type , array( &$this->backend , 'clear' ), 0 );
|
||||||
add_action( 'draft_to_publish' .$post_type , array( &$this->backend , 'clear' ), 0 );
|
add_action( 'draft_to_publish' .$post_type , array( &$this->backend , 'clear' ), 0 );
|
||||||
|
@ -187,6 +189,7 @@ class WP_FFPC extends PluginAbstract {
|
||||||
add_action( 'private_to_publish' .$post_type , array( &$this->backend , 'clear' ), 0 );
|
add_action( 'private_to_publish' .$post_type , array( &$this->backend , 'clear' ), 0 );
|
||||||
add_action( 'publish_' . $post_type , array( &$this->backend , 'clear' ), 0 );
|
add_action( 'publish_' . $post_type , array( &$this->backend , 'clear' ), 0 );
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|
||||||
/* comments invalidation hooks */
|
/* comments invalidation hooks */
|
||||||
if ( $this->options['comments_invalidate'] ) {
|
if ( $this->options['comments_invalidate'] ) {
|
||||||
|
@ -462,11 +465,27 @@ class WP_FFPC extends PluginAbstract {
|
||||||
</dd>
|
</dd>
|
||||||
|
|
||||||
<dt>
|
<dt>
|
||||||
<label for="expire"><?php _e('Expiration time (seconds)', $this->plugin_constant); ?></label>
|
<label for="expire"><?php _e('Expiration time for posts', $this->plugin_constant); ?></label>
|
||||||
</dt>
|
</dt>
|
||||||
<dd>
|
<dd>
|
||||||
<input type="number" name="expire" id="expire" value="<?php echo $this->options['expire']; ?>" />
|
<input type="number" name="expire" id="expire" value="<?php echo $this->options['expire']; ?>" />
|
||||||
<span class="description"><?php _e('Sets validity time of entry in seconds', $this->plugin_constant); ?></span>
|
<span class="description"><?php _e('Sets validity time of post entry in seconds, including custom post types and pages.', $this->plugin_constant); ?></span>
|
||||||
|
</dd>
|
||||||
|
|
||||||
|
<dt>
|
||||||
|
<label for="expire_taxonomy"><?php _e('Expiration time for taxonomy', $this->plugin_constant); ?></label>
|
||||||
|
</dt>
|
||||||
|
<dd>
|
||||||
|
<input type="number" name="expire_taxonomy" id="expire_taxonomy" value="<?php echo $this->options['expire_taxonomy']; ?>" />
|
||||||
|
<span class="description"><?php _e('Sets validity time of taxonomy entry in seconds, including custom taxonomy.', $this->plugin_constant); ?></span>
|
||||||
|
</dd>
|
||||||
|
|
||||||
|
<dt>
|
||||||
|
<label for="expire_home"><?php _e('Expiration time for home', $this->plugin_constant); ?></label>
|
||||||
|
</dt>
|
||||||
|
<dd>
|
||||||
|
<input type="number" name="expire_home" id="expire_home" value="<?php echo $this->options['expire_home']; ?>" />
|
||||||
|
<span class="description"><?php _e('Sets validity time of home.', $this->plugin_constant); ?></span>
|
||||||
</dd>
|
</dd>
|
||||||
|
|
||||||
<dt>
|
<dt>
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
Plugin Name: WP-FFPC
|
Plugin Name: WP-FFPC
|
||||||
Plugin URI: https://github.com/petermolnar/wp-ffpc
|
Plugin URI: https://github.com/petermolnar/wp-ffpc
|
||||||
Description: WordPress in-memory full page cache plugin
|
Description: WordPress in-memory full page cache plugin
|
||||||
Version: 1.6.4
|
Version: 1.7.0
|
||||||
Author: Peter Molnar <hello@petermolnar.eu>
|
Author: Peter Molnar <hello@petermolnar.eu>
|
||||||
Author URI: http://petermolnar.eu/
|
Author URI: http://petermolnar.eu/
|
||||||
License: GPLv3
|
License: GPLv3
|
||||||
|
@ -32,6 +32,8 @@ $wp_ffpc_defaults = array (
|
||||||
'authpass'=>'',
|
'authpass'=>'',
|
||||||
'authuser'=>'',
|
'authuser'=>'',
|
||||||
'expire'=>300,
|
'expire'=>300,
|
||||||
|
'expire_home'=>300,
|
||||||
|
'expire_taxonomy'=>300,
|
||||||
'invalidation_method'=>0,
|
'invalidation_method'=>0,
|
||||||
'prefix_meta' =>'meta-',
|
'prefix_meta' =>'meta-',
|
||||||
'prefix_data' =>'data-',
|
'prefix_data' =>'data-',
|
||||||
|
@ -55,6 +57,6 @@ $wp_ffpc_defaults = array (
|
||||||
'comments_invalidate' => true,
|
'comments_invalidate' => true,
|
||||||
);
|
);
|
||||||
|
|
||||||
$wp_ffpc = new WP_FFPC ( 'wp-ffpc', '1.6.0', 'WP-FFPC', $wp_ffpc_defaults, 'PeterMolnar_WordPressPlugins_wp-ffpc_HU' , 'WP-FFPC' , 'FA3NT7XDVHPWU' );
|
$wp_ffpc = new WP_FFPC ( 'wp-ffpc', '1.7.0', 'WP-FFPC', $wp_ffpc_defaults, 'PeterMolnar_WordPressPlugins_wp-ffpc_HU' , 'WP-FFPC' , 'FA3NT7XDVHPWU' );
|
||||||
|
|
||||||
?>
|
?>
|
||||||
|
|
Loading…
Reference in a new issue