NAME

Business::Tax::VAT::Validation - A class for european VAT numbers validation.

SYNOPSIS

use Business::Tax::VAT::Validation;

my $hvatn=Business::Tax::VAT::Validation->new();

# Check number
if ($hvatn->check($VAT, [$member_state])){
      print "OK\n";
} else {
      print $hvatn->get_last_error;
}

DESCRIPTION

This class provides you a easy api to check validity of european VAT numbers (if the provided number exists).

It asks the EU database for this.

METHODS

new Class constructor.
$hvatn=Business::Tax::VAT::Validation->new();
check - Checks if a VAT number exists into the VIES database
$ok=$hvatn->check($VAT, [$member_state]);

You may either provide the VAT number under his complete form (e.g. BE-123456789, BE123456789 or BE 123 456 789) or specify VAT and MS (member state) individually.

Valid MS values are :

AT, BE, DE, DK, EL, ES, FI, FR, GB, IE, IT, LU, NL, PT, SE
get_last_error - Returns last recorded error
$hvatn->get_last_error();

Possible errors are :

- Unknown MS code : Internal checkup failed (does not exists) - Invalid VAT number format : Internal checkup failed (bad syntax) - This VAT number doesn't exists in EU database : distant checkup - This VAT number contains errors : distant checkup - Invalid response, please contact the author of this module. : This normally only happens if this software doesn't recognize any valid pattern into the response document: this generally means that the database interface has been modified.

Other documentation

Jetez un oeil sur http://www.it-development.be/software/PERL/Business-Tax-VAT-Validation/ pour la documentation en français.

Feedback

If you find this module useful, or have any comments, suggestions or improvements, please let me know.

AUTHOR

Bernard Nauwelaerts <bpn@it-development.be>

LICENSE

GPL. Enjoy ! See COPYING for further informations on the GPL.

Credits

Thanks to Robert Alloway for providing us internal checkup regexp's for VAT numbers.

Disclaimer

See http://europa.eu.int/comm/taxation_customs/vies/en/viesdisc.htm to known the limitations of the EU validation service.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

2 POD Errors

The following errors were encountered while parsing the POD:

Around line 186:

You forgot a '=back' before '=head1'

Around line 188:

Non-ASCII character seen before =encoding in 'français.'. Assuming UTF-8