After cloning the repo, open a terminal and go to examples/basic
Second, install packages and transpile:
npm i && npm run build
If you don't have Camunda installed, you can use docker command to run it in the root folder:
docker run -d --name camunda -p 8080:8080 camunda/camunda-bpm-platform:latest
Make sure to have Camunda running at http://localhost:8080/camunda (user/pass demo/demo)
Run in your terminal in the root folder:
npm run camunda:deploy
Now, You should have a Demo
process definition visible here: http://localhost:8080/camunda/app/cockpit/default/#/processes
npm run camunda:create-instance
Now, in your Demo
process definition, you should see the bpmn with 1 instance attached to Activity
.
If not, look that you are on the right bpmn version.
npm run camunda:worker
You should see in the console, all activities crushed by the worker. Now, if you look back to the Demo
Bpmn (refresh the page), you see that the instance has disappeared.
👏 Congrats, you have finished the Camunda BPM section!
If you don't have Zeebee installed, you can use docker command to run it in the root folder:
docker/run
Make sure to have Zeebe operate running at http://localhost:8080 (user/pass demo/demo)
Now you just need to change the tag TAG.camundaBpm
to TAG.zeebe
.
After cloning the repo, open a terminal and go to examples/basic
Edit the file at examples/basic/src/deploy.ts
, change the tag to TAG.zeebe
and MUST use a different bpmn file (one compatible with Zeebe as XML elements are differents) ${ process.cwd() }/bpmn/zeebe/BPMN_DEMO.bpmn
(the zeebe folder contains BPMN_DEMO.bpmn
)
npm run build && npm run camunda:deploy
Now, You should have a Demo
process definition visible here: http://localhost:8080/#/instances?filter=%7B%22active%22%3Atrue%2C%22incidents%22%3Atrue%2C%22workflow%22%3A%22BPMN_DEMO%22%2C%22version%22%3A%221%22%7D
Edit the file at examples/basic/src/create-process-instances.ts
, change the tag to TAG.zeebe
npm run build && npm run camunda:create-instance
Now, in your Demo
process definition, you should see the bpmn with 1 instance attached to Activity
.
If not look that you are on the right bpmn version.
Edit the file at examples/basic/src/worker.ts
, change the tag to TAG.zeebe
npm run build && npm run camunda:worker
You should see in the console, all activities crushed by the worker. Now, if you look back to the Demo
Bpmn (refresh the page), you see that the instance have disappeared.
👏 Congrats, you have finished the Zeebe BPM section!
First, start Jaeger with docker
docker run -d --name jaeger \
-e COLLECTOR_ZIPKIN_HTTP_PORT=9411 \
-p 5775:5775/udp \
-p 6831:6831/udp \
-p 6832:6832/udp \
-p 5778:5778 \
-p 16686:16686 \
-p 14268:14268 \
-p 9411:9411 \
jaegertracing/all-in-one:latest
Be sure to have a Camunda platform running. Let's say, you have Camunda BPM (default):
docker run -d --name camunda -p 8080:8080 camunda/camunda-bpm-platform:latest
If you have a port confict (stop Zeebe broker/operate)
Then, with your terminal, go to examples/opentelemetry
run:
npm i && npm run build
and in order to deploy your bpmn and create a process instance in Camunda, run:
npm run camunda:deploy && npm run camunda:create-instance
Finally, run the worker by running the following command:
npm run camunda:worker
You can then navigate to http://localhost:16686
to access the Jaeger UI.
You should see something like:
By clicking on a trace, you should see something like:
👏 Congrats, you have finished the tracing section!
related issue: jaegertracing/jaeger-client-node#124 In your terminal, you can do something like:
% sysctl net.inet.udp.maxdgram
net.inet.udp.maxdgram: 9216
% sudo sysctl net.inet.udp.maxdgram=65536
net.inet.udp.maxdgram: 9216 -> 65536
% sysctl net.inet.udp.maxdgram
net.inet.udp.maxdgram: 65536
Make sure to have Camunda running. Create a simple process model with an External Service Task and define the topic as 'topicName' (or type for Zeebe). Deploy the process to the Camunda BPM engine or Zeebe.
In your NodeJS script:
import { SERVICE_IDENTIFIER as CORE_IDENTIFIER, IoC, ICamundaConfig, Worker } from '@villedemontreal/workit-camunda';
// In helloWorldTask.ts file
class HelloWorldTask extends TaskBase<IMessage> {
public execute(message: IMessage): Promise<IMessage> {
console.log('Servus!');
// put your logic in here
return Promise.resolve(message);
}
}
// In config file
// configuration for the Client:
// - 'baseUrl': url to the Workflow Engine
// - 'maxTasks': maximum task to take
// - 'workerId': name of your worker
// - 'topicName': topic to subscribe
// ... there is more options you can add
const config: ICamundaConfig = {
maxTasks: 1,
workerId: 'demo',
baseUrl: `https://localhost:8080/engine-rest`,
topicName: 'topic_demo'
};
IoC.bindTo(HelloWorldTask, '<ACTIVITY_ID_FROM_BPMN>');
IoC.bindToObject(config, SERVICE_IDENTIFIER.camunda_external_config);
// In app.ts file
const worker = IoC.get<Worker>(SERVICE_IDENTIFIER.worker);
worker.start();
worker.run();
Some events are available to you : starting
, stopping
, stopped
, message
, message-handled
.
message
event haveICamundaTask
arguments. It occurs when the worker receive a message.message-handled
event have some arguments (error: Error, message:IMessage
). In case of sucess, error will be null. It occurs when the message has been resolved (success or failure).
In Camunda
, each external task has an ID. You need to use IoC
in order to bind the task that extends TaskBase<I>
to the external task id.
For example, I have an external task myTask
(id) in my bpmn file :
export class MyTask extends TaskBase<IMessage> {
constructor() {
super();
}
public async execute(message: IMessage): Promise<IMessage> {
// put your logic here
return message;
}
}
export const myTask = new MyTask();
After creating this new task, we need to bind it by using IoC
.
In my "config/ioc.ts" file :
IoC.bindToObject(myTask, 'myTask');
Now, the worker knows what to resolve when this external task will be executed through Camunda.
Since we use IoC for binding classes, you are able to :
- Tell Camunda that the execution is a success
- Tell Camunda that the execution is a failure
- Pass logger (notice that in standard env we replace default logger by another for reducing noise and safety)
- Pass interceptors. For example, give Oauth info to Camunda, if needed.
- ...
By default, we have implemented :
FailureStrategySimple
(not for production use) but you can provide your own by implementingIFailureStrategy
SuccessStrategySimple
but you can provide your own by implementingISuccessStrategy
- You can specify workflows and versions in order to bind a task for a specific workflow version.
- You can also bind a default task (without workflow)