use v5.10; use utf8; package Business::US::USPS::WebTools::ZipCodeLookup; use strict; no warnings 'uninitialized'; use parent qw(Business::US::USPS::WebTools); use subs qw(); use vars qw($VERSION); $VERSION = '1.125'; =encoding utf8 =head1 NAME Business::US::USPS::WebTools::ZipCodeLookup - lookup a Zip Code using the USPS Web Tools =head1 SYNOPSIS use Business::US::USPS::WebTools::ZipCodeLookup; my $looker_upper = Business::US::USPS::WebTools::ZipCodeLookup->new( { UserID => $ENV{USPS_WEBTOOLS_USERID}, Password => $ENV{USPS_WEBTOOLS_PASSWORD}, Testing => 1, } ); my $hash = $looker_upper->lookup_zipcode( ); if( $looker_upper->is_error ) { warn "Oh No! $looker_upper->{error}{description}\n"; } else { print join "\n", map { "$_: $hash->{$_}" } qw(FirmName Address1 Address2 City State Zip5 Zip4); } =head1 DESCRIPTION *** THIS IS ALPHA SOFTWARE *** This module implements the Zip Code Lookup web service from the US Postal Service. It is a subclass of Business::US::USPS::WebTools. =cut =over 4 =cut sub _fields { qw( FirmName Address1 Address2 City State) } sub _required { qw( Address2 City State ) } =item lookup_zipcode( KEY, VALUE, ... ) The C method takes the following keys, which come directly from the USPS web service interface: Address2 The street address City The name of the city State The two letter state abbreviation Zip5 The 5 digit zip code Zip4 The 4 digit extension to the zip code It returns an anonymous hash with the same keys, but the values are the USPS's canonicalized address. If there is an error, the hash values will be the empty string, and the error flag is set. Check is with C: $verifier->is_error; See the C documentation in Business::US::USPS::WebTools for more details on error information. =cut sub lookup_zipcode { my( $self, %hash ) = @_; $self->_make_url( \%hash ); $self->_make_request; $self->_parse_response; } sub _api_name { "ZipCodeLookup" } sub _make_query_xml { my( $self, $hash ) = @_; my $user = $self->userid; my $pass = $self->password; my $xml = qq|| . qq|
|; foreach my $field ( $self->_fields ) { $xml .= "<$field>$$hash{$field}"; } $xml .= qq|
|; return $xml; } sub _parse_response { my( $self ) = @_; #require 'Hash::AsObject'; my %hash = (); foreach my $field ( $self->_fields, qw( Zip5 Zip4 ) ) { my( $value ) = $self->response =~ m|<$field>(.*?)|g; $hash{$field} = $value || ''; } bless \%hash, ref $self; # 'Hash::AsObject'; } =back =head1 TO DO =head1 SEE ALSO L The WebTools API is documented on the US Postal Service's website: http://www.usps.com/webtools/htm/Address-Information.htm =head1 SOURCE AVAILABILITY This source is in GitHub: https://github.com/ssimms/business-us-usps-webtools =head1 AUTHOR brian d foy =head1 COPYRIGHT AND LICENSE Copyright © 2020, Steve Simms. All rights reserved. This program is free software; you can redistribute it and/or modify it under the terms of the Artistic License 2.0. =cut 1;