The Queue API makes it easy to manage inference jobs for your deployed ComfyUI workflows. You can use it to submit new jobs, track their progress, retrieve results, and cancel them whenever necessary.

Queue endpoints

Base URL: https://api.runcomfy.net
EndpointMethodDescription
/prod/v1/deployments/{deployment_id}/inferencePOSTRun workflow
/prod/v1/deployments/{deployment_id}/requests/{request_id}/statusGETCheck job status
/prod/v1/deployments/{deployment_id}/requests/{request_id}/resultGETGet job result
/prod/v1/deployments/{deployment_id}/requests/{request_id}/cancelPOSTCancel job

Common Path Parameters

  • deployment_id: string (required)
    This is the unique ID for your deployed workflow. You get it when you create a deployment. It tells the server which workflow to use.
  • request_id: string (required, except for submission)
    This is the unique ID for a specific job, given back when you submit a request.

Submitting a Request

POST /prod/v1/deployments/{deployment_id}/inference Use this endpoint to start a new inference job. When you deploy a workflow on RunComfy, the platform stores its workflow_api.json as the base configuration for that deployment. By default, each POST to this endpoint runs that cloud-saved workflow and lets you tweak inputs via overrides. For advanced cases, you can instead include a complete different workflow_api.json inline and skip the cloud-saved workflow entirely.

Using Cloud-Saved Workflow

In this mode, the server uses the deployment’s cloud-saved workflow’s workflow_api.json and applies any per-request changes you send in overrides. Unspecified values fall back to the saved defaults. overrides reference the workflow_api.json, target specific nodes (by ID) and updates only their inputs. For guidance on valid ranges, types, and defaults, refer to the object_info.json. Read more about workflow_api.json and object_info.json here. The following snippet shows two nodes from a sample flux_workflow_api.json file, illustrating typical structure with inputs like text prompts and seeds. View the complete example here: runcomfy-flux-workflow-api.json.
{
  "6": {
    "inputs": {
      "text": "Add ASCII style text only the single word \"Kontext\" no additional letters to the display",
      "speak_and_recognation": {
        "__value__": [
          false,
          true
        ]
      },
      "clip": [
        "38",
        0
      ]
    },
    "class_type": "CLIPTextEncode",
    "_meta": {
      "title": "CLIP Text Encode (Positive Prompt)"
    }
  },
  "31": {
    "inputs": {
      "seed": 736220757721744,
      "steps": 20,
      "cfg": 1,
      "sampler_name": "euler",
      "scheduler": "simple",
      "denoise": 1,
      "model": [
        "37",
        0
      ],
      "positive": [
        "35",
        0
      ],
      "negative": [
        "135",
        0
      ],
      "latent_image": [
        "124",
        0
      ]
    },
    "class_type": "KSampler",
    "_meta": {
      "title": "KSampler"
    }
  }
}
Based on the above snippet, overrides can be written as follows to update the prompt and seed without altering other parts of the workflow:
{
  "overrides": {
    "6": {
      "inputs": {
        "text": "futuristic cityscape"
      }
    },
    "31": {
      "inputs": {
        "seed": 987654321
      }
    }
  }
}

Request Example - Basic

For example, this request overrides the seed in KSampler (ID "31") and the text in CLIPTextEncode (ID "6") from flux_kontext_workflow_api.json.
curl --request POST \
  --url https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/inference \
  --header "Content-Type: application/json" \
  --header "Authorization: Bearer <token>" \
  --data '{
    "overrides": {
      "31": {
        "inputs": {
          "seed": 987654321
        }
      },
      "6": {
        "inputs": {
          "text": "futuristic cityscape"
        }
      }
    }
  }'

Request Example - Image/Video

Image/Video Upload with a URL For example, this request overrides the image in LoadImage (ID "189") from flux_kontext_workflow_api.json with a URL.
curl --request POST \
  --url https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/inference \
  --header "Content-Type: application/json" \
  --header "Authorization: Bearer <token>" \
  --data '{
    "overrides": {
      "189": {
        "inputs": {
          "image": "https://example.com/new-image.jpg"
        }
      }
    }
  }'
Image/Video Upload with a Base64 data URI For example, this request overrides the image in LoadImage (ID "189") from flux_kontext_workflow_api.json with a Base64 data URI.
curl --request POST \
  --url https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/inference \
  --header "Content-Type: application/json" \
  --header "Authorization: Bearer <token>" \
  --data '{
    "overrides": {
      "189": {
        "inputs": {
          "image": "..."
        }
      }
    }
  }'

Request Example - API Nodes

If your workflow uses ComfyUI API Nodes that require an API key, include it in the request body as extra_data.api_key_comfy_org. The key is passed to the node at runtime, used only for the duration of the request, and discarded upon completion. Note: extra_data and overrides are top-level sibling fields in the JSON payload, keep them side by side.
curl --request POST \
  --url https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/inference \
  --header "Content-Type: application/json" \
  --header "Authorization: Bearer <token>" \
  --data '{
    "overrides": {
      "10": {
        "inputs": {
          "prompt": "a golden retriever playing in a park"
        }
      }
    },
    "extra_data": {
      "api_key_comfy_org": "<comfy_org_api_key>"
    }
  }'
Request Body Explanation A JSON object for customizing the workflow. All fields are optional.
  • overrides (object):
    • Keys: Node IDs as strings (e.g., "31"), matching your workflow’s API JSON exactly.
    • Values: Objects with an inputs field containing input names and updated values (e.g., { "inputs": { "seed": 987654321 } }).
      Input keys and formats must match your workflow’s API JSON. For media inputs, use a URL (e.g., "image": "https://example.com/new-image.jpg") or Base64 data URI (e.g., "image": "...") in the inputs object.
Image/Video Inputs Explanation Image/Video inputs can be added via either Base64 data URIs or public URLs.
  • Via Base64 (Data URI):
    • Include a Base64 data URI in the inputs object (for example: "image": "...").
    • Large files may slow down requests.
    • Recommended limits: images ≤256KB (around 512x512); videos ≤1MB for short clips (around 480p).
  • Via URL (Public file link):
    • Include a public URL in the inputs object (for example: "image": "https://example.com/image.jpg").
    • Some hosts may block requests.
    • Recommended limits: images ≤50MB (around 4K); videos ≤100MB (about 2–5 minutes at 720p).

Response Example

{
  "request_id": "{request_id}",
  "status_url": "https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/status",
  "result_url": "https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/result",
  "cancel_url": "https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/cancel"
}
Response Explanation Successful requests return a 200 OK status with a JSON object providing job tracking details.
  • request_id (string): Unique identifier for the job.
  • status_url (string): URL to poll for job progress.
  • result_url (string): URL to fetch outputs once the job completes.
  • cancel_url (string): URL to cancel the job if still queued.

Using Dynamic Workflow

If you need to run a different workflow for a single request, send a complete ComfyUI Workflow API JSON under the top-level workflow_api_json field and omit overrides. In this mode, the server executes the inline workflow and ignores the cloud-saved one for this request.

Request Example

curl --request POST \
  --url https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/inference \
  --header "Content-Type: application/json" \
  --header "Authorization: Bearer <token>" \
  --data '{
    "workflow_api_json": {your-full-workflow-api-json-here}
  }'
Other request semantics are unchanged: image/video uploads and API node credentials behave the same as in the cloud-saved mode.

Response Example

The response format is identical to the cloud-saved workflow mode:
{
  "request_id": "{request_id}",
  "status_url": "https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/status",
  "result_url": "https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/result",
  "cancel_url": "https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/cancel"
}

Monitoring Request Status

GET /prod/v1/deployments/{deployment_id}/requests/{request_id}/status Use this endpoint to check the current state of a queued or running job. Poll this endpoint periodically for updates on progress.

Request Example

curl --request GET \
  --url https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/status \
  --header "Authorization: Bearer <token>"

Response Example

{
  "request_id": "{request_id}",
  "status": "in_queue",
  "queue_position": 0,
  "result_url": "https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/result",
  "status_url": "https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/status"
}
Response Explanation Successful requests return a 200 OK status with a JSON object describing the job’s state. The content varies by status:
  • status (string): Current state (e.g., "in_queue", "in_progress", "completed", or "canceled").
  • Additional fields based on status:
    • For "in_queue":
      • queue_position (integer): Your position in the queue.
      • result_url (string): URL where results will be available.
    • For "in_progress", "completed", or "canceled":
      • result_url (string): The URL to get the final outputs (available only when "completed" or "canceled").

Retrieving Request Results

GET /prod/v1/deployments/{deployment_id}/requests/{request_id}/result Use this endpoint to fetch outputs once the job status is "completed".

Request Example

curl --request GET \
  --url https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/result \
  --header "Authorization: Bearer <token>"

Response Example

{
  "request_id": "{request_id}",
  "status": "succeeded",
  "outputs": {
    "136": {
      "images": [
        {
          "url": "https://example.com/ComfyUI_00001_.png",
          "filename": "ComfyUI_00001_.png",
          "subfolder": "",
          "type": "output"
        }
      ]
    }
  },
  "created_at": "2025-07-22T13:05:16.143086",
  "finished_at": "2025-07-22T13:13:03.624471"
}
Response Explanation Successful requests return a 200 OK status with a JSON object containing the job’s final details. The content varies by status:
  • status (string): Outcome (e.g., "succeeded", "failed", "in_queue" , "in_progress", "canceled").
  • Additional fields based on status:
    • For "succeeded":
      • outputs (array): Generated files, each with:
        • url (string): Direct link to the output file (e.g., "https://example.com/outputs/ComfyUI_00001_.png").
        • filename (string): Name of the output file.
      • created_at (string): When the request was created.
      • finished_at (string): When the request completed.
    • For "failed":
      • error: Details on why the job failed.
      • created_at (string): When the request was created.
      • finished_at: When the request failed or was canceled.
    • For "in_queue", "in_progress", or "canceled":
      • created_at (string): When the request was created.
      • finished_at (string, only for "canceled"): When the request was canceled.

Cancelling a Request

POST /prod/v1/deployments/{deployment_id}/requests/{request_id}/cancel Use this endpoint to cancel a queued or running job.

Request Example

curl --request POST \
  --url https://api.runcomfy.net/prod/v1/deployments/{deployment_id}/requests/{request_id}/cancel \
  --header "Authorization: Bearer <token>"

Response Example

{
  "request_id": "{request_id}",
  "status": "cancellation_requested"
}
Response Explanation Successful requests return a 202 Accepted status with a JSON object containing the cancellation outcome.
  • status (string): Outcome (e.g., "cancellation_requested"if accepted, "not_cancellable" if the job is completed or otherwise cannot be canceled).
By using these endpoints, you can fully manage the lifecycle of your ComfyUI inference jobs, from submission and monitoring to retrieving results and canceling tasks, directly through the API.