Create workflow

POST
/api/v2/projects/:projectKey/flags/:featureFlagKey/environments/:environmentKey/workflows

Create a workflow for a feature flag. You can create a workflow directly, or you can apply a template to create a new workflow.

Creating a workflow

You can use the create workflow endpoint to create a workflow directly by adding a stages array to the request body.

For each stage, define the name, conditions when the stage should be executed, and action that describes the stage.

Click to expand example

Example request body

1{
2 "name": "Progressive rollout starting in two days",
3 "description": "Turn flag targeting on and increase feature rollout in 10% increments each day",
4 "stages": [
5 {
6 "name": "10% rollout on day 1",
7 "conditions": [
8 {
9 "kind": "schedule",
10 "scheduleKind": "relative", // or "absolute"
11 // If "scheduleKind" is "absolute", set "executionDate";
12 // "waitDuration" and "waitDurationUnit" will be ignored
13 "waitDuration": 2,
14 "waitDurationUnit": "calendarDay"
15 },
16 {
17 "kind": "ld-approval",
18 "notifyMemberIds": [ "507f1f77bcf86cd799439011" ],
19 "notifyTeamKeys": [ "team-key-123abc" ]
20 }
21 ],
22 "action": {
23 "instructions": [
24 {
25 "kind": "turnFlagOn"
26 },
27 {
28 "kind": "updateFallthroughVariationOrRollout",
29 "rolloutWeights": {
30 "452f5fb5-7320-4ba3-81a1-8f4324f79d49": 90000,
31 "fc15f6a4-05d3-4aa4-a997-446be461345d": 10000
32 }
33 }
34 ]
35 }
36 }
37 ]
38}

Creating a workflow by applying a workflow template

You can also create a workflow by applying a workflow template. If you pass a valid workflow template key as the templateKey query parameter with the request, the API will attempt to create a new workflow with the stages defined in the workflow template with the corresponding key.

Applicability of stages

Templates are created in the context of a particular flag in a particular environment in a particular project. However, because workflows created from a template can be applied to any project, environment, and flag, some steps of the workflow may need to be updated in order to be applicable for the target resource.

You can pass a dryRun query parameter to tell the API to return a report of which steps of the workflow template are applicable in the target project/environment/flag, and which will need to be updated. When the dryRun query parameter is present the response body includes a meta property that holds a list of parameters that could potentially be inapplicable for the target resource. Each of these parameters will include a valid field. You will need to update any invalid parameters in order to create the new workflow. You can do this using the parameters property, which overrides the workflow template parameters.

Overriding template parameters

You can use the parameters property in the request body to tell the API to override the specified workflow template parameters with new values that are specific to your target project/environment/flag.

Click to expand example

Example request body

1{
2 "name": "workflow created from my-template",
3 "description": "description of my workflow",
4 "parameters": [
5 {
6 "_id": "62cf2bc4cadbeb7697943f3b",
7 "path": "/clauses/0/values",
8 "default": {
9 "value": ["updated-segment"]
10 }
11 },
12 {
13 "_id": "62cf2bc4cadbeb7697943f3d",
14 "path": "/variationId",
15 "default": {
16 "value": "abcd1234-abcd-1234-abcd-1234abcd12"
17 }
18 }
19 ]
20}

If there are any steps in the template that are not applicable to the target resource, the workflow will not be created, and the meta property will be included in the response body detailing which parameters need to be updated.

Path parameters

projectKeystringRequired

The project key

featureFlagKeystringRequired

The feature flag key

environmentKeystringRequired

The environment key

Query parameters

templateKeystringOptional

The template key to apply as a starting point for the new workflow

dryRunbooleanOptional

Whether to call the endpoint in dry-run mode

Request

This endpoint expects an object.
namestringRequired

The workflow name

maintainerIdstringOptional

The ID of the workflow maintainer. Defaults to the workflow creator.

descriptionstringOptional

The workflow description

stageslist of objectsOptional

A list of the workflow stages

templateKeystringOptional

The template key

Response

Workflow response

_idstring

The ID of the workflow

_versioninteger

The version of the workflow

_conflictslist of objects

Any conflicts that are present in the workflow stages

_creationDatelong

Timestamp of when the workflow was created

_maintainerIdstring

The member ID of the maintainer of the workflow. Defaults to the workflow creator.

namestring

The name of the workflow

_executionobject

The current execution status of the workflow

descriptionstringOptional

A brief description of the workflow

kindstringOptional

The kind of workflow

stageslist of objectsOptional

The stages that make up the workflow. Each stage contains conditions and actions.

metaobjectOptional

For workflows being created from a workflow template, this value holds any parameters that could potentially be incompatible with the current project, environment, or flag

templateKeystringOptional

For workflows being created from a workflow template, this value is the template’s key

Errors

Built with