mcp-einvoicing-de
mcp-einvoicing-de đ©đȘ
MCP-Server (Model Context Protocol) in Python fĂŒr die deutsche elektronische Rechnung in den Formaten ZUGFeRD 2.x und XRechnung 3.x (EN 16931, FeRD, KoSIT). Ermöglicht KI-Agenten (Claude, IDEs) das Erstellen, Validieren, Parsen und Konvertieren von E-Rechnungen, die vollstĂ€ndig dem deutschen B2B-E-Rechnungsmandat (gĂŒltig ab 2025, schrittweise Durchsetzung bis 2027â2028) und der europĂ€ischen Norm EN 16931 entsprechen.
English summary
This is a Model Context Protocol (MCP) server for German electronic invoicing. It exposes 6 tools covering the full lifecycle of a ZUGFeRD or XRechnung invoice: creation (CII/UBL XML), validation against EN 16931 and KoSIT Schematron rules (BR-DE-*), parsing of existing invoice files, profile and syntax conversion, Peppol participant registration lookup (AS4), and German VAT rules (Steuerklassen, §13b UStG reverse charge, exemptions). Supports all ZUGFeRD 2.x profiles (MINIMUM through EXTENDED) and XRechnung 3.x (CII and UBL syntax). Licensed under Apache 2.0.
Aufgebaut auf
Dieses Paket basiert auf mcp-einvoicing-core, einer gemeinsamen Basisbibliothek fĂŒr europĂ€ische E-Rechnungs-MCP-Server. Sie stellt gemeinsame Modelle, Validierungsabstraktionen, XML-Hilfsfunktionen und die Ausnahmehierarchie bereit.
mcp-einvoicing-core wird automatisch als transitive AbhĂ€ngigkeit installiert â kein zusĂ€tzlicher Schritt erforderlich.
FĂŒr Entwickler:
pip install -e ".[dev]"installiert das Basispaket automatisch aus PyPI.
đïž Architektur
mcp-einvoicing-de (dieses Paket â eigenstĂ€ndiger MCP-Server)
âââ ZUGFeRDInvoice / XRechnungInvoice â Pydantic-Modelle (alle Profile)
âââ SchematronValidator â EN 16931 + KoSIT BR-DE-* Regeln
âââ KoSITValidator â Remote-Validierungstool (optional)
âââ Tools: create / validate / parse / convert / peppol_check / tax_rules
â erweitert
mcp-einvoicing-core (gemeinsame Basis, als AbhÀngigkeit installiert)
âââ BaseDocumentGenerator / Validator / Parser
âââ BaseInvoice, BaseParty ⊠(Pydantic)
âââ xml_utils, exceptions
âââ EInvoicingMCPServerđ Installation
Ăber PyPI (empfohlen)
pip install mcp-einvoicing-deOhne vorherige Installation mit uvx:
uvx mcp-einvoicing-deAus den Quellen
git clone https://github.com/cmendezs/mcp-einvoicing-de.git
cd mcp-einvoicing-de
python -m venv .venv
source .venv/bin/activate # Windows: .venv\Scripts\activate
pip install -e ".[dev]"âïž Konfiguration
Der Server benötigt in v0.1.0 keine externen Zugangsdaten. VerfĂŒgbare Umgebungsvariablen:
Variable | Beschreibung | Standard |
| Protokollierungsgrad ( |
|
| URL des KoSIT-Validierungstools (optional, fĂŒr Remote-Validierung) | â |
| Peppol-SMP-Lookup-URL (optional) | â |
| PDF-Generierungsmodul ( |
|
đ€ Integration Claude Desktop
Eintrag in die Datei claude_desktop_config.json:
{
"mcpServers": {
"einvoicing-de": {
"command": "uvx",
"args": ["mcp-einvoicing-de"]
}
}
}âšïž Integration Cursor
Konfigurationsdatei (~/.cursor/mcp.json oder .cursor/mcp.json im Projektverzeichnis):
{
"mcpServers": {
"einvoicing-de": {
"command": "uvx",
"args": ["mcp-einvoicing-de"]
}
}
}đȘ Integration Kiro
{
"mcpServers": {
"einvoicing-de": {
"command": "uvx",
"args": ["mcp-einvoicing-de"],
"disabled": false,
"autoApprove": []
}
}
}đ§° VerfĂŒgbare MCP-Werkzeuge
Werkzeug | Beschreibung |
| ZUGFeRD- oder XRechnung-XML (CII oder UBL) erzeugen; PDF/A-3-Hybrid geplant (v0.2.0) |
| Rechnung gegen EN 16931 und KoSIT-Schematron-Regeln (BR-DE-*) prĂŒfen |
| Strukturierte Daten aus einer bestehenden ZUGFeRD- oder XRechnung-Datei extrahieren |
| Zwischen ZUGFeRD-Profilen oder ZUGFeRD â XRechnung konvertieren |
| Peppol-Teilnehmerregistrierung eines deutschen Unternehmens prĂŒfen (AS4) |
| Deutsche Umsatzsteuerregeln abfragen (Steuerklassen, §13b UStG, Befreiungen) |
Verwendungsbeispiele
Beispiel 1 â Rechnung validieren
1. invoice_validate(
xml_base64="...", # Base64-kodiertes ZUGFeRD-XML
strict=True
)
â {
"is_valid": true,
"profile": "EN_16931",
"syntax": "CII",
"error_count": 0,
"warning_count": 2,
"errors": [],
"warnings": [...],
"validator_used": "local_schematron"
}Beispiel 2 â Deutsche Steuerregeln abfragen
2. tax_rules(query="reverse_charge", context="Bauleistungen")
â {
"results": [
{
"paragraph": "§13b Abs. 2 Nr. 5 UStG",
"description_en": "Construction services (building contractor rule)",
"vatex_code": "VATEX-EU-AE",
"invoice_note": "Steuerschuldnerschaft des LeistungsempfÀngers (§13b UStG)"
}
],
"legal_disclaimer": "..."
}Beispiel 3 â Peppol-Registrierung prĂŒfen
3. peppol_check(
participant_id="0204:991-1234512345-06",
environment="production"
)
â {
"is_registered": true,
"participant_id": "0204:991-1234512345-06",
"document_type_supported": true,
"access_point_url": "https://ap.example.de/as4",
"transport_profile": "peppol-transport-as4-v2.0"
}Beispiel 4 â Rechnungsdaten parsen
4. invoice_parse(xml_base64="...", include_raw_xml=False)
â {
"profile": "XRECHNUNG",
"syntax": "CII",
"invoice_number": "RE-2025-001",
"invoice_date": "2025-01-15",
"seller_name": "Muster GmbH",
"buyer_name": "KĂ€ufer AG",
"tax_inclusive_amount": "119.00",
"currency_code": "EUR"
}đ UnterstĂŒtzte Standards
Standard | Version | Profile / Syntax |
ZUGFeRD | 2.3 | MINIMUM, BASIC WL, BASIC, EN 16931, EXTENDED |
XRechnung | 3.x | CII (Cross Industry Invoice), UBL (Universal Business Language) |
EN 16931 | â | EuropĂ€isches Kerndatenmodell fĂŒr die elektronische Rechnung |
Peppol BIS | 3.0 | Billing 3.0 (DE PINT) |
Hinweis: ZUGFeRD 2.x und XRechnung 3.x teilen auf Profilebene EN 16931 dieselbe CII-XML-Syntax. Eine Konvertierung zwischen beiden Formaten ist daher ohne Datenverlust möglich. Das EXTENDED-Profil ist ZUGFeRD-spezifisch und hat kein XRechnung-Ăquivalent.
Ressource | Link |
FeRD ZUGFeRD-Spezifikation | |
KoSIT XRechnung | |
KoSIT Validierungstool | |
EN 16931-1:2017 | |
Peppol BIS Billing 3.0 |
đ§Ș Tests
# EntwicklungsabhÀngigkeiten installieren
pip install -e ".[dev]"
# Gesamte Testsuite ausfĂŒhren
pytest tests/ -v
# Mit Abdeckungsbericht
pytest --cov=mcp_einvoicing_de --cov-report=term-missing
# Nur Modell-Tests
pytest tests/test_models.py -vRoadmap
Version | Funktionen |
v0.1.0 (aktuell) | Werkzeuge: create, validate, parse, convert, peppol_check, tax_rules |
v0.2.0 | PDF/A-3-Einbettung (ZUGFeRD-Hybrid) via |
v0.3.0 | KoSIT-Online-Validator vollstÀndig integriert |
v0.4.0 | Peppol AS4 DirektĂŒbermittlung |
v0.5.0 | DATEV-Exportformat |
v1.0.0 | Produktionsreif, vollstÀndige EN 16931-Abdeckung |
Mitwirken
BeitrĂ€ge sind willkommen. Bitte öffnen Sie ein Issue, bevor Sie einen Pull Request fĂŒr wesentliche Ănderungen einreichen.
git clone https://github.com/cmendezs/mcp-einvoicing-de.git
cd mcp-einvoicing-de
pip install -e ".[dev]"
pytest
make auditOther e-invoicing MCP servers
Country | Server |
đ Global | |
đ§đȘ Belgium | |
đ«đ· France | |
đźđč Italy | |
đ©đȘ Germany |
đ Lizenz
Dieses Projekt steht unter der Apache-2.0-Lizenz.
Einzelheiten finden Sie in der Datei LICENSE.
Copyright 2026 cmendezs
Projekt gepflegt von cmendezs. FĂŒr Fragen zur Implementierung der ZUGFeRD- oder XRechnung-Spezifikation bitte ein Issue eröffnen.
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/cmendezs/mcp-einvoicing-de'
If you have feedback or need assistance with the MCP directory API, please join our Discord server