NAME

OpenInteract2::Request::Standalone - Manually create a request object

SYNOPSIS

# Set the request implementation to use

OpenInteract2::Request->set_implementation_type( 'standalone' );

# Create all the request infomration offline...

my %req_params = (
  url         => '/path/to/my/doc.html',
  referer     => 'http://www.foo.bar/path/to/my/index.html',
  user_agent  => 'OI2 Standalone Requester',
  server_name => 'www.foo.bar',
  remote_host => '192.168.1.1',
  param       => { eyes => 'two',
                   soda => [ 'rc', 'mr. pibb' ] },
  cookie      => [ 'lastSeen=1051797475;firstLogin=1051797075',
                   OpenInteract2::Cookie->new( ... ), ],
  upload      => { sendfile   => OpenInteract2::Upload->new( ... ),
                   screenshot => OpenInteract2::Upload->new( ... ) },
);

# ...and create a new object with it

my $req = OpenInteract2::Request->new( \%req_params );

# ...or just create an empty object with the bare minimum of
# infomration and set properties as needed

my $req = OpenInteract2::Request->new( { url => '/path/to/my/doc.html' } );
$req->referer( 'http://www.foo.bar/path/to/my/index.html' );
$req->param( eyes => 'two' );
$req->param( soda => [ 'rc', 'mr. pibb' ] );
$req->cookie( lastSeen => '1051797475' );

DESCRIPTION

This object is mainly used for testing, but you can also use it as glue to some other operating environment. The only thing this module does is take the properties passed into the new() call (and passed by OpenInteract2::Request via init()) and set them into the object.

METHODS

init( \%properties )

Set all the properties from \%properties in the object. Since almost all the properties are simple key/value pairs this is straightforward. There are a few more complicated ones:

  • url - Required. This is the full URL path (without the protocol, host and port information) and will get parsed into the url_absolute, url_relative and url_initial request properties.

    Default: none

  • param - This must be a hashref of key/value pairs. You can represent multi-valued parameters by setting the value within the hashref to an arrayref. Setting the value of this property to a simple scalar or arrayref, or setting any of the parameter values to a hashref, is grounds for an exception to be thrown.

    Default: none

  • cookie - You can pass in one or more cookie strings (what the browser passes in its Cookie header) and/or one or more CGI::Cookie objects. If the values set aren't simple scalars or cookie objects an exception is thrown.

    Default: none

  • upload - You can pass in one or more OpenInteract2::Upload objects associated with fields in a hashref. Setting the property value to anything other than a hashref, or setting the value associated with an upload field to anything other than an upload object, will cause an exception.

    Default: none

The simple request properties set are:

  • referer - Set to what you'd like to be the referring page.

    Default: none

  • user_agent - Set to the user agent for this request.

    Default: none

  • server_name - Set to the server hostname.

    Default: return value from Sys::Hostname

  • remote_host - Set to the host making the request.

    Default: none

BUGS

None known.

TO DO

Add settable auth_* properties

Add settable theme_* properties?

SEE ALSO

OpenInteract2::Response::Standalone

COPYRIGHT

Copyright (c) 2001-2003 Chris Winters. All rights reserved.

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

AUTHORS

Chris Winters <chris@cwinters.com>