A Client for an atlas-engine.io hosted workflow engine.
Project description
AtlasEngine mittels Python verwenden
Wenn es darum geht mit Python Prozess zu starten bzw. zu kontrollieren, External Task zu verarbeiten
und Benutzer-Tasks auszuführen, dann ist der AtlasEngine
-Client richtig. In dieser README
wird die Verwendung der unterschiedliche Aspekte anhand von Beispielen gezeigt:
- Vorbereitung der Umgebung
- Prozess starten
- External Task verarbeiten
- TODO: User Task bearbeiten
- TODO: Event aus der Prozessengine verarbeiten
- TODO: Verweis auf API-Dokumentation hinzufügen
Die Erweiterung der Client wird dagegen in CONTRIBUTION.MD erklärt.
Vorbereitung der Umgebung
Installation des BPMN-Studio
Die einfachster Version mit der Interaktion von Python und der Engine zu starten, ist die Installation des BPMN-Studio, da es die Entwicklung von BPMN-Prozess unterstützt und eine vorbereitete Engine mitbringt, die für die ersten Schritte ausreichend ist.
Prozess erstellen bzw. Beispiel verwenden
Um den ersten Prozess nicht erstellen zu müssen, ist der Prozess Hello World vorhanden, dieser muss in das BPMN-Studio geladen werden.
Prozess auf die Engine veröffentlichen
Um den Prozess verwenden zu können, ist es notwendig, dass dieser auf doe Engine veröffentlicht worden ist. Dazu ist es notwendig, den Prozess zu öffenen (1) und anschließend auf die Engine zu veröffentlichen (2).
Nachdem der Prozess veröffenticht würde, kann er mittels Python gestartet werden.
Prozess starten
Um einen Prozess zu startet ist die Prozess-Id (hier: hello_world
) und die URL (hier: http://localhost:56000
) unter der die Engine zu erreichen ist, notwendig. Nachdem die Informationen bekannt sind, kann der Prozess mit dem entsprechenden angepassten Script mit Hilfe von Python gestartet werden.
Beispiel mit nicht blockierendem Client
import logging
from atlas_engine_client.process_model import ProcessModelClient
logger = logging.getLogger(__name__)
def main(engine_url):
client = ProcessModelClient(engine_url)
result = client.start_process_instance('hello_world')
logger.info(f"Started process instance with result {result}")
if __name__ == '__main__':
engine_url = 'http://localhost:56000'
format_template = '%(asctime)s - %(name)s - %(levelname)s - %(message)s'
level = logging.DEBUG
logging.basicConfig(level=level, format=format_template)
main(engine_url)
Beispiel mit blockierendem Client
import logging
from atlas_engine_client.process_model import ProcessModelClient, StartCallbackType
logger = logging.getLogger(__name__)
def main(engine_url):
client = ProcessModelClient(engine_url)
result = client.start_process_instance('hello_world',
'the_start_event',
'the_end_event',
start_callback=StartCallbackType.ON_ENDEVENT_REACHED
)
logger.info(f"Started process instance with result {result}")
if __name__ == '__main__':
engine_url = 'http://localhost:56000'
format_template = '%(asctime)s - %(name)s - %(levelname)s - %(message)s'
level = logging.DEBUG
logging.basicConfig(level=level, format=format_template)
main(engine_url)
External Task verarbeiten
Im Beispiel-Prozess ist bereit eine ServiceTask als External Task konfiguriert.
Für die Verwendung des External Task muss ein Topic (hier: SampleExternalTask
) festgelegt werden und die URL der Engine (hier: http://localhost:56000
) bekannt sein.
Nachdem die Informationen bekannt sind, kann der External Task mit dem angepassten Script abgearbeitet werden.
Optionen für das Abonnieren von Aufträgen:
- max_tasks: Anzahl der Aufträge (task), die gleichzeitig verarbeitet werden sollen
- long_polling_timeout: Timeout für das Abonnieren
- lock_duration: Wir lange soll der Auftrag reseviert werden, bis er für weitere Worker zur Verfügung steht
- additional_lock_duration: Wir lange soll eine Auftragsreservierung verlängert werden.
- extend_lock_timeout: ...
Beispiel mit einem Parameter für den Handler _handler
import logging
from atlas_engine_client.external_task import ExternalTaskClient
logger = logging.getLogger(__name__)
def _handler(payload):
logger.debug("so some work")
logger.debug(payload)
logger.debug("some worker done.")
return {'some': 'result'}
def main(engine_url):
client = ExternalTaskClient(engine_url)
client.subscribe_to_external_task_for_topic("SampleExternalTask", _handler, max_tasks=5)
client.start()
if __name__ == '__main__':
engine_url = 'http://localhost:56000'
format_template = '%(asctime)s - %(name)s - %(levelname)s - %(message)s'
level = logging.INFO #logging.DEBUG
logging.basicConfig(level=level, format=format_template)
main(engine_url)
Beispiel mit einem weiteren Parameter für den Handler _handler
import logging
from atlas_engine_client.external_task import ExternalTaskClient
logger = logging.getLogger(__name__)
def _handler(payload, task):
logger.debug("so some work")
logger.info(f"payload: {payload} for task {task}")
logger.debug("some worker done.")
return {'some': 'result'}
def main(engine_url):
client = ExternalTaskClient(engine_url)
client.subscribe_to_external_task_for_topic("SampleExternalTask", _handler)
client.start()
if __name__ == '__main__':
engine_url = 'http://localhost:56000'
format_template = '%(asctime)s - %(name)s - %(levelname)s - %(message)s'
level = logging.INFO #logging.DEBUG
logging.basicConfig(level=level, format=format_template)
main(engine_url)
Mitmachen
Deployment auf pypi
Abhängigkeiten installieren
python -m pip install twine
Quellenpaket erstellen
python setup.py sdist
Upload zu pypi
twine upload dist/*
Die Anmeldedaten für den Upload zu pypi stehen in 1Password im Tresor processengine.
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
File details
Details for the file atlas_engine_client-1.1.0a3.tar.gz
.
File metadata
- Download URL: atlas_engine_client-1.1.0a3.tar.gz
- Upload date:
- Size: 16.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.54.0 CPython/3.9.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 59aaa62126e885d626378fcedd34341ca8a7f7c5faed681527c1fe515f2d5994 |
|
MD5 | e33f255dddb277d759827760912c9137 |
|
BLAKE2b-256 | 7b59f1f642fa3626035e133dedc935310e20b611d37dcb5fd224f3a86deb7b23 |
File details
Details for the file atlas_engine_client-1.1.0a3-py3-none-any.whl
.
File metadata
- Download URL: atlas_engine_client-1.1.0a3-py3-none-any.whl
- Upload date:
- Size: 22.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.6.1 requests/2.25.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.54.0 CPython/3.9.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 98a70d679300b867ba430fac35aa11e4f79d431565b509ad0c2981f1d394f215 |
|
MD5 | 5b4181242d454f0073bce60e148f1dba |
|
BLAKE2b-256 | f1f28c82bfbbd31a6a028299006d84499039860f878416cd5464077d0c325b94 |