Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/camunda-community-hub/zeebe-slack-worker
A reusable Slack task worker for Zeebe
https://github.com/camunda-community-hub/zeebe-slack-worker
camunda-8 slack zeebe
Last synced: about 1 month ago
JSON representation
A reusable Slack task worker for Zeebe
- Host: GitHub
- URL: https://github.com/camunda-community-hub/zeebe-slack-worker
- Owner: camunda-community-hub
- Created: 2019-10-30T10:24:46.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2023-12-15T05:40:49.000Z (about 1 year ago)
- Last Synced: 2024-07-31T20:30:22.962Z (5 months ago)
- Topics: camunda-8, slack, zeebe
- Language: TypeScript
- Size: 1.42 MB
- Stars: 4
- Watchers: 2
- Forks: 1
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-camunda-platform-8 - Zeebe Slack Worker - A Node.js library for building job workers that send messages to Slack based on service tasks. (Job Workers)
README
# Zeebe Slack Worker
A Node.js Slack message task worker for Zeebe and Camunda Cloud.
## Usage
Add `zeebe-slack-worker` to your project as a dependency:
```
npm i zeebe-slack-worker
```In your application code, create a `SlackProfile` with the configuration for your Slack integration, then create a `SlackWorker`:
```typescript
import { SlackWorker, SlackProfile } from 'zeebe-slack-worker'const profile: SlackProfile = {
webhook: process.env.SLACK_WEBHOOK_URL,
defaultChannel: process.env.SLACK_CHANNEL || "general"
}const slackworker = new SlackWorker({
SlackProfiles: { default: profile }
})
```This code starts a worker that subscribes to tasks of type `slack:message`.
In your BPMN model, add a service task with the type set to `slack:message`. Set a custom header with the key `slack:message` and the value of the message that you want to send to Slack.
![](img/example-bpmn.png)
Process variables will be templated into this message string using [micromustache](https://www.npmjs.com/package/micromustache). For example, to template in the variable `customerName`, you would set a `slack:message` custom header on the service task with a value like this:
```
{{customerName}} subscribed!
```## More Advanced Usage
### Sending messages to different channels
To specify a channel other than the default, add a custom header to the service task with the key `slack:channel`, and the value set to the channel you want to send to.
You might use this to send exception messages to a specific channel.
### Use message templates
You can abstract the message string text out of the model by specifying a `slack:template` in a custom header, in place of a `slack:message`.
This enables you to create complex messages in a editor, and also to refactor them in a way that does not require redeploying the model or restarting process instances.
To use templates, add templates to the `SlackProfile`:
```typescript
import { SlackWorker, SlackProfile } from 'zeebe-slack-worker'const profile: SlackProfile = {
webhook: process.env.SLACK_WEBHOOK_URL,
defaultChannel: process.env.SLACK_CHANNEL || "general",
templates: {
subscribe: `Great news!
{{customerName}} has subscribed.`,
unsubscribe: `{{customerName}} unsubscribed because {{unsubscribeReason}}`
}
}const slackworker = new SlackWorker({
SlackProfiles: { default: profile }
})
```### Send messages to multiple Slack Teams
You can send messages to distinct Slack Teams using the same worker, by setting up different profiles.
In the service task, set the custom header `slack:profile` to the key of the profile to use for jobs for that service task.
```typescript
import { SlackWorker, SlackProfile } from 'zeebe-slack-worker'const templates = {
subscribe: `Great news!
{{customerName}} has subscribed.`,
unsubscribe: `{{customerName}} unsubscribed because {{unsubscribeReason}}`
}// Service tasks with `slack:profile` set to `happyPath` send to this Slack team
const happyPath: SlackProfile = {
webhook: process.env.SLACK_HAPPY_WEBHOOK_URL,
defaultChannel: process.env.SLACK_CHANNEL || "general",
templates
}// Service tasks with `slack:profile` set to `sadPath` send to this Slack team
const sadPath: SlackProfile = {
webhook: process.env.SLACK_SAD_WEBHOOK_URL,
defaultChannel: process.env.SLACK_CHANNEL || "general",
templates
}const profiles = {
happyPath,
sadPath
}const slackworker = new SlackWorker({
SlackProfiles: profiles
})
```