docs/versioned_docs/version-1.9.0/API-Reference/workflows-api.mdx
import CodeSnippet from '@site/src/components/CodeSnippet'; import exampleWorkflowsApiExampleSynchronousRequest from '!!raw-loader!@site/docs/API-Reference/curl-examples/workflows-api/example-synchronous-request.sh'; import exampleWorkflowsApiExampleAsynchronousRequest from '!!raw-loader!@site/docs/API-Reference/curl-examples/workflows-api/example-asynchronous-request.sh'; import exampleWorkflowsApiExampleRequest from '!!raw-loader!@site/docs/API-Reference/curl-examples/workflows-api/example-request.sh'; import exampleWorkflowsApiExampleRequest2 from '!!raw-loader!@site/docs/API-Reference/curl-examples/workflows-api/example-request-2.sh'; import examplePythonWorkflowsApiExampleSynchronousRequest from '!!raw-loader!@site/docs/API-Reference/python-examples/workflows-api/example-synchronous-request.py'; import examplePythonWorkflowsApiExampleAsynchronousRequest from '!!raw-loader!@site/docs/API-Reference/python-examples/workflows-api/example-asynchronous-request.py'; import examplePythonWorkflowsApiExampleRequest from '!!raw-loader!@site/docs/API-Reference/python-examples/workflows-api/example-request.py'; import examplePythonWorkflowsApiExampleRequest2 from '!!raw-loader!@site/docs/API-Reference/python-examples/workflows-api/example-request-2.py'; import exampleJavascriptWorkflowsApiExampleSynchronousRequest from '!!raw-loader!@site/docs/API-Reference/javascript-examples/workflows-api/example-synchronous-request.js'; import exampleJavascriptWorkflowsApiExampleAsynchronousRequest from '!!raw-loader!@site/docs/API-Reference/javascript-examples/workflows-api/example-asynchronous-request.js'; import exampleJavascriptWorkflowsApiExampleRequest from '!!raw-loader!@site/docs/API-Reference/javascript-examples/workflows-api/example-request.js'; import exampleJavascriptWorkflowsApiExampleRequest2 from '!!raw-loader!@site/docs/API-Reference/javascript-examples/workflows-api/example-request-2.js';
import Tabs from '@theme/Tabs'; import TabItem from '@theme/TabItem'; import PartialAPISetup from '@site/docs/_partial-api-setup.mdx';
:::warning Beta Feature The Workflow API is currently in Beta. The API endpoints and response formats may change in future releases. :::
The Workflow API provides programmatic access to execute Langflow workflows synchronously or asynchronously. Synchronous requests receive complete results immediately upon completion. Asynchronous requests are queued in the background and will run until complete, or a request is issued to the Stop Workflow endpoint.
The Workflow API is part of the Langflow Developer v2 API and offers enhanced workflow execution capabilities compared to the v1 /run endpoint.
Endpoint:
POST /api/v2/workflows
Description: Execute a workflow synchronously and receive complete results immediately upon completion.
Set background=false to make the request synchronous.
Execute a workflow synchronously and receive complete results immediately:
<Tabs> <TabItem value="Python" label="Python" default> <CodeSnippet source={examplePythonWorkflowsApiExampleSynchronousRequest} language="python" /> </TabItem> <TabItem value="JavaScript" label="JavaScript"> <CodeSnippet source={exampleJavascriptWorkflowsApiExampleSynchronousRequest} language="javascript" /> </TabItem> <TabItem value="curl" label="curl"> <CodeSnippet source={exampleWorkflowsApiExampleSynchronousRequest} language="bash" /> </TabItem> </Tabs>For long-running workflows, set background=true to get a job_id immediately, and then poll the status using the GET endpoint until the job is complete.
To stop a job, send a POST request to the Stop workflow endpoint.
:::tip
The asynchronous request contains stream parameter, but streaming is not yet supported. The parameter is included for future compatibility.
:::
Example request:
<Tabs> <TabItem value="Python" label="Python" default> <CodeSnippet source={examplePythonWorkflowsApiExampleAsynchronousRequest} language="python" /> </TabItem> <TabItem value="JavaScript" label="JavaScript"> <CodeSnippet source={exampleJavascriptWorkflowsApiExampleAsynchronousRequest} language="javascript" /> </TabItem> <TabItem value="curl" label="curl"> <CodeSnippet source={exampleWorkflowsApiExampleAsynchronousRequest} language="bash" /> </TabItem> </Tabs>Response:
{
"job_id": "job_id_1234567890",
"created_timestamp": "2025-01-15T10:30:00Z",
"status": "queued",
"errors": []
}
| Field | Type | Required | Default | Description |
|---|---|---|---|---|
flow_id | string | Yes | - | The ID or endpoint name of the flow to execute. |
flow_version | string | No | - | Optional version hash to pin to a specific flow version. |
background | boolean | No | false | Must be false for synchronous execution. |
inputs | object | No | {} | Inputs for the workflow execution. Uses component identifiers with dot notation (e.g., ChatInput-abc.input_value). See Component identifiers and input structure for detailed information. |
{
"flow_id": "flow_67ccd2be17f0819081ff3bb2cf6508e60bb6a6b452d3795b",
"job_id": "job_id_1234567890",
"object": "response",
"created_at": 1741476542,
"status": "completed",
"errors": [],
"inputs": {
"ChatInput-abc.input_type": "chat",
"ChatInput-abc.input_value": "what is 2+2",
"ChatInput-abc.session_id": "session-123"
},
"outputs": {
"ChatOutput-xyz": {
"type": "message",
"component_id": "ChatOutput-xyz",
"status": "completed",
"content": "2 + 2 equals 4."
}
},
"metadata": {}
}
The response includes an outputs field containing component-level results. Each output has a type field indicating the type of content:
| Type | Description | Example |
|---|---|---|
message | Text message content. | Chat responses, summaries |
image | Image URL or data. | Generated images, processed images |
sql | SQL query results. | Database query outputs |
data | Structured data. | JSON objects, arrays |
file | File reference. | Generated documents, reports |
Endpoint: GET /api/v2/workflows
Description: Retrieve the status and results of a workflow execution by job ID.
| Parameter | Type | Required | Description |
|---|---|---|---|
job_id | string | Yes | The job ID returned from a workflow execution. |
stream | boolean | No | If true, returns server-sent events stream. Default: false. |
sequence_id | integer | No | Optional sequence ID to resume streaming from a specific point. |
{
"flow_id": "flow_67ccd2be17f0819081ff3bb2cf6508e60bb6a6b452d3795b",
"job_id": "job_id_1234567890",
"object": "response",
"created_at": 1741476542,
"status": "completed",
"errors": [],
"outputs": {
"ChatOutput-xyz": {
"type": "message",
"component_id": "ChatOutput-xyz",
"status": "completed",
"content": "Processing complete..."
}
},
"input": [
{
"type": "text",
"data": "Input text prompt for the workflow execution",
"role": "User"
}
],
"metadata": {}
}
The response includes a status field that indicates the current state of the workflow execution:
| Status | Description |
|---|---|
queued | Job is queued and waiting to start. |
in_progress | Job is currently executing. |
completed | Job completed successfully. |
failed | Job failed during execution. |
error | Job encountered an error. |
Endpoint: POST /api/v2/workflows/stop
Description: Stop a running workflow execution by job ID.
| Field | Type | Required | Default | Description |
|---|---|---|---|---|
job_id | string | Yes | - | The job ID of the workflow to stop. |
{
"job_id": "job_id_1234567890",
"message": "Job job_id_1234567890 cancelled successfully."
}
The Workflows API uses component identifiers with dot notation to specify inputs for individual components in your workflow. This allows you to pass values to specific components and override component parameters.
Component identifiers use the format {component_id}.{parameter_name}.
When making requests to the Workflows API, include component identifiers in the inputs object.
For example, this demonstrates targeting multiple components and their parameters in a single request.
{
"flow_id": "your-flow-id",
"inputs": {
"ChatInput-abc.input_type": "chat",
"ChatInput-abc.input_value": "what is 2+2",
"ChatInput-abc.session_id": "session-123",
"OpenSearchComponent-xyz.opensearch_url": "https://opensearch:9200",
"LLMComponent-123.temperature": 0.7,
"LLMComponent-123.max_tokens": 100
}
}
To find the component ID in the Langflow UI, open your flow in Langflow, click the component, and then click Controls. The component ID is at the top of the Controls pane.
You can override any component's parameters.
The API uses standard HTTP status codes to indicate success or failure:
| Status Code | Description |
|---|---|
200 OK | Request successful. |
400 Bad Request | Invalid request parameters. |
401 Unauthorized | Invalid or missing API key. |
404 Not Found | Flow not found or developer API disabled. |
500 Internal Server Error | Server error during execution. |
501 Not Implemented | Endpoint not yet implemented. |
{
"detail": "Error message describing what went wrong"
}