Server data from the Official MCP Registry
Italian e-invoicing: FatturaPA XML/SDI v1.6.1, 21 MCP tools for B2B and B2G.
Italian e-invoicing: FatturaPA XML/SDI v1.6.1, 21 MCP tools for B2B and B2G.
Valid MCP server (1 strong, 2 medium validity signals). 5 known CVEs in dependencies (1 critical, 3 high severity) Package registry verified. Imported from the Official MCP Registry.
4 files analyzed ยท 6 issues found
Security scores are indicators to help you make informed decisions, not guarantees. Always review permissions before connecting any MCP server.
This plugin requests these system permissions. Most are normal for its category.
Add this to your MCP configuration file:
{
"mcpServers": {
"io-github-cmendezs-mcp-fattura-elettronica-it": {
"args": [
"mcp-fattura-elettronica-it"
],
"command": "uvx"
}
}
}From the project's GitHub README.
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).
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.
pip install mcp-fattura-elettronica-it
Senza installazione previa con uvx:
uvx mcp-fattura-elettronica-it
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
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 |
Aggiungere al file claude_desktop_config.json:
{
"mcpServers": {
"fattura-elettronica-it": {
"command": "uvx",
"args": ["mcp-fattura-elettronica-it"]
}
}
}
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"]
}
}
}
{
"mcpServers": {
"fattura-elettronica-it": {
"command": "uvx",
"args": ["mcp-fattura-elettronica-it"],
"disabled": false,
"autoApprove": []
}
}
}
| 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 |
| 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 |
| 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 |
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 }
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"
}
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" },
...
]
| 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 |
# 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
| 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 |
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.
Be the first to review this server!
by Modelcontextprotocol ยท Developer Tools
Web content fetching and conversion for efficient LLM usage
by Modelcontextprotocol ยท Developer Tools
Read, search, and manipulate Git repositories programmatically
by Toleno ยท Developer Tools
Toleno Network MCP Server โ Manage your Toleno mining account with Claude AI using natural language.
by mcp-marketplace ยท Developer Tools
Create, build, and publish Python MCP servers to PyPI โ conversationally.
by Microsoft ยท Content & Media
Convert files (PDF, Word, Excel, images, audio) to Markdown for LLM consumption
by mcp-marketplace ยท Developer Tools
Scaffold, build, and publish TypeScript MCP servers to npm โ conversationally