Skip to content

dseichter/vatservice

VATService

Service to validate VAT numbers against BZSt, VIES or HMRC.

Looking for an GUI? Checkout vatservice-gui for single or batch validation using CSV, XLSX or JSON.

Badges

pep8 tflint trivy

Prerequisites

  • AWS Account to deploy the complete infrastructure
  • Python
  • terraform

optional: you own a VAT number to be able to perform requests

Contributing

Please read CONTRIBUTING and also CODE_OF_CONDUCT. All contributions are welcome.

Short overview

Instead of performing a request to different services with different formats, VATService provides a common interface. This makes an integration into applications easier.

architecture

How it works

If you perform a request to the API Gateway, the first Lambda function is getting invoked. This will precheck the received data. If everything is fine, the Step Function will be triggered synchronous. The Step Function will decide, if

  • your VAT id starts with GB, the HMRC Lambda will be triggered (all others will fail after the Brexit).
  • your own VAT starts with DE, you will be able to use the BZSt interface. Otherwise your request will be performed by using the VIES interface.

You can overwrite this behaviour by specifying the type in the payload.

Every response will be stored in the DynamoDB to keep the original response of the interfaces. This enables you to be able to have the evidence in case of an audit.

Interfaces

References to the used services on AWS

The main components used by VATService:

And a lot more :)

About

Service to validate VAT numbers using BZSt, VIES or HMRC.

Topics

Resources

License

Code of conduct

Security policy

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published