Supported Workflows Actions
Introduction
Workflow Actions in IDP are integration points with third-party tools, used to take inputs from workflows frontend and execute specific tasks based on users input. The Workflows come with several built-in actions for fetching content, registering in the catalog and of course actions for creating and publishing a git repository.
There are several repository providers supported out of the box such as GitHub, Azure, GitLab and Bitbucket.
How To View Supported Actions
A list of all registered Workflow actions can be found under
Workflows/Create/Self Service
-> Installed Actions
Harness Specific Workflow Actions
1. trigger:harness-custom-pipeline
This action currently supports IDP Stage along with the Deploy Stage, Custom Stage(Available with Harness CD License or Free Tier usage), Pipelines using Pipeline Templates and codebase disabled Build Stage(Only Available with Harness CI License) with Run step.
This Worfklow action requires variables of type pipeline, stage or step as input along with the pipeline url, and then trigger the pipeline based in the inputset
obtained from the user.
Note: For pipelines using Git Experience make sure your URL includes
branch
andrepoName
e.g.,https://app.harness.io/ng/account/accountID/module/idp/orgs/orgID/projects/projectID/pipelines/pipelineID?repoName=repo-name&branch=branch
...
## Example
steps:
- id: trigger
name: Creating your react app
action: trigger:harness-custom-pipeline
input:
url: "https://app.harness.io/ng/account/vpCkHKsDSxK9_KYfjCTMKA/home/orgs/default/projects/communityeng/pipelines/IDP_New_NextJS_app/pipeline-studio/?storeType=INLINE"
inputset:
project_name: ${{ parameters.project_name }}
github_repo: ${{ parameters.github_repo }}
pipeline.variables.cloud_provider: ${{ parameters.provider }}
db: ${{ parameters.db }}
cache: ${{ parameters.cache }}
apikey: ${{ parameters.token }}
showOutputVariables: true
output:
text:
- title: Output Variable
content: |
Output Variable **test2** is `${{ steps.trigger.output.test2 }}`
- title: Another Output Variable
content: |
Output Variable **test1** with fqnPath is `${{ steps.trigger.output['pipeline.stages.testci.spec.execution.steps.Run_1.output.outputVariables.test1'] }}`
...
In the YAML example above, under inputset
, values such as project_name
and github_repo
are placeholders for pipeline variable names. You can use the reference format <+pipeline.variables.VARIABLE_NAME>
directly within the inputset
key-value pairs. For example, instead of simply specifying the variable name, you can reference the pipeline variable like this:
...
inputset:
pipeline.variables.project_name: ${{ parameters.project_name }}
pipeline.variables.github_repo: ${{ parameters.github_repo }}
...
...
To obtain these references, simply copy the variable path from the Harness Pipeline Studio UI. Please make sure to remove <+
& >
from the expression copied from UI.
Support for Stage Variables and Pipeline Templates
In addition to pipeline variables, you can also reference stage variables within the inputset
. Here’s how each type of variable can be referenced:
- Stage variable reference:
pipeline.stages.STAGE_IDENTIFIER.variables.VARIABLE_NAME
If you need to reference lower-level variables (such as stage, step group, and step variables) from outside their original scope, you must include the relative path to that variable. For instance, if you want to reference a stage variable from a different stage, you should use the format, pipeline.stages.originalStageID.variables.variableName
Instead of the simpler stage.variables.variableName
. This fully qualified path ensures the correct variable is referenced across stages, step groups, or steps.
inputset:
pipeline.variables.project_name: ${{ parameters.project_name }}
pipeline.stages.originalStageID.variables.github_repo: ${{ parameters.github_repo }}
To obtain these references, simply copy the variable path from the Harness Pipeline Studio UI and remove the special characters <+
and >
.
Note: This is the only way to reference stage variables and pipelines using templates with variables under
inputset
. Without the fully qualified path, the input will not be valid.
Variables under inputset | What's Supported |
---|---|
Variable name (variable_name ) | Supported with Pipelines Variables for IDP stage, custom stage and Codebase Disabled build stage along Pipelines not containing any templates. |
Variable name with Fully Qualified Path (pipeline.variables.variable_name ) | Supported with Pipelines Variables for all supported stages and Pipelines containing any templates. |
In the above example the apikey
parameter takes input from Harness Token which is specified under spec as a mandatory parameter as mentioned below
...
token:
title: Harness Token
type: string
ui:widget: password
ui:field: HarnessAuthToken
...
Without the above parameter input the pipeline won't be executed. Take a look at this example
The token
property we use to fetch Harness Auth Token is hidden on the Review Step using ui:widget: password
, but for this to work the token property needs to be mentioned under the first page
in-case you have multiple pages.
# example workflow.yaml
...
parameters:
- title: <PAGE-1 TITLE>
properties:
property-1:
title: title-1
type: string
property-2:
title: title-2
token:
title: Harness Token
type: string
ui:widget: password
ui:field: HarnessAuthToken
- title: <PAGE-2 TITLE>
properties:
property-1:
title: title-1
type: string
property-2:
title: title-2
- title: <PAGE-n TITLE>
...
Output
Title
: Name of the Pipeline.url
: Execution URL of the Pipeline e.g.:https://app.harness.io/ng/account/********************/module/idp-admin/orgs/default/projects/communityeng/pipelines/uniteddemo/executions/**********/pipeline?storeType=INLINE
Once you create the workflow with this Workflow action, you can see the pipeline URL running in the background and executing the flow.
You can now optionally remove the pipeline URL from the workflow execution logs, for this you need to use the boolean property hidePipelineURLLog
and set the value as true
.
## Example
steps:
- id: trigger
name: Creating your react app
action: trigger:harness-custom-pipeline
input:
url: "Pipeline URL"
hidePipelineURLLog: true
inputset:
project_name: ${{ parameters.project_name }}
apikey: ${{ parameters.token }}
- You can as well configure the output to display the pipeline output variables, by setting the
showOutputVariables: true
underinputs
and addingoutput
as shown in the example below:
...
output:
text:
- title: Output Variable
content: |
Output Variable **test2** is `${{ steps.trigger.output.test2 }}`
- title: Another Output Variable
content: |
Output Variable **test1** with fqnPath is `${{ steps.trigger.output['pipeline.stages.testci.spec.execution.steps.Run_1.output.outputVariables.test1'] }}`
...
Only user defined output variables are allowed, but you can as well use the system generated variables by assigning them as a new variable under shell script step as displayed below. For e.g. we have mentioned the system generated output as jira_id
and under Optional Configuration added a test-var which becomes a user defined output variable and could be displayed as output in the IDP workflows.
There are two ways in which you can add the output variable to the template syntax.
-
You can directly mention the output variable name
${{ steps.trigger.output.test2 }}
, heretest2
is the output variable name we created in the pipeline. -
You can copy the JEXL expression of the output variable and remove the JEXL constructs,
${{ steps.trigger.output['pipeline.stages.testci.spec.execution.steps.Run_1.output.outputVariables.test1'] }}
, here the partpipeline.stages.testci.spec.execution.steps.Run_1.output.outputVariables.test1
comes from<+pipeline.stages.testci.spec.execution.steps.Run_1.output.outputVariables.test2>
copied from execution logs.
2. trigger:trigger-pipeline-with-webhook
This Workflow action could be used to trigger a pipeline execution based on the input-set identifier and a webhook name. Usually a single deployment pipeline has different input-set as per the environment it's going to be deployed and developers can just specify the input-set ID aligning with the environment name to trigger the deployment pipeline.
Developers need to mention the input set identifier instead of the name in the workflows input, usually identifier are names devoid of any special characters and spaces, e.g., input set-test
name would have an identifier as inputsettest
. It is suggested to provide all the available input-set as enums
in the template to avoid any ambiguity by developers.
Here's an example workflow based on this source.
## Example
...
steps:
- id: trigger
name: Creating your react app
action: trigger:trigger-pipeline-with-webhook
input:
url: "YOUR PIPELINE URL"
inputSetName: ${{ parameters.inputSetName }}
triggerName: ${{ parameters.triggerName }}
apikey: ${{ parameters.token }}
...
In the above example the apikey
parameter takes input from Harness Token which is specified under spec as a mandatory parameter as mentioned below
...
token:
title: Harness Token
type: string
ui:widget: password
ui:field: HarnessAuthToken
...
Without the above parameter input the pipeline won't be executed. Take a look at this example
Output
API URL:
: The webhook URL used to execute the pipeline.Pipeline Details
: Redirects you to the pipeline in Harness Pipeline Editor.UI URL
: Lists all the recent executions of the pipeline.
Once you create the workflow with this Workflow action, you can see the pipeline URL running in the background and executing the flow.
3. harness:create-secret
4. harness:delete-secret
Workflow Actions Usage Limitations
Workflow Actions | Pipelines and Stages |
---|---|
trigger:harness-custom-pipeline | Supports only IDP Stage along with the Deploy Stage, Custom Stage(Available with Harness CD License or Free Tier usage), Pipelines using Pipeline Templates and codebase disabled Build Stage(Only Available with Harness CI License) with Run step |
trigger:trigger-pipeline-with-webhook | Supports all the pipelines with a custom webhook based trigger |