NAME

HTTP::Request::AsCGI - Setup a CGI enviroment from a HTTP::Request

SYNOPSIS

use CGI;
use HTTP::Request;
use HTTP::Request::AsCGI;

my $request = HTTP::Request->new( GET => 'http://www.host.com/' );
my $stdout;

{
    my $c = HTTP::Request::AsCGI->new($request)->setup;
    my $q = CGI->new;
    
    print $q->header,
          $q->start_html('Hello World'),
          $q->h1('Hello World'),
          $q->end_html;
    
    $stdout = $c->stdout;
    
    # enviroment and descriptors will automatically be restored 
    # when $c is destructed.
}

while ( my $line = $stdout->getline ) {
    print $line;
}

DESCRIPTION

Provides a convinient way of setting up an CGI enviroment from a HTTP::Request.

METHODS

new ( $request [, key => value ] )

Contructor, first argument must be a instance of HTTP::Request followed by optional pairs of environment keys and values.

enviroment

Returns a hashref containing the environment that will be used in setup. Changing the hashref after setup has been called will have no effect.

setup

Setups the environment and descriptors.

restore

Restores the enviroment and descriptors. Can only be called after setup.

request

Returns the request given to constructor.

response

Returns a HTTP::Response. Can only be called after restore.

stdin

Accessor for handle that will be used for STDIN, must be a real seekable handle with an file descriptor. Defaults to a tempoary IO::File instance.

stdout

Accessor for handle that will be used for STDOUT, must be a real seekable handle with an file descriptor. Defaults to a tempoary IO::File instance.

stderr

Accessor for handle that will be used for STDERR, must be a real seekable handle with an file descriptor.

THANKS TO

Thomas L. Shinnick for his valuable win32 testing.

AUTHOR

Christian Hansen, ch@ngmedia.com

LICENSE

This library is free software. You can redistribute it and/or modify it under the same terms as perl itself.