Skip to content
/ mydata Public

Python interface for IARP's (ΑΑΔΕ) myDATA service

License

Notifications You must be signed in to change notification settings

apyrgio/mydata

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

49 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Supported Python Versions PyPI version

CLI / HTTP client for myDATA

This project allows users to interact with myDATA ("my Digital Accounting and Tax Application") either via a Python HTTP client or from the CLI.

Install

Install it with pip:

python -m pip install mydata-client

Usage

Warning

The tool is not suitable yet for production use. We strongly suggest that you use it for experimenting only with the development sandbox that myDATA provides.

Note

Oh, you may also find the docs a bit... lacking 😬

If you want to interact programmatically with myDATA's API, you can use the HTTP client under mydata/client.py. The Python dataclasses that bind to XML documents can be found in the mydata/models* modules, depending on which version of the API you want to use.

There is also a proof-of-concept CLI that you can use:

mydata --username <username> <command>

There are two command groups that you can invoke:

  • The api command group, which is unopinionated and straight up hits the endpoint that you ask.
  • The invoice command group, which is heavily opinionated and adds some helper commands to work with invoices. Basically, it's there to assist the list -> retrieve -> copy -> edit -> validate -> send lifecycle of an invoice.

Building

Install Poetry. Then, install the project dependencies:

poetry install

Adding new XSD schemas

Whenever there's an API update, myDATA devs include the XML schemas for the latest API. You can include them in the project as follows:

  • Add the XML schemas under schemas/<version> dir. For example, for the 1.0.8 XSDs, we added them with:

    cp -r '/path/to/version v1.0.8 XSDs' schemas/1.0.8
    
  • Remove the previously generated mydata/__init__.py module:

    rm mydata/__init__.py
    
  • Generate Python classes from the new XSDs. For example, for the 1.0.8 XSDs, we generated Python classes with:

    poetry run xsdata -ss single-package -ds Google -r schemas/1.0.8/ -p mydata.models_v1_0_8
    
  • Generate Markdown documentation from the generated Python classes with:

    poetry run pydoc-markdown -m mydata.models_v1_0_8 --render-toc > docs/models_v1_0_8.md
    

License

Licensed under MPL-2.0. Please read the NOTICE.md and LICENSE files for the full copyright and license information.

Useful links

About

Python interface for IARP's (ΑΑΔΕ) myDATA service

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages