mcp-fattura-elettronica-it
Model Context Protocol (MCP) server for Italian Electronic Invoicing (FatturaPA / SDI). Provide tools to validate, generate, and explore API specifications for Sistema di Interscambio (SDI) interoperability.
README
mcp-fattura-elettronica-it ๐ฎ๐น
<!-- mcp-name: io.github.cmendezs/mcp-fattura-elettronica-it -->
Server MCP Python per la fatturazione elettronica italiana in formato FatturaPA XML (standard SDI / Agenzia delle Entrate, versione 1.6.1). Permette agli agenti IA (Claude, IDE) di generare, validare e analizzare fatture elettroniche B2B, B2G e transfrontaliere direttamente conformi alle specifiche tecniche del Sistema di Interscambio (SDI).
English summary
This is a Model Context Protocol (MCP) server for Italian electronic invoicing. It exposes 21 tools covering the full lifecycle of a FatturaPA XML document: transmission header construction, seller/buyer validation, document type codes (TD01โTD28), line items, VAT summary computation, payment terms, XSD validation against the official Agenzia delle Entrate schema (v1.6.1), XML generation, parsing, JSON export, SDI filename generation, and withholding tax (ritenuta d'acconto) calculation. The server requires no external API calls โ all logic runs locally. Licensed under Apache 2.0.
๐ Installazione
Via PyPI (raccomandato)
pip install mcp-fattura-elettronica-it
mcp-einvoicing-core is installed automatically as a dependency.
lxml is also required and included โ no extra steps needed.
Senza installazione previa con uvx:
uvx mcp-fattura-elettronica-it
Dalle sorgenti
git clone https://github.com/cmendezs/mcp-fattura-elettronica-it.git
cd mcp-fattura-elettronica-it
python -m venv .venv
source .venv/bin/activate # Windows: .venv\Scripts\activate
pip install -e ".[dev]"
cp .env.example .env
โ๏ธ Configurazione
Il server non richiede credenziali esterne in v0.1.0. Le variabili d'ambiente disponibili sono:
| Variabile | Descrizione | Default |
|---|---|---|
LOG_LEVEL |
Livello di log (DEBUG, INFO, WARNING, ERROR) |
INFO |
FATTURA_XSD_PATH |
Percorso del file XSD FatturaPA | schemas/FatturaPA_v1.6.1.xsd |
๐ค Integrazione Claude Desktop
Aggiungere al file claude_desktop_config.json:
{
"mcpServers": {
"fattura-elettronica-it": {
"command": "uvx",
"args": ["mcp-fattura-elettronica-it"]
}
}
}
โจ๏ธ Integrazione Cursor
File di configurazione (~/.cursor/mcp.json oppure .cursor/mcp.json nella cartella del progetto):
{
"mcpServers": {
"fattura-elettronica-it": {
"command": "uvx",
"args": ["mcp-fattura-elettronica-it"]
}
}
}
๐ช Integrazione Kiro
{
"mcpServers": {
"fattura-elettronica-it": {
"command": "uvx",
"args": ["mcp-fattura-elettronica-it"],
"disabled": false,
"autoApprove": []
}
}
}
๐งฐ Strumenti MCP disponibili
Header โ FatturaElettronicaHeader (7 strumenti)
| Strumento | Descrizione |
|---|---|
build_transmission_header |
Build DatiTrasmissione block: ProgressivoInvio, CodiceDestinatario, PECDestinatario |
validate_cedente_prestatore |
Validate seller block: IdFiscaleIVA, Anagrafica, Sede, RegimeFiscale codes |
validate_cessionario |
Validate buyer block: IdFiscaleIVA or CodiceFiscale, Sede |
get_regime_fiscale_codes |
Return all valid RegimeFiscale codes with descriptions (RF01โRF19) |
validate_partita_iva |
Validate Italian VAT number (Partita IVA) format and checksum (11 digits) |
generate_progressivo_invio |
Generate a unique ProgressivoInvio identifier (max 10 alphanumeric chars) |
lookup_codice_destinatario |
Return info about a CodiceDestinatario (6-char SDI code) or PEC address |
Body โ FatturaElettronicaBody (7 strumenti)
| Strumento | Descrizione |
|---|---|
build_dati_generali |
Build DatiGenerali block: TipoDocumento, Divisa, Data, Numero, Causale |
get_tipo_documento_codes |
Return all TD01โTD28 codes with descriptions and use cases (incl. cross-border) |
add_linea_dettaglio |
Add a DettaglioLinee entry: NumeroLinea, Descrizione, Quantita, PrezzoUnitario |
compute_totali |
Compute DatiRiepilogo: imponibile, imposta, AliquotaIVA from line items |
get_natura_codes |
Return all Natura codes (N1โN7 and sub-codes) for VAT exemption with legal references |
build_dati_pagamento |
Build DatiPagamento: CondizioniPagamento (TP01/02/03), ModalitaPagamento (MP01โMP23) |
add_allegato |
Attach a base64-encoded document to the Allegati block with name and format |
Globali โ generazione e validazione (7 strumenti)
| Strumento | Descrizione |
|---|---|
generate_fattura_xml |
Generate a complete FatturaPA XML file from structured input data |
validate_fattura_xsd |
Validate a FatturaPA XML string against the official XSD schema v1.6.1 |
parse_fattura_xml |
Parse an existing FatturaPA XML string and return a structured JSON dict |
export_to_json |
Export a parsed FatturaPA structure to clean JSON format |
validate_partita_iva_format |
Validate Partita IVA format and Luhn-like checksum (11-digit Italian VAT) |
get_sdi_filename |
Generate the official SDI filename: IT{PartitaIVA}_{ProgressivoInvio}.xml |
check_ritenuta_acconto |
Check and compute ritenuta d'acconto (withholding tax) for professional invoices |
Esempi di utilizzo
Esempio 1 โ Generare una fattura B2B completa
1. validate_partita_iva_format("01234567897")
โ { "valid": true }
2. generate_progressivo_invio(sequence=1)
โ { "progressivo_invio": "00001" }
3. build_transmission_header(id_paese="IT", id_codice="01234567897",
progressivo_invio="00001", formato_trasmissione="FPR12",
codice_destinatario="ABC123")
4. validate_cedente_prestatore(id_paese="IT", id_codice="01234567897",
denominazione="ACME Srl", regime_fiscale="RF01",
indirizzo="Via Roma 1", cap="00100", comune="Roma", nazione="IT")
5. validate_cessionario(denominazione="Buyer Srl",
id_paese="IT", id_codice="98765432109",
indirizzo="Via Verdi 2", cap="20100", comune="Milano")
6. build_dati_generali(tipo_documento="TD01", data="2026-01-15",
numero="2026/001", divisa="EUR")
7. add_linea_dettaglio(numero_linea=1, descrizione="Consulenza informatica",
quantita=8, unita_misura="ORE", prezzo_unitario=100.0,
prezzo_totale=800.0, aliquota_iva=22.0)
8. compute_totali(linee=[{"prezzo_totale": 800.0, "aliquota_iva": 22.0}])
โ { "totale_fattura": "976.00" }
9. build_dati_pagamento(condizioni_pagamento="TP02", modalita_pagamento="MP05",
importo_pagamento=976.0, iban="IT60X0542811101000000123456")
10. generate_fattura_xml(...tutti i blocchi precedenti...)
โ { "xml": "<?xml ...", "filename": "IT01234567897_00001.xml" }
11. validate_fattura_xsd(xml_string=...)
โ { "valid": true }
Esempio 2 โ Fattura professionale con ritenuta d'acconto
check_ritenuta_acconto(imponibile=1000.0, tipo_ritenuta="RT02",
causale_pagamento="A")
โ {
"DatiRitenuta": {
"TipoRitenuta": "RT02",
"ImportoRitenuta": "200.00",
"AliquotaRitenuta": "20.00",
"CausalePagamento": "A"
},
"importo_ritenuta": "200.00"
}
Esempio 3 โ Consultare i codici di esenzione IVA
get_natura_codes()
โ codes: [
{ "code": "N3.1", "description": "Non imponibili โ esportazioni",
"legal_ref": "Art. 8 DPR 633/72" },
{ "code": "N6.1", "description": "Inversione contabile โ rottami",
"legal_ref": "Art. 74 c. 7-8 DPR 633/72" },
...
]
Architecture
mcp-fattura-elettronica-it (this package โ standalone MCP server)
โโโ ItalyPartyValidator(BasePartyValidator) โ Partita IVA modulo-10
โโโ FatturaGenerator(BaseDocumentGenerator) โ FatturaPA XML v1.6.1
โโโ FatturaValidator(BaseDocumentValidator) โ lxml XSD v1.6.1
โโโ FatturaParser(BaseDocumentParser) โ lxml xpath
โ extends
mcp-einvoicing-core (shared foundation, installed as dependency)
โโโ BaseDocumentGenerator / Validator / Parser / PartyValidator
โโโ InvoiceDocument, InvoiceParty, InvoiceLineItem โฆ (Pydantic)
โโโ xml_utils, logging_utils, exceptions
โโโ EInvoicingMCPServer (optional multi-country aggregator)
๐ Standard di riferimento
| Risorsa | Link |
|---|---|
| Specifiche FatturaPA | fatturapa.gov.it |
| XSD ufficiale v1.6.1 | Schema v1.2.2 โ Agenzia delle Entrate |
| Namespace XML | http://ivaservizi.agenziaentrate.gov.it/docs/xsd/fatture/v1.2 |
| SDI โ Sistema di Interscambio | Agenzia delle Entrate |
| Ritenuta d'acconto | Art. 25 DPR 600/73 โ Modello 770 |
๐งช Test
# Installare le dipendenze di sviluppo
pip install -e ".[dev]"
# Eseguire tutti i test
pytest tests/ -v
# Eseguire solo i test di integrazione MCP
pytest tests/test_mcp_integration.py -v
Roadmap
| Versione | Funzionalitร |
|---|---|
| v0.1.0 (attuale) | Generazione XML, validazione XSD, parsing, 21 strumenti MCP, ritenuta d'acconto |
| v0.2 | Firma digitale CAdES-BES e XAdES (smart card, HSM, P12) |
| v0.3 | Integrazione diretta SDI via SDICoop SOAP e SFTP โ invio e ricezione |
| v0.4 | Fattura Semplificata (TD07/TD08/TD09) โ importi โค 400 EUR |
| v0.5 | Conservazione a norma โ integrazione con provider accreditati AgID |
๐ Licenza
Questo progetto รจ distribuito sotto licenza Apache 2.0.
Vedere il file LICENSE per i dettagli completi.
Copyright 2026 cmendezs
Progetto mantenuto da cmendezs. Per domande relative all'implementazione dello standard FatturaPA, aprire una Issue.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.