@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,1366 @@
1
+ ---
2
+ summary: "Plugin internals: capability model, ownership, contracts, load pipeline, and runtime helpers"
3
+ read_when:
4
+ - Building or debugging native QuantumClaw plugins
5
+ - Understanding the plugin capability model or ownership boundaries
6
+ - Working on the plugin load pipeline or registry
7
+ - Implementing provider runtime hooks or channel plugins
8
+ title: "Plugin Internals"
9
+ sidebarTitle: "Internals"
10
+ ---
11
+
12
+ # Plugin Internals
13
+
14
+ <Info>
15
+ This is the **deep architecture reference**. For practical guides, see:
16
+ - [Install and use plugins](/tools/plugin) — user guide
17
+ - [Getting Started](/plugins/building-plugins) — first plugin tutorial
18
+ - [Channel Plugins](/plugins/sdk-channel-plugins) — build a messaging channel
19
+ - [Provider Plugins](/plugins/sdk-provider-plugins) — build a model provider
20
+ - [SDK Overview](/plugins/sdk-overview) — import map and registration API
21
+ </Info>
22
+
23
+ This page covers the internal architecture of the QuantumClaw plugin system.
24
+
25
+ ## Public capability model
26
+
27
+ Capabilities are the public **native plugin** model inside QuantumClaw. Every
28
+ native QuantumClaw plugin registers against one or more capability types:
29
+
30
+ | Capability | Registration method | Example plugins |
31
+ | ------------------- | --------------------------------------------- | ------------------------- |
32
+ | Text inference | `api.registerProvider(...)` | `openai`, `anthropic` |
33
+ | Speech | `api.registerSpeechProvider(...)` | `elevenlabs`, `microsoft` |
34
+ | Media understanding | `api.registerMediaUnderstandingProvider(...)` | `openai`, `google` |
35
+ | Image generation | `api.registerImageGenerationProvider(...)` | `openai`, `google` |
36
+ | Web search | `api.registerWebSearchProvider(...)` | `google` |
37
+ | Channel / messaging | `api.registerChannel(...)` | `msteams`, `matrix` |
38
+
39
+ A plugin that registers zero capabilities but provides hooks, tools, or
40
+ services is a **legacy hook-only** plugin. That pattern is still fully supported.
41
+
42
+ ### External compatibility stance
43
+
44
+ The capability model is landed in core and used by bundled/native plugins
45
+ today, but external plugin compatibility still needs a tighter bar than "it is
46
+ exported, therefore it is frozen."
47
+
48
+ Current guidance:
49
+
50
+ - **existing external plugins:** keep hook-based integrations working; treat
51
+ this as the compatibility baseline
52
+ - **new bundled/native plugins:** prefer explicit capability registration over
53
+ vendor-specific reach-ins or new hook-only designs
54
+ - **external plugins adopting capability registration:** allowed, but treat the
55
+ capability-specific helper surfaces as evolving unless docs explicitly mark a
56
+ contract as stable
57
+
58
+ Practical rule:
59
+
60
+ - capability registration APIs are the intended direction
61
+ - legacy hooks remain the safest no-breakage path for external plugins during
62
+ the transition
63
+ - exported helper subpaths are not all equal; prefer the narrow documented
64
+ contract, not incidental helper exports
65
+
66
+ ### Plugin shapes
67
+
68
+ QuantumClaw classifies every loaded plugin into a shape based on its actual
69
+ registration behavior (not just static metadata):
70
+
71
+ - **plain-capability** -- registers exactly one capability type (for example a
72
+ provider-only plugin like `mistral`)
73
+ - **hybrid-capability** -- registers multiple capability types (for example
74
+ `openai` owns text inference, speech, media understanding, and image
75
+ generation)
76
+ - **hook-only** -- registers only hooks (typed or custom), no capabilities,
77
+ tools, commands, or services
78
+ - **non-capability** -- registers tools, commands, services, or routes but no
79
+ capabilities
80
+
81
+ Use `quantumclaw plugins inspect <id>` to see a plugin's shape and capability
82
+ breakdown. See [CLI reference](/cli/plugins#inspect) for details.
83
+
84
+ ### Legacy hooks
85
+
86
+ The `before_agent_start` hook remains supported as a compatibility path for
87
+ hook-only plugins. Legacy real-world plugins still depend on it.
88
+
89
+ Direction:
90
+
91
+ - keep it working
92
+ - document it as legacy
93
+ - prefer `before_model_resolve` for model/provider override work
94
+ - prefer `before_prompt_build` for prompt mutation work
95
+ - remove only after real usage drops and fixture coverage proves migration safety
96
+
97
+ ### Compatibility signals
98
+
99
+ When you run `quantumclaw doctor` or `quantumclaw plugins inspect <id>`, you may see
100
+ one of these labels:
101
+
102
+ | Signal | Meaning |
103
+ | -------------------------- | ------------------------------------------------------------ |
104
+ | **config valid** | Config parses fine and plugins resolve |
105
+ | **compatibility advisory** | Plugin uses a supported-but-older pattern (e.g. `hook-only`) |
106
+ | **legacy warning** | Plugin uses `before_agent_start`, which is deprecated |
107
+ | **hard error** | Config is invalid or plugin failed to load |
108
+
109
+ Neither `hook-only` nor `before_agent_start` will break your plugin today --
110
+ `hook-only` is advisory, and `before_agent_start` only triggers a warning. These
111
+ signals also appear in `quantumclaw status --all` and `quantumclaw plugins doctor`.
112
+
113
+ ## Architecture overview
114
+
115
+ QuantumClaw's plugin system has four layers:
116
+
117
+ 1. **Manifest + discovery**
118
+ QuantumClaw finds candidate plugins from configured paths, workspace roots,
119
+ global extension roots, and bundled extensions. Discovery reads native
120
+ `quantumclaw.plugin.json` manifests plus supported bundle manifests first.
121
+ 2. **Enablement + validation**
122
+ Core decides whether a discovered plugin is enabled, disabled, blocked, or
123
+ selected for an exclusive slot such as memory.
124
+ 3. **Runtime loading**
125
+ Native QuantumClaw plugins are loaded in-process via jiti and register
126
+ capabilities into a central registry. Compatible bundles are normalized into
127
+ registry records without importing runtime code.
128
+ 4. **Surface consumption**
129
+ The rest of QuantumClaw reads the registry to expose tools, channels, provider
130
+ setup, hooks, HTTP routes, CLI commands, and services.
131
+
132
+ The important design boundary:
133
+
134
+ - discovery + config validation should work from **manifest/schema metadata**
135
+ without executing plugin code
136
+ - native runtime behavior comes from the plugin module's `register(api)` path
137
+
138
+ That split lets QuantumClaw validate config, explain missing/disabled plugins, and
139
+ build UI/schema hints before the full runtime is active.
140
+
141
+ ### Channel plugins and the shared message tool
142
+
143
+ Channel plugins do not need to register a separate send/edit/react tool for
144
+ normal chat actions. QuantumClaw keeps one shared `message` tool in core, and
145
+ channel plugins own the channel-specific discovery and execution behind it.
146
+
147
+ The current boundary is:
148
+
149
+ - core owns the shared `message` tool host, prompt wiring, session/thread
150
+ bookkeeping, and execution dispatch
151
+ - channel plugins own scoped action discovery, capability discovery, and any
152
+ channel-specific schema fragments
153
+ - channel plugins execute the final action through their action adapter
154
+
155
+ For channel plugins, the SDK surface is
156
+ `ChannelMessageActionAdapter.describeMessageTool(...)`. That unified discovery
157
+ call lets a plugin return its visible actions, capabilities, and schema
158
+ contributions together so those pieces do not drift apart.
159
+
160
+ Core passes runtime scope into that discovery step. Important fields include:
161
+
162
+ - `accountId`
163
+ - `currentChannelId`
164
+ - `currentThreadTs`
165
+ - `currentMessageId`
166
+ - `sessionKey`
167
+ - `sessionId`
168
+ - `agentId`
169
+ - trusted inbound `requesterSenderId`
170
+
171
+ That matters for context-sensitive plugins. A channel can hide or expose
172
+ message actions based on the active account, current room/thread/message, or
173
+ trusted requester identity without hardcoding channel-specific branches in the
174
+ core `message` tool.
175
+
176
+ This is why embedded-runner routing changes are still plugin work: the runner is
177
+ responsible for forwarding the current chat/session identity into the plugin
178
+ discovery boundary so the shared `message` tool exposes the right channel-owned
179
+ surface for the current turn.
180
+
181
+ For channel-owned execution helpers, bundled plugins should keep the execution
182
+ runtime inside their own extension modules. Core no longer owns the Discord,
183
+ Slack, Telegram, or WhatsApp message-action runtimes under `src/agents/tools`.
184
+ We do not publish separate `plugin-sdk/*-action-runtime` subpaths, and bundled
185
+ plugins should import their own local runtime code directly from their
186
+ extension-owned modules.
187
+
188
+ For polls specifically, there are two execution paths:
189
+
190
+ - `outbound.sendPoll` is the shared baseline for channels that fit the common
191
+ poll model
192
+ - `actions.handleAction("poll")` is the preferred path for channel-specific
193
+ poll semantics or extra poll parameters
194
+
195
+ Core now defers shared poll parsing until after plugin poll dispatch declines
196
+ the action, so plugin-owned poll handlers can accept channel-specific poll
197
+ fields without being blocked by the generic poll parser first.
198
+
199
+ See [Load pipeline](#load-pipeline) for the full startup sequence.
200
+
201
+ ## Capability ownership model
202
+
203
+ QuantumClaw treats a native plugin as the ownership boundary for a **company** or a
204
+ **feature**, not as a grab bag of unrelated integrations.
205
+
206
+ That means:
207
+
208
+ - a company plugin should usually own all of that company's QuantumClaw-facing
209
+ surfaces
210
+ - a feature plugin should usually own the full feature surface it introduces
211
+ - channels should consume shared core capabilities instead of re-implementing
212
+ provider behavior ad hoc
213
+
214
+ Examples:
215
+
216
+ - the bundled `openai` plugin owns OpenAI model-provider behavior and OpenAI
217
+ speech + media-understanding + image-generation behavior
218
+ - the bundled `elevenlabs` plugin owns ElevenLabs speech behavior
219
+ - the bundled `microsoft` plugin owns Microsoft speech behavior
220
+ - the bundled `google` plugin owns Google model-provider behavior plus Google
221
+ media-understanding + image-generation + web-search behavior
222
+ - the bundled `minimax`, `mistral`, `moonshot`, and `zai` plugins own their
223
+ media-understanding backends
224
+ - the `voice-call` plugin is a feature plugin: it owns call transport, tools,
225
+ CLI, routes, and runtime, but it consumes core TTS/STT capability instead of
226
+ inventing a second speech stack
227
+
228
+ The intended end state is:
229
+
230
+ - OpenAI lives in one plugin even if it spans text models, speech, images, and
231
+ future video
232
+ - another vendor can do the same for its own surface area
233
+ - channels do not care which vendor plugin owns the provider; they consume the
234
+ shared capability contract exposed by core
235
+
236
+ This is the key distinction:
237
+
238
+ - **plugin** = ownership boundary
239
+ - **capability** = core contract that multiple plugins can implement or consume
240
+
241
+ So if QuantumClaw adds a new domain such as video, the first question is not
242
+ "which provider should hardcode video handling?" The first question is "what is
243
+ the core video capability contract?" Once that contract exists, vendor plugins
244
+ can register against it and channel/feature plugins can consume it.
245
+
246
+ If the capability does not exist yet, the right move is usually:
247
+
248
+ 1. define the missing capability in core
249
+ 2. expose it through the plugin API/runtime in a typed way
250
+ 3. wire channels/features against that capability
251
+ 4. let vendor plugins register implementations
252
+
253
+ This keeps ownership explicit while avoiding core behavior that depends on a
254
+ single vendor or a one-off plugin-specific code path.
255
+
256
+ ### Capability layering
257
+
258
+ Use this mental model when deciding where code belongs:
259
+
260
+ - **core capability layer**: shared orchestration, policy, fallback, config
261
+ merge rules, delivery semantics, and typed contracts
262
+ - **vendor plugin layer**: vendor-specific APIs, auth, model catalogs, speech
263
+ synthesis, image generation, future video backends, usage endpoints
264
+ - **channel/feature plugin layer**: Slack/Discord/voice-call/etc. integration
265
+ that consumes core capabilities and presents them on a surface
266
+
267
+ For example, TTS follows this shape:
268
+
269
+ - core owns reply-time TTS policy, fallback order, prefs, and channel delivery
270
+ - `openai`, `elevenlabs`, and `microsoft` own synthesis implementations
271
+ - `voice-call` consumes the telephony TTS runtime helper
272
+
273
+ That same pattern should be preferred for future capabilities.
274
+
275
+ ### Multi-capability company plugin example
276
+
277
+ A company plugin should feel cohesive from the outside. If QuantumClaw has shared
278
+ contracts for models, speech, media understanding, and web search, a vendor can
279
+ own all of its surfaces in one place:
280
+
281
+ ```ts
282
+ import type { QuantumClawPluginDefinition } from "quantumclaw/plugin-sdk";
283
+ import {
284
+ buildOpenAISpeechProvider,
285
+ createPluginBackedWebSearchProvider,
286
+ describeImageWithModel,
287
+ transcribeOpenAiCompatibleAudio,
288
+ } from "quantumclaw/plugin-sdk";
289
+
290
+ const plugin: QuantumClawPluginDefinition = {
291
+ id: "exampleai",
292
+ name: "ExampleAI",
293
+ register(api) {
294
+ api.registerProvider({
295
+ id: "exampleai",
296
+ // auth/model catalog/runtime hooks
297
+ });
298
+
299
+ api.registerSpeechProvider(
300
+ buildOpenAISpeechProvider({
301
+ id: "exampleai",
302
+ // vendor speech config
303
+ }),
304
+ );
305
+
306
+ api.registerMediaUnderstandingProvider({
307
+ id: "exampleai",
308
+ capabilities: ["image", "audio", "video"],
309
+ async describeImage(req) {
310
+ return describeImageWithModel({
311
+ provider: "exampleai",
312
+ model: req.model,
313
+ input: req.input,
314
+ });
315
+ },
316
+ async transcribeAudio(req) {
317
+ return transcribeOpenAiCompatibleAudio({
318
+ provider: "exampleai",
319
+ model: req.model,
320
+ input: req.input,
321
+ });
322
+ },
323
+ });
324
+
325
+ api.registerWebSearchProvider(
326
+ createPluginBackedWebSearchProvider({
327
+ id: "exampleai-search",
328
+ // credential + fetch logic
329
+ }),
330
+ );
331
+ },
332
+ };
333
+
334
+ export default plugin;
335
+ ```
336
+
337
+ What matters is not the exact helper names. The shape matters:
338
+
339
+ - one plugin owns the vendor surface
340
+ - core still owns the capability contracts
341
+ - channels and feature plugins consume `api.runtime.*` helpers, not vendor code
342
+ - contract tests can assert that the plugin registered the capabilities it
343
+ claims to own
344
+
345
+ ### Capability example: video understanding
346
+
347
+ QuantumClaw already treats image/audio/video understanding as one shared
348
+ capability. The same ownership model applies there:
349
+
350
+ 1. core defines the media-understanding contract
351
+ 2. vendor plugins register `describeImage`, `transcribeAudio`, and
352
+ `describeVideo` as applicable
353
+ 3. channels and feature plugins consume the shared core behavior instead of
354
+ wiring directly to vendor code
355
+
356
+ That avoids baking one provider's video assumptions into core. The plugin owns
357
+ the vendor surface; core owns the capability contract and fallback behavior.
358
+
359
+ If QuantumClaw adds a new domain later, such as video generation, use the same
360
+ sequence again: define the core capability first, then let vendor plugins
361
+ register implementations against it.
362
+
363
+ Need a concrete rollout checklist? See
364
+ [Capability Cookbook](/tools/capability-cookbook).
365
+
366
+ ## Contracts and enforcement
367
+
368
+ The plugin API surface is intentionally typed and centralized in
369
+ `QuantumClawPluginApi`. That contract defines the supported registration points and
370
+ the runtime helpers a plugin may rely on.
371
+
372
+ Why this matters:
373
+
374
+ - plugin authors get one stable internal standard
375
+ - core can reject duplicate ownership such as two plugins registering the same
376
+ provider id
377
+ - startup can surface actionable diagnostics for malformed registration
378
+ - contract tests can enforce bundled-plugin ownership and prevent silent drift
379
+
380
+ There are two layers of enforcement:
381
+
382
+ 1. **runtime registration enforcement**
383
+ The plugin registry validates registrations as plugins load. Examples:
384
+ duplicate provider ids, duplicate speech provider ids, and malformed
385
+ registrations produce plugin diagnostics instead of undefined behavior.
386
+ 2. **contract tests**
387
+ Bundled plugins are captured in contract registries during test runs so
388
+ QuantumClaw can assert ownership explicitly. Today this is used for model
389
+ providers, speech providers, web search providers, and bundled registration
390
+ ownership.
391
+
392
+ The practical effect is that QuantumClaw knows, up front, which plugin owns which
393
+ surface. That lets core and channels compose seamlessly because ownership is
394
+ declared, typed, and testable rather than implicit.
395
+
396
+ ### What belongs in a contract
397
+
398
+ Good plugin contracts are:
399
+
400
+ - typed
401
+ - small
402
+ - capability-specific
403
+ - owned by core
404
+ - reusable by multiple plugins
405
+ - consumable by channels/features without vendor knowledge
406
+
407
+ Bad plugin contracts are:
408
+
409
+ - vendor-specific policy hidden in core
410
+ - one-off plugin escape hatches that bypass the registry
411
+ - channel code reaching straight into a vendor implementation
412
+ - ad hoc runtime objects that are not part of `QuantumClawPluginApi` or
413
+ `api.runtime`
414
+
415
+ When in doubt, raise the abstraction level: define the capability first, then
416
+ let plugins plug into it.
417
+
418
+ ## Execution model
419
+
420
+ Native QuantumClaw plugins run **in-process** with the Gateway. They are not
421
+ sandboxed. A loaded native plugin has the same process-level trust boundary as
422
+ core code.
423
+
424
+ Implications:
425
+
426
+ - a native plugin can register tools, network handlers, hooks, and services
427
+ - a native plugin bug can crash or destabilize the gateway
428
+ - a malicious native plugin is equivalent to arbitrary code execution inside
429
+ the QuantumClaw process
430
+
431
+ Compatible bundles are safer by default because QuantumClaw currently treats them
432
+ as metadata/content packs. In current releases, that mostly means bundled
433
+ skills.
434
+
435
+ Use allowlists and explicit install/load paths for non-bundled plugins. Treat
436
+ workspace plugins as development-time code, not production defaults.
437
+
438
+ Important trust note:
439
+
440
+ - `plugins.allow` trusts **plugin ids**, not source provenance.
441
+ - A workspace plugin with the same id as a bundled plugin intentionally shadows
442
+ the bundled copy when that workspace plugin is enabled/allowlisted.
443
+ - This is normal and useful for local development, patch testing, and hotfixes.
444
+
445
+ ## Export boundary
446
+
447
+ QuantumClaw exports capabilities, not implementation convenience.
448
+
449
+ Keep capability registration public. Trim non-contract helper exports:
450
+
451
+ - bundled-plugin-specific helper subpaths
452
+ - runtime plumbing subpaths not intended as public API
453
+ - vendor-specific convenience helpers
454
+ - setup/onboarding helpers that are implementation details
455
+
456
+ ## Load pipeline
457
+
458
+ At startup, QuantumClaw does roughly this:
459
+
460
+ 1. discover candidate plugin roots
461
+ 2. read native or compatible bundle manifests and package metadata
462
+ 3. reject unsafe candidates
463
+ 4. normalize plugin config (`plugins.enabled`, `allow`, `deny`, `entries`,
464
+ `slots`, `load.paths`)
465
+ 5. decide enablement for each candidate
466
+ 6. load enabled native modules via jiti
467
+ 7. call native `register(api)` hooks and collect registrations into the plugin registry
468
+ 8. expose the registry to commands/runtime surfaces
469
+
470
+ The safety gates happen **before** runtime execution. Candidates are blocked
471
+ when the entry escapes the plugin root, the path is world-writable, or path
472
+ ownership looks suspicious for non-bundled plugins.
473
+
474
+ ### Manifest-first behavior
475
+
476
+ The manifest is the control-plane source of truth. QuantumClaw uses it to:
477
+
478
+ - identify the plugin
479
+ - discover declared channels/skills/config schema or bundle capabilities
480
+ - validate `plugins.entries.<id>.config`
481
+ - augment Control UI labels/placeholders
482
+ - show install/catalog metadata
483
+
484
+ For native plugins, the runtime module is the data-plane part. It registers
485
+ actual behavior such as hooks, tools, commands, or provider flows.
486
+
487
+ ### What the loader caches
488
+
489
+ QuantumClaw keeps short in-process caches for:
490
+
491
+ - discovery results
492
+ - manifest registry data
493
+ - loaded plugin registries
494
+
495
+ These caches reduce bursty startup and repeated command overhead. They are safe
496
+ to think of as short-lived performance caches, not persistence.
497
+
498
+ Performance note:
499
+
500
+ - Set `QUANTUMCLAW_DISABLE_PLUGIN_DISCOVERY_CACHE=1` or
501
+ `QUANTUMCLAW_DISABLE_PLUGIN_MANIFEST_CACHE=1` to disable these caches.
502
+ - Tune cache windows with `QUANTUMCLAW_PLUGIN_DISCOVERY_CACHE_MS` and
503
+ `QUANTUMCLAW_PLUGIN_MANIFEST_CACHE_MS`.
504
+
505
+ ## Registry model
506
+
507
+ Loaded plugins do not directly mutate random core globals. They register into a
508
+ central plugin registry.
509
+
510
+ The registry tracks:
511
+
512
+ - plugin records (identity, source, origin, status, diagnostics)
513
+ - tools
514
+ - legacy hooks and typed hooks
515
+ - channels
516
+ - providers
517
+ - gateway RPC handlers
518
+ - HTTP routes
519
+ - CLI registrars
520
+ - background services
521
+ - plugin-owned commands
522
+
523
+ Core features then read from that registry instead of talking to plugin modules
524
+ directly. This keeps loading one-way:
525
+
526
+ - plugin module -> registry registration
527
+ - core runtime -> registry consumption
528
+
529
+ That separation matters for maintainability. It means most core surfaces only
530
+ need one integration point: "read the registry", not "special-case every plugin
531
+ module".
532
+
533
+ ## Conversation binding callbacks
534
+
535
+ Plugins that bind a conversation can react when an approval is resolved.
536
+
537
+ Use `api.onConversationBindingResolved(...)` to receive a callback after a bind
538
+ request is approved or denied:
539
+
540
+ ```ts
541
+ export default {
542
+ id: "my-plugin",
543
+ register(api) {
544
+ api.onConversationBindingResolved(async (event) => {
545
+ if (event.status === "approved") {
546
+ // A binding now exists for this plugin + conversation.
547
+ console.log(event.binding?.conversationId);
548
+ return;
549
+ }
550
+
551
+ // The request was denied; clear any local pending state.
552
+ console.log(event.request.conversation.conversationId);
553
+ });
554
+ },
555
+ };
556
+ ```
557
+
558
+ Callback payload fields:
559
+
560
+ - `status`: `"approved"` or `"denied"`
561
+ - `decision`: `"allow-once"`, `"allow-always"`, or `"deny"`
562
+ - `binding`: the resolved binding for approved requests
563
+ - `request`: the original request summary, detach hint, sender id, and
564
+ conversation metadata
565
+
566
+ This callback is notification-only. It does not change who is allowed to bind a
567
+ conversation, and it runs after core approval handling finishes.
568
+
569
+ ## Provider runtime hooks
570
+
571
+ Provider plugins now have two layers:
572
+
573
+ - manifest metadata: `providerAuthEnvVars` for cheap env-auth lookup before
574
+ runtime load, plus `providerAuthChoices` for cheap onboarding/auth-choice
575
+ labels and CLI flag metadata before runtime load
576
+ - config-time hooks: `catalog` / legacy `discovery`
577
+ - runtime hooks: `resolveDynamicModel`, `prepareDynamicModel`, `normalizeResolvedModel`, `capabilities`, `prepareExtraParams`, `wrapStreamFn`, `formatApiKey`, `refreshOAuth`, `buildAuthDoctorHint`, `isCacheTtlEligible`, `buildMissingAuthMessage`, `suppressBuiltInModel`, `augmentModelCatalog`, `isBinaryThinking`, `supportsXHighThinking`, `resolveDefaultThinkingLevel`, `isModernModelRef`, `prepareRuntimeAuth`, `resolveUsageAuth`, `fetchUsageSnapshot`
578
+
579
+ QuantumClaw still owns the generic agent loop, failover, transcript handling, and
580
+ tool policy. These hooks are the extension surface for provider-specific behavior without
581
+ needing a whole custom inference transport.
582
+
583
+ Use manifest `providerAuthEnvVars` when the provider has env-based credentials
584
+ that generic auth/status/model-picker paths should see without loading plugin
585
+ runtime. Use manifest `providerAuthChoices` when onboarding/auth-choice CLI
586
+ surfaces should know the provider's choice id, group labels, and simple
587
+ one-flag auth wiring without loading provider runtime. Keep provider runtime
588
+ `envVars` for operator-facing hints such as onboarding labels or OAuth
589
+ client-id/client-secret setup vars.
590
+
591
+ ### Hook order and usage
592
+
593
+ For model/provider plugins, QuantumClaw calls hooks in this rough order.
594
+ The "When to use" column is the quick decision guide.
595
+
596
+ | # | Hook | What it does | When to use |
597
+ | --- | ----------------------------- | ---------------------------------------------------------------------------------------- | ------------------------------------------------------------------------------------ |
598
+ | 1 | `catalog` | Publish provider config into `models.providers` during `models.json` generation | Provider owns a catalog or base URL defaults |
599
+ | -- | _(built-in model lookup)_ | QuantumClaw tries the normal registry/catalog path first | _(not a plugin hook)_ |
600
+ | 2 | `resolveDynamicModel` | Sync fallback for provider-owned model ids not in the local registry yet | Provider accepts arbitrary upstream model ids |
601
+ | 3 | `prepareDynamicModel` | Async warm-up, then `resolveDynamicModel` runs again | Provider needs network metadata before resolving unknown ids |
602
+ | 4 | `normalizeResolvedModel` | Final rewrite before the embedded runner uses the resolved model | Provider needs transport rewrites but still uses a core transport |
603
+ | 5 | `capabilities` | Provider-owned transcript/tooling metadata used by shared core logic | Provider needs transcript/provider-family quirks |
604
+ | 6 | `prepareExtraParams` | Request-param normalization before generic stream option wrappers | Provider needs default request params or per-provider param cleanup |
605
+ | 7 | `wrapStreamFn` | Stream wrapper after generic wrappers are applied | Provider needs request headers/body/model compat wrappers without a custom transport |
606
+ | 8 | `formatApiKey` | Auth-profile formatter: stored profile becomes the runtime `apiKey` string | Provider stores extra auth metadata and needs a custom runtime token shape |
607
+ | 9 | `refreshOAuth` | OAuth refresh override for custom refresh endpoints or refresh-failure policy | Provider does not fit the shared `pi-ai` refreshers |
608
+ | 10 | `buildAuthDoctorHint` | Repair hint appended when OAuth refresh fails | Provider needs provider-owned auth repair guidance after refresh failure |
609
+ | 11 | `isCacheTtlEligible` | Prompt-cache policy for proxy/backhaul providers | Provider needs proxy-specific cache TTL gating |
610
+ | 12 | `buildMissingAuthMessage` | Replacement for the generic missing-auth recovery message | Provider needs a provider-specific missing-auth recovery hint |
611
+ | 13 | `suppressBuiltInModel` | Stale upstream model suppression plus optional user-facing error hint | Provider needs to hide stale upstream rows or replace them with a vendor hint |
612
+ | 14 | `augmentModelCatalog` | Synthetic/final catalog rows appended after discovery | Provider needs synthetic forward-compat rows in `models list` and pickers |
613
+ | 15 | `isBinaryThinking` | On/off reasoning toggle for binary-thinking providers | Provider exposes only binary thinking on/off |
614
+ | 16 | `supportsXHighThinking` | `xhigh` reasoning support for selected models | Provider wants `xhigh` on only a subset of models |
615
+ | 17 | `resolveDefaultThinkingLevel` | Default `/think` level for a specific model family | Provider owns default `/think` policy for a model family |
616
+ | 18 | `isModernModelRef` | Modern-model matcher for live profile filters and smoke selection | Provider owns live/smoke preferred-model matching |
617
+ | 19 | `prepareRuntimeAuth` | Exchange a configured credential into the actual runtime token/key just before inference | Provider needs a token exchange or short-lived request credential |
618
+ | 20 | `resolveUsageAuth` | Resolve usage/billing credentials for `/usage` and related status surfaces | Provider needs custom usage/quota token parsing or a different usage credential |
619
+ | 21 | `fetchUsageSnapshot` | Fetch and normalize provider-specific usage/quota snapshots after auth is resolved | Provider needs a provider-specific usage endpoint or payload parser |
620
+
621
+ If the provider needs a fully custom wire protocol or custom request executor,
622
+ that is a different class of extension. These hooks are for provider behavior
623
+ that still runs on QuantumClaw's normal inference loop.
624
+
625
+ ### Provider example
626
+
627
+ ```ts
628
+ api.registerProvider({
629
+ id: "example-proxy",
630
+ label: "Example Proxy",
631
+ auth: [],
632
+ catalog: {
633
+ order: "simple",
634
+ run: async (ctx) => {
635
+ const apiKey = ctx.resolveProviderApiKey("example-proxy").apiKey;
636
+ if (!apiKey) {
637
+ return null;
638
+ }
639
+ return {
640
+ provider: {
641
+ baseUrl: "https://proxy.example.com/v1",
642
+ apiKey,
643
+ api: "openai-completions",
644
+ models: [{ id: "auto", name: "Auto" }],
645
+ },
646
+ };
647
+ },
648
+ },
649
+ resolveDynamicModel: (ctx) => ({
650
+ id: ctx.modelId,
651
+ name: ctx.modelId,
652
+ provider: "example-proxy",
653
+ api: "openai-completions",
654
+ baseUrl: "https://proxy.example.com/v1",
655
+ reasoning: false,
656
+ input: ["text"],
657
+ cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
658
+ contextWindow: 128000,
659
+ maxTokens: 8192,
660
+ }),
661
+ prepareRuntimeAuth: async (ctx) => {
662
+ const exchanged = await exchangeToken(ctx.apiKey);
663
+ return {
664
+ apiKey: exchanged.token,
665
+ baseUrl: exchanged.baseUrl,
666
+ expiresAt: exchanged.expiresAt,
667
+ };
668
+ },
669
+ resolveUsageAuth: async (ctx) => {
670
+ const auth = await ctx.resolveOAuthToken();
671
+ return auth ? { token: auth.token } : null;
672
+ },
673
+ fetchUsageSnapshot: async (ctx) => {
674
+ return await fetchExampleProxyUsage(ctx.token, ctx.timeoutMs, ctx.fetchFn);
675
+ },
676
+ });
677
+ ```
678
+
679
+ ### Built-in examples
680
+
681
+ - Anthropic uses `resolveDynamicModel`, `capabilities`, `buildAuthDoctorHint`,
682
+ `resolveUsageAuth`, `fetchUsageSnapshot`, `isCacheTtlEligible`,
683
+ `resolveDefaultThinkingLevel`, and `isModernModelRef` because it owns Claude
684
+ 4.6 forward-compat, provider-family hints, auth repair guidance, usage
685
+ endpoint integration, prompt-cache eligibility, and Claude default/adaptive
686
+ thinking policy.
687
+ - OpenAI uses `resolveDynamicModel`, `normalizeResolvedModel`, and
688
+ `capabilities` plus `buildMissingAuthMessage`, `suppressBuiltInModel`,
689
+ `augmentModelCatalog`, `supportsXHighThinking`, and `isModernModelRef`
690
+ because it owns GPT-5.4 forward-compat, the direct OpenAI
691
+ `openai-completions` -> `openai-responses` normalization, Codex-aware auth
692
+ hints, Spark suppression, synthetic OpenAI list rows, and GPT-5 thinking /
693
+ live-model policy.
694
+ - OpenRouter uses `catalog` plus `resolveDynamicModel` and
695
+ `prepareDynamicModel` because the provider is pass-through and may expose new
696
+ model ids before QuantumClaw's static catalog updates; it also uses
697
+ `capabilities`, `wrapStreamFn`, and `isCacheTtlEligible` to keep
698
+ provider-specific request headers, routing metadata, reasoning patches, and
699
+ prompt-cache policy out of core.
700
+ - GitHub Copilot uses `catalog`, `auth`, `resolveDynamicModel`, and
701
+ `capabilities` plus `prepareRuntimeAuth` and `fetchUsageSnapshot` because it
702
+ needs provider-owned device login, model fallback behavior, Claude transcript
703
+ quirks, a GitHub token -> Copilot token exchange, and a provider-owned usage
704
+ endpoint.
705
+ - OpenAI Codex uses `catalog`, `resolveDynamicModel`,
706
+ `normalizeResolvedModel`, `refreshOAuth`, and `augmentModelCatalog` plus
707
+ `prepareExtraParams`, `resolveUsageAuth`, and `fetchUsageSnapshot` because it
708
+ still runs on core OpenAI transports but owns its transport/base URL
709
+ normalization, OAuth refresh fallback policy, default transport choice,
710
+ synthetic Codex catalog rows, and ChatGPT usage endpoint integration.
711
+ - Google AI Studio and Gemini CLI OAuth use `resolveDynamicModel` and
712
+ `isModernModelRef` because they own Gemini 3.1 forward-compat fallback and
713
+ modern-model matching; Gemini CLI OAuth also uses `formatApiKey`,
714
+ `resolveUsageAuth`, and `fetchUsageSnapshot` for token formatting, token
715
+ parsing, and quota endpoint wiring.
716
+ - Moonshot uses `catalog` plus `wrapStreamFn` because it still uses the shared
717
+ OpenAI transport but needs provider-owned thinking payload normalization.
718
+ - Kilocode uses `catalog`, `capabilities`, `wrapStreamFn`, and
719
+ `isCacheTtlEligible` because it needs provider-owned request headers,
720
+ reasoning payload normalization, Gemini transcript hints, and Anthropic
721
+ cache-TTL gating.
722
+ - Z.AI uses `resolveDynamicModel`, `prepareExtraParams`, `wrapStreamFn`,
723
+ `isCacheTtlEligible`, `isBinaryThinking`, `isModernModelRef`,
724
+ `resolveUsageAuth`, and `fetchUsageSnapshot` because it owns GLM-5 fallback,
725
+ `tool_stream` defaults, binary thinking UX, modern-model matching, and both
726
+ usage auth + quota fetching.
727
+ - Mistral, OpenCode Zen, and OpenCode Go use `capabilities` only to keep
728
+ transcript/tooling quirks out of core.
729
+ - Catalog-only bundled providers such as `byteplus`, `cloudflare-ai-gateway`,
730
+ `huggingface`, `kimi-coding`, `modelstudio`, `nvidia`, `qianfan`,
731
+ `synthetic`, `together`, `venice`, `vercel-ai-gateway`, and `volcengine` use
732
+ `catalog` only.
733
+ - Qwen portal uses `catalog`, `auth`, and `refreshOAuth`.
734
+ - MiniMax and Xiaomi use `catalog` plus usage hooks because their `/usage`
735
+ behavior is plugin-owned even though inference still runs through the shared
736
+ transports.
737
+
738
+ ## Runtime helpers
739
+
740
+ Plugins can access selected core helpers via `api.runtime`. For TTS:
741
+
742
+ ```ts
743
+ const clip = await api.runtime.tts.textToSpeech({
744
+ text: "Hello from QuantumClaw",
745
+ cfg: api.config,
746
+ });
747
+
748
+ const result = await api.runtime.tts.textToSpeechTelephony({
749
+ text: "Hello from QuantumClaw",
750
+ cfg: api.config,
751
+ });
752
+
753
+ const voices = await api.runtime.tts.listVoices({
754
+ provider: "elevenlabs",
755
+ cfg: api.config,
756
+ });
757
+ ```
758
+
759
+ Notes:
760
+
761
+ - `textToSpeech` returns the normal core TTS output payload for file/voice-note surfaces.
762
+ - Uses core `messages.tts` configuration and provider selection.
763
+ - Returns PCM audio buffer + sample rate. Plugins must resample/encode for providers.
764
+ - `listVoices` is optional per provider. Use it for vendor-owned voice pickers or setup flows.
765
+ - Voice listings can include richer metadata such as locale, gender, and personality tags for provider-aware pickers.
766
+ - OpenAI and ElevenLabs support telephony today. Microsoft does not.
767
+
768
+ Plugins can also register speech providers via `api.registerSpeechProvider(...)`.
769
+
770
+ ```ts
771
+ api.registerSpeechProvider({
772
+ id: "acme-speech",
773
+ label: "Acme Speech",
774
+ isConfigured: ({ config }) => Boolean(config.messages?.tts),
775
+ synthesize: async (req) => {
776
+ return {
777
+ audioBuffer: Buffer.from([]),
778
+ outputFormat: "mp3",
779
+ fileExtension: ".mp3",
780
+ voiceCompatible: false,
781
+ };
782
+ },
783
+ });
784
+ ```
785
+
786
+ Notes:
787
+
788
+ - Keep TTS policy, fallback, and reply delivery in core.
789
+ - Use speech providers for vendor-owned synthesis behavior.
790
+ - Legacy Microsoft `edge` input is normalized to the `microsoft` provider id.
791
+ - The preferred ownership model is company-oriented: one vendor plugin can own
792
+ text, speech, image, and future media providers as QuantumClaw adds those
793
+ capability contracts.
794
+
795
+ For image/audio/video understanding, plugins register one typed
796
+ media-understanding provider instead of a generic key/value bag:
797
+
798
+ ```ts
799
+ api.registerMediaUnderstandingProvider({
800
+ id: "google",
801
+ capabilities: ["image", "audio", "video"],
802
+ describeImage: async (req) => ({ text: "..." }),
803
+ transcribeAudio: async (req) => ({ text: "..." }),
804
+ describeVideo: async (req) => ({ text: "..." }),
805
+ });
806
+ ```
807
+
808
+ Notes:
809
+
810
+ - Keep orchestration, fallback, config, and channel wiring in core.
811
+ - Keep vendor behavior in the provider plugin.
812
+ - Additive expansion should stay typed: new optional methods, new optional
813
+ result fields, new optional capabilities.
814
+ - If QuantumClaw adds a new capability such as video generation later, define the
815
+ core capability contract first, then let vendor plugins register against it.
816
+
817
+ For media-understanding runtime helpers, plugins can call:
818
+
819
+ ```ts
820
+ const image = await api.runtime.mediaUnderstanding.describeImageFile({
821
+ filePath: "/tmp/inbound-photo.jpg",
822
+ cfg: api.config,
823
+ agentDir: "/tmp/agent",
824
+ });
825
+
826
+ const video = await api.runtime.mediaUnderstanding.describeVideoFile({
827
+ filePath: "/tmp/inbound-video.mp4",
828
+ cfg: api.config,
829
+ });
830
+ ```
831
+
832
+ For audio transcription, plugins can use either the media-understanding runtime
833
+ or the older STT alias:
834
+
835
+ ```ts
836
+ const { text } = await api.runtime.mediaUnderstanding.transcribeAudioFile({
837
+ filePath: "/tmp/inbound-audio.ogg",
838
+ cfg: api.config,
839
+ // Optional when MIME cannot be inferred reliably:
840
+ mime: "audio/ogg",
841
+ });
842
+ ```
843
+
844
+ Notes:
845
+
846
+ - `api.runtime.mediaUnderstanding.*` is the preferred shared surface for
847
+ image/audio/video understanding.
848
+ - Uses core media-understanding audio configuration (`tools.media.audio`) and provider fallback order.
849
+ - Returns `{ text: undefined }` when no transcription output is produced (for example skipped/unsupported input).
850
+ - `api.runtime.stt.transcribeAudioFile(...)` remains as a compatibility alias.
851
+
852
+ Plugins can also launch background subagent runs through `api.runtime.subagent`:
853
+
854
+ ```ts
855
+ const result = await api.runtime.subagent.run({
856
+ sessionKey: "agent:main:subagent:search-helper",
857
+ message: "Expand this query into focused follow-up searches.",
858
+ provider: "openai",
859
+ model: "gpt-4.1-mini",
860
+ deliver: false,
861
+ });
862
+ ```
863
+
864
+ Notes:
865
+
866
+ - `provider` and `model` are optional per-run overrides, not persistent session changes.
867
+ - QuantumClaw only honors those override fields for trusted callers.
868
+ - For plugin-owned fallback runs, operators must opt in with `plugins.entries.<id>.subagent.allowModelOverride: true`.
869
+ - Use `plugins.entries.<id>.subagent.allowedModels` to restrict trusted plugins to specific canonical `provider/model` targets, or `"*"` to allow any target explicitly.
870
+ - Untrusted plugin subagent runs still work, but override requests are rejected instead of silently falling back.
871
+
872
+ For web search, plugins can consume the shared runtime helper instead of
873
+ reaching into the agent tool wiring:
874
+
875
+ ```ts
876
+ const providers = api.runtime.webSearch.listProviders({
877
+ config: api.config,
878
+ });
879
+
880
+ const result = await api.runtime.webSearch.search({
881
+ config: api.config,
882
+ args: {
883
+ query: "QuantumClaw plugin runtime helpers",
884
+ count: 5,
885
+ },
886
+ });
887
+ ```
888
+
889
+ Plugins can also register web-search providers via
890
+ `api.registerWebSearchProvider(...)`.
891
+
892
+ Notes:
893
+
894
+ - Keep provider selection, credential resolution, and shared request semantics in core.
895
+ - Use web-search providers for vendor-specific search transports.
896
+ - `api.runtime.webSearch.*` is the preferred shared surface for feature/channel plugins that need search behavior without depending on the agent tool wrapper.
897
+
898
+ ## Gateway HTTP routes
899
+
900
+ Plugins can expose HTTP endpoints with `api.registerHttpRoute(...)`.
901
+
902
+ ```ts
903
+ api.registerHttpRoute({
904
+ path: "/acme/webhook",
905
+ auth: "plugin",
906
+ match: "exact",
907
+ handler: async (_req, res) => {
908
+ res.statusCode = 200;
909
+ res.end("ok");
910
+ return true;
911
+ },
912
+ });
913
+ ```
914
+
915
+ Route fields:
916
+
917
+ - `path`: route path under the gateway HTTP server.
918
+ - `auth`: required. Use `"gateway"` to require normal gateway auth, or `"plugin"` for plugin-managed auth/webhook verification.
919
+ - `match`: optional. `"exact"` (default) or `"prefix"`.
920
+ - `replaceExisting`: optional. Allows the same plugin to replace its own existing route registration.
921
+ - `handler`: return `true` when the route handled the request.
922
+
923
+ Notes:
924
+
925
+ - `api.registerHttpHandler(...)` is obsolete. Use `api.registerHttpRoute(...)`.
926
+ - Plugin routes must declare `auth` explicitly.
927
+ - Exact `path + match` conflicts are rejected unless `replaceExisting: true`, and one plugin cannot replace another plugin's route.
928
+ - Overlapping routes with different `auth` levels are rejected. Keep `exact`/`prefix` fallthrough chains on the same auth level only.
929
+
930
+ ## Plugin SDK import paths
931
+
932
+ Use SDK subpaths instead of the monolithic `quantumclaw/plugin-sdk` import when
933
+ authoring plugins:
934
+
935
+ - `quantumclaw/plugin-sdk/plugin-entry` for plugin registration primitives.
936
+ - `quantumclaw/plugin-sdk/core` for the generic shared plugin-facing contract.
937
+ - Stable channel primitives such as `quantumclaw/plugin-sdk/channel-setup`,
938
+ `quantumclaw/plugin-sdk/channel-pairing`,
939
+ `quantumclaw/plugin-sdk/channel-contract`,
940
+ `quantumclaw/plugin-sdk/channel-feedback`,
941
+ `quantumclaw/plugin-sdk/channel-inbound`,
942
+ `quantumclaw/plugin-sdk/channel-lifecycle`,
943
+ `quantumclaw/plugin-sdk/channel-reply-pipeline`,
944
+ `quantumclaw/plugin-sdk/command-auth`,
945
+ `quantumclaw/plugin-sdk/secret-input`, and
946
+ `quantumclaw/plugin-sdk/webhook-ingress` for shared setup/auth/reply/webhook
947
+ wiring. `channel-inbound` is the shared home for debounce, mention matching,
948
+ envelope formatting, and inbound envelope context helpers.
949
+ - Domain subpaths such as `quantumclaw/plugin-sdk/channel-config-helpers`,
950
+ `quantumclaw/plugin-sdk/allow-from`,
951
+ `quantumclaw/plugin-sdk/channel-config-schema`,
952
+ `quantumclaw/plugin-sdk/channel-policy`,
953
+ `quantumclaw/plugin-sdk/config-runtime`,
954
+ `quantumclaw/plugin-sdk/infra-runtime`,
955
+ `quantumclaw/plugin-sdk/agent-runtime`,
956
+ `quantumclaw/plugin-sdk/lazy-runtime`,
957
+ `quantumclaw/plugin-sdk/reply-history`,
958
+ `quantumclaw/plugin-sdk/routing`,
959
+ `quantumclaw/plugin-sdk/status-helpers`,
960
+ `quantumclaw/plugin-sdk/runtime-store`, and
961
+ `quantumclaw/plugin-sdk/directory-runtime` for shared runtime/config helpers.
962
+ - `quantumclaw/plugin-sdk/channel-runtime` remains only as a compatibility shim.
963
+ New code should import the narrower primitives instead.
964
+ - Bundled extension internals remain private. External plugins should use only
965
+ `quantumclaw/plugin-sdk/*` subpaths. QuantumClaw core/test code may use the repo
966
+ public entry points under `extensions/<id>/index.js`, `api.js`, `runtime-api.js`,
967
+ `setup-entry.js`, and narrowly scoped files such as `login-qr-api.js`. Never
968
+ import `extensions/<id>/src/*` from core or from another extension.
969
+ - Repo entry point split:
970
+ `extensions/<id>/api.js` is the helper/types barrel,
971
+ `extensions/<id>/runtime-api.js` is the runtime-only barrel,
972
+ `extensions/<id>/index.js` is the bundled plugin entry,
973
+ and `extensions/<id>/setup-entry.js` is the setup plugin entry.
974
+ - No bundled channel-branded public subpaths remain. Channel-specific helper and
975
+ runtime seams live under `extensions/<id>/api.js` and `extensions/<id>/runtime-api.js`;
976
+ the public SDK contract is the generic shared primitives instead.
977
+
978
+ Compatibility note:
979
+
980
+ - Avoid the root `quantumclaw/plugin-sdk` barrel for new code.
981
+ - Prefer the narrow stable primitives first. The newer setup/pairing/reply/
982
+ feedback/contract/inbound/threading/command/secret-input/webhook/infra/
983
+ allowlist/status/message-tool subpaths are the intended contract for new
984
+ bundled and external plugin work.
985
+ Target parsing/matching belongs on `quantumclaw/plugin-sdk/channel-targets`.
986
+ Message action gates and reaction message-id helpers belong on
987
+ `quantumclaw/plugin-sdk/channel-actions`.
988
+ - Bundled extension-specific helper barrels are not stable by default. If a
989
+ helper is only needed by a bundled extension, keep it behind the extension's
990
+ local `api.js` or `runtime-api.js` seam instead of promoting it into
991
+ `quantumclaw/plugin-sdk/<extension>`.
992
+ - Channel-branded bundled bars stay private unless they are explicitly added
993
+ back to the public contract.
994
+ - Capability-specific subpaths such as `image-generation`,
995
+ `media-understanding`, and `speech` exist because bundled/native plugins use
996
+ them today. Their presence does not by itself mean every exported helper is a
997
+ long-term frozen external contract.
998
+
999
+ ## Message tool schemas
1000
+
1001
+ Plugins should own channel-specific `describeMessageTool(...)` schema
1002
+ contributions. Keep provider-specific fields in the plugin, not in shared core.
1003
+
1004
+ For shared portable schema fragments, reuse the generic helpers exported through
1005
+ `quantumclaw/plugin-sdk/channel-actions`:
1006
+
1007
+ - `createMessageToolButtonsSchema()` for button-grid style payloads
1008
+ - `createMessageToolCardSchema()` for structured card payloads
1009
+
1010
+ If a schema shape only makes sense for one provider, define it in that plugin's
1011
+ own source instead of promoting it into the shared SDK.
1012
+
1013
+ ## Channel target resolution
1014
+
1015
+ Channel plugins should own channel-specific target semantics. Keep the shared
1016
+ outbound host generic and use the messaging adapter surface for provider rules:
1017
+
1018
+ - `messaging.inferTargetChatType({ to })` decides whether a normalized target
1019
+ should be treated as `direct`, `group`, or `channel` before directory lookup.
1020
+ - `messaging.targetResolver.looksLikeId(raw, normalized)` tells core whether an
1021
+ input should skip straight to id-like resolution instead of directory search.
1022
+ - `messaging.targetResolver.resolveTarget(...)` is the plugin fallback when
1023
+ core needs a final provider-owned resolution after normalization or after a
1024
+ directory miss.
1025
+ - `messaging.resolveOutboundSessionRoute(...)` owns provider-specific session
1026
+ route construction once a target is resolved.
1027
+
1028
+ Recommended split:
1029
+
1030
+ - Use `inferTargetChatType` for category decisions that should happen before
1031
+ searching peers/groups.
1032
+ - Use `looksLikeId` for "treat this as an explicit/native target id" checks.
1033
+ - Use `resolveTarget` for provider-specific normalization fallback, not for
1034
+ broad directory search.
1035
+ - Keep provider-native ids like chat ids, thread ids, JIDs, handles, and room
1036
+ ids inside `target` values or provider-specific params, not in generic SDK
1037
+ fields.
1038
+
1039
+ ## Config-backed directories
1040
+
1041
+ Plugins that derive directory entries from config should keep that logic in the
1042
+ plugin and reuse the shared helpers from
1043
+ `quantumclaw/plugin-sdk/directory-runtime`.
1044
+
1045
+ Use this when a channel needs config-backed peers/groups such as:
1046
+
1047
+ - allowlist-driven DM peers
1048
+ - configured channel/group maps
1049
+ - account-scoped static directory fallbacks
1050
+
1051
+ The shared helpers in `directory-runtime` only handle generic operations:
1052
+
1053
+ - query filtering
1054
+ - limit application
1055
+ - deduping/normalization helpers
1056
+ - building `ChannelDirectoryEntry[]`
1057
+
1058
+ Channel-specific account inspection and id normalization should stay in the
1059
+ plugin implementation.
1060
+
1061
+ ## Provider catalogs
1062
+
1063
+ Provider plugins can define model catalogs for inference with
1064
+ `registerProvider({ catalog: { run(...) { ... } } })`.
1065
+
1066
+ `catalog.run(...)` returns the same shape QuantumClaw writes into
1067
+ `models.providers`:
1068
+
1069
+ - `{ provider }` for one provider entry
1070
+ - `{ providers }` for multiple provider entries
1071
+
1072
+ Use `catalog` when the plugin owns provider-specific model ids, base URL
1073
+ defaults, or auth-gated model metadata.
1074
+
1075
+ `catalog.order` controls when a plugin's catalog merges relative to QuantumClaw's
1076
+ built-in implicit providers:
1077
+
1078
+ - `simple`: plain API-key or env-driven providers
1079
+ - `profile`: providers that appear when auth profiles exist
1080
+ - `paired`: providers that synthesize multiple related provider entries
1081
+ - `late`: last pass, after other implicit providers
1082
+
1083
+ Later providers win on key collision, so plugins can intentionally override a
1084
+ built-in provider entry with the same provider id.
1085
+
1086
+ Compatibility:
1087
+
1088
+ - `discovery` still works as a legacy alias
1089
+ - if both `catalog` and `discovery` are registered, QuantumClaw uses `catalog`
1090
+
1091
+ ## Read-only channel inspection
1092
+
1093
+ If your plugin registers a channel, prefer implementing
1094
+ `plugin.config.inspectAccount(cfg, accountId)` alongside `resolveAccount(...)`.
1095
+
1096
+ Why:
1097
+
1098
+ - `resolveAccount(...)` is the runtime path. It is allowed to assume credentials
1099
+ are fully materialized and can fail fast when required secrets are missing.
1100
+ - Read-only command paths such as `quantumclaw status`, `quantumclaw status --all`,
1101
+ `quantumclaw channels status`, `quantumclaw channels resolve`, and doctor/config
1102
+ repair flows should not need to materialize runtime credentials just to
1103
+ describe configuration.
1104
+
1105
+ Recommended `inspectAccount(...)` behavior:
1106
+
1107
+ - Return descriptive account state only.
1108
+ - Preserve `enabled` and `configured`.
1109
+ - Include credential source/status fields when relevant, such as:
1110
+ - `tokenSource`, `tokenStatus`
1111
+ - `botTokenSource`, `botTokenStatus`
1112
+ - `appTokenSource`, `appTokenStatus`
1113
+ - `signingSecretSource`, `signingSecretStatus`
1114
+ - You do not need to return raw token values just to report read-only
1115
+ availability. Returning `tokenStatus: "available"` (and the matching source
1116
+ field) is enough for status-style commands.
1117
+ - Use `configured_unavailable` when a credential is configured via SecretRef but
1118
+ unavailable in the current command path.
1119
+
1120
+ This lets read-only commands report "configured but unavailable in this command
1121
+ path" instead of crashing or misreporting the account as not configured.
1122
+
1123
+ ## Package packs
1124
+
1125
+ A plugin directory may include a `package.json` with `quantumclaw.extensions`:
1126
+
1127
+ ```json
1128
+ {
1129
+ "name": "my-pack",
1130
+ "quantumclaw": {
1131
+ "extensions": ["./src/safety.ts", "./src/tools.ts"],
1132
+ "setupEntry": "./src/setup-entry.ts"
1133
+ }
1134
+ }
1135
+ ```
1136
+
1137
+ Each entry becomes a plugin. If the pack lists multiple extensions, the plugin id
1138
+ becomes `name/<fileBase>`.
1139
+
1140
+ If your plugin imports npm deps, install them in that directory so
1141
+ `node_modules` is available (`npm install` / `pnpm install`).
1142
+
1143
+ Security guardrail: every `quantumclaw.extensions` entry must stay inside the plugin
1144
+ directory after symlink resolution. Entries that escape the package directory are
1145
+ rejected.
1146
+
1147
+ Security note: `quantumclaw plugins install` installs plugin dependencies with
1148
+ `npm install --ignore-scripts` (no lifecycle scripts). Keep plugin dependency
1149
+ trees "pure JS/TS" and avoid packages that require `postinstall` builds.
1150
+
1151
+ Optional: `quantumclaw.setupEntry` can point at a lightweight setup-only module.
1152
+ When QuantumClaw needs setup surfaces for a disabled channel plugin, or
1153
+ when a channel plugin is enabled but still unconfigured, it loads `setupEntry`
1154
+ instead of the full plugin entry. This keeps startup and setup lighter
1155
+ when your main plugin entry also wires tools, hooks, or other runtime-only
1156
+ code.
1157
+
1158
+ Optional: `quantumclaw.startup.deferConfiguredChannelFullLoadUntilAfterListen`
1159
+ can opt a channel plugin into the same `setupEntry` path during the gateway's
1160
+ pre-listen startup phase, even when the channel is already configured.
1161
+
1162
+ Use this only when `setupEntry` fully covers the startup surface that must exist
1163
+ before the gateway starts listening. In practice, that means the setup entry
1164
+ must register every channel-owned capability that startup depends on, such as:
1165
+
1166
+ - channel registration itself
1167
+ - any HTTP routes that must be available before the gateway starts listening
1168
+ - any gateway methods, tools, or services that must exist during that same window
1169
+
1170
+ If your full entry still owns any required startup capability, do not enable
1171
+ this flag. Keep the plugin on the default behavior and let QuantumClaw load the
1172
+ full entry during startup.
1173
+
1174
+ Example:
1175
+
1176
+ ```json
1177
+ {
1178
+ "name": "@scope/my-channel",
1179
+ "quantumclaw": {
1180
+ "extensions": ["./index.ts"],
1181
+ "setupEntry": "./setup-entry.ts",
1182
+ "startup": {
1183
+ "deferConfiguredChannelFullLoadUntilAfterListen": true
1184
+ }
1185
+ }
1186
+ }
1187
+ ```
1188
+
1189
+ ### Channel catalog metadata
1190
+
1191
+ Channel plugins can advertise setup/discovery metadata via `quantumclaw.channel` and
1192
+ install hints via `quantumclaw.install`. This keeps the core catalog data-free.
1193
+
1194
+ Example:
1195
+
1196
+ ```json
1197
+ {
1198
+ "name": "@quantumclaw/nextcloud-talk",
1199
+ "quantumclaw": {
1200
+ "extensions": ["./index.ts"],
1201
+ "channel": {
1202
+ "id": "nextcloud-talk",
1203
+ "label": "Nextcloud Talk",
1204
+ "selectionLabel": "Nextcloud Talk (self-hosted)",
1205
+ "docsPath": "/channels/nextcloud-talk",
1206
+ "docsLabel": "nextcloud-talk",
1207
+ "blurb": "Self-hosted chat via Nextcloud Talk webhook bots.",
1208
+ "order": 65,
1209
+ "aliases": ["nc-talk", "nc"]
1210
+ },
1211
+ "install": {
1212
+ "npmSpec": "@quantumclaw/nextcloud-talk",
1213
+ "localPath": "extensions/nextcloud-talk",
1214
+ "defaultChoice": "npm"
1215
+ }
1216
+ }
1217
+ }
1218
+ ```
1219
+
1220
+ QuantumClaw can also merge **external channel catalogs** (for example, an MPM
1221
+ registry export). Drop a JSON file at one of:
1222
+
1223
+ - `~/.quantumclaw/mpm/plugins.json`
1224
+ - `~/.quantumclaw/mpm/catalog.json`
1225
+ - `~/.quantumclaw/plugins/catalog.json`
1226
+
1227
+ Or point `QUANTUMCLAW_PLUGIN_CATALOG_PATHS` (or `QUANTUMCLAW_MPM_CATALOG_PATHS`) at
1228
+ one or more JSON files (comma/semicolon/`PATH`-delimited). Each file should
1229
+ contain `{ "entries": [ { "name": "@scope/pkg", "quantumclaw": { "channel": {...}, "install": {...} } } ] }`.
1230
+
1231
+ ## Context engine plugins
1232
+
1233
+ Context engine plugins own session context orchestration for ingest, assembly,
1234
+ and compaction. Register them from your plugin with
1235
+ `api.registerContextEngine(id, factory)`, then select the active engine with
1236
+ `plugins.slots.contextEngine`.
1237
+
1238
+ Use this when your plugin needs to replace or extend the default context
1239
+ pipeline rather than just add memory search or hooks.
1240
+
1241
+ ```ts
1242
+ export default function (api) {
1243
+ api.registerContextEngine("lossless-claw", () => ({
1244
+ info: { id: "lossless-claw", name: "Lossless Claw", ownsCompaction: true },
1245
+ async ingest() {
1246
+ return { ingested: true };
1247
+ },
1248
+ async assemble({ messages }) {
1249
+ return { messages, estimatedTokens: 0 };
1250
+ },
1251
+ async compact() {
1252
+ return { ok: true, compacted: false };
1253
+ },
1254
+ }));
1255
+ }
1256
+ ```
1257
+
1258
+ If your engine does **not** own the compaction algorithm, keep `compact()`
1259
+ implemented and delegate it explicitly:
1260
+
1261
+ ```ts
1262
+ import { delegateCompactionToRuntime } from "quantumclaw/plugin-sdk/core";
1263
+
1264
+ export default function (api) {
1265
+ api.registerContextEngine("my-memory-engine", () => ({
1266
+ info: {
1267
+ id: "my-memory-engine",
1268
+ name: "My Memory Engine",
1269
+ ownsCompaction: false,
1270
+ },
1271
+ async ingest() {
1272
+ return { ingested: true };
1273
+ },
1274
+ async assemble({ messages }) {
1275
+ return { messages, estimatedTokens: 0 };
1276
+ },
1277
+ async compact(params) {
1278
+ return await delegateCompactionToRuntime(params);
1279
+ },
1280
+ }));
1281
+ }
1282
+ ```
1283
+
1284
+ ## Adding a new capability
1285
+
1286
+ When a plugin needs behavior that does not fit the current API, do not bypass
1287
+ the plugin system with a private reach-in. Add the missing capability.
1288
+
1289
+ Recommended sequence:
1290
+
1291
+ 1. define the core contract
1292
+ Decide what shared behavior core should own: policy, fallback, config merge,
1293
+ lifecycle, channel-facing semantics, and runtime helper shape.
1294
+ 2. add typed plugin registration/runtime surfaces
1295
+ Extend `QuantumClawPluginApi` and/or `api.runtime` with the smallest useful
1296
+ typed capability surface.
1297
+ 3. wire core + channel/feature consumers
1298
+ Channels and feature plugins should consume the new capability through core,
1299
+ not by importing a vendor implementation directly.
1300
+ 4. register vendor implementations
1301
+ Vendor plugins then register their backends against the capability.
1302
+ 5. add contract coverage
1303
+ Add tests so ownership and registration shape stay explicit over time.
1304
+
1305
+ This is how QuantumClaw stays opinionated without becoming hardcoded to one
1306
+ provider's worldview. See the [Capability Cookbook](/tools/capability-cookbook)
1307
+ for a concrete file checklist and worked example.
1308
+
1309
+ ### Capability checklist
1310
+
1311
+ When you add a new capability, the implementation should usually touch these
1312
+ surfaces together:
1313
+
1314
+ - core contract types in `src/<capability>/types.ts`
1315
+ - core runner/runtime helper in `src/<capability>/runtime.ts`
1316
+ - plugin API registration surface in `src/plugins/types.ts`
1317
+ - plugin registry wiring in `src/plugins/registry.ts`
1318
+ - plugin runtime exposure in `src/plugins/runtime/*` when feature/channel
1319
+ plugins need to consume it
1320
+ - capture/test helpers in `src/test-utils/plugin-registration.ts`
1321
+ - ownership/contract assertions in `src/plugins/contracts/registry.ts`
1322
+ - operator/plugin docs in `docs/`
1323
+
1324
+ If one of those surfaces is missing, that is usually a sign the capability is
1325
+ not fully integrated yet.
1326
+
1327
+ ### Capability template
1328
+
1329
+ Minimal pattern:
1330
+
1331
+ ```ts
1332
+ // core contract
1333
+ export type VideoGenerationProviderPlugin = {
1334
+ id: string;
1335
+ label: string;
1336
+ generateVideo: (req: VideoGenerationRequest) => Promise<VideoGenerationResult>;
1337
+ };
1338
+
1339
+ // plugin API
1340
+ api.registerVideoGenerationProvider({
1341
+ id: "openai",
1342
+ label: "OpenAI",
1343
+ async generateVideo(req) {
1344
+ return await generateOpenAiVideo(req);
1345
+ },
1346
+ });
1347
+
1348
+ // shared runtime helper for feature/channel plugins
1349
+ const clip = await api.runtime.videoGeneration.generateFile({
1350
+ prompt: "Show the robot walking through the lab.",
1351
+ cfg,
1352
+ });
1353
+ ```
1354
+
1355
+ Contract test pattern:
1356
+
1357
+ ```ts
1358
+ expect(findVideoGenerationProviderIdsForPlugin("openai")).toEqual(["openai"]);
1359
+ ```
1360
+
1361
+ That keeps the rule simple:
1362
+
1363
+ - core owns the capability contract + orchestration
1364
+ - vendor plugins own vendor implementations
1365
+ - feature/channel plugins consume runtime helpers
1366
+ - contract tests keep ownership explicit