跳至主要内容
版本:3.5.x

JSON 规范

所有服务接口均采用 JSON 格式。本页面记录了通用的模式。

端口

港口界面版本
10001HTTP REST + WebSocket(模拟通道)v3.1(当前版本)
10020WebSocket(事件通道,只读)
10000旧版 WebSocket(v3.0 — 将在 v4.0 中移除)v3.0

HTTP 响应封装

每个 HTTP 响应都使用相同的封装:

成功(基于数据):

{ "ok": true, "data": {} }

成功(无数据——仅限突变相关终点):

{ "ok": true }

错误:

{ "ok": false, "error": "reason string" }

已弃用的端点:

{ "ok": true, "deprecation_warning": "This route is deprecated. Use …" }

HTTP 状态码

代码含义
200成功
400请求错误 — 请求体无效、选择器不明确、缺少必填字段
404找不到设备、会话或资源
405方法不被允许

WebSocket 消息格式

消息是 JSON 对象。顶级键是设备组名称 (inverse3, verse_grip, wireless_verse_grip) 以及一个可选的 session 会话级命令的键。

客户端 → 服务(命令):

{
"session": { "configure": {} },
"inverse3": [
{ "device_id": "049D", "configure": {}, "commands": {} }
]
}

服务 → 客户(状态):

{
"session_id": 7,
"inverse3": [
{ "device_id": "049D", "config": {}, "state": {}, "status": {} }
]
}

该服务发送的首条消息包含 config (完整快照);后续 消息仅包含 statestatus. 参见 WebSocket 协议 查看完整工作流程。

内容类型

所有带有正文的 HTTP 请求都必须发送 Content-Type: application/json. WebSocket 消息始终是明文 JSON 帧。

未知键

未知键将被静默忽略

该服务目前会忽略未识别的 JSON 键,且不会报错。如果某个 命令似乎没有生效,请检查服务日志,并对照API 参考文档核对字段 名称。 计划在未来版本中更改此行为(未知键将 触发警告事件)。