Skip to main content

An Open Banking CLI

Project description

💲 leggen

A self hosted Open Banking Dashboard, API and CLI for managing bank connections and transactions.

Having your bank data accessible through both CLI and REST API gives you the power to backup, analyze, create reports, and integrate with other applications.

Leggen demo

🛠️ Technologies

Frontend

  • React: Modern web interface with TypeScript
  • Vite: Fast build tool and development server
  • Tailwind CSS: Utility-first CSS framework
  • shadcn/ui: Modern component system built on Radix UI
  • TanStack Query: Powerful data synchronization for React

🔌 API & Backend

  • FastAPI: High-performance async API backend (integrated into leggen server)
  • EnableBanking: Open Banking data access for connecting to banks
  • APScheduler: Background job scheduling with configurable cron

📦 Storage

  • SQLite: for storing transactions, simple and easy to use

✨ Features

🎯 Core Banking Features

  • Connect to banks using EnableBanking (30+ EU countries)
  • List all connected banks and their connection statuses
  • View balances of all connected accounts
  • List and filter transactions across all accounts

🔄 Data Management

  • Sync all transactions with SQLite database
  • Background sync scheduling with configurable cron expressions

📡 API & Integration

  • REST API: Complete FastAPI backend with comprehensive endpoints
  • CLI Interface: Enhanced command-line tools with new options

🔔 Notifications & Monitoring

  • Discord and Telegram notifications for filtered transactions
  • Configurable transaction filters (case-sensitive/insensitive)
  • Account expiry notifications and status alerts
  • Comprehensive logging and error handling

🚀 Quick Start

Prerequisites

  1. Create an Enable Banking account at https://enablebanking.com/
  2. Create an application in the Enable Banking Customer Portal as the image below. The redirect URL must use HTTPS and must end with /bank-connected. Enable Banking does not support HTTP.
  3. Set up your bank accounts following the Enable Banking Setup Guide

Enable Banking new application

Installation

Docker Compose

# Clone the repository
git clone https://github.com/elisiariocouto/leggen.git
cd leggen

# Create your configuration
mkdir -p data && cp config.example.toml data/config.toml
# Edit data/config.toml with your EnableBanking credentials

# Start all services
docker compose up -d

Configuration

Create a configuration file at ./data/config.toml:

[enablebanking]
application_id = "your-application-id"
key_path = "/path/to/private-key.pem"
# url = "https://api.enablebanking.com"

[database]
sqlite = true

# Optional: Background sync scheduling
[scheduler.sync]
enabled = true
hour = 3      # 3 AM
minute = 0
# cron = "0 3 * * *"  # Alternative: use cron expression

# Optional: Discord notifications
[notifications.discord]
webhook = "https://discord.com/api/webhooks/..."
enabled = true

# Optional: Telegram notifications
[notifications.telegram]
token = "your-bot-token"
chat_id = 12345
enabled = true

# Optional: Transaction filters for notifications
[filters]
case_insensitive = ["salary", "utility"]
case_sensitive = ["SpecificStore"]

📖 Usage

Web Interface

Access the React web interface at http://localhost:3000 after starting the services.

API Service

Visit http://localhost:3000/api/v1/docs for interactive API documentation.

CLI Commands

leggen status              # Check connection status
leggen bank add            # Connect to a new bank
leggen balances            # View account balances
leggen transactions        # List transactions
leggen sync                # Trigger accounts sync

For more options, run leggen --help or leggen <command> --help.

⚠️ Notes

  • This project is in active development

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

leggen-2026.3.0.tar.gz (52.2 kB view details)

Uploaded Source

Built Distribution

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

leggen-2026.3.0-py3-none-any.whl (72.8 kB view details)

Uploaded Python 3

File details

Details for the file leggen-2026.3.0.tar.gz.

File metadata

  • Download URL: leggen-2026.3.0.tar.gz
  • Upload date:
  • Size: 52.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for leggen-2026.3.0.tar.gz
Algorithm Hash digest
SHA256 878b2af6b885b5dcfa7fac2dbe1e6e7893fc36f6f1904cf48cc7d8f8fc0a39fc
MD5 8adee632da0b75ce8ee88bc65669ec5d
BLAKE2b-256 6f5e83240fc0bebe1ba0a0fe52f928da891d0d7ef3642cf54d1e97b08f4a7cb8

See more details on using hashes here.

File details

Details for the file leggen-2026.3.0-py3-none-any.whl.

File metadata

  • Download URL: leggen-2026.3.0-py3-none-any.whl
  • Upload date:
  • Size: 72.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.7 {"installer":{"name":"uv","version":"0.10.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for leggen-2026.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 cb77bf5bcfa630d39369be28dc69c0c015c2453fec075bfd32906de690b71977
MD5 63cb963d7d83ebde04225e854cb79b4a
BLAKE2b-256 fde2c6c478cbf1d77cb11f500d6207c6a6e6030d93713da909541b443481725e

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