Skip to main content

Quickstart 1: Create Your First Workflow

As you will have learned in Core Concepts, Conductor’s core orchestration unit is a workflow. In this quickstart, you will learn how to create your first Conductor workflow.

Approaches to create workflows

In Conductor, workflow definitions are stored as JSON. To create a workflow, you can use one of the following ways:

  • Workflow as code—Using the Conductor SDKs, define your workflow in your preferred language.
  • Visual workflow editor—Using Conductor UI, define your workflow visually, which is formatted as JSON under the hood.

Static vs dynamic workflows

With Conductor, you can define workflows statically (ahead of time) or dynamically (at runtime). This quickstart will teach you how to creating static workflows using your preferred approach. Once you master this, you can dive into creating dynamic workflows as code.

Tasks in workflows

A workflow definition consists of a collection of tasks and operators and specifies the order and execution of the defined tasks. Conductor provides a set of system tasks and operators, but you can also write your own custom worker tasks. This is a powerful feature which you will learn more in Quickstart 2.

For this quickstart, let’s begin by using system tasks to create your first workflow.

Quickstart overview

  1. Create a workflow definition consisting of system tasks and operators.
  2. Register the workflow definition to the Conductor server.
  3. Run the workflow.

Before you begin

Ensure that you have prepared your tools and access.

A. Workflow as code

Create a project for your workflow client.

This sample Python code demonstrates how to create, register, and execute a workflow in Conductor.

Check out the full project here.

from conductor.client.http.models import StartWorkflowRequest
from conductor.client.configuration.configuration import Configuration
from conductor.client.configuration.settings.authentication_settings import AuthenticationSettings
from conductor.client.workflow.conductor_workflow import ConductorWorkflow
from conductor.client.workflow.executor.workflow_executor import WorkflowExecutor
from conductor.client.workflow.task.simple_task import SimpleTask
from conductor.client.workflow.task.http_task import HttpTask
from conductor.client.workflow.task.switch_task import SwitchTask


def main():
# Set up an application in your Orkes Conductor cluster. Sign up for a Developer Edition account at https://developer.orkescloud.com.
# - Set your cluster's URL as base_url (e.g., "https://developer.orkescloud.com" for Developer Edition).
# - Use the application's Key ID and Secret here.
conf = Configuration(base_url='_CHANGE_ME_',
authentication_settings=AuthenticationSettings(key_id='_CHANGE_ME_',
key_secret='_CHANGE_ME_'))

# A WorkflowExecutor instance is used to register and execute workflows.
executor = WorkflowExecutor(conf)

# Create the workflow definition.
workflow = ConductorWorkflow(
executor=executor,
name='myFirstWorkflow',
description='Workflow that greets a user. Uses a Switch task, HTTP task, and Simple task.',
version=1
)

# Create the tasks.
httpTask = HttpTask('get-user_ref', {'uri': 'https://randomuser.me/api/'})
switchTask = SwitchTask('user-criteria_ref', '${get-user_ref.output.response.body.results[0].location.country}').switch_case(
'United States', SimpleTask('helloWorld', 'simple_ref').input(
key='user', value='${get-user_ref.output.response.body.results[0].name.first}'))

# Add the tasks to the workflow using `add` method or the `>>` operator.
workflow.add(httpTask)
workflow >> switchTask

# Register the workflow.
workflow.register(True)
print(f"Registered workflow {workflow.name}")

# Start the workflow.
request = StartWorkflowRequest()
request.name = 'myFirstWorkflow'
request.version = 1
id = executor.start_workflow(request)
print(f"Started workflow {id}")


if __name__ == '__main__':
main()

B. Visual workflow editor

Use the visual workflow editor in Conductor UI to create your workflows.

To create a workflow:

  1. Log in to your Orkes cluster or the Orkes Developer Edition.
  2. In the left navigation menu, go to Definitions > Workflow.
  3. Select (+) Define workflow.
  4. Enter a Name and Description for your workflow.
  5. To add tasks to the workflow, select the (+) icon in the visual workflow diagram.
  6. To register the workflow, select Save > Confirm.

Screenshot of visual workflow editor in Orkes Conductor.

Once created, you can run your workflow by going to the Run tab and selecting Run workflow.

Tutorial — your first workflow:

Follow along to build your first workflow, which is a conditional notification flow based on the user’s location.

  1. The first task will retrieve the user information through an HTTP endpoint.

    1. Add an HTTP task to the workflow.
    2. Enter the task name get-user in Task definition.
    3. Set the URL as https://randomuser.me/api/ with GET as the Method.
  2. The next task will evaluate the user information based on a set criteria. In this case, we want the workflow to send a notification only if the user is located in United States.

    1. Add a Switch task to the workflow.
    2. Enter the task name user-criteria in Task definition.
    3. Set the evaluation criteria to Value-Param and enter the evaluation cases in Switch cases. In this case, select Add more switch cases and enter United States. This creates a new branch, where its tasks are only executed if the evaluation criteria is met. The parameter to be evaluated will be switchCaseValue, which will be wired to a variable input based on the previous get-user task output.
    4. To do so, in Script params, enter ${get-user_ref.output.response.body.results[0].location.country} as the value for switchCaseValue. This is a dynamic variable, which is expressed in JSONPath syntax.
  3. The final task will send a notification to the user if they are located in United States.

    1. In the United States branch of the Switch task, add a HTTP task.
    2. Enter the task name send-notification in Task definition.
    3. Set the URL as https://orkes-api-tester.orkesconductor.com/api, which will serve as the mock notification endpoint, with POST as the Method.

    Alternatively, you can copy the JSON code below into the Code tab of the workflow builder.

{
"name": "myFirstWorkflow",
"description": "Workflow that greets a user. Uses a Switch task, HTTP task, and Simple task.",
"version": 1,
"tasks": [
{
"name": "get-user",
"taskReferenceName": "get-user_ref",
"inputParameters": {
"uri": "https://randomuser.me/api/",
"method": "GET",
"accept": "application/json",
"contentType": "application/json",
"encode": true
},
"type": "HTTP",
"decisionCases": {},
"defaultCase": [],
"forkTasks": [],
"startDelay": 0,
"joinOn": [],
"optional": false,
"defaultExclusiveJoinTask": [],
"asyncComplete": false,
"loopOver": [],
"onStateChange": {},
"permissive": false
},
{
"name": "user-criteria",
"taskReferenceName": "user-criteria_ref",
"inputParameters": {
"switchCaseValue": "${get-user_ref.output.response.body.results[0].location.country}"
},
"type": "SWITCH",
"decisionCases": {
"United States": [
{
"name": "helloWorld",
"taskReferenceName": "simple_ref",
"inputParameters": {
"user": "${get-user_ref.output.response.body.results[0].name.first}"
},
"type": "SIMPLE",
"decisionCases": {},
"defaultCase": [],
"forkTasks": [],
"startDelay": 0,
"joinOn": [],
"optional": false,
"defaultExclusiveJoinTask": [],
"asyncComplete": false,
"loopOver": [],
"onStateChange": {},
"permissive": false
}
]
},
"defaultCase": [],
"forkTasks": [],
"startDelay": 0,
"joinOn": [],
"optional": false,
"defaultExclusiveJoinTask": [],
"asyncComplete": false,
"loopOver": [],
"evaluatorType": "value-param",
"expression": "switchCaseValue",
"onStateChange": {},
"permissive": false
}
],
"inputParameters": [],
"outputParameters": {},
"failureWorkflow": "",
"schemaVersion": 2
}
  1. Save and register your workflow.

Your first workflow is now created. Give it a test run.

Now that you have gotten a hang of creating workflows, you can make them more powerful by using Worker tasks, which execute custom logic just like any regular function. Head to the next quickstart to learn more.