NAME
SimpleDB::Class::HTTP - The network interface to the SimpleDB service.
VERSION
version 0.0600
SYNOPSIS
use SimpleDB::Class::HTTP;
my $http = SimpleDB::Class::HTTP->new(secret_key=>'abc', access_key=>'123');
my $hashref = $http->send_request('CreateDomain', {DomainName => 'my_new_domain'});
DESCRIPTION
This class will let you quickly and easily inteface with AWS SimpleDB. It throws exceptions from SimpleDB::Class::Exception, but other than that doesn't rely on any of the other modules in the SimpleDB::Class system, which means it's very light weight. Although we haven't run any benchmarks, it should outperform any of the other Perl modules that exist today.
It's also got built-in AnyEvent support, so you can use it in your Coro, POE, or other event frameworks and it will handle its requests and timers in a non-blocking fashion.
METHODS
The following methods are available from this class.
new ( params )
params
A hash containing the parameters to pass in to this method.
access_key
The access key given to you from Amazon when you sign up for the SimpleDB service at this URL: http://aws.amazon.com/simpledb/
secret_key
The secret access key given to you from Amazon.
access_key ( )
Returns the access key passed to the constructor.
secret_key ( )
Returns the secret key passed to the constructor.
construct_request ( action, [ params ] )
Returns a string that contains the HTTP post data ready to make a request to SimpleDB. Normally this is only called by send_request(), but if you want to debug a SimpleDB interaction, then having access to this method is critical.
action
The action to perform on SimpleDB. See the "Operations" section of the guide located at "/docs.amazonwebservices.com/AmazonSimpleDB/2009-04-15/DeveloperGuide/"" in <a href="http:http://docs.amazonwebservices.com/AmazonSimpleDB/2009-04-15/DeveloperGuide/</a>>.
params
Any extra prameters required by the operation. The normal parameters of Action, AWSAccessKeyId, Version, Timestamp, SignatureMethod, SignatureVersion, and Signature are all automatically provided by this method.
send_request ( action, [ params ] )
Creates a request, and then sends it to SimpleDB. The response is returned as a hash reference of the raw XML document returned by SimpleDB. Automatically attempts 5 cascading retries on connection failure.
Throws SimpleDB::Class::Exception::Response and SimpleDB::Class::Exception::Connection.
action
See create_request() for details.
params
See create_request() for details.
handle_response ( body, headers )
Returns a hashref containing the response from SimpleDB.
Throws SimpleDB::Class::Exception::Response.
body
The XML returned by SimpleDB.
headers
The HTTP headers.
LEGAL
SimpleDB::Class is Copyright 2009 Plain Black Corporation (http://www.plainblack.com/) and is licensed under the same terms as Perl itself.