@quantumclaw/quantumclaw 2026.3.22

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 (821) hide show
  1. package/CHANGELOG.md +4601 -0
  2. package/LICENSE +21 -0
  3. package/README.md +559 -0
  4. package/assets/avatar-placeholder.svg +19 -0
  5. package/assets/chrome-extension/icons/icon128.png +0 -0
  6. package/assets/chrome-extension/icons/icon16.png +0 -0
  7. package/assets/chrome-extension/icons/icon32.png +0 -0
  8. package/assets/chrome-extension/icons/icon48.png +0 -0
  9. package/assets/dmg-background-small.png +0 -0
  10. package/assets/dmg-background.png +0 -0
  11. package/docs/.i18n/README.md +31 -0
  12. package/docs/.i18n/glossary.ja-JP.json +14 -0
  13. package/docs/.i18n/glossary.zh-CN.json +302 -0
  14. package/docs/.i18n/ja-JP.tm.jsonl +0 -0
  15. package/docs/assets/install-script.svg +1 -0
  16. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  17. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  18. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  19. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  20. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  21. package/docs/assets/pixel-lobster.svg +60 -0
  22. package/docs/assets/quantumclaw-logo-text-dark.png +0 -0
  23. package/docs/assets/quantumclaw-logo-text-dark.svg +418 -0
  24. package/docs/assets/quantumclaw-logo-text.png +0 -0
  25. package/docs/assets/quantumclaw-logo-text.svg +418 -0
  26. package/docs/assets/showcase/agents-ui.jpg +0 -0
  27. package/docs/assets/showcase/bambu-cli.png +0 -0
  28. package/docs/assets/showcase/codexmonitor.png +0 -0
  29. package/docs/assets/showcase/gohome-grafana.png +0 -0
  30. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  31. package/docs/assets/showcase/oura-health.png +0 -0
  32. package/docs/assets/showcase/padel-cli.svg +11 -0
  33. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  34. package/docs/assets/showcase/papla-tts.jpg +0 -0
  35. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  36. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  37. package/docs/assets/showcase/roborock-status.svg +13 -0
  38. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  39. package/docs/assets/showcase/snag.png +0 -0
  40. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  41. package/docs/assets/showcase/wienerlinien.png +0 -0
  42. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  43. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  44. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  45. package/docs/assets/sponsors/blacksmith.svg +14 -0
  46. package/docs/assets/sponsors/convex.svg +16 -0
  47. package/docs/assets/sponsors/openai.svg +3 -0
  48. package/docs/assets/sponsors/vercel.svg +5 -0
  49. package/docs/auth-credential-semantics.md +53 -0
  50. package/docs/automation/auth-monitoring.md +44 -0
  51. package/docs/automation/cron-jobs.md +727 -0
  52. package/docs/automation/cron-vs-heartbeat.md +286 -0
  53. package/docs/automation/gmail-pubsub.md +256 -0
  54. package/docs/automation/hooks.md +1056 -0
  55. package/docs/automation/poll.md +86 -0
  56. package/docs/automation/standing-orders.md +251 -0
  57. package/docs/automation/troubleshooting.md +122 -0
  58. package/docs/automation/webhook.md +217 -0
  59. package/docs/brave-search.md +93 -0
  60. package/docs/channels/bluebubbles.md +347 -0
  61. package/docs/channels/broadcast-groups.md +442 -0
  62. package/docs/channels/channel-routing.md +139 -0
  63. package/docs/channels/discord.md +1229 -0
  64. package/docs/channels/feishu.md +747 -0
  65. package/docs/channels/googlechat.md +261 -0
  66. package/docs/channels/group-messages.md +84 -0
  67. package/docs/channels/groups.md +379 -0
  68. package/docs/channels/imessage.md +367 -0
  69. package/docs/channels/index.md +47 -0
  70. package/docs/channels/irc.md +242 -0
  71. package/docs/channels/line.md +194 -0
  72. package/docs/channels/location.md +56 -0
  73. package/docs/channels/matrix.md +677 -0
  74. package/docs/channels/mattermost.md +427 -0
  75. package/docs/channels/msteams.md +780 -0
  76. package/docs/channels/nextcloud-talk.md +138 -0
  77. package/docs/channels/nostr.md +249 -0
  78. package/docs/channels/pairing.md +114 -0
  79. package/docs/channels/signal.md +329 -0
  80. package/docs/channels/slack.md +603 -0
  81. package/docs/channels/synology-chat.md +134 -0
  82. package/docs/channels/telegram.md +987 -0
  83. package/docs/channels/tlon.md +276 -0
  84. package/docs/channels/troubleshooting.md +118 -0
  85. package/docs/channels/twitch.md +379 -0
  86. package/docs/channels/whatsapp.md +460 -0
  87. package/docs/channels/zalo.md +243 -0
  88. package/docs/channels/zalouser.md +181 -0
  89. package/docs/ci.md +55 -0
  90. package/docs/cli/acp.md +288 -0
  91. package/docs/cli/agent.md +29 -0
  92. package/docs/cli/agents.md +123 -0
  93. package/docs/cli/approvals.md +50 -0
  94. package/docs/cli/backup.md +76 -0
  95. package/docs/cli/browser.md +106 -0
  96. package/docs/cli/channels.md +102 -0
  97. package/docs/cli/clawbot.md +21 -0
  98. package/docs/cli/completion.md +35 -0
  99. package/docs/cli/config.md +295 -0
  100. package/docs/cli/configure.md +36 -0
  101. package/docs/cli/cron.md +77 -0
  102. package/docs/cli/daemon.md +53 -0
  103. package/docs/cli/dashboard.md +22 -0
  104. package/docs/cli/devices.md +139 -0
  105. package/docs/cli/directory.md +63 -0
  106. package/docs/cli/dns.md +23 -0
  107. package/docs/cli/docs.md +15 -0
  108. package/docs/cli/doctor.md +48 -0
  109. package/docs/cli/gateway.md +235 -0
  110. package/docs/cli/health.md +21 -0
  111. package/docs/cli/hooks.md +329 -0
  112. package/docs/cli/index.md +1150 -0
  113. package/docs/cli/logs.md +28 -0
  114. package/docs/cli/memory.md +66 -0
  115. package/docs/cli/message.md +278 -0
  116. package/docs/cli/models.md +81 -0
  117. package/docs/cli/node.md +127 -0
  118. package/docs/cli/nodes.md +75 -0
  119. package/docs/cli/onboard.md +157 -0
  120. package/docs/cli/pairing.md +32 -0
  121. package/docs/cli/plugins.md +210 -0
  122. package/docs/cli/qr.md +46 -0
  123. package/docs/cli/reset.md +20 -0
  124. package/docs/cli/sandbox.md +197 -0
  125. package/docs/cli/secrets.md +188 -0
  126. package/docs/cli/security.md +79 -0
  127. package/docs/cli/sessions.md +110 -0
  128. package/docs/cli/setup.md +29 -0
  129. package/docs/cli/skills.md +36 -0
  130. package/docs/cli/status.md +30 -0
  131. package/docs/cli/system.md +60 -0
  132. package/docs/cli/tui.md +30 -0
  133. package/docs/cli/uninstall.md +20 -0
  134. package/docs/cli/update.md +103 -0
  135. package/docs/cli/voicecall.md +34 -0
  136. package/docs/cli/webhooks.md +25 -0
  137. package/docs/concepts/agent-loop.md +148 -0
  138. package/docs/concepts/agent-workspace.md +236 -0
  139. package/docs/concepts/agent.md +122 -0
  140. package/docs/concepts/architecture.md +137 -0
  141. package/docs/concepts/compaction.md +123 -0
  142. package/docs/concepts/context-engine.md +268 -0
  143. package/docs/concepts/context.md +172 -0
  144. package/docs/concepts/delegate-architecture.md +296 -0
  145. package/docs/concepts/features.md +73 -0
  146. package/docs/concepts/markdown-formatting.md +130 -0
  147. package/docs/concepts/memory.md +108 -0
  148. package/docs/concepts/messages.md +154 -0
  149. package/docs/concepts/model-failover.md +152 -0
  150. package/docs/concepts/model-providers.md +607 -0
  151. package/docs/concepts/models.md +225 -0
  152. package/docs/concepts/multi-agent.md +552 -0
  153. package/docs/concepts/oauth.md +158 -0
  154. package/docs/concepts/presence.md +102 -0
  155. package/docs/concepts/queue.md +89 -0
  156. package/docs/concepts/retry.md +69 -0
  157. package/docs/concepts/session-pruning.md +121 -0
  158. package/docs/concepts/session-tool.md +242 -0
  159. package/docs/concepts/session.md +310 -0
  160. package/docs/concepts/streaming.md +155 -0
  161. package/docs/concepts/system-prompt.md +132 -0
  162. package/docs/concepts/timezone.md +91 -0
  163. package/docs/concepts/typebox.md +291 -0
  164. package/docs/concepts/typing-indicators.md +68 -0
  165. package/docs/concepts/usage-tracking.md +35 -0
  166. package/docs/date-time.md +128 -0
  167. package/docs/debug/node-issue.md +85 -0
  168. package/docs/diagnostics/flags.md +91 -0
  169. package/docs/docs.json +2078 -0
  170. package/docs/gateway/authentication.md +179 -0
  171. package/docs/gateway/background-process.md +97 -0
  172. package/docs/gateway/bonjour.md +177 -0
  173. package/docs/gateway/bridge-protocol.md +91 -0
  174. package/docs/gateway/cli-backends.md +225 -0
  175. package/docs/gateway/configuration-examples.md +651 -0
  176. package/docs/gateway/configuration-reference.md +3123 -0
  177. package/docs/gateway/configuration.md +633 -0
  178. package/docs/gateway/discovery.md +123 -0
  179. package/docs/gateway/doctor.md +362 -0
  180. package/docs/gateway/gateway-lock.md +34 -0
  181. package/docs/gateway/health.md +44 -0
  182. package/docs/gateway/heartbeat.md +393 -0
  183. package/docs/gateway/index.md +261 -0
  184. package/docs/gateway/local-models.md +152 -0
  185. package/docs/gateway/logging.md +113 -0
  186. package/docs/gateway/multiple-gateways.md +112 -0
  187. package/docs/gateway/network-model.md +22 -0
  188. package/docs/gateway/openai-http-api.md +132 -0
  189. package/docs/gateway/openresponses-http-api.md +295 -0
  190. package/docs/gateway/openshell.md +307 -0
  191. package/docs/gateway/pairing.md +99 -0
  192. package/docs/gateway/protocol.md +267 -0
  193. package/docs/gateway/remote-gateway-readme.md +158 -0
  194. package/docs/gateway/remote.md +153 -0
  195. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +134 -0
  196. package/docs/gateway/sandboxing.md +469 -0
  197. package/docs/gateway/secrets-plan-contract.md +116 -0
  198. package/docs/gateway/secrets.md +503 -0
  199. package/docs/gateway/security/index.md +1220 -0
  200. package/docs/gateway/tailscale.md +132 -0
  201. package/docs/gateway/tools-invoke-http-api.md +118 -0
  202. package/docs/gateway/troubleshooting.md +378 -0
  203. package/docs/gateway/trusted-proxy-auth.md +330 -0
  204. package/docs/help/debugging.md +168 -0
  205. package/docs/help/environment.md +163 -0
  206. package/docs/help/faq.md +2997 -0
  207. package/docs/help/index.md +28 -0
  208. package/docs/help/scripts.md +28 -0
  209. package/docs/help/testing.md +526 -0
  210. package/docs/help/troubleshooting.md +297 -0
  211. package/docs/images/configure-model-picker-unsearchable.png +0 -0
  212. package/docs/images/feishu-step2-create-app.png +0 -0
  213. package/docs/images/feishu-step3-credentials.png +0 -0
  214. package/docs/images/feishu-step4-permissions.png +0 -0
  215. package/docs/images/feishu-step5-bot-capability.png +0 -0
  216. package/docs/images/feishu-step6-event-subscription.png +0 -0
  217. package/docs/images/feishu-verification-token.png +0 -0
  218. package/docs/images/groups-flow.svg +52 -0
  219. package/docs/images/mobile-ui-screenshot.png +0 -0
  220. package/docs/index.md +196 -0
  221. package/docs/install/ansible.md +230 -0
  222. package/docs/install/azure.md +311 -0
  223. package/docs/install/bun.md +55 -0
  224. package/docs/install/development-channels.md +120 -0
  225. package/docs/install/digitalocean.md +129 -0
  226. package/docs/install/docker-vm-runtime.md +142 -0
  227. package/docs/install/docker.md +375 -0
  228. package/docs/install/exe-dev.md +126 -0
  229. package/docs/install/fly.md +501 -0
  230. package/docs/install/gcp.md +402 -0
  231. package/docs/install/hetzner.md +251 -0
  232. package/docs/install/index.md +183 -0
  233. package/docs/install/installer.md +415 -0
  234. package/docs/install/kubernetes.md +191 -0
  235. package/docs/install/macos-vm.md +281 -0
  236. package/docs/install/migrating-matrix.md +346 -0
  237. package/docs/install/migrating.md +110 -0
  238. package/docs/install/nix.md +89 -0
  239. package/docs/install/node.md +138 -0
  240. package/docs/install/northflank.mdx +54 -0
  241. package/docs/install/oracle.md +156 -0
  242. package/docs/install/podman.md +133 -0
  243. package/docs/install/railway.mdx +100 -0
  244. package/docs/install/raspberry-pi.md +159 -0
  245. package/docs/install/render.mdx +169 -0
  246. package/docs/install/uninstall.md +128 -0
  247. package/docs/install/updating.md +128 -0
  248. package/docs/ja-JP/index.md +186 -0
  249. package/docs/ja-JP/start/getting-started.md +125 -0
  250. package/docs/ja-JP/start/wizard.md +77 -0
  251. package/docs/logging.md +352 -0
  252. package/docs/nav-tabs-underline.js +100 -0
  253. package/docs/network.md +54 -0
  254. package/docs/nodes/audio.md +187 -0
  255. package/docs/nodes/camera.md +162 -0
  256. package/docs/nodes/images.md +72 -0
  257. package/docs/nodes/index.md +393 -0
  258. package/docs/nodes/location-command.md +98 -0
  259. package/docs/nodes/media-understanding.md +394 -0
  260. package/docs/nodes/talk.md +92 -0
  261. package/docs/nodes/troubleshooting.md +114 -0
  262. package/docs/nodes/voicewake.md +66 -0
  263. package/docs/perplexity.md +174 -0
  264. package/docs/pi-dev.md +80 -0
  265. package/docs/pi.md +567 -0
  266. package/docs/platforms/android.md +168 -0
  267. package/docs/platforms/digitalocean.md +266 -0
  268. package/docs/platforms/index.md +54 -0
  269. package/docs/platforms/ios.md +220 -0
  270. package/docs/platforms/linux.md +94 -0
  271. package/docs/platforms/mac/bundled-gateway.md +73 -0
  272. package/docs/platforms/mac/canvas.md +125 -0
  273. package/docs/platforms/mac/child-process.md +69 -0
  274. package/docs/platforms/mac/dev-setup.md +104 -0
  275. package/docs/platforms/mac/health.md +34 -0
  276. package/docs/platforms/mac/icon.md +31 -0
  277. package/docs/platforms/mac/logging.md +57 -0
  278. package/docs/platforms/mac/menu-bar.md +81 -0
  279. package/docs/platforms/mac/peekaboo.md +65 -0
  280. package/docs/platforms/mac/permissions.md +50 -0
  281. package/docs/platforms/mac/remote.md +84 -0
  282. package/docs/platforms/mac/signing.md +47 -0
  283. package/docs/platforms/mac/skills.md +33 -0
  284. package/docs/platforms/mac/voice-overlay.md +60 -0
  285. package/docs/platforms/mac/voicewake.md +67 -0
  286. package/docs/platforms/mac/webchat.md +43 -0
  287. package/docs/platforms/mac/xpc.md +61 -0
  288. package/docs/platforms/macos.md +226 -0
  289. package/docs/platforms/oracle.md +303 -0
  290. package/docs/platforms/raspberry-pi.md +412 -0
  291. package/docs/platforms/windows.md +241 -0
  292. package/docs/plugins/agent-tools.md +10 -0
  293. package/docs/plugins/architecture.md +1366 -0
  294. package/docs/plugins/building-extensions.md +10 -0
  295. package/docs/plugins/building-plugins.md +239 -0
  296. package/docs/plugins/bundles.md +181 -0
  297. package/docs/plugins/community.md +145 -0
  298. package/docs/plugins/manifest.md +241 -0
  299. package/docs/plugins/sdk-channel-plugins.md +370 -0
  300. package/docs/plugins/sdk-entrypoints.md +161 -0
  301. package/docs/plugins/sdk-migration.md +172 -0
  302. package/docs/plugins/sdk-overview.md +196 -0
  303. package/docs/plugins/sdk-provider-plugins.md +370 -0
  304. package/docs/plugins/sdk-runtime.md +345 -0
  305. package/docs/plugins/sdk-setup.md +331 -0
  306. package/docs/plugins/sdk-testing.md +263 -0
  307. package/docs/plugins/voice-call.md +380 -0
  308. package/docs/plugins/zalouser.md +77 -0
  309. package/docs/prose.md +134 -0
  310. package/docs/providers/anthropic.md +259 -0
  311. package/docs/providers/bedrock.md +176 -0
  312. package/docs/providers/claude-max-api-proxy.md +154 -0
  313. package/docs/providers/cloudflare-ai-gateway.md +71 -0
  314. package/docs/providers/deepgram.md +93 -0
  315. package/docs/providers/github-copilot.md +72 -0
  316. package/docs/providers/glm.md +43 -0
  317. package/docs/providers/google.md +78 -0
  318. package/docs/providers/groq.md +96 -0
  319. package/docs/providers/huggingface.md +209 -0
  320. package/docs/providers/index.md +69 -0
  321. package/docs/providers/kilocode.md +74 -0
  322. package/docs/providers/litellm.md +154 -0
  323. package/docs/providers/minimax.md +224 -0
  324. package/docs/providers/mistral.md +54 -0
  325. package/docs/providers/models.md +45 -0
  326. package/docs/providers/modelstudio.md +66 -0
  327. package/docs/providers/moonshot.md +175 -0
  328. package/docs/providers/nvidia.md +55 -0
  329. package/docs/providers/ollama.md +352 -0
  330. package/docs/providers/openai.md +303 -0
  331. package/docs/providers/opencode-go.md +45 -0
  332. package/docs/providers/opencode.md +64 -0
  333. package/docs/providers/openrouter.md +37 -0
  334. package/docs/providers/perplexity-provider.md +62 -0
  335. package/docs/providers/qianfan.md +38 -0
  336. package/docs/providers/qwen.md +53 -0
  337. package/docs/providers/sglang.md +104 -0
  338. package/docs/providers/synthetic.md +99 -0
  339. package/docs/providers/together.md +66 -0
  340. package/docs/providers/venice.md +282 -0
  341. package/docs/providers/vercel-ai-gateway.md +60 -0
  342. package/docs/providers/vllm.md +92 -0
  343. package/docs/providers/volcengine.md +74 -0
  344. package/docs/providers/xai.md +60 -0
  345. package/docs/providers/xiaomi.md +86 -0
  346. package/docs/providers/zai.md +46 -0
  347. package/docs/reference/AGENTS.default.md +126 -0
  348. package/docs/reference/RELEASING.md +42 -0
  349. package/docs/reference/api-usage-costs.md +144 -0
  350. package/docs/reference/credits.md +30 -0
  351. package/docs/reference/device-models.md +47 -0
  352. package/docs/reference/memory-config.md +711 -0
  353. package/docs/reference/prompt-caching.md +185 -0
  354. package/docs/reference/rpc.md +43 -0
  355. package/docs/reference/secretref-credential-surface.md +140 -0
  356. package/docs/reference/secretref-user-supplied-credentials-matrix.json +563 -0
  357. package/docs/reference/session-management-compaction.md +324 -0
  358. package/docs/reference/templates/AGENTS.dev.md +83 -0
  359. package/docs/reference/templates/AGENTS.md +219 -0
  360. package/docs/reference/templates/BOOT.md +11 -0
  361. package/docs/reference/templates/BOOTSTRAP.md +62 -0
  362. package/docs/reference/templates/HEARTBEAT.md +14 -0
  363. package/docs/reference/templates/IDENTITY.dev.md +47 -0
  364. package/docs/reference/templates/IDENTITY.md +29 -0
  365. package/docs/reference/templates/SOUL.dev.md +76 -0
  366. package/docs/reference/templates/SOUL.md +43 -0
  367. package/docs/reference/templates/TOOLS.dev.md +24 -0
  368. package/docs/reference/templates/TOOLS.md +47 -0
  369. package/docs/reference/templates/USER.dev.md +18 -0
  370. package/docs/reference/templates/USER.md +23 -0
  371. package/docs/reference/test.md +90 -0
  372. package/docs/reference/token-use.md +175 -0
  373. package/docs/reference/transcript-hygiene.md +151 -0
  374. package/docs/reference/wizard.md +235 -0
  375. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +98 -0
  376. package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
  377. package/docs/security/formal-verification.md +167 -0
  378. package/docs/start/bootstrapping.md +41 -0
  379. package/docs/start/docs-directory.md +66 -0
  380. package/docs/start/getting-started.md +116 -0
  381. package/docs/start/hubs.md +198 -0
  382. package/docs/start/lore.md +219 -0
  383. package/docs/start/onboarding-overview.md +67 -0
  384. package/docs/start/onboarding.md +91 -0
  385. package/docs/start/openclaw.md +221 -0
  386. package/docs/start/quickstart.md +22 -0
  387. package/docs/start/setup.md +164 -0
  388. package/docs/start/showcase.md +418 -0
  389. package/docs/start/wizard-cli-automation.md +215 -0
  390. package/docs/start/wizard-cli-reference.md +299 -0
  391. package/docs/start/wizard.md +125 -0
  392. package/docs/style.css +37 -0
  393. package/docs/tools/acp-agents.md +623 -0
  394. package/docs/tools/agent-send.md +100 -0
  395. package/docs/tools/apply-patch.md +51 -0
  396. package/docs/tools/brave-search.md +93 -0
  397. package/docs/tools/browser-linux-troubleshooting.md +138 -0
  398. package/docs/tools/browser-login.md +73 -0
  399. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +211 -0
  400. package/docs/tools/browser.md +731 -0
  401. package/docs/tools/btw.md +142 -0
  402. package/docs/tools/capability-cookbook.md +119 -0
  403. package/docs/tools/clawhub.md +298 -0
  404. package/docs/tools/creating-skills.md +117 -0
  405. package/docs/tools/diffs.md +386 -0
  406. package/docs/tools/elevated.md +114 -0
  407. package/docs/tools/exec-approvals.md +430 -0
  408. package/docs/tools/exec.md +207 -0
  409. package/docs/tools/firecrawl.md +140 -0
  410. package/docs/tools/index.md +137 -0
  411. package/docs/tools/llm-task.md +119 -0
  412. package/docs/tools/lobster.md +340 -0
  413. package/docs/tools/loop-detection.md +100 -0
  414. package/docs/tools/multi-agent-sandbox-tools.md +364 -0
  415. package/docs/tools/pdf.md +156 -0
  416. package/docs/tools/perplexity-search.md +174 -0
  417. package/docs/tools/plugin.md +255 -0
  418. package/docs/tools/reactions.md +64 -0
  419. package/docs/tools/skills-config.md +86 -0
  420. package/docs/tools/skills.md +309 -0
  421. package/docs/tools/slash-commands.md +294 -0
  422. package/docs/tools/subagents.md +295 -0
  423. package/docs/tools/tavily.md +125 -0
  424. package/docs/tools/thinking.md +96 -0
  425. package/docs/tools/tts.md +406 -0
  426. package/docs/tools/web.md +516 -0
  427. package/docs/tts.md +406 -0
  428. package/docs/vps.md +112 -0
  429. package/docs/web/control-ui.md +275 -0
  430. package/docs/web/dashboard.md +54 -0
  431. package/docs/web/index.md +120 -0
  432. package/docs/web/tui.md +170 -0
  433. package/docs/web/webchat.md +61 -0
  434. package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
  435. package/docs/whatsapp-openclaw.jpg +0 -0
  436. package/docs/zh-CN/AGENTS.md +61 -0
  437. package/docs/zh-CN/automation/auth-monitoring.md +47 -0
  438. package/docs/zh-CN/automation/cron-jobs.md +435 -0
  439. package/docs/zh-CN/automation/cron-vs-heartbeat.md +286 -0
  440. package/docs/zh-CN/automation/gmail-pubsub.md +249 -0
  441. package/docs/zh-CN/automation/hooks.md +1051 -0
  442. package/docs/zh-CN/automation/poll.md +76 -0
  443. package/docs/zh-CN/automation/troubleshooting.md +8 -0
  444. package/docs/zh-CN/automation/webhook.md +163 -0
  445. package/docs/zh-CN/brave-search.md +60 -0
  446. package/docs/zh-CN/channels/bluebubbles.md +354 -0
  447. package/docs/zh-CN/channels/broadcast-groups.md +449 -0
  448. package/docs/zh-CN/channels/channel-routing.md +117 -0
  449. package/docs/zh-CN/channels/discord.md +468 -0
  450. package/docs/zh-CN/channels/feishu.md +728 -0
  451. package/docs/zh-CN/channels/googlechat.md +257 -0
  452. package/docs/zh-CN/channels/grammy.md +38 -0
  453. package/docs/zh-CN/channels/group-messages.md +91 -0
  454. package/docs/zh-CN/channels/groups.md +379 -0
  455. package/docs/zh-CN/channels/imessage.md +302 -0
  456. package/docs/zh-CN/channels/index.md +53 -0
  457. package/docs/zh-CN/channels/line.md +180 -0
  458. package/docs/zh-CN/channels/location.md +63 -0
  459. package/docs/zh-CN/channels/matrix.md +221 -0
  460. package/docs/zh-CN/channels/mattermost.md +144 -0
  461. package/docs/zh-CN/channels/msteams.md +775 -0
  462. package/docs/zh-CN/channels/nextcloud-talk.md +142 -0
  463. package/docs/zh-CN/channels/nostr.md +249 -0
  464. package/docs/zh-CN/channels/pairing.md +89 -0
  465. package/docs/zh-CN/channels/signal.md +209 -0
  466. package/docs/zh-CN/channels/slack.md +531 -0
  467. package/docs/zh-CN/channels/synology-chat.md +138 -0
  468. package/docs/zh-CN/channels/telegram.md +751 -0
  469. package/docs/zh-CN/channels/tlon.md +136 -0
  470. package/docs/zh-CN/channels/troubleshooting.md +36 -0
  471. package/docs/zh-CN/channels/twitch.md +385 -0
  472. package/docs/zh-CN/channels/whatsapp.md +411 -0
  473. package/docs/zh-CN/channels/zalo.md +196 -0
  474. package/docs/zh-CN/channels/zalouser.md +147 -0
  475. package/docs/zh-CN/cli/acp.md +173 -0
  476. package/docs/zh-CN/cli/agent.md +30 -0
  477. package/docs/zh-CN/cli/agents.md +82 -0
  478. package/docs/zh-CN/cli/approvals.md +57 -0
  479. package/docs/zh-CN/cli/browser.md +114 -0
  480. package/docs/zh-CN/cli/channels.md +86 -0
  481. package/docs/zh-CN/cli/config.md +57 -0
  482. package/docs/zh-CN/cli/configure.md +38 -0
  483. package/docs/zh-CN/cli/cron.md +43 -0
  484. package/docs/zh-CN/cli/dashboard.md +23 -0
  485. package/docs/zh-CN/cli/devices.md +74 -0
  486. package/docs/zh-CN/cli/directory.md +70 -0
  487. package/docs/zh-CN/cli/dns.md +30 -0
  488. package/docs/zh-CN/cli/docs.md +22 -0
  489. package/docs/zh-CN/cli/doctor.md +48 -0
  490. package/docs/zh-CN/cli/gateway.md +206 -0
  491. package/docs/zh-CN/cli/health.md +28 -0
  492. package/docs/zh-CN/cli/hooks.md +298 -0
  493. package/docs/zh-CN/cli/index.md +1143 -0
  494. package/docs/zh-CN/cli/logs.md +31 -0
  495. package/docs/zh-CN/cli/memory.md +52 -0
  496. package/docs/zh-CN/cli/message.md +246 -0
  497. package/docs/zh-CN/cli/models.md +85 -0
  498. package/docs/zh-CN/cli/node.md +115 -0
  499. package/docs/zh-CN/cli/nodes.md +80 -0
  500. package/docs/zh-CN/cli/onboard.md +164 -0
  501. package/docs/zh-CN/cli/pairing.md +28 -0
  502. package/docs/zh-CN/cli/plugins.md +66 -0
  503. package/docs/zh-CN/cli/reset.md +24 -0
  504. package/docs/zh-CN/cli/sandbox.md +158 -0
  505. package/docs/zh-CN/cli/security.md +33 -0
  506. package/docs/zh-CN/cli/sessions.md +23 -0
  507. package/docs/zh-CN/cli/setup.md +36 -0
  508. package/docs/zh-CN/cli/skills.md +33 -0
  509. package/docs/zh-CN/cli/status.md +33 -0
  510. package/docs/zh-CN/cli/system.md +63 -0
  511. package/docs/zh-CN/cli/tui.md +30 -0
  512. package/docs/zh-CN/cli/uninstall.md +24 -0
  513. package/docs/zh-CN/cli/update.md +101 -0
  514. package/docs/zh-CN/cli/voicecall.md +41 -0
  515. package/docs/zh-CN/cli/webhooks.md +32 -0
  516. package/docs/zh-CN/concepts/agent-loop.md +146 -0
  517. package/docs/zh-CN/concepts/agent-workspace.md +219 -0
  518. package/docs/zh-CN/concepts/agent.md +115 -0
  519. package/docs/zh-CN/concepts/architecture.md +123 -0
  520. package/docs/zh-CN/concepts/compaction.md +67 -0
  521. package/docs/zh-CN/concepts/context.md +168 -0
  522. package/docs/zh-CN/concepts/features.md +59 -0
  523. package/docs/zh-CN/concepts/markdown-formatting.md +117 -0
  524. package/docs/zh-CN/concepts/memory.md +412 -0
  525. package/docs/zh-CN/concepts/messages.md +141 -0
  526. package/docs/zh-CN/concepts/model-failover.md +145 -0
  527. package/docs/zh-CN/concepts/model-providers.md +606 -0
  528. package/docs/zh-CN/concepts/models.md +225 -0
  529. package/docs/zh-CN/concepts/multi-agent.md +372 -0
  530. package/docs/zh-CN/concepts/oauth.md +164 -0
  531. package/docs/zh-CN/concepts/presence.md +99 -0
  532. package/docs/zh-CN/concepts/queue.md +94 -0
  533. package/docs/zh-CN/concepts/retry.md +76 -0
  534. package/docs/zh-CN/concepts/session-pruning.md +129 -0
  535. package/docs/zh-CN/concepts/session-tool.md +200 -0
  536. package/docs/zh-CN/concepts/session.md +166 -0
  537. package/docs/zh-CN/concepts/streaming.md +133 -0
  538. package/docs/zh-CN/concepts/system-prompt.md +101 -0
  539. package/docs/zh-CN/concepts/timezone.md +96 -0
  540. package/docs/zh-CN/concepts/typebox.md +284 -0
  541. package/docs/zh-CN/concepts/typing-indicators.md +74 -0
  542. package/docs/zh-CN/concepts/usage-tracking.md +42 -0
  543. package/docs/zh-CN/date-time.md +129 -0
  544. package/docs/zh-CN/debug/node-issue.md +90 -0
  545. package/docs/zh-CN/diagnostics/flags.md +98 -0
  546. package/docs/zh-CN/gateway/authentication.md +184 -0
  547. package/docs/zh-CN/gateway/background-process.md +100 -0
  548. package/docs/zh-CN/gateway/bonjour.md +174 -0
  549. package/docs/zh-CN/gateway/bridge-protocol.md +86 -0
  550. package/docs/zh-CN/gateway/cli-backends.md +213 -0
  551. package/docs/zh-CN/gateway/configuration-examples.md +587 -0
  552. package/docs/zh-CN/gateway/configuration-reference.md +3103 -0
  553. package/docs/zh-CN/gateway/configuration.md +640 -0
  554. package/docs/zh-CN/gateway/discovery.md +123 -0
  555. package/docs/zh-CN/gateway/doctor.md +238 -0
  556. package/docs/zh-CN/gateway/gateway-lock.md +41 -0
  557. package/docs/zh-CN/gateway/health.md +42 -0
  558. package/docs/zh-CN/gateway/heartbeat.md +274 -0
  559. package/docs/zh-CN/gateway/index.md +335 -0
  560. package/docs/zh-CN/gateway/local-models.md +159 -0
  561. package/docs/zh-CN/gateway/logging.md +114 -0
  562. package/docs/zh-CN/gateway/multiple-gateways.md +119 -0
  563. package/docs/zh-CN/gateway/network-model.md +23 -0
  564. package/docs/zh-CN/gateway/openai-http-api.md +125 -0
  565. package/docs/zh-CN/gateway/openresponses-http-api.md +317 -0
  566. package/docs/zh-CN/gateway/pairing.md +99 -0
  567. package/docs/zh-CN/gateway/protocol.md +220 -0
  568. package/docs/zh-CN/gateway/remote-gateway-readme.md +164 -0
  569. package/docs/zh-CN/gateway/remote.md +133 -0
  570. package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +135 -0
  571. package/docs/zh-CN/gateway/sandboxing.md +188 -0
  572. package/docs/zh-CN/gateway/security/index.md +777 -0
  573. package/docs/zh-CN/gateway/tailscale.md +124 -0
  574. package/docs/zh-CN/gateway/tools-invoke-http-api.md +92 -0
  575. package/docs/zh-CN/gateway/troubleshooting.md +771 -0
  576. package/docs/zh-CN/help/debugging.md +160 -0
  577. package/docs/zh-CN/help/environment.md +88 -0
  578. package/docs/zh-CN/help/faq.md +2640 -0
  579. package/docs/zh-CN/help/index.md +28 -0
  580. package/docs/zh-CN/help/scripts.md +35 -0
  581. package/docs/zh-CN/help/testing.md +375 -0
  582. package/docs/zh-CN/help/troubleshooting.md +104 -0
  583. package/docs/zh-CN/index.md +186 -0
  584. package/docs/zh-CN/install/ansible.md +215 -0
  585. package/docs/zh-CN/install/bun.md +65 -0
  586. package/docs/zh-CN/install/development-channels.md +81 -0
  587. package/docs/zh-CN/install/docker.md +532 -0
  588. package/docs/zh-CN/install/exe-dev.md +133 -0
  589. package/docs/zh-CN/install/fly.md +490 -0
  590. package/docs/zh-CN/install/gcp.md +510 -0
  591. package/docs/zh-CN/install/hetzner.md +337 -0
  592. package/docs/zh-CN/install/index.md +235 -0
  593. package/docs/zh-CN/install/installer.md +422 -0
  594. package/docs/zh-CN/install/macos-vm.md +288 -0
  595. package/docs/zh-CN/install/migrating.md +199 -0
  596. package/docs/zh-CN/install/nix.md +99 -0
  597. package/docs/zh-CN/install/node.md +8 -0
  598. package/docs/zh-CN/install/northflank.mdx +60 -0
  599. package/docs/zh-CN/install/railway.mdx +106 -0
  600. package/docs/zh-CN/install/render.mdx +169 -0
  601. package/docs/zh-CN/install/uninstall.md +135 -0
  602. package/docs/zh-CN/install/updating.md +233 -0
  603. package/docs/zh-CN/logging.md +329 -0
  604. package/docs/zh-CN/network.md +59 -0
  605. package/docs/zh-CN/nodes/audio.md +120 -0
  606. package/docs/zh-CN/nodes/camera.md +162 -0
  607. package/docs/zh-CN/nodes/images.md +79 -0
  608. package/docs/zh-CN/nodes/index.md +348 -0
  609. package/docs/zh-CN/nodes/location-command.md +120 -0
  610. package/docs/zh-CN/nodes/media-understanding.md +380 -0
  611. package/docs/zh-CN/nodes/talk.md +97 -0
  612. package/docs/zh-CN/nodes/troubleshooting.md +8 -0
  613. package/docs/zh-CN/nodes/voicewake.md +72 -0
  614. package/docs/zh-CN/perplexity.md +102 -0
  615. package/docs/zh-CN/pi-dev.md +77 -0
  616. package/docs/zh-CN/pi.md +619 -0
  617. package/docs/zh-CN/platforms/android.md +155 -0
  618. package/docs/zh-CN/platforms/digitalocean.md +273 -0
  619. package/docs/zh-CN/platforms/index.md +60 -0
  620. package/docs/zh-CN/platforms/ios.md +114 -0
  621. package/docs/zh-CN/platforms/linux.md +100 -0
  622. package/docs/zh-CN/platforms/mac/bundled-gateway.md +75 -0
  623. package/docs/zh-CN/platforms/mac/canvas.md +128 -0
  624. package/docs/zh-CN/platforms/mac/child-process.md +73 -0
  625. package/docs/zh-CN/platforms/mac/dev-setup.md +109 -0
  626. package/docs/zh-CN/platforms/mac/health.md +41 -0
  627. package/docs/zh-CN/platforms/mac/icon.md +38 -0
  628. package/docs/zh-CN/platforms/mac/logging.md +64 -0
  629. package/docs/zh-CN/platforms/mac/menu-bar.md +88 -0
  630. package/docs/zh-CN/platforms/mac/peekaboo.md +62 -0
  631. package/docs/zh-CN/platforms/mac/permissions.md +46 -0
  632. package/docs/zh-CN/platforms/mac/remote.md +90 -0
  633. package/docs/zh-CN/platforms/mac/signing.md +54 -0
  634. package/docs/zh-CN/platforms/mac/skills.md +40 -0
  635. package/docs/zh-CN/platforms/mac/voice-overlay.md +67 -0
  636. package/docs/zh-CN/platforms/mac/voicewake.md +74 -0
  637. package/docs/zh-CN/platforms/mac/webchat.md +43 -0
  638. package/docs/zh-CN/platforms/mac/xpc.md +68 -0
  639. package/docs/zh-CN/platforms/macos.md +193 -0
  640. package/docs/zh-CN/platforms/oracle.md +310 -0
  641. package/docs/zh-CN/platforms/raspberry-pi.md +416 -0
  642. package/docs/zh-CN/platforms/windows.md +247 -0
  643. package/docs/zh-CN/plugins/agent-tools.md +99 -0
  644. package/docs/zh-CN/plugins/manifest.md +68 -0
  645. package/docs/zh-CN/plugins/voice-call.md +250 -0
  646. package/docs/zh-CN/plugins/zalouser.md +88 -0
  647. package/docs/zh-CN/prose.md +141 -0
  648. package/docs/zh-CN/providers/anthropic.md +265 -0
  649. package/docs/zh-CN/providers/bedrock.md +170 -0
  650. package/docs/zh-CN/providers/claude-max-api-proxy.md +155 -0
  651. package/docs/zh-CN/providers/cloudflare-ai-gateway.md +78 -0
  652. package/docs/zh-CN/providers/deepgram.md +97 -0
  653. package/docs/zh-CN/providers/github-copilot.md +67 -0
  654. package/docs/zh-CN/providers/glm.md +50 -0
  655. package/docs/zh-CN/providers/huggingface.md +216 -0
  656. package/docs/zh-CN/providers/index.md +69 -0
  657. package/docs/zh-CN/providers/kilocode.md +80 -0
  658. package/docs/zh-CN/providers/litellm.md +160 -0
  659. package/docs/zh-CN/providers/minimax.md +222 -0
  660. package/docs/zh-CN/providers/mistral.md +61 -0
  661. package/docs/zh-CN/providers/models.md +51 -0
  662. package/docs/zh-CN/providers/moonshot.md +182 -0
  663. package/docs/zh-CN/providers/nvidia.md +62 -0
  664. package/docs/zh-CN/providers/ollama.md +359 -0
  665. package/docs/zh-CN/providers/openai.md +308 -0
  666. package/docs/zh-CN/providers/opencode-go.md +52 -0
  667. package/docs/zh-CN/providers/opencode.md +71 -0
  668. package/docs/zh-CN/providers/openrouter.md +44 -0
  669. package/docs/zh-CN/providers/qianfan.md +45 -0
  670. package/docs/zh-CN/providers/qwen.md +55 -0
  671. package/docs/zh-CN/providers/sglang.md +111 -0
  672. package/docs/zh-CN/providers/synthetic.md +106 -0
  673. package/docs/zh-CN/providers/together.md +72 -0
  674. package/docs/zh-CN/providers/venice.md +289 -0
  675. package/docs/zh-CN/providers/vercel-ai-gateway.md +66 -0
  676. package/docs/zh-CN/providers/xiaomi.md +93 -0
  677. package/docs/zh-CN/providers/zai.md +53 -0
  678. package/docs/zh-CN/reference/AGENTS.default.md +131 -0
  679. package/docs/zh-CN/reference/RELEASING.md +48 -0
  680. package/docs/zh-CN/reference/api-usage-costs.md +141 -0
  681. package/docs/zh-CN/reference/credits.md +34 -0
  682. package/docs/zh-CN/reference/device-models.md +54 -0
  683. package/docs/zh-CN/reference/rpc.md +48 -0
  684. package/docs/zh-CN/reference/session-management-compaction.md +287 -0
  685. package/docs/zh-CN/reference/templates/AGENTS.dev.md +89 -0
  686. package/docs/zh-CN/reference/templates/AGENTS.md +225 -0
  687. package/docs/zh-CN/reference/templates/BOOT.md +17 -0
  688. package/docs/zh-CN/reference/templates/BOOTSTRAP.md +68 -0
  689. package/docs/zh-CN/reference/templates/HEARTBEAT.md +18 -0
  690. package/docs/zh-CN/reference/templates/IDENTITY.dev.md +54 -0
  691. package/docs/zh-CN/reference/templates/IDENTITY.md +36 -0
  692. package/docs/zh-CN/reference/templates/SOUL.dev.md +83 -0
  693. package/docs/zh-CN/reference/templates/SOUL.md +49 -0
  694. package/docs/zh-CN/reference/templates/TOOLS.dev.md +31 -0
  695. package/docs/zh-CN/reference/templates/TOOLS.md +53 -0
  696. package/docs/zh-CN/reference/templates/USER.dev.md +25 -0
  697. package/docs/zh-CN/reference/templates/USER.md +30 -0
  698. package/docs/zh-CN/reference/test.md +57 -0
  699. package/docs/zh-CN/reference/token-use.md +119 -0
  700. package/docs/zh-CN/reference/transcript-hygiene.md +109 -0
  701. package/docs/zh-CN/reference/wizard.md +242 -0
  702. package/docs/zh-CN/security/formal-verification.md +171 -0
  703. package/docs/zh-CN/start/bootstrapping.md +9 -0
  704. package/docs/zh-CN/start/docs-directory.md +70 -0
  705. package/docs/zh-CN/start/getting-started.md +143 -0
  706. package/docs/zh-CN/start/hubs.md +194 -0
  707. package/docs/zh-CN/start/lore.md +226 -0
  708. package/docs/zh-CN/start/onboarding-overview.md +58 -0
  709. package/docs/zh-CN/start/onboarding.md +105 -0
  710. package/docs/zh-CN/start/openclaw.md +248 -0
  711. package/docs/zh-CN/start/quickstart.md +88 -0
  712. package/docs/zh-CN/start/setup.md +153 -0
  713. package/docs/zh-CN/start/showcase.md +423 -0
  714. package/docs/zh-CN/start/wizard-cli-automation.md +222 -0
  715. package/docs/zh-CN/start/wizard-cli-reference.md +306 -0
  716. package/docs/zh-CN/start/wizard.md +132 -0
  717. package/docs/zh-CN/tools/agent-send.md +59 -0
  718. package/docs/zh-CN/tools/apply-patch.md +57 -0
  719. package/docs/zh-CN/tools/browser-linux-troubleshooting.md +144 -0
  720. package/docs/zh-CN/tools/browser-login.md +75 -0
  721. package/docs/zh-CN/tools/browser.md +553 -0
  722. package/docs/zh-CN/tools/chrome-extension.md +183 -0
  723. package/docs/zh-CN/tools/clawhub.md +209 -0
  724. package/docs/zh-CN/tools/creating-skills.md +61 -0
  725. package/docs/zh-CN/tools/elevated.md +64 -0
  726. package/docs/zh-CN/tools/exec-approvals.md +234 -0
  727. package/docs/zh-CN/tools/exec.md +169 -0
  728. package/docs/zh-CN/tools/firecrawl.md +68 -0
  729. package/docs/zh-CN/tools/index.md +515 -0
  730. package/docs/zh-CN/tools/llm-task.md +117 -0
  731. package/docs/zh-CN/tools/lobster.md +349 -0
  732. package/docs/zh-CN/tools/multi-agent-sandbox-tools.md +401 -0
  733. package/docs/zh-CN/tools/plugin.md +1612 -0
  734. package/docs/zh-CN/tools/reactions.md +29 -0
  735. package/docs/zh-CN/tools/skills-config.md +78 -0
  736. package/docs/zh-CN/tools/skills.md +279 -0
  737. package/docs/zh-CN/tools/slash-commands.md +205 -0
  738. package/docs/zh-CN/tools/subagents.md +167 -0
  739. package/docs/zh-CN/tools/thinking.md +80 -0
  740. package/docs/zh-CN/tools/web.md +289 -0
  741. package/docs/zh-CN/tts.md +375 -0
  742. package/docs/zh-CN/vps.md +47 -0
  743. package/docs/zh-CN/web/control-ui.md +191 -0
  744. package/docs/zh-CN/web/dashboard.md +53 -0
  745. package/docs/zh-CN/web/index.md +118 -0
  746. package/docs/zh-CN/web/tui.md +166 -0
  747. package/docs/zh-CN/web/webchat.md +56 -0
  748. package/package.json +841 -0
  749. package/quantumclaw.mjs +135 -0
  750. package/skills/1password/SKILL.md +70 -0
  751. package/skills/1password/references/cli-examples.md +29 -0
  752. package/skills/1password/references/get-started.md +17 -0
  753. package/skills/apple-notes/SKILL.md +77 -0
  754. package/skills/apple-reminders/SKILL.md +118 -0
  755. package/skills/bear-notes/SKILL.md +107 -0
  756. package/skills/blogwatcher/SKILL.md +69 -0
  757. package/skills/blucli/SKILL.md +47 -0
  758. package/skills/bluebubbles/SKILL.md +131 -0
  759. package/skills/camsnap/SKILL.md +45 -0
  760. package/skills/canvas/SKILL.md +198 -0
  761. package/skills/clawhub/SKILL.md +77 -0
  762. package/skills/coding-agent/SKILL.md +295 -0
  763. package/skills/discord/SKILL.md +197 -0
  764. package/skills/eightctl/SKILL.md +50 -0
  765. package/skills/gemini/SKILL.md +43 -0
  766. package/skills/gh-issues/SKILL.md +865 -0
  767. package/skills/gifgrep/SKILL.md +79 -0
  768. package/skills/github/SKILL.md +163 -0
  769. package/skills/gog/SKILL.md +116 -0
  770. package/skills/goplaces/SKILL.md +52 -0
  771. package/skills/healthcheck/SKILL.md +245 -0
  772. package/skills/himalaya/SKILL.md +257 -0
  773. package/skills/himalaya/references/configuration.md +184 -0
  774. package/skills/himalaya/references/message-composition.md +199 -0
  775. package/skills/imsg/SKILL.md +122 -0
  776. package/skills/mcporter/SKILL.md +61 -0
  777. package/skills/model-usage/SKILL.md +69 -0
  778. package/skills/model-usage/references/codexbar-cli.md +33 -0
  779. package/skills/model-usage/scripts/model_usage.py +320 -0
  780. package/skills/model-usage/scripts/test_model_usage.py +40 -0
  781. package/skills/nano-pdf/SKILL.md +38 -0
  782. package/skills/node-connect/SKILL.md +142 -0
  783. package/skills/notion/SKILL.md +174 -0
  784. package/skills/obsidian/SKILL.md +81 -0
  785. package/skills/openai-image-gen/SKILL.md +92 -0
  786. package/skills/openai-image-gen/scripts/gen.py +328 -0
  787. package/skills/openai-image-gen/scripts/test_gen.py +140 -0
  788. package/skills/openai-whisper/SKILL.md +38 -0
  789. package/skills/openai-whisper-api/SKILL.md +52 -0
  790. package/skills/openai-whisper-api/scripts/transcribe.sh +85 -0
  791. package/skills/openhue/SKILL.md +112 -0
  792. package/skills/oracle/SKILL.md +125 -0
  793. package/skills/ordercli/SKILL.md +78 -0
  794. package/skills/peekaboo/SKILL.md +190 -0
  795. package/skills/sag/SKILL.md +87 -0
  796. package/skills/session-logs/SKILL.md +115 -0
  797. package/skills/sherpa-onnx-tts/SKILL.md +103 -0
  798. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  799. package/skills/skill-creator/SKILL.md +372 -0
  800. package/skills/skill-creator/license.txt +202 -0
  801. package/skills/skill-creator/scripts/init_skill.py +378 -0
  802. package/skills/skill-creator/scripts/package_skill.py +139 -0
  803. package/skills/skill-creator/scripts/quick_validate.py +159 -0
  804. package/skills/skill-creator/scripts/test_package_skill.py +160 -0
  805. package/skills/skill-creator/scripts/test_quick_validate.py +72 -0
  806. package/skills/slack/SKILL.md +144 -0
  807. package/skills/songsee/SKILL.md +49 -0
  808. package/skills/sonoscli/SKILL.md +65 -0
  809. package/skills/spotify-player/SKILL.md +64 -0
  810. package/skills/summarize/SKILL.md +87 -0
  811. package/skills/things-mac/SKILL.md +86 -0
  812. package/skills/tmux/SKILL.md +153 -0
  813. package/skills/tmux/scripts/find-sessions.sh +112 -0
  814. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  815. package/skills/trello/SKILL.md +95 -0
  816. package/skills/video-frames/SKILL.md +46 -0
  817. package/skills/video-frames/scripts/frame.sh +81 -0
  818. package/skills/voice-call/SKILL.md +45 -0
  819. package/skills/wacli/SKILL.md +72 -0
  820. package/skills/weather/SKILL.md +112 -0
  821. package/skills/xurl/SKILL.md +461 -0
@@ -0,0 +1,295 @@
1
+ ---
2
+ summary: "Expose an OpenResponses-compatible /v1/responses HTTP endpoint from the Gateway"
3
+ read_when:
4
+ - Integrating clients that speak the OpenResponses API
5
+ - You want item-based inputs, client tool calls, or SSE events
6
+ title: "OpenResponses API"
7
+ ---
8
+
9
+ # OpenResponses API (HTTP)
10
+
11
+ QuantumClaw’s Gateway can serve an OpenResponses-compatible `POST /v1/responses` endpoint.
12
+
13
+ This endpoint is **disabled by default**. Enable it in config first.
14
+
15
+ - `POST /v1/responses`
16
+ - Same port as the Gateway (WS + HTTP multiplex): `http://<gateway-host>:<port>/v1/responses`
17
+
18
+ Under the hood, requests are executed as a normal Gateway agent run (same codepath as
19
+ `quantumclaw agent`), so routing/permissions/config match your Gateway.
20
+
21
+ ## Authentication, security, and routing
22
+
23
+ Operational behavior matches [OpenAI Chat Completions](/gateway/openai-http-api):
24
+
25
+ - use `Authorization: Bearer <token>` with the normal Gateway auth config
26
+ - treat the endpoint as full operator access for the gateway instance
27
+ - select agents with `model: "quantumclaw:<agentId>"`, `model: "agent:<agentId>"`, or `x-quantumclaw-agent-id`
28
+ - use `x-quantumclaw-session-key` for explicit session routing
29
+
30
+ Enable or disable this endpoint with `gateway.http.endpoints.responses.enabled`.
31
+
32
+ ## Session behavior
33
+
34
+ By default the endpoint is **stateless per request** (a new session key is generated each call).
35
+
36
+ If the request includes an OpenResponses `user` string, the Gateway derives a stable session key
37
+ from it, so repeated calls can share an agent session.
38
+
39
+ ## Request shape (supported)
40
+
41
+ The request follows the OpenResponses API with item-based input. Current support:
42
+
43
+ - `input`: string or array of item objects.
44
+ - `instructions`: merged into the system prompt.
45
+ - `tools`: client tool definitions (function tools).
46
+ - `tool_choice`: filter or require client tools.
47
+ - `stream`: enables SSE streaming.
48
+ - `max_output_tokens`: best-effort output limit (provider dependent).
49
+ - `user`: stable session routing.
50
+
51
+ Accepted but **currently ignored**:
52
+
53
+ - `max_tool_calls`
54
+ - `reasoning`
55
+ - `metadata`
56
+ - `store`
57
+ - `previous_response_id`
58
+ - `truncation`
59
+
60
+ ## Items (input)
61
+
62
+ ### `message`
63
+
64
+ Roles: `system`, `developer`, `user`, `assistant`.
65
+
66
+ - `system` and `developer` are appended to the system prompt.
67
+ - The most recent `user` or `function_call_output` item becomes the “current message.”
68
+ - Earlier user/assistant messages are included as history for context.
69
+
70
+ ### `function_call_output` (turn-based tools)
71
+
72
+ Send tool results back to the model:
73
+
74
+ ```json
75
+ {
76
+ "type": "function_call_output",
77
+ "call_id": "call_123",
78
+ "output": "{\"temperature\": \"72F\"}"
79
+ }
80
+ ```
81
+
82
+ ### `reasoning` and `item_reference`
83
+
84
+ Accepted for schema compatibility but ignored when building the prompt.
85
+
86
+ ## Tools (client-side function tools)
87
+
88
+ Provide tools with `tools: [{ type: "function", function: { name, description?, parameters? } }]`.
89
+
90
+ If the agent decides to call a tool, the response returns a `function_call` output item.
91
+ You then send a follow-up request with `function_call_output` to continue the turn.
92
+
93
+ ## Images (`input_image`)
94
+
95
+ Supports base64 or URL sources:
96
+
97
+ ```json
98
+ {
99
+ "type": "input_image",
100
+ "source": { "type": "url", "url": "https://example.com/image.png" }
101
+ }
102
+ ```
103
+
104
+ Allowed MIME types (current): `image/jpeg`, `image/png`, `image/gif`, `image/webp`, `image/heic`, `image/heif`.
105
+ Max size (current): 10MB.
106
+
107
+ ## Files (`input_file`)
108
+
109
+ Supports base64 or URL sources:
110
+
111
+ ```json
112
+ {
113
+ "type": "input_file",
114
+ "source": {
115
+ "type": "base64",
116
+ "media_type": "text/plain",
117
+ "data": "SGVsbG8gV29ybGQh",
118
+ "filename": "hello.txt"
119
+ }
120
+ }
121
+ ```
122
+
123
+ Allowed MIME types (current): `text/plain`, `text/markdown`, `text/html`, `text/csv`,
124
+ `application/json`, `application/pdf`.
125
+
126
+ Max size (current): 5MB.
127
+
128
+ Current behavior:
129
+
130
+ - File content is decoded and added to the **system prompt**, not the user message,
131
+ so it stays ephemeral (not persisted in session history).
132
+ - PDFs are parsed for text. If little text is found, the first pages are rasterized
133
+ into images and passed to the model.
134
+
135
+ PDF parsing uses the Node-friendly `pdfjs-dist` legacy build (no worker). The modern
136
+ PDF.js build expects browser workers/DOM globals, so it is not used in the Gateway.
137
+
138
+ URL fetch defaults:
139
+
140
+ - `files.allowUrl`: `true`
141
+ - `images.allowUrl`: `true`
142
+ - `maxUrlParts`: `8` (total URL-based `input_file` + `input_image` parts per request)
143
+ - Requests are guarded (DNS resolution, private IP blocking, redirect caps, timeouts).
144
+ - Optional hostname allowlists are supported per input type (`files.urlAllowlist`, `images.urlAllowlist`).
145
+ - Exact host: `"cdn.example.com"`
146
+ - Wildcard subdomains: `"*.assets.example.com"` (does not match apex)
147
+ - Empty or omitted allowlists mean no hostname allowlist restriction.
148
+ - To disable URL-based fetches entirely, set `files.allowUrl: false` and/or `images.allowUrl: false`.
149
+
150
+ ## File + image limits (config)
151
+
152
+ Defaults can be tuned under `gateway.http.endpoints.responses`:
153
+
154
+ ```json5
155
+ {
156
+ gateway: {
157
+ http: {
158
+ endpoints: {
159
+ responses: {
160
+ enabled: true,
161
+ maxBodyBytes: 20000000,
162
+ maxUrlParts: 8,
163
+ files: {
164
+ allowUrl: true,
165
+ urlAllowlist: ["cdn.example.com", "*.assets.example.com"],
166
+ allowedMimes: [
167
+ "text/plain",
168
+ "text/markdown",
169
+ "text/html",
170
+ "text/csv",
171
+ "application/json",
172
+ "application/pdf",
173
+ ],
174
+ maxBytes: 5242880,
175
+ maxChars: 200000,
176
+ maxRedirects: 3,
177
+ timeoutMs: 10000,
178
+ pdf: {
179
+ maxPages: 4,
180
+ maxPixels: 4000000,
181
+ minTextChars: 200,
182
+ },
183
+ },
184
+ images: {
185
+ allowUrl: true,
186
+ urlAllowlist: ["images.example.com"],
187
+ allowedMimes: [
188
+ "image/jpeg",
189
+ "image/png",
190
+ "image/gif",
191
+ "image/webp",
192
+ "image/heic",
193
+ "image/heif",
194
+ ],
195
+ maxBytes: 10485760,
196
+ maxRedirects: 3,
197
+ timeoutMs: 10000,
198
+ },
199
+ },
200
+ },
201
+ },
202
+ },
203
+ }
204
+ ```
205
+
206
+ Defaults when omitted:
207
+
208
+ - `maxBodyBytes`: 20MB
209
+ - `maxUrlParts`: 8
210
+ - `files.maxBytes`: 5MB
211
+ - `files.maxChars`: 200k
212
+ - `files.maxRedirects`: 3
213
+ - `files.timeoutMs`: 10s
214
+ - `files.pdf.maxPages`: 4
215
+ - `files.pdf.maxPixels`: 4,000,000
216
+ - `files.pdf.minTextChars`: 200
217
+ - `images.maxBytes`: 10MB
218
+ - `images.maxRedirects`: 3
219
+ - `images.timeoutMs`: 10s
220
+ - HEIC/HEIF `input_image` sources are accepted and normalized to JPEG before provider delivery.
221
+
222
+ Security note:
223
+
224
+ - URL allowlists are enforced before fetch and on redirect hops.
225
+ - Allowlisting a hostname does not bypass private/internal IP blocking.
226
+ - For internet-exposed gateways, apply network egress controls in addition to app-level guards.
227
+ See [Security](/gateway/security).
228
+
229
+ ## Streaming (SSE)
230
+
231
+ Set `stream: true` to receive Server-Sent Events (SSE):
232
+
233
+ - `Content-Type: text/event-stream`
234
+ - Each event line is `event: <type>` and `data: <json>`
235
+ - Stream ends with `data: [DONE]`
236
+
237
+ Event types currently emitted:
238
+
239
+ - `response.created`
240
+ - `response.in_progress`
241
+ - `response.output_item.added`
242
+ - `response.content_part.added`
243
+ - `response.output_text.delta`
244
+ - `response.output_text.done`
245
+ - `response.content_part.done`
246
+ - `response.output_item.done`
247
+ - `response.completed`
248
+ - `response.failed` (on error)
249
+
250
+ ## Usage
251
+
252
+ `usage` is populated when the underlying provider reports token counts.
253
+
254
+ ## Errors
255
+
256
+ Errors use a JSON object like:
257
+
258
+ ```json
259
+ { "error": { "message": "...", "type": "invalid_request_error" } }
260
+ ```
261
+
262
+ Common cases:
263
+
264
+ - `401` missing/invalid auth
265
+ - `400` invalid request body
266
+ - `405` wrong method
267
+
268
+ ## Examples
269
+
270
+ Non-streaming:
271
+
272
+ ```bash
273
+ curl -sS http://127.0.0.1:18789/v1/responses \
274
+ -H 'Authorization: Bearer YOUR_TOKEN' \
275
+ -H 'Content-Type: application/json' \
276
+ -H 'x-quantumclaw-agent-id: main' \
277
+ -d '{
278
+ "model": "quantumclaw",
279
+ "input": "hi"
280
+ }'
281
+ ```
282
+
283
+ Streaming:
284
+
285
+ ```bash
286
+ curl -N http://127.0.0.1:18789/v1/responses \
287
+ -H 'Authorization: Bearer YOUR_TOKEN' \
288
+ -H 'Content-Type: application/json' \
289
+ -H 'x-quantumclaw-agent-id: main' \
290
+ -d '{
291
+ "model": "quantumclaw",
292
+ "stream": true,
293
+ "input": "hi"
294
+ }'
295
+ ```
@@ -0,0 +1,307 @@
1
+ ---
2
+ title: OpenShell
3
+ summary: "Use OpenShell as a managed sandbox backend for QuantumClaw agents"
4
+ read_when:
5
+ - You want cloud-managed sandboxes instead of local Docker
6
+ - You are setting up the OpenShell plugin
7
+ - You need to choose between mirror and remote workspace modes
8
+ ---
9
+
10
+ # OpenShell
11
+
12
+ OpenShell is a managed sandbox backend for QuantumClaw. Instead of running Docker
13
+ containers locally, QuantumClaw delegates sandbox lifecycle to the `openshell` CLI,
14
+ which provisions remote environments with SSH-based command execution.
15
+
16
+ The OpenShell plugin reuses the same core SSH transport and remote filesystem
17
+ bridge as the generic [SSH backend](/gateway/sandboxing#ssh-backend). It adds
18
+ OpenShell-specific lifecycle (`sandbox create/get/delete`, `sandbox ssh-config`)
19
+ and an optional `mirror` workspace mode.
20
+
21
+ ## Prerequisites
22
+
23
+ - The `openshell` CLI installed and on `PATH` (or set a custom path via
24
+ `plugins.entries.openshell.config.command`)
25
+ - An OpenShell account with sandbox access
26
+ - QuantumClaw Gateway running on the host
27
+
28
+ ## Quick start
29
+
30
+ 1. Enable the plugin and set the sandbox backend:
31
+
32
+ ```json5
33
+ {
34
+ agents: {
35
+ defaults: {
36
+ sandbox: {
37
+ mode: "all",
38
+ backend: "openshell",
39
+ scope: "session",
40
+ workspaceAccess: "rw",
41
+ },
42
+ },
43
+ },
44
+ plugins: {
45
+ entries: {
46
+ openshell: {
47
+ enabled: true,
48
+ config: {
49
+ from: "quantumclaw",
50
+ mode: "remote",
51
+ },
52
+ },
53
+ },
54
+ },
55
+ }
56
+ ```
57
+
58
+ 2. Restart the Gateway. On the next agent turn, QuantumClaw creates an OpenShell
59
+ sandbox and routes tool execution through it.
60
+
61
+ 3. Verify:
62
+
63
+ ```bash
64
+ quantumclaw sandbox list
65
+ quantumclaw sandbox explain
66
+ ```
67
+
68
+ ## Workspace modes
69
+
70
+ This is the most important decision when using OpenShell.
71
+
72
+ ### `mirror`
73
+
74
+ Use `plugins.entries.openshell.config.mode: "mirror"` when you want the **local
75
+ workspace to stay canonical**.
76
+
77
+ Behavior:
78
+
79
+ - Before `exec`, QuantumClaw syncs the local workspace into the OpenShell sandbox.
80
+ - After `exec`, QuantumClaw syncs the remote workspace back to the local workspace.
81
+ - File tools still operate through the sandbox bridge, but the local workspace
82
+ remains the source of truth between turns.
83
+
84
+ Best for:
85
+
86
+ - You edit files locally outside QuantumClaw and want those changes visible in the
87
+ sandbox automatically.
88
+ - You want the OpenShell sandbox to behave as much like the Docker backend as
89
+ possible.
90
+ - You want the host workspace to reflect sandbox writes after each exec turn.
91
+
92
+ Tradeoff: extra sync cost before and after each exec.
93
+
94
+ ### `remote`
95
+
96
+ Use `plugins.entries.openshell.config.mode: "remote"` when you want the
97
+ **OpenShell workspace to become canonical**.
98
+
99
+ Behavior:
100
+
101
+ - When the sandbox is first created, QuantumClaw seeds the remote workspace from
102
+ the local workspace once.
103
+ - After that, `exec`, `read`, `write`, `edit`, and `apply_patch` operate
104
+ directly against the remote OpenShell workspace.
105
+ - QuantumClaw does **not** sync remote changes back into the local workspace.
106
+ - Prompt-time media reads still work because file and media tools read through
107
+ the sandbox bridge.
108
+
109
+ Best for:
110
+
111
+ - The sandbox should live primarily on the remote side.
112
+ - You want lower per-turn sync overhead.
113
+ - You do not want host-local edits to silently overwrite remote sandbox state.
114
+
115
+ Important: if you edit files on the host outside QuantumClaw after the initial seed,
116
+ the remote sandbox does **not** see those changes. Use
117
+ `quantumclaw sandbox recreate` to re-seed.
118
+
119
+ ### Choosing a mode
120
+
121
+ | | `mirror` | `remote` |
122
+ | ------------------------ | -------------------------- | ------------------------- |
123
+ | **Canonical workspace** | Local host | Remote OpenShell |
124
+ | **Sync direction** | Bidirectional (each exec) | One-time seed |
125
+ | **Per-turn overhead** | Higher (upload + download) | Lower (direct remote ops) |
126
+ | **Local edits visible?** | Yes, on next exec | No, until recreate |
127
+ | **Best for** | Development workflows | Long-running agents, CI |
128
+
129
+ ## Configuration reference
130
+
131
+ All OpenShell config lives under `plugins.entries.openshell.config`:
132
+
133
+ | Key | Type | Default | Description |
134
+ | ------------------------- | ------------------------ | ------------- | ----------------------------------------------------- |
135
+ | `mode` | `"mirror"` or `"remote"` | `"mirror"` | Workspace sync mode |
136
+ | `command` | `string` | `"openshell"` | Path or name of the `openshell` CLI |
137
+ | `from` | `string` | `"quantumclaw"` | Sandbox source for first-time create |
138
+ | `gateway` | `string` | — | OpenShell gateway name (`--gateway`) |
139
+ | `gatewayEndpoint` | `string` | — | OpenShell gateway endpoint URL (`--gateway-endpoint`) |
140
+ | `policy` | `string` | — | OpenShell policy ID for sandbox creation |
141
+ | `providers` | `string[]` | `[]` | Provider names to attach when sandbox is created |
142
+ | `gpu` | `boolean` | `false` | Request GPU resources |
143
+ | `autoProviders` | `boolean` | `true` | Pass `--auto-providers` during sandbox create |
144
+ | `remoteWorkspaceDir` | `string` | `"/sandbox"` | Primary writable workspace inside the sandbox |
145
+ | `remoteAgentWorkspaceDir` | `string` | `"/agent"` | Agent workspace mount path (for read-only access) |
146
+ | `timeoutSeconds` | `number` | `120` | Timeout for `openshell` CLI operations |
147
+
148
+ Sandbox-level settings (`mode`, `scope`, `workspaceAccess`) are configured under
149
+ `agents.defaults.sandbox` as with any backend. See
150
+ [Sandboxing](/gateway/sandboxing) for the full matrix.
151
+
152
+ ## Examples
153
+
154
+ ### Minimal remote setup
155
+
156
+ ```json5
157
+ {
158
+ agents: {
159
+ defaults: {
160
+ sandbox: {
161
+ mode: "all",
162
+ backend: "openshell",
163
+ },
164
+ },
165
+ },
166
+ plugins: {
167
+ entries: {
168
+ openshell: {
169
+ enabled: true,
170
+ config: {
171
+ from: "quantumclaw",
172
+ mode: "remote",
173
+ },
174
+ },
175
+ },
176
+ },
177
+ }
178
+ ```
179
+
180
+ ### Mirror mode with GPU
181
+
182
+ ```json5
183
+ {
184
+ agents: {
185
+ defaults: {
186
+ sandbox: {
187
+ mode: "all",
188
+ backend: "openshell",
189
+ scope: "agent",
190
+ workspaceAccess: "rw",
191
+ },
192
+ },
193
+ },
194
+ plugins: {
195
+ entries: {
196
+ openshell: {
197
+ enabled: true,
198
+ config: {
199
+ from: "quantumclaw",
200
+ mode: "mirror",
201
+ gpu: true,
202
+ providers: ["openai"],
203
+ timeoutSeconds: 180,
204
+ },
205
+ },
206
+ },
207
+ },
208
+ }
209
+ ```
210
+
211
+ ### Per-agent OpenShell with custom gateway
212
+
213
+ ```json5
214
+ {
215
+ agents: {
216
+ defaults: {
217
+ sandbox: { mode: "off" },
218
+ },
219
+ list: [
220
+ {
221
+ id: "researcher",
222
+ sandbox: {
223
+ mode: "all",
224
+ backend: "openshell",
225
+ scope: "agent",
226
+ workspaceAccess: "rw",
227
+ },
228
+ },
229
+ ],
230
+ },
231
+ plugins: {
232
+ entries: {
233
+ openshell: {
234
+ enabled: true,
235
+ config: {
236
+ from: "quantumclaw",
237
+ mode: "remote",
238
+ gateway: "lab",
239
+ gatewayEndpoint: "https://lab.example",
240
+ policy: "strict",
241
+ },
242
+ },
243
+ },
244
+ },
245
+ }
246
+ ```
247
+
248
+ ## Lifecycle management
249
+
250
+ OpenShell sandboxes are managed through the normal sandbox CLI:
251
+
252
+ ```bash
253
+ # List all sandbox runtimes (Docker + OpenShell)
254
+ quantumclaw sandbox list
255
+
256
+ # Inspect effective policy
257
+ quantumclaw sandbox explain
258
+
259
+ # Recreate (deletes remote workspace, re-seeds on next use)
260
+ quantumclaw sandbox recreate --all
261
+ ```
262
+
263
+ For `remote` mode, **recreate is especially important**: it deletes the canonical
264
+ remote workspace for that scope. The next use seeds a fresh remote workspace from
265
+ the local workspace.
266
+
267
+ For `mirror` mode, recreate mainly resets the remote execution environment because
268
+ the local workspace remains canonical.
269
+
270
+ ### When to recreate
271
+
272
+ Recreate after changing any of these:
273
+
274
+ - `agents.defaults.sandbox.backend`
275
+ - `plugins.entries.openshell.config.from`
276
+ - `plugins.entries.openshell.config.mode`
277
+ - `plugins.entries.openshell.config.policy`
278
+
279
+ ```bash
280
+ quantumclaw sandbox recreate --all
281
+ ```
282
+
283
+ ## Current limitations
284
+
285
+ - Sandbox browser is not supported on the OpenShell backend.
286
+ - `sandbox.docker.binds` does not apply to OpenShell.
287
+ - Docker-specific runtime knobs under `sandbox.docker.*` apply only to the Docker
288
+ backend.
289
+
290
+ ## How it works
291
+
292
+ 1. QuantumClaw calls `openshell sandbox create` (with `--from`, `--gateway`,
293
+ `--policy`, `--providers`, `--gpu` flags as configured).
294
+ 2. QuantumClaw calls `openshell sandbox ssh-config <name>` to get SSH connection
295
+ details for the sandbox.
296
+ 3. Core writes the SSH config to a temp file and opens an SSH session using the
297
+ same remote filesystem bridge as the generic SSH backend.
298
+ 4. In `mirror` mode: sync local to remote before exec, run, sync back after exec.
299
+ 5. In `remote` mode: seed once on create, then operate directly on the remote
300
+ workspace.
301
+
302
+ ## See also
303
+
304
+ - [Sandboxing](/gateway/sandboxing) -- modes, scopes, and backend comparison
305
+ - [Sandbox vs Tool Policy vs Elevated](/gateway/sandbox-vs-tool-policy-vs-elevated) -- debugging blocked tools
306
+ - [Multi-Agent Sandbox and Tools](/tools/multi-agent-sandbox-tools) -- per-agent overrides
307
+ - [Sandbox CLI](/cli/sandbox) -- `quantumclaw sandbox` commands
@@ -0,0 +1,99 @@
1
+ ---
2
+ summary: "Gateway-owned node pairing (Option B) for iOS and other remote nodes"
3
+ read_when:
4
+ - Implementing node pairing approvals without macOS UI
5
+ - Adding CLI flows for approving remote nodes
6
+ - Extending gateway protocol with node management
7
+ title: "Gateway-Owned Pairing"
8
+ ---
9
+
10
+ # Gateway-owned pairing (Option B)
11
+
12
+ In Gateway-owned pairing, the **Gateway** is the source of truth for which nodes
13
+ are allowed to join. UIs (macOS app, future clients) are just frontends that
14
+ approve or reject pending requests.
15
+
16
+ **Important:** WS nodes use **device pairing** (role `node`) during `connect`.
17
+ `node.pair.*` is a separate pairing store and does **not** gate the WS handshake.
18
+ Only clients that explicitly call `node.pair.*` use this flow.
19
+
20
+ ## Concepts
21
+
22
+ - **Pending request**: a node asked to join; requires approval.
23
+ - **Paired node**: approved node with an issued auth token.
24
+ - **Transport**: the Gateway WS endpoint forwards requests but does not decide
25
+ membership. (Legacy TCP bridge support is deprecated/removed.)
26
+
27
+ ## How pairing works
28
+
29
+ 1. A node connects to the Gateway WS and requests pairing.
30
+ 2. The Gateway stores a **pending request** and emits `node.pair.requested`.
31
+ 3. You approve or reject the request (CLI or UI).
32
+ 4. On approval, the Gateway issues a **new token** (tokens are rotated on re‑pair).
33
+ 5. The node reconnects using the token and is now “paired”.
34
+
35
+ Pending requests expire automatically after **5 minutes**.
36
+
37
+ ## CLI workflow (headless friendly)
38
+
39
+ ```bash
40
+ quantumclaw nodes pending
41
+ quantumclaw nodes approve <requestId>
42
+ quantumclaw nodes reject <requestId>
43
+ quantumclaw nodes status
44
+ quantumclaw nodes rename --node <id|name|ip> --name "Living Room iPad"
45
+ ```
46
+
47
+ `nodes status` shows paired/connected nodes and their capabilities.
48
+
49
+ ## API surface (gateway protocol)
50
+
51
+ Events:
52
+
53
+ - `node.pair.requested` — emitted when a new pending request is created.
54
+ - `node.pair.resolved` — emitted when a request is approved/rejected/expired.
55
+
56
+ Methods:
57
+
58
+ - `node.pair.request` — create or reuse a pending request.
59
+ - `node.pair.list` — list pending + paired nodes.
60
+ - `node.pair.approve` — approve a pending request (issues token).
61
+ - `node.pair.reject` — reject a pending request.
62
+ - `node.pair.verify` — verify `{ nodeId, token }`.
63
+
64
+ Notes:
65
+
66
+ - `node.pair.request` is idempotent per node: repeated calls return the same
67
+ pending request.
68
+ - Approval **always** generates a fresh token; no token is ever returned from
69
+ `node.pair.request`.
70
+ - Requests may include `silent: true` as a hint for auto-approval flows.
71
+
72
+ ## Auto-approval (macOS app)
73
+
74
+ The macOS app can optionally attempt a **silent approval** when:
75
+
76
+ - the request is marked `silent`, and
77
+ - the app can verify an SSH connection to the gateway host using the same user.
78
+
79
+ If silent approval fails, it falls back to the normal “Approve/Reject” prompt.
80
+
81
+ ## Storage (local, private)
82
+
83
+ Pairing state is stored under the Gateway state directory (default `~/.quantumclaw`):
84
+
85
+ - `~/.quantumclaw/nodes/paired.json`
86
+ - `~/.quantumclaw/nodes/pending.json`
87
+
88
+ If you override `QUANTUMCLAW_STATE_DIR`, the `nodes/` folder moves with it.
89
+
90
+ Security notes:
91
+
92
+ - Tokens are secrets; treat `paired.json` as sensitive.
93
+ - Rotating a token requires re-approval (or deleting the node entry).
94
+
95
+ ## Transport behavior
96
+
97
+ - The transport is **stateless**; it does not store membership.
98
+ - If the Gateway is offline or pairing is disabled, nodes cannot pair.
99
+ - If the Gateway is in remote mode, pairing still happens against the remote Gateway’s store.