HTTP::Request::AsCGI - Set up a CGI environment from an HTTP::Request


HTTP-Request-AsCGI documentation  | view source Contained in the HTTP-Request-AsCGI distribution.

Index


NAME

Top

HTTP::Request::AsCGI - Set up a CGI environment from an HTTP::Request

VERSION

Top

version 1.2

SYNOPSIS

Top

    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;

        # environment and descriptors will automatically be restored
        # when $c is destructed.
    }

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

DESCRIPTION

Top

Provides a convenient way of setting up an CGI environment from an HTTP::Request.

METHODS

Top

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

Constructor. The first argument must be a instance of HTTP::Request, followed by optional pairs of environment key and value.

environment

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

Sets up the environment and descriptors.

restore

Restores the environment 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.

SEE ALSO

Top

examples directory in this distribution.
WWW::Mechanize::CGI
Test::WWW::Mechanize::CGI

THANKS TO

Top

Thomas L. Shinnick for his valuable win32 testing.

AUTHORS

Top

Christian Hansen <ch@ngmedia.com> Hans Dieter Pearcey <hdp@cpan.org>

COPYRIGHT AND LICENSE

Top


HTTP-Request-AsCGI documentation  | view source Contained in the HTTP-Request-AsCGI distribution.