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,580 @@
1
+ ---
2
+ summary: "Live (network-touching) tests: model matrix, CLI backends, ACP, media providers, credentials"
3
+ read_when:
4
+ - Running live model matrix / CLI backend / ACP / media-provider smokes
5
+ - Debugging live-test credential resolution
6
+ - Adding a new provider-specific live test
7
+ title: "Testing: live suites"
8
+ sidebarTitle: "Live tests"
9
+ ---
10
+
11
+ For quick start, QA runners, unit/integration suites, and Docker flows, see
12
+ [Testing](/help/testing). This page covers the **live** (network-touching) test
13
+ suites: model matrix, CLI backends, ACP, and media-provider live tests, plus
14
+ credential handling.
15
+
16
+ ## Live: local smoke commands
17
+
18
+ Export the needed provider key in the process environment before ad hoc live
19
+ checks.
20
+
21
+ Safe media smoke:
22
+
23
+ ```bash
24
+ pnpm nodmix infer tts convert --local --json \
25
+ --text "Nodmix live smoke." \
26
+ --output /tmp/nodmix-live-smoke.mp3
27
+ ```
28
+
29
+ Safe voice-call readiness smoke:
30
+
31
+ ```bash
32
+ pnpm nodmix voicecall setup --json
33
+ pnpm nodmix voicecall smoke --to "+15555550123"
34
+ ```
35
+
36
+ `voicecall smoke` is a dry run unless `--yes` is also present. Use `--yes` only
37
+ when you intentionally want to place a real notify call. For Twilio, Telnyx, and
38
+ Plivo, a successful readiness check requires a public webhook URL; local-only
39
+ loopback/private fallbacks are rejected by design.
40
+
41
+ ## Live: Android node capability sweep
42
+
43
+ - Test: `src/gateway/android-node.capabilities.live.test.ts`
44
+ - Script: `pnpm android:test:integration`
45
+ - Goal: invoke **every command currently advertised** by a connected Android node and assert command contract behavior.
46
+ - Scope:
47
+ - Preconditioned/manual setup (the suite does not install/run/pair the app).
48
+ - Command-by-command gateway `node.invoke` validation for the selected Android node.
49
+ - Required pre-setup:
50
+ - Android app already connected + paired to the gateway.
51
+ - App kept in foreground.
52
+ - Permissions/capture consent granted for capabilities you expect to pass.
53
+ - Optional target overrides:
54
+ - `NODMIX_ANDROID_NODE_ID` or `NODMIX_ANDROID_NODE_NAME`.
55
+ - `NODMIX_ANDROID_GATEWAY_URL` / `NODMIX_ANDROID_GATEWAY_TOKEN` / `NODMIX_ANDROID_GATEWAY_PASSWORD`.
56
+ - Full Android setup details: [Android App](/platforms/android)
57
+
58
+ ## Live: model smoke (profile keys)
59
+
60
+ Live tests are split into two layers so we can isolate failures:
61
+
62
+ - "Direct model" tells us the provider/model can answer at all with the given key.
63
+ - "Gateway smoke" tells us the full gateway+agent pipeline works for that model (sessions, history, tools, sandbox policy, etc.).
64
+
65
+ ### Layer 1: Direct model completion (no gateway)
66
+
67
+ - Test: `src/agents/models.profiles.live.test.ts`
68
+ - Goal:
69
+ - Enumerate discovered models
70
+ - Use `getApiKeyForModel` to select models you have creds for
71
+ - Run a small completion per model (and targeted regressions where needed)
72
+ - How to enable:
73
+ - `pnpm test:live` (or `NODMIX_LIVE_TEST=1` if invoking Vitest directly)
74
+ - Set `NODMIX_LIVE_MODELS=modern` (or `all`, alias for modern) to actually run this suite; otherwise it skips to keep `pnpm test:live` focused on gateway smoke
75
+ - How to select models:
76
+ - `NODMIX_LIVE_MODELS=modern` to run the modern allowlist (Opus/Sonnet 4.6+, GPT-5.2 + Codex, Gemini 3, DeepSeek V4, GLM 4.7, MiniMax M2.7, Grok 4.3)
77
+ - `NODMIX_LIVE_MODELS=all` is an alias for the modern allowlist
78
+ - or `NODMIX_LIVE_MODELS="openai/gpt-5.5,openai-codex/gpt-5.5,anthropic/claude-opus-4-6,..."` (comma allowlist)
79
+ - Modern/all sweeps default to a curated high-signal cap; set `NODMIX_LIVE_MAX_MODELS=0` for an exhaustive modern sweep or a positive number for a smaller cap.
80
+ - Exhaustive sweeps use `NODMIX_LIVE_TEST_TIMEOUT_MS` for the whole direct-model test timeout. Default: 60 minutes.
81
+ - Direct-model probes run with 20-way parallelism by default; set `NODMIX_LIVE_MODEL_CONCURRENCY` to override.
82
+ - How to select providers:
83
+ - `NODMIX_LIVE_PROVIDERS="google,google-antigravity,google-gemini-cli"` (comma allowlist)
84
+ - Where keys come from:
85
+ - By default: profile store and env fallbacks
86
+ - Set `NODMIX_LIVE_REQUIRE_PROFILE_KEYS=1` to enforce **profile store** only
87
+ - Why this exists:
88
+ - Separates "provider API is broken / key is invalid" from "gateway agent pipeline is broken"
89
+ - Contains small, isolated regressions (example: OpenAI Responses/Codex Responses reasoning replay + tool-call flows)
90
+
91
+ ### Layer 2: Gateway + dev agent smoke (what "@nodmix" actually does)
92
+
93
+ - Test: `src/gateway/gateway-models.profiles.live.test.ts`
94
+ - Goal:
95
+ - Spin up an in-process gateway
96
+ - Create/patch a `agent:dev:*` session (model override per run)
97
+ - Iterate models-with-keys and assert:
98
+ - "meaningful" response (no tools)
99
+ - a real tool invocation works (read probe)
100
+ - optional extra tool probes (exec+read probe)
101
+ - OpenAI regression paths (tool-call-only → follow-up) keep working
102
+ - Probe details (so you can explain failures quickly):
103
+ - `read` probe: the test writes a nonce file in the workspace and asks the agent to `read` it and echo the nonce back.
104
+ - `exec+read` probe: the test asks the agent to `exec`-write a nonce into a temp file, then `read` it back.
105
+ - image probe: the test attaches a generated PNG (cat + randomized code) and expects the model to return `cat <CODE>`.
106
+ - Implementation reference: `src/gateway/gateway-models.profiles.live.test.ts` and `test/helpers/live-image-probe.ts`.
107
+ - How to enable:
108
+ - `pnpm test:live` (or `NODMIX_LIVE_TEST=1` if invoking Vitest directly)
109
+ - How to select models:
110
+ - Default: modern allowlist (Opus/Sonnet 4.6+, GPT-5.2 + Codex, Gemini 3, DeepSeek V4, GLM 4.7, MiniMax M2.7, Grok 4.3)
111
+ - `NODMIX_LIVE_GATEWAY_MODELS=all` is an alias for the modern allowlist
112
+ - Or set `NODMIX_LIVE_GATEWAY_MODELS="provider/model"` (or comma list) to narrow
113
+ - Modern/all gateway sweeps default to a curated high-signal cap; set `NODMIX_LIVE_GATEWAY_MAX_MODELS=0` for an exhaustive modern sweep or a positive number for a smaller cap.
114
+ - How to select providers (avoid "OpenRouter everything"):
115
+ - `NODMIX_LIVE_GATEWAY_PROVIDERS="google,google-antigravity,google-gemini-cli,openai,anthropic,zai,minimax"` (comma allowlist)
116
+ - Tool + image probes are always on in this live test:
117
+ - `read` probe + `exec+read` probe (tool stress)
118
+ - image probe runs when the model advertises image input support
119
+ - Flow (high level):
120
+ - Test generates a tiny PNG with "CAT" + random code (`test/helpers/live-image-probe.ts`)
121
+ - Sends it via `agent` `attachments: [{ mimeType: "image/png", content: "<base64>" }]`
122
+ - Gateway parses attachments into `images[]` (`src/gateway/server-methods/agent.ts` + `src/gateway/chat-attachments.ts`)
123
+ - Embedded agent forwards a multimodal user message to the model
124
+ - Assertion: reply contains `cat` + the code (OCR tolerance: minor mistakes allowed)
125
+
126
+ <Tip>
127
+ To see what you can test on your machine (and the exact `provider/model` ids), run:
128
+
129
+ ```bash
130
+ nodmix models list
131
+ nodmix models list --json
132
+ ```
133
+
134
+ </Tip>
135
+
136
+ ## Live: CLI backend smoke (Claude, Gemini, or other local CLIs)
137
+
138
+ - Test: `src/gateway/gateway-cli-backend.live.test.ts`
139
+ - Goal: validate the Gateway + agent pipeline using a local CLI backend, without touching your default config.
140
+ - Backend-specific smoke defaults live with the owning extension's `cli-backend.ts` definition.
141
+ - Enable:
142
+ - `pnpm test:live` (or `NODMIX_LIVE_TEST=1` if invoking Vitest directly)
143
+ - `NODMIX_LIVE_CLI_BACKEND=1`
144
+ - Defaults:
145
+ - Default provider/model: `claude-cli/claude-sonnet-4-6`
146
+ - Command/args/image behavior come from the owning CLI backend plugin metadata.
147
+ - Overrides (optional):
148
+ - `NODMIX_LIVE_CLI_BACKEND_MODEL="claude-cli/claude-sonnet-4-6"`
149
+ - `NODMIX_LIVE_CLI_BACKEND_COMMAND="/full/path/to/claude"`
150
+ - `NODMIX_LIVE_CLI_BACKEND_ARGS='["-p","--output-format","json"]'`
151
+ - `NODMIX_LIVE_CLI_BACKEND_IMAGE_PROBE=1` to send a real image attachment (paths are injected into the prompt). Docker recipes default this off unless explicitly requested.
152
+ - `NODMIX_LIVE_CLI_BACKEND_IMAGE_ARG="--image"` to pass image file paths as CLI args instead of prompt injection.
153
+ - `NODMIX_LIVE_CLI_BACKEND_IMAGE_MODE="repeat"` (or `"list"`) to control how image args are passed when `IMAGE_ARG` is set.
154
+ - `NODMIX_LIVE_CLI_BACKEND_RESUME_PROBE=1` to send a second turn and validate resume flow.
155
+ - `NODMIX_LIVE_CLI_BACKEND_MODEL_SWITCH_PROBE=1` to opt into the Claude Sonnet -> Opus same-session continuity probe when the selected model supports a switch target. Docker recipes default this off for aggregate reliability.
156
+ - `NODMIX_LIVE_CLI_BACKEND_MCP_PROBE=1` to opt into the MCP/tool loopback probe. Docker recipes default this off unless explicitly requested.
157
+
158
+ Example:
159
+
160
+ ```bash
161
+ NODMIX_LIVE_CLI_BACKEND=1 \
162
+ NODMIX_LIVE_CLI_BACKEND_MODEL="claude-cli/claude-sonnet-4-6" \
163
+ pnpm test:live src/gateway/gateway-cli-backend.live.test.ts
164
+ ```
165
+
166
+ Cheap Gemini MCP config smoke:
167
+
168
+ ```bash
169
+ NODMIX_LIVE_TEST=1 \
170
+ pnpm test:live src/agents/cli-runner/bundle-mcp.gemini.live.test.ts
171
+ ```
172
+
173
+ This does not ask Gemini to generate a response. It writes the same system
174
+ settings Nodmix gives Gemini, then runs `gemini --debug mcp list` to prove a
175
+ saved `transport: "streamable-http"` server is normalized to Gemini's HTTP MCP
176
+ shape and can connect to a local streamable-HTTP MCP server.
177
+
178
+ Docker recipe:
179
+
180
+ ```bash
181
+ pnpm test:docker:live-cli-backend
182
+ ```
183
+
184
+ Single-provider Docker recipes:
185
+
186
+ ```bash
187
+ pnpm test:docker:live-cli-backend:claude
188
+ pnpm test:docker:live-cli-backend:claude-subscription
189
+ pnpm test:docker:live-cli-backend:gemini
190
+ ```
191
+
192
+ Notes:
193
+
194
+ - The Docker runner lives at `scripts/test-live-cli-backend-docker.sh`.
195
+ - It runs the live CLI-backend smoke inside the repo Docker image as the non-root `node` user.
196
+ - It resolves CLI smoke metadata from the owning extension, then installs the matching Linux CLI package (`@anthropic-ai/claude-code` or `@google/gemini-cli`) into a cached writable prefix at `NODMIX_DOCKER_CLI_TOOLS_DIR` (default: `~/.cache/nodmix/docker-cli-tools`).
197
+ - `pnpm test:docker:live-cli-backend:claude-subscription` requires portable Claude Code subscription OAuth through either `~/.claude/.credentials.json` with `claudeAiOauth.subscriptionType` or `CLAUDE_CODE_OAUTH_TOKEN` from `claude setup-token`. It first proves direct `claude -p` in Docker, then runs two Gateway CLI-backend turns without preserving Anthropic API-key env vars. This subscription lane disables the Claude MCP/tool and image probes by default because Claude currently routes third-party app usage through extra-usage billing instead of normal subscription plan limits.
198
+ - The live CLI-backend smoke now exercises the same end-to-end flow for Claude and Gemini: text turn, image classification turn, then MCP `cron` tool call verified through the gateway CLI.
199
+ - Claude's default smoke also patches the session from Sonnet to Opus and verifies the resumed session still remembers an earlier note.
200
+
201
+ ## Live: APNs HTTP/2 proxy reachability
202
+
203
+ - Test: `src/infra/push-apns-http2.live.test.ts`
204
+ - Goal: tunnel through a local HTTP CONNECT proxy to Apple's sandbox APNs endpoint, send the APNs HTTP/2 validation request, and assert Apple's real `403 InvalidProviderToken` response comes back through the proxy path.
205
+ - Enable:
206
+ - `NODMIX_LIVE_TEST=1 NODMIX_LIVE_APNS_REACHABILITY=1 pnpm test:live src/infra/push-apns-http2.live.test.ts`
207
+ - Optional timeout:
208
+ - `NODMIX_LIVE_APNS_TIMEOUT_MS=30000`
209
+
210
+ ## Live: ACP bind smoke (`/acp spawn ... --bind here`)
211
+
212
+ - Test: `src/gateway/gateway-acp-bind.live.test.ts`
213
+ - Goal: validate the real ACP conversation-bind flow with a live ACP agent:
214
+ - send `/acp spawn <agent> --bind here`
215
+ - bind a synthetic message-channel conversation in place
216
+ - send a normal follow-up on that same conversation
217
+ - verify the follow-up lands in the bound ACP session transcript
218
+ - Enable:
219
+ - `pnpm test:live src/gateway/gateway-acp-bind.live.test.ts`
220
+ - `NODMIX_LIVE_ACP_BIND=1`
221
+ - Defaults:
222
+ - ACP agents in Docker: `claude,codex,gemini`
223
+ - ACP agent for direct `pnpm test:live ...`: `claude`
224
+ - Synthetic channel: Slack DM-style conversation context
225
+ - ACP backend: `acpx`
226
+ - Overrides:
227
+ - `NODMIX_LIVE_ACP_BIND_AGENT=claude`
228
+ - `NODMIX_LIVE_ACP_BIND_AGENT=codex`
229
+ - `NODMIX_LIVE_ACP_BIND_AGENT=droid`
230
+ - `NODMIX_LIVE_ACP_BIND_AGENT=gemini`
231
+ - `NODMIX_LIVE_ACP_BIND_AGENT=opencode`
232
+ - `NODMIX_LIVE_ACP_BIND_AGENTS=claude,codex,gemini`
233
+ - `NODMIX_LIVE_ACP_BIND_AGENT_COMMAND='npx -y @agentclientprotocol/claude-agent-acp@<version>'`
234
+ - `NODMIX_LIVE_ACP_BIND_CODEX_MODEL=gpt-5.5`
235
+ - `NODMIX_LIVE_ACP_BIND_OPENCODE_MODEL=opencode/kimi-k2.6`
236
+ - `NODMIX_LIVE_ACP_BIND_REQUIRE_TRANSCRIPT=1`
237
+ - `NODMIX_LIVE_ACP_BIND_REQUIRE_CRON=1`
238
+ - `NODMIX_LIVE_ACP_BIND_PARENT_MODEL=openai/gpt-5.5`
239
+ - Notes:
240
+ - This lane uses the gateway `chat.send` surface with admin-only synthetic originating-route fields so tests can attach message-channel context without pretending to deliver externally.
241
+ - When `NODMIX_LIVE_ACP_BIND_AGENT_COMMAND` is unset, the test uses the embedded `acpx` plugin's built-in agent registry for the selected ACP harness agent.
242
+ - Bound-session cron MCP creation is best-effort by default because external ACP harnesses can cancel MCP calls after the bind/image proof has passed; set `NODMIX_LIVE_ACP_BIND_REQUIRE_CRON=1` to make that post-bind cron probe strict.
243
+
244
+ Example:
245
+
246
+ ```bash
247
+ NODMIX_LIVE_ACP_BIND=1 \
248
+ NODMIX_LIVE_ACP_BIND_AGENT=claude \
249
+ pnpm test:live src/gateway/gateway-acp-bind.live.test.ts
250
+ ```
251
+
252
+ Docker recipe:
253
+
254
+ ```bash
255
+ pnpm test:docker:live-acp-bind
256
+ ```
257
+
258
+ Single-agent Docker recipes:
259
+
260
+ ```bash
261
+ pnpm test:docker:live-acp-bind:claude
262
+ pnpm test:docker:live-acp-bind:codex
263
+ pnpm test:docker:live-acp-bind:droid
264
+ pnpm test:docker:live-acp-bind:gemini
265
+ pnpm test:docker:live-acp-bind:opencode
266
+ ```
267
+
268
+ Docker notes:
269
+
270
+ - The Docker runner lives at `scripts/test-live-acp-bind-docker.sh`.
271
+ - By default, it runs the ACP bind smoke against the aggregate live CLI agents in sequence: `claude`, `codex`, then `gemini`.
272
+ - Use `NODMIX_LIVE_ACP_BIND_AGENTS=claude`, `NODMIX_LIVE_ACP_BIND_AGENTS=codex`, `NODMIX_LIVE_ACP_BIND_AGENTS=droid`, `NODMIX_LIVE_ACP_BIND_AGENTS=gemini`, or `NODMIX_LIVE_ACP_BIND_AGENTS=opencode` to narrow the matrix.
273
+ - It stages the matching CLI auth material into the container, then installs the requested live CLI (`@anthropic-ai/claude-code`, `@openai/codex`, Factory Droid via `https://app.factory.ai/cli`, `@google/gemini-cli`, or `opencode-ai`) if missing. The ACP backend itself is the embedded `acpx/runtime` package from the official `acpx` plugin.
274
+ - The Droid Docker variant stages `~/.factory` for settings, forwards `FACTORY_API_KEY`, and requires that API key because local Factory OAuth/keyring auth is not portable into the container. It uses ACPX's built-in `droid exec --output-format acp` registry entry.
275
+ - The OpenCode Docker variant is a strict single-agent regression lane. It writes a temporary `OPENCODE_CONFIG_CONTENT` default model from `NODMIX_LIVE_ACP_BIND_OPENCODE_MODEL` (default `opencode/kimi-k2.6`), and `pnpm test:docker:live-acp-bind:opencode` requires a bound assistant transcript instead of accepting the generic post-bind skip.
276
+ - Direct `acpx` CLI calls are only a manual/workaround path for comparing behavior outside the Gateway. The Docker ACP bind smoke exercises Nodmix's embedded `acpx` runtime backend.
277
+
278
+ ## Live: Codex app-server harness smoke
279
+
280
+ - Goal: validate the plugin-owned Codex harness through the normal gateway
281
+ `agent` method:
282
+ - load the bundled `codex` plugin
283
+ - select `openai/gpt-5.5`, which routes OpenAI agent turns through Codex by default
284
+ - send a first gateway agent turn to `openai/gpt-5.5` with the Codex harness selected
285
+ - send a second turn to the same Nodmix session and verify the app-server
286
+ thread can resume
287
+ - run `/codex status` and `/codex models` through the same gateway command
288
+ path
289
+ - optionally run two Guardian-reviewed escalated shell probes: one benign
290
+ command that should be approved and one fake-secret upload that should be
291
+ denied so the agent asks back
292
+ - Test: `src/gateway/gateway-codex-harness.live.test.ts`
293
+ - Enable: `NODMIX_LIVE_CODEX_HARNESS=1`
294
+ - Default model: `openai/gpt-5.5`
295
+ - Optional image probe: `NODMIX_LIVE_CODEX_HARNESS_IMAGE_PROBE=1`
296
+ - Optional MCP/tool probe: `NODMIX_LIVE_CODEX_HARNESS_MCP_PROBE=1`
297
+ - Optional Guardian probe: `NODMIX_LIVE_CODEX_HARNESS_GUARDIAN_PROBE=1`
298
+ - The smoke forces provider/model `agentRuntime.id: "codex"` so a broken Codex
299
+ harness cannot pass by silently falling back to PI.
300
+ - Auth: Codex app-server auth from the local Codex subscription login. Docker
301
+ smokes can also provide `OPENAI_API_KEY` for non-Codex probes when applicable,
302
+ plus optional copied `~/.codex/auth.json` and `~/.codex/config.toml`.
303
+
304
+ Local recipe:
305
+
306
+ ```bash
307
+ NODMIX_LIVE_CODEX_HARNESS=1 \
308
+ NODMIX_LIVE_CODEX_HARNESS_IMAGE_PROBE=1 \
309
+ NODMIX_LIVE_CODEX_HARNESS_MCP_PROBE=1 \
310
+ NODMIX_LIVE_CODEX_HARNESS_GUARDIAN_PROBE=1 \
311
+ NODMIX_LIVE_CODEX_HARNESS_MODEL=openai/gpt-5.5 \
312
+ pnpm test:live -- src/gateway/gateway-codex-harness.live.test.ts
313
+ ```
314
+
315
+ Docker recipe:
316
+
317
+ ```bash
318
+ pnpm test:docker:live-codex-harness
319
+ ```
320
+
321
+ Docker notes:
322
+
323
+ - The Docker runner lives at `scripts/test-live-codex-harness-docker.sh`.
324
+ - It passes `OPENAI_API_KEY`, copies Codex CLI auth files when present, installs
325
+ `@openai/codex` into a writable mounted npm
326
+ prefix, stages the source tree, then runs only the Codex-harness live test.
327
+ - Docker enables the image, MCP/tool, and Guardian probes by default. Set
328
+ `NODMIX_LIVE_CODEX_HARNESS_IMAGE_PROBE=0` or
329
+ `NODMIX_LIVE_CODEX_HARNESS_MCP_PROBE=0` or
330
+ `NODMIX_LIVE_CODEX_HARNESS_GUARDIAN_PROBE=0` when you need a narrower debug
331
+ run.
332
+ - Docker uses the same explicit Codex runtime config, so legacy aliases or PI
333
+ fallback cannot hide a Codex harness regression.
334
+
335
+ ### Recommended live recipes
336
+
337
+ Narrow, explicit allowlists are fastest and least flaky:
338
+
339
+ - Single model, direct (no gateway):
340
+ - `NODMIX_LIVE_MODELS="openai/gpt-5.5" pnpm test:live src/agents/models.profiles.live.test.ts`
341
+
342
+ - Single model, gateway smoke:
343
+ - `NODMIX_LIVE_GATEWAY_MODELS="openai/gpt-5.5" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts`
344
+
345
+ - Tool calling across several providers:
346
+ - `NODMIX_LIVE_GATEWAY_MODELS="openai/gpt-5.5,openai-codex/gpt-5.5,anthropic/claude-opus-4-6,google/gemini-3-flash-preview,deepseek/deepseek-v4-flash,zai/glm-5.1,minimax/MiniMax-M2.7" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts`
347
+
348
+ - Google focus (Gemini API key + Antigravity):
349
+ - Gemini (API key): `NODMIX_LIVE_GATEWAY_MODELS="google/gemini-3-flash-preview" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts`
350
+ - Antigravity (OAuth): `NODMIX_LIVE_GATEWAY_MODELS="google-antigravity/claude-opus-4-6-thinking,google-antigravity/gemini-3-pro-high" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts`
351
+
352
+ - Google adaptive thinking smoke:
353
+ - Gemini 3 dynamic default: `pnpm nodmix qa manual --provider-mode live-frontier --model google/gemini-3.1-pro-preview --alt-model google/gemini-3.1-pro-preview --message '/think adaptive Reply exactly: GEMINI_ADAPTIVE_OK' --timeout-ms 180000`
354
+ - Gemini 2.5 dynamic budget: `pnpm nodmix qa manual --provider-mode live-frontier --model google/gemini-2.5-flash --alt-model google/gemini-2.5-flash --message '/think adaptive Reply exactly: GEMINI25_ADAPTIVE_OK' --timeout-ms 180000`
355
+
356
+ Notes:
357
+
358
+ - `google/...` uses the Gemini API (API key).
359
+ - `google-antigravity/...` uses the Antigravity OAuth bridge (Cloud Code Assist-style agent endpoint).
360
+ - `google-gemini-cli/...` uses the local Gemini CLI on your machine (separate auth + tooling quirks).
361
+ - Gemini API vs Gemini CLI:
362
+ - API: Nodmix calls Google's hosted Gemini API over HTTP (API key / profile auth); this is what most users mean by "Gemini".
363
+ - CLI: Nodmix shells out to a local `gemini` binary; it has its own auth and can behave differently (streaming/tool support/version skew).
364
+
365
+ ## Live: model matrix (what we cover)
366
+
367
+ There is no fixed "CI model list" (live is opt-in), but these are the **recommended** models to cover regularly on a dev machine with keys.
368
+
369
+ ### Modern smoke set (tool calling + image)
370
+
371
+ This is the "common models" run we expect to keep working:
372
+
373
+ - OpenAI (non-Codex): `openai/gpt-5.5`
374
+ - OpenAI Codex OAuth: `openai-codex/gpt-5.5`
375
+ - Anthropic: `anthropic/claude-opus-4-6` (or `anthropic/claude-sonnet-4-6`)
376
+ - Google (Gemini API): `google/gemini-3.1-pro-preview` and `google/gemini-3-flash-preview` (avoid older Gemini 2.x models)
377
+ - Google (Antigravity): `google-antigravity/claude-opus-4-6-thinking` and `google-antigravity/gemini-3-flash`
378
+ - DeepSeek: `deepseek/deepseek-v4-flash` and `deepseek/deepseek-v4-pro`
379
+ - Z.AI (GLM): `zai/glm-5.1`
380
+ - MiniMax: `minimax/MiniMax-M2.7`
381
+
382
+ Run gateway smoke with tools + image:
383
+ `NODMIX_LIVE_GATEWAY_MODELS="openai/gpt-5.5,openai-codex/gpt-5.5,anthropic/claude-opus-4-6,google/gemini-3.1-pro-preview,google/gemini-3-flash-preview,google-antigravity/claude-opus-4-6-thinking,google-antigravity/gemini-3-flash,deepseek/deepseek-v4-flash,zai/glm-5.1,minimax/MiniMax-M2.7" pnpm test:live src/gateway/gateway-models.profiles.live.test.ts`
384
+
385
+ ### Baseline: tool calling (Read + optional Exec)
386
+
387
+ Pick at least one per provider family:
388
+
389
+ - OpenAI: `openai/gpt-5.5`
390
+ - Anthropic: `anthropic/claude-opus-4-6` (or `anthropic/claude-sonnet-4-6`)
391
+ - Google: `google/gemini-3-flash-preview` (or `google/gemini-3.1-pro-preview`)
392
+ - DeepSeek: `deepseek/deepseek-v4-flash`
393
+ - Z.AI (GLM): `zai/glm-5.1`
394
+ - MiniMax: `minimax/MiniMax-M2.7`
395
+
396
+ Optional additional coverage (nice to have):
397
+
398
+ - xAI: `xai/grok-4.3` (or latest available)
399
+ - Mistral: `mistral/`… (pick one "tools" capable model you have enabled)
400
+ - Cerebras: `cerebras/`… (if you have access)
401
+ - LM Studio: `lmstudio/`… (local; tool calling depends on API mode)
402
+
403
+ ### Vision: image send (attachment → multimodal message)
404
+
405
+ Include at least one image-capable model in `NODMIX_LIVE_GATEWAY_MODELS` (Claude/Gemini/OpenAI vision-capable variants, etc.) to exercise the image probe.
406
+
407
+ ### Aggregators / alternate gateways
408
+
409
+ If you have keys enabled, we also support testing via:
410
+
411
+ - OpenRouter: `openrouter/...` (hundreds of models; use `nodmix models scan` to find tool+image capable candidates)
412
+ - OpenCode: `opencode/...` for Zen and `opencode-go/...` for Go (auth via `OPENCODE_API_KEY` / `OPENCODE_ZEN_API_KEY`)
413
+
414
+ More providers you can include in the live matrix (if you have creds/config):
415
+
416
+ - Built-in: `openai`, `openai-codex`, `anthropic`, `google`, `google-vertex`, `google-antigravity`, `google-gemini-cli`, `zai`, `openrouter`, `opencode`, `opencode-go`, `xai`, `groq`, `cerebras`, `mistral`, `github-copilot`
417
+ - Via `models.providers` (custom endpoints): `minimax` (cloud/API), plus any OpenAI/Anthropic-compatible proxy (LM Studio, vLLM, LiteLLM, etc.)
418
+
419
+ <Tip>
420
+ Do not hardcode "all models" in docs. The authoritative list is whatever `discoverModels(...)` returns on your machine plus whatever keys are available.
421
+ </Tip>
422
+
423
+ ## Credentials (never commit)
424
+
425
+ Live tests discover credentials the same way the CLI does. Practical implications:
426
+
427
+ - If the CLI works, live tests should find the same keys.
428
+ - If a live test says "no creds", debug the same way you'd debug `nodmix models list` / model selection.
429
+
430
+ - Per-agent auth profiles: `~/.nodmix/agents/<agentId>/agent/auth-profiles.json` (this is what "profile keys" means in the live tests)
431
+ - Config: `~/.nodmix/nodmix.json` (or `NODMIX_CONFIG_PATH`)
432
+ - Legacy state dir: `~/.nodmix/credentials/` (copied into the staged live home when present, but not the main profile-key store)
433
+ - Live local runs copy the active config, per-agent `auth-profiles.json` files, legacy `credentials/`, and supported external CLI auth dirs into a temp test home by default; staged live homes skip `workspace/` and `sandboxes/`, and `agents.*.workspace` / `agentDir` path overrides are stripped so probes stay off your real host workspace.
434
+
435
+ If you want to rely on env keys, export them before local tests or use the
436
+ Docker runners below with an explicit `NODMIX_PROFILE_FILE`.
437
+
438
+ ## Deepgram live (audio transcription)
439
+
440
+ - Test: `extensions/deepgram/audio.live.test.ts`
441
+ - Enable: `DEEPGRAM_API_KEY=... DEEPGRAM_LIVE_TEST=1 pnpm test:live extensions/deepgram/audio.live.test.ts`
442
+
443
+ ## BytePlus coding plan live
444
+
445
+ - Test: `extensions/byteplus/live.test.ts`
446
+ - Enable: `BYTEPLUS_API_KEY=... BYTEPLUS_LIVE_TEST=1 pnpm test:live extensions/byteplus/live.test.ts`
447
+ - Optional model override: `BYTEPLUS_CODING_MODEL=ark-code-latest`
448
+
449
+ ## ComfyUI workflow media live
450
+
451
+ - Test: `extensions/comfy/comfy.live.test.ts`
452
+ - Enable: `NODMIX_LIVE_TEST=1 COMFY_LIVE_TEST=1 pnpm test:live -- extensions/comfy/comfy.live.test.ts`
453
+ - Scope:
454
+ - Exercises the bundled comfy image, video, and `music_generate` paths
455
+ - Skips each capability unless `plugins.entries.comfy.config.<capability>` is configured
456
+ - Useful after changing comfy workflow submission, polling, downloads, or plugin registration
457
+
458
+ ## Image generation live
459
+
460
+ - Test: `test/image-generation.runtime.live.test.ts`
461
+ - Command: `pnpm test:live test/image-generation.runtime.live.test.ts`
462
+ - Harness: `pnpm test:live:media image`
463
+ - Scope:
464
+ - Enumerates every registered image-generation provider plugin
465
+ - Uses already-exported provider env vars before probing
466
+ - Uses live/env API keys ahead of stored auth profiles by default, so stale test keys in `auth-profiles.json` do not mask real shell credentials
467
+ - Skips providers with no usable auth/profile/model
468
+ - Runs each configured provider through the shared image-generation runtime:
469
+ - `<provider>:generate`
470
+ - `<provider>:edit` when the provider declares edit support
471
+ - Current bundled providers covered:
472
+ - `deepinfra`
473
+ - `fal`
474
+ - `google`
475
+ - `minimax`
476
+ - `openai`
477
+ - `openrouter`
478
+ - `vydra`
479
+ - `xai`
480
+ - Optional narrowing:
481
+ - `NODMIX_LIVE_IMAGE_GENERATION_PROVIDERS="openai,google,openrouter,xai"`
482
+ - `NODMIX_LIVE_IMAGE_GENERATION_PROVIDERS="deepinfra"`
483
+ - `NODMIX_LIVE_IMAGE_GENERATION_MODELS="openai/gpt-image-2,google/gemini-3.1-flash-image-preview,openrouter/google/gemini-3.1-flash-image-preview,xai/grok-imagine-image"`
484
+ - `NODMIX_LIVE_IMAGE_GENERATION_CASES="google:flash-generate,google:pro-edit,openrouter:generate,xai:default-generate,xai:default-edit"`
485
+ - Optional auth behavior:
486
+ - `NODMIX_LIVE_REQUIRE_PROFILE_KEYS=1` to force profile-store auth and ignore env-only overrides
487
+
488
+ For the shipped CLI path, add an `infer` smoke after the provider/runtime live
489
+ test passes:
490
+
491
+ ```bash
492
+ NODMIX_LIVE_TEST=1 NODMIX_LIVE_INFER_CLI_TEST=1 pnpm test:live -- test/image-generation.infer-cli.live.test.ts
493
+ nodmix infer image providers --json
494
+ nodmix infer image generate \
495
+ --model google/gemini-3.1-flash-image-preview \
496
+ --prompt "Minimal flat test image: one blue square on a white background, no text." \
497
+ --output ./nodmix-infer-image-smoke.png \
498
+ --json
499
+ ```
500
+
501
+ This covers CLI argument parsing, config/default-agent resolution, bundled
502
+ plugin activation, the shared image-generation runtime, and the live provider
503
+ request. Plugin dependencies are expected to be present before runtime load.
504
+
505
+ ## Music generation live
506
+
507
+ - Test: `extensions/music-generation-providers.live.test.ts`
508
+ - Enable: `NODMIX_LIVE_TEST=1 pnpm test:live -- extensions/music-generation-providers.live.test.ts`
509
+ - Harness: `pnpm test:live:media music`
510
+ - Scope:
511
+ - Exercises the shared bundled music-generation provider path
512
+ - Currently covers Google and MiniMax
513
+ - Uses already-exported provider env vars before probing
514
+ - Uses live/env API keys ahead of stored auth profiles by default, so stale test keys in `auth-profiles.json` do not mask real shell credentials
515
+ - Skips providers with no usable auth/profile/model
516
+ - Runs both declared runtime modes when available:
517
+ - `generate` with prompt-only input
518
+ - `edit` when the provider declares `capabilities.edit.enabled`
519
+ - Current shared-lane coverage:
520
+ - `google`: `generate`, `edit`
521
+ - `minimax`: `generate`
522
+ - `comfy`: separate Comfy live file, not this shared sweep
523
+ - Optional narrowing:
524
+ - `NODMIX_LIVE_MUSIC_GENERATION_PROVIDERS="google,minimax"`
525
+ - `NODMIX_LIVE_MUSIC_GENERATION_MODELS="google/lyria-3-clip-preview,minimax/music-2.6"`
526
+ - Optional auth behavior:
527
+ - `NODMIX_LIVE_REQUIRE_PROFILE_KEYS=1` to force profile-store auth and ignore env-only overrides
528
+
529
+ ## Video generation live
530
+
531
+ - Test: `extensions/video-generation-providers.live.test.ts`
532
+ - Enable: `NODMIX_LIVE_TEST=1 pnpm test:live -- extensions/video-generation-providers.live.test.ts`
533
+ - Harness: `pnpm test:live:media video`
534
+ - Scope:
535
+ - Exercises the shared bundled video-generation provider path
536
+ - Defaults to the release-safe smoke path: non-FAL providers, one text-to-video request per provider, one-second lobster prompt, and a per-provider operation cap from `NODMIX_LIVE_VIDEO_GENERATION_TIMEOUT_MS` (`180000` by default)
537
+ - Skips FAL by default because provider-side queue latency can dominate release time; pass `--video-providers fal` or `NODMIX_LIVE_VIDEO_GENERATION_PROVIDERS="fal"` to run it explicitly
538
+ - Uses already-exported provider env vars before probing
539
+ - Uses live/env API keys ahead of stored auth profiles by default, so stale test keys in `auth-profiles.json` do not mask real shell credentials
540
+ - Skips providers with no usable auth/profile/model
541
+ - Runs only `generate` by default
542
+ - Set `NODMIX_LIVE_VIDEO_GENERATION_FULL_MODES=1` to also run declared transform modes when available:
543
+ - `imageToVideo` when the provider declares `capabilities.imageToVideo.enabled` and the selected provider/model accepts buffer-backed local image input in the shared sweep
544
+ - `videoToVideo` when the provider declares `capabilities.videoToVideo.enabled` and the selected provider/model accepts buffer-backed local video input in the shared sweep
545
+ - Current declared-but-skipped `imageToVideo` providers in the shared sweep:
546
+ - `vydra` because bundled `veo3` is text-only and bundled `kling` requires a remote image URL
547
+ - Provider-specific Vydra coverage:
548
+ - `NODMIX_LIVE_TEST=1 NODMIX_LIVE_VYDRA_VIDEO=1 pnpm test:live -- extensions/vydra/vydra.live.test.ts`
549
+ - that file runs `veo3` text-to-video plus a `kling` lane that uses a remote image URL fixture by default
550
+ - Current `videoToVideo` live coverage:
551
+ - `runway` only when the selected model is `runway/gen4_aleph`
552
+ - Current declared-but-skipped `videoToVideo` providers in the shared sweep:
553
+ - `alibaba`, `qwen`, `xai` because those paths currently require remote `http(s)` / MP4 reference URLs
554
+ - `google` because the current shared Gemini/Veo lane uses local buffer-backed input and that path is not accepted in the shared sweep
555
+ - `openai` because the current shared lane lacks org-specific video inpaint/remix access guarantees
556
+ - Optional narrowing:
557
+ - `NODMIX_LIVE_VIDEO_GENERATION_PROVIDERS="deepinfra,google,openai,runway"`
558
+ - `NODMIX_LIVE_VIDEO_GENERATION_MODELS="google/veo-3.1-fast-generate-preview,openai/sora-2,runway/gen4_aleph"`
559
+ - `NODMIX_LIVE_VIDEO_GENERATION_SKIP_PROVIDERS=""` to include every provider in the default sweep, including FAL
560
+ - `NODMIX_LIVE_VIDEO_GENERATION_TIMEOUT_MS=60000` to reduce each provider operation cap for an aggressive smoke run
561
+ - Optional auth behavior:
562
+ - `NODMIX_LIVE_REQUIRE_PROFILE_KEYS=1` to force profile-store auth and ignore env-only overrides
563
+
564
+ ## Media live harness
565
+
566
+ - Command: `pnpm test:live:media`
567
+ - Purpose:
568
+ - Runs the shared image, music, and video live suites through one repo-native entrypoint
569
+ - Uses already-exported provider env vars
570
+ - Auto-narrows each suite to providers that currently have usable auth by default
571
+ - Reuses `scripts/test-live.mjs`, so heartbeat and quiet-mode behavior stay consistent
572
+ - Examples:
573
+ - `pnpm test:live:media`
574
+ - `pnpm test:live:media image video --providers openai,google,minimax`
575
+ - `pnpm test:live:media video --video-providers openai,runway --all-providers`
576
+ - `pnpm test:live:media music --quiet`
577
+
578
+ ## Related
579
+
580
+ - [Testing](/help/testing) - unit, integration, QA, and Docker suites