Skip to main content

Bindings for the Amatino API, an accounting & financial data engine

Project description

Amatino Python

Amatino is a double-entry accounting system. It provides double entry accounting as a service via an HTTP API. Amatino Python is a library for interacting with the Amatino API from within a Python application. By using Amatino Python, a Python developer can utilise Amatino services without needing to deal with raw HTTP requests.

About Amatino

Amatino gives you a full set of tools to store, organise and retrieve financial information. You don't need to set up databases or write any of your own double-entry accounting logic. All you need is this library, an Amatino account (Try free for two weeks!), and you are off and running.

Under construction

Right now, the Amatino API offers a full range of accounting services via HTTP requests. However, this Amatino Python library is in an 'Alpha' state. Its capabilities are limited. A subset of full Amatino features are available.

To see what proportion of Amatino features are ready in Amatino Python, check out the Documentation page. Linked classes are available, un-linked ones are still under construction.

Installation

Amatino Python may be installed via PIP.

$ pip install amatino

To use Amatino Python, you will need an active Amatino subscription. You can start a free trial at https://amatino.io/subscribe.

Example Usage

The first step is to login to Amatino by creating a Session instance. That Session then becomes your key to using Amatino classes.

from amatino import Session

session = Session.create_with_email(
  email='clever@cookie.com',
  secret='uncrackable epic passphrase!'
)

Amatino stores financial data inside discrete Entities. An Entity might describe a person, project, company, or some other entity which you wish to describe with financial data.

from amatino import Entity

mega_corporation = Entity.create(
  session=session,  # Created above
  name='Mega Corporation'
)

Entities are structured as a hierarchical tree of Accounts. You might wish to create a chart of Accounts that mirror the real-world structure of the Entity you are describing.

from amatino import Account

revenue = Account.create(
  entity=mega_corporation,  # Created above
  description='Revenue from world domination',
  am_type=AMType.revenue,  # An AMType enumeration option
  denomination=USD  # A GlobalUnit
)

The real fun begins with Transactions, where debits and credits come into play

from amatino import Transaction, Entry, Side
from datetime import datetime
from decimal import Decimal

revenue_recognition = Transaction.create(
  entity=mega_corporation,
  time=datetime.utcnow(),
  entries=[
    Entry(Side.debit, Decimal(10), cash),
    Entry(Side.credit, Decimal(5), revenue),
    Entry(Side.credit, Decimal(5), customer_deposits)
  ]
  denomination=USD
)

Check out the full range of available classes, including Ledgers, in the Amatino Python documentation

API stability & versioning

Amatino Python obeys the Semantic Version convention. Until v1.0.0, the Python API (not to be confused with the Amatino HTTP API) should be considered unstable and liable to change at any time.

Watch out! API currently unstable!

You can see available versions in GitHub's releases section or in PyPi's release history section.

Tell us what your think/want/like/hate

Please join us on the Amatino discussion forums and give us your feedback. We would love to hear from you. Amatino is in its earliest stages of development, and your feedback will influence the direction it moves in.

Pull requests, comments, issues, forking, and so on are also most welcome on Github!

Useful links

Get in contact

To quickly speak to a human about Amatino, email hugh@amatino.io or yell at him on Twitter (@hugh_jeremy).

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

amatino-0.0.19.tar.gz (48.4 kB view details)

Uploaded Source

Built Distribution

amatino-0.0.19-py3-none-any.whl (97.9 kB view details)

Uploaded Python 3

File details

Details for the file amatino-0.0.19.tar.gz.

File metadata

  • Download URL: amatino-0.0.19.tar.gz
  • Upload date:
  • Size: 48.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.0 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0

File hashes

Hashes for amatino-0.0.19.tar.gz
Algorithm Hash digest
SHA256 c93df585c1b26116597ae816bb328b59863c7d7b90fa6fdb09ff2ebfbafc9246
MD5 c8b6ffafa8d2715f1981e55e9e721741
BLAKE2b-256 6ba67aa980c4815ced8bef35f24cff9f922cd9dc1bf47c045918000414b1dad5

See more details on using hashes here.

File details

Details for the file amatino-0.0.19-py3-none-any.whl.

File metadata

  • Download URL: amatino-0.0.19-py3-none-any.whl
  • Upload date:
  • Size: 97.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.0 importlib_metadata/4.8.2 pkginfo/1.8.2 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.0

File hashes

Hashes for amatino-0.0.19-py3-none-any.whl
Algorithm Hash digest
SHA256 cda884b495add86f493d5180f2d183040aa66da68954c08adb04bceaa121ef22
MD5 67927fb34cce517a1d6d7c0ca59cd0ab
BLAKE2b-256 d479c8011e1a96168097e372aacabe3197a0390209c0c77257c2586d63ac2b36

See more details on using hashes here.

Supported by

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