Skip to main content

A German laws MCP server using FastMCP

Project description

Deutsche Gesetze MCP Server

Dieser Server implementiert das Model Context Protocol (MCP), um deutschen Gesetzestexte für LLMs (Large Language Models) bereitzustellen. Er ermöglicht es KI-Assistenten, gezielt nach Gesetzen zu suchen und spezifische Paragraphen abzurufen.

Die Gesetzestexte werden aus Markdown-Dateien geparst, die dem Format des Bundestag/gesetze Repositories entsprechen (Hinweis: Dieses Repository ist veraltet und dient nur zu Demozwecken).

Funktionen

  • Gesetze auflisten & suchen: Durchsuchen der verfügbaren Gesetze (z.B. BGB, StGB, HGB).
  • Volltextsuche: Suche nach Begriffen in den Gesetzestexten.
  • Paragraphen abrufen: Abruf des Volltextes spezifischer Paragraphen (inkl. Absätze).
  • Flexible Datenquellen: Laden der Gesetze aus einem lokalen Ordner oder direkt von GitHub.

Installation

Lokal

  1. Repository klonen:

    git clone https://github.com/floleuerer/deutsche-gesetze-mcp.git
    cd deutsche-gesetze-mcp
    
  2. Abhängigkeiten installieren: Es wird empfohlen, eine virtuelle Umgebung zu verwenden (z.B. venv oder conda).

    pip install -r mcp/requirements.txt
    

Docker (Empfohlen)

Die Docker-Version klont automatisch das gesamte Bundestag/gesetze Repository (veraltet, nur Demo) in das Image, sodass alle Gesetze sofort lokal verfügbar sind.

  1. Image bauen:

    docker build -t deutsche-gesetze-mcp .
    
  2. Container starten:

    docker run -p 8001:8001 deutsche-gesetze-mcp
    

Datenvorbereitung

Das Projekt enthält im Ordner prepare_data Skripte, um aktuelle Gesetzestexte direkt von www.gesetze-im-internet.de herunterzuladen und für den Server aufzubereiten.

  1. Skript ausführen:
    cd prepare_data
    ./prepare_gesetze_im_internet.sh
    
    Dies lädt die Gesetze herunter, entpackt sie und konvertiert sie in das benötigte Format.

Konfiguration

Die Konfiguration erfolgt über Umgebungsvariablen oder eine .env Datei. Die Einstellungen werden in mcp/config.py definiert.

Variable Beschreibung Standardwert
LOAD_FROM_FOLDER Pfad zu einem lokalen Ordner mit Gesetzes-Markdown-Dateien. /app/gesetze/
LOAD_FROM_GITHUB JSON-Liste von Gesetzeskürzeln, die von GitHub geladen werden sollen (überschreibt LOAD_FROM_FOLDER, wenn gesetzt). None
MIN_PARAGRAPHS Minimale Anzahl an Paragraphen, damit ein Gesetz geladen wird. 5

Beispiel .env Datei: Um Gesetze direkt von GitHub zu laden (z.B. BGB und StGB):

LOAD_FROM_GITHUB='["BGB", "StGB"]'
LOAD_FROM_FOLDER=

Um lokale Dateien zu nutzen (angenommen, sie liegen in ./gesetze):

LOAD_FROM_FOLDER=./gesetze

Nutzung

Server starten

Der Server kann direkt über Python gestartet werden. Er nutzt FastMCP und stellt standardmäßig einen HTTP-Server auf Port 8001 bereit.

python mcp/server.py

Tests

Die Tests können mit pytest ausgeführt werden. Um die Tests zu starten, muss der mcp Ordner im Python-Pfad liegen:

PYTHONPATH=mcp python3 -m pytest mcp/tests

Verfügbare Tools

Der Server stellt folgende MCP-Tools zur Verfügung:

  1. get_lawlibrary(law: str | None)

    • Listet verfügbare Gesetze auf.
    • Parameter law: (Optional) Suchbegriff oder Kürzel, um die Liste zu filtern (z.B. "BGB").
    • Gibt eine JSON-Liste der gefundenen Gesetze zurück.
  2. get_paragraph(law: str, paragraph: str)

    • Ruft den Inhalt eines Paragraphen ab.
    • Parameter law: Das Kürzel des Gesetzes (z.B. "BGB").
    • Parameter paragraph: Die Nummer des Paragraphen (z.B. "1", "14a").
    • Gibt den Text des Paragraphen (und ggf. spezifische Absätze) zurück.
  3. search_laws(query: str, laws: list[str] | None)

    • Volltextsuche über alle oder ausgewählte Gesetze.
    • Parameter query: Der Suchbegriff (z.B. "Schadensersatz", "Kündigung").
    • Parameter laws: (Optional) Liste von Gesetzeskürzeln zur Einschränkung der Suche (z.B. ["BGB", "HGB"]).
    • Gibt eine Liste von Treffern mit Paragraphen und Textausschnitten zurück.

Verwendung mit MCP-Clients

Dieser Server kann mit jedem MCP-kompatiblen Client verbunden werden. Da er als HTTP-Server (SSE) läuft, muss der Client entsprechend konfiguriert werden, um sich mit http://localhost:8001/mcp zu verbinden.

Ein Beispiel für die Integration in einen KI-Agenten findest du im Ordner google-adk-agent, der das Google Agent Development Kit (ADK) nutzt.

Datenformat

Der Parser erwartet Markdown-Dateien, wie sie im Projekt bundestag/gesetze (veraltet, nur Demo) verwendet werden. Die Struktur sieht typischerweise so aus:

---
Title: Bürgerliches Gesetzbuch
jurabk: BGB
---

# § 1 Beginn der Rechtsfähigkeit

Die Rechtsfähigkeit des Menschen beginnt mit der Vollendung der Geburt.
...

Lizenz

Siehe LICENSE Datei.

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

Built Distribution

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

File details

Details for the file iflow_mcp_floleuerer_deutsche_gesetze_mcp-0.1.2.tar.gz.

File metadata

  • Download URL: iflow_mcp_floleuerer_deutsche_gesetze_mcp-0.1.2.tar.gz
  • Upload date:
  • Size: 552.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_floleuerer_deutsche_gesetze_mcp-0.1.2.tar.gz
Algorithm Hash digest
SHA256 51fa06c666707d31ed76e7556004bbfe2df07c9d19e7c5bc2e4f750e8718e1d5
MD5 f39788a349c9abd647e9a81c0980f685
BLAKE2b-256 7fbf7090517c6cc2e6ccbf55bd5147eb17a4d5f1185f336c4dc240a78de680e0

See more details on using hashes here.

File details

Details for the file iflow_mcp_floleuerer_deutsche_gesetze_mcp-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_floleuerer_deutsche_gesetze_mcp-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 12.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_floleuerer_deutsche_gesetze_mcp-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 59ebdcf9791684b1ef14256220320afe5edcf89dcaa3994433fdc4b0cad5b57a
MD5 5a17bfca960b0207e69ccdb7e1c2d7e2
BLAKE2b-256 050b911e1a6b5f358728392c2d935df1056bbca996063b166fb297ccaacbd854

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