NAME

POE::Component::CPAN::Mirror::Multiplexer - Multiplex HTTP CPAN mirrors

SYNOPSIS

use strict;
use warnings;
use Getopt::Long;
use POE qw(Component::CPAN::Mirror::Multiplexer);

my $port = 8080;
GetOptions('port=i',\$port) or die;

my $test_httpd = POE::Component::CPAN::Mirror::Multiplexer->new( port => $port );

$poe_kernel->run();
exit 0;

DESCRIPTION

POE::Component::CPAN::Mirror::Multiplexer is a POE component that acts as a HTTP server that multiplexes HTTP CPAN mirrors. CPAN clients such as CPAN or CPANPLUS can be configured to use the multiplexer as their CPAN mirror. The multiplexer will then query a list of HTTP CPAN mirrors for the requested URLs.

CONSTRUCTOR

spawn

Takes a number of options, only those marked as mandatory are required:

'address', bind to a particular IP address, default is INADDR_ANY;
'port', bind to a particular TCP port, default is 0;
'event', an event in your session to send request meta to;
'session', specify an alternative session to send the above event to;
'postback', specify a POE::Session postback instead of the above;
'mirrors', an arrayref of http urls, the default should be fine;
'error_page', a scalar of HTML to be returned instead of the default on error conditions;

METHODS

get_session_id

Returns the POE::Session ID of the component.

port

Returns the assigned TCP port.

INPUT EVENTS

shutdown

Terminates the component.

OUTPUT EVENTS

If event or postback is specified in spawn then the following events will be emitted whenever a client makes a request.

event

ARG0 will be a HTTP::Request object. ARG1 will be a HASHREF with the following keys:

'peeraddr', the client address;
'peerport', the client TCP port;
'sockaddr', our address;
'sockport', our TCP port;
postback

ARG0 will be an ARRAYREF with the parameters that were specified when the postback was created, see POE::Session for details. ARG1 will be an ARRAYREF with two items, a HTTP::Request object and a HASHREF with the following keys:

'peeraddr', the client address;
'peerport', the client TCP port;
'sockaddr', our address;
'sockport', our TCP port;

AUTHOR

Chris BinGOs Williams <chris@bingosnet.co.uk>

LICENSE

Copyright © Chris Williams

This module may be used, modified, and distributed under the same terms as Perl itself. Please see the license that came with your Perl distribution for details.

SEE ALSO

HTTP::Request

POE::Session

http://mirrors.cpan.org/