A command-line tool for interacting with KSeF 2.0 (Krajowy System e-Faktur), Poland's national electronic invoicing platform
Project description
Opis
Jest to "command line" rozszerzenie rozwiązania: https://github.com/stanislawbartkowski/ksef_pyth. Umożliwia komunikację z systemem KSeF z poprzez wywołanie python3. Daje to możliwość integracji z systemami, które nie są oparte w Python.
Dodatkowe cechy rozwiązania:
- Konfiguracje metody autentykacji: token lub certyfikat na podstawie pliku konfiguracyjnego
- Tworzenie dziennika i logów, historii wykonywanych operacji.
- Możliwość wywołania funkcjonalności z poziomu bash lub bezpośrednio jako komenda python3
Python
Testowane dla wersji: 3.10, 3.11 i 3.12
Testowane w testowym środowisku KSeF 2.0. Jest także wykorzystywane w produkcyjnym środowisku.
Konfiguracja
Zmienne środowiskowe
- KSEFCONF - plik zawierający listę dopuszczalnych NIPów oraz tokenów związanych z NIPami. Zawiera także definicje obsługiwanego środowiska KSeF 2.0 - deweloperskie/testowe, przedprodukcyjne oraz produkcyjne.
- KSEFDIR - katalog na logi operacji
Instalacja
pip install git+https://github.com/stanislawbartkowski/ksef_cli.git
lub
pip install ksef2.0-cli
python
import ksef_cli
Konfiguracja NIP oraz metody autentykacji
Plik jest wskazywany przez zmienną środowiskową KSEFCONF. Jest to plik w formacie YAML.
tokens:
NIP{nip}:
token: {token dla NIP}
env: prod|demo|test (produkcyjne, demo, testowe)
Token
Przykład:
NIP - 7497725064
Wartość tokena dostępowego dla NIP
Środowisko testowe
NIP7497725064:
token: 20251116-EC-0317C65000-2CA83C40D9-73|nip-7497725064|80be6cfced7f44eb860aeeb644e8cffdd59bbad9e218415296db90a39e6e5370
env: test
Certyfikat
Przykład:
NIP - 7497725064
Środowisko testowe
Plik p12 z certyfikatami: keyStore.p12
Hasło odczytu: 1234
NIP7497725064:
env: test
password: "1234"
p12: keyStore.p12
Dodatkowa informacja dotycząca certyfikatów.
Testy były przeprowadzane tylko dla tylko dla testowych certyfikatów generowanych poprzez testowe środowisko KSeF 2.0
Parametr p12 wskazuje na plik w formacie P12 zawierający wygenerowany klucz i certyfikat.
Przykładowa komenda tworząca plik P12. Pliki CertyfikatKSEF zawierają pliki utworzone przez KSeF 2.0
openssl pkcs12 -export -out keyStore.p12 -inkey CertyfikatKSEF.key -in CertyfikatKSEF.crt
NIP
NIP przekazywany jako parametr do wszystkich wywołań może przybierać dwie postacie:
- NIP
- NIP$podkatalog
W drugim przypadku po symbolu NIP są dodane separator $ oraz nazwa podkatalogu. Podkatalog ma znaczenie dla tworzenia struktury logów oraz miejsca składowania faktur/UPO. Bez podkatalogu miejscem jest zawsze symbol NIP. Z podkatalogiem do NIP jest dodawany podkatalog. Ten sam symbol NIP może być wywoływany z różnymi podkatalogami. Przykład:
- 7497725064, miejscem składowania jest NIP 7497725064
- 7497725064$ROK2025, miejscem składowania jest 7497725064/ROK2025
Struktura kodu w Python
- ksef_cli
- ksef_cli.py Dostępna funkcjonalność
- ksef_conf.py Wykorzystywany wewnętrznie, konfiguracja
- ksef_log.py Wykorzystywany wewnętrznie, tworzenie dziennika
- ksef_tokens.py Wykorzystywany wewnętrznie, tokeny i środowiska
- tests Unit test suite
Struktura katalogu z logami i dziennikiem
Katalog jest wskazywany przez zmienną środowiskową KSEFDIR. Dane są logowane na poziomie wspólnym i na poziomie NIP. Dodatkowo każda wysłana faktura tworzy podkatalog z numerem KSeF nadanym po wysłaniu, gdzie zawarty jest odczytany plik UPO oraz wysłana faktura. Zapamietywane są tylko faktury zaakceptowane w KSeF 2.0 i mające nadany numer KSeF.
- KSEFDIR
- events.csv Plik w formacie tekstowym CSV z historią operacji. Pamiętane są operacje zakończone sukcesem oraz operacje, które nie zostały wykonane z opisem błędu.
- ksef.log Zawiera dane logging z wykonywania
- {nip}
- events.csv Plik w formacie tekstowym CSV z historią operacji. Zawiera te same dane co plik event.csv w katalogu KSEFDIR, ale tylko dla danego NIP
- ksef.log Zawiera dane logging z wykonywania, Zawiera te same dane co plik ksef.log w katalog KSEFDIR, ale tylko dla operacji związanych z danym NIP
- {ksef_number} Dla każdej wysłanej i zaakceptowanej faktury z danego NIP
- upo.xml Plik UPO
- faktura.xml Wysłana faktura
Przykładowy fragment pliku events.csv
2025-12-16T20:49:42.166316,2025-12-16T20:49:42.917164,0.75,1,Czytanie faktur zakupowych,FAIL,KSEFCLI._czytaj_faktury_zakupe_action() got an unexpected keyword argument 'run_func',7497725064,
2025-12-16T20:50:30.552768,2025-12-16T20:50:31.310412,0.76,1,Czytanie faktur zakupowych,FAIL,KSEFCLI._czytaj_faktury_zakupe_action() got an unexpected keyword argument 'run_func',7497725064,
2025-12-16T20:53:06.316936,2025-12-16T20:53:07.139957,0.82,1,Czytanie faktur zakupowych,FAIL,KSEFCLI._czytaj_faktury_zakupe_action() missing 1 required positional argument: 'K',7497725064,
2025-12-16T20:54:07.355882,2025-12-16T20:54:08.150260,0.79,1,Czytanie faktur zakupowych,FAIL,KSEFCLI._czytaj_faktury_zakupe_action() missing 1 required positional argument: 'K',7497725064,
2025-12-16T20:54:08.754346,2025-12-16T20:54:09.493529,0.74,1,Czytanie faktur zakupowych,FAIL,KSEFCLI._czytaj_faktury_zakupe_action() missing 1 required positional argument: 'K',7497725064,
2025-12-16T20:54:54.710717,2025-12-16T20:54:55.807550,1.10,1,Czytanie faktur zakupowych,OK,,7497725064,2025-12-11 - 2025-12-18
2025-12-16T20:54:55.809410,2025-12-16T20:54:56.915264,1.11,4,Weź fakturę z KSeF,OK,,7497725064,
2025-12-16T20:58:32.052180,2025-12-16T20:58:35.711541,3.66,2,Wyślij fakture do KSeF,FAIL,Nieprawidłowy zakres uprawnień Kontekst 7497725064 nie jest uprawniony do wystawienia faktury w imieniu sprzedawcy (NIP: 7952809480),7497725064,
2025-12-16T20:58:36.123971,2025-12-16T20:58:38.096498,1.97,1,Czytanie faktur zakupowych,OK,,7497725064,2025-12-11 - 2025-12-18
Przyrostowe odczytywanie faktur zakupowych
Dostępne są trzy dodatkowe funkcjonalności, bardziej szczegółowy opis w sekcji Operacje
- daj_zakupowe_bufor Odczytuje listę metadanych aktualnie zapisanych z buforze
- uaktualnij_zakupowe_bufor Uaktualnia bufor o faktury,które się pojawiły od poprzedniej aktualizacji
- wez_faktura_bufor Ścieżka dostęu do faktury zakupowej XML w buforze
Faktury zakupowe są zapisywane w katalogu {KSEFDIR}-zakupowe - ścieżka wskazywana przez zmienną KSEFDIR z dodanym przyrostkiem -zakupowe.
Każda faktura zakupowa jest trzymana w osobnym katalogu z zawierającym dwa pliki:
- {KSEF-DIR}-zakupowe
- /numer nip/
- /numer ksef/
- faktura.xml Faktura KSeF jako XML
- metadane.json Dane z opisem faktury w formacie JSON
- /numer ksef/
- /numer nip/
Operacje
Wywołanie:
python -m ksef_cli <nip> <plik_na_wynik> <dodatkowe_parametry>
akcja, dopuszczalne wartości:
- wyslij_fakture Wysłanie faktury do system KSeF 2.0
- odczytaj_upo Odczytaj plik UPO do wysłanej i zaakceptowanej faktury
- pobierz_zakupowe Odczytaj nagłówki (metadata) faktur zakupowych
- odczytaj_fakture Odczytaj fakturę na podstawie nadanego numeru KSeF
- wyslij_wsadowo Wysyła paczkę faktur w sesji wsadowej
nip:
- Numer NIP użytkownika KSeF 2.0. Numer NIP musi być zawarty w pliku KSEFCONF. Z pliku konfiguracyjnego jest odczytywany odpowiedni token służący do autentykacji.
plik_na_wynik:
- Nazwa pliku, gdzie będzie zapisany wynik akcji. Wynik jest zapisany w formacie JSON.
Plik zawiera zawsze dwa pola oraz dodatkowe pola zależne od akcji
- OK: true/false Akcja zakończona sukcesem lub niepowodzeniem
- errmess: Jeśli akcja zakończona niepowodzeniem, to informacja o błędzie
Działanie:
- Odczytuje NIP oraz wyszukuje metodę autentykacji (token lub certyfikat) w pliku KSEFCONF
- Autentykacja z użyciem NIP oraz poprzez token lub certyfikat
- Wykonuje akcję na podstawie podanych paeametrów
- Uzupełnia dziennik oraz logging w katalogu KSEFDIR
- Zapisuje plik plik_na_wynik w formacie JSON z wynikiem akcji
Dodatkowa uwaga:
Wywołanie nie zwraca znaczącego exit code. Wynik akcji, także niepowodzenie, trzeba odczytać z pliku plik_na_wynik
wyslij_fakture
python -m ksef_cli wyslij_fakture <nip> <plik_na_wynik> <plik XML z fakturą do wysłania>
Zwracana wartość w pliku plik_na_wynik
- OK
- errmess
- numer_ksef Jeśli faktura jest zaakceptowana w systemie KSeF 2.0, to nadany przez KSeF 2.0 numer
wyslij_wsadowo
python -m ksef_cli wyslij_wsadowo <nip> <plik_na_wynik> <katalog z paczką faktur>
- <katalog z paczką faktur>. Katalog w którym znajdują się faktury XML gotowe do wysłania do systemu KSeF. Wysyłane są tylko pliki z rozszerzeniem .xml, inne pliki są ignorowane. UWAGA: w środowisku testowym akceptowanych jest tylko pierwsze 10 faktur, pozostałe są ignorowane bez sygnalizowania żadnego błędu.
Działanie:
- Faktury z katalogu są pakowane w formacie ZIP i wysyłane do systemu KSeF zgodnie ze specyfikacją API. Jeśli rozmiar po spakowaniu przekracza 100MB, to dane są odpowiednio dzielone na poszczególne paczki.
Zwracana wartość w pliku plik_na_wynik
- OK
- errmess
- invoices Lista wysłanych faktur z nadanym numerem KSeF. Jeden element listy zawiera następujące informacje:
- ok True/False True jeśli faktura została zaakceptowana w KSeF 2.0 i ma nadany numer KSeF
- msg Jeśli ok=False, to komunikat o błędzie
- ordinalNumber Numer kolejny faktury w paczce faktur (od 1)
- invoiceNumber Numer faktury pobrany ze źródłowego pliku XML
- ksefNumber Jeśli faktura jest zaakceptowana, to nadany numer KSeF
odczytaj_upo
python -m ksef_cli odczytaj_upo <nip> <plik_na_wynik> <numer_ksef>
Zwracana wartość w pliku plik_na_wynik
- OK
- errmess
- upo Nazwa pliku zawierającego UPO w formacie XML
UWAGA: UPO jest odczytywane bezpośrednio po wysłaniu faktury wyslij_fakture i zapamiętane w katalogu KSEFDIR/nip/numer_ksef. Wywołanie odczytaj_upo zwraca link do tego pliku, nie jest uruchamiana komunikacja z KSeF.
odczytaj_fakture
python -m ksef_cli odczytaj_fakture <nip> <plik_na_wynik> <numer_ksef>
Zwracana wartość w pliku plik_na_wynik
- OK
- errmess
- invoice Nazwa plik z odczytaną fakturą w formacie XML
pobierz_zakupowe
python -m ksef_cli pobierz_zakupowe <nip> <plik_na_wynik> <data_od> <data_do>
Odczytuje faktury zakupowe w przedziale dat. Daty muszą być w formacie YYYY-MM-DD
Zwracana wartość w pliku plik_na_wynik
- OK
- errmess
- faktury Lista zawierająca odczytane nagłówki faktur zakupowych z podanego zakresu dat.
pobierz_sprzedazowe
python -m ksef_cli pobierz_sprzedazowe <nip> <plik_na_wynik> <data_od> <data_do>
Odczytuje faktury sprzedażowe w przedziale dat. Daty muszą być w formacie YYYY-MM-DD
Zwracana wartość w pliku plik_na_wynik
- OK
- errmess
- faktury Lista zawierająca odczytane nagłówki faktur sprzedażowych z podanego zakresu dat.
pobierz_zbiorczo
python -m ksef_cli pobierz_zbiorczo <nip> <plik_na_wynik> <data_od> <data_do> <subject>
Zwraca w plik_na_wynik
- OK: true/false
- errmess
- katalog: Katalog tymczasowy, gdzie znajdują się odczytane faktury lub None, jeśli nic nie odczytano. Jeśli odczytano faktury, to w katalogu pojawi się także plik _metadata.json zawierający zbiorczą informację o odczytanych fakturach.
- liczba_faktur: Liczba odczytanych faktur. Liczba może być 0, wówczas katalog jest None
- subject:
- Subject1 Podmiot 1 - sprzedawca
- Subject2 Podmiot 2 - nabywca
- Subject3 Podmiot 3
- SubjectAuthorized Podmiot upoważniony
daj_konfiguracje
Pozwala sprawdzić, czy NIP jest skonfigurowany do komunikacji z systemem KSeF 2.0
python -m ksef_cli daj_konfiguracje <nip> <plik_na_wynik>
Zwraca w plik_na_wynik
- OK: true/false
- errmess
- mess, Dodatkowy komunikat
- auth, Dwa wartości, token lub certyfikat
- env, Środowisko: prod, demo lub test. Wartość z pliku kseftoken
- files:
- ksef_conf, wartość zmiennej konfiguracyjnej KSEFCONF
- work_dir, ścieżka katalogu z danymi dla NIP. Jest to podkatalog WORKDIR dla danego NIP
- log_file, ścieżka do pliku z logami tworzonymi w trakcie wykonywania operacji
- events_file, ścieżka do pliku z dziennikiem operacji dla danego NIP
daj_zakupowe_bufor
Odczytuje aktualną zawartość bufora faktur zakupowych z katalogu {KSEFDIR}-zakupowe. Odczytywane są pliki metadata.json dla każdej faktury, nie jest tutaj nawiązywana komunikacja z systemem KSeF 2.0
python -m ksef_cli daj_zakupowe_bufor <nip> <plik_na_wynik>
Zwraca w plik_na_wynik
- OK: true/false
- errmess
- invoices Lista metadada.json faktur zakupowych znajdujących się w buforze. UWAGA: zwracane są metadata.json. Fakturę w postaci XML należy odczytać za pomocą wywołania wez_faktura_bufor
- ostatnia_data Data (timestamp) najpóźniejszej faktury znajdującej sie w buforze
uaktualnij_zakupowe_bufor
Aktualizuje bufor faktur zakupowych o nowe faktury. Możliwe są dwa przypadki:
- Bufor jest pusty. Odczytywane są faktury z zakresu 2 miesiące wstecz do daty dzisiejszej
- Bufor zawiera faktury. Odczytywane są faktury z KSeF od najpóźniejszej daty faktury z bufora do daty dzisiejszej. Dodawane są tylko nowe faktury, jeśli w odczytane faktury z KSeF nakładają się na istniejące w buforze, to takie faktury są pomijane.
python -m ksef_cli uaktualnij_zakupowe_bufor <nip> <plik_na_wynik>
Zwraca w plik_na_wynik
- OK: true/false
- errmess
- liczba_faktur Liczba nowo znalezionych faktur. Liczba może być równa 0, jeśi nic sie nie zmieniło od ostatniej aktualizacji
wez_faktura_bufor
Zwraca ścieżkę dostępu do pliku XML z fakturą KSeF
python -m ksef_cli wez_faktura_bufor <nip> <plik_na_wynik>
Zwraca w plik_na_wynik
- OK: true/false
- errmess
- faktura_path Ścieżka dostępu do pliku XML z zawartością faktury zakupowej KSeF w buforze.
Przykładowe wywołanie
export KSEFCONF=/ścieżka/
export KSEFDIR=/ścieżka/
python -m ksef_cli /parametry/
Dev environment, happy coding
source .venv/bin/activate
git clone https://github.com/stanislawbartkowski/ksef_cli.git
pip install -r requirements.txt
code .
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 ksef2_0_cli-1.1.5.post3.tar.gz.
File metadata
- Download URL: ksef2_0_cli-1.1.5.post3.tar.gz
- Upload date:
- Size: 21.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
85cc9ce52e673f37b53dcf9c867d42271e8d74ad8e8d2f3d8621e041cd77397f
|
|
| MD5 |
15f8d71f1a36f72f9d1f8068bd773520
|
|
| BLAKE2b-256 |
3fbbd67597654cf3f57f1e11b13ccfd902ae8e61491c99fc512224c8baad971d
|
Provenance
The following attestation bundles were made for ksef2_0_cli-1.1.5.post3.tar.gz:
Publisher:
publish.yml on stanislawbartkowski/ksef_cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ksef2_0_cli-1.1.5.post3.tar.gz -
Subject digest:
85cc9ce52e673f37b53dcf9c867d42271e8d74ad8e8d2f3d8621e041cd77397f - Sigstore transparency entry: 1397986764
- Sigstore integration time:
-
Permalink:
stanislawbartkowski/ksef_cli@5d0f2df0206f68dcbaf905093a53f9233d139799 -
Branch / Tag:
refs/tags/v1.1.5r3 - Owner: https://github.com/stanislawbartkowski
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@5d0f2df0206f68dcbaf905093a53f9233d139799 -
Trigger Event:
push
-
Statement type:
File details
Details for the file ksef2_0_cli-1.1.5.post3-py3-none-any.whl.
File metadata
- Download URL: ksef2_0_cli-1.1.5.post3-py3-none-any.whl
- Upload date:
- Size: 19.4 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 |
8771a77638abb1a97dc231f8e4166b38ca09f19ad93cdd240394561f2e44f6b3
|
|
| MD5 |
d33e4e04c3ae667fca8dacf0867fc122
|
|
| BLAKE2b-256 |
7fa38a101db093a787e608aafdd5a9f6b6dd640a24e5a03b161ddc6b8a5d5d31
|
Provenance
The following attestation bundles were made for ksef2_0_cli-1.1.5.post3-py3-none-any.whl:
Publisher:
publish.yml on stanislawbartkowski/ksef_cli
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ksef2_0_cli-1.1.5.post3-py3-none-any.whl -
Subject digest:
8771a77638abb1a97dc231f8e4166b38ca09f19ad93cdd240394561f2e44f6b3 - Sigstore transparency entry: 1397986775
- Sigstore integration time:
-
Permalink:
stanislawbartkowski/ksef_cli@5d0f2df0206f68dcbaf905093a53f9233d139799 -
Branch / Tag:
refs/tags/v1.1.5r3 - Owner: https://github.com/stanislawbartkowski
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@5d0f2df0206f68dcbaf905093a53f9233d139799 -
Trigger Event:
push
-
Statement type: