Create and manage organizations in your account. You use organizations to group together related projects. For example, you can use an organization to group together projects within a business unit or division.
- Send event
Harness NextGen Software Delivery Platform API Reference (1.0)
The Harness Software Delivery Platform uses OpenAPI Specification v3.0. Harness constantly improves these APIs. Please be aware that some improvements could cause breaking changes.
The Harness API allows you to integrate and use all the services and modules we provide on the Harness Platform. If you use client-side SDKs, Harness functionality can be integrated with your client-side automation, helping you reduce manual efforts and deploy code faster.
For more information about how Harness works, read our documentation or visit the Harness Developer Hub.
The Harness API is a RESTful API that uses standard HTTP verbs. You can send requests in JSON, YAML, or form-data format. The format of the response matches the format of your request. You must send a single request at a time and ensure that you include your authentication key. For more information about this, go to Authentication.
Before you start integrating, get to know our API better by reading the following topics:
The methods you need to integrate with depend on the functionality you want to use. Work with your Harness Solutions Engineer to determine which methods you need.
To authenticate with the Harness API, you need to:
- Generate an API token on the Harness Platform.
- Send the API token you generate in the
x-api-keyheader in each request.
To generate an API token, complete the following steps:
- Go to the Harness Platform.
- On the left-hand navigation, click My Profile.
- Click +API Key, enter a name for your key and then click Save.
- Within the API Key tile, click +Token.
- Enter a name for your token and click Generate Token. Important: Make sure to save your token securely. Harness does not store the API token for future reference, so make sure to save your token securely before you leave the page.
Send the token you created in the Harness Platform in the x-api-key header. For example: x-api-key: YOUR_API_KEY_HERE
The structure for each request and response is outlined in the API documentation. We have examples in JSON and YAML for every request and response. You can use our online editor to test the examples.
| Field Name | Type | Default | Description |
|---|---|---|---|
| identifier | string | none | URL-friendly version of the name, used to identify a resource within it's scope and so needs to be unique within the scope. |
| name | string | none | Human-friendly name for the resource. |
| org | string | none | Limit to provided org identifiers. |
| project | string | none | Limit to provided project identifiers. |
| description | string | none | More information about the specific resource. |
| tags | map[string]string | none | List of labels applied to the resource. |
| order | string | desc | Order to use when sorting the specified fields. Type: enum(asc,desc). |
| sort | string | none | Fields on which to sort. Note: Specify the fields that you want to use for sorting. When doing so, consider the operational overhead of sorting fields. |
| limit | int | 30 | Pagination: Number of items to return. |
| page | int | 1 | Pagination page number strategy: Specify the page number within the paginated collection related to the number of items in each page. |
| created | int64 | none | Unix timestamp that shows when the resource was created (in milliseconds). |
| updated | int64 | none | Unix timestamp that shows when the resource was last edited (in milliseconds). |
Harness uses conventional HTTP status codes to indicate the status of an API request. Generally, 2xx responses are reserved for success and 4xx status codes are reserved for failures. A 5xx response code indicates an error on the Harness server.
| Error Code | Description |
|---|---|
| 200 | OK |
| 201 | Created |
| 202 | Accepted |
| 204 | No Content |
| 400 | Bad Request |
| 401 | Unauthorized |
| 403 | Forbidden |
| 412 | Precondition Failed |
| 415 | Unsupported Media Type |
| 500 | Server Error |
To view our error response structures, go here.
The current version of our Beta APIs is yet to be announced. The version number will use the date-header format and will be valid only for our Beta APIs.
All our beta APIs are versioned as a Generation, and this version is included in the path to every API resource. For example, v1 beta APIs begin with app.harness.io/v1/, where v1 is the API Generation.
The version number represents the core API and does not change frequently. The version number changes only if there is a significant departure from the basic underpinnings of the existing API. For example, when Harness performs a system-wide refactoring of core concepts or resources.
We use pagination to place limits on the number of responses associated with list endpoints. Pagination is achieved by the use of limit query parameters. The limit defaults to 30. Its maximum value is 100.
Following are the pagination headers supported in the response bodies of paginated APIs:
- X-Total-Elements : Indicates the total number of entries in a paginated response.
- X-Page-Number : Indicates the page number currently returned for a paginated response.
- X-Page-Size : Indicates the number of entries per page for a paginated response.
For example:
X-Total-Elements : 30
X-Page-Number : 0
X-Page-Size : 10Request
Configures time-to-live settings to automatically destroy infrastructure and optionally delete the workspace.
Delete workspace after N hours or days from now
Specific date to delete workspace (ISO 8601 format, e.g. 2026-09-02)
Whether to delete the workspace record after infrastructure is destroyed
Destroy infrastructure after N hours or days from now
Specific date to destroy infrastructure (ISO 8601 format, e.g. 2026-08-24)
- Harness host URLhttps://app.harness.io/iacm/api/orgs/{org}/projects/{project}/workspaces/{workspace}/ephemeral-config
- Vanity URLhttps://app.harness.io/iacm/api/orgs/{org}/projects/{project}/workspaces/{workspace}/ephemeral-config
- curl
- JavaScript
- Node.js
- Python
- Java
- C#
- PHP
- Go
- Ruby
- R
- Payload
curl -i -X PUT \
'https://app.harness.io/iacm/api/orgs/e5/projects/5/workspaces/Voluptatem consequatur perferendis est vero perferendis maxime./ephemeral-config' \
-H 'Content-Type: application/json' \
-H 'Harness-Account: c' \
-H 'x-api-key: YOUR_API_KEY_HERE' \
-d '{
"delete_delay_unit": "days",
"delete_delay_value": 5658182695913891000,
"delete_on_date": "Repellendus ipsum consectetur dolorem possimus et laboriosam.",
"delete_workspace": true,
"destroy_delay_unit": "hours",
"destroy_delay_value": 7377461511445357000,
"destroy_on_date": "Laboriosam tempora.",
"pipeline_id": "Cumque aut asperiores in qui.",
"provisioner": "Occaecati nesciunt laudantium temporibus officiis autem."
}'{ "delete_at": "Necessitatibus ut in expedita.", "destroy_at": "Natus porro et aut quis saepe dicta.", "status": "Magni id." }
The type of event that occurred
Deprecated: use metadata instead
- Harness host URLhttps://app.harness.io/iacm/api/orgs/{org}/projects/{project}/workspaces/{workspace}/events
- Vanity URLhttps://app.harness.io/iacm/api/orgs/{org}/projects/{project}/workspaces/{workspace}/events
- curl
- JavaScript
- Node.js
- Python
- Java
- C#
- PHP
- Go
- Ruby
- R
- Payload
curl -i -X POST \
https://app.harness.io/iacm/api/orgs/8vd/projects/z9b/workspaces/igs/events \
-H 'Content-Type: application/json' \
-H 'Harness-Account: 9y' \
-H 'x-api-key: YOUR_API_KEY_HERE' \
-d '{
"data": {
"Ea incidunt sed cumque.": "Nesciunt aut."
},
"event_type": "drifted",
"metadata": {
"PlannedChangesCount": 2804434113934260000,
"activity_status": "incomplete",
"activity_type": "import",
"cost_breakdown_uuid": "Ut et qui voluptatem quo deleniti.",
"cost_currency": "Ipsam delectus.",
"cost_diff_total_monthly": "Dolor distinctio.",
"cost_diff_uuid": "Illo quos earum odio voluptatem unde.",
"cost_past_total_monthly": "Autem qui vitae.",
"cost_total_monthly": "Fugiat similique dolores vel officia placeat impedit.",
"cost_total_monthly_percentage_change": "Vel sed nisi nemo.",
"data_length": 4005858975216118000,
"drift_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"enable_solutions_factory": true,
"git_branch": "Mollitia consectetur voluptatem qui nesciunt ut.",
"git_commit_message": "Maxime vel aut autem.",
"git_commit_sha": "Quae laudantium molestiae inventore repellendus.",
"git_repo": "Sit asperiores omnis tempora possimus maxime neque.",
"modules_uuid": "Fuga dolorem excepturi ut ratione.",
"output_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"pipeline": "Sapiente officia dolores voluptatem rem.",
"pipeline_execution_id": "Ut repellendus non illum.",
"pipeline_execution_number": "Ut doloribus.",
"pipeline_name": "Doloremque veritatis cumque adipisci occaecati distinctio.",
"pipeline_stage_id": "Nobis optio nesciunt cupiditate aperiam libero impedit.",
"plan_uuid": "Voluptas maiores soluta et vel ipsam nobis.",
"providers_uuid": "Saepe blanditiis quas vel voluptate esse.",
"provisioner": "Libero reiciendis est dignissimos in magnam.",
"provisioner_version": "Aspernatur enim laboriosam numquam deleniti.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"stacks": [
{
"assets_uuid": "Ad quo occaecati ratione.",
"error_message": "Non vero.",
"manifest_uuid": "Architecto ipsum mollitia.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"stack_name": "Illum rerum atque rerum ipsa maiores.",
"stack_outputs": {
"Est quia facilis maxime.": "Quibusdam totam praesentium ut sunt eius accusamus."
},
"stack_path": "Odio expedita enim sit.",
"status": "skipped",
"template_uuid": "Consequuntur laudantium excepturi.",
"tree_uuid": "Occaecati voluptate animi quas consequatur vel."
},
{
"assets_uuid": "Ad quo occaecati ratione.",
"error_message": "Non vero.",
"manifest_uuid": "Architecto ipsum mollitia.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"stack_name": "Illum rerum atque rerum ipsa maiores.",
"stack_outputs": {
"Est quia facilis maxime.": "Quibusdam totam praesentium ut sunt eius accusamus."
},
"stack_path": "Odio expedita enim sit.",
"status": "skipped",
"template_uuid": "Consequuntur laudantium excepturi.",
"tree_uuid": "Occaecati voluptate animi quas consequatur vel."
},
{
"assets_uuid": "Ad quo occaecati ratione.",
"error_message": "Non vero.",
"manifest_uuid": "Architecto ipsum mollitia.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"stack_name": "Illum rerum atque rerum ipsa maiores.",
"stack_outputs": {
"Est quia facilis maxime.": "Quibusdam totam praesentium ut sunt eius accusamus."
},
"stack_path": "Odio expedita enim sit.",
"status": "skipped",
"template_uuid": "Consequuntur laudantium excepturi.",
"tree_uuid": "Occaecati voluptate animi quas consequatur vel."
},
{
"assets_uuid": "Ad quo occaecati ratione.",
"error_message": "Non vero.",
"manifest_uuid": "Architecto ipsum mollitia.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"stack_name": "Illum rerum atque rerum ipsa maiores.",
"stack_outputs": {
"Est quia facilis maxime.": "Quibusdam totam praesentium ut sunt eius accusamus."
},
"stack_path": "Odio expedita enim sit.",
"status": "skipped",
"template_uuid": "Consequuntur laudantium excepturi.",
"tree_uuid": "Occaecati voluptate animi quas consequatur vel."
}
],
"state_checksum": "Eius beatae nihil nam aut veniam atque.",
"state_uuid": "Harum cum molestiae repellat quo quisquam.",
"terragrunt_details": [
{
"cost_breakdown_uuid": "Dolores hic ratione ut nesciunt asperiores culpa.",
"cost_currency": "Nostrum qui.",
"cost_diff_total_monthly": "Repellat ad.",
"cost_diff_uuid": "Aut voluptatem rerum et ut.",
"cost_past_total_monthly": "Accusantium ut.",
"cost_total_monthly": "Quia beatae minus.",
"cost_total_monthly_percentage_change": "Delectus eveniet sint quaerat excepturi.",
"drift_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"output_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"path_id": "Adipisci repellat optio dolor corporis cumque.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"state_file_link": "Nostrum optio aut hic blanditiis iusto sint.",
"status": "Velit enim quidem laborum consequuntur tenetur praesentium."
},
{
"cost_breakdown_uuid": "Dolores hic ratione ut nesciunt asperiores culpa.",
"cost_currency": "Nostrum qui.",
"cost_diff_total_monthly": "Repellat ad.",
"cost_diff_uuid": "Aut voluptatem rerum et ut.",
"cost_past_total_monthly": "Accusantium ut.",
"cost_total_monthly": "Quia beatae minus.",
"cost_total_monthly_percentage_change": "Delectus eveniet sint quaerat excepturi.",
"drift_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"output_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"path_id": "Adipisci repellat optio dolor corporis cumque.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"state_file_link": "Nostrum optio aut hic blanditiis iusto sint.",
"status": "Velit enim quidem laborum consequuntur tenetur praesentium."
},
{
"cost_breakdown_uuid": "Dolores hic ratione ut nesciunt asperiores culpa.",
"cost_currency": "Nostrum qui.",
"cost_diff_total_monthly": "Repellat ad.",
"cost_diff_uuid": "Aut voluptatem rerum et ut.",
"cost_past_total_monthly": "Accusantium ut.",
"cost_total_monthly": "Quia beatae minus.",
"cost_total_monthly_percentage_change": "Delectus eveniet sint quaerat excepturi.",
"drift_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"output_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"path_id": "Adipisci repellat optio dolor corporis cumque.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"state_file_link": "Nostrum optio aut hic blanditiis iusto sint.",
"status": "Velit enim quidem laborum consequuntur tenetur praesentium."
},
{
"cost_breakdown_uuid": "Dolores hic ratione ut nesciunt asperiores culpa.",
"cost_currency": "Nostrum qui.",
"cost_diff_total_monthly": "Repellat ad.",
"cost_diff_uuid": "Aut voluptatem rerum et ut.",
"cost_past_total_monthly": "Accusantium ut.",
"cost_total_monthly": "Quia beatae minus.",
"cost_total_monthly_percentage_change": "Delectus eveniet sint quaerat excepturi.",
"drift_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"output_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"path_id": "Adipisci repellat optio dolor corporis cumque.",
"resource_counts": {
"added": 5452058477675979000,
"changed": 1695353077733875500,
"deleted": 8575944221100701000,
"imported": 7694534750416046000,
"removed": 685647354458541400,
"unchanged": 6822933890220024000
},
"state_file_link": "Nostrum optio aut hic blanditiis iusto sint.",
"status": "Velit enim quidem laborum consequuntur tenetur praesentium."
}
],
"trigger": {
"Excepturi rerum corrupti reprehenderit libero in architecto.": "Accusantium sunt magni tenetur ut.",
"Inventore nostrum perferendis impedit architecto necessitatibus ipsum.": "Libero repellat voluptate voluptatibus."
}
},
"pipeline_execution_id": "Quidem quia quia voluptate repellendus.",
"pipeline_stage_id": "Facilis quis dicta illum."
}'- Harness host URLhttps://app.harness.io/iacm/api/orgs/{org}/projects/{project}/workspaces/{workspace}/pipelines
- Vanity URLhttps://app.harness.io/iacm/api/orgs/{org}/projects/{project}/workspaces/{workspace}/pipelines
- curl
- JavaScript
- Node.js
- Python
- Java
- C#
- PHP
- Go
- Ruby
- R
- Payload
curl -i -X GET \
'https://app.harness.io/iacm/api/orgs/2j/projects/6s/workspaces/Amet explicabo unde./pipelines?limit=30&page=1' \
-H 'Harness-Account: 746' \
-H 'x-api-key: YOUR_API_KEY_HERE'{ "account": "jgy", "org": "l8", "pipelines": [ "Perferendis laudantium officiis sed illo ea aperiam.", "Maxime nihil aut quia laborum.", "Voluptates corporis aut voluptatem quis laborum." ], "project": "g" }