Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jwulf/slack-cloud-worker
A Cloudflare Zero-Scale Slack Worker for Zeebe on Camunda Cloud
https://github.com/jwulf/slack-cloud-worker
cloudflare-worker slack zeebe
Last synced: 20 days ago
JSON representation
A Cloudflare Zero-Scale Slack Worker for Zeebe on Camunda Cloud
- Host: GitHub
- URL: https://github.com/jwulf/slack-cloud-worker
- Owner: jwulf
- License: apache-2.0
- Created: 2019-12-03T20:18:41.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2021-08-11T18:31:08.000Z (over 3 years ago)
- Last Synced: 2024-10-31T23:51:27.756Z (2 months ago)
- Topics: cloudflare-worker, slack, zeebe
- Language: JavaScript
- Homepage: https://zeebe.io/blog/2019/12/cloudflare-slack/
- Size: 98.6 KB
- Stars: 2
- Watchers: 2
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE_APACHE
- Code of conduct: CODE_OF_CONDUCT.md
Awesome Lists containing this project
README
# Cloudflare Zero-Scale Slack Worker for Camunda Cloud
This is a [Cloudflare worker](https://developers.cloudflare.com/workers) that provides a zero-scale Slack messaging task for [Camunda Cloud](https://zeebe.io/blog/2019/09/getting-started-camunda-cloud/), using the Camunda Cloud HTTP Worker.
On the free tier of Cloudflare Workers, you can send 100,000 messages a day.
## Setup
### Slack Setup
1. Go to your Slack.
2. Click on the part that has your name and the Slack team name, then go to "Customize Slack".
3. Click on "Configure apps".
4. Search the App Directory for "Incoming WebHooks".
5. Click on "Add to Slack".
6. Choose a channel, then click on "Add Incoming WebHooks integration"
7. Copy the Webhook URL.### Cloudflare Setup
1. Sign up for a [Cloudflare Workers account](https://dash.cloudflare.com/).
2. Clone [this repo](https://github.com/jwulf/slack-cloud-worker), then cd into the checked out directory and run `npm i`.
3. Install `wrangler`, the Cloudflare Worker CLI:```bash
npm i -g wrangler
```4. Grab your Account ID from your [Cloudflare dashboard](https://dash.cloudflare.com/) (click on Workers on the right). Put the Account ID into `wrangler.toml` in the `account_id` field.
5. Create a new API key in your Cloudflare account. Click on "Get your API token" under your Account ID, and create a new token with Permissions: Account > Workers Scripts > Edit.
6. Copy the API key.
7. Run `wrangler config`.
8. Enter the email address of your Cloudflare account, and paste in the API key.
9. Now publish the worker with `wrangler publish`
10. Copy the url of your deployed Cloudflare worker.### Camunda Cloud Setup
1. Log in to your [Camunda Cloud](https://console.cloud.camunda.io/) account.
2. Go to the configuration screen for your cluster.
3. Click on "Worker Variables" next to the HTTP-Worker.
4. Create a new variable `slackWorkerUrl` and paste in your Cloudflare Worker url.
5. Create a new variable `slackWebhook` and paste in your Slack webhook url.## Use
Check the `bpmn/test-message.bpmn` file for an example.
To send a message to Slack in a business process, add a task with the Type "CAMUNDA-HTTP".
Set these Headers on the task:
url : ${slackWorkerUrl}
slackWebhook : ${slackWebhook}
method : postYou have two options for setting the message.
1. You can hardcode a message in the task header.
2. You can set a `message` variable in the workflow.Either way, any field that you want replaced by a variable from the workflow should be escaped like this: `{{ variable }}`.
The templating is performed using [micromustache](https://www.npmjs.com/package/micromustache).
In the example, the message is set in the headers: `Hello {{ name }}`. When the worker receives a job, it substitutes the value of the variable `name`. If you examine the file `bpmn/test.js`, you'll see that it kicks off a workflow setting the variable `name` to "World!", leading to the Slack message "Hello World!".
## Running the demo
1. Cd into the `bpmn` directory.
2. Run `npm i`.
3. Grab your config from your Camunda Cloud account (create Client credentials for the cluster if you don't already have some in there).
4. Run the demo like this - substituting your configuration:```bash
ZEEBE_ADDRESS=${YOUR CLUSTER CONTACT POINT} ZEEBE_CLIENT_ID=${CLIENT ID} ZEEBE_CLIENT_SECRET=${CLIENT SECRET} node index.js
```