Batch Run Workflow

Submit a batch of files to run through a specified workflow.

This endpoint allows you to efficiently initiate large batches of workflow runs in a single request (up to 1,000 in a single request, but you can queue up multiple batches in rapid succession). It accepts an array of inputs, each containing a file and metadata pair. The primary use case for this endpoint is for doing large bulk runs of >1000 files at a time that can process over the course of a few hours without needing to manage rate limits that would likely occur using the primary run endpoint.

Unlike the single Run Workflow endpoint which returns the details of the created workflow runs immediately, this batch endpoint returns a batchId.

Our recommended usage pattern is to integrate with Webhooks for consuming results, using the metadata and batchId to match up results to the original inputs in your downstream systems. However, you can integrate in a polling mechanism by using a combination of the List Workflow Runs endpoint to fetch all runs via a batch, and then Get Workflow Run to fetch the full outputs each run.

Body

workflowId
stringRequired

The ID of the workflow that the inputs will be run through. This ID can be found by viewing the workflow on the Extend platform.

version
string

An optional version of the workflow to use. This can be a specific version number (e.g., "1", "2") found on the Extend platform, or "draft" to use the current unpublished draft version. When a version is not supplied, the latest deployed version of the workflow will be used.

inputs
Input[]Required

An array of input objects to be processed by the workflow. Each object represents a single workflow run to be created. The array must contain at least 1 input and at most 1000 inputs.

file
object

Specifies a file to be processed. Either file or rawText must be provided for each input.

fileUrl
string

A presigned URL for the file. For the batch endpoint, we suggest a slightly longer expiration time, ideally 30 minutes for a worst case scenario.

fileId
string

An existing Extend file ID (e.g., from a previous workflow run or file upload). If provided, Extend will reuse the existing file data. Either fileUrl or fileId must be provided if the file object is used.

fileName
string

The name to associate with the file. If not provided when using fileUrl, the name may be inferred from the URL. This param is only for your reference, and will be rendered in our dashboard, it is not used by the workflow.

rawText
string

A string containing raw text data to be processed. This will be treated as a .txt file by the workflow. Use the file parameter for structured data or specific file types. Either file or rawText must be provided for each input.

metadata
object

An optional object containing arbitrary key-value pairs to associate with this specific workflow run. This metadata will be included in webhook payloads and responses when fetching the workflow run details.

secrets
object

An optional object containing secrets to be used by processors within the workflow for this specific run. Secrets provided here override any globally configured secrets for the workflow.

Response

success
boolean

Indicates whether the batch request was successfully accepted and queued. true signifies success.

batchId
string

A unique identifier for the submitted batch. This ID can be used to correlate the workflow runs created by this request. You can find this batchId associated with individual runs when listing workflow runs or in webhook payloads.

Processing and Monitoring

Upon successful submission, the endpoint returns a batchId. The individual workflow runs are then queued for processing.

  • Monitoring: Track the progress and consume results of individual runs using Webhooks. Subscribe to events like workflow_run.completed, workflow_run.failed, etc. The webhook payload for these events will include the corresponding batchId and the metadata you provided for each input.
  • Fetching Results: You can also use the List Workflow Runs endpoint and filter using the batchId query param.

Error Responses

Common errors include:

  • 400 Bad Request: Invalid request body (e.g., missing required fields, array size limits exceeded, issues with fileUrl or fileId). The response body will contain an error message detailing the specific validation issues. Can also indicate issues accessing a provided fileUrl.
  • 401 Unauthorized: Missing or invalid API token.
  • 403 Forbidden: The API token does not have permission to access the specified workflow.
  • 404 Not Found: The specified workflowId or version does not exist.
  • 429 Too Many Requests: The request was rate limited. Please try again later.
  • 500 Internal Server Error: An unexpected error occurred on the server.