Skip to main content

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:

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 laden

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).

Prozess veröffentlichen

Nachdem der Prozess veröffenticht würde, kann er mittels Python gestartet werden.

Prozess veröffentlicht

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

atlas_engine_client-1.0.0a5.tar.gz (15.9 kB view details)

Uploaded Source

Built Distribution

atlas_engine_client-1.0.0a5-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

Details for the file atlas_engine_client-1.0.0a5.tar.gz.

File metadata

  • Download URL: atlas_engine_client-1.0.0a5.tar.gz
  • Upload date:
  • Size: 15.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.0 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.9.0

File hashes

Hashes for atlas_engine_client-1.0.0a5.tar.gz
Algorithm Hash digest
SHA256 46371533a7ddf697297ffc0412cf43fadaf4755ccb7849fb0db03f39a3b1a47f
MD5 6500718ec8d49b18e27c9566573c2c92
BLAKE2b-256 905c692099ad235a413d16d318e4de7bf1c525c2320d74f4d1eeb2f930d4f56e

See more details on using hashes here.

File details

Details for the file atlas_engine_client-1.0.0a5-py3-none-any.whl.

File metadata

  • Download URL: atlas_engine_client-1.0.0a5-py3-none-any.whl
  • Upload date:
  • Size: 21.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.6.0 requests/2.24.0 setuptools/49.2.1 requests-toolbelt/0.9.1 tqdm/4.51.0 CPython/3.9.0

File hashes

Hashes for atlas_engine_client-1.0.0a5-py3-none-any.whl
Algorithm Hash digest
SHA256 8173b8e1a33249a7a4254eb9c83de94c2de3d315d4868b8af5b98ae8e9be3564
MD5 51ae727812996c163e225ebe679b566d
BLAKE2b-256 79949a61fa783ab5ecb6b84078b6af57e4f5fa9703616f155367699c21adea2f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page