Executions API¶
API endpoints for managing workflow executions.
List Executions¶
Retrieve execution history with optional filtering.
Query Parameters¶
| Parameter | Type | Default | Description |
|---|---|---|---|
offset |
integer | 0 | Pagination offset |
limit |
integer | 20 | Items per page (max 100) |
workflowId |
string | - | Filter by workflow |
status |
string | - | Filter by status |
mode |
string | - | Filter by execution mode |
since |
datetime | - | Executions since timestamp |
until |
datetime | - | Executions until timestamp |
Status Values¶
| Status | Description |
|---|---|
pending |
Queued, waiting to run |
running |
Currently executing |
completed |
Completed successfully |
failed |
Completed with errors |
cancelled |
Manually cancelled |
Mode Values¶
| Mode | Description |
|---|---|
manual |
Started via API/CLI |
scheduled |
Triggered by schedule |
webhook |
Triggered by webhook |
Example Request¶
curl "http://localhost:8080/api/v1/executions?workflowId=wf-123&status=failed&limit=10" \
-H "Authorization: Bearer <token>"
Response¶
{
"data": [
{
"id": "exec-123456",
"workflowId": "550e8400-e29b-41d4-a716-446655440000",
"workflowName": "Daily Report",
"status": "completed",
"mode": "manual",
"startedAt": "2024-01-26T10:00:00Z",
"finishedAt": "2024-01-26T10:00:01Z",
"duration": 1234
}
],
"executions": [
{
"id": "exec-123456",
"status": "completed"
}
],
"total": 150,
"offset": 0,
"limit": 20
}
Get Execution¶
Retrieve detailed execution information.
Example Request¶
Response¶
{
"id": "exec-123456",
"workflowId": "550e8400-e29b-41d4-a716-446655440000",
"workflowName": "Daily Report",
"status": "completed",
"mode": "manual",
"startedAt": "2024-01-26T10:00:00Z",
"finishedAt": "2024-01-26T10:00:01Z",
"duration": 1234,
"inputData": [
{
"json": {
"key": "value"
}
}
],
"data": [
{
"json": {
"result": "processed"
}
}
],
"nodeExecutions": [
{
"nodeId": "start-1",
"nodeName": "Start",
"status": "completed",
"startedAt": "2024-01-26T10:00:00.000Z",
"finishedAt": "2024-01-26T10:00:00.001Z",
"duration": 1,
"outputData": [{"json": {}}]
},
{
"nodeId": "http-1",
"nodeName": "Fetch Data",
"status": "completed",
"startedAt": "2024-01-26T10:00:00.001Z",
"finishedAt": "2024-01-26T10:00:00.824Z",
"duration": 823,
"outputData": [{"json": {"response": "..."}}]
}
]
}
Failed Execution Response¶
{
"id": "exec-789",
"status": "failed",
"error": {
"message": "HTTP request failed: connection timeout",
"node": "Fetch Data",
"nodeId": "http-1"
},
"nodeExecutions": [
{
"nodeId": "start-1",
"status": "success"
},
{
"nodeId": "http-1",
"status": "failed",
"error": "connection timeout"
}
]
}
Delete Execution¶
Delete an execution record.
Example Request¶
curl -X DELETE http://localhost:8080/api/v1/executions/exec-123456 \
-H "Authorization: Bearer <token>"
Response¶
Retry Execution¶
Retry a failed execution with the same input data.
Example Request¶
curl -X POST http://localhost:8080/api/v1/executions/exec-789/retry \
-H "Authorization: Bearer <token>"
Response¶
{
"id": "exec-790",
"workflowId": "550e8400-e29b-41d4-a716-446655440000",
"status": "completed",
"mode": "retry",
"startedAt": "2024-01-26T16:00:00Z",
"finishedAt": "2024-01-26T16:00:01Z"
}
Cancel Execution¶
Cancel a running execution.
Example Request¶
curl -X POST http://localhost:8080/api/v1/executions/exec-running/cancel \
-H "Authorization: Bearer <token>"
Response (cancellation requested)¶
{
"message": "Cancellation requested",
"executionId": "exec-running",
"status": "cancel_requested"
}
Status code: 202 Accepted
Response (runtime cannot cancel this execution)¶
{
"error": true,
"message": "Execution is running but cancellation is not supported by this runtime",
"executionId": "exec-running",
"status": "running"
}
Status code: 409 Conflict
Bulk Delete¶
Delete multiple executions.
Request Body¶
Or filter-based deletion:
Example Request¶
curl -X POST http://localhost:8080/api/v1/executions/delete \
-H "Authorization: Bearer <token>" \
-H "Content-Type: application/json" \
-d '{
"workflowId": "wf-123",
"status": "success",
"olderThan": "2024-01-01T00:00:00Z"
}'
Response¶
Execution Statistics¶
Get execution statistics.
Query Parameters¶
| Parameter | Type | Description |
|---|---|---|
workflowId |
string | Filter by workflow |
since |
datetime | Stats since timestamp |
Example Request¶
curl "http://localhost:8080/api/v1/executions/stats?since=2024-01-01" \
-H "Authorization: Bearer <token>"
Response¶
{
"total": 1500,
"success": 1400,
"failed": 80,
"cancelled": 20,
"averageDuration": 1234,
"byWorkflow": [
{
"workflowId": "wf-123",
"workflowName": "Daily Report",
"total": 365,
"success": 360,
"failed": 5
}
],
"byDay": [
{
"date": "2024-01-26",
"total": 50,
"success": 48,
"failed": 2
}
]
}
Error Responses¶
404 Not Found¶
409 Conflict¶
{
"error": true,
"message": "Execution is running but cancellation is not supported by this runtime",
"executionId": "exec-running",
"status": "running"
}