version 1.6.0, see changelog

This commit is contained in:
Peter Molnar 2014-08-22 11:55:25 +01:00
parent aaf703fd8d
commit 2b2345c763
6 changed files with 115 additions and 47 deletions

View file

@ -3,8 +3,8 @@ Contributors: cadeyrn
Donate link: https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=XU3DG7LLA76WC Donate link: https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=XU3DG7LLA76WC
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: 3.9.1 Tested up to: 4.0
Stable tag: 1.5.0 Stable tag: 1.6.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
@ -17,14 +17,14 @@ It can be configured to join forces with [NGiNX](http://NGiNX.org "NGiNX")'s bui
= Features: = = Features: =
* Wordpress Network support * Wordpress Network support
* fully supported domain/subdomain based WordPress Networks on per site setup as well * fully supported domain/subdomain based WordPress Networks on per site setup as well
* will work in Network Enabled mode only for subdirectory based Multisites ( no per site setting possibility ) * will work in Network Enabled mode only for subdirectory based Multisites ( per site settings will not work in this case )
* supports variable backends * supports various backends
* memcached with [PHP Memcached](http://php.net/manual/en/book.memcached.php "Memcached") * memcached with [PHP Memcached](http://php.net/manual/en/book.memcached.php "Memcached")
* memcached with [PHP Memcache](http://php.net/manual/en/book.memcache.php "Memcache") * memcached with [PHP Memcache](http://php.net/manual/en/book.memcache.php "Memcache")
* [APC](http://php.net/manual/en/book.apc.php "APC") * [APC](http://php.net/manual/en/book.apc.php "APC")
* [APCu](http://pecl.php.net/package/APCu "APC User Cache") * [APCu](http://pecl.php.net/package/APCu "APC User Cache")
* [Xcache](http://xcache.lighttpd.net/ "Xcache") - not stable yet, volunteer testers required! * [Xcache](http://xcache.lighttpd.net/ "Xcache") - not stable yet, volunteer testers required!
* cache exclude possibilities ( home, feeds, archieves, pages, singles ) * cache exclude options ( home, feeds, archieves, pages, singles; regex based url exclusion )
* (optional) cache for logged-in users * (optional) cache for logged-in users
* 404 caching * 404 caching
* canonical redirects caching * canonical redirects caching
@ -43,6 +43,8 @@ Many thanks for donations, contributors, supporters, testers & bug reporters:
* [Mark Costlow](mailto:cheeks@swcp.com "Mark Costlow") * [Mark Costlow](mailto:cheeks@swcp.com "Mark Costlow")
* [Jason Miller](mailto:jason@redconfetti.com "Jason Miller") * [Jason Miller](mailto:jason@redconfetti.com "Jason Miller")
* [Dave Clark](https://github.com/dkcwd "Dave Clark") * [Dave Clark](https://github.com/dkcwd "Dave Clark")
* Miguel Clara
* [plescheff](https://github.com/plescheff)
== Installation == == Installation ==
@ -98,6 +100,29 @@ Please post feature requests to [WP-FFPC feature request topic](http://wordpress
== Changelog == == Changelog ==
Version numbering logic:
* every A. indicates BIG changes.
* every .B version indicates new features.
* every ..C indicates bugfixes for A.B version.
= 1.6.0 =
*2014-05-30*
What's new:
* added functionality to exclude regex urls, contribution from [plescheff](https://github.com/plescheff/wp-ffpc/commit/3c875ad4fe1e083d3968421dd83b9c179c686649)
* added functionality to include "?" containing URL
What's fixed:
* some warning messages removed in case there's not a single backend installed when the plugin is activated
Under the hood:
* major changes to the abstract wp-common class for better interoperability between my plugins
= 1.5.0 = = 1.5.0 =
*2014-05-30* *2014-05-30*

@ -1 +1 @@
Subproject commit 2dd92a681f986a6637550a2640c697be39399de9 Subproject commit d84ff213cd944c22a6a440d6faba502abd1da774

View file

@ -26,7 +26,7 @@ if (defined('SID') && SID != '')
$wp_ffpc_uri = $_SERVER['REQUEST_URI']; $wp_ffpc_uri = $_SERVER['REQUEST_URI'];
/* no cache for uri with query strings, things usually go bad that way */ /* no cache for uri with query strings, things usually go bad that way */
if ( stripos($wp_ffpc_uri, '?') !== false) if ( isset($wp_ffpc_config['nocache_dyn']) && !empty($wp_ffpc_config['nocache_dyn']) && stripos($wp_ffpc_uri, '?') !== false ) {
return false; return false;
/* no cache for pages starting with /wp- like WP admin */ /* no cache for pages starting with /wp- like WP admin */
@ -67,6 +67,14 @@ if ( isset($wp_ffpc_config['nocache_cookies']) && !empty($wp_ffpc_config['nocach
} }
} }
/* no cache for excluded URL patterns */
if ( isset($wp_ffpc_config['nocache_url']) && trim($wp_ffpc_config['nocache_url']) ) {
$pattern = sprintf('#%s#', trim($wp_ffpc_config['nocache_url']));
if ( preg_match($pattern, $wp_ffpc_uri) ) {
return false;
}
}
/* canonical redirect storage */ /* canonical redirect storage */
$wp_ffpc_redirect = null; $wp_ffpc_redirect = null;
/* fires up the backend storage array with current config */ /* fires up the backend storage array with current config */

View file

@ -520,7 +520,7 @@ class WP_FFPC_Backend {
} }
/* verify apcu is working */ /* verify apcu is working */
if ( apcu_cache_info("user",true) ) { if ( apcu_cache_info("user") ) {
$this->log ( __translate__('backend OK', $this->plugin_constant ) ); $this->log ( __translate__('backend OK', $this->plugin_constant ) );
$this->alive = true; $this->alive = true;
} }
@ -606,6 +606,14 @@ class WP_FFPC_Backend {
return false; 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 */ /* verify apc is working */
$info = xcache_info(); $info = xcache_info();
if ( !empty( $info )) { if ( !empty( $info )) {
@ -716,7 +724,7 @@ class WP_FFPC_Backend {
$this->connection->setOption( Memcached::OPT_COMPRESSION , false ); $this->connection->setOption( Memcached::OPT_COMPRESSION , false );
$this->connection->setOption( Memcached::OPT_BINARY_PROTOCOL , true ); $this->connection->setOption( Memcached::OPT_BINARY_PROTOCOL , true );
if ( version_compare( phpversion( 'memcached' ) , '2.0.0', '>=' ) && ini_get( 'memcached.use_sasl' ) == 1 ) { if ( version_compare( phpversion( 'memcached' ) , '2.0.0', '>=' ) && ini_get( 'memcached.use_sasl' ) == 1 && isset($this->options['authpass']) && !empty($this->options['authpass']) && isset($this->options['authuser']) && !empty($this->options['authuser']) ) {
$this->connection->setSaslAuthData ( $this->options['authuser'], $this->options['authpass']); $this->connection->setSaslAuthData ( $this->options['authuser'], $this->options['authpass']);
} }
} }

View file

@ -3,9 +3,9 @@
if ( ! class_exists( 'WP_FFPC' ) ) : if ( ! class_exists( 'WP_FFPC' ) ) :
/* get the plugin abstract class*/ /* get the plugin abstract class*/
include_once ( 'wp-common/plugin_abstract.php' ); include_once ( dirname(__FILE__) . '/wp-common/plugin_abstract.php' );
/* get the common functions class*/ /* get the common functions class*/
include_once ( 'wp-ffpc-backend.php' ); include_once ( dirname(__FILE__) .'/wp-ffpc-backend.php' );
/** /**
* main wp-ffpc class * main wp-ffpc class
@ -63,6 +63,20 @@ class WP_FFPC extends PluginAbstract {
private $scheduled = false; private $scheduled = false;
private $errors = array(); private $errors = array();
/**
*
*/
public function plugin_post_construct () {
$this->plugin_url = plugin_dir_url( __FILE__ );
$this->plugin_dir = plugin_dir_path( __FILE__ );
$this->common_url = $this->plugin_url . self::common_slug;
$this->common_dir = $this->plugin_dir . self::common_slug;
$this->admin_css_handle = $this->plugin_constant . '-admin-css';
$this->admin_css_url = $this->common_url . 'wp-admin.css';
}
/** /**
* init hook function runs before admin panel hook, themeing and options read * init hook function runs before admin panel hook, themeing and options read
*/ */
@ -272,12 +286,11 @@ class WP_FFPC extends PluginAbstract {
*/ */
public function plugin_extend_admin_init () { public function plugin_extend_admin_init () {
/* save parameter updates, if there are any */ /* save parameter updates, if there are any */
if ( isset( $_POST[ $this->button_flush ] ) ) { if ( isset( $_POST[ $this->button_flush ] ) && check_admin_referer ( $this->plugin_constant ) ) {
/* remove precache log entry */ /* remove precache log entry */
$this->_delete_option( self::precache_log ); $this->utils->_delete_option( self::precache_log );
/* remove precache timestamp entry */ /* remove precache timestamp entry */
$this->_delete_option( self::precache_timestamp ); $this->utils->_delete_option( self::precache_timestamp );
/* remove precache logfile */ /* remove precache logfile */
if ( @file_exists ( $this->precache_logfile ) ) { if ( @file_exists ( $this->precache_logfile ) ) {
@ -296,8 +309,7 @@ class WP_FFPC extends PluginAbstract {
} }
/* save parameter updates, if there are any */ /* save parameter updates, if there are any */
if ( isset( $_POST[ $this->button_precache ] ) ) { if ( isset( $_POST[ $this->button_precache ] ) && check_admin_referer ( $this->plugin_constant ) ) {
/* is no shell function is possible, fail */ /* is no shell function is possible, fail */
if ( $this->shell_function == false ) { if ( $this->shell_function == false ) {
$this->status = 5; $this->status = 5;
@ -407,15 +419,17 @@ class WP_FFPC extends PluginAbstract {
/* we need to go through all servers */ /* we need to go through all servers */
$servers = $this->backend->status(); $servers = $this->backend->status();
foreach ( $servers as $server_string => $status ) { if ( is_array( $servers ) && !empty ( $servers ) ) {
echo $server_string ." => "; foreach ( $servers as $server_string => $status ) {
echo $server_string ." => ";
if ( $status == 0 ) if ( $status == 0 )
_e ( '<span class="error-msg">down</span><br />', $this->plugin_constant ); _e ( '<span class="error-msg">down</span><br />', $this->plugin_constant );
elseif ( ( $this->options['cache_type'] == 'memcache' && $status > 0 ) || $status == 1 ) elseif ( ( $this->options['cache_type'] == 'memcache' && $status > 0 ) || $status == 1 )
_e ( '<span class="ok-msg">up & running</span><br />', $this->plugin_constant ); _e ( '<span class="ok-msg">up & running</span><br />', $this->plugin_constant );
else else
_e ( '<span class="error-msg">unknown, please try re-saving settings!</span><br />', $this->plugin_constant ); _e ( '<span class="error-msg">unknown, please try re-saving settings!</span><br />', $this->plugin_constant );
}
} }
?></p><?php ?></p><?php
@ -423,6 +437,7 @@ class WP_FFPC extends PluginAbstract {
</div> </div>
<form autocomplete="off" method="post" action="#" id="<?php echo $this->plugin_constant ?>-settings" class="plugin-admin"> <form autocomplete="off" method="post" action="#" id="<?php echo $this->plugin_constant ?>-settings" class="plugin-admin">
<?php wp_nonce_field( $this->plugin_constant ); ?>
<ul class="tabs"> <ul class="tabs">
<li><a href="#<?php echo $this->plugin_constant ?>-type" class="wp-switch-editor"><?php _e( 'Cache type', $this->plugin_constant ); ?></a></li> <li><a href="#<?php echo $this->plugin_constant ?>-type" class="wp-switch-editor"><?php _e( 'Cache type', $this->plugin_constant ); ?></a></li>
<li><a href="#<?php echo $this->plugin_constant ?>-debug" class="wp-switch-editor"><?php _e( 'Debug & in-depth', $this->plugin_constant ); ?></a></li> <li><a href="#<?php echo $this->plugin_constant ?>-debug" class="wp-switch-editor"><?php _e( 'Debug & in-depth', $this->plugin_constant ); ?></a></li>
@ -600,6 +615,26 @@ class WP_FFPC extends PluginAbstract {
<input type="text" name="nocache_cookies" id="nocache_cookies" value="<?php if(isset( $this->options['nocache_cookies'] ) ) echo $this->options['nocache_cookies']; ?>" /> <input type="text" name="nocache_cookies" id="nocache_cookies" value="<?php if(isset( $this->options['nocache_cookies'] ) ) echo $this->options['nocache_cookies']; ?>" />
<span class="description"><?php _e('Exclude cookies names starting with this from caching. Separate multiple cookies names with commas.<br />If you are caching with nginx, you should update your nginx configuration and reload nginx after changing this value.', $this->plugin_constant); ?></span> <span class="description"><?php _e('Exclude cookies names starting with this from caching. Separate multiple cookies names with commas.<br />If you are caching with nginx, you should update your nginx configuration and reload nginx after changing this value.', $this->plugin_constant); ?></span>
</dd> </dd>
<dt>
<label for="nocache_dyn"><?php _e("Don't cache dynamic requests", $this->plugin_constant); ?></label>
</dt>
<dd>
<input type="checkbox" name="nocache_dyn" id="nocache_dyn" value="1" <?php checked($this->options['nocache_dyn'],true); ?> />
<span class="description"><?php _e('Exclude every URL with "?" in it.', $this->plugin_constant); ?></span>
</dd>
<dt>
<label for="nocache_url"><?php _e("Don't cache following URL paths - use with caution!", $this->plugin_constant); ?></label>
</dt>
<dd>
<textarea name="nocache_url" id="nocache_url" rows="3" cols="100" class="large-text code"><?php
if( isset( $this->options['nocache_url'] ) ) {
echo $this->options['nocache_url'];
}
?></textarea>
<span class="description"><?php _e('Regular expressions use you must! e.g. <em>pattern1|pattern2|etc</em>', $this->plugin_constant); ?></span>
</dd>
</dl> </dl>
</fieldset> </fieldset>
@ -717,6 +752,8 @@ class WP_FFPC extends PluginAbstract {
<form method="post" action="#" id="<?php echo $this->plugin_constant ?>-commands" class="plugin-admin" style="padding-top:2em;"> <form method="post" action="#" id="<?php echo $this->plugin_constant ?>-commands" class="plugin-admin" style="padding-top:2em;">
<?php wp_nonce_field( $this->plugin_constant ); ?>
<ul class="tabs"> <ul class="tabs">
<li><a href="#<?php echo $this->plugin_constant ?>-precache" class="wp-switch-editor"><?php _e( 'Precache', $this->plugin_constant ); ?></a></li> <li><a href="#<?php echo $this->plugin_constant ?>-precache" class="wp-switch-editor"><?php _e( 'Precache', $this->plugin_constant ); ?></a></li>
<li><a href="#<?php echo $this->plugin_constant ?>-flush" class="wp-switch-editor"><?php _e( 'Empty cache', $this->plugin_constant ); ?></a></li> <li><a href="#<?php echo $this->plugin_constant ?>-flush" class="wp-switch-editor"><?php _e( 'Empty cache', $this->plugin_constant ); ?></a></li>
@ -824,9 +861,8 @@ class WP_FFPC extends PluginAbstract {
* *
*/ */
public function plugin_options_migrate( &$options ) { public function plugin_options_migrate( &$options ) {
$migrated = false;
if ( version_compare ( $options['version'] , $this->plugin_version , '<' ) ) { if ( version_compare ( $options['version'] , $this->plugin_version, '<' ) ) {
/* cleanup possible leftover files from previous versions */ /* cleanup possible leftover files from previous versions */
$check = array ( 'advanced-cache.php', 'nginx-sample.conf', 'wp-ffpc.admin.css', 'wp-ffpc-common.php' ); $check = array ( 'advanced-cache.php', 'nginx-sample.conf', 'wp-ffpc.admin.css', 'wp-ffpc-common.php' );
foreach ( $check as $fname ) { foreach ( $check as $fname ) {
@ -844,37 +880,26 @@ class WP_FFPC extends PluginAbstract {
if ( empty ( $options ) && array_key_exists ( $this->global_config_key, $try ) ) { if ( empty ( $options ) && array_key_exists ( $this->global_config_key, $try ) ) {
$options = $try [ $this->global_config_key ]; $options = $try [ $this->global_config_key ];
$migrated = true;
} }
elseif ( empty ( $options ) && array_key_exists ( 'host', $try ) ) { elseif ( empty ( $options ) && array_key_exists ( 'host', $try ) ) {
$options = $try; $options = $try;
$migrated = true;
} }
} }
/* updating from version <= 0.4.x */ /* updating from version <= 0.4.x */
if ( !empty ( $options['host'] ) ) { if ( !empty ( $options['host'] ) ) {
$options['hosts'] = $options['host'] . ':' . $options['port']; $options['hosts'] = $options['host'] . ':' . $options['port'];
$migrated = true;
} }
/* migrating from version 0.6.x */ /* migrating from version 0.6.x */
elseif ( is_array ( $options ) && array_key_exists ( $this->global_config_key , $options ) ) { elseif ( is_array ( $options ) && array_key_exists ( $this->global_config_key , $options ) ) {
$options = $options[ $this->global_config_key ]; $options = $options[ $this->global_config_key ];
$migrated = true;
}
/* migrating from something, drop previous config */
else {
$options = array();
} }
if ( $migrated ) { /* renamed options */
/* renamed options */ if ( isset ( $options['syslog'] ) )
if ( isset ( $options['syslog'] ) ) $options['log'] = $options['syslog'];
$options['log'] = $options['syslog']; if ( isset ( $options['debug'] ) )
if ( isset ( $options['debug'] ) )
$options['response_header'] = $options['debug']; $options['response_header'] = $options['debug'];
}
} }
} }
@ -1146,7 +1171,7 @@ class WP_FFPC extends PluginAbstract {
} }
/* in case the bloglinks are relative links add the base url, site specific */ /* in case the bloglinks are relative links add the base url, site specific */
$baseurl = empty( $url ) ? $this->_site_url() : $url; $baseurl = empty( $url ) ? $this->utils->_site_url() : $url;
if ( !strstr( $permalink, $baseurl ) ) { if ( !strstr( $permalink, $baseurl ) ) {
$permalink = $baseurl . $permalink; $permalink = $baseurl . $permalink;
} }

View file

@ -1,9 +1,9 @@
<?php <?php
/* /*
Plugin Name: WP-FFPC Plugin Name: WP-FFPC
Plugin URI: http://petermolnar.eu/wordpress/wp-ffpc Plugin URI: https://github.com/petermolnar/wp-ffpc
Description: WordPress cache plugin for memcached & nginx - unbeatable speed Description: WordPress in-memory full page cache plugin
Version: 1.5.0 Version: 1.6.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
@ -45,6 +45,8 @@ $wp_ffpc_defaults = array (
'nocache_single' => false, 'nocache_single' => false,
'nocache_page' => false, 'nocache_page' => false,
'nocache_cookies' => false, 'nocache_cookies' => false,
'nocache_dyn' => true,
'nocache_url' => '',
'persistent' => false, 'persistent' => false,
'response_header' => false, 'response_header' => false,
'generate_time' => false, 'generate_time' => false,