nodmix 2026.5.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (827) hide show
  1. package/CHANGELOG.md +11573 -0
  2. package/LICENSE +21 -0
  3. package/README.md +486 -0
  4. package/docs/.i18n/README.md +81 -0
  5. package/docs/.i18n/ar-navigation.json +18 -0
  6. package/docs/.i18n/de-navigation.json +18 -0
  7. package/docs/.i18n/es-navigation.json +18 -0
  8. package/docs/.i18n/fr-navigation.json +18 -0
  9. package/docs/.i18n/glossary.ar.json +78 -0
  10. package/docs/.i18n/glossary.de.json +78 -0
  11. package/docs/.i18n/glossary.es.json +78 -0
  12. package/docs/.i18n/glossary.fa.json +78 -0
  13. package/docs/.i18n/glossary.fr.json +78 -0
  14. package/docs/.i18n/glossary.id.json +78 -0
  15. package/docs/.i18n/glossary.it.json +78 -0
  16. package/docs/.i18n/glossary.ja-JP.json +98 -0
  17. package/docs/.i18n/glossary.ko.json +78 -0
  18. package/docs/.i18n/glossary.nl.json +78 -0
  19. package/docs/.i18n/glossary.pl.json +78 -0
  20. package/docs/.i18n/glossary.pt-BR.json +78 -0
  21. package/docs/.i18n/glossary.th.json +78 -0
  22. package/docs/.i18n/glossary.tr.json +78 -0
  23. package/docs/.i18n/glossary.uk.json +78 -0
  24. package/docs/.i18n/glossary.vi.json +78 -0
  25. package/docs/.i18n/glossary.zh-CN.json +1002 -0
  26. package/docs/.i18n/glossary.zh-TW.json +78 -0
  27. package/docs/.i18n/id-navigation.json +18 -0
  28. package/docs/.i18n/it-navigation.json +18 -0
  29. package/docs/.i18n/ja-navigation.json +18 -0
  30. package/docs/.i18n/ko-navigation.json +18 -0
  31. package/docs/.i18n/pl-navigation.json +18 -0
  32. package/docs/.i18n/pt-BR-navigation.json +18 -0
  33. package/docs/.i18n/tr-navigation.json +18 -0
  34. package/docs/.i18n/translation-workflow.md +111 -0
  35. package/docs/.i18n/zh-Hans-navigation.json +542 -0
  36. package/docs/AGENTS.md +36 -0
  37. package/docs/announcements/bluebubbles-imessage.md +79 -0
  38. package/docs/assets/install-script.svg +1 -0
  39. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  40. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  41. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  42. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  43. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  44. package/docs/assets/openclaw-logo-text-dark.png +0 -0
  45. package/docs/assets/openclaw-logo-text-dark.svg +418 -0
  46. package/docs/assets/openclaw-logo-text.png +0 -0
  47. package/docs/assets/openclaw-logo-text.svg +418 -0
  48. package/docs/assets/pixel-lobster.svg +60 -0
  49. package/docs/assets/pr/quick-settings-browser-tools.png +0 -0
  50. package/docs/assets/showcase/agents-ui.jpg +0 -0
  51. package/docs/assets/showcase/bambu-cli.png +0 -0
  52. package/docs/assets/showcase/codexmonitor.png +0 -0
  53. package/docs/assets/showcase/gohome-grafana.png +0 -0
  54. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  55. package/docs/assets/showcase/oura-health.png +0 -0
  56. package/docs/assets/showcase/padel-cli.svg +11 -0
  57. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  58. package/docs/assets/showcase/papla-tts.jpg +0 -0
  59. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  60. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  61. package/docs/assets/showcase/roborock-status.svg +13 -0
  62. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  63. package/docs/assets/showcase/snag.png +0 -0
  64. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  65. package/docs/assets/showcase/wienerlinien.png +0 -0
  66. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  67. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  68. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  69. package/docs/assets/sponsors/blacksmith-light.svg +14 -0
  70. package/docs/assets/sponsors/blacksmith.svg +14 -0
  71. package/docs/assets/sponsors/convex-light.svg +16 -0
  72. package/docs/assets/sponsors/convex.svg +16 -0
  73. package/docs/assets/sponsors/github-light.svg +3 -0
  74. package/docs/assets/sponsors/github.svg +3 -0
  75. package/docs/assets/sponsors/nvidia-dark.svg +9 -0
  76. package/docs/assets/sponsors/nvidia.svg +9 -0
  77. package/docs/assets/sponsors/openai-light.svg +3 -0
  78. package/docs/assets/sponsors/openai.svg +3 -0
  79. package/docs/assets/sponsors/vercel-light.svg +5 -0
  80. package/docs/assets/sponsors/vercel.svg +5 -0
  81. package/docs/auth-credential-semantics.md +124 -0
  82. package/docs/automation/auth-monitoring.md +11 -0
  83. package/docs/automation/clawflow.md +12 -0
  84. package/docs/automation/cron-jobs.md +500 -0
  85. package/docs/automation/cron-vs-heartbeat.md +11 -0
  86. package/docs/automation/gmail-pubsub.md +11 -0
  87. package/docs/automation/hooks.md +365 -0
  88. package/docs/automation/index.md +135 -0
  89. package/docs/automation/poll.md +12 -0
  90. package/docs/automation/standing-orders.md +250 -0
  91. package/docs/automation/taskflow.md +155 -0
  92. package/docs/automation/tasks.md +374 -0
  93. package/docs/automation/troubleshooting.md +12 -0
  94. package/docs/automation/webhook.md +12 -0
  95. package/docs/brave-search.md +11 -0
  96. package/docs/channels/access-groups.md +201 -0
  97. package/docs/channels/ambient-room-events.md +214 -0
  98. package/docs/channels/bot-loop-protection.md +131 -0
  99. package/docs/channels/broadcast-groups.md +472 -0
  100. package/docs/channels/channel-routing.md +162 -0
  101. package/docs/channels/clickclack.md +138 -0
  102. package/docs/channels/discord.md +1762 -0
  103. package/docs/channels/feishu.md +502 -0
  104. package/docs/channels/googlechat.md +284 -0
  105. package/docs/channels/group-messages.md +95 -0
  106. package/docs/channels/groups.md +519 -0
  107. package/docs/channels/imessage-from-bluebubbles.md +259 -0
  108. package/docs/channels/imessage.md +813 -0
  109. package/docs/channels/index.md +64 -0
  110. package/docs/channels/irc.md +253 -0
  111. package/docs/channels/line.md +243 -0
  112. package/docs/channels/location.md +71 -0
  113. package/docs/channels/matrix-migration.md +370 -0
  114. package/docs/channels/matrix-presentation.md +77 -0
  115. package/docs/channels/matrix-push-rules.md +150 -0
  116. package/docs/channels/matrix.md +921 -0
  117. package/docs/channels/mattermost.md +542 -0
  118. package/docs/channels/msteams.md +1042 -0
  119. package/docs/channels/nextcloud-talk.md +176 -0
  120. package/docs/channels/nostr.md +253 -0
  121. package/docs/channels/pairing.md +214 -0
  122. package/docs/channels/qqbot.md +309 -0
  123. package/docs/channels/signal.md +400 -0
  124. package/docs/channels/slack.md +1564 -0
  125. package/docs/channels/synology-chat.md +187 -0
  126. package/docs/channels/telegram.md +1107 -0
  127. package/docs/channels/tlon.md +296 -0
  128. package/docs/channels/troubleshooting.md +161 -0
  129. package/docs/channels/twitch.md +431 -0
  130. package/docs/channels/wechat.md +171 -0
  131. package/docs/channels/whatsapp.md +739 -0
  132. package/docs/channels/yuanbao.md +416 -0
  133. package/docs/channels/zalo.md +253 -0
  134. package/docs/channels/zalouser.md +199 -0
  135. package/docs/ci.md +612 -0
  136. package/docs/clawhub/publishing.md +96 -0
  137. package/docs/cli/acp.md +370 -0
  138. package/docs/cli/agent.md +103 -0
  139. package/docs/cli/agents.md +232 -0
  140. package/docs/cli/approvals.md +190 -0
  141. package/docs/cli/backup.md +97 -0
  142. package/docs/cli/browser.md +307 -0
  143. package/docs/cli/channels.md +154 -0
  144. package/docs/cli/clawbot.md +25 -0
  145. package/docs/cli/commitments.md +90 -0
  146. package/docs/cli/completion.md +39 -0
  147. package/docs/cli/config.md +504 -0
  148. package/docs/cli/configure.md +77 -0
  149. package/docs/cli/crestodian.md +332 -0
  150. package/docs/cli/cron.md +281 -0
  151. package/docs/cli/daemon.md +67 -0
  152. package/docs/cli/dashboard.md +33 -0
  153. package/docs/cli/devices.md +204 -0
  154. package/docs/cli/directory.md +68 -0
  155. package/docs/cli/dns.md +53 -0
  156. package/docs/cli/docs.md +73 -0
  157. package/docs/cli/doctor.md +237 -0
  158. package/docs/cli/flows.md +52 -0
  159. package/docs/cli/gateway.md +567 -0
  160. package/docs/cli/health.md +43 -0
  161. package/docs/cli/hooks.md +345 -0
  162. package/docs/cli/index.md +396 -0
  163. package/docs/cli/infer.md +364 -0
  164. package/docs/cli/logs.md +65 -0
  165. package/docs/cli/mcp.md +529 -0
  166. package/docs/cli/memory.md +183 -0
  167. package/docs/cli/message.md +317 -0
  168. package/docs/cli/migrate.md +290 -0
  169. package/docs/cli/models.md +224 -0
  170. package/docs/cli/node.md +177 -0
  171. package/docs/cli/nodes.md +76 -0
  172. package/docs/cli/onboard.md +245 -0
  173. package/docs/cli/pairing.md +77 -0
  174. package/docs/cli/path.md +502 -0
  175. package/docs/cli/plugins.md +454 -0
  176. package/docs/cli/policy.md +418 -0
  177. package/docs/cli/proxy.md +89 -0
  178. package/docs/cli/qr.md +56 -0
  179. package/docs/cli/reset.md +39 -0
  180. package/docs/cli/sandbox.md +208 -0
  181. package/docs/cli/secrets.md +202 -0
  182. package/docs/cli/security.md +124 -0
  183. package/docs/cli/sessions.md +164 -0
  184. package/docs/cli/setup.md +59 -0
  185. package/docs/cli/skills.md +102 -0
  186. package/docs/cli/status.md +45 -0
  187. package/docs/cli/system.md +89 -0
  188. package/docs/cli/tasks.md +111 -0
  189. package/docs/cli/tui.md +89 -0
  190. package/docs/cli/uninstall.md +44 -0
  191. package/docs/cli/update.md +242 -0
  192. package/docs/cli/voicecall.md +204 -0
  193. package/docs/cli/webhooks.md +117 -0
  194. package/docs/cli/wiki.md +256 -0
  195. package/docs/concepts/active-memory.md +856 -0
  196. package/docs/concepts/agent-loop.md +185 -0
  197. package/docs/concepts/agent-runtimes.md +243 -0
  198. package/docs/concepts/agent-workspace.md +230 -0
  199. package/docs/concepts/agent.md +136 -0
  200. package/docs/concepts/architecture.md +154 -0
  201. package/docs/concepts/channel-docking.md +145 -0
  202. package/docs/concepts/commitments.md +150 -0
  203. package/docs/concepts/compaction.md +203 -0
  204. package/docs/concepts/context-engine.md +306 -0
  205. package/docs/concepts/context.md +199 -0
  206. package/docs/concepts/delegate-architecture.md +319 -0
  207. package/docs/concepts/dreaming.md +261 -0
  208. package/docs/concepts/experimental-features.md +108 -0
  209. package/docs/concepts/features.md +91 -0
  210. package/docs/concepts/mantis-slack-desktop-runbook.md +202 -0
  211. package/docs/concepts/mantis.md +740 -0
  212. package/docs/concepts/markdown-formatting.md +139 -0
  213. package/docs/concepts/memory-builtin.md +146 -0
  214. package/docs/concepts/memory-honcho.md +144 -0
  215. package/docs/concepts/memory-qmd.md +271 -0
  216. package/docs/concepts/memory-search.md +166 -0
  217. package/docs/concepts/memory.md +258 -0
  218. package/docs/concepts/message-lifecycle-refactor.md +1128 -0
  219. package/docs/concepts/messages.md +214 -0
  220. package/docs/concepts/model-failover.md +385 -0
  221. package/docs/concepts/model-providers.md +715 -0
  222. package/docs/concepts/models.md +370 -0
  223. package/docs/concepts/multi-agent.md +619 -0
  224. package/docs/concepts/oauth.md +198 -0
  225. package/docs/concepts/openclaw-sdk.md +323 -0
  226. package/docs/concepts/parallel-specialist-lanes.md +127 -0
  227. package/docs/concepts/personal-agent-benchmark-pack.md +74 -0
  228. package/docs/concepts/presence.md +117 -0
  229. package/docs/concepts/progress-drafts.md +362 -0
  230. package/docs/concepts/qa-e2e-automation.md +820 -0
  231. package/docs/concepts/qa-matrix.md +139 -0
  232. package/docs/concepts/queue-steering.md +90 -0
  233. package/docs/concepts/queue.md +122 -0
  234. package/docs/concepts/retry.md +86 -0
  235. package/docs/concepts/session-pruning.md +104 -0
  236. package/docs/concepts/session-tool.md +190 -0
  237. package/docs/concepts/session.md +164 -0
  238. package/docs/concepts/soul.md +116 -0
  239. package/docs/concepts/streaming.md +251 -0
  240. package/docs/concepts/system-prompt.md +310 -0
  241. package/docs/concepts/timezone.md +47 -0
  242. package/docs/concepts/typebox.md +309 -0
  243. package/docs/concepts/typing-indicators.md +88 -0
  244. package/docs/concepts/usage-tracking.md +66 -0
  245. package/docs/date-time.md +126 -0
  246. package/docs/debug/node-issue.md +90 -0
  247. package/docs/diagnostics/flags.md +138 -0
  248. package/docs/docs.json +1832 -0
  249. package/docs/gateway/authentication.md +239 -0
  250. package/docs/gateway/background-process.md +147 -0
  251. package/docs/gateway/bonjour.md +303 -0
  252. package/docs/gateway/bridge-protocol.md +94 -0
  253. package/docs/gateway/cli-backends.md +420 -0
  254. package/docs/gateway/config-agents.md +1514 -0
  255. package/docs/gateway/config-channels.md +945 -0
  256. package/docs/gateway/config-tools.md +769 -0
  257. package/docs/gateway/configuration-examples.md +705 -0
  258. package/docs/gateway/configuration-reference.md +1393 -0
  259. package/docs/gateway/configuration.md +737 -0
  260. package/docs/gateway/diagnostics.md +213 -0
  261. package/docs/gateway/discovery.md +154 -0
  262. package/docs/gateway/doctor.md +574 -0
  263. package/docs/gateway/gateway-lock.md +37 -0
  264. package/docs/gateway/health.md +73 -0
  265. package/docs/gateway/heartbeat.md +493 -0
  266. package/docs/gateway/index.md +383 -0
  267. package/docs/gateway/local-model-services.md +205 -0
  268. package/docs/gateway/local-models.md +355 -0
  269. package/docs/gateway/logging.md +149 -0
  270. package/docs/gateway/multiple-gateways.md +178 -0
  271. package/docs/gateway/network-model.md +15 -0
  272. package/docs/gateway/openai-http-api.md +350 -0
  273. package/docs/gateway/openresponses-http-api.md +347 -0
  274. package/docs/gateway/openshell.md +316 -0
  275. package/docs/gateway/opentelemetry.md +404 -0
  276. package/docs/gateway/operator-scopes.md +111 -0
  277. package/docs/gateway/pairing.md +207 -0
  278. package/docs/gateway/prometheus.md +230 -0
  279. package/docs/gateway/protocol.md +803 -0
  280. package/docs/gateway/remote-gateway-readme.md +169 -0
  281. package/docs/gateway/remote.md +280 -0
  282. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +146 -0
  283. package/docs/gateway/sandboxing.md +545 -0
  284. package/docs/gateway/secrets-plan-contract.md +114 -0
  285. package/docs/gateway/secrets.md +609 -0
  286. package/docs/gateway/security/audit-checks.md +127 -0
  287. package/docs/gateway/security/index.md +1326 -0
  288. package/docs/gateway/security/secure-file-operations.md +76 -0
  289. package/docs/gateway/tailscale.md +156 -0
  290. package/docs/gateway/tools-invoke-http-api.md +169 -0
  291. package/docs/gateway/troubleshooting.md +772 -0
  292. package/docs/gateway/trusted-proxy-auth.md +451 -0
  293. package/docs/help/debugging.md +344 -0
  294. package/docs/help/environment.md +214 -0
  295. package/docs/help/faq-first-run.md +867 -0
  296. package/docs/help/faq-models.md +553 -0
  297. package/docs/help/faq.md +1975 -0
  298. package/docs/help/gpt55-codex-agentic-parity-maintainers.md +196 -0
  299. package/docs/help/gpt55-codex-agentic-parity.md +230 -0
  300. package/docs/help/index.md +39 -0
  301. package/docs/help/scripts.md +56 -0
  302. package/docs/help/testing-live.md +580 -0
  303. package/docs/help/testing-updates-plugins.md +291 -0
  304. package/docs/help/testing.md +928 -0
  305. package/docs/help/troubleshooting.md +424 -0
  306. package/docs/images/configure-model-picker-unsearchable.png +0 -0
  307. package/docs/images/feishu-get-group-id.png +0 -0
  308. package/docs/images/groups-flow.svg +52 -0
  309. package/docs/images/mobile-ui-screenshot.png +0 -0
  310. package/docs/index.md +196 -0
  311. package/docs/install/ansible.md +233 -0
  312. package/docs/install/azure.md +315 -0
  313. package/docs/install/bun.md +59 -0
  314. package/docs/install/clawdock.md +112 -0
  315. package/docs/install/development-channels.md +135 -0
  316. package/docs/install/digitalocean.md +174 -0
  317. package/docs/install/docker-vm-runtime.md +154 -0
  318. package/docs/install/docker.md +562 -0
  319. package/docs/install/exe-dev.md +201 -0
  320. package/docs/install/fly.md +524 -0
  321. package/docs/install/gcp.md +418 -0
  322. package/docs/install/hetzner.md +285 -0
  323. package/docs/install/hostinger.md +98 -0
  324. package/docs/install/index.md +221 -0
  325. package/docs/install/installer.md +455 -0
  326. package/docs/install/kubernetes.md +196 -0
  327. package/docs/install/macos-vm.md +281 -0
  328. package/docs/install/migrating-claude.md +165 -0
  329. package/docs/install/migrating-hermes.md +177 -0
  330. package/docs/install/migrating.md +137 -0
  331. package/docs/install/nix.md +112 -0
  332. package/docs/install/node.md +142 -0
  333. package/docs/install/northflank.mdx +44 -0
  334. package/docs/install/oracle.md +218 -0
  335. package/docs/install/podman.md +210 -0
  336. package/docs/install/railway.mdx +92 -0
  337. package/docs/install/raspberry-pi.md +234 -0
  338. package/docs/install/render.mdx +167 -0
  339. package/docs/install/uninstall.md +131 -0
  340. package/docs/install/updating.md +280 -0
  341. package/docs/logging.md +318 -0
  342. package/docs/nav-tabs-underline.js +100 -0
  343. package/docs/network.md +72 -0
  344. package/docs/nodes/audio.md +215 -0
  345. package/docs/nodes/camera.md +166 -0
  346. package/docs/nodes/images.md +77 -0
  347. package/docs/nodes/index.md +439 -0
  348. package/docs/nodes/location-command.md +102 -0
  349. package/docs/nodes/media-understanding.md +469 -0
  350. package/docs/nodes/talk.md +154 -0
  351. package/docs/nodes/troubleshooting.md +123 -0
  352. package/docs/nodes/voicewake.md +93 -0
  353. package/docs/perplexity.md +11 -0
  354. package/docs/pi-dev.md +82 -0
  355. package/docs/pi.md +573 -0
  356. package/docs/plan/codex-context-engine-harness.md +624 -0
  357. package/docs/plan/ui-channels.md +284 -0
  358. package/docs/platforms/android.md +285 -0
  359. package/docs/platforms/digitalocean.md +12 -0
  360. package/docs/platforms/index.md +60 -0
  361. package/docs/platforms/ios.md +283 -0
  362. package/docs/platforms/linux.md +141 -0
  363. package/docs/platforms/mac/bundled-gateway.md +79 -0
  364. package/docs/platforms/mac/canvas.md +128 -0
  365. package/docs/platforms/mac/child-process.md +72 -0
  366. package/docs/platforms/mac/dev-setup.md +112 -0
  367. package/docs/platforms/mac/health.md +39 -0
  368. package/docs/platforms/mac/icon.md +36 -0
  369. package/docs/platforms/mac/logging.md +62 -0
  370. package/docs/platforms/mac/menu-bar.md +93 -0
  371. package/docs/platforms/mac/peekaboo.md +92 -0
  372. package/docs/platforms/mac/permissions.md +53 -0
  373. package/docs/platforms/mac/remote.md +123 -0
  374. package/docs/platforms/mac/signing.md +52 -0
  375. package/docs/platforms/mac/skills.md +43 -0
  376. package/docs/platforms/mac/voice-overlay.md +66 -0
  377. package/docs/platforms/mac/voicewake.md +73 -0
  378. package/docs/platforms/mac/webchat.md +54 -0
  379. package/docs/platforms/mac/xpc.md +66 -0
  380. package/docs/platforms/macos.md +226 -0
  381. package/docs/platforms/oracle.md +12 -0
  382. package/docs/platforms/raspberry-pi.md +13 -0
  383. package/docs/platforms/windows.md +286 -0
  384. package/docs/plugins/adding-capabilities.md +133 -0
  385. package/docs/plugins/admin-http-rpc.md +216 -0
  386. package/docs/plugins/agent-tools.md +13 -0
  387. package/docs/plugins/architecture-internals.md +1195 -0
  388. package/docs/plugins/architecture.md +481 -0
  389. package/docs/plugins/building-extensions.md +13 -0
  390. package/docs/plugins/building-plugins.md +330 -0
  391. package/docs/plugins/bundles.md +310 -0
  392. package/docs/plugins/cli-backend-plugins.md +310 -0
  393. package/docs/plugins/codex-computer-use.md +293 -0
  394. package/docs/plugins/codex-harness-reference.md +409 -0
  395. package/docs/plugins/codex-harness-runtime.md +247 -0
  396. package/docs/plugins/codex-harness.md +746 -0
  397. package/docs/plugins/codex-native-plugins.md +276 -0
  398. package/docs/plugins/community.md +77 -0
  399. package/docs/plugins/compatibility.md +164 -0
  400. package/docs/plugins/dependency-resolution.md +143 -0
  401. package/docs/plugins/google-meet.md +1737 -0
  402. package/docs/plugins/hooks.md +459 -0
  403. package/docs/plugins/install-overrides.md +80 -0
  404. package/docs/plugins/manage-plugins.md +210 -0
  405. package/docs/plugins/manifest.md +1359 -0
  406. package/docs/plugins/memory-lancedb.md +385 -0
  407. package/docs/plugins/memory-wiki.md +529 -0
  408. package/docs/plugins/message-presentation.md +473 -0
  409. package/docs/plugins/oc-path.md +166 -0
  410. package/docs/plugins/plugin-inventory.md +182 -0
  411. package/docs/plugins/reference/acpx.md +23 -0
  412. package/docs/plugins/reference/admin-http-rpc.md +23 -0
  413. package/docs/plugins/reference/alibaba.md +23 -0
  414. package/docs/plugins/reference/amazon-bedrock-mantle.md +23 -0
  415. package/docs/plugins/reference/amazon-bedrock.md +23 -0
  416. package/docs/plugins/reference/anthropic-vertex.md +19 -0
  417. package/docs/plugins/reference/anthropic.md +23 -0
  418. package/docs/plugins/reference/arcee.md +23 -0
  419. package/docs/plugins/reference/azure-speech.md +23 -0
  420. package/docs/plugins/reference/bonjour.md +19 -0
  421. package/docs/plugins/reference/brave.md +23 -0
  422. package/docs/plugins/reference/browser.md +23 -0
  423. package/docs/plugins/reference/byteplus.md +19 -0
  424. package/docs/plugins/reference/canvas.md +19 -0
  425. package/docs/plugins/reference/cerebras.md +23 -0
  426. package/docs/plugins/reference/chutes.md +23 -0
  427. package/docs/plugins/reference/clickclack.md +23 -0
  428. package/docs/plugins/reference/cloudflare-ai-gateway.md +23 -0
  429. package/docs/plugins/reference/codex.md +23 -0
  430. package/docs/plugins/reference/comfy.md +23 -0
  431. package/docs/plugins/reference/copilot-proxy.md +19 -0
  432. package/docs/plugins/reference/deepgram.md +23 -0
  433. package/docs/plugins/reference/deepinfra.md +23 -0
  434. package/docs/plugins/reference/deepseek.md +23 -0
  435. package/docs/plugins/reference/diagnostics-otel.md +19 -0
  436. package/docs/plugins/reference/diagnostics-prometheus.md +19 -0
  437. package/docs/plugins/reference/diffs.md +19 -0
  438. package/docs/plugins/reference/discord.md +23 -0
  439. package/docs/plugins/reference/document-extract.md +23 -0
  440. package/docs/plugins/reference/duckduckgo.md +23 -0
  441. package/docs/plugins/reference/elevenlabs.md +23 -0
  442. package/docs/plugins/reference/exa.md +23 -0
  443. package/docs/plugins/reference/fal.md +23 -0
  444. package/docs/plugins/reference/feishu.md +23 -0
  445. package/docs/plugins/reference/file-transfer.md +19 -0
  446. package/docs/plugins/reference/firecrawl.md +23 -0
  447. package/docs/plugins/reference/fireworks.md +23 -0
  448. package/docs/plugins/reference/github-copilot.md +23 -0
  449. package/docs/plugins/reference/google-meet.md +23 -0
  450. package/docs/plugins/reference/google.md +23 -0
  451. package/docs/plugins/reference/googlechat.md +23 -0
  452. package/docs/plugins/reference/gradium.md +23 -0
  453. package/docs/plugins/reference/groq.md +23 -0
  454. package/docs/plugins/reference/huggingface.md +23 -0
  455. package/docs/plugins/reference/imessage.md +23 -0
  456. package/docs/plugins/reference/inworld.md +23 -0
  457. package/docs/plugins/reference/irc.md +23 -0
  458. package/docs/plugins/reference/kilocode.md +23 -0
  459. package/docs/plugins/reference/kimi.md +23 -0
  460. package/docs/plugins/reference/line.md +23 -0
  461. package/docs/plugins/reference/litellm.md +23 -0
  462. package/docs/plugins/reference/llm-task.md +19 -0
  463. package/docs/plugins/reference/lmstudio.md +23 -0
  464. package/docs/plugins/reference/lobster.md +19 -0
  465. package/docs/plugins/reference/matrix.md +23 -0
  466. package/docs/plugins/reference/mattermost.md +23 -0
  467. package/docs/plugins/reference/memory-core.md +19 -0
  468. package/docs/plugins/reference/memory-lancedb.md +23 -0
  469. package/docs/plugins/reference/memory-wiki.md +23 -0
  470. package/docs/plugins/reference/microsoft-foundry.md +19 -0
  471. package/docs/plugins/reference/microsoft.md +19 -0
  472. package/docs/plugins/reference/migrate-claude.md +19 -0
  473. package/docs/plugins/reference/migrate-hermes.md +19 -0
  474. package/docs/plugins/reference/minimax.md +23 -0
  475. package/docs/plugins/reference/mistral.md +23 -0
  476. package/docs/plugins/reference/moonshot.md +23 -0
  477. package/docs/plugins/reference/msteams.md +23 -0
  478. package/docs/plugins/reference/nextcloud-talk.md +23 -0
  479. package/docs/plugins/reference/nostr.md +23 -0
  480. package/docs/plugins/reference/nvidia.md +23 -0
  481. package/docs/plugins/reference/oc-path.md +23 -0
  482. package/docs/plugins/reference/ollama.md +23 -0
  483. package/docs/plugins/reference/open-prose.md +19 -0
  484. package/docs/plugins/reference/openai.md +23 -0
  485. package/docs/plugins/reference/opencode-go.md +23 -0
  486. package/docs/plugins/reference/opencode.md +23 -0
  487. package/docs/plugins/reference/openrouter.md +23 -0
  488. package/docs/plugins/reference/openshell.md +19 -0
  489. package/docs/plugins/reference/perplexity.md +23 -0
  490. package/docs/plugins/reference/policy.md +23 -0
  491. package/docs/plugins/reference/qa-channel.md +23 -0
  492. package/docs/plugins/reference/qa-lab.md +19 -0
  493. package/docs/plugins/reference/qa-matrix.md +19 -0
  494. package/docs/plugins/reference/qianfan.md +23 -0
  495. package/docs/plugins/reference/qqbot.md +23 -0
  496. package/docs/plugins/reference/qwen.md +23 -0
  497. package/docs/plugins/reference/runway.md +23 -0
  498. package/docs/plugins/reference/searxng.md +19 -0
  499. package/docs/plugins/reference/senseaudio.md +23 -0
  500. package/docs/plugins/reference/sglang.md +23 -0
  501. package/docs/plugins/reference/signal.md +23 -0
  502. package/docs/plugins/reference/skill-workshop.md +23 -0
  503. package/docs/plugins/reference/slack.md +23 -0
  504. package/docs/plugins/reference/stepfun.md +23 -0
  505. package/docs/plugins/reference/synology-chat.md +23 -0
  506. package/docs/plugins/reference/synthetic.md +23 -0
  507. package/docs/plugins/reference/tavily.md +23 -0
  508. package/docs/plugins/reference/telegram.md +23 -0
  509. package/docs/plugins/reference/tencent.md +23 -0
  510. package/docs/plugins/reference/tlon.md +23 -0
  511. package/docs/plugins/reference/together.md +23 -0
  512. package/docs/plugins/reference/tokenjuice.md +23 -0
  513. package/docs/plugins/reference/tts-local-cli.md +19 -0
  514. package/docs/plugins/reference/twitch.md +23 -0
  515. package/docs/plugins/reference/venice.md +23 -0
  516. package/docs/plugins/reference/vercel-ai-gateway.md +23 -0
  517. package/docs/plugins/reference/vllm.md +23 -0
  518. package/docs/plugins/reference/voice-call.md +23 -0
  519. package/docs/plugins/reference/volcengine.md +23 -0
  520. package/docs/plugins/reference/voyage.md +19 -0
  521. package/docs/plugins/reference/vydra.md +23 -0
  522. package/docs/plugins/reference/web-readability.md +19 -0
  523. package/docs/plugins/reference/webhooks.md +23 -0
  524. package/docs/plugins/reference/whatsapp.md +23 -0
  525. package/docs/plugins/reference/xai.md +23 -0
  526. package/docs/plugins/reference/xiaomi.md +23 -0
  527. package/docs/plugins/reference/zai.md +23 -0
  528. package/docs/plugins/reference/zalo.md +23 -0
  529. package/docs/plugins/reference/zalouser.md +24 -0
  530. package/docs/plugins/reference.md +138 -0
  531. package/docs/plugins/sdk-agent-harness.md +339 -0
  532. package/docs/plugins/sdk-channel-ingress.md +137 -0
  533. package/docs/plugins/sdk-channel-message.md +458 -0
  534. package/docs/plugins/sdk-channel-plugins.md +762 -0
  535. package/docs/plugins/sdk-channel-turn.md +580 -0
  536. package/docs/plugins/sdk-entrypoints.md +333 -0
  537. package/docs/plugins/sdk-migration.md +949 -0
  538. package/docs/plugins/sdk-overview.md +501 -0
  539. package/docs/plugins/sdk-provider-plugins.md +807 -0
  540. package/docs/plugins/sdk-runtime.md +676 -0
  541. package/docs/plugins/sdk-setup.md +550 -0
  542. package/docs/plugins/sdk-subpaths.md +396 -0
  543. package/docs/plugins/sdk-testing.md +401 -0
  544. package/docs/plugins/skill-workshop.md +713 -0
  545. package/docs/plugins/tool-plugins.md +411 -0
  546. package/docs/plugins/voice-call.md +943 -0
  547. package/docs/plugins/webhooks.md +192 -0
  548. package/docs/plugins/zalouser.md +86 -0
  549. package/docs/prose.md +137 -0
  550. package/docs/providers/alibaba.md +158 -0
  551. package/docs/providers/anthropic.md +344 -0
  552. package/docs/providers/arcee.md +144 -0
  553. package/docs/providers/azure-speech.md +119 -0
  554. package/docs/providers/bedrock-mantle.md +211 -0
  555. package/docs/providers/bedrock.md +414 -0
  556. package/docs/providers/cerebras.md +130 -0
  557. package/docs/providers/chutes.md +153 -0
  558. package/docs/providers/claude-max-api-proxy.md +188 -0
  559. package/docs/providers/cloudflare-ai-gateway.md +119 -0
  560. package/docs/providers/comfy.md +362 -0
  561. package/docs/providers/deepgram.md +184 -0
  562. package/docs/providers/deepinfra.md +87 -0
  563. package/docs/providers/deepseek.md +146 -0
  564. package/docs/providers/ds4.md +309 -0
  565. package/docs/providers/elevenlabs.md +130 -0
  566. package/docs/providers/fal.md +204 -0
  567. package/docs/providers/fireworks.md +144 -0
  568. package/docs/providers/github-copilot.md +225 -0
  569. package/docs/providers/glm.md +137 -0
  570. package/docs/providers/google.md +472 -0
  571. package/docs/providers/gradium.md +123 -0
  572. package/docs/providers/groq.md +180 -0
  573. package/docs/providers/huggingface.md +235 -0
  574. package/docs/providers/index.md +102 -0
  575. package/docs/providers/inferrs.md +272 -0
  576. package/docs/providers/inworld.md +120 -0
  577. package/docs/providers/kilocode.md +135 -0
  578. package/docs/providers/litellm.md +234 -0
  579. package/docs/providers/lmstudio.md +224 -0
  580. package/docs/providers/minimax.md +505 -0
  581. package/docs/providers/mistral.md +235 -0
  582. package/docs/providers/models.md +65 -0
  583. package/docs/providers/moonshot.md +413 -0
  584. package/docs/providers/nvidia.md +140 -0
  585. package/docs/providers/ollama.md +1180 -0
  586. package/docs/providers/openai.md +1057 -0
  587. package/docs/providers/opencode-go.md +123 -0
  588. package/docs/providers/opencode.md +149 -0
  589. package/docs/providers/openrouter.md +349 -0
  590. package/docs/providers/perplexity-provider.md +123 -0
  591. package/docs/providers/qianfan.md +132 -0
  592. package/docs/providers/qwen.md +332 -0
  593. package/docs/providers/runway.md +103 -0
  594. package/docs/providers/senseaudio.md +68 -0
  595. package/docs/providers/sglang.md +161 -0
  596. package/docs/providers/stepfun.md +229 -0
  597. package/docs/providers/synthetic.md +154 -0
  598. package/docs/providers/tencent.md +130 -0
  599. package/docs/providers/together.md +141 -0
  600. package/docs/providers/venice.md +315 -0
  601. package/docs/providers/vercel-ai-gateway.md +128 -0
  602. package/docs/providers/vllm.md +383 -0
  603. package/docs/providers/volcengine.md +199 -0
  604. package/docs/providers/vydra.md +180 -0
  605. package/docs/providers/xai.md +560 -0
  606. package/docs/providers/xiaomi.md +188 -0
  607. package/docs/providers/zai.md +203 -0
  608. package/docs/refactor/access.md +9 -0
  609. package/docs/refactor/acp.md +298 -0
  610. package/docs/refactor/canvas.md +131 -0
  611. package/docs/refactor/ingress-core.md +341 -0
  612. package/docs/reference/AGENTS.default.md +129 -0
  613. package/docs/reference/RELEASING.md +767 -0
  614. package/docs/reference/api-usage-costs.md +202 -0
  615. package/docs/reference/application-modernization-plan.md +208 -0
  616. package/docs/reference/code-mode.md +757 -0
  617. package/docs/reference/credits.md +33 -0
  618. package/docs/reference/device-models.md +50 -0
  619. package/docs/reference/full-release-validation.md +202 -0
  620. package/docs/reference/memory-config.md +630 -0
  621. package/docs/reference/openclaw-sdk-api-design.md +390 -0
  622. package/docs/reference/prompt-caching.md +358 -0
  623. package/docs/reference/rich-output-protocol.md +79 -0
  624. package/docs/reference/rpc.md +43 -0
  625. package/docs/reference/secretref-credential-surface.md +159 -0
  626. package/docs/reference/secretref-user-supplied-credentials-matrix.json +663 -0
  627. package/docs/reference/session-management-compaction.md +461 -0
  628. package/docs/reference/templates/AGENTS.dev.md +89 -0
  629. package/docs/reference/templates/AGENTS.md +225 -0
  630. package/docs/reference/templates/BOOT.md +16 -0
  631. package/docs/reference/templates/BOOTSTRAP.md +66 -0
  632. package/docs/reference/templates/HEARTBEAT.md +16 -0
  633. package/docs/reference/templates/IDENTITY.dev.md +52 -0
  634. package/docs/reference/templates/IDENTITY.md +34 -0
  635. package/docs/reference/templates/SOUL.dev.md +82 -0
  636. package/docs/reference/templates/SOUL.md +49 -0
  637. package/docs/reference/templates/TOOLS.dev.md +29 -0
  638. package/docs/reference/templates/TOOLS.md +51 -0
  639. package/docs/reference/templates/USER.dev.md +23 -0
  640. package/docs/reference/templates/USER.md +28 -0
  641. package/docs/reference/test.md +239 -0
  642. package/docs/reference/token-use.md +233 -0
  643. package/docs/reference/transcript-hygiene.md +214 -0
  644. package/docs/reference/wizard.md +252 -0
  645. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +101 -0
  646. package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
  647. package/docs/security/formal-verification.md +170 -0
  648. package/docs/security/incident-response.md +59 -0
  649. package/docs/security/network-proxy.md +268 -0
  650. package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +12 -0
  651. package/docs/snippets/plugin-publish/minimal-package.json +16 -0
  652. package/docs/start/bootstrapping.md +49 -0
  653. package/docs/start/docs-directory.md +69 -0
  654. package/docs/start/getting-started.md +152 -0
  655. package/docs/start/hubs.md +201 -0
  656. package/docs/start/lore.md +223 -0
  657. package/docs/start/onboarding-overview.md +72 -0
  658. package/docs/start/onboarding.md +95 -0
  659. package/docs/start/openclaw.md +244 -0
  660. package/docs/start/quickstart.md +25 -0
  661. package/docs/start/setup.md +178 -0
  662. package/docs/start/showcase.md +383 -0
  663. package/docs/start/wizard-cli-automation.md +232 -0
  664. package/docs/start/wizard-cli-reference.md +331 -0
  665. package/docs/start/wizard.md +141 -0
  666. package/docs/style.css +184 -0
  667. package/docs/superpowers/specs/2026-04-22-tweakcn-custom-theme-import-design.md +316 -0
  668. package/docs/tools/acp-agents-setup.md +352 -0
  669. package/docs/tools/acp-agents.md +847 -0
  670. package/docs/tools/agent-send.md +112 -0
  671. package/docs/tools/apply-patch.md +64 -0
  672. package/docs/tools/brave-search.md +139 -0
  673. package/docs/tools/browser-control.md +391 -0
  674. package/docs/tools/browser-linux-troubleshooting.md +173 -0
  675. package/docs/tools/browser-login.md +77 -0
  676. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +219 -0
  677. package/docs/tools/browser.md +769 -0
  678. package/docs/tools/btw.md +159 -0
  679. package/docs/tools/capability-cookbook.md +12 -0
  680. package/docs/tools/clawhub.md +5 -0
  681. package/docs/tools/code-execution.md +173 -0
  682. package/docs/tools/creating-skills.md +120 -0
  683. package/docs/tools/diffs.md +506 -0
  684. package/docs/tools/duckduckgo-search.md +109 -0
  685. package/docs/tools/elevated.md +128 -0
  686. package/docs/tools/exa-search.md +152 -0
  687. package/docs/tools/exec-approvals-advanced.md +360 -0
  688. package/docs/tools/exec-approvals.md +474 -0
  689. package/docs/tools/exec.md +282 -0
  690. package/docs/tools/firecrawl.md +155 -0
  691. package/docs/tools/gemini-search.md +114 -0
  692. package/docs/tools/grok-search.md +113 -0
  693. package/docs/tools/image-generation.md +433 -0
  694. package/docs/tools/index.md +178 -0
  695. package/docs/tools/kimi-search.md +105 -0
  696. package/docs/tools/llm-task.md +137 -0
  697. package/docs/tools/lobster.md +365 -0
  698. package/docs/tools/loop-detection.md +154 -0
  699. package/docs/tools/media-overview.md +157 -0
  700. package/docs/tools/minimax-search.md +102 -0
  701. package/docs/tools/multi-agent-sandbox-tools.md +409 -0
  702. package/docs/tools/music-generation.md +371 -0
  703. package/docs/tools/ollama-search.md +153 -0
  704. package/docs/tools/pdf.md +195 -0
  705. package/docs/tools/perplexity-search.md +220 -0
  706. package/docs/tools/plugin.md +327 -0
  707. package/docs/tools/reactions.md +100 -0
  708. package/docs/tools/searxng-search.md +141 -0
  709. package/docs/tools/skills-config.md +195 -0
  710. package/docs/tools/skills.md +535 -0
  711. package/docs/tools/slash-commands.md +488 -0
  712. package/docs/tools/steer.md +84 -0
  713. package/docs/tools/subagents.md +650 -0
  714. package/docs/tools/tavily.md +162 -0
  715. package/docs/tools/thinking.md +140 -0
  716. package/docs/tools/tokenjuice.md +81 -0
  717. package/docs/tools/tool-search.md +269 -0
  718. package/docs/tools/trajectory.md +229 -0
  719. package/docs/tools/tts.md +1004 -0
  720. package/docs/tools/video-generation.md +552 -0
  721. package/docs/tools/web-fetch.md +195 -0
  722. package/docs/tools/web.md +459 -0
  723. package/docs/tts.md +11 -0
  724. package/docs/vps.md +139 -0
  725. package/docs/web/control-ui.md +503 -0
  726. package/docs/web/dashboard.md +107 -0
  727. package/docs/web/index.md +133 -0
  728. package/docs/web/tui.md +246 -0
  729. package/docs/web/webchat.md +99 -0
  730. package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
  731. package/docs/whatsapp-openclaw.jpg +0 -0
  732. package/nodmix.mjs +487 -0
  733. package/package.json +1852 -0
  734. package/patches/.gitkeep +0 -0
  735. package/patches/@agentclientprotocol__claude-agent-acp@0.36.1.patch +41 -0
  736. package/pnpm-workspace.yaml +63 -0
  737. package/scripts/crabbox-wrapper.mjs +353 -0
  738. package/scripts/lib/official-external-channel-catalog.json +559 -0
  739. package/scripts/lib/official-external-plugin-catalog.json +192 -0
  740. package/scripts/lib/official-external-provider-catalog.json +117 -0
  741. package/scripts/lib/package-dist-imports.mjs +171 -0
  742. package/scripts/npm-runner.mjs +91 -0
  743. package/scripts/postinstall-bundled-plugins.mjs +978 -0
  744. package/scripts/preinstall-package-manager-warning.mjs +64 -0
  745. package/scripts/windows-cmd-helpers.mjs +20 -0
  746. package/skills/1password/SKILL.md +70 -0
  747. package/skills/1password/references/cli-examples.md +29 -0
  748. package/skills/1password/references/get-started.md +17 -0
  749. package/skills/apple-notes/SKILL.md +77 -0
  750. package/skills/apple-reminders/SKILL.md +118 -0
  751. package/skills/bear-notes/SKILL.md +107 -0
  752. package/skills/blogwatcher/SKILL.md +69 -0
  753. package/skills/blucli/SKILL.md +47 -0
  754. package/skills/camsnap/SKILL.md +45 -0
  755. package/skills/canvas/SKILL.md +78 -0
  756. package/skills/clawhub/SKILL.md +77 -0
  757. package/skills/coding-agent/SKILL.md +149 -0
  758. package/skills/diagram-maker/SKILL.md +53 -0
  759. package/skills/diagram-maker/references/excalidraw-patterns.md +85 -0
  760. package/skills/diagram-maker/references/svg-template.md +112 -0
  761. package/skills/discord/SKILL.md +136 -0
  762. package/skills/eightctl/SKILL.md +50 -0
  763. package/skills/gemini/SKILL.md +47 -0
  764. package/skills/gh-issues/SKILL.md +213 -0
  765. package/skills/gifgrep/SKILL.md +85 -0
  766. package/skills/github/SKILL.md +84 -0
  767. package/skills/gog/SKILL.md +116 -0
  768. package/skills/goplaces/SKILL.md +52 -0
  769. package/skills/healthcheck/SKILL.md +105 -0
  770. package/skills/himalaya/SKILL.md +80 -0
  771. package/skills/himalaya/references/configuration.md +184 -0
  772. package/skills/himalaya/references/message-composition.md +199 -0
  773. package/skills/imsg/SKILL.md +122 -0
  774. package/skills/mcporter/SKILL.md +61 -0
  775. package/skills/meme-maker/SKILL.md +42 -0
  776. package/skills/meme-maker/references/templates.json +358 -0
  777. package/skills/meme-maker/scripts/meme.mjs +398 -0
  778. package/skills/model-usage/SKILL.md +69 -0
  779. package/skills/model-usage/references/codexbar-cli.md +33 -0
  780. package/skills/model-usage/scripts/model_usage.py +319 -0
  781. package/skills/model-usage/scripts/test_model_usage.py +40 -0
  782. package/skills/nano-pdf/SKILL.md +38 -0
  783. package/skills/node-connect/SKILL.md +142 -0
  784. package/skills/node-inspect-debugger/SKILL.md +85 -0
  785. package/skills/notion/SKILL.md +150 -0
  786. package/skills/obsidian/SKILL.md +119 -0
  787. package/skills/openai-whisper/SKILL.md +38 -0
  788. package/skills/openai-whisper-api/SKILL.md +71 -0
  789. package/skills/openai-whisper-api/scripts/transcribe.sh +154 -0
  790. package/skills/openhue/SKILL.md +112 -0
  791. package/skills/oracle/SKILL.md +126 -0
  792. package/skills/ordercli/SKILL.md +78 -0
  793. package/skills/peekaboo/SKILL.md +190 -0
  794. package/skills/pyproject.toml +10 -0
  795. package/skills/python-debugpy/SKILL.md +73 -0
  796. package/skills/sag/SKILL.md +87 -0
  797. package/skills/session-logs/SKILL.md +151 -0
  798. package/skills/sherpa-onnx-tts/SKILL.md +109 -0
  799. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  800. package/skills/skill-creator/SKILL.md +78 -0
  801. package/skills/skill-creator/license.txt +202 -0
  802. package/skills/skill-creator/scripts/init_skill.py +378 -0
  803. package/skills/skill-creator/scripts/package_skill.py +139 -0
  804. package/skills/skill-creator/scripts/quick_validate.py +169 -0
  805. package/skills/skill-creator/scripts/test_package_skill.py +161 -0
  806. package/skills/skill-creator/scripts/test_quick_validate.py +116 -0
  807. package/skills/slack/SKILL.md +78 -0
  808. package/skills/songsee/SKILL.md +49 -0
  809. package/skills/sonoscli/SKILL.md +65 -0
  810. package/skills/spike/SKILL.md +51 -0
  811. package/skills/spotify-player/SKILL.md +64 -0
  812. package/skills/summarize/SKILL.md +87 -0
  813. package/skills/taskflow/SKILL.md +149 -0
  814. package/skills/taskflow/examples/inbox-triage.lobster +33 -0
  815. package/skills/taskflow/examples/pr-intake.lobster +32 -0
  816. package/skills/taskflow-inbox-triage/SKILL.md +119 -0
  817. package/skills/things-mac/SKILL.md +86 -0
  818. package/skills/tmux/SKILL.md +91 -0
  819. package/skills/tmux/scripts/find-sessions.sh +112 -0
  820. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  821. package/skills/trello/SKILL.md +108 -0
  822. package/skills/video-frames/SKILL.md +46 -0
  823. package/skills/video-frames/scripts/frame.sh +81 -0
  824. package/skills/voice-call/SKILL.md +45 -0
  825. package/skills/wacli/SKILL.md +72 -0
  826. package/skills/weather/SKILL.md +64 -0
  827. package/skills/xurl/SKILL.md +120 -0
@@ -0,0 +1,803 @@
1
+ ---
2
+ summary: "Gateway WebSocket protocol: handshake, frames, versioning"
3
+ read_when:
4
+ - Implementing or updating gateway WS clients
5
+ - Debugging protocol mismatches or connect failures
6
+ - Regenerating protocol schema/models
7
+ title: "Gateway protocol"
8
+ ---
9
+
10
+ The Gateway WS protocol is the **single control plane + node transport** for
11
+ Nodmix. All clients (CLI, web UI, macOS app, iOS/Android nodes, headless
12
+ nodes) connect over WebSocket and declare their **role** + **scope** at
13
+ handshake time.
14
+
15
+ ## Transport
16
+
17
+ - WebSocket, text frames with JSON payloads.
18
+ - First frame **must** be a `connect` request.
19
+ - Pre-connect frames are capped at 64 KiB. After a successful handshake, clients
20
+ should follow the `hello-ok.policy.maxPayload` and
21
+ `hello-ok.policy.maxBufferedBytes` limits. With diagnostics enabled,
22
+ oversized inbound frames and slow outbound buffers emit `payload.large` events
23
+ before the gateway closes or drops the affected frame. These events keep
24
+ sizes, limits, surfaces, and safe reason codes. They do not keep the message
25
+ body, attachment contents, raw frame body, tokens, cookies, or secret values.
26
+
27
+ ## Handshake (connect)
28
+
29
+ Gateway → Client (pre-connect challenge):
30
+
31
+ ```json
32
+ {
33
+ "type": "event",
34
+ "event": "connect.challenge",
35
+ "payload": { "nonce": "…", "ts": 1737264000000 }
36
+ }
37
+ ```
38
+
39
+ Client → Gateway:
40
+
41
+ ```json
42
+ {
43
+ "type": "req",
44
+ "id": "…",
45
+ "method": "connect",
46
+ "params": {
47
+ "minProtocol": 3,
48
+ "maxProtocol": 4,
49
+ "client": {
50
+ "id": "cli",
51
+ "version": "1.2.3",
52
+ "platform": "macos",
53
+ "mode": "operator"
54
+ },
55
+ "role": "operator",
56
+ "scopes": ["operator.read", "operator.write"],
57
+ "caps": [],
58
+ "commands": [],
59
+ "permissions": {},
60
+ "auth": { "token": "…" },
61
+ "locale": "en-US",
62
+ "userAgent": "nodmix-cli/1.2.3",
63
+ "device": {
64
+ "id": "device_fingerprint",
65
+ "publicKey": "…",
66
+ "signature": "…",
67
+ "signedAt": 1737264000000,
68
+ "nonce": "…"
69
+ }
70
+ }
71
+ }
72
+ ```
73
+
74
+ Gateway → Client:
75
+
76
+ ```json
77
+ {
78
+ "type": "res",
79
+ "id": "…",
80
+ "ok": true,
81
+ "payload": {
82
+ "type": "hello-ok",
83
+ "protocol": 4,
84
+ "server": { "version": "…", "connId": "…" },
85
+ "features": { "methods": ["…"], "events": ["…"] },
86
+ "snapshot": { "…": "…" },
87
+ "auth": {
88
+ "role": "operator",
89
+ "scopes": ["operator.read", "operator.write"]
90
+ },
91
+ "policy": {
92
+ "maxPayload": 26214400,
93
+ "maxBufferedBytes": 52428800,
94
+ "tickIntervalMs": 15000
95
+ }
96
+ }
97
+ }
98
+ ```
99
+
100
+ While the Gateway is still finishing startup sidecars, the `connect` request can
101
+ return a retryable `UNAVAILABLE` error with `details.reason` set to
102
+ `"startup-sidecars"` and `retryAfterMs`. Clients should retry that response
103
+ within their overall connection budget instead of surfacing it as a terminal
104
+ handshake failure.
105
+
106
+ `server`, `features`, `snapshot`, and `policy` are all required by the schema
107
+ (`src/gateway/protocol/schema/frames.ts`). `auth` is also required and reports
108
+ the negotiated role/scopes. `pluginSurfaceUrls` is optional and maps plugin
109
+ surface names, such as `canvas`, to scoped hosted URLs.
110
+
111
+ Scoped plugin surface URLs may expire. Nodes can call
112
+ `node.pluginSurface.refresh` with `{ "surface": "canvas" }` to receive a fresh
113
+ entry in `pluginSurfaceUrls`. The experimental Canvas plugin refactor does not
114
+ support the deprecated `canvasHostUrl`, `canvasCapability`, or
115
+ `node.canvas.capability.refresh` compatibility path; current native clients and
116
+ gateways must use plugin surfaces.
117
+
118
+ When no device token is issued, `hello-ok.auth` reports the negotiated
119
+ permissions without token fields:
120
+
121
+ ```json
122
+ {
123
+ "auth": {
124
+ "role": "operator",
125
+ "scopes": ["operator.read", "operator.write"]
126
+ }
127
+ }
128
+ ```
129
+
130
+ Trusted same-process backend clients (`client.id: "gateway-client"`,
131
+ `client.mode: "backend"`) may omit `device` on direct loopback connections when
132
+ they authenticate with the shared gateway token/password. This path is reserved
133
+ for internal control-plane RPCs and keeps stale CLI/device pairing baselines from
134
+ blocking local backend work such as subagent session updates. Remote clients,
135
+ browser-origin clients, node clients, and explicit device-token/device-identity
136
+ clients still use the normal pairing and scope-upgrade checks.
137
+
138
+ When a device token is issued, `hello-ok` also includes:
139
+
140
+ ```json
141
+ {
142
+ "auth": {
143
+ "deviceToken": "…",
144
+ "role": "operator",
145
+ "scopes": ["operator.read", "operator.write"]
146
+ }
147
+ }
148
+ ```
149
+
150
+ Built-in QR/setup-code bootstrap is a fresh mobile handoff path. A successful
151
+ baseline setup-code connect returns a primary node token plus one bounded
152
+ operator token:
153
+
154
+ ```json
155
+ {
156
+ "auth": {
157
+ "deviceToken": "…",
158
+ "role": "node",
159
+ "scopes": [],
160
+ "deviceTokens": [
161
+ {
162
+ "deviceToken": "…",
163
+ "role": "operator",
164
+ "scopes": ["operator.approvals", "operator.read", "operator.write"]
165
+ }
166
+ ]
167
+ }
168
+ }
169
+ ```
170
+
171
+ The operator handoff is intentionally bounded so QR onboarding can start the
172
+ mobile operator loop without granting `operator.admin`, `operator.pairing`, or
173
+ `operator.talk.secrets`. Those scopes require a separate approved operator
174
+ pairing or token flow. Clients should persist `hello-ok.auth.deviceTokens` only
175
+ when the connect used bootstrap auth on trusted transport such as `wss://` or
176
+ loopback/local pairing.
177
+
178
+ ### Node example
179
+
180
+ ```json
181
+ {
182
+ "type": "req",
183
+ "id": "…",
184
+ "method": "connect",
185
+ "params": {
186
+ "minProtocol": 3,
187
+ "maxProtocol": 4,
188
+ "client": {
189
+ "id": "ios-node",
190
+ "version": "1.2.3",
191
+ "platform": "ios",
192
+ "mode": "node"
193
+ },
194
+ "role": "node",
195
+ "scopes": [],
196
+ "caps": ["camera", "canvas", "screen", "location", "voice"],
197
+ "commands": ["camera.snap", "canvas.navigate", "screen.record", "location.get"],
198
+ "permissions": { "camera.capture": true, "screen.record": false },
199
+ "auth": { "token": "…" },
200
+ "locale": "en-US",
201
+ "userAgent": "nodmix-ios/1.2.3",
202
+ "device": {
203
+ "id": "device_fingerprint",
204
+ "publicKey": "…",
205
+ "signature": "…",
206
+ "signedAt": 1737264000000,
207
+ "nonce": "…"
208
+ }
209
+ }
210
+ }
211
+ ```
212
+
213
+ ## Framing
214
+
215
+ - **Request**: `{type:"req", id, method, params}`
216
+ - **Response**: `{type:"res", id, ok, payload|error}`
217
+ - **Event**: `{type:"event", event, payload, seq?, stateVersion?}`
218
+
219
+ Side-effecting methods require **idempotency keys** (see schema).
220
+
221
+ ## Roles + scopes
222
+
223
+ For the full operator scope model, approval-time checks, and shared-secret
224
+ semantics, see [Operator scopes](/gateway/operator-scopes).
225
+
226
+ ### Roles
227
+
228
+ - `operator` = control plane client (CLI/UI/automation).
229
+ - `node` = capability host (camera/screen/canvas/system.run).
230
+
231
+ ### Scopes (operator)
232
+
233
+ Common scopes:
234
+
235
+ - `operator.read`
236
+ - `operator.write`
237
+ - `operator.admin`
238
+ - `operator.approvals`
239
+ - `operator.pairing`
240
+ - `operator.talk.secrets`
241
+
242
+ `talk.config` with `includeSecrets: true` requires `operator.talk.secrets`
243
+ (or `operator.admin`).
244
+
245
+ Plugin-registered gateway RPC methods may request their own operator scope, but
246
+ reserved core admin prefixes (`config.*`, `exec.approvals.*`, `wizard.*`,
247
+ `update.*`) always resolve to `operator.admin`.
248
+
249
+ Method scope is only the first gate. Some slash commands reached through
250
+ `chat.send` apply stricter command-level checks on top. For example, persistent
251
+ `/config set` and `/config unset` writes require `operator.admin`.
252
+
253
+ `node.pair.approve` also has an extra approval-time scope check on top of the
254
+ base method scope:
255
+
256
+ - commandless requests: `operator.pairing`
257
+ - requests with non-exec node commands: `operator.pairing` + `operator.write`
258
+ - requests that include `system.run`, `system.run.prepare`, or `system.which`:
259
+ `operator.pairing` + `operator.admin`
260
+
261
+ ### Caps/commands/permissions (node)
262
+
263
+ Nodes declare capability claims at connect time:
264
+
265
+ - `caps`: high-level capability categories such as `camera`, `canvas`, `screen`,
266
+ `location`, `voice`, and `talk`.
267
+ - `commands`: command allowlist for invoke.
268
+ - `permissions`: granular toggles (e.g. `screen.record`, `camera.capture`).
269
+
270
+ The Gateway treats these as **claims** and enforces server-side allowlists.
271
+
272
+ ## Presence
273
+
274
+ - `system-presence` returns entries keyed by device identity.
275
+ - Presence entries include `deviceId`, `roles`, and `scopes` so UIs can show a single row per device
276
+ even when it connects as both **operator** and **node**.
277
+ - `node.list` includes optional `lastSeenAtMs` and `lastSeenReason` fields. Connected nodes report
278
+ their current connection time as `lastSeenAtMs` with reason `connect`; paired nodes can also report
279
+ durable background presence when a trusted node event updates their pairing metadata.
280
+
281
+ ### Node background alive event
282
+
283
+ Nodes may call `node.event` with `event: "node.presence.alive"` to record that a paired node was
284
+ alive during a background wake without marking it connected.
285
+
286
+ ```json
287
+ {
288
+ "event": "node.presence.alive",
289
+ "payloadJSON": "{\"trigger\":\"silent_push\",\"sentAtMs\":1737264000000,\"displayName\":\"Peter's iPhone\",\"version\":\"2026.4.28\",\"platform\":\"iOS 18.4.0\",\"deviceFamily\":\"iPhone\",\"modelIdentifier\":\"iPhone17,1\",\"pushTransport\":\"relay\"}"
290
+ }
291
+ ```
292
+
293
+ `trigger` is a closed enum: `background`, `silent_push`, `bg_app_refresh`,
294
+ `significant_location`, `manual`, or `connect`. Unknown trigger strings are normalized to
295
+ `background` by the gateway before persistence. The event is durable only for authenticated node
296
+ device sessions; device-less or unpaired sessions return `handled: false`.
297
+
298
+ Successful gateways return a structured result:
299
+
300
+ ```json
301
+ {
302
+ "ok": true,
303
+ "event": "node.presence.alive",
304
+ "handled": true,
305
+ "reason": "persisted"
306
+ }
307
+ ```
308
+
309
+ Older gateways may still return `{ "ok": true }` for `node.event`; clients should treat that as an
310
+ acknowledged RPC, not as durable presence persistence.
311
+
312
+ ## Broadcast event scoping
313
+
314
+ Server-pushed WebSocket broadcast events are scope-gated so that pairing-scoped or node-only sessions do not passively receive session content.
315
+
316
+ - **Chat, agent, and tool-result frames** (including streamed `agent` events and tool call results) require at least `operator.read`. Sessions without `operator.read` skip these frames entirely.
317
+ - **Plugin-defined `plugin.*` broadcasts** are gated to `operator.write` or `operator.admin`, depending on how the plugin registered them.
318
+ - **Status and transport events** (`heartbeat`, `presence`, `tick`, connect/disconnect lifecycle, etc.) remain unrestricted so transport health stays observable to every authenticated session.
319
+ - **Unknown broadcast event families** are scope-gated by default (fail-closed) unless a registered handler explicitly relaxes them.
320
+
321
+ Each client connection keeps its own per-client sequence number so broadcasts preserve monotonic ordering on that socket even when different clients see different scope-filtered subsets of the event stream.
322
+
323
+ ## Common RPC method families
324
+
325
+ The public WS surface is broader than the handshake/auth examples above. This
326
+ is not a generated dump — `hello-ok.features.methods` is a conservative
327
+ discovery list built from `src/gateway/server-methods-list.ts` plus loaded
328
+ plugin/channel method exports. Treat it as feature discovery, not a full
329
+ enumeration of `src/gateway/server-methods/*.ts`.
330
+
331
+ <AccordionGroup>
332
+ <Accordion title="System and identity">
333
+ - `health` returns the cached or freshly probed gateway health snapshot.
334
+ - `diagnostics.stability` returns the recent bounded diagnostic stability recorder. It keeps operational metadata such as event names, counts, byte sizes, memory readings, queue/session state, channel/plugin names, and session ids. It does not keep chat text, webhook bodies, tool outputs, raw request or response bodies, tokens, cookies, or secret values. Operator read scope is required.
335
+ - `status` returns the `/status`-style gateway summary; sensitive fields are included only for admin-scoped operator clients.
336
+ - `gateway.identity.get` returns the gateway device identity used by relay and pairing flows.
337
+ - `system-presence` returns the current presence snapshot for connected operator/node devices.
338
+ - `system-event` appends a system event and can update/broadcast presence context.
339
+ - `last-heartbeat` returns the latest persisted heartbeat event.
340
+ - `set-heartbeats` toggles heartbeat processing on the gateway.
341
+
342
+ </Accordion>
343
+
344
+ <Accordion title="Models and usage">
345
+ - `models.list` returns the runtime-allowed model catalog. Pass `{ "view": "configured" }` for picker-sized configured models (`agents.defaults.models` first, then `models.providers.*.models`), or `{ "view": "all" }` for the full catalog.
346
+ - `usage.status` returns provider usage windows/remaining quota summaries.
347
+ - `usage.cost` returns aggregated cost usage summaries for a date range.
348
+ - `doctor.memory.status` returns vector-memory / cached embedding readiness for the active default agent workspace. Pass `{ "probe": true }` or `{ "deep": true }` only when the caller explicitly wants a live embedding provider ping.
349
+ - `doctor.memory.remHarness` returns a bounded, read-only REM harness preview for remote control-plane clients. It can include workspace paths, memory snippets, rendered grounded markdown, and deep promotion candidates, so callers need `operator.read`.
350
+ - `sessions.usage` returns per-session usage summaries.
351
+ - `sessions.usage.timeseries` returns timeseries usage for one session.
352
+ - `sessions.usage.logs` returns usage log entries for one session.
353
+
354
+ </Accordion>
355
+
356
+ <Accordion title="Channels and login helpers">
357
+ - `channels.status` returns built-in + bundled channel/plugin status summaries.
358
+ - `channels.logout` logs out a specific channel/account where the channel supports logout.
359
+ - `web.login.start` starts a QR/web login flow for the current QR-capable web channel provider.
360
+ - `web.login.wait` waits for that QR/web login flow to complete and starts the channel on success.
361
+ - `push.test` sends a test APNs push to a registered iOS node.
362
+ - `voicewake.get` returns the stored wake-word triggers.
363
+ - `voicewake.set` updates wake-word triggers and broadcasts the change.
364
+
365
+ </Accordion>
366
+
367
+ <Accordion title="Messaging and logs">
368
+ - `send` is the direct outbound-delivery RPC for channel/account/thread-targeted sends outside the chat runner.
369
+ - `logs.tail` returns the configured gateway file-log tail with cursor/limit and max-byte controls.
370
+
371
+ </Accordion>
372
+
373
+ <Accordion title="Talk and TTS">
374
+ - `talk.catalog` returns the read-only Talk provider catalog for speech, streaming transcription, and realtime voice. It includes provider ids, labels, configured state, exposed model/voice ids, canonical modes, transports, brain strategies, and realtime audio/capability flags without returning provider secrets or mutating global config.
375
+ - `talk.config` returns the effective Talk config payload; `includeSecrets` requires `operator.talk.secrets` (or `operator.admin`).
376
+ - `talk.session.create` creates a Gateway-owned Talk session for `realtime/gateway-relay`, `transcription/gateway-relay`, or `stt-tts/managed-room`. For `stt-tts/managed-room`, `operator.write` callers that pass `sessionKey` must also pass `spawnedBy` for scoped session-key visibility; unscoped `sessionKey` creation and `brain: "direct-tools"` require `operator.admin`.
377
+ - `talk.session.join` validates a managed-room session token, emits `session.ready` or `session.replaced` events as needed, and returns room/session metadata plus recent Talk events without the plaintext token or stored token hash.
378
+ - `talk.session.appendAudio` appends base64 PCM input audio to Gateway-owned realtime relay and transcription sessions.
379
+ - `talk.session.startTurn`, `talk.session.endTurn`, and `talk.session.cancelTurn` drive managed-room turn lifecycle with stale-turn rejection before state is cleared.
380
+ - `talk.session.cancelOutput` stops assistant audio output, primarily for VAD-gated barge-in in Gateway relay sessions.
381
+ - `talk.session.submitToolResult` completes a provider tool call emitted by a Gateway-owned realtime relay session. Pass `options: { willContinue: true }` for interim tool output when a final result will follow, or `options: { suppressResponse: true }` when the tool result should satisfy the provider call without starting another realtime assistant response.
382
+ - `talk.session.close` closes a Gateway-owned relay, transcription, or managed-room session and emits terminal Talk events.
383
+ - `talk.mode` sets/broadcasts the current Talk mode state for WebChat/Control UI clients.
384
+ - `talk.client.create` creates a client-owned realtime provider session using `webrtc` or `provider-websocket` while the Gateway owns config, credentials, instructions, and tool policy.
385
+ - `talk.client.toolCall` lets client-owned realtime transports forward provider tool calls to Gateway policy. The first supported tool is `nodmix_agent_consult`; clients receive a run id and wait for normal chat lifecycle events before submitting the provider-specific tool result.
386
+ - `talk.event` is the single Talk event channel for realtime, transcription, STT/TTS, managed-room, telephony, and meeting adapters.
387
+ - `talk.speak` synthesizes speech through the active Talk speech provider.
388
+ - `tts.status` returns TTS enabled state, active provider, fallback providers, and provider config state.
389
+ - `tts.providers` returns the visible TTS provider inventory.
390
+ - `tts.enable` and `tts.disable` toggle TTS prefs state.
391
+ - `tts.setProvider` updates the preferred TTS provider.
392
+ - `tts.convert` runs one-shot text-to-speech conversion.
393
+
394
+ </Accordion>
395
+
396
+ <Accordion title="Secrets, config, update, and wizard">
397
+ - `secrets.reload` re-resolves active SecretRefs and swaps runtime secret state only on full success.
398
+ - `secrets.resolve` resolves command-target secret assignments for a specific command/target set.
399
+ - `config.get` returns the current config snapshot and hash.
400
+ - `config.set` writes a validated config payload.
401
+ - `config.patch` merges a partial config update.
402
+ - `config.apply` validates + replaces the full config payload.
403
+ - `config.schema` returns the live config schema payload used by Control UI and CLI tooling: schema, `uiHints`, version, and generation metadata, including plugin + channel schema metadata when the runtime can load it. The schema includes field `title` / `description` metadata derived from the same labels and help text used by the UI, including nested object, wildcard, array-item, and `anyOf` / `oneOf` / `allOf` composition branches when matching field documentation exists.
404
+ - `config.schema.lookup` returns a path-scoped lookup payload for one config path: normalized path, a shallow schema node, matched hint + `hintPath`, optional `reloadKind`, and immediate child summaries for UI/CLI drill-down. `reloadKind` is one of `restart`, `hot`, or `none` and mirrors the Gateway config reload planner for the requested path. Lookup schema nodes keep the user-facing docs and common validation fields (`title`, `description`, `type`, `enum`, `const`, `format`, `pattern`, numeric/string/array/object bounds, and flags like `additionalProperties`, `deprecated`, `readOnly`, `writeOnly`). Child summaries expose `key`, normalized `path`, `type`, `required`, `hasChildren`, optional `reloadKind`, plus the matched `hint` / `hintPath`.
405
+ - `update.run` runs the gateway update flow and schedules a restart only when the update itself succeeded; callers with a session can include `continuationMessage` so startup resumes one follow-up agent turn through the restart continuation queue. Package-manager updates from the control plane use a detached managed-service handoff instead of replacing the package tree inside the live Gateway. A started handoff returns `ok: true` with `result.reason: "managed-service-handoff-started"` and `handoff.status: "started"`; unavailable or failed handoffs return `ok: false` with `managed-service-handoff-unavailable` or `managed-service-handoff-failed`, plus `handoff.command` when a manual shell update is required. During a started handoff, the restart sentinel may briefly report `stats.reason: "restart-health-pending"`; the continuation is delayed until the CLI verifies the restarted Gateway and writes the final `ok` sentinel.
406
+ - `update.status` returns the latest cached update restart sentinel, including the post-restart running version when available.
407
+ - `wizard.start`, `wizard.next`, `wizard.status`, and `wizard.cancel` expose the onboarding wizard over WS RPC.
408
+
409
+ </Accordion>
410
+
411
+ <Accordion title="Agent and workspace helpers">
412
+ - `agents.list` returns configured agent entries, including effective model and runtime metadata.
413
+ - `agents.create`, `agents.update`, and `agents.delete` manage agent records and workspace wiring.
414
+ - `agents.files.list`, `agents.files.get`, and `agents.files.set` manage the bootstrap workspace files exposed for an agent.
415
+ - `tasks.list`, `tasks.get`, and `tasks.cancel` expose the Gateway task ledger to SDK and operator clients.
416
+ - `artifacts.list`, `artifacts.get`, and `artifacts.download` expose transcript-derived artifact summaries and downloads for an explicit `sessionKey`, `runId`, or `taskId` scope. Run and task queries resolve the owning session server-side and only return transcript media with matching provenance; unsafe or local URL sources return unsupported downloads instead of fetching server-side.
417
+ - `environments.list` and `environments.status` expose read-only Gateway-local and node environment discovery for SDK clients.
418
+ - `agent.identity.get` returns the effective assistant identity for an agent or session.
419
+ - `agent.wait` waits for a run to finish and returns the terminal snapshot when available.
420
+
421
+ </Accordion>
422
+
423
+ <Accordion title="Session control">
424
+ - `sessions.list` returns the current session index, including per-row `agentRuntime` metadata when an agent runtime backend is configured.
425
+ - `sessions.subscribe` and `sessions.unsubscribe` toggle session change event subscriptions for the current WS client.
426
+ - `sessions.messages.subscribe` and `sessions.messages.unsubscribe` toggle transcript/message event subscriptions for one session.
427
+ - `sessions.preview` returns bounded transcript previews for specific session keys.
428
+ - `sessions.describe` returns one Gateway session row for an exact session key.
429
+ - `sessions.resolve` resolves or canonicalizes a session target.
430
+ - `sessions.create` creates a new session entry.
431
+ - `sessions.send` sends a message into an existing session.
432
+ - `sessions.steer` is the interrupt-and-steer variant for an active session.
433
+ - `sessions.abort` aborts active work for a session. A caller may pass `key` plus optional `runId`, or pass `runId` alone for active runs the Gateway can resolve to a session.
434
+ - `sessions.patch` updates session metadata/overrides and reports the resolved canonical model plus effective `agentRuntime`.
435
+ - `sessions.reset`, `sessions.delete`, and `sessions.compact` perform session maintenance.
436
+ - `sessions.get` returns the full stored session row.
437
+ - Chat execution still uses `chat.history`, `chat.send`, `chat.abort`, and `chat.inject`. `chat.history` is display-normalized for UI clients: inline directive tags are stripped from visible text, plain-text tool-call XML payloads (including `<tool_call>...</tool_call>`, `<function_call>...</function_call>`, `<tool_calls>...</tool_calls>`, `<function_calls>...</function_calls>`, and truncated tool-call blocks) and leaked ASCII/full-width model control tokens are stripped, pure silent-token assistant rows such as exact `NO_REPLY` / `no_reply` are omitted, and oversized rows can be replaced with placeholders.
438
+
439
+ </Accordion>
440
+
441
+ <Accordion title="Device pairing and device tokens">
442
+ - `device.pair.list` returns pending and approved paired devices.
443
+ - `device.pair.approve`, `device.pair.reject`, and `device.pair.remove` manage device-pairing records.
444
+ - `device.token.rotate` rotates a paired device token within its approved role and caller scope bounds.
445
+ - `device.token.revoke` revokes a paired device token within its approved role and caller scope bounds.
446
+
447
+ </Accordion>
448
+
449
+ <Accordion title="Node pairing, invoke, and pending work">
450
+ - `node.pair.request`, `node.pair.list`, `node.pair.approve`, `node.pair.reject`, `node.pair.remove`, and `node.pair.verify` cover node pairing and bootstrap verification.
451
+ - `node.list` and `node.describe` return known/connected node state.
452
+ - `node.rename` updates a paired node label.
453
+ - `node.invoke` forwards a command to a connected node.
454
+ - `node.invoke.result` returns the result for an invoke request.
455
+ - `node.event` carries node-originated events back into the gateway.
456
+ - `node.pending.pull` and `node.pending.ack` are the connected-node queue APIs.
457
+ - `node.pending.enqueue` and `node.pending.drain` manage durable pending work for offline/disconnected nodes.
458
+
459
+ </Accordion>
460
+
461
+ <Accordion title="Approval families">
462
+ - `exec.approval.request`, `exec.approval.get`, `exec.approval.list`, and `exec.approval.resolve` cover one-shot exec approval requests plus pending approval lookup/replay.
463
+ - `exec.approval.waitDecision` waits on one pending exec approval and returns the final decision (or `null` on timeout).
464
+ - `exec.approvals.get` and `exec.approvals.set` manage gateway exec approval policy snapshots.
465
+ - `exec.approvals.node.get` and `exec.approvals.node.set` manage node-local exec approval policy via node relay commands.
466
+ - `plugin.approval.request`, `plugin.approval.list`, `plugin.approval.waitDecision`, and `plugin.approval.resolve` cover plugin-defined approval flows.
467
+
468
+ </Accordion>
469
+
470
+ <Accordion title="Automation, skills, and tools">
471
+ - Automation: `wake` schedules an immediate or next-heartbeat wake text injection; `cron.get`, `cron.list`, `cron.status`, `cron.add`, `cron.update`, `cron.remove`, `cron.run`, `cron.runs` manage scheduled work.
472
+ - `cron.run` remains an enqueue-style RPC for manual runs. Clients that need completion semantics should read the returned `runId` and poll `cron.runs`.
473
+ - `cron.runs` accepts an optional non-empty `runId` filter so clients can follow one queued manual run without racing against other history entries for the same job.
474
+ - Skills and tools: `commands.list`, `skills.*`, `tools.catalog`, `tools.effective`, `tools.invoke`.
475
+
476
+ </Accordion>
477
+ </AccordionGroup>
478
+
479
+ ### Common event families
480
+
481
+ - `chat`: UI chat updates such as `chat.inject` and other transcript-only chat
482
+ events. In protocol v4, delta payloads carry `deltaText`; `message` remains
483
+ the cumulative assistant snapshot. Non-prefix replacements set `replace=true`
484
+ and use `deltaText` as the replacement text.
485
+ - `session.message`, `session.operation`, and `session.tool`: transcript,
486
+ in-flight session operation, and event-stream updates for a subscribed
487
+ session.
488
+ - `sessions.changed`: session index or metadata changed.
489
+ - `presence`: system presence snapshot updates.
490
+ - `tick`: periodic keepalive / liveness event.
491
+ - `health`: gateway health snapshot update.
492
+ - `heartbeat`: heartbeat event stream update.
493
+ - `cron`: cron run/job change event.
494
+ - `shutdown`: gateway shutdown notification.
495
+ - `node.pair.requested` / `node.pair.resolved`: node pairing lifecycle.
496
+ - `node.invoke.request`: node invoke request broadcast.
497
+ - `device.pair.requested` / `device.pair.resolved`: paired-device lifecycle.
498
+ - `voicewake.changed`: wake-word trigger config changed.
499
+ - `exec.approval.requested` / `exec.approval.resolved`: exec approval
500
+ lifecycle.
501
+ - `plugin.approval.requested` / `plugin.approval.resolved`: plugin approval
502
+ lifecycle.
503
+
504
+ ### Node helper methods
505
+
506
+ - Nodes may call `skills.bins` to fetch the current list of skill executables
507
+ for auto-allow checks.
508
+
509
+ ### Task ledger RPCs
510
+
511
+ Operator clients may inspect and cancel Gateway background task records through
512
+ the task ledger RPCs. These methods return sanitized task summaries, not raw
513
+ runtime state.
514
+
515
+ - `tasks.list` requires `operator.read`.
516
+ - Params: optional `status` (`"queued"`, `"running"`, `"completed"`,
517
+ `"failed"`, `"cancelled"`, or `"timed_out"`) or an array of those statuses,
518
+ optional `agentId`, optional `sessionKey`, optional `limit` from `1` to
519
+ `500`, and optional string `cursor`.
520
+ - Result: `{ "tasks": TaskSummary[], "nextCursor"?: string }`.
521
+ - `tasks.get` requires `operator.read`.
522
+ - Params: `{ "taskId": string }`.
523
+ - Result: `{ "task": TaskSummary }`.
524
+ - Missing task ids return the Gateway not-found error shape.
525
+ - `tasks.cancel` requires `operator.write`.
526
+ - Params: `{ "taskId": string, "reason"?: string }`.
527
+ - Result:
528
+ `{ "found": boolean, "cancelled": boolean, "reason"?: string, "task"?: TaskSummary }`.
529
+ - `found` reports whether the ledger had a matching task. `cancelled`
530
+ reports whether the runtime accepted or recorded cancellation.
531
+
532
+ `TaskSummary` includes `id`, `status`, and optional metadata such as `kind`,
533
+ `runtime`, `title`, `agentId`, `sessionKey`, `childSessionKey`, `ownerKey`,
534
+ `runId`, `taskId`, `flowId`, `parentTaskId`, `sourceId`, timestamps, progress,
535
+ terminal summary, and sanitized error text.
536
+
537
+ ### Operator helper methods
538
+
539
+ - Operators may call `commands.list` (`operator.read`) to fetch the runtime
540
+ command inventory for an agent.
541
+ - `agentId` is optional; omit it to read the default agent workspace.
542
+ - `scope` controls which surface the primary `name` targets:
543
+ - `text` returns the primary text command token without the leading `/`
544
+ - `native` and the default `both` path return provider-aware native names
545
+ when available
546
+ - `textAliases` carries exact slash aliases such as `/model` and `/m`.
547
+ - `nativeName` carries the provider-aware native command name when one exists.
548
+ - `provider` is optional and only affects native naming plus native plugin
549
+ command availability.
550
+ - `includeArgs=false` omits serialized argument metadata from the response.
551
+ - Operators may call `tools.catalog` (`operator.read`) to fetch the runtime tool catalog for an
552
+ agent. The response includes grouped tools and provenance metadata:
553
+ - `source`: `core` or `plugin`
554
+ - `pluginId`: plugin owner when `source="plugin"`
555
+ - `optional`: whether a plugin tool is optional
556
+ - Operators may call `tools.effective` (`operator.read`) to fetch the runtime-effective tool
557
+ inventory for a session.
558
+ - `sessionKey` is required.
559
+ - The gateway derives trusted runtime context from the session server-side instead of accepting
560
+ caller-supplied auth or delivery context.
561
+ - The response is session-scoped and reflects what the active conversation can use right now,
562
+ including core, plugin, and channel tools.
563
+ - Operators may call `tools.invoke` (`operator.write`) to invoke one available tool through the
564
+ same gateway policy path as `/tools/invoke`.
565
+ - `name` is required. `args`, `sessionKey`, `agentId`, `confirm`, and
566
+ `idempotencyKey` are optional.
567
+ - If both `sessionKey` and `agentId` are present, the resolved session agent must match
568
+ `agentId`.
569
+ - The response is an SDK-facing envelope with `ok`, `toolName`, optional `output`, and typed
570
+ `error` fields. Approval or policy refusals return `ok:false` in the payload rather than
571
+ bypassing the gateway tool policy pipeline.
572
+ - Operators may call `skills.status` (`operator.read`) to fetch the visible
573
+ skill inventory for an agent.
574
+ - `agentId` is optional; omit it to read the default agent workspace.
575
+ - The response includes eligibility, missing requirements, config checks, and
576
+ sanitized install options without exposing raw secret values.
577
+ - Operators may call `skills.search` and `skills.detail` (`operator.read`) for
578
+ ClawHub discovery metadata.
579
+ - Operators may call `skills.upload.begin`, `skills.upload.chunk`, and
580
+ `skills.upload.commit` (`operator.admin`) to stage a private skill archive
581
+ before installing it. This is a separate admin upload path for trusted clients,
582
+ not the normal ClawHub skill install flow, and is disabled by default unless
583
+ `skills.install.allowUploadedArchives` is enabled.
584
+ - `skills.upload.begin({ kind: "skill-archive", slug, sizeBytes, sha256?, force?, idempotencyKey? })`
585
+ creates an upload bound to that slug and force value.
586
+ - `skills.upload.chunk({ uploadId, offset, dataBase64 })` appends bytes at
587
+ the exact decoded offset.
588
+ - `skills.upload.commit({ uploadId, sha256? })` verifies the final size and
589
+ SHA-256. Commit only finalizes the upload; it does not install the skill.
590
+ - Uploaded skill archives are zip archives containing a `SKILL.md` root. The
591
+ archive's internal directory name never selects the install target.
592
+ - Operators may call `skills.install` (`operator.admin`) in three modes:
593
+ - ClawHub mode: `{ source: "clawhub", slug, version?, force? }` installs a
594
+ skill folder into the default agent workspace `skills/` directory.
595
+ - Upload mode: `{ source: "upload", uploadId, slug, force?, sha256?, timeoutMs? }`
596
+ installs a committed upload into the default agent workspace `skills/<slug>`
597
+ directory. The slug and force value must match the original
598
+ `skills.upload.begin` request. This mode is rejected unless
599
+ `skills.install.allowUploadedArchives` is enabled. The setting does not
600
+ affect ClawHub installs.
601
+ - Gateway installer mode: `{ name, installId, dangerouslyForceUnsafeInstall?, timeoutMs? }`
602
+ runs a declared `metadata.nodmix.install` action on the gateway host.
603
+ - Operators may call `skills.update` (`operator.admin`) in two modes:
604
+ - ClawHub mode updates one tracked slug or all tracked ClawHub installs in
605
+ the default agent workspace.
606
+ - Config mode patches `skills.entries.<skillKey>` values such as `enabled`,
607
+ `apiKey`, and `env`.
608
+
609
+ ### `models.list` views
610
+
611
+ `models.list` accepts an optional `view` parameter:
612
+
613
+ - Omitted or `"default"`: current runtime behavior. If `agents.defaults.models` is configured, the response is the allowed catalog, including dynamically discovered models for `provider/*` entries. Otherwise the response is the full Gateway catalog.
614
+ - `"configured"`: picker-sized behavior. If `agents.defaults.models` is configured, it still wins, including provider-scoped discovery for `provider/*` entries. Without an allowlist, the response uses explicit `models.providers.*.models` entries, falling back to the full catalog only when no configured model rows exist.
615
+ - `"all"`: full Gateway catalog, bypassing `agents.defaults.models`. Use this for diagnostics and discovery UIs, not normal model pickers.
616
+
617
+ ## Exec approvals
618
+
619
+ - When an exec request needs approval, the gateway broadcasts `exec.approval.requested`.
620
+ - Operator clients resolve by calling `exec.approval.resolve` (requires `operator.approvals` scope).
621
+ - For `host=node`, `exec.approval.request` must include `systemRunPlan` (canonical `argv`/`cwd`/`rawCommand`/session metadata). Requests missing `systemRunPlan` are rejected.
622
+ - After approval, forwarded `node.invoke system.run` calls reuse that canonical
623
+ `systemRunPlan` as the authoritative command/cwd/session context.
624
+ - If a caller mutates `command`, `rawCommand`, `cwd`, `agentId`, or
625
+ `sessionKey` between prepare and the final approved `system.run` forward, the
626
+ gateway rejects the run instead of trusting the mutated payload.
627
+
628
+ ## Agent delivery fallback
629
+
630
+ - `agent` requests can include `deliver=true` to request outbound delivery.
631
+ - `bestEffortDeliver=false` keeps strict behavior: unresolved or internal-only delivery targets return `INVALID_REQUEST`.
632
+ - `bestEffortDeliver=true` allows fallback to session-only execution when no external deliverable route can be resolved (for example internal/webchat sessions or ambiguous multi-channel configs).
633
+ - Final `agent` results may include `result.deliveryStatus` when delivery was
634
+ requested, using the same `sent`, `suppressed`, `partial_failed`, and `failed`
635
+ statuses documented for [`nodmix agent --json --deliver`](/cli/agent#json-delivery-status).
636
+
637
+ ## Versioning
638
+
639
+ - `PROTOCOL_VERSION` lives in `src/gateway/protocol/version.ts`.
640
+ - Clients send `minProtocol` + `maxProtocol`; the server rejects ranges that
641
+ do not include its current protocol. Current clients and servers require
642
+ protocol v4.
643
+ - Schemas + models are generated from TypeBox definitions:
644
+ - `pnpm protocol:gen`
645
+ - `pnpm protocol:gen:swift`
646
+ - `pnpm protocol:check`
647
+
648
+ ### Client constants
649
+
650
+ The reference client in `src/gateway/client.ts` uses these defaults. Values are
651
+ stable across protocol v4 and are the expected baseline for third-party clients.
652
+
653
+ | Constant | Default | Source |
654
+ | ----------------------------------------- | ----------------------------------------------------- | ------------------------------------------------------------------------------------------ |
655
+ | `PROTOCOL_VERSION` | `4` | `src/gateway/protocol/version.ts` |
656
+ | `MIN_CLIENT_PROTOCOL_VERSION` | `4` | `src/gateway/protocol/version.ts` |
657
+ | Request timeout (per RPC) | `30_000` ms | `src/gateway/client.ts` (`requestTimeoutMs`) |
658
+ | Preauth / connect-challenge timeout | `15_000` ms | `src/gateway/handshake-timeouts.ts` (config/env can raise the paired server/client budget) |
659
+ | Initial reconnect backoff | `1_000` ms | `src/gateway/client.ts` (`backoffMs`) |
660
+ | Max reconnect backoff | `30_000` ms | `src/gateway/client.ts` (`scheduleReconnect`) |
661
+ | Fast-retry clamp after device-token close | `250` ms | `src/gateway/client.ts` |
662
+ | Force-stop grace before `terminate()` | `250` ms | `FORCE_STOP_TERMINATE_GRACE_MS` |
663
+ | `stopAndWait()` default timeout | `1_000` ms | `STOP_AND_WAIT_TIMEOUT_MS` |
664
+ | Default tick interval (pre `hello-ok`) | `30_000` ms | `src/gateway/client.ts` |
665
+ | Tick-timeout close | code `4000` when silence exceeds `tickIntervalMs * 2` | `src/gateway/client.ts` |
666
+ | `MAX_PAYLOAD_BYTES` | `25 * 1024 * 1024` (25 MB) | `src/gateway/server-constants.ts` |
667
+
668
+ The server advertises the effective `policy.tickIntervalMs`, `policy.maxPayload`,
669
+ and `policy.maxBufferedBytes` in `hello-ok`; clients should honor those values
670
+ rather than the pre-handshake defaults.
671
+
672
+ ## Auth
673
+
674
+ - Shared-secret gateway auth uses `connect.params.auth.token` or
675
+ `connect.params.auth.password`, depending on the configured auth mode.
676
+ - Identity-bearing modes such as Tailscale Serve
677
+ (`gateway.auth.allowTailscale: true`) or non-loopback
678
+ `gateway.auth.mode: "trusted-proxy"` satisfy the connect auth check from
679
+ request headers instead of `connect.params.auth.*`.
680
+ - Private-ingress `gateway.auth.mode: "none"` skips shared-secret connect auth
681
+ entirely; do not expose that mode on public/untrusted ingress.
682
+ - After pairing, the Gateway issues a **device token** scoped to the connection
683
+ role + scopes. It is returned in `hello-ok.auth.deviceToken` and should be
684
+ persisted by the client for future connects.
685
+ - Clients should persist the primary `hello-ok.auth.deviceToken` after any
686
+ successful connect.
687
+ - Reconnecting with that **stored** device token should also reuse the stored
688
+ approved scope set for that token. This preserves read/probe/status access
689
+ that was already granted and avoids silently collapsing reconnects to a
690
+ narrower implicit admin-only scope.
691
+ - Client-side connect auth assembly (`selectConnectAuth` in
692
+ `src/gateway/client.ts`):
693
+ - `auth.password` is orthogonal and is always forwarded when set.
694
+ - `auth.token` is populated in priority order: explicit shared token first,
695
+ then an explicit `deviceToken`, then a stored per-device token (keyed by
696
+ `deviceId` + `role`).
697
+ - `auth.bootstrapToken` is sent only when none of the above resolved an
698
+ `auth.token`. A shared token or any resolved device token suppresses it.
699
+ - Auto-promotion of a stored device token on the one-shot
700
+ `AUTH_TOKEN_MISMATCH` retry is gated to **trusted endpoints only** —
701
+ loopback, or `wss://` with a pinned `tlsFingerprint`. Public `wss://`
702
+ without pinning does not qualify.
703
+ - Built-in setup-code bootstrap returns the primary node
704
+ `hello-ok.auth.deviceToken` plus a bounded operator token in
705
+ `hello-ok.auth.deviceTokens` for trusted mobile handoff. The operator token
706
+ excludes `operator.admin`, `operator.pairing`, and `operator.talk.secrets`.
707
+ - While a non-baseline setup-code bootstrap is waiting for approval, `PAIRING_REQUIRED`
708
+ details include `recommendedNextStep: "wait_then_retry"`, `retryable: true`,
709
+ and `pauseReconnect: false`. Clients should keep reconnecting with the same
710
+ bootstrap token until the request is approved or the token becomes invalid.
711
+ - Persist `hello-ok.auth.deviceTokens` only when the connect used bootstrap auth
712
+ on a trusted transport such as `wss://` or loopback/local pairing.
713
+ - If a client supplies an **explicit** `deviceToken` or explicit `scopes`, that
714
+ caller-requested scope set remains authoritative; cached scopes are only
715
+ reused when the client is reusing the stored per-device token.
716
+ - Device tokens can be rotated/revoked via `device.token.rotate` and
717
+ `device.token.revoke` (requires `operator.pairing` scope).
718
+ - `device.token.rotate` returns rotation metadata. It echoes the replacement
719
+ bearer token only for same-device calls that are already authenticated with
720
+ that device token, so token-only clients can persist their replacement before
721
+ reconnecting. Shared/admin rotations do not echo the bearer token.
722
+ - Token issuance, rotation, and revocation stay bounded to the approved role set
723
+ recorded in that device's pairing entry; token mutation cannot expand or
724
+ target a device role that pairing approval never granted.
725
+ - For paired-device token sessions, device management is self-scoped unless the
726
+ caller also has `operator.admin`: non-admin callers can remove/revoke/rotate
727
+ only their **own** device entry.
728
+ - `device.token.rotate` and `device.token.revoke` also check the target operator
729
+ token scope set against the caller's current session scopes. Non-admin callers
730
+ cannot rotate or revoke a broader operator token than they already hold.
731
+ - Auth failures include `error.details.code` plus recovery hints:
732
+ - `error.details.canRetryWithDeviceToken` (boolean)
733
+ - `error.details.recommendedNextStep` (`retry_with_device_token`, `update_auth_configuration`, `update_auth_credentials`, `wait_then_retry`, `review_auth_configuration`)
734
+ - Client behavior for `AUTH_TOKEN_MISMATCH`:
735
+ - Trusted clients may attempt one bounded retry with a cached per-device token.
736
+ - If that retry fails, clients should stop automatic reconnect loops and surface operator action guidance.
737
+ - `AUTH_SCOPE_MISMATCH` means the device token was recognized but does not cover
738
+ the requested role/scopes. Clients should not present this as a bad token;
739
+ prompt the operator to re-pair or approve the narrower/broader scope contract.
740
+
741
+ ## Device identity + pairing
742
+
743
+ - Nodes should include a stable device identity (`device.id`) derived from a
744
+ keypair fingerprint.
745
+ - Gateways issue tokens per device + role.
746
+ - Pairing approvals are required for new device IDs unless local auto-approval
747
+ is enabled.
748
+ - Pairing auto-approval is centered on direct local loopback connects.
749
+ - Nodmix also has a narrow backend/container-local self-connect path for
750
+ trusted shared-secret helper flows.
751
+ - Same-host tailnet or LAN connects are still treated as remote for pairing and
752
+ require approval.
753
+ - WS clients normally include `device` identity during `connect` (operator +
754
+ node). The only device-less operator exceptions are explicit trust paths:
755
+ - `gateway.controlUi.allowInsecureAuth=true` for localhost-only insecure HTTP compatibility.
756
+ - successful `gateway.auth.mode: "trusted-proxy"` operator Control UI auth.
757
+ - `gateway.controlUi.dangerouslyDisableDeviceAuth=true` (break-glass, severe security downgrade).
758
+ - direct-loopback `gateway-client` backend RPCs authenticated with the shared
759
+ gateway token/password.
760
+ - All connections must sign the server-provided `connect.challenge` nonce.
761
+
762
+ ### Device auth migration diagnostics
763
+
764
+ For legacy clients that still use pre-challenge signing behavior, `connect` now returns
765
+ `DEVICE_AUTH_*` detail codes under `error.details.code` with a stable `error.details.reason`.
766
+
767
+ Common migration failures:
768
+
769
+ | Message | details.code | details.reason | Meaning |
770
+ | --------------------------- | -------------------------------- | ------------------------ | -------------------------------------------------- |
771
+ | `device nonce required` | `DEVICE_AUTH_NONCE_REQUIRED` | `device-nonce-missing` | Client omitted `device.nonce` (or sent blank). |
772
+ | `device nonce mismatch` | `DEVICE_AUTH_NONCE_MISMATCH` | `device-nonce-mismatch` | Client signed with a stale/wrong nonce. |
773
+ | `device signature invalid` | `DEVICE_AUTH_SIGNATURE_INVALID` | `device-signature` | Signature payload does not match v2 payload. |
774
+ | `device signature expired` | `DEVICE_AUTH_SIGNATURE_EXPIRED` | `device-signature-stale` | Signed timestamp is outside allowed skew. |
775
+ | `device identity mismatch` | `DEVICE_AUTH_DEVICE_ID_MISMATCH` | `device-id-mismatch` | `device.id` does not match public key fingerprint. |
776
+ | `device public key invalid` | `DEVICE_AUTH_PUBLIC_KEY_INVALID` | `device-public-key` | Public key format/canonicalization failed. |
777
+
778
+ Migration target:
779
+
780
+ - Always wait for `connect.challenge`.
781
+ - Sign the v2 payload that includes the server nonce.
782
+ - Send the same nonce in `connect.params.device.nonce`.
783
+ - Preferred signature payload is `v3`, which binds `platform` and `deviceFamily`
784
+ in addition to device/client/role/scopes/token/nonce fields.
785
+ - Legacy `v2` signatures remain accepted for compatibility, but paired-device
786
+ metadata pinning still controls command policy on reconnect.
787
+
788
+ ## TLS + pinning
789
+
790
+ - TLS is supported for WS connections.
791
+ - Clients may optionally pin the gateway cert fingerprint (see `gateway.tls`
792
+ config plus `gateway.remote.tlsFingerprint` or CLI `--tls-fingerprint`).
793
+
794
+ ## Scope
795
+
796
+ This protocol exposes the **full gateway API** (status, channels, models, chat,
797
+ agent, sessions, nodes, approvals, etc.). The exact surface is defined by the
798
+ TypeBox schemas in `src/gateway/protocol/schema.ts`.
799
+
800
+ ## Related
801
+
802
+ - [Bridge protocol](/gateway/bridge-protocol)
803
+ - [Gateway runbook](/gateway)