NAME

HTTP::Proxy::HeaderFilter - A base class for HTTP message header filters

SYNOPSIS

package MyFilter;

use base qw( HTTP::Proxy::HeaderFilter );

# changes the User-Agent header in all requests
# this filter must be pushed on the request stack
sub filter {
    my ( $self, $headers, $message ) = @_;

    $message->headers->header( User_Agent => 'MyFilter/1.0' );
}

1;

DESCRIPTION

The HTTP::Proxy::HeaderFilter class is used to create filters for HTTP request/response headers.

Creating a HeaderFilter

A HeaderFilter is just a derived class that implements the filter() method. See the example in SYNOPSIS.

The signature of the filter() method is the following:

sub filter { my ( $self, $headers, $message) = @_; ... }

where $self is the filter object, $headers is a HTTP::Headers object, and $message is either a HTTP::Request or a HTTP::Response object.

The $headers HTTP::Headers object is the one that will be sent to the client (if the filter is on the response stack) or origin server (if the filter is on the request stack). If $headers is modified by the filter, the modified headers will be sent to the client or server.

A HTTP::Proxy::HeaderFilter object is a blessed hash, and the base class reserves only hash keys that start with _hphf.

Standard HeaderFilters

Standard HTTP::Proxy::HeaderFilter classes are lowercase.

The following HeaderFilters are included in the HTTP::Proxy distribution:

simple

This class lets you create a simple header filter from a code reference.

standard

This is the filter that provides standard headers handling for HTTP::Proxy. It is loaded automatically by HTTP::Proxy.

Please read each filter's documentation for more details about their use.

AVAILABLE METHODS

Some methods are available to filters, so that they can eventually use the little knowledge they might have of HTTP::Proxy's internals. They mostly are accessors.

proxy()

Gets a reference to the HTTP::Proxy objects that owns the filter. This gives access to some of the proxy methods.

AUTHOR

Philippe "BooK" Bruhat, <book@cpan.org>.

SEE ALSO

HTTP::Proxy, HTTP::Proxy::BodyFilter.

COPYRIGHT

This module is free software; you can redistribute it or modify it under the same terms as Perl itself.