Skip to content
You're viewing an older version of this GitHub Action. Do you want to see the latest version instead?
upload-cloud

GitHub Action

Camunda 8 Action

1.0.1

Camunda 8 Action

upload-cloud

Camunda 8 Action

A GitHub action to interact with Camunda SaaS

Installation

Copy and paste the following snippet into your .yml file.

              

- name: Camunda 8 Action

uses: camunda-community-hub/camunda-platform-8-github-action@1.0.1

Learn more about this action in camunda-community-hub/camunda-platform-8-github-action

Choose a version

Integrate GitHub Actions with Zeebe on Camunda Cloud

Community Extension

Lifecycle

This GitHub Action allows you to integrate GitHub Actions into workflows orchestrated by Zeebe on Camunda Cloud.

You can deploy a workflow definition to Camunda Cloud, create a Camunda Cloud workflow instance from a GitHub Action, start and run an entire workflow on Camunda Cloud and act on the outcome in a GitHub Action, or publish a message from a GitHub Action to a workflow instance running in Camunda Cloud.

See this article: "Complex multi-repo builds with GitHub Actions and Camunda Cloud" for some ideas on orchestrating multi-repo build workflows using Camunda Cloud.

Node version compatibility

This GitHub Action uses a version of the Zeebe Node client that requires Node versions 12.22.5+, 14.17.5+, or 16.6.1+.

Operations

Operation Required Parameters Optional Parameters
deployWorkflow One of: bpmnFilename or bpmnDir verbose, quiet
createWorkflowInstance bpmnProcessId variables, verbose, quiet
createWorkflowInstanceWithResult bpmnProcessId, requestTimeoutSeconds variables, verbose, quiet
publishMessage messageName timetoLive, variables, correlationKey, verbose, quiet
startWorkers workerHandlerFile, workerLifetimeMins githubToken, verbose, quiet

Configure Camunda Cloud credentials

In a repository where you have a GitHub workflow that uses this action, you need to configure your Camunda Cloud client credentials.

  • Set a secret in your repo (Repo Settings > Secrets) ZEEBE_CLIENT_CONFIG, and paste in the entire block from Camunda Cloud.

See the note at the end of this document if you get errors about missing required configuration keys.

Deploy a Workflow

Here is an example of deploying a workflow from GitHub. This will deploy the process in the file bpmn/demo-get-time.bpmn in the repo:

name: Run Get Time Demo

on: [repository_dispatch]

jobs:
  demo-get-time:
    if: github.event.action == 'get_time'
    runs-on: ubuntu-latest

steps:
  - uses: actions/checkout@v2
  - name: Deploy Demo Workflow "Get Time"
    uses: jwulf/zeebe-action@master
    with:
      clientConfig: ${{ secrets.ZEEBE_CLIENT_CONFIG }}
      operation: deployWorkflow
      bpmnFilename: bpmn/demo-get-time.bpmn

Automate Deployment of BPMN Models on Push to master

Here is a workflow that redeploys changed models in the bpmn directory of your repo on a push to the master branch:

name: Deploy Workflows

on:
  push:
    branches:
      - master
    paths:
      - 'bpmn/*'

jobs:
  deploy-workflows:
    runs-on: ubuntu-latest

    steps:
      - uses: actions/checkout@v2
      - name: Deploy Updated Workflows
        uses: jwulf/zeebe-action@master
        with:
          clientConfig: ${{ secrets.ZEEBE_CLIENT_CONFIG }}
          operation: deployWorkflow
          bpmnDirectory: bpmn

Start a Workflow

Here is an example of starting a workflow from within a GitHub Action:

name: Report Outcome

on: repository_dispatch

jobs:
  report:
    runs-on: ubuntu-latest
    timeout-minutes: 10
    steps:
      - uses: actions/checkout@v2
      - name: Use Node.js 16.x
        uses: actions/setup-node@v1
        with:
          node-version: 16.x
      - run: echo github.event.action: ${{ github.event.action }}
      - name: Create Zeebe Workflow
        uses: jwulf/zeebe-action@master
        with:
          clientConfig: ${{ secrets.ZEEBE_CLIENT_CONFIG }}
          operation: createWorkflowInstance
          bpmnProcessId: throw-test
          variables: '{"event": "${{ github.event.action }}" }'

Awaiting the outcome of a Workflow

You can create a workflow instance and retrieve the outcome of the workflow for use in further steps:

name: Run Get Time Demo

on: [repository_dispatch]

jobs:
  demo-get-time:
    if: github.event.action == 'get_time'
    runs-on: ubuntu-latest

steps:
  - uses: actions/checkout@v2
  - name: Deploy Demo Workflow "Get Time"
    uses: jwulf/zeebe-action@master
    with:
      clientConfig: ${{ secrets.ZEEBE_CLIENT_CONFIG }}
      operation: deployWorkflow
      bpmnFilename: bpmn/demo-get-time.bpmn
  - name: Execute Demo Workflow "Get Time"
    uses: jwulf/zeebe-action@master
    id: get-time
    with:
      operation: createWorkflowInstanceWithResult
      bpmnProcessId: demo-get-time
      requestTimeout: 30 # seconds
  - name: Print Workflow Outcome
    run: echo The outcome is ${{ toJSON(steps.get-time.outputs.result }}
  - name: Print time
    run: echo The time is ${{ steps.get-time.outputs.result.body.time }}

When awaiting a workflow outcome, if no request_timeout is provided, it defaults to the Gateway timeout of the cluster (15 seconds). For workflows that take longer than this to complete, you should specify a request_timeout.

Note that once the connection configuration is provided, it is available to any further Zeebe Action operations in the GitHub workflow.

Publish a message

Here is an example of publishing a message back to Camunda Cloud, to be correlated with a running workflow. In this example, the action has been started with a repository_dispatch event from the CAMUNDA-HTTP worker. The client_payload on the event contains the correlationKey value for the message:

triggerDependentFlow:
  runs-on: ubuntu-latest
  steps:
    - name: Tell Camunda Cloud What's up!
      uses: jwulf/zeebe-action@master
      with:
        clientConfig: ${{ secrets.ZEEBE_CLIENT_CONFIG }}
        operation: publishMessage
        messageName: BASE_IMAGE_REBUILT
        correlationKey: ${{ github.event.client_payload.buildid }}

Variables can be provided in a publishMessage operation. They should be stringified JSON, just like the createWorkflowInstance operation.

Create Workers

You can start Zeebe task workers in a GitHub Workflow, using handler code loaded from your repo.

Dependencies in a package.json file in the .github/workflows folder are installed when workers are started.

For example, to start workers based on a workers.js file in the root of your repo, and shut them down after 10 minutes:

name: Start Workers

on: repository_dispatch

jobs:
  report:
    runs-on: ubuntu-latest
    timeout-minutes: 10
    steps:
      - uses: actions/checkout@v2
      - name: Use Node.js 12.x
        uses: actions/setup-node@v1
        with:
          node-version: 12.x
      - name: Start Zeebe Workers
        uses: jwulf/zeebe-action@master
        with:
          clientConfig: ${{ secrets.ZEEBE_CLIENT_CONFIG }}
          # If you want to access the GitHub API in your worker:
          githubToken: ${{ secrets.GITHUB_TOKEN }} 
          operation: startWorkers
          workerHandlerFile: workers.js
          workerLifetimeMins: 10

The workers.js file should look like this:

module.exports = {
  let stockLevel = 100
  tasks: {
    'get-stock-level: (job, complete) => {
      // you have @actions/core in scope
      core.info(JSON.stringify(job, null, 2))
      complete.success({
        stockLevel
      })
    },
    'decrement-stock': (job, complete) => {
      stock --
      complete.success({
        stockLevel
      })
    }
  }
}

If you want to make GitHub API calls in your worker, then set the gitHubToken parameter as githubToken: ${{ secrets.GITHUB_TOKEN }}.

Then your worker code will have a hydrated Octokit reference in scope as octokit.

Development

Run the npm run rebuild task before checking the code in.

For this, you need Docker running.

The action is rebuilt on GitHub by the build.yaml workflow, to ensure that it has the correct binaries for gRPC in the GitHub runner environment.

To create a new release, tag the master branch, then use the GitHub "Create a Release" feature.

A note on configuration

Previously, you had to create individual secrets for each of the client credential fields: ZEEBE_ADDRESS, ZEEBE_CLIENT_ID, etc...

However, this is clunky. Ain't nobody got time fo' that!

We are waiting on the single JSON-parseable connection string to land. In the meantime, the Zeebe Action parses the text of the credentials block from the Cloud console to extract the credential values. Text parsing is brittle, and a change in the formatting of that block could break it.

As a backup, the previous method still works. To use it that way, create a secret for each one, and paste in the unquoted value of the variable.

Then in your workflows, you need to do:

jobs:
  startWorkflow:
    runs-on: ubuntu-latest
    steps:
      - name: Get current time
        uses: gerred/actions/current-time@master
        id: current-time
      - name: Create Zeebe Workflow
        uses: jwulf/zeebe-action@master
        with:
          zeebeAddress: ${{ secrets.ZEEBE_ADDRESS }}
          zeebeClientId: ${{ secrets.ZEEBE_CLIENT_ID }}
          zeebeAuthorizationServerUrl: ${{ secrets.ZEEBE_AUTHORIZATION_SERVER_URL }}
          zeebeClientSecret: ${{ secrets.ZEEBE_CLIENT_SECRET }}
          operation: createWorkflowInstance
          bpmnProcessId: magikcraft-github-build
          variables: '{"buildid": "${{ github.sha }}-${{ steps.current-time.outputs.time }}"}'