跳转到主要内容

Documentation Index

Fetch the complete documentation index at: https://dripart-docs-recommend-jobs-api.mintlify.app/llms.txt

Use this file to discover all available pages before exploring further.

路由

服务器定义了一系列 getpost 方法, 这些方法可以通过在 server.py 中搜索 @routes 找到。当你在网页客户端提交工作流时, 它会被发送到 /prompt 端点,该端点会验证提示并将其添加到执行队列中, 返回 prompt_idnumber(队列中的位置),如果验证失败则返回 errornode_errors。 提示队列定义在 execution.py 中,该文件还定义了 PromptExecutor 类。

内置路由

server.py 定义了以下路由:

核心 API 路由

路径get/post/ws用途
/get加载 Comfy 网页
/wswebsocket用于与服务器进行实时通信的 WebSocket 端点
/embeddingsget获取可用的嵌入模型名称列表
/extensionsget获取注册了 WEB_DIRECTORY 的扩展列表
/featuresget获取服务器功能和能力
/modelsget获取可用模型类型列表
/models/{folder}get获取特定文件夹中的模型
/workflow_templatesget获取自定义节点模块及其关联模板工作流的映射
/upload/imagepost上传图片
/upload/maskpost上传蒙版
/viewget查看图片。更多选项请参见 server.py 中的 @routes.get("/view")
/view_metadata/get获取模型的元数据
/system_statsget获取系统信息(Python 版本、设备、显存等)
/promptget获取当前队列状态和执行信息
/promptpost提交提示到队列
/object_infoget获取所有节点类型的详细信息
/object_info/{node_class}get获取特定节点类型的详细信息
/jobsget列出任务,支持过滤、排序和分页(推荐)
/jobs/{job_id}get获取特定任务的完整详情(推荐)
/historyget获取队列历史记录(旧版)
/history/{prompt_id}get获取特定提示的队列历史记录(旧版)
/historypost清除历史记录或删除历史记录项
/queueget获取执行队列的当前状态(旧版)
/queuepost管理队列操作(清除待处理/运行中的任务)
/interruptpost停止当前工作流执行
/freepost通过卸载指定模型释放内存
/userdataget列出指定目录中的用户数据文件
/v2/userdataget增强版本,以结构化格式列出文件和目录
/userdata/{file}get获取特定的用户数据文件
/userdata/{file}post上传或更新用户数据文件
/userdata/{file}delete删除特定的用户数据文件
/userdata/{file}/move/{dest}post移动或重命名用户数据文件
/usersget获取用户信息
/userspost创建新用户(仅限多用户模式)

Jobs API

Jobs API (/jobs) 提供了一个统一的接口来列出和获取任务信息,支持过滤、排序和分页。这是查询任务状态和历史记录的推荐方式。

列出任务

GET /jobs 返回一个分页的任务列表,支持可选的过滤:
参数类型描述
statusstring按状态过滤(逗号分隔):pendingin_progresscompletedfailedcancelled
workflow_idstring按工作流 ID 过滤
sort_bystring排序字段:created_at(默认)、execution_duration
sort_orderstring排序方向:ascdesc(默认)
limitinteger返回的最大条目数
offsetinteger跳过的条目数(默认:0)
响应:
{
  "jobs": [
    {
      "id": "prompt-uuid",
      "status": "completed",
      "create_time": 1706540000,
      "workflow_id": "workflow-uuid",
      "outputs_count": 2,
      "preview_output": {"filename": "output.png", "type": "output"},
      "execution_start_time": 1706540001000,
      "execution_end_time": 1706540005000
    }
  ],
  "pagination": {
    "offset": 0,
    "limit": 100,
    "total": 42,
    "has_more": false
  }
}

获取任务详情

GET /jobs/{job_id} 返回特定任务的完整详情,包括输出和工作流:
{
  "id": "prompt-uuid",
  "status": "completed",
  "create_time": 1706540000,
  "outputs": {
    "9": {"images": [{"filename": "output.png", "type": "output"}]}
  },
  "workflow": {
    "prompt": {...},
    "extra_data": {...}
  },
  "execution_status": {...}
}
Jobs API 将队列和历史记录的数据整合为单一的统一格式。建议使用 /jobs 而不是分别查询 /queue/history 端点。

WebSocket 通信

/ws 端点提供客户端与服务器之间的实时双向通信。用于:
  • 接收执行进度更新
  • 实时获取节点执行状态
  • 接收错误消息和调试信息
  • 队列状态变化时的实时更新
WebSocket 连接发送不同类型的 JSON 消息,例如:
  • status - 整体系统状态更新
  • execution_start - 当提示执行开始时
  • execution_cached - 当使用缓存结果时
  • executing - 节点执行期间的更新
  • progress - 长时间运行操作的进度更新
  • executed - 当节点完成执行时

自定义路由

如果你想在执行过程中从客户端向服务器发送消息,你需要在服务器中添加一个自定义路由。 对于复杂的情况,你需要深入研究 aiohttp 框架文档,但大多数情况可以按以下方式处理:
from server import PromptServer
from aiohttp import web
routes = PromptServer.instance.routes
@routes.post('/my_new_path')
async def my_function(request):
    the_data = await request.post()
    # the_data now holds a dictionary of the values sent
    MyClass.handle_my_message(the_data)
    return web.json_response({})
除非你确切知道自己在做什么,否则不要尝试在类中定义 my_function@routes.post 装饰器做了很多工作!相反,应该像上面那样定义函数, 然后调用一个类方法。
如果你不需要修改任何内容,也可以定义 @routes.get
客户端可以通过发送 FormData 对象来使用这个新路由,代码如下所示, 这将导致上面代码中的 the_data 包含 messagenode_id 键:
import { api } from "../../scripts/api.js";
function send_message(node_id, message) {
    const body = new FormData();
    body.append('message',message);
    body.append('node_id', node_id);
    api.fetchApi("/my_new_path", { method: "POST", body, });
}