The XLeitstelle model-driven application schema app.
Project description
XMAS-App
The XLeistelle model-driven application schema app is a Python web application to edit and create data according to geo-spatial standards of the XLeistelle, e.g. XPlanung, XTrasse. It is based on NiceGUI for a graphical user interface and XPlan-Tools for the data model and respective functionality.
While it could be advanced to a standalone application, its current focus is integration in QGIS to provide attribute forms etc.
Features
- Render attribute forms for features.
- Create and edit features in combination with the corresponding QGIS Plugin.
- Import GML documents into a database.
- Export GML, JSON-FG or GPKG files from a databse.
- Delete plans from a database.
- Display and edit relations of plan objects in a tree view.
Installation
Container Image
Container images are available in the registry. See here for configuration.
Python >= v3.11
GDAL and its Python bindings are required, so you need to make sure the GDAL system library and Python package versions match. QGIS installations come with GDAL and a Python environment that can readily be used to install the app.
Install with pip, e.g. via OSGeo4W Shell:
pip install xmas-app
Pixi
This project uses Pixi for package management. To install this repo with a self-contained environment, run
git clone https://gitlab.opencode.de/xleitstelle/xmas-app.git
cd xmas-app
pixi install
Running
Preconditions
A Postgres DB with PostGIS extension and adequate permissions for the used role. If no database schema was previously created with xplan-tools, it will be generated on initialization.
For convenience, you can run
docker compose -f compose.yaml up -d
This will spin up a readily usable XMAS-App container with a PostGIS backend.
Modes
QGIS Plugin mode
If XPlan-GUI was installed in the QGIS Python environment, it can be started from the plugin panel. Configuration parameters are handled by the plugin.
Standalone mode
Starting in standalone mode requires some configuration parameters which have to be provided as an .env file or via environment variables.
The database connection parameters can be either user name, password etc. or a service definition.
| Variable | Description | Required | Example | |
|---|---|---|---|---|
| PGDATABASE | name of the database | (x) | coretable | |
| PGHOST | host of the database | (x) | localhost | |
| PGPORT | port of the database | (x) | 55432 | |
| PGUSER | user of the database | (x) | foo | |
| PGPASSWORD | password of the database user | (x) | bar | |
| PGSERVICE | the databas service to use | (x) | coretable | |
| APP_PORT | the port on which the app should run | x | 1337 | |
| APPSCHEMA | the default appschema | x | xplan | |
| APPSCHEMA_VERSION | the default appschema's version | x | 6.0 |
First activate the pixi shell
pixi shell
then run
xmas-app
Optional: batch import test data to the database using xplan-tools
Test data can be downloaded from https://gitlab.opencode.de/xleitstelle/xplanung/testdaten, e.g. a ZIP archive with BP_Plans in v 6.0.
To import all .gml files at once, extract the archive and use:
(on Linux/Mac/Wsl Bash):
for f in <pfad>/bp/*.gml; do
xplan-tools convert "$f" postgresql://postgres:postgres@localhost:5432/postgres
done
(on Windows:):
for %f in (*.gml) do xplan-tools convert "%f" postgresql://postgres:postgres@127.0.0.1:55432/postgres
License
The code in this repository is licensed under the EUPL-1.2-or-later
© XLeitstelle, 2025
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 xmas_app-0.10.0.tar.gz.
File metadata
- Download URL: xmas_app-0.10.0.tar.gz
- Upload date:
- Size: 56.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.13.9 Linux/5.4.0-205-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fc6921406ea4e5956ceca33724e70d4eb5e47cea9d3ba3b683602d2bf5c6da0c
|
|
| MD5 |
584df4364a7de97b45b460f1836e5fde
|
|
| BLAKE2b-256 |
be2844a40bea5f91b1c9b55229bdfbc787e6ddac5f26ce285afa1be1f5337846
|
File details
Details for the file xmas_app-0.10.0-py3-none-any.whl.
File metadata
- Download URL: xmas_app-0.10.0-py3-none-any.whl
- Upload date:
- Size: 59.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/2.2.1 CPython/3.13.9 Linux/5.4.0-205-generic
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9deeecec35edb36ffbb4bec9de8c401a6d533698bfe5e26cc49d3511f27b925a
|
|
| MD5 |
d8e77eb01f2be183550710e6371599ee
|
|
| BLAKE2b-256 |
79c8eef44b9a09fa0703a444c8b6a5b766cddaec3ce420fd3c4ceeff4a755028
|