Skip to main content

Python wrapper for BI SomConnexió API

Project description

This library is a Python wrapper for accessing Som Connexió BI API.

Operations

  • Notify the BI API with an invoice number
  • Recreate the PDF of an invoice
  • Create a temporal token to access an invoice

Installation

$ pip install bi-sc-client

Configuration Environment

To use this library you must expose the needed environment variables:

BI_URL:
BI_USER:
BI_PASSWORD:

These environment variables are needed to locate and access to the BI API.

Usage

  • Notify the BI API with an invoice number
    from bi_sc_client.services.notify_invoice_number import NotifyInvoiceNumber
    NotifyInvoiceNumber(invoice_id=123, invoice_number="AB-1234Z").run()
  • Recreate the PDF of group invoices
    from bi_sc_client.services.invoice_pdf_regenerate import InvoicePDFRegenerator
    InvoicePDFRegenerator(invoice_numbers=["AB-1234Z", "AB-1234Z"]).run()
  • Create a temporal token to access an invoice
    from bi_sc_client.resources.token import Token
    from bi_sc_client.client import BISomConnexioClient
    client = BISomConnexioClient()
    token_instance = Token(client=client)
    print(token_instance.token)

Development

Setup environment

  1. Install pyenv
curl https://pyenv.run | bash
  1. Build the Python version
pyenv install  3.7.13
  1. Create a virtualenv
pyenv virtualenv 3.7.13 bi-sc-client
  1. Install dependencies
pyenv exec pip install -r requirements.txt
  1. Install pre-commit hooks
pyenv exec pre-commit install

Install the package locally in development mode

When we are using this package in other projects, we need to install it to use as import in the other files. Install the package in development mode helps us to modify the package and use the new version in live in the other project.

pip install -e .

Test the HTTP request

We are using the HTTP recording plugin of Pytest: pytest-recording.

With VRC we can catch the HTTP responses and then, execute the tests using them.

To add a new test:

  • Expose the needed envvars. Look for them at the Configuration Environment section
  • Execute the tests using pytest command:
  • If you are writing a new test that is making requests, you should run:
$ pytest --record-mode=once path/to/your/test
  • You might need to record requests for an specific tests. In that case make sure to only run the tests affected and run
$ pytest --record-mode=rewrite path/to/your/test
  • Add the new cassetes to the commit and push them.
  • The CI uses the cassetes to emulate the HTTP response in the test.

Run test suite

$ tox

Formatting

We use Black as formatter. First to commit, tun the black command:

$ black .
All done! ✨ 🍰 ✨
29 files left unchanged.

Darker

Black is a great formatter, but to mantain your code without execute the black command avery time, you can configure your IDE to use darker to format only the changed or added code when you save the file.

Release process

Update CHANGELOG.md following this steps:

  1. Add any entries missing from merged merge requests.
  2. Duplicate the [Unreleased] header.
  3. Replace the second Unreleased with a version number followed by the current date. Copy the exact format from previous releases.

Then, you can release and publish the package to PyPi:

  1. Update the __version__ var in __init__.py matching the version you specified in the CHANGELOG.
  2. Open a merge request with these changes for the team to approve
  3. Merge it, add a git tag on that merge commit and push it.
  4. Once the pipeline has successfully passed, your package had been published.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

bi_sc_client-0.0.6.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

bi_sc_client-0.0.6-py2.py3-none-any.whl (6.7 kB view details)

Uploaded Python 2Python 3

File details

Details for the file bi_sc_client-0.0.6.tar.gz.

File metadata

  • Download URL: bi_sc_client-0.0.6.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.7.17

File hashes

Hashes for bi_sc_client-0.0.6.tar.gz
Algorithm Hash digest
SHA256 33d9c131bccf8a7fc7bd8edb12b7ac1b269b2e76bd9e05840eb340d9998d93d5
MD5 1b90c2d69b34242b2de647bbd9f3f623
BLAKE2b-256 318838f4fd30700129b8fd44cfd54203e17e1666a8ff08ba9cb76438846d09a8

See more details on using hashes here.

File details

Details for the file bi_sc_client-0.0.6-py2.py3-none-any.whl.

File metadata

  • Download URL: bi_sc_client-0.0.6-py2.py3-none-any.whl
  • Upload date:
  • Size: 6.7 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.7.17

File hashes

Hashes for bi_sc_client-0.0.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 c07bac49227503be9ba008765fd26b921c8758b272d19d99a95dcc7ae1e9ba7d
MD5 cce377410a6e42e1bb468abbb0d2a8cc
BLAKE2b-256 8497a97b1c4b8259d58b534123b7c68671ed4eaa7900cc5f09d811ff685b4d0d

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page