Skip to main content
Glama
cmendezs

mcp-einvoicing-de

mcp-einvoicing-de đŸ‡©đŸ‡Ș

License PyPI version Python mcp-einvoicing-de MCP server

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-de

Ohne vorherige Installation mit uvx:

uvx mcp-einvoicing-de

Aus 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

EINVOICING_DE_LOG_LEVEL

Protokollierungsgrad (DEBUG, INFO, WARNING, ERROR)

INFO

EINVOICING_DE_KOSIT_VALIDATOR_URL

URL des KoSIT-Validierungstools (optional, fĂŒr Remote-Validierung)

—

EINVOICING_DE_PEPPOL_SMP_URL

Peppol-SMP-Lookup-URL (optional)

—

EINVOICING_DE_PDF_ENGINE

PDF-Generierungsmodul (reportlab oder pymupdf)

reportlab

đŸ€– 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

invoice_create

ZUGFeRD- oder XRechnung-XML (CII oder UBL) erzeugen; PDF/A-3-Hybrid geplant (v0.2.0)

invoice_validate

Rechnung gegen EN 16931 und KoSIT-Schematron-Regeln (BR-DE-*) prĂŒfen

invoice_parse

Strukturierte Daten aus einer bestehenden ZUGFeRD- oder XRechnung-Datei extrahieren

invoice_convert

Zwischen ZUGFeRD-Profilen oder ZUGFeRD ↔ XRechnung konvertieren

peppol_check

Peppol-Teilnehmerregistrierung eines deutschen Unternehmens prĂŒfen (AS4)

tax_rules

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

ferd-net.de

KoSIT XRechnung

xeinkauf.de

KoSIT Validierungstool

github.com/itplr-kosit/validationtool

EN 16931-1:2017

CEN

Peppol BIS Billing 3.0

docs.peppol.eu


đŸ§Ș 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 -v

Roadmap

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 reportlab / PyMuPDF

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 audit

Other e-invoicing MCP servers

Country

Server

🌍 Global

mcp-einvoicing-core

🇧đŸ‡Ș Belgium

mcp-einvoicing-be

đŸ‡«đŸ‡· France

mcp-facture-electronique-fr

🇼đŸ‡č Italy

mcp-fattura-elettronica-it

đŸ‡©đŸ‡Ș Germany

mcp-einvoicing-de


📄 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