Merge branch 'cookies' of https://github.com/haroldkyle/wp-ffpc into dev

This commit is contained in:
Peter Molnar 2013-04-28 10:36:36 +01:00
commit baa5fbc9c3
4 changed files with 59 additions and 8 deletions

View file

@ -53,17 +53,34 @@ else
return false; return false;
/* no cache for for logged in users normally, only if enabled */ /* no cache for for logged in users normally, only if enabled */
if ( $wp_ffpc_config['cache_loggedin'] == 0 ) { if ( $wp_ffpc_config['cache_loggedin'] == 0 || $wp_ffpc_config['nocache_cookies'] ) {
$nocache_cookies = array();
if( $wp_ffpc_config['nocache_cookies'] ){
$nocache_cookies = array_map('trim',explode(",", $wp_ffpc_config['nocache_cookies'] ) );
}
foreach ($_COOKIE as $n=>$v) { foreach ($_COOKIE as $n=>$v) {
// test cookie makes to cache not work!!! // test cookie makes to cache not work!!!
if ($n == 'wordpress_test_cookie') continue; if ($n == 'wordpress_test_cookie') continue;
// wp 2.5 and wp 2.3 have different cookie prefix, skip cache if a post password cookie is present, also // wp 2.5 and wp 2.3 have different cookie prefix, skip cache if a post password cookie is present, also
if ( (substr($n, 0, 14) == 'wordpressuser_' || substr($n, 0, 10) == 'wordpress_' || substr($n, 0, 12) == 'wp-postpass_') && !$wp_ffpc_config['cache_loggedin'] ) { if ( $wp_ffpc_config['cache_loggedin'] == 0 ) {
return false; if ( (substr($n, 0, 14) == 'wordpressuser_' || substr($n, 0, 10) == 'wordpress_' || substr($n, 0, 12) == 'wp-postpass_') && !$wp_ffpc_config['cache_loggedin'] ) {
return false;
}
}
/* check for any matches to user-added cookies to no-cache */
if ( ! empty( $nocache_cookies ) ){
foreach ( $nocache_cookies as $nocache_cookie ) {
if( strpos( $n, $nocache_cookie ) === 0 ) {
return false;
}
}
} }
} }
} }
/* canonical redirect storage */ /* canonical redirect storage */
$wp_ffpc_redirect = null; $wp_ffpc_redirect = null;
@ -146,7 +163,7 @@ if ( !empty( $wp_ffpc_values['meta']['pingback'] ) )
/* for debugging */ /* for debugging */
if ( $wp_ffpc_config['response_header'] ) if ( $wp_ffpc_config['response_header'] )
header( 'X-Cache-Engine: WP-FFPC with ' . $wp_ffpc_config['cache_type'] ); header( 'X-Cache-Engine: WP-FFPC with ' . $wp_ffpc_config['cache_type'] .' via PHP');
/* HTML data */ /* HTML data */
echo $wp_ffpc_values['data']; echo $wp_ffpc_values['data'];

View file

@ -391,7 +391,7 @@ if ( ! class_exists( 'WP_FFPC' ) ) {
</dt> </dt>
<dd> <dd>
<input type="text" name="prefix_data" id="prefix_data" value="<?php echo $this->options['prefix_data']; ?>" /> <input type="text" name="prefix_data" id="prefix_data" value="<?php echo $this->options['prefix_data']; ?>" />
<span class="description"><?php _e('Prefix for HTML content keys, can be used in nginx. If you are caching with nginx, you should update your nginx configuration and restart nginx after changing this value.', $this->plugin_constant); ?></span> <span class="description"><?php _e('Prefix for HTML content keys, can be used in nginx.<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> <dt>
@ -420,7 +420,7 @@ if ( ! class_exists( 'WP_FFPC' ) ) {
</dt> </dt>
<dd> <dd>
<input type="checkbox" name="log_info" id="log_info" value="1" <?php checked($this->options['log_info'],true); ?> /> <input type="checkbox" name="log_info" id="log_info" value="1" <?php checked($this->options['log_info'],true); ?> />
<span class="description"><?php _e('Enables INFO level messages; carefull, plugin is really talkative. Requires PHP syslog function.', $this->plugin_constant); ?></span> <span class="description"><?php _e('Enables INFO level messages; careful, plugin is really talkative. Requires PHP syslog function.', $this->plugin_constant); ?></span>
</dd> </dd>
<dt> <dt>
@ -440,7 +440,7 @@ if ( ! class_exists( 'WP_FFPC' ) ) {
</dd> </dd>
<dt> <dt>
<label for="sync_protocols"><?php _e("Enable sync protocolls", $this->plugin_constant); ?></label> <label for="sync_protocols"><?php _e("Enable sync protocols", $this->plugin_constant); ?></label>
</dt> </dt>
<dd> <dd>
<input type="checkbox" name="sync_protocols" id="sync_protocols" value="1" <?php checked($this->options['sync_protocols'],true); ?> /> <input type="checkbox" name="sync_protocols" id="sync_protocols" value="1" <?php checked($this->options['sync_protocols'],true); ?> />
@ -501,6 +501,14 @@ if ( ! class_exists( 'WP_FFPC' ) ) {
<input type="checkbox" name="nocache_page" id="nocache_page" value="1" <?php checked($this->options['nocache_page'],true); ?> /> <input type="checkbox" name="nocache_page" id="nocache_page" value="1" <?php checked($this->options['nocache_page'],true); ?> />
<span class="description"><?php _e('Exclude pages from caching.', $this->plugin_constant); ?></span> <span class="description"><?php _e('Exclude pages from caching.', $this->plugin_constant); ?></span>
</dd> </dd>
<dt>
<label for="nocache_cookies"><?php _e("Don't cache cookies", $this->plugin_constant); ?></label>
</dt>
<dd>
<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>
</dd>
</dl> </dl>
</fieldset> </fieldset>
@ -519,7 +527,7 @@ if ( ! class_exists( 'WP_FFPC' ) ) {
</dt> </dt>
<dd> <dd>
<input type="checkbox" name="persistent" id="persistent" value="1" <?php checked($this->options['persistent'],true); ?> /> <input type="checkbox" name="persistent" id="persistent" value="1" <?php checked($this->options['persistent'],true); ?> />
<span class="description"><?php _e('Make all memcache(d) connections persistent. Be carefull with this setting, always test the outcome.', $this->plugin_constant); ?></span> <span class="description"><?php _e('Make all memcache(d) connections persistent. Be careful with this setting, always test the outcome.', $this->plugin_constant); ?></span>
</dd> </dd>
</dl> </dl>
</fieldset> </fieldset>
@ -784,6 +792,27 @@ if ( ! class_exists( 'WP_FFPC' ) ) {
else else
$nginx = str_replace ( 'LOGGEDIN_EXCEPTION' , '' , $nginx ); $nginx = str_replace ( 'LOGGEDIN_EXCEPTION' , '' , $nginx );
/* nginx can skip caching for visitors with certain cookies specified in the options */
if( $this->options['nocache_cookies'] ) {
$cookies = str_replace( ",","|", $this->options['nocache_cookies'] );
$cookies = str_replace( " ","", $cookies );
$cookie_exception = '# avoid cache for cookies specified
if ($http_cookie ~* ' . $cookies . ' ) {
set $memcached_request 0;
}';
$nginx = str_replace ( 'COOKIES_EXCEPTION' , $cookie_exception , $nginx );
} else {
$nginx = str_replace ( 'COOKIES_EXCEPTION' , '' , $nginx );
}
/* add custom response header if specified in the options */
if( $this->options['response_header'] ){
$response_header = 'add_header X-Cache-Engine "WP-FFPC with ' . $this->options['cache_type'] .' via nginx";';
$nginx = str_replace ( 'RESPONSE_HEADER' , $response_header , $nginx );
} else{
$nginx = str_replace ( 'RESPONSE_HEADER' , '' , $nginx );
}
return $nginx; return $nginx;
} }

View file

@ -129,7 +129,10 @@ MEMCACHED_SERVERS
LOGGEDIN_EXCEPTION LOGGEDIN_EXCEPTION
COOKIES_EXCEPTION
if ( $memcached_request = 1) { if ( $memcached_request = 1) {
RESPONSE_HEADER
memcached_pass memcached-servers; memcached_pass memcached-servers;
error_page 404 = @rewrites; error_page 404 = @rewrites;
} }
@ -141,6 +144,7 @@ MEMCACHED_SERVERS
## rewrite rules ## rewrite rules
location @rewrites { location @rewrites {
add_header X-Cache-Engine "";
rewrite ^ /index.php?$args last; rewrite ^ /index.php?$args last;
} }

View file

@ -43,6 +43,7 @@ $wp_ffpc_defaults = array (
'nocache_archive' => false, 'nocache_archive' => false,
'nocache_single' => false, 'nocache_single' => false,
'nocache_page' => false, 'nocache_page' => false,
'nocache_cookies' => false,
'sync_protocols' => false, 'sync_protocols' => false,
'persistent' => false, 'persistent' => false,
'response_header' => false, 'response_header' => false,