Apache-AxKit-Plugin-QueryStringCacheRegexp

 view release on metacpan or  search on metacpan

lib/Apache/AxKit/Plugin/QueryStringCacheRegexp.pm  view on Meta::CPAN

# $Id: QueryStringCacheRegexp.pm,v 1.12 2006/08/07 14:12:06 c10232 Exp $
package Apache::AxKit::Plugin::QueryStringCacheRegexp;

use strict;
use Apache::Constants qw(OK);
use Apache::Request;

our $VERSION = '0.04';

sub handler {
    my $r = shift;
    my $cache_extra;

    # An extra bend to correctly make multiple-valued CGI-Parameters
    # significant by concatenating them. (The whole exercise is to
    # create a "axkit_cache_extra"-string that depends as little as
    # possible on how the QueryString "looks"; i.e. the order of the
    # parameters should not be significant unless there are multiple
    # occurences of the same key)
    my @args = $r->args();
    my %args;
    while (@args) {$args{ shift(@args) } .= shift(@args);}
    
    my $use = $r->dir_config('AxQueryStringCacheRegexpUse') || '^\w+$';             #'
    my $ignore = $r->dir_config('AxQueryStringCacheRegexpIgnore') || undef;

    foreach (sort keys %args) {
        if ( length $_ && /$use/ && ( (not defined $ignore) || (not /$ignore/) ) ) {
            $cache_extra .= $_ . "=" . $args{$_} . ";";
        }
    }

    AxKit::Debug(7, "[QueryStringCacheRegexp] QueryString in: " . $r->args . " significant for caching: $cache_extra");

    $r->notes('axkit_cache_extra', $r->notes('axkit_cache_extra') . $cache_extra);

    return OK;
}

1;
__END__

=head1 NAME

Apache::AxKit::Plugin::QueryStringCacheRegexp - Cache based on QS and
regular expression matching

=head1 SYNOPSIS

  SetHandler axkit
  AxAddPlugin Apache::AxKit::Plugin::QueryStringCacheRegexp
  PerlSetVar AxQueryStringCacheRegexpUse    '\w{2,15}'
  PerlSetVar AxQueryStringCacheRegexpIgnore 'foo.*'

=head1 DESCRIPTION

This module is a replacement for
Apache::AxKit::Plugin::QueryStringCache.  It offers the following at the
expense of a little overhead:

The querystring is "taken apart", the parameters are matched against a
positive (I<use>) and a negative (I<ignore>) pattern, both to be
specified in F<httpd.conf>. A changed order of parameters, old (C<&>)
vs. new-style (C<;>) delimiters or multiple occurances of the same
parameter will not force AxKit to retransform a document.

Parameters taken into account will have to match the I<use>-pattern
I<and not> match the I<ignore>-pattern (if given).

Setting C<AxDebugLevel 7> or greater prints some debug-info to the log.

C<PerlSetVar AxQueryStringCacheRegexpUse    '^\w{2,15}$'>

Takes a perl regular expression; C<^\w+$> is used if omitted.

C<PerlSetVar AxQueryStringCacheRegexpIgnore '^foo.*'>



( run in 1.737 second using v1.01-cache-2.11-cpan-39bf76dae61 )