4.3.5 • Published 8 months ago

@atlas-engine/atlas_engine_client v4.3.5

Weekly downloads
4,218
License
MIT
Repository
github
Last release
8 months ago

Engine Client.ts

Ein NodeJS basierter Client zur Kommunikation mit der ProcessCube Engine.

Codebeispiele zur Verwendung des Clients und der External Task Worker finden sich hier.

Schnelleinstieg

import { EngineClient } from '@5minds/processcube_engine_client';

const engineUri = 'http://localhost:10560';

const client = new EngineClient(engineUri);

const processInstancesInCorrelation = await client.processInstances.query({
  correlationid: 'my-correlation-id',
});

Wie kann ich den Client verwenden?

Man benötigt lediglich die URL der anzusteuernden Engine. Mit dieser lässt sich eine Instanz des Clients anlegen, die direkt verwendbar ist.

Es gibt verschiedene Wege sich Clients anzulegen.

EngineClient

Man kann eine Instanz des EngineClients direkt anlegen, welche die API der ProcessCube Engine vollständig abdeckt.

import { EngineClient } from '@5minds/processcube_engine_client';

const engineUri = 'http://localhost:10560';

const client = new EngineClient(engineUri);

const processInstancesInCorrelation = await client.processInstances.query({
  correlationid: 'my-correlation-id',
});

Client Factory

Oder man kann sich über die Client Factory einen feature-spezifischen Client anlegen, der nur einen besimmten fachlichen Aspekt der ProcessCube Engine abdeckt.

Beispiel:

import { ClientFactory } from '@5minds/processcube_engine_client';

const engineUri = 'http://localhost:10560';

const processInstanceClient = ClientFactory.createProcessInstanceClient(engineUri);

const processInstances = await processInstanceClient.query({
  correlationid: 'my-correlation-id',
});

Hier wird eine Client Instanz angelegt, welche lediglich die Interaktion mit Prozessinstanzen abdeckt.

Anwendungsbeispiele

Nachfolgend werden ein paar der am häufigsten verwendeten Use Cases demonstriert.

Prozesse starten

Das Starten von Prozessinstanzen kann über die EngineClient.processModels Fachlichkeit realisiert werden.

Prozesse lassen sich auf mehrere Arten starten.

Einfacher Prozessstart

import { EngineClient } from '@5minds/processcube_engine_client';

const engineUri = 'http://localhost:10560';

const client = new EngineClient(engineUri);

await client.processModels.startProcessInstance({processModelId: 'myProcessModelId'});

Die processModelId ist der einzige erforderliche Parameter für diesen Request.

Der Client wartet in diesem Szenario nur, bis die Engine den Start des Prozesses bestätigt hat.

Konfigurierter Prozessstart

Neben der processModelId können folgende Paramter mitgegeben werden:

  • startEventId: Die ID des Start Events von welchem aus der Prozess losgehen soll
    • Hinweis: Bei Prozessen mit mehreren Start Events ist dieser Parameter ebenfalls erforderlich!
  • correlationId: Gibt an, in welcher Correlation die Prozessinstanz laufen soll
  • initialToken: Der JSON-formatierte Prozess-Token, den die Prozessinstanz zu beginn besitzen soll
import { EngineClient } from '@5minds/processcube_engine_client';

const engineUri = 'http://localhost:10560';

const client = new EngineClient(engineUri);

await client.processModels.startProcessInstance({
  processModelId: 'myProcessModelId',
  startEventId: 'StartEvent_1',
  correlationId: 'MyCorrelatioNid',
  initialToken: {
    hello: 'world',
  },
});

Prozess starten und auf dessen Ende warten

import { EngineClient } from '@5minds/processcube_engine_client';

const engineUri = 'http://localhost:10560';

const client = new EngineClient(engineUri);

await client.processModels.startProcessInstanceAndAwaitEndEvent({processModelId: 'myProcessModelId'});

Hier wartet der Client, bis die Engine den Prozess bis zum Ende ausgeführt hat.

Die Methode akzeptiert dieselben Parameter wie processModels.startProcessInstance.

Query UserTasks

Abfragen aller User Tasks eines bestimmten Prozesses, die sich in einem "suspended" State befinden:

import { EngineClient, DataModels } from '@5minds/processcube_engine_client';

const engineUri = 'http://localhost:10560';

const client = new EngineClient(engineUri);

const userTasks = await client.userTasks.query({
  processModelId: 'myProcessModelId',
  state: DataModels.FlowNodeInstances.FlowNodeInstanceState.suspended,
});

console.log(userTasks);

External Task Worker

External Task Worker werden dazu benutzt, um die an einer Prozessinstanz anfallenden External Service Tasks zu verarbeiten.

Ein Worker benötigt minimal die folgenden 3 Einstellungen

  • Die URL der Ziel-Engine
  • Das Topic der abzuarbeitenden External Tasks
  • Eine Handler Funktion zum Verarbeiten der External Tasks

Beispiel:

import {ExternalTaskWorker} from '@5minds/processcube_engine_client';

interface AddPayload {
  number1: number;
  number2: number;
}

interface AddResult {
  sum: number;
}

const engineUri = 'http://localhost:10560';
const topic = 'sum_numbers';

const externalTaskWorker = new ExternalTaskWorker<AddPayload, AddResult>(url, topic, doAdd, config);

externalTaskWorker.start();

async function doAdd(
  payload: AddPayload,
  externalTask: DataModels.ExternalTasks.ExternalTask<AddPayload>,
): Promise<AddResult> {
  const result: AddResult = {
    sum: payload.number1 + payload.number2,
  };

  return result;
}

Der Worker lässt sich mit folgendem Befehl starten:

externalTaskWorker.start();

und mit folgendem Befehl stoppen:

externalTaskWorker.stop();

Ein ausführbares Code-Beispiel findet sich hier.

4.3.4

9 months ago

4.3.3

9 months ago

4.3.5

8 months ago

4.3.1

11 months ago

4.3.0

11 months ago

4.4.0-alpha.1

11 months ago

4.3.0-beta.3

12 months ago

4.3.0-beta.2

1 year ago

4.3.0-beta.1

1 year ago

4.3.0-beta.4

12 months ago

4.3.0-alpha.12

1 year ago

4.3.0-alpha.11

1 year ago

4.3.0-alpha.10

1 year ago

4.2.5

1 year ago

4.2.7

1 year ago

4.2.6

1 year ago

4.3.0-alpha.7

1 year ago

4.3.0-alpha.8

1 year ago

4.3.0-alpha.9

1 year ago

4.2.0-alpha.10

1 year ago

4.2.0-alpha.9

1 year ago

4.2.0-beta.5

1 year ago

4.2.3

1 year ago

4.2.2

1 year ago

4.2.4

1 year ago

4.2.1

1 year ago

4.2.0

1 year ago

4.3.0-alpha.1

1 year ago

4.3.0-alpha.2

1 year ago

4.3.0-alpha.3

1 year ago

4.3.0-alpha.4

1 year ago

4.3.0-alpha.5

1 year ago

4.3.0-alpha.6

1 year ago

4.2.0-alpha.2

1 year ago

4.2.0-alpha.1

1 year ago

4.2.0-alpha.8

1 year ago

4.2.0-alpha.7

1 year ago

4.2.0-alpha.4

1 year ago

4.2.0-alpha.3

1 year ago

4.2.0-alpha.6

1 year ago

4.2.0-alpha.5

1 year ago

4.1.0

1 year ago

4.1.0-alpha.13

1 year ago

4.1.0-alpha.11

2 years ago

4.1.0-alpha.12

2 years ago

4.1.0-alpha.5

2 years ago

4.1.0-alpha.7

2 years ago

4.1.0-alpha.6

2 years ago

4.1.0-alpha.9

2 years ago

4.1.0-alpha.8

2 years ago

4.0.1

2 years ago

4.2.0-beta.4

1 year ago

4.2.0-beta.3

1 year ago

4.2.0-beta.2

1 year ago

4.2.0-beta.1

1 year ago

4.1.0-beta.6

2 years ago

4.1.0-beta.4

2 years ago

4.1.0-beta.5

2 years ago

4.1.0-beta.2

2 years ago

4.1.0-beta.3

2 years ago

4.0.0-beta.5

2 years ago

4.0.0-beta.4

2 years ago

4.1.0-alpha.4

2 years ago

4.1.0-alpha.1

2 years ago

4.1.0-alpha.3

2 years ago

4.1.0-alpha.2

2 years ago

4.0.0

2 years ago

4.0.0-alpha.9

2 years ago

4.0.0-alpha.7

2 years ago

4.0.0-alpha.8

2 years ago

4.0.0-alpha.5

2 years ago

4.0.0-alpha.6

2 years ago

4.1.0-beta.1

2 years ago

3.4.3-beta.1

2 years ago

4.0.0-beta.3

2 years ago

4.0.0-beta.2

2 years ago

4.0.0-beta.1

2 years ago

3.5.0

2 years ago

3.5.0-beta.3

2 years ago

3.5.0-beta.1

2 years ago

3.5.0-beta.2

2 years ago

3.5.0-alpha.3

2 years ago

3.5.0-alpha.4

2 years ago

3.5.0-alpha.1

2 years ago

3.5.0-alpha.2

2 years ago

3.5.0-alpha.7

2 years ago

3.5.0-alpha.8

2 years ago

3.5.0-alpha.5

2 years ago

3.5.0-alpha.6

2 years ago

3.5.0-alpha.9

2 years ago

3.4.4-beta.1

2 years ago

3.4.4

2 years ago

3.4.3

2 years ago

3.4.3-alpha.1

2 years ago

3.4.5

2 years ago

4.0.0-alpha.3

2 years ago

4.0.0-alpha.4

2 years ago

4.0.0-alpha.1

2 years ago

4.0.0-alpha.2

2 years ago

3.4.4-alpha.3

2 years ago

3.4.4-alpha.2

2 years ago

3.4.4-alpha.1

2 years ago

3.4.1-beta.1

2 years ago

3.4.0

2 years ago

3.4.2

2 years ago

3.4.1

2 years ago

3.3.0

2 years ago

3.4.0-alpha.12

2 years ago

3.4.0-alpha.11

2 years ago

3.4.0-alpha.10

2 years ago

3.4.0-alpha.16

2 years ago

3.4.0-alpha.15

2 years ago

3.4.0-alpha.14

2 years ago

3.4.0-alpha.13

2 years ago

3.3.0-beta.4

2 years ago

3.3.0-beta.3

2 years ago

3.3.0-beta.5

2 years ago

3.3.0-alpha.9

2 years ago

3.3.0-alpha.8

2 years ago

3.4.0-alpha.1

2 years ago

3.4.0-alpha.8

2 years ago

3.4.0-alpha.9

2 years ago

3.4.0-alpha.6

2 years ago

3.4.0-alpha.7

2 years ago

3.4.0-alpha.4

2 years ago

3.4.0-alpha.5

2 years ago

3.4.0-alpha.2

2 years ago

3.4.0-alpha.3

2 years ago

3.4.0-beta.4

2 years ago

3.4.0-beta.3

2 years ago

3.4.0-beta.2

2 years ago

3.4.0-beta.1

2 years ago

3.1.3

2 years ago

3.1.2

2 years ago

3.3.0-beta.2

2 years ago

3.3.0-beta.1

2 years ago

3.2.1

2 years ago

3.2.0

2 years ago

3.3.0-alpha.1

2 years ago

3.3.0-alpha.6

2 years ago

3.3.0-alpha.5

2 years ago

3.3.0-alpha.4

2 years ago

3.3.0-alpha.3

2 years ago

3.3.0-alpha.7

2 years ago

3.2.0-alpha.4

2 years ago

3.2.0-alpha.5

2 years ago

3.2.0-beta.4

2 years ago

3.2.0-beta.5

2 years ago

3.1.1

3 years ago

3.1.0

3 years ago

3.2.0-alpha.1

3 years ago

3.2.0-alpha.3

3 years ago

3.2.0-beta.2

3 years ago

3.2.0-beta.3

3 years ago

3.2.0-beta.1

3 years ago

3.1.0-beta.2

3 years ago

3.1.0-alpha.7

3 years ago

3.1.0-beta.1

3 years ago

3.1.0-alpha.6

3 years ago

3.1.0-alpha.5

3 years ago

3.0.7

3 years ago

3.0.7-beta.1

3 years ago

3.1.0-alpha.1

3 years ago

3.1.0-alpha.2

3 years ago

3.1.0-alpha.3

3 years ago

3.1.0-alpha.4

3 years ago

3.0.6

3 years ago

3.0.6-beta.1

3 years ago

3.0.6-alpha.1

3 years ago

3.0.5

3 years ago

3.0.5-beta.1

3 years ago

3.0.5-alpha.1

3 years ago

3.0.4-alpha.2

3 years ago

3.0.4

3 years ago

3.0.4-beta.1

3 years ago

3.0.4-alpha.1

3 years ago

3.0.3

3 years ago

3.0.3-alpha.1

3 years ago

3.0.3-beta.1

3 years ago

3.0.2

3 years ago

3.0.2-beta.1

3 years ago

3.0.2-alpha.1

3 years ago

3.0.1

3 years ago

3.0.1-beta.1

3 years ago

3.0.0-beta.6

3 years ago

3.0.0

3 years ago

3.0.0-alpha.16

3 years ago

3.0.0-beta.5

3 years ago

3.0.0-alpha.14

3 years ago

3.0.0-alpha.15

3 years ago

3.0.0-beta.4

3 years ago

2.3.8

3 years ago

2.3.8-alpha.1

3 years ago

3.0.0-alpha.13

3 years ago

3.0.0-alpha.10

3 years ago

3.0.0-alpha.12

3 years ago

3.0.0-alpha.11

3 years ago

3.0.0-beta.3

3 years ago

2.3.7

3 years ago

3.0.0-alpha.9

3 years ago

3.0.0-alpha.7

3 years ago

3.0.0-alpha.6

3 years ago

3.0.0-alpha.8

3 years ago

3.0.0-beta.1

3 years ago

3.0.0-beta.2

3 years ago

3.0.0-alpha.5

3 years ago

2.3.6

3 years ago

3.0.0-alpha.1

3 years ago

3.0.0-alpha.3

3 years ago

3.0.0-alpha.2

3 years ago

3.0.0-alpha.4

3 years ago

2.4.0-alpha.6

3 years ago

2.3.6-beta.1

3 years ago

2.4.0-alpha.5

3 years ago

2.3.4-alpha.1

3 years ago

2.3.4

3 years ago

2.3.3

3 years ago

2.3.5

3 years ago

2.3.5-alpha.1

3 years ago

2.3.4-beta.1

3 years ago

2.3.5-beta.1

3 years ago

2.3.3-beta.1

3 years ago

2.3.3-alpha.2

3 years ago

2.3.3-alpha.1

3 years ago

2.3.2

3 years ago

2.3.2-alpha.1

3 years ago

2.3.2-beta.1

3 years ago

2.4.0-alpha.4

3 years ago

2.4.0-alpha.3

3 years ago

2.3.1

3 years ago

2.3.1-beta.1

3 years ago

2.4.0-alpha.2

3 years ago

2.3.0

3 years ago

2.3.0-beta.5

3 years ago

2.4.0-alpha.1

3 years ago

2.3.0-beta.4

3 years ago

2.3.0-alpha.13

3 years ago

2.3.0-alpha.12

3 years ago

2.3.0-beta.3

3 years ago

2.3.0-alpha.11

3 years ago

2.3.0-alpha.10

3 years ago

2.3.0-beta.2

3 years ago

2.3.0-alpha.8

3 years ago

2.3.0-alpha.9

3 years ago

2.3.0-alpha.6

3 years ago

2.3.0-alpha.7

3 years ago

2.3.0-alpha.5

3 years ago

2.3.0-beta.1

3 years ago

2.3.0-alpha.4

3 years ago

2.3.0-alpha.3

3 years ago

2.3.0-alpha.2

3 years ago

2.2.0-beta.4

3 years ago

2.3.0-alpha.1

3 years ago

2.2.0-beta.3

3 years ago

2.2.0

3 years ago

2.2.0-beta.2

3 years ago

2.2.0-alpha.8

3 years ago

2.2.0-alpha.7

3 years ago

2.2.0-alpha.6

3 years ago

2.2.0-alpha.5

3 years ago

2.2.0-beta.1

3 years ago

2.1.1

3 years ago

2.1.1-beta.1

3 years ago

2.2.0-alpha.3

3 years ago

2.2.0-alpha.2

3 years ago

2.2.0-alpha.1

3 years ago

2.1.0-alpha.4

3 years ago

2.1.0

3 years ago

2.1.0-alpha.3

3 years ago

2.1.0-beta.2

3 years ago

2.1.0-alpha.2

3 years ago

2.1.0-alpha.1

3 years ago

2.1.0-beta.1

3 years ago

2.0.1

3 years ago

2.0.0-beta.5

3 years ago

2.0.0

3 years ago

2.0.0-alpha.20

4 years ago

2.0.0-beta.4

4 years ago

2.0.0-alpha.19

4 years ago

2.0.0-alpha.18

4 years ago

2.0.0-alpha.17

4 years ago

2.0.0-alpha.16

4 years ago

2.0.0-alpha.15

4 years ago

2.0.0-alpha.14

4 years ago

2.0.0-alpha.13

4 years ago

2.0.0-alpha.12

4 years ago

2.0.0-alpha.11

4 years ago

2.0.0-beta.3

4 years ago

2.0.0-alpha.10

4 years ago

2.0.0-beta.2

4 years ago

2.0.0-alpha.8

4 years ago

2.0.0-alpha.9

4 years ago

2.0.0-alpha.7

4 years ago

2.0.0-alpha.6

4 years ago

2.0.0-alpha.5

4 years ago

2.0.0-beta.1

4 years ago

2.0.0-alpha.4

4 years ago

2.0.0-alpha.3

4 years ago

2.0.0-alpha.1

4 years ago

2.0.0-alpha.2

4 years ago

1.2.0-alpha.15

4 years ago

1.2.0

4 years ago

1.2.0-alpha.14

4 years ago

1.2.0-alpha.13

4 years ago

1.2.0-alpha.12

4 years ago

1.2.0-alpha.11

4 years ago

1.2.0-alpha.10

4 years ago

1.2.0-beta.3

4 years ago

1.2.0-alpha.9

4 years ago

1.2.0-beta.2

4 years ago

1.2.0-alpha.8

4 years ago

1.2.0-alpha.7

4 years ago

1.2.0-beta.1

4 years ago

1.2.0-alpha.6

4 years ago

1.2.0-alpha.5

4 years ago

1.2.0-alpha.4

4 years ago

1.2.0-alpha.3

4 years ago

1.2.0-alpha.2

4 years ago

1.2.0-alpha.1

4 years ago

1.1.0

4 years ago

1.1.0-beta.2

4 years ago

1.1.0-alpha.7

4 years ago

1.1.0-alpha.6

4 years ago

1.1.0-alpha.5

4 years ago

1.1.0-alpha.4

4 years ago

1.1.0-beta.1

4 years ago

1.1.0-alpha.3

4 years ago

1.1.0-alpha.2

4 years ago

1.1.0-alpha.1

4 years ago

1.0.0

4 years ago

1.0.0-alpha.42

4 years ago

1.0.0-beta.14

4 years ago

1.0.0-alpha.41

4 years ago

1.0.0-alpha.40

4 years ago

1.0.0-alpha.39

4 years ago

1.0.0-alpha.38

4 years ago

1.0.0-beta.13

4 years ago

1.0.0-alpha.37

4 years ago

1.0.0-alpha.36

4 years ago

1.0.0-alpha.35

4 years ago

1.0.0-beta.12

4 years ago

1.0.0-alpha.34

4 years ago

1.0.0-alpha.33

4 years ago

1.0.0-alpha.32

4 years ago

1.0.0-alpha.31

4 years ago

1.0.0-alpha.30

4 years ago

1.0.0-alpha.29

4 years ago

1.0.0-beta.11

4 years ago

1.0.0-alpha.28

4 years ago

1.0.0-alpha.27

4 years ago

1.0.0-alpha.26

4 years ago

1.0.0-alpha.25

4 years ago

1.0.0-beta.10

4 years ago

1.0.0-alpha.24

4 years ago

1.0.0-alpha.23

4 years ago

1.0.0-beta.9

4 years ago

1.0.0-alpha.22

4 years ago

1.0.0-alpha.21

4 years ago

1.0.0-beta.8

4 years ago

1.0.0-alpha.19

4 years ago

1.0.0-alpha.20

4 years ago

1.0.0-alpha.18

4 years ago

1.0.0-beta.7

4 years ago

1.0.0-alpha.17

4 years ago

1.0.0-alpha.16

4 years ago

1.0.0-alpha.15

4 years ago

1.0.0-beta.6

4 years ago

1.0.0-alpha.14

4 years ago

1.0.0-alpha.13

4 years ago

1.0.0-alpha.12

4 years ago

1.0.0-beta.5

4 years ago

1.0.0-alpha.11

4 years ago

1.0.0-alpha.10

4 years ago

1.0.0-alpha.9

4 years ago

1.0.0-beta.4

4 years ago

1.0.0-alpha.8

4 years ago

1.0.0-alpha.7

4 years ago

1.0.0-alpha.6

4 years ago

1.0.0-alpha.5

4 years ago

1.0.0-beta.3

4 years ago

1.0.0-alpha.4

4 years ago

1.0.0-beta.2

4 years ago

1.0.0-alpha.3

4 years ago

1.0.0-beta.1

4 years ago

1.0.0-alpha.2

4 years ago

1.0.0-alpha.1

4 years ago

0.5.1-alpha.7

4 years ago

0.5.1-alpha.5

4 years ago

0.5.1-alpha.6

4 years ago

0.5.1-alpha.4

4 years ago

0.5.1-beta.1

4 years ago

0.5.1-alpha.3

4 years ago

0.5.1-alpha.2

4 years ago

0.5.1-alpha.1

4 years ago

0.5.1

4 years ago

0.5.0

4 years ago

0.4.8

4 years ago

0.4.7

4 years ago

0.4.6

4 years ago

0.4.5

4 years ago

0.0.1

5 years ago