FinTS-Finanzen
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@FinTS-Finanzenshow my account balances"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
FinTS-Finanzen
Read-only MCP-Server fuer FinTS/HBCI-Banking via PIN-TAN — Konten, Saldo, Umsaetze.
Strikt read-only. Es gibt keinen Code fuer Ueberweisungen oder sonstige Schreibzugriffe.
Standard-Bank ist DKB (12030000), ueber Env-Vars auf jede andere FinTS-Bank umstellbar.
Was es kann
MCP-Tools ueber stdio:
Tool | Beschreibung |
| Alle Konten (IBAN, Kontonummer, BIC) |
| Aktueller Saldo (leer → erstes Konto) |
| Umsaetze der letzten |
| Alle Konten + Salden kompakt in einem Aufruf |
Related MCP server: personal-finance-mcp
Sicherheit / Secret-Modell
Die PIN landet nie im Klartext auf Platte, nie im Repo, nie im git.
Verschluesselung: AES-256-GCM (
cryptography), 12-Byte-Nonce pro Verschluesselung vor dem Ciphertext.Der Schluessel kommt aus der Env-Var
FINTS_MASTER_KEY(base64-kodierte 32 Byte). Ohne diesen Schluessel sind die gespeicherten Credentials unbrauchbar.Verschluesselte Credentials und der FinTS-State liegen unter
~/.config/fints-finanzen/(credentials.enc,fints_state.bin), Verzeichnis0o700, Dateien0o600. Nichts davon ist im Repo.
PSD2-SCA-Exemption (~90 Tage)
Lesen ist nicht TAN-frei. Beim ersten Login verlangt die Bank eine pushTAN-Freigabe. enroll.py fuehrt diesen Flow interaktiv durch und serialisiert danach den FinTS-Client-State (system_id, BPD/UPD) via client.deconstruct(including_private=True). Dieser State wird beim naechsten Lauf wieder geladen — dann bleiben Lesezugriffe dank PSD2 SCA-Exemption ~90 Tage TAN-frei.
Nach Ablauf der ~90 Tage meldet der MCP-Server tan_required (Tool-Fehler, kein Crash) — dann einfach enroll.py erneut ausfuehren (Reenrollment).
Setup
cd FinTS-Finanzen
python3 -m venv .venv
.venv/bin/pip install -r requirements.txtMaster-Key erzeugen und eintragen (einmalig):
cp .env.example .env
.venv/bin/python -c "import crypto; print(crypto.generate_key())"
# Ausgabe als FINTS_MASTER_KEY in .env eintragenAlternativ bietet enroll.py an, den Key zu generieren und anzuzeigen.
Enroll (interaktiv):
set -a; . ./.env; set +a # FINTS_MASTER_KEY in die Umgebung laden
.venv/bin/python enroll.pyDer Enroll fragt Anmeldename (nicht Kontonummer) und PIN ab, fuehrt den pushTAN-Flow durch und speichert PIN verschluesselt + Client-State.
FINTS_PRODUCT_ID/ product_id: Leer lassen nutzt den Default ausconfig.py— eine oeffentliche, in python-fints#183 mehrfach als DKB-akzeptiert belegte ID. Die DKB lehnt ungueltige product_ids bereits bei der Dialog-Initialisierung ab. Wer sauber/dauerhaft fahren will, registriert eine eigene ID bei der Deutschen Kreditwirtschaft (fints.org Produktregistrierung, Formular anregistrierung@hbci-zka.de, ~5–10 Werktage) und setzt sie viaFINTS_PRODUCT_ID.
Andere Bank nutzen
Per Env-Vars umstellbar:
export FINTS_BANK_CODE="12345678" # BLZ deiner Bank
export FINTS_ENDPOINT="https://fints.meine-bank.de/fints"MCP registrieren
Der Server laeuft ueber stdio. Eintrag in der MCP-Config (FINTS_MASTER_KEY muss in der Server-Umgebung gesetzt sein):
{
"mcpServers": {
"fints-finanzen": {
"command": "./.venv/bin/python",
"args": ["mcp_server.py"],
"env": {
"FINTS_MASTER_KEY": "<base64-32-byte-key>",
"FINTS_BANK_CODE": "12030000",
"FINTS_PRODUCT_ID": ""
}
}
}
}Dateien
config.py (Pfade/Konstanten) · crypto.py (AES-GCM) · fints_client.py (FinTS-Wrapper) · enroll.py (interaktiver Enroll) · mcp_server.py (FastMCP stdio).
Lizenz
MIT License — siehe LICENSE.
This server cannot be installed
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/NG-Bullseye/FinTS-Finanzen'
If you have feedback or need assistance with the MCP directory API, please join our Discord server