LWP::UserAgent::Cache::Memcached - LWP::UserAgent extension with memcached


LWP-UserAgent-Cache-Memcached documentation Contained in the LWP-UserAgent-Cache-Memcached distribution.

Index


Code Index:

NAME

Top

LWP::UserAgent::Cache::Memcached - LWP::UserAgent extension with memcached

SYNOPSIS

Top

  use LWP::UserAgent::Cache::Memcached;
  my %cache_opt = (
    'namespace' => 'lwp-cache:',
    'servers' => [ "10.0.0.15:11211", "10.0.0.15:11212", "/var/sock/memcached",
                   "10.0.0.17:11211", [ "10.0.0.17:11211", 3 ] ],
    'compress_threshold' => 10_000,
    'exptime' => 600,
  );

  my $ua = LWP::UserAgent::Cache::Memcached->new(\%cache_opt);
  my $response = $ua->get('http://search.cpan.org/');

DESCRIPTION

Top

LWP::UserAgent::Cache::Memcached is a LWP::UserAgent extention. It handle 'If-Modified-Since' request header with memcached. memcached are implemented by Cache::Memcached or Cache::Memcached::Fast. When you use this module, this module tries to use Cache::Memcached::Fast. If this call is fail, it uses Cache::Memcached.

SEE ALSO

Top

LWP::UserAgent, Cache::Memcached, Cache::Memcached::Fast

AUTHOR

Top

This module is derived from LWP::UserAgent::WithCache code, and has been lightly modified since.

Kazuma Shiraiwa

COPYRIGHT AND LICENSE

Top


LWP-UserAgent-Cache-Memcached documentation Contained in the LWP-UserAgent-Cache-Memcached distribution.

package LWP::UserAgent::Cache::Memcached;

use strict;
use warnings;
use base qw(LWP::UserAgent);
use Module::Load;

our $VERSION = '0.02';

our $FAST = 1;
our %default_cache_args = (
	'servers' => [ "127.0.0.1:11211" ],
	'namespace' => 'lwp-cache',
	'exptime' => 0,
);

sub new {
	my $class = shift;
	my $cache_opt = shift || {};
	my $self = $class->SUPER::new(@_);
	my %cache_args = (%default_cache_args, %$cache_opt);
	$self->{lwp_useragent_cache_memcached_config} = {
		exptime => $cache_args{exptime},
	};
	delete $cache_args{exptime};
	$self->{cache} = $self->cacher->new(\%cache_args);
	return $self
}

sub cacher {
	my @cacher = qw/Cache::Memcached::Fast Cache::Memcached/;
	my $cacher;

	if ($FAST) {
		$cacher = $cacher[0];
		eval {load $cacher};
		if ($@) {
			$cacher = $cacher[1];
			eval {load $cacher};
			$FAST = 0;
		}
	}
	else {
		$cacher = $cacher[1];
		eval {load $cacher};
	}

	return $cacher;
}

sub request {
	my $self = shift;
	my @args = @_;
	my $request = $args[0];

	return $self->SUPER::request(@args) if $request->method ne 'GET';

	my $uri = $request->uri->as_string;
	my $cache = $self->{cache};
	my $obj = $cache->get( $uri );

	if ( defined $obj ) {

		unless (defined $obj->{expires} and $obj->{expires} <= time()) {
			return HTTP::Response->parse($obj->{as_string});
		}

		if (defined $obj->{last_modified}) {
			$request->header(
				'If-Modified-Since' => HTTP::Date::time2str($obj->{last_modified})
			);
		}

		if (defined $obj->{etag}) {
			$request->header('If-None-Match' => $obj->{etag});
		}

		$args[0] = $request;
	}

	my $res = $self->SUPER::request(@args);
	my $exptime = int($self->{lwp_useragent_cache_memcached_config}->{exptime} || 0);
	$self->set_cache($uri, $res, $exptime) if $res->code eq HTTP::Status::RC_OK;

	return $res;
}

sub set_cache {
	my $self = shift;
	my ($uri, $res, $exptime) = @_;
	my $cache = $self->{cache};

	$cache->set($uri,{
		content       => $res->content,
		last_modified => $res->last_modified,
		etag          => $res->header('Etag') ? $res->header('Etag') : undef,
		expires       => $res->expires ? $res->expires : undef,
		as_string     => $res->as_string,
	},$exptime); 
}

1;
__END__