NAME
USPS::RateRequest - Ultra fast parallelized asyncronous USPS rate lookups.
VERSION
version 1.0003
SYNOPSIS
use USPS::RateRequest;
use Box::Calc;
use Ouch;
my $calc = Box::Calc->new();
$calc->add_box_type(...);
$calc->add_item(...);
$calc->pack_items;
my $rates = eval {
USPS::RateRequest->new(
user_id => 'usps username'
password => 'usps password',
from => 53716,
postal_code => 90210,
country => 'US',
)->request_rates($calc->boxes)->recv;
};
if (hug) {
die "USPS Error: $@";
}
my $priority_postage_for_first_box = $rates->{$calc->get_box(0)->id}{'USPS Priority'}{postage};
# view the complete data structure
use Data::Dumper;
say Dumper($rates);
DESCRIPTION
USPS::RateRequest exists for two reasons:
Business::Shipping is very slow when you have to request rates for varying amounts and sizes of parcels. That's because each request is done in serial. USPS::RateRequest makes all requests in parallel, thus increasing performance dramatically.
Box::Calc does a ton of work figuring out exactly what can be packed into each parcel. USPS::RateRequest takes advantage of all that data being loaded and makes use of it to calculate very precise package dimensions and weights to get the most accurate shipping prices.
If there are errors returned from the USPS, USPS::RateRequest will throw exceptions via Ouch with the code "USPS Error" and the error returned from the USPS. If no rates are returned at all, then it will throw an exception with the code "No Rates".
METHODS
new( params )
Constructor.
- params
-
A hash of initialization parameters. An asterisk denotes required parameters.
- test_mode
-
Boolean. If true requests will be posted to the USPS test server rather than the production server.
- prod_uri
-
The URI to the production instance of the USPS web tools web services. Defaults to
http://production.shippingapis.com/ShippingAPI.dll
. - test_uri
-
The URI to the test instance of the USPS web tools web services. Defaults to
http://testing.shippingapis.com/ShippingAPItest.dll
. - user_id (*)
-
The username provided to you by signing up for USPS web tools here: https://www.usps.com/business/web-tools-apis/welcome.htm
- password (*)
-
The password that goes with
user_id
. - from (*)
-
The zip code from which the parcels will ship.
- postal_code (*)
-
The postal_code code where the parcels will be delivered.
- country (*)
-
The name of the country where the parcels will be delivered. See the USPS web services documentation for a list of valid countries. https://www.usps.com/business/web-tools-apis/price-calculators.htm The proper name for the USA is "United States of America".
- service
-
Defaults to
all
. Optionally limit the response to specific delivery services, such asPRIORITY
. See the USPS web service documentation for details: https://www.usps.com/business/web-tools-apis/price-calculators.htm - debug
-
Add additional items into the returned rate request data for debugging issues with rate lookups and name sanitization. This data is not guaranteed to stay the same from release to release.
request_rates ( boxes )
Returns an AnyEvent condition variable. When you call the recv
method on that variable it will send out all the requests for rates, collate and translate the responses, and return a hash reference that looks like this:
{
'box-id-1' => {
'USPS Priority Small Flat Rate Box' => {
'postage' => '5.80'
},
'USPS Priority Express Hold For Pickup' => {
'postage' => '56.05'
},
'USPS Priority Express Flat Rate Envelope' => {
'postage' => '19.99'
},
'USPS Priority Medium Flat Rate Box' => {
'postage' => '12.35'
},
'USPS Standard Post' => {
'postage' => '13.34'
},
'USPS Media' => {
'postage' => '4.61'
},
[....]
},
'box-id-2' => {
[....]
},
[....]
}
- boxes
-
An array reference of boxes created by
Box::Calc
.
sanitize_service_name ( name )
domestic ( )
Returns a 1 or 0 depending upon whether the country
is 'United States of America'.
CAVEATS
Although Box::Calc doesn't care what units you use for weights and measurements, USPS does. Make sure all your weights are in ounces and all your measurements are in inches.
AUTHOR
LEGAL
Box::Calc is Copyright 2014 Plain Black Corporation (http://www.plainblack.com) and is licensed under the same terms as Perl itself.