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,455 @@
1
+ ---
2
+ summary: "How the installer scripts work (install.sh, install-cli.sh, install.ps1), flags, and automation"
3
+ read_when:
4
+ - You want to understand `nodmix.ai/install.sh`
5
+ - You want to automate installs (CI / headless)
6
+ - You want to install from a GitHub checkout
7
+ title: "Installer internals"
8
+ ---
9
+
10
+ Nodmix ships three installer scripts, served from `nodmix.ai`.
11
+
12
+ | Script | Platform | What it does |
13
+ | ---------------------------------- | -------------------- | -------------------------------------------------------------------------------------------------------------- |
14
+ | [`install.sh`](#installsh) | macOS / Linux / WSL | Installs Node if needed, installs Nodmix via npm (default) or git, and can run onboarding. |
15
+ | [`install-cli.sh`](#install-clish) | macOS / Linux / WSL | Installs Node + Nodmix into a local prefix (`~/.nodmix`) with npm or git checkout modes. No root required. |
16
+ | [`install.ps1`](#installps1) | Windows (PowerShell) | Installs Node if needed, installs Nodmix via npm (default) or git, and can run onboarding. |
17
+
18
+ ## Quick commands
19
+
20
+ <Tabs>
21
+ <Tab title="install.sh">
22
+ ```bash
23
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash
24
+ ```
25
+
26
+ ```bash
27
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash -s -- --help
28
+ ```
29
+
30
+ </Tab>
31
+ <Tab title="install-cli.sh">
32
+ ```bash
33
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install-cli.sh | bash
34
+ ```
35
+
36
+ ```bash
37
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install-cli.sh | bash -s -- --help
38
+ ```
39
+
40
+ </Tab>
41
+ <Tab title="install.ps1">
42
+ ```powershell
43
+ iwr -useb https://nodmix.ai/install.ps1 | iex
44
+ ```
45
+
46
+ ```powershell
47
+ & ([scriptblock]::Create((iwr -useb https://nodmix.ai/install.ps1))) -Tag beta -NoOnboard -DryRun
48
+ ```
49
+
50
+ </Tab>
51
+ </Tabs>
52
+
53
+ <Note>
54
+ If install succeeds but `nodmix` is not found in a new terminal, see [Node.js troubleshooting](/install/node#troubleshooting).
55
+ </Note>
56
+
57
+ ---
58
+
59
+ <a id="installsh"></a>
60
+
61
+ ## install.sh
62
+
63
+ <Tip>
64
+ Recommended for most interactive installs on macOS/Linux/WSL.
65
+ </Tip>
66
+
67
+ ### Flow (install.sh)
68
+
69
+ <Steps>
70
+ <Step title="Detect OS">
71
+ Supports macOS and Linux (including WSL). If macOS is detected, installs Homebrew if missing.
72
+ </Step>
73
+ <Step title="Ensure Node.js 24 by default">
74
+ Checks Node version and installs Node 24 if needed (Homebrew on macOS, NodeSource setup scripts on Linux apt/dnf/yum). Nodmix still supports Node 22 LTS, currently `22.19+`, for compatibility.
75
+ </Step>
76
+ <Step title="Ensure Git">
77
+ Installs Git if missing.
78
+ </Step>
79
+ <Step title="Install Nodmix">
80
+ - `npm` method (default): global npm install
81
+ - `git` method: clone/update repo, install deps with pnpm, build, then install wrapper at `~/.local/bin/nodmix`
82
+
83
+ </Step>
84
+ <Step title="Post-install tasks">
85
+ - Refreshes a loaded gateway service best-effort (`nodmix gateway install --force`, then restart)
86
+ - Runs `nodmix doctor --non-interactive` on upgrades and git installs (best effort)
87
+ - Attempts onboarding when appropriate (TTY available, onboarding not disabled, and bootstrap/config checks pass)
88
+ - Defaults `SHARP_IGNORE_GLOBAL_LIBVIPS=1`
89
+
90
+ </Step>
91
+ </Steps>
92
+
93
+ ### Source checkout detection
94
+
95
+ If run inside an Nodmix checkout (`package.json` + `pnpm-workspace.yaml`), the script offers:
96
+
97
+ - use checkout (`git`), or
98
+ - use global install (`npm`)
99
+
100
+ If no TTY is available and no install method is set, it defaults to `npm` and warns.
101
+
102
+ The script exits with code `2` for invalid method selection or invalid `--install-method` values.
103
+
104
+ ### Examples (install.sh)
105
+
106
+ <Tabs>
107
+ <Tab title="Default">
108
+ ```bash
109
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash
110
+ ```
111
+ </Tab>
112
+ <Tab title="Skip onboarding">
113
+ ```bash
114
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash -s -- --no-onboard
115
+ ```
116
+ </Tab>
117
+ <Tab title="Git install">
118
+ ```bash
119
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash -s -- --install-method git
120
+ ```
121
+ </Tab>
122
+ <Tab title="GitHub main via npm">
123
+ ```bash
124
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash -s -- --version main
125
+ ```
126
+ </Tab>
127
+ <Tab title="Dry run">
128
+ ```bash
129
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash -s -- --dry-run
130
+ ```
131
+ </Tab>
132
+ </Tabs>
133
+
134
+ <AccordionGroup>
135
+ <Accordion title="Flags reference">
136
+
137
+ | Flag | Description |
138
+ | ------------------------------------- | ---------------------------------------------------------- |
139
+ | `--install-method npm\|git` | Choose install method (default: `npm`). Alias: `--method` |
140
+ | `--npm` | Shortcut for npm method |
141
+ | `--git` | Shortcut for git method. Alias: `--github` |
142
+ | `--version <version\|dist-tag\|spec>` | npm version, dist-tag, or package spec (default: `latest`) |
143
+ | `--beta` | Use beta dist-tag if available, else fallback to `latest` |
144
+ | `--git-dir <path>` | Checkout directory (default: `~/nodmix`). Alias: `--dir` |
145
+ | `--no-git-update` | Skip `git pull` for existing checkout |
146
+ | `--no-prompt` | Disable prompts |
147
+ | `--no-onboard` | Skip onboarding |
148
+ | `--onboard` | Enable onboarding |
149
+ | `--dry-run` | Print actions without applying changes |
150
+ | `--verbose` | Enable debug output (`set -x`, npm notice-level logs) |
151
+ | `--help` | Show usage (`-h`) |
152
+
153
+ </Accordion>
154
+
155
+ <Accordion title="Environment variables reference">
156
+
157
+ | Variable | Description |
158
+ | ------------------------------------------------------- | --------------------------------------------- |
159
+ | `NODMIX_INSTALL_METHOD=git\|npm` | Install method |
160
+ | `NODMIX_VERSION=latest\|next\|main\|<semver>\|<spec>` | npm version, dist-tag, or package spec |
161
+ | `NODMIX_BETA=0\|1` | Use beta if available |
162
+ | `NODMIX_GIT_DIR=<path>` | Checkout directory |
163
+ | `NODMIX_GIT_UPDATE=0\|1` | Toggle git updates |
164
+ | `NODMIX_NO_PROMPT=1` | Disable prompts |
165
+ | `NODMIX_NO_ONBOARD=1` | Skip onboarding |
166
+ | `NODMIX_DRY_RUN=1` | Dry run mode |
167
+ | `NODMIX_VERBOSE=1` | Debug mode |
168
+ | `NODMIX_NPM_LOGLEVEL=error\|warn\|notice` | npm log level |
169
+ | `SHARP_IGNORE_GLOBAL_LIBVIPS=0\|1` | Control sharp/libvips behavior (default: `1`) |
170
+
171
+ </Accordion>
172
+ </AccordionGroup>
173
+
174
+ ---
175
+
176
+ <a id="install-clish"></a>
177
+
178
+ ## install-cli.sh
179
+
180
+ <Info>
181
+ Designed for environments where you want everything under a local prefix
182
+ (default `~/.nodmix`) and no system Node dependency. Supports npm installs
183
+ by default, plus git-checkout installs under the same prefix flow.
184
+ </Info>
185
+
186
+ ### Flow (install-cli.sh)
187
+
188
+ <Steps>
189
+ <Step title="Install local Node runtime">
190
+ Downloads a pinned supported Node LTS tarball (the version is embedded in the script and updated independently) to `<prefix>/tools/node-v<version>` and verifies SHA-256.
191
+ </Step>
192
+ <Step title="Ensure Git">
193
+ If Git is missing, attempts install via apt/dnf/yum on Linux or Homebrew on macOS.
194
+ </Step>
195
+ <Step title="Install Nodmix under prefix">
196
+ - `npm` method (default): installs under the prefix with npm, then writes wrapper to `<prefix>/bin/nodmix`
197
+ - `git` method: clones/updates a checkout (default `~/nodmix`) and still writes the wrapper to `<prefix>/bin/nodmix`
198
+
199
+ </Step>
200
+ <Step title="Refresh loaded gateway service">
201
+ If a gateway service is already loaded from that same prefix, the script runs
202
+ `nodmix gateway install --force`, then `nodmix gateway restart`, and
203
+ probes gateway health best-effort.
204
+ </Step>
205
+ </Steps>
206
+
207
+ ### Examples (install-cli.sh)
208
+
209
+ <Tabs>
210
+ <Tab title="Default">
211
+ ```bash
212
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install-cli.sh | bash
213
+ ```
214
+ </Tab>
215
+ <Tab title="Custom prefix + version">
216
+ ```bash
217
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install-cli.sh | bash -s -- --prefix /opt/nodmix --version latest
218
+ ```
219
+ </Tab>
220
+ <Tab title="Git install">
221
+ ```bash
222
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install-cli.sh | bash -s -- --install-method git --git-dir ~/nodmix
223
+ ```
224
+ </Tab>
225
+ <Tab title="Automation JSON output">
226
+ ```bash
227
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install-cli.sh | bash -s -- --json --prefix /opt/nodmix
228
+ ```
229
+ </Tab>
230
+ <Tab title="Run onboarding">
231
+ ```bash
232
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install-cli.sh | bash -s -- --onboard
233
+ ```
234
+ </Tab>
235
+ </Tabs>
236
+
237
+ <AccordionGroup>
238
+ <Accordion title="Flags reference">
239
+
240
+ | Flag | Description |
241
+ | --------------------------- | ------------------------------------------------------------------------------- |
242
+ | `--prefix <path>` | Install prefix (default: `~/.nodmix`) |
243
+ | `--install-method npm\|git` | Choose install method (default: `npm`). Alias: `--method` |
244
+ | `--npm` | Shortcut for npm method |
245
+ | `--git`, `--github` | Shortcut for git method |
246
+ | `--git-dir <path>` | Git checkout directory (default: `~/nodmix`). Alias: `--dir` |
247
+ | `--version <ver>` | Nodmix version or dist-tag (default: `latest`) |
248
+ | `--node-version <ver>` | Node version (default: `22.22.0`) |
249
+ | `--json` | Emit NDJSON events |
250
+ | `--onboard` | Run `nodmix onboard` after install |
251
+ | `--no-onboard` | Skip onboarding (default) |
252
+ | `--set-npm-prefix` | On Linux, force npm prefix to `~/.npm-global` if current prefix is not writable |
253
+ | `--help` | Show usage (`-h`) |
254
+
255
+ </Accordion>
256
+
257
+ <Accordion title="Environment variables reference">
258
+
259
+ | Variable | Description |
260
+ | ------------------------------------------- | --------------------------------------------- |
261
+ | `NODMIX_PREFIX=<path>` | Install prefix |
262
+ | `NODMIX_INSTALL_METHOD=git\|npm` | Install method |
263
+ | `NODMIX_VERSION=<ver>` | Nodmix version or dist-tag |
264
+ | `NODMIX_NODE_VERSION=<ver>` | Node version |
265
+ | `NODMIX_GIT_DIR=<path>` | Git checkout directory for git installs |
266
+ | `NODMIX_GIT_UPDATE=0\|1` | Toggle git updates for existing checkouts |
267
+ | `NODMIX_NO_ONBOARD=1` | Skip onboarding |
268
+ | `NODMIX_NPM_LOGLEVEL=error\|warn\|notice` | npm log level |
269
+ | `SHARP_IGNORE_GLOBAL_LIBVIPS=0\|1` | Control sharp/libvips behavior (default: `1`) |
270
+
271
+ </Accordion>
272
+ </AccordionGroup>
273
+
274
+ ---
275
+
276
+ <a id="installps1"></a>
277
+
278
+ ## install.ps1
279
+
280
+ ### Flow (install.ps1)
281
+
282
+ <Steps>
283
+ <Step title="Ensure PowerShell + Windows environment">
284
+ Requires PowerShell 5+.
285
+ </Step>
286
+ <Step title="Ensure Node.js 24 by default">
287
+ If missing, attempts install via winget, then Chocolatey, then Scoop. Node 22 LTS, currently `22.19+`, remains supported for compatibility.
288
+ </Step>
289
+ <Step title="Install Nodmix">
290
+ - `npm` method (default): global npm install using selected `-Tag`, launched from a writable installer temp directory so shells opened in protected folders such as `C:\` still work
291
+ - `git` method: clone/update repo, install/build with pnpm, and install wrapper at `%USERPROFILE%\.local\bin\nodmix.cmd`
292
+
293
+ </Step>
294
+ <Step title="Post-install tasks">
295
+ - Adds needed bin directory to user PATH when possible
296
+ - Refreshes a loaded gateway service best-effort (`nodmix gateway install --force`, then restart)
297
+ - Runs `nodmix doctor --non-interactive` on upgrades and git installs (best effort)
298
+
299
+ </Step>
300
+ <Step title="Handle failures">
301
+ `iwr ... | iex` and scriptblock installs report a terminating error without closing the current PowerShell session. Direct `powershell -File` / `pwsh -File` installs still exit non-zero for automation.
302
+ </Step>
303
+ </Steps>
304
+
305
+ ### Examples (install.ps1)
306
+
307
+ <Tabs>
308
+ <Tab title="Default">
309
+ ```powershell
310
+ iwr -useb https://nodmix.ai/install.ps1 | iex
311
+ ```
312
+ </Tab>
313
+ <Tab title="Git install">
314
+ ```powershell
315
+ & ([scriptblock]::Create((iwr -useb https://nodmix.ai/install.ps1))) -InstallMethod git
316
+ ```
317
+ </Tab>
318
+ <Tab title="GitHub main via npm">
319
+ ```powershell
320
+ & ([scriptblock]::Create((iwr -useb https://nodmix.ai/install.ps1))) -Tag main
321
+ ```
322
+ </Tab>
323
+ <Tab title="Custom git directory">
324
+ ```powershell
325
+ & ([scriptblock]::Create((iwr -useb https://nodmix.ai/install.ps1))) -InstallMethod git -GitDir "C:\nodmix"
326
+ ```
327
+ </Tab>
328
+ <Tab title="Dry run">
329
+ ```powershell
330
+ & ([scriptblock]::Create((iwr -useb https://nodmix.ai/install.ps1))) -DryRun
331
+ ```
332
+ </Tab>
333
+ <Tab title="Debug trace">
334
+ ```powershell
335
+ # install.ps1 has no dedicated -Verbose flag yet.
336
+ Set-PSDebug -Trace 1
337
+ & ([scriptblock]::Create((iwr -useb https://nodmix.ai/install.ps1))) -NoOnboard
338
+ Set-PSDebug -Trace 0
339
+ ```
340
+ </Tab>
341
+ </Tabs>
342
+
343
+ <AccordionGroup>
344
+ <Accordion title="Flags reference">
345
+
346
+ | Flag | Description |
347
+ | --------------------------- | ---------------------------------------------------------- |
348
+ | `-InstallMethod npm\|git` | Install method (default: `npm`) |
349
+ | `-Tag <tag\|version\|spec>` | npm dist-tag, version, or package spec (default: `latest`) |
350
+ | `-GitDir <path>` | Checkout directory (default: `%USERPROFILE%\nodmix`) |
351
+ | `-NoOnboard` | Skip onboarding |
352
+ | `-NoGitUpdate` | Skip `git pull` |
353
+ | `-DryRun` | Print actions only |
354
+
355
+ </Accordion>
356
+
357
+ <Accordion title="Environment variables reference">
358
+
359
+ | Variable | Description |
360
+ | ---------------------------------- | ------------------ |
361
+ | `NODMIX_INSTALL_METHOD=git\|npm` | Install method |
362
+ | `NODMIX_GIT_DIR=<path>` | Checkout directory |
363
+ | `NODMIX_NO_ONBOARD=1` | Skip onboarding |
364
+ | `NODMIX_GIT_UPDATE=0` | Disable git pull |
365
+ | `NODMIX_DRY_RUN=1` | Dry run mode |
366
+
367
+ </Accordion>
368
+ </AccordionGroup>
369
+
370
+ <Note>
371
+ If `-InstallMethod git` is used and Git is missing, the script exits and prints the Git for Windows link.
372
+ </Note>
373
+
374
+ ---
375
+
376
+ ## CI and automation
377
+
378
+ Use non-interactive flags/env vars for predictable runs.
379
+
380
+ <Tabs>
381
+ <Tab title="install.sh (non-interactive npm)">
382
+ ```bash
383
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash -s -- --no-prompt --no-onboard
384
+ ```
385
+ </Tab>
386
+ <Tab title="install.sh (non-interactive git)">
387
+ ```bash
388
+ NODMIX_INSTALL_METHOD=git NODMIX_NO_PROMPT=1 \
389
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash
390
+ ```
391
+ </Tab>
392
+ <Tab title="install-cli.sh (JSON)">
393
+ ```bash
394
+ curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install-cli.sh | bash -s -- --json --prefix /opt/nodmix
395
+ ```
396
+ </Tab>
397
+ <Tab title="install.ps1 (skip onboarding)">
398
+ ```powershell
399
+ & ([scriptblock]::Create((iwr -useb https://nodmix.ai/install.ps1))) -NoOnboard
400
+ ```
401
+ </Tab>
402
+ </Tabs>
403
+
404
+ ---
405
+
406
+ ## Troubleshooting
407
+
408
+ <AccordionGroup>
409
+ <Accordion title="Why is Git required?">
410
+ Git is required for `git` install method. For `npm` installs, Git is still checked/installed to avoid `spawn git ENOENT` failures when dependencies use git URLs.
411
+ </Accordion>
412
+
413
+ <Accordion title="Why does npm hit EACCES on Linux?">
414
+ Some Linux setups point npm global prefix to root-owned paths. `install.sh` can switch prefix to `~/.npm-global` and append PATH exports to shell rc files (when those files exist).
415
+ </Accordion>
416
+
417
+ <Accordion title="sharp/libvips issues">
418
+ The scripts default `SHARP_IGNORE_GLOBAL_LIBVIPS=1` to avoid sharp building against system libvips. To override:
419
+
420
+ ```bash
421
+ SHARP_IGNORE_GLOBAL_LIBVIPS=0 curl -fsSL --proto '=https' --tlsv1.2 https://nodmix.ai/install.sh | bash
422
+ ```
423
+
424
+ </Accordion>
425
+
426
+ <Accordion title='Windows: "npm error spawn git / ENOENT"'>
427
+ Install Git for Windows, reopen PowerShell, rerun installer.
428
+ </Accordion>
429
+
430
+ <Accordion title='Windows: "nodmix is not recognized"'>
431
+ Run `npm config get prefix` and add that directory to your user PATH (no `\bin` suffix needed on Windows), then reopen PowerShell.
432
+ </Accordion>
433
+
434
+ <Accordion title="Windows: how to get verbose installer output">
435
+ `install.ps1` does not currently expose a `-Verbose` switch.
436
+ Use PowerShell tracing for script-level diagnostics:
437
+
438
+ ```powershell
439
+ Set-PSDebug -Trace 1
440
+ & ([scriptblock]::Create((iwr -useb https://nodmix.ai/install.ps1))) -NoOnboard
441
+ Set-PSDebug -Trace 0
442
+ ```
443
+
444
+ </Accordion>
445
+
446
+ <Accordion title="nodmix not found after install">
447
+ Usually a PATH issue. See [Node.js troubleshooting](/install/node#troubleshooting).
448
+ </Accordion>
449
+ </AccordionGroup>
450
+
451
+ ## Related
452
+
453
+ - [Install overview](/install)
454
+ - [Updating](/install/updating)
455
+ - [Uninstall](/install/uninstall)
@@ -0,0 +1,196 @@
1
+ ---
2
+ summary: "Deploy Nodmix Gateway to a Kubernetes cluster with Kustomize"
3
+ read_when:
4
+ - You want to run Nodmix on a Kubernetes cluster
5
+ - You want to test Nodmix in a Kubernetes environment
6
+ title: "Kubernetes"
7
+ ---
8
+
9
+ A minimal starting point for running Nodmix on Kubernetes — not a production-ready deployment. It covers the core resources and is meant to be adapted to your environment.
10
+
11
+ ## Why not Helm?
12
+
13
+ Nodmix is a single container with some config files. The interesting customization is in agent content (markdown files, skills, config overrides), not infrastructure templating. Kustomize handles overlays without the overhead of a Helm chart. If your deployment grows more complex, a Helm chart can be layered on top of these manifests.
14
+
15
+ ## What you need
16
+
17
+ - A running Kubernetes cluster (AKS, EKS, GKE, k3s, kind, OpenShift, etc.)
18
+ - `kubectl` connected to your cluster
19
+ - An API key for at least one model provider
20
+
21
+ ## Quick start
22
+
23
+ ```bash
24
+ # Replace with your provider: ANTHROPIC, GEMINI, OPENAI, or OPENROUTER
25
+ export <PROVIDER>_API_KEY="..."
26
+ ./scripts/k8s/deploy.sh
27
+
28
+ kubectl port-forward svc/nodmix 18789:18789 -n nodmix
29
+ open http://localhost:18789
30
+ ```
31
+
32
+ Retrieve the configured shared secret for the Control UI. This deploy script
33
+ creates token auth by default:
34
+
35
+ ```bash
36
+ kubectl get secret nodmix-secrets -n nodmix -o jsonpath='{.data.NODMIX_GATEWAY_TOKEN}' | base64 -d
37
+ ```
38
+
39
+ For local debugging, `./scripts/k8s/deploy.sh --show-token` prints the token after deploy.
40
+
41
+ ## Local testing with Kind
42
+
43
+ If you don't have a cluster, create one locally with [Kind](https://kind.sigs.k8s.io/):
44
+
45
+ ```bash
46
+ ./scripts/k8s/create-kind.sh # auto-detects docker or podman
47
+ ./scripts/k8s/create-kind.sh --delete # tear down
48
+ ```
49
+
50
+ Then deploy as usual with `./scripts/k8s/deploy.sh`.
51
+
52
+ ## Step by step
53
+
54
+ ### 1) Deploy
55
+
56
+ **Option A** — API key in environment (one step):
57
+
58
+ ```bash
59
+ # Replace with your provider: ANTHROPIC, GEMINI, OPENAI, or OPENROUTER
60
+ export <PROVIDER>_API_KEY="..."
61
+ ./scripts/k8s/deploy.sh
62
+ ```
63
+
64
+ The script creates a Kubernetes Secret with the API key and an auto-generated gateway token, then deploys. If the Secret already exists, it preserves the current gateway token and any provider keys not being changed.
65
+
66
+ **Option B** — create the secret separately:
67
+
68
+ ```bash
69
+ export <PROVIDER>_API_KEY="..."
70
+ ./scripts/k8s/deploy.sh --create-secret
71
+ ./scripts/k8s/deploy.sh
72
+ ```
73
+
74
+ Use `--show-token` with either command if you want the token printed to stdout for local testing.
75
+
76
+ ### 2) Access the gateway
77
+
78
+ ```bash
79
+ kubectl port-forward svc/nodmix 18789:18789 -n nodmix
80
+ open http://localhost:18789
81
+ ```
82
+
83
+ ## What gets deployed
84
+
85
+ ```
86
+ Namespace: nodmix (configurable via NODMIX_NAMESPACE)
87
+ ├── Deployment/nodmix # Single pod, init container + gateway
88
+ ├── Service/nodmix # ClusterIP on port 18789
89
+ ├── PersistentVolumeClaim # 10Gi for agent state and config
90
+ ├── ConfigMap/nodmix-config # nodmix.json + AGENTS.md
91
+ └── Secret/nodmix-secrets # Gateway token + API keys
92
+ ```
93
+
94
+ ## Customization
95
+
96
+ ### Agent instructions
97
+
98
+ Edit the `AGENTS.md` in `scripts/k8s/manifests/configmap.yaml` and redeploy:
99
+
100
+ ```bash
101
+ ./scripts/k8s/deploy.sh
102
+ ```
103
+
104
+ ### Gateway config
105
+
106
+ Edit `nodmix.json` in `scripts/k8s/manifests/configmap.yaml`. See [Gateway configuration](/gateway/configuration) for the full reference.
107
+
108
+ ### Add providers
109
+
110
+ Re-run with additional keys exported:
111
+
112
+ ```bash
113
+ export ANTHROPIC_API_KEY="..."
114
+ export OPENAI_API_KEY="..."
115
+ ./scripts/k8s/deploy.sh --create-secret
116
+ ./scripts/k8s/deploy.sh
117
+ ```
118
+
119
+ Existing provider keys stay in the Secret unless you overwrite them.
120
+
121
+ Or patch the Secret directly:
122
+
123
+ ```bash
124
+ kubectl patch secret nodmix-secrets -n nodmix \
125
+ -p '{"stringData":{"<PROVIDER>_API_KEY":"..."}}'
126
+ kubectl rollout restart deployment/nodmix -n nodmix
127
+ ```
128
+
129
+ ### Custom namespace
130
+
131
+ ```bash
132
+ NODMIX_NAMESPACE=my-namespace ./scripts/k8s/deploy.sh
133
+ ```
134
+
135
+ ### Custom image
136
+
137
+ Edit the `image` field in `scripts/k8s/manifests/deployment.yaml`:
138
+
139
+ ```yaml
140
+ image: ghcr.io/nodmix/nodmix:latest # or pin to a specific version from https://github.com/nodmix/nodmix/releases
141
+ ```
142
+
143
+ ### Expose beyond port-forward
144
+
145
+ The default manifests bind the gateway to loopback inside the pod. That works with `kubectl port-forward`, but it does not work with a Kubernetes `Service` or Ingress path that needs to reach the pod IP.
146
+
147
+ If you want to expose the gateway through an Ingress or load balancer:
148
+
149
+ - Change the gateway bind in `scripts/k8s/manifests/configmap.yaml` from `loopback` to a non-loopback bind that matches your deployment model
150
+ - Keep gateway auth enabled and use a proper TLS-terminated entrypoint
151
+ - Configure the Control UI for remote access using the supported web security model (for example HTTPS/Tailscale Serve and explicit allowed origins when needed)
152
+
153
+ ## Re-deploy
154
+
155
+ ```bash
156
+ ./scripts/k8s/deploy.sh
157
+ ```
158
+
159
+ This applies all manifests and restarts the pod to pick up any config or secret changes.
160
+
161
+ ## Teardown
162
+
163
+ ```bash
164
+ ./scripts/k8s/deploy.sh --delete
165
+ ```
166
+
167
+ This deletes the namespace and all resources in it, including the PVC.
168
+
169
+ ## Architecture notes
170
+
171
+ - The gateway binds to loopback inside the pod by default, so the included setup is for `kubectl port-forward`
172
+ - No cluster-scoped resources — everything lives in a single namespace
173
+ - Security: `readOnlyRootFilesystem`, `drop: ALL` capabilities, non-root user (UID 1000)
174
+ - The default config keeps the Control UI on the safer local-access path: loopback bind plus `kubectl port-forward` to `http://127.0.0.1:18789`
175
+ - If you move beyond localhost access, use the supported remote model: HTTPS/Tailscale plus the appropriate gateway bind and Control UI origin settings
176
+ - Secrets are generated in a temp directory and applied directly to the cluster — no secret material is written to the repo checkout
177
+
178
+ ## File structure
179
+
180
+ ```
181
+ scripts/k8s/
182
+ ├── deploy.sh # Creates namespace + secret, deploys via kustomize
183
+ ├── create-kind.sh # Local Kind cluster (auto-detects docker/podman)
184
+ └── manifests/
185
+ ├── kustomization.yaml # Kustomize base
186
+ ├── configmap.yaml # nodmix.json + AGENTS.md
187
+ ├── deployment.yaml # Pod spec with security hardening
188
+ ├── pvc.yaml # 10Gi persistent storage
189
+ └── service.yaml # ClusterIP on 18789
190
+ ```
191
+
192
+ ## Related
193
+
194
+ - [Docker](/install/docker)
195
+ - [Docker VM runtime](/install/docker-vm-runtime)
196
+ - [Install overview](/install)