Skip to main content

Workflows

Overview

The Workflows tool in Cortex allow you to automate running sequential actions and development workflows based on contextual data that exist inside your workspace. This tool supports both simple workflows, like granting permissions to a database, and sophisticated ones, like creating a Jira ticket for an incident detected in Cortex.

Workflow RBAC

It is possible to configure specific users, teams, or roles who are allowed to run a Workflow, or you can require the user to be an Owner or Editor of an entity in order to run the workflow. This is described in more detail under Step 2: Configure your workflow settings.

It is also possible to create a "Manual approval" action that requires approval from specific team members. Read more about configuring this under Add actions to your workflow.

View Workflows and run history

To see your workflows, click Workflows in the lefthand navigation menu. To view existing workflows, you must have the View Workflows permission.

For auditing and debugging purposes, Cortex stores run history, which includes the initiator, run context, and the inputs/outputs of each action, for 30 days. To view previous Workflow runs, you must have the View Workflow runs permission.

  • In the Workflows tab, view all existing workflows, including each workflow's name, description, and last update. If a workflow is in draft mode, you'll also see a Draft tag next to its name. From this page, you can edit, run, delete, or create a workflow. Click Workflows on the left sidebar
  • In the Runs tab, view historic runs for each Workflow, as well as each run's status: In Progress, Paused, Successful, Canceled, or Error. Click any of the individual actions to view the action's inputs, outputs, and run context in the side panel. View a run's inputs, output, and context

Creating a workflow

note

You must have the Edit Workflows permission in order to complete these steps.

You can choose to create a workflow from a template or you can choose to create one from scratch.

There are templates available for the following common workflows:

  • Create AWS S3 bucket
  • Create AWS EC2 instance
  • Create ServiceNow incident
  • Create Azure function
  • Create Jira issue

Step 1: Choose a template or a blank workflow

  1. In the lefthand navigation menu of Cortex, click Workflows.
  2. On the right side of the search bar, click Create workflow. Create Workflows link on right side of search bar
  3. Choose whether to start with a template or start from scratch. tile options to start with a template or start from scratch
    • Workflow Template: Click the tile for the template you wish to use, then click Continue at the bottom of the page.
      • Note: Each tile displays the requirements for secrets you must define before using the template; make sure to follow the template's requirements before you proceed.
    • Start from Scratch: Click Start from Scratch, then click Continue at the bottom of the page.

Step 2: Configure your workflow settings

  1. On the Create Workflow page, fill in the fields to configure your workflow. The name, slug, and description are prepopulated for templates.
    • Name: Enter a descriptive name for your workflow.
    • Slug: Enter a unique slug. If you have previously used a template, make sure to update the prepopulated slug when you use the template again.
    • Description: Optionally enter a description of the workflow.
    • Response template: Optionally enter a response template.
      • See more information about templating in the Actions docs.
    • Scope: Select Entity to narrow the workflow's scope to a specific entity, or select Global if the workflow should not be scoped to a specific entity.
      • If you choose Entity:
        • User relation to entities: Specify the relation to the entity that the user running the workflow must have in order to run the workflow. You can require the user to be an Owner or an Editor of the entity in order to run the workflow. If you choose Editor, you must have the Team ownership entity setting enabled.
        • Entity Type: Select the entity type that this workflow applies to.
        • Optionally, you can also choose groups to include or exclude.
    • The toggle for Everyone can run this workflow is enabled by default.
      • If you disable this toggle, you can select specific users, teams, or roles who are allowed to run the workflow.
      • In order for a user to run the workflow, they must have the Workflow runs execute permission and they must match at least one of the users, teams, or roles that you specify here. Disable the toggle and select a user, role, or team
  2. Optionally, if you want to first save this workflow as a draft, toggle the Draft setting on.
    • When a workflow is saved as a draft, it is only visible to users with the Workflow edit permission.
  3. Click Save Workflow.

Step 3: Add actions to your workflow

To add an action to your workflow, click + in the workflow visual in the center of the page.

Click + to add an action

You can create the following action types:

  • Branch
  • Data transformation
  • HTTP request
  • Manual approval
  • Scaffolder
  • Slack
  • User input

Action types

caution

The slug for each action must be unique across a workflow.

See the tabs below for instructions specific to each type of action that you can add to a workflow.

The Branch action allows you to set up to five conditional paths for a workflow.

The branch tile is highlighted

Configure a branch action

To configure a branch action:

  1. Click Branch from the list of actions.
  2. Enter a name.
    • The slug field will automatically pre-populate based on the name you enter.
  3. Click +Add Path.
  4. In the dialog that appears, enter a name, a slug, and a path expression.
    • The path expression is compatible with CEL syntax. The path expression does not accept dashed values; if you reference an action's slug that contains a dash, wrap the slug in quotes and square brackets.
      • For example, if you want to reference an action with the slug example-action, the expression would begin with actions["example-action"].
        Fill out the path creation fields
tip

Autocomplete will provide correctly formatted options based on the actions defined in your workflow.

  1. Click Add path.
    • You will be redirected to the action editor page, showing your newly-added path in the workflow visual.
  2. Optionally, add additional paths and a fallback path.
    • Click + under a path to add the next type of action. You can add any action type, including another branch.
  3. When you are finished adding paths, click Save Workflow at the bottom of the action editor.
  4. If you want to add additional actions that occur after the paths within your branch action, click + below the branch action box in the workflow editor.

How paths work

The paths defined run sequentially. The first path that returns true will execute, even if subsequent paths would also return true. The workflow will then continue performing actions in that path. You can also set a fallback path that will run if all other paths fail.

Primary and nested branches function the same way.

Nested branches

You can nest a branch under any or all of the original paths, but you cannot nest further.

To nest a branch:

  1. In the visual workflow, click the + that is branched off your original branch. Click the + off the original branch
  2. On the right side of the page in the workflow editor, select Branch.
  3. Enter a name for your branch, then click Save action.
    A visual of a nested branch and path

There are no limits on how many branches you can nest.


Referencing previous actions and workflow state

Each workflow, when run, will build up a state object that can be referenced throughout the workflow, and allows actions to reference both the top-level state and a previous action's state.

In addition, you can use an action's unique identifier (a slug or a user input key) to reference it in another action within your workflow.

Read more in the Actions documentation.

Additional information on actions

To learn about using request signing with actions, duplicating an action, and templating an action, see the Actions documentation.

Running a Workflow

Run a Workflow from the Workflows page

  1. On the Workflows page, locate the Workflow you want to run.
  2. On the right side of the Workflow, click the Play icon. Click the play icon to run a Workflow
    • The workflow will automatically launch. Workflows that require User input or Manual approval will pause until your configured input or approval is completed.

When an action completes, a green checkmark is displayed in the top right corner. Actions that require input or approval will display an orange Pause icon.

Completed actions show a green checkmark, paused actions show an orange pause icon

When a run has been started, it appears in the Runs tab on the Workflows page. A completed runs will display as Successful, while those awaiting input or approval will display as Paused.

Running a workflow with secret user input

If the Workflow has a secret user input action configured, the user running the Workflow will be prompted to enter information into the field, which will be redacted in the Workflow's Outputs tab. If the Workflow has regex validation configured, the user must enter a secret matching the value of the Validation regex that was configured for this action.

The secret fields can be seen in the Output of the workflow after it has been run, but the secret values will be redacted.

Note that users with permission Edit Workflows will be able to obtain secret values using complex data transformation on secrets or echoing services.

Run a workflow from an entity

You can also run a workflow while viewing an entity:

  1. On the left navigation menu of Cortex, click Catalogs > All entities.
  2. Click an entity to view its details page.
  3. On the left side of the entity details, click Workflows to view and run any entity-scoped Workflows. The Workflows link is on the left side of an entity page

Cancel a workflow

If you cancel a run that is partially complete, it will not undo any successfully completed actions.

To cancel a running workflow:

  1. On the Workflows page, click the Runs tab then locate the Workflow you want to cancel.
  2. Click on the Workflow to view its run details page.
  3. Click Cancel run.

In the upper right click Cancel Run