MCP server for Polish electronic invoicing — KSeF (FA(2)) and Peppol/EN 16931
Project description
mcp-ksef-pl 🇵🇱
Serwer MCP w Pythonie udostępniający narzędzia do polskiej faktury elektronicznej zgodnej z KSeF (FA(2)) i Peppol BIS Billing 3.0 / EN 16931. Umożliwia agentom AI (Claude, IDE) generowanie, walidację i przesyłanie faktur do Krajowego Systemu e-Faktur (KSeF), a także weryfikację identyfikatorów podatkowych NIP i REGON.
English: This is a Model Context Protocol (MCP) server for Polish electronic invoicing. It implements the KSeF FA(2) national invoice format and the Peppol BIS Billing 3.0 / EN 16931 cross-border format, enabling AI agents to generate, validate, submit, and query invoices via the Krajowy System e-Faktur (KSeF) platform, and to validate Polish tax identifiers (NIP, REGON).
Built on
Ten pakiet jest zbudowany na bazie mcp-einvoicing-core — wspólnej biblioteki bazowej dla europejskich serwerów MCP do fakturowania elektronicznego. Dostarcza ona klienta HTTP OAuth2, pamięć podręczną tokenów, modele danych, narzędzia do logowania i hierarchię wyjątków.
mcp-einvoicing-core jest instalowane automatycznie jako zależność — nie jest wymagany dodatkowy krok.
🏗️ Architektura
Serwer pełni rolę inteligentnego interfejsu komunikacyjnego między agentem AI a platformą KSeF oraz siecią Peppol:
[ System ERP / Aplikacja ] <--> [ Serwer MCP ] <--> [ KSeF (MF) / Sieć Peppol ]
^ |
| v
[ Agent AI (Claude) ] <--- (FA(2) / EN 16931)
🛠️ Dostępne narzędzia
Obsługa faktur FA(2)
| Narzędzie | Opis |
|---|---|
generate_fa2_invoice |
Generuje fakturę XML FA(2) zgodną z KSeF na podstawie danych wejściowych |
validate_fa2_invoice |
Waliduje XML FA(2) — walidacja XSD (jeśli schemat dostępny) i reguły biznesowe |
parse_fa2_invoice |
Parsuje XML FA(2) do słownika strukturalnego |
Cykl życia w KSeF
| Narzędzie | Opis |
|---|---|
submit_invoice_to_ksef |
Przesyła fakturę FA(2) do platformy KSeF i zwraca numer referencyjny |
get_ksef_invoice_status |
Pobiera status przetwarzania faktury według numeru referencyjnego |
search_ksef_invoices |
Wyszukuje faktury w KSeF według zakresu dat i kierunku (sprzedawca/nabywca) |
Walidacja identyfikatorów
| Narzędzie | Opis |
|---|---|
validate_polish_nip |
Waliduje NIP (10-cyfrowy numer identyfikacji podatkowej) algorytmem sumy kontrolnej |
validate_polish_regon |
Waliduje REGON (9- lub 14-cyfrowy numer ewidencyjny) algorytmem sumy kontrolnej |
Peppol / EN 16931
| Narzędzie | Opis |
|---|---|
generate_peppol_invoice |
Generuje fakturę UBL 2.1 zgodną z Peppol BIS Billing 3.0 / EN 16931 |
🚀 Instalacja
Przez PyPI (zalecane)
pip install mcp-ksef-pl
Lub bez wcześniejszej instalacji z uvx:
uvx mcp-ksef-pl
Ze źródeł
git clone https://github.com/cmendezs/mcp-ksef-pl.git
cd mcp-ksef-pl
uv sync --all-extras
⚙️ Konfiguracja (zmienne środowiskowe)
| Zmienna | Domyślna | Opis |
|---|---|---|
KSEF_ENVIRONMENT |
test |
Środowisko KSeF: production, test lub demo |
KSEF_SESSION_TOKEN |
— | Token sesji KSeF (uzyskiwany przez przepływ challenge-response z MF) |
KSEF_NIP |
— | NIP podmiotu wysyłającego faktury |
KSEF_TIMEOUT |
30 |
Limit czasu żądań HTTP w sekundach |
🔐 Uwierzytelnianie w KSeF
KSeF wymaga podpisanego XML (challenge-response) do uzyskania tokenu sesji. Podpisanie
wymaga kwalifikowanego podpisu elektronicznego lub poświadczeń z portalu MF i nie może
być zautomatyzowane przez ten serwer MCP. Token sesji należy uzyskać poza serwerem
i przekazać przez KSEF_SESSION_TOKEN lub parametr session_token narzędzia
submit_invoice_to_ksef.
Dokumentacja techniczna KSeF: https://www.podatki.gov.pl/ksef/dokumentacja-techniczna-ksef/
🤖 Integracja z Claude Desktop
Dodaj poniższą konfigurację do pliku claude_desktop_config.json:
{
"mcpServers": {
"ksef-pl": {
"command": "uvx",
"args": ["mcp-ksef-pl"],
"env": {
"KSEF_ENVIRONMENT": "test",
"KSEF_SESSION_TOKEN": "<twój-token-sesji-ksef>",
"KSEF_NIP": "<twój-nip>"
}
}
}
}
⌨️ Integracja z Cursor
Cursor obsługuje serwery MCP przez stdio. Dodaj konfigurację do:
- Globalnie (wszystkie projekty):
~/.cursor/mcp.json - Projekt (tylko to repozytorium):
.cursor/mcp.json
{
"mcpServers": {
"ksef-pl": {
"command": "uvx",
"args": ["mcp-ksef-pl"],
"env": {
"KSEF_ENVIRONMENT": "test",
"KSEF_SESSION_TOKEN": "<twój-token-sesji-ksef>",
"KSEF_NIP": "<twój-nip>"
}
}
}
}
Przeładuj okno Cursor (Ctrl+Shift+P → Reload Window) po zapisaniu zmian.
🪐 Integracja z Kiro
Kiro obsługuje serwery MCP przez dedykowany plik konfiguracyjny:
- Globalnie:
~/.kiro/settings/mcp.json - Workspace:
.kiro/settings/mcp.json
{
"mcpServers": {
"ksef-pl": {
"command": "uvx",
"args": ["mcp-ksef-pl"],
"env": {
"KSEF_ENVIRONMENT": "test",
"KSEF_SESSION_TOKEN": "<twój-token-sesji-ksef>",
"KSEF_NIP": "<twój-nip>"
},
"disabled": false,
"autoApprove": []
}
}
}
Wskazówka bezpieczeństwa: zamiast wpisywać token wprost, użyj składni
"KSEF_SESSION_TOKEN": "${KSEF_SESSION_TOKEN}"— Kiro rozwiązuje zmienne środowiskowe powłoki przy uruchomieniu.
📋 Schemat XSD (FA_VAT_v1-0E.xsd)
Pełna walidacja XSD wymaga oficjalnego schematu Ministerstwa Finansów.
Bez niego validate_fa2_invoice wykonuje wyłącznie reguły biznesowe.
- Przejdź na stronę: https://www.podatki.gov.pl/ksef/dokumentacja-techniczna-ksef/
- Pobierz pakiet dokumentacji technicznej FA(2)
- Umieść plik
FA_VAT_v1-0E.xsdw katalogusrc/mcp_ksef_pl/schemas/
Plik jest wykluczony z repozytorium (.gitignore) — należy go pobrać ręcznie.
Pomocniczy skrypt: scripts/download_schemas.sh
🧪 Testy
# Uruchom testy jednostkowe
uv run pytest tests/ -v
Other e-invoicing MCP servers
| Country | Server |
|---|---|
| 🌍 Global | mcp-einvoicing-core |
| 🇧🇪 Belgium | mcp-einvoicing-be |
| 🇫🇷 France | mcp-facture-electronique-fr |
| 🇩🇪 Germany | mcp-einvoicing-de |
| 🇮🇹 Italy | mcp-fattura-elettronica-it |
| 🇵🇱 Poland | mcp-ksef-pl |
📄 Licencja
Ten projekt jest dystrybuowany na licencji Apache 2.0. Szczegóły w pliku LICENSE.
Projekt utrzymywany przez cmendezs. W przypadku pytań dotyczących implementacji KSeF lub Peppol otwórz Issue.
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_ksef_pl-0.1.0.tar.gz.
File metadata
- Download URL: mcp_ksef_pl-0.1.0.tar.gz
- Upload date:
- Size: 769.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
062dc57be248e22551ae9605f451cac75beba1e85543a5485489fa590ca6c6e5
|
|
| MD5 |
24a8b4c1c9ffa93e7b9cb3afd346dc42
|
|
| BLAKE2b-256 |
b30c471c604754702931e33b0940b7355797ec6210ea65ed1d2796d2ec0b5e88
|
Provenance
The following attestation bundles were made for mcp_ksef_pl-0.1.0.tar.gz:
Publisher:
publish.yml on cmendezs/mcp-ksef-pl
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_ksef_pl-0.1.0.tar.gz -
Subject digest:
062dc57be248e22551ae9605f451cac75beba1e85543a5485489fa590ca6c6e5 - Sigstore transparency entry: 1449617349
- Sigstore integration time:
-
Permalink:
cmendezs/mcp-ksef-pl@ec0a823189c7cc66a07c510d120e92b748258ddd -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/cmendezs
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ec0a823189c7cc66a07c510d120e92b748258ddd -
Trigger Event:
push
-
Statement type:
File details
Details for the file mcp_ksef_pl-0.1.0-py3-none-any.whl.
File metadata
- Download URL: mcp_ksef_pl-0.1.0-py3-none-any.whl
- Upload date:
- Size: 32.5 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 |
ac9ebd58033a443276f560e4e416d057cfed44d6eb90ee4681117f3879385a33
|
|
| MD5 |
b5a86edfcc34a5ed468619dac185a5cd
|
|
| BLAKE2b-256 |
9ba8910acb39c414db76205609a964d52c2c2d78d946e5def945b6ff583d1649
|
Provenance
The following attestation bundles were made for mcp_ksef_pl-0.1.0-py3-none-any.whl:
Publisher:
publish.yml on cmendezs/mcp-ksef-pl
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
mcp_ksef_pl-0.1.0-py3-none-any.whl -
Subject digest:
ac9ebd58033a443276f560e4e416d057cfed44d6eb90ee4681117f3879385a33 - Sigstore transparency entry: 1449617361
- Sigstore integration time:
-
Permalink:
cmendezs/mcp-ksef-pl@ec0a823189c7cc66a07c510d120e92b748258ddd -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/cmendezs
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@ec0a823189c7cc66a07c510d120e92b748258ddd -
Trigger Event:
push
-
Statement type: