Base package for European electronic invoicing MCP servers
Project description
mcp-einvoicing-core
Topics: mcp mcp-server e-invoicing electronic-invoicing european-invoicing python fastmcp peppol en16931 ubl fatturapa xp-z12-013 xml base-library
Base package for European electronic invoicing MCP servers.
Provides abstract base classes, shared Pydantic models, XML utilities, and an HTTP client
so country-specific packages (mcp-facture-electronique-fr, mcp-fattura-elettronica-it, …)
share a common foundation without duplicating code.
What this package provides
| Module | Contents | Used by |
|---|---|---|
models.py |
InvoiceParty, InvoiceLineItem, VATSummary, PaymentTerms, InvoiceDocument, DocumentValidationResult |
IT (structured invoice generation), future BE/PL/DE/ES |
base_server.py |
BaseDocumentGenerator, BaseDocumentValidator, BaseDocumentParser, BaseLifecycleManager, BasePartyValidator, EInvoicingMCPServer |
All country adapters |
xml_utils.py |
format_amount, format_quantity, validate_date_iso, validate_iban, xml_element, xml_optional, format_error, filter_empty_values |
IT (extracted verbatim), future XML-based formats |
http_client.py |
TokenCache, OAuthConfig, BaseEInvoicingClient (OAuth2 + no-auth) |
FR (extracted verbatim), future API-based countries |
exceptions.py |
EInvoicingError, ValidationError, PartyValidationError, XSDValidationError, DocumentGenerationError, AuthenticationError, PlatformError |
All country adapters |
logging_utils.py |
setup_logging, get_logger |
All country adapters |
Installation
pip install mcp-einvoicing-core
This package has no country-specific dependencies. lxml (needed for XSD validation
in IT and future countries) is declared by each country package individually.
Architecture
mcp-einvoicing-core ← this package
├── BaseDocumentGenerator ← abstract: generate(InvoiceDocument) → str
├── BaseDocumentValidator ← abstract: validate(xml) → DocumentValidationResult
├── BaseDocumentParser ← abstract: parse(xml) → dict
├── BaseLifecycleManager ← abstract: submit/search/get_status (async HTTP)
├── BasePartyValidator ← abstract: validate_seller/buyer/tax_id
├── BaseEInvoicingClient ← concrete: async HTTP + OAuth2/no-auth/token
├── InvoiceDocument (Pydantic) ← shared data model
└── EInvoicingMCPServer ← plugin registry wrapping FastMCP
mcp-facture-electronique-fr ← country adapter (FR)
├── PAConfig(OAuthConfig)
├── FlowClient(BaseEInvoicingClient) ← OAuth2, XP Z12-013 Annex A
├── DirectoryClient(BaseEInvoicingClient) ← OAuth2, XP Z12-013 Annex B
└── FrLifecycleManager(BaseLifecycleManager)
mcp-fattura-elettronica-it ← country adapter (IT)
├── ItalyPartyValidator(BasePartyValidator) ← Partita IVA modulo-10
├── FatturaGenerator(BaseDocumentGenerator) ← FatturaPA XML v1.6.1
├── FatturaValidator(BaseDocumentValidator) ← lxml XSD v1.6.1
└── FatturaParser(BaseDocumentParser) ← lxml xpath
Plugin registration pattern
Country packages register their tools on a shared or standalone FastMCP instance:
# Standalone (existing server.py — no changes required)
from fastmcp import FastMCP
mcp = FastMCP(name="mcp-fattura-elettronica-it", instructions="…")
register_header_tools(mcp)
register_body_tools(mcp)
register_global_tools(mcp)
# Multi-country (optional EInvoicingMCPServer)
from mcp_einvoicing_core import EInvoicingMCPServer
server = EInvoicingMCPServer(name="mcp-einvoicing-eu", instructions="…")
server.register_plugin(register_header_tools, "it-header")
server.register_plugin(register_flow_tools, "fr-flow")
server.run()
Claude Desktop / Cursor / Kiro compatibility
Existing configurations for mcp-facture-electronique-fr and mcp-fattura-elettronica-it
require no changes: tool names, signatures, environment variables, and entry points
(server:main) are fully preserved.
Roadmap compatibility
| Country | Status | Standard | Transport | Inherits | Overrides | Known gaps |
|---|---|---|---|---|---|---|
| 🇫🇷 FR | ✅ Done | XP Z12-013 | Hybrid / PPF hub | BaseEInvoicingClient, BaseLifecycleManager |
submit_lifecycle_status, healthcheck |
None |
| 🇮🇹 IT | ✅ Done | FatturaPA v1.6.1 | Direct / SDI | BaseDocumentGenerator, BaseDocumentValidator, BaseDocumentParser, BasePartyValidator |
all abstract methods | to_invoice_document() not yet implemented |
| 🇧🇪 BE | ✅ Done | Peppol BIS 3.0 | AS4 / Peppol | all base classes | generate() → UBL 2.1, validate() → Schematron EN16931 |
None |
| 🇵🇱 PL | 🔄 In progress | KSeF FA(2) | Direct API | BaseDocumentGenerator, BaseDocumentValidator, BaseLifecycleManager |
KSeF session auth flow | MTLS auth mode not yet implemented |
| 🇩🇪 DE | 🔄 In progress | ZUGFeRD / XRechnung | AS4 / Peppol | all base classes | generate() returns PDF bytes (base64) |
generate() return type: str vs bytes ambiguity |
| 🇪🇸 ES | 🔄 In progress | FACeB2B / FacturaE | Direct API | all base classes | mTLS auth | MTLS auth mode not yet implemented |
| 🇷🇴 RO | 📋 Backlog | RO-UBL (EN 16931) | Direct API / clearance | BaseDocumentGenerator, BaseLifecycleManager |
ANAF clearance flow | BaseSchematronValidator variant needed |
| 🇬🇷 GR | 📋 Backlog | myDATA XML | Direct API / reporting | BaseEInvoicingClient, BaseLifecycleManager |
myDATA auth + reporting flow | myDATA API client not yet designed |
| 🇳🇱🇸🇪🇩🇰🇳🇴 Nordics/NL | 📋 Backlog | Peppol BIS 3.0 / UBL | AS4 / Peppol | all base classes | generate() → UBL 2.1, validate() → Schematron |
Reuses BE AS4 transport layer |
| 🇵🇹 PT | 📋 Backlog | CIUS-PT + QR Code | Signature / direct | BaseDocumentGenerator, BaseDocumentValidator |
Qualified signature + QR injection | Qualified signature integration not designed |
Architectural notes
Transport interface
As the adapter count grows, a TransportInterface abstraction in core will prevent duplication across countries that share the same transport layer:
| Transport | Countries |
|---|---|
| Direct API (clearance / reporting) | FR, RO, GR, HU |
| AS4 / Peppol network | BE, DE, Nordics/NL |
| Hybrid / hub | FR (PPF/PDP dual path) |
Germany: 80% reuse from FR
Germany's mandate (active since Jan 2025 for B2B receiving) heavily favors ZUGFeRD/Factur-X — the same PDF-embedded XML model as the French Factur-X profile. The mcp-facture-electronique-fr XML generation and validation logic can be reused with minimal changes, making DE the lowest-effort next adapter after BE.
ViDA / DRR (2030)
By July 2030, all national systems must align with the EU Digital Reporting Requirement for cross-border transactions. Using EN 16931 as the internal InvoiceDocument data model in this core package already future-proofs the project: country adapters translate EN 16931 → local format, not the other way around.
License
Apache 2.0 — see LICENSE.
Project details
Release history Release notifications | RSS feed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file mcp_einvoicing_core-0.3.0.tar.gz.
File metadata
- Download URL: mcp_einvoicing_core-0.3.0.tar.gz
- Upload date:
- Size: 45.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
ec8e8c79a78e074ee0719cd8adc12bd317bd13b3b2628b24f863825ef0777b94
|
|
| MD5 |
24cbaeb4c4d91f9d06e95c63608cca34
|
|
| BLAKE2b-256 |
ed041fa81f616d2c7fb6bb9deaed4d86591abfcfba754ed44317ede7f85c589d
|
Provenance
The following attestation bundles were made for mcp_einvoicing_core-0.3.0.tar.gz:
Publisher:
publish.yml on cmendezs/mcp-einvoicing-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_einvoicing_core-0.3.0.tar.gz -
Subject digest:
ec8e8c79a78e074ee0719cd8adc12bd317bd13b3b2628b24f863825ef0777b94 - Sigstore transparency entry: 1439215330
- Sigstore integration time:
-
Permalink:
cmendezs/mcp-einvoicing-core@6a388b8f527db63ffae6c21917eda9f0054facef -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/cmendezs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@6a388b8f527db63ffae6c21917eda9f0054facef -
Trigger Event:
push
-
Statement type:
File details
Details for the file mcp_einvoicing_core-0.3.0-py3-none-any.whl.
File metadata
- Download URL: mcp_einvoicing_core-0.3.0-py3-none-any.whl
- Upload date:
- Size: 52.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
44e5b818cc090282d57af1866d9d075cf3db4d05739d92a92ff337162a498669
|
|
| MD5 |
532a222ac1ec345289f71bf88f5c28d9
|
|
| BLAKE2b-256 |
f94df2bb871cf39e92ed4ba088bcd521c06ca392bee14879a59fc38b245d3819
|
Provenance
The following attestation bundles were made for mcp_einvoicing_core-0.3.0-py3-none-any.whl:
Publisher:
publish.yml on cmendezs/mcp-einvoicing-core
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_einvoicing_core-0.3.0-py3-none-any.whl -
Subject digest:
44e5b818cc090282d57af1866d9d075cf3db4d05739d92a92ff337162a498669 - Sigstore transparency entry: 1439215336
- Sigstore integration time:
-
Permalink:
cmendezs/mcp-einvoicing-core@6a388b8f527db63ffae6c21917eda9f0054facef -
Branch / Tag:
refs/tags/v0.3.0 - Owner: https://github.com/cmendezs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@6a388b8f527db63ffae6c21917eda9f0054facef -
Trigger Event:
push
-
Statement type: