NAME
Net::UPCDatabase - Simple OO interface to UPCDatabase.com
SYNOPSIS
use Net::UPCDatabase;
my $upcdb = Net::UPCDatabase->new;
print "\n[lookup]\n";
my $upc = '035000764119';
my $item = $upcdb->lookup($upc);
print "UPC: $item->{upc}\n";
if ($item->{error}) {
print "Error: $item->{error}\n";
}
else {
print "Product: $item->{description}\n";
print "Size: $item->{size}\n";
}
print "\n[convertUpcE]\n";
my $upcE = '01212901';
my $upcA = $upcdb->convertUpcE($upcE);
print "UPCE: $upcA->{upcE}\n";
if ($upcA->{error}) {
print "Error: $upcA->{error}\n";
}
else {
print "UPCA: $upcA->{upc}\n";
}
print "\n[calculateCheckDigit]\n";
my $upcC = '01200000129C';
my $upcA = $upcdb->calculateCheckDigit($upcE);
print "UPCC: $upcA->{upcC}\n";
if ($upcA->{error}) {
print "Error: $upcA->{error}\n";
}
else {
print "UPCA: $upcA->{upc}\n";
}
DESCRIPTION
Connects to UPCDatabase.com to get information about a given UPC.
FUNCTIONS
new
$upcObject = Net::UPCDatabase->new;
# .. or ..
$upcObject = Net::UPCDatabase->new( url => $aDifferentUrlThanDefault );
Accepts an OPTIONAL argument, a URL to use instead of the default. Unless you're really sure what you're doing, don't give it a URL. It defaults to 'http://www.upcdatabase.com/rpc', which is probably the right thing.
Returns the object.
lookup
$itemInfo = $upcObject->lookup($upc);
Accepts a REQUIRED argument, the UPC to lookup. The UPC can be either UPC-A or UPC-E.
Returns the data about the given UPC in a hash reference.
On error, it returns the given error reason as $itemInfo->{error}
.
convertUpcE
$ean = $upcObject->convertUpcE($upcE);
$isError = $ean !~ m|^\d{13}$|;
Accepts a REQUIRED argument, the UPC-E to convert.
Returns the EAN (exactly 13 digits).
On error, it returns the given error reason as $itemInfo->{error}
.
calculateCheckDigit
$upcA = '01200000C2X1'; # bad (more than one digit being calculated)
$upcA = '01200000C29C'; # bad (more than one digit being calculated)
$upcA = '01200000129C'; # good (only one digit)
$upcA = '0120000012C1'; # good (only one digit)
$upcA = $upcObject->calculateCheckDigit($upcA);
$isError = $upcA !~ m|^\d{12}$|;
Accepts a REQUIRED argument, the UPC-A with checkdigit placeholder (C or X) to calculate. This function will calculate the missing digit for any position, not just the last position. This only works if only one digit being calculated. This doesn't work with UPC-E. There is no difference between using "X" or "C" as the placeholder.
Returns the UPC-A with the checkdigit properly calculated.
On error, it returns the given error reason as $itemInfo->{error}
.
NOTE: This uses an internal function, not the function on UPCDatabase.com because it appears that it is currently not implemented on the UPCDatabase.com side of things. If it is implemented on UPCDatabase.com, it is a simple change to use it instead.
_calculateCheckDigit
The internal function that calculates the check digit. You won't want to use this yourself.
DEPENDENCIES
TODO
- UPC checksum checking/creation
-
Clean up calculation of odd-position checkdigit calculation. It currently uses an inefficient brute-force method of calculation for that position. Even-position and checksum position calculation is pretty efficient. OEOEOEOEOEOX (O=odd, E=even, X=checksum) It's not *really* that wasteful, just not as efficient as it could be.
BUGS
Report bugs on the CPAN bug tracker. Please, do complain if something is broken.
SEE ALSO
COPYRIGHT AND LICENSE
Copyright 2005-2009 by Dusty Wilson
This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself.