Fattura24

Build Status Maintainability Test Coverage

Simple, lightweight and with minimal dependencies ruby 2+ wrapper for the Fattura24 apis.

Tested and developed on rubies 2.4+.

Installation

Add this line to your application's Gemfile:

gem 'fattura24'

And then execute:

$ bundle

Or install it yourself as:

$ gem install fattura24

Usage

First, configure the module by adding your api key.

Fattura24.configure do |configuration|
  configuration.api_key = 'your_secret_key'
end

Once set, you can call the api methods to get the responses you need.

# This method checks if your key is valid
response = Fattura24::Api.test_key

# Check for possible network errors, returns true on ok (200) responses
puts response.success?

# Call .to_h to get a hash version of the xml response
puts response.to_h[:returnCode]

# If you need more info, check the raw Net::HTTP response object
raw_response = response.http_response

Api calls

You can take inspiration on the params to provide to your calls by visiting the official documentation. Generally speaking, this library will translate the structure of your hash to an equivalent xml document camelizing all of your keys.

TestKey, GetTemplate, GetPdc, GetNumerator

All of these calls don't require any argument. Simply call them and inspect their response:

r = Fattura24::Api.test_key
r = Fattura24::Api.get_template
r = Fattura24::Api.get_pdc
r = Fattura24::Api.get_numerator

puts r.to_h

SaveCustomer

r = Fattura24::Api.save_customer(
  customer_name: 'John Doe',
  customer_address: '100 Yonge Street',
  customer_city: 'Toronto',
  customer_country: 'CA',
  customer_fiscal_code: 'Set this for persons',
  customer_vat_code: 'vat',
  customer_email: '[email protected]',
  fe_customer_pec: '[email protected]'
)

SaveDocument

r = Fattura24::Api.save_document(
  document_type: Fattura24::DocumentType::ELECTRONIC_INVOICE,
  customer_name: 'John Doe',
  customer_fiscal_code: 'NDASFN89A27L219Y',
  customer_address: '100 Yonge Street',
  customer_city: 'Toronto',
  customer_country: 'CA',
  fe_payment_code: Fattura24::FePaymentCode::CREDIT_CARD,
  payments: [
    {
      date: '2020-04-27',
      amount: '100',
      paid: 'true'
    }
  ],
  rows: [
    {
      code: '001',
      description: 'Element description',
      qty: '1',
      price: '100'
    }
  ],
  id_template: '65',
  send_email: 'true',
  object: 'test',
  total: 100,
  total_without_tax: 100,
  vat_amount: 0
)

GetFile

r = Fattura24::Api.get_file('1234567')

# true if response content is actually a file
if r.pdf?
  File.write('invoice.pdf', r.to_s)
end

GetProduct

# gets all products
r = Fattura24::Api.get_product

# filters by code
r = Fattura24::Api.get_product(code: 'some_code')

# filters by category
r = Fattura24::Api.get_product(category: 'some_category')

# combines both
r = Fattura24::Api.get_product({
  code: 'some_code',
  category: 'some_category'
})

Development

After checking out the repo, run bundle to install dependencies. You can run bin/console for an interactive prompt that will allow you to experiment.

To install this gem onto your local machine, run bundle exec rake install.

To run tests and linting, simply run bundle exec rake.

When you edit something, include appropriate docs and rebuild them by running bundle exec rake rdoc.

If you have docker installed, you can test against all of the supported ruby versions by running:

$ make build

That will build the required docker images, and then you can run tests with:

$ make

Release of a new version

To release a new version, update the version number in lib/fattura24/version.rb. Make sure version tests are still satisfied. Then run bundle exec rake release, which will create a git tag for the version, push git commits and tags, and push the .gem file to rubygems.org.

Contributing

Everyone is welcome to contribute. This project tries to follow the git-flow branching model. Open a branch named feature/<name> and make a PR against develop.

Please, make sure you include appropriate unit tests to the codebase (also check coverage) and that your code satisfies rubocop checks.

License

The gem is available as open source under the terms of the MIT License.