NOT PRODUCTION READY
A python library for Polish KSEF (National e-invoice system, original: Krajowy System e-Faktur) system.
The official KSEF API documentation can be found at https://github.com/CIRFMF/ksef-docs/tree/main.
IMPORTANT Currently the project is not even in alpha stage, I barely started working on it. Initially it will support my personal needs only, but I plan to gradually implement new and more complex features.
To add and install this package as a dependency of your project, run uv add ksef (or pip install ksef).
The library supports two authentication methods for KSEF API v2:
A KSeF token can be generated via the KSeF web portal or obtained through the API after XAdES authentication.
from ksef.auth.token import TokenAuthorization
from ksef.client import Client
from ksef.constants import Environment
auth = TokenAuthorization(
token="your-ksef-token",
environment=Environment.TEST,
)
tokens = auth.authorize(nip="1234567890")
client = Client(authorization=auth, environment=Environment.TEST)Requires a qualified certificate from a trusted CA, or a KSeF-issued certificate. Provide PEM-encoded certificate and private key bytes.
from pathlib import Path
from ksef.auth.xades import XadesAuthorization
from ksef.client import Client
from ksef.constants import Environment
auth = XadesAuthorization(
signing_cert=Path("cert.pem").read_bytes(),
private_key=Path("key.pem").read_bytes(),
environment=Environment.TEST,
)
tokens = auth.authorize(nip="1234567890")
client = Client(authorization=auth, environment=Environment.TEST)Environment.PRODUCTION—https://api.ksef.mf.gov.pl/api/v2/Environment.DEMO—https://api-demo.ksef.mf.gov.pl/api/v2/Environment.TEST—https://api-test.ksef.mf.gov.pl/api/v2/
Integration tests connect to the live KSEF test environment using real credentials. They are excluded from the default test run and must be invoked explicitly:
source .env
uv run pytest -m integrationCredentials are provided via environment variables. Tests with missing variables are skipped automatically. See tests/integration/README.md for the full list of variables and per-method usage.
Prerequisites
1. Set up Git to use SSH
- Generate an SSH key and add the SSH key to your GitHub account.
- Configure SSH to automatically load your SSH keys:
cat << EOF >> ~/.ssh/config Host * AddKeysToAgent yes IgnoreUnknown UseKeychain UseKeychain yes EOF
2. Install Docker
- Install Docker Desktop.
- Enable Use Docker Compose V2 in Docker Desktop's preferences window.
- Linux only:
- Configure Docker to use the BuildKit build system. On macOS and Windows, BuildKit is enabled by default in Docker Desktop.
- Export your user's user id and group id so that files created in the Dev Container are owned by your user:
cat << EOF >> ~/.bashrc export UID=$(id --user) export GID=$(id --group) EOF
3. Install VS Code or PyCharm
- Install VS Code and VS Code's Dev Containers extension. Alternatively, install PyCharm.
- Optional: install a Nerd Font such as FiraCode Nerd Font and configure VS Code or configure PyCharm to use it.
Development environments
The following development environments are supported:
- ⭐️ GitHub Codespaces: click on Code and select Create codespace to start a Dev Container with GitHub Codespaces.
- ⭐️ Dev Container (with container volume): click on Open in Dev Containers to clone this repository in a container volume and create a Dev Container with VS Code.
- Dev Container: clone this repository, open it with VS Code, and run Ctrl/⌘ + ⇧ + P → Dev Containers: Reopen in Container.
- PyCharm: clone this repository, open it with PyCharm, and configure Docker Compose as a remote interpreter with the
devservice. - Terminal: clone this repository, open it with your terminal, and run
docker compose up --detach devto start a Dev Container in the background, and then rundocker compose exec dev zshto open a shell prompt in the Dev Container.
Developing
- This project follows the Conventional Commits standard to automate Semantic Versioning and Keep A Changelog with Commitizen.
- Run
poefrom within the development environment to print a list of Poe the Poet tasks available to run on this project. - Run
poetry add {package}from within the development environment to install a run time dependency and add it topyproject.tomlandpoetry.lock. Add--group testor--group devto install a CI or development dependency, respectively. - Run
poetry updatefrom within the development environment to upgrade all dependencies to the latest versions allowed bypyproject.toml. - Run
cz bumpto bump the package's version, update theCHANGELOG.md, and create a git tag.