Skip to content

A beancount importer that provides import functionality to retrieve transactions from a Hibiscus H2DB using the v3 [Beangulp](https://github.com/beancount/beangulp) interface.

License

Notifications You must be signed in to change notification settings

Sieboldianus/beancount-hibiscus-importer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

30 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Beancount Hibiscus Importer

Hibiscus is a widely used open source software in Germany. It supports the retrieval of transactions from banks using the HBCI or FinTS standards and (with plugins) via web scraping (credit cards) or APIs (e.g. Paypal). This Beancount Hibiscus Importer provides import functionality to retrieve transactions from the Hibiscus H2DB (either directly or via XML-RPC) and convert them to the Beancount format using the v3 Beangulp interface.


TL;DR (Setup)

On Linux or Windows Subsystem for Linux (WSL1 or 2), follow these steps to install and run this importer.

First make sure Java is available.

apt update && apt install default-jre
java -version
> openjdk version "11.0.25" 2024-10-15

Clone this repository.

git clone [email protected]:Sieboldianus/beancount-hibiscus-importer.git
cd beancount-hibiscus-importer

Create a virtual environment in a local .venv folder and install dependencies.

python3 -m venv .venv
source ./.venv/bin/activate
pip install beangulp beancount python-dotenv jaydebeapi

Set up custom environment variables. Either use a .env file or export variables manually. See .env.example for a description of configuration settings.

cp .env.example .env
nano .env # edit your settings

Run the tests:

bash src/importers/runtests.sh

Run the importer. Beangulp will hook all .mv.db (Hibiscus H2DB) files to the Hibiscus importer:

python import.py identify ./path/to/h2db
python import.py extract ./path/to/h2db > tmp.beancount

Features

  • Balances and Transactions are currently imported from Hibiscus
  • The Hibiscus H2 DB is opened in read-only mode.
  • Hibiscus Unique IDs: The Hibiscus H2DB uses unique IDs to deduplicate transactions. These UIDs are used by the importer to avoid duplicate imports. They are called HUID (Hibiscus Unique IDs). The huids are added as metadata to beancount transactions to keep a reference to the Hibiscus database. Depending on whether this is an receiving or sending transfer, huid_receiving and huid_sending are used, e.g.:
    2023-12-11 * "LAG INTERNET SERVICES GMB FIBU 52344 RENR 3021233243280"
      huid_sending: "22"
      Assets:EUR:DKB:Giro  -23.94 EUR
    
  • Duplicate detection: huids are also used to avoid importing hibiscus transactions multiple times. A cache of already processed huids is kept in PROCESSED_HUIDS_FILE. This feature can be turned off in the importer function (set ignore_already_processed=False)
  • Account Mappings: Multiple Hibiscus Accounts are mapped to Beancount accounts through hibiscus/.accounts (set via ACCOUNTS_MAPPING_CSV).
  • Choose either H2, to query the Hibiscus database directly, or RPC, to query via the Hibiscus XML-RPC interface (see below)
  • A number features are implemented to restrict querying H2 transactions, e.g. limit by number of entries (LIMIT_ENTRIES), by last date (SINCE_DATE), or by HUID (SINCE_HUID).
  • Categories Mapping: This is what Martin Blais calls the second leg of the transaction. Beancount Hibiscus Importer can add some of these category accounts.
    • Merge of internal transactions: Internal transfers between your own accounts, it will automatically add the second leg. For this to work, you need to specify a payee_ref in hibiscus/.accounts (third column). The payee_ref is what is shown in the Hibiscus H2 DB as the recipient account (usually your IBAN, Paypal email, etc.).
      2023-12-11 * "Umbuchung             DATUM 11.12.2023, 06.23 UHR"
        huid_sending: "21"
        huid_receiving: "25"
        Assets:EUR:DKB:Giro        -10000.0 EUR
        Assets:EUR:Comdirect:Giro   10000.0 EUR
      

Configuration

I decided to move most configuration to environment variables. Feel free to set these any way you want. Have a look at .env.example for a description of configuration settings.

The common way to set env settings in Linux is to use a file called .env. This file is automatically loaded. Beancount Hibiscus Importer imitates this behaviour. Note that you should usually not commit .env to git.

Notes

  • Only one connection per H2DB is allowed. Close Hibiscus before importing to beancount from the H2DB
  • Not implemented: If you use Hibiscus to categorize transactions, these categories are not yet used to categorize the second leg of beancount transactions (e.g. expense accounts).
  • Language conventions: The code is primarily written in English. All references to Hibiscus (e.g. H2 column names) are kept in German.

XML-RPC

Note: XML-RPC query is currently a proof of concept. Not all H2 DB query features are implemented.

Querying automated transaction categories from Hibiscus is only possible via XML-RPC protocol, as automated categories are not stored in H2 itself. See the documentation. You can still query Hibiscus categories from the H2DB after transactions have been manually marked as verified in Hibiscus (make sure to confirm hard-linking categories in this case).

I still wanted to be able to query via XML-RPC, as this also allows connecting to Hibiscus running on a remote server. Note that the XML-RPC mapping of values is currently not included in the tests and the processing of values is a bit rough (str, int, and float conversion; regionalization).

Setup of Hibiscus XML-RPC connection

Datei > Einstellungen > Verfügbare Plugins > <Alle Repositories> auswählen

  • hibiscus.xmlrpc finden und installieren, installiert dependencies:
    • jameica.webadmin
    • jameica.xmlrpc

Datei > Einstellungen > HTTP

  • Server binden an: 127.0.0.1
  • no HTTPS
  • no auth

About

A beancount importer that provides import functionality to retrieve transactions from a Hibiscus H2DB using the v3 [Beangulp](https://github.com/beancount/beangulp) interface.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published