nodmix 2026.5.25

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (827) hide show
  1. package/CHANGELOG.md +11573 -0
  2. package/LICENSE +21 -0
  3. package/README.md +486 -0
  4. package/docs/.i18n/README.md +81 -0
  5. package/docs/.i18n/ar-navigation.json +18 -0
  6. package/docs/.i18n/de-navigation.json +18 -0
  7. package/docs/.i18n/es-navigation.json +18 -0
  8. package/docs/.i18n/fr-navigation.json +18 -0
  9. package/docs/.i18n/glossary.ar.json +78 -0
  10. package/docs/.i18n/glossary.de.json +78 -0
  11. package/docs/.i18n/glossary.es.json +78 -0
  12. package/docs/.i18n/glossary.fa.json +78 -0
  13. package/docs/.i18n/glossary.fr.json +78 -0
  14. package/docs/.i18n/glossary.id.json +78 -0
  15. package/docs/.i18n/glossary.it.json +78 -0
  16. package/docs/.i18n/glossary.ja-JP.json +98 -0
  17. package/docs/.i18n/glossary.ko.json +78 -0
  18. package/docs/.i18n/glossary.nl.json +78 -0
  19. package/docs/.i18n/glossary.pl.json +78 -0
  20. package/docs/.i18n/glossary.pt-BR.json +78 -0
  21. package/docs/.i18n/glossary.th.json +78 -0
  22. package/docs/.i18n/glossary.tr.json +78 -0
  23. package/docs/.i18n/glossary.uk.json +78 -0
  24. package/docs/.i18n/glossary.vi.json +78 -0
  25. package/docs/.i18n/glossary.zh-CN.json +1002 -0
  26. package/docs/.i18n/glossary.zh-TW.json +78 -0
  27. package/docs/.i18n/id-navigation.json +18 -0
  28. package/docs/.i18n/it-navigation.json +18 -0
  29. package/docs/.i18n/ja-navigation.json +18 -0
  30. package/docs/.i18n/ko-navigation.json +18 -0
  31. package/docs/.i18n/pl-navigation.json +18 -0
  32. package/docs/.i18n/pt-BR-navigation.json +18 -0
  33. package/docs/.i18n/tr-navigation.json +18 -0
  34. package/docs/.i18n/translation-workflow.md +111 -0
  35. package/docs/.i18n/zh-Hans-navigation.json +542 -0
  36. package/docs/AGENTS.md +36 -0
  37. package/docs/announcements/bluebubbles-imessage.md +79 -0
  38. package/docs/assets/install-script.svg +1 -0
  39. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  40. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  41. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  42. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  43. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  44. package/docs/assets/openclaw-logo-text-dark.png +0 -0
  45. package/docs/assets/openclaw-logo-text-dark.svg +418 -0
  46. package/docs/assets/openclaw-logo-text.png +0 -0
  47. package/docs/assets/openclaw-logo-text.svg +418 -0
  48. package/docs/assets/pixel-lobster.svg +60 -0
  49. package/docs/assets/pr/quick-settings-browser-tools.png +0 -0
  50. package/docs/assets/showcase/agents-ui.jpg +0 -0
  51. package/docs/assets/showcase/bambu-cli.png +0 -0
  52. package/docs/assets/showcase/codexmonitor.png +0 -0
  53. package/docs/assets/showcase/gohome-grafana.png +0 -0
  54. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  55. package/docs/assets/showcase/oura-health.png +0 -0
  56. package/docs/assets/showcase/padel-cli.svg +11 -0
  57. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  58. package/docs/assets/showcase/papla-tts.jpg +0 -0
  59. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  60. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  61. package/docs/assets/showcase/roborock-status.svg +13 -0
  62. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  63. package/docs/assets/showcase/snag.png +0 -0
  64. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  65. package/docs/assets/showcase/wienerlinien.png +0 -0
  66. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  67. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  68. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  69. package/docs/assets/sponsors/blacksmith-light.svg +14 -0
  70. package/docs/assets/sponsors/blacksmith.svg +14 -0
  71. package/docs/assets/sponsors/convex-light.svg +16 -0
  72. package/docs/assets/sponsors/convex.svg +16 -0
  73. package/docs/assets/sponsors/github-light.svg +3 -0
  74. package/docs/assets/sponsors/github.svg +3 -0
  75. package/docs/assets/sponsors/nvidia-dark.svg +9 -0
  76. package/docs/assets/sponsors/nvidia.svg +9 -0
  77. package/docs/assets/sponsors/openai-light.svg +3 -0
  78. package/docs/assets/sponsors/openai.svg +3 -0
  79. package/docs/assets/sponsors/vercel-light.svg +5 -0
  80. package/docs/assets/sponsors/vercel.svg +5 -0
  81. package/docs/auth-credential-semantics.md +124 -0
  82. package/docs/automation/auth-monitoring.md +11 -0
  83. package/docs/automation/clawflow.md +12 -0
  84. package/docs/automation/cron-jobs.md +500 -0
  85. package/docs/automation/cron-vs-heartbeat.md +11 -0
  86. package/docs/automation/gmail-pubsub.md +11 -0
  87. package/docs/automation/hooks.md +365 -0
  88. package/docs/automation/index.md +135 -0
  89. package/docs/automation/poll.md +12 -0
  90. package/docs/automation/standing-orders.md +250 -0
  91. package/docs/automation/taskflow.md +155 -0
  92. package/docs/automation/tasks.md +374 -0
  93. package/docs/automation/troubleshooting.md +12 -0
  94. package/docs/automation/webhook.md +12 -0
  95. package/docs/brave-search.md +11 -0
  96. package/docs/channels/access-groups.md +201 -0
  97. package/docs/channels/ambient-room-events.md +214 -0
  98. package/docs/channels/bot-loop-protection.md +131 -0
  99. package/docs/channels/broadcast-groups.md +472 -0
  100. package/docs/channels/channel-routing.md +162 -0
  101. package/docs/channels/clickclack.md +138 -0
  102. package/docs/channels/discord.md +1762 -0
  103. package/docs/channels/feishu.md +502 -0
  104. package/docs/channels/googlechat.md +284 -0
  105. package/docs/channels/group-messages.md +95 -0
  106. package/docs/channels/groups.md +519 -0
  107. package/docs/channels/imessage-from-bluebubbles.md +259 -0
  108. package/docs/channels/imessage.md +813 -0
  109. package/docs/channels/index.md +64 -0
  110. package/docs/channels/irc.md +253 -0
  111. package/docs/channels/line.md +243 -0
  112. package/docs/channels/location.md +71 -0
  113. package/docs/channels/matrix-migration.md +370 -0
  114. package/docs/channels/matrix-presentation.md +77 -0
  115. package/docs/channels/matrix-push-rules.md +150 -0
  116. package/docs/channels/matrix.md +921 -0
  117. package/docs/channels/mattermost.md +542 -0
  118. package/docs/channels/msteams.md +1042 -0
  119. package/docs/channels/nextcloud-talk.md +176 -0
  120. package/docs/channels/nostr.md +253 -0
  121. package/docs/channels/pairing.md +214 -0
  122. package/docs/channels/qqbot.md +309 -0
  123. package/docs/channels/signal.md +400 -0
  124. package/docs/channels/slack.md +1564 -0
  125. package/docs/channels/synology-chat.md +187 -0
  126. package/docs/channels/telegram.md +1107 -0
  127. package/docs/channels/tlon.md +296 -0
  128. package/docs/channels/troubleshooting.md +161 -0
  129. package/docs/channels/twitch.md +431 -0
  130. package/docs/channels/wechat.md +171 -0
  131. package/docs/channels/whatsapp.md +739 -0
  132. package/docs/channels/yuanbao.md +416 -0
  133. package/docs/channels/zalo.md +253 -0
  134. package/docs/channels/zalouser.md +199 -0
  135. package/docs/ci.md +612 -0
  136. package/docs/clawhub/publishing.md +96 -0
  137. package/docs/cli/acp.md +370 -0
  138. package/docs/cli/agent.md +103 -0
  139. package/docs/cli/agents.md +232 -0
  140. package/docs/cli/approvals.md +190 -0
  141. package/docs/cli/backup.md +97 -0
  142. package/docs/cli/browser.md +307 -0
  143. package/docs/cli/channels.md +154 -0
  144. package/docs/cli/clawbot.md +25 -0
  145. package/docs/cli/commitments.md +90 -0
  146. package/docs/cli/completion.md +39 -0
  147. package/docs/cli/config.md +504 -0
  148. package/docs/cli/configure.md +77 -0
  149. package/docs/cli/crestodian.md +332 -0
  150. package/docs/cli/cron.md +281 -0
  151. package/docs/cli/daemon.md +67 -0
  152. package/docs/cli/dashboard.md +33 -0
  153. package/docs/cli/devices.md +204 -0
  154. package/docs/cli/directory.md +68 -0
  155. package/docs/cli/dns.md +53 -0
  156. package/docs/cli/docs.md +73 -0
  157. package/docs/cli/doctor.md +237 -0
  158. package/docs/cli/flows.md +52 -0
  159. package/docs/cli/gateway.md +567 -0
  160. package/docs/cli/health.md +43 -0
  161. package/docs/cli/hooks.md +345 -0
  162. package/docs/cli/index.md +396 -0
  163. package/docs/cli/infer.md +364 -0
  164. package/docs/cli/logs.md +65 -0
  165. package/docs/cli/mcp.md +529 -0
  166. package/docs/cli/memory.md +183 -0
  167. package/docs/cli/message.md +317 -0
  168. package/docs/cli/migrate.md +290 -0
  169. package/docs/cli/models.md +224 -0
  170. package/docs/cli/node.md +177 -0
  171. package/docs/cli/nodes.md +76 -0
  172. package/docs/cli/onboard.md +245 -0
  173. package/docs/cli/pairing.md +77 -0
  174. package/docs/cli/path.md +502 -0
  175. package/docs/cli/plugins.md +454 -0
  176. package/docs/cli/policy.md +418 -0
  177. package/docs/cli/proxy.md +89 -0
  178. package/docs/cli/qr.md +56 -0
  179. package/docs/cli/reset.md +39 -0
  180. package/docs/cli/sandbox.md +208 -0
  181. package/docs/cli/secrets.md +202 -0
  182. package/docs/cli/security.md +124 -0
  183. package/docs/cli/sessions.md +164 -0
  184. package/docs/cli/setup.md +59 -0
  185. package/docs/cli/skills.md +102 -0
  186. package/docs/cli/status.md +45 -0
  187. package/docs/cli/system.md +89 -0
  188. package/docs/cli/tasks.md +111 -0
  189. package/docs/cli/tui.md +89 -0
  190. package/docs/cli/uninstall.md +44 -0
  191. package/docs/cli/update.md +242 -0
  192. package/docs/cli/voicecall.md +204 -0
  193. package/docs/cli/webhooks.md +117 -0
  194. package/docs/cli/wiki.md +256 -0
  195. package/docs/concepts/active-memory.md +856 -0
  196. package/docs/concepts/agent-loop.md +185 -0
  197. package/docs/concepts/agent-runtimes.md +243 -0
  198. package/docs/concepts/agent-workspace.md +230 -0
  199. package/docs/concepts/agent.md +136 -0
  200. package/docs/concepts/architecture.md +154 -0
  201. package/docs/concepts/channel-docking.md +145 -0
  202. package/docs/concepts/commitments.md +150 -0
  203. package/docs/concepts/compaction.md +203 -0
  204. package/docs/concepts/context-engine.md +306 -0
  205. package/docs/concepts/context.md +199 -0
  206. package/docs/concepts/delegate-architecture.md +319 -0
  207. package/docs/concepts/dreaming.md +261 -0
  208. package/docs/concepts/experimental-features.md +108 -0
  209. package/docs/concepts/features.md +91 -0
  210. package/docs/concepts/mantis-slack-desktop-runbook.md +202 -0
  211. package/docs/concepts/mantis.md +740 -0
  212. package/docs/concepts/markdown-formatting.md +139 -0
  213. package/docs/concepts/memory-builtin.md +146 -0
  214. package/docs/concepts/memory-honcho.md +144 -0
  215. package/docs/concepts/memory-qmd.md +271 -0
  216. package/docs/concepts/memory-search.md +166 -0
  217. package/docs/concepts/memory.md +258 -0
  218. package/docs/concepts/message-lifecycle-refactor.md +1128 -0
  219. package/docs/concepts/messages.md +214 -0
  220. package/docs/concepts/model-failover.md +385 -0
  221. package/docs/concepts/model-providers.md +715 -0
  222. package/docs/concepts/models.md +370 -0
  223. package/docs/concepts/multi-agent.md +619 -0
  224. package/docs/concepts/oauth.md +198 -0
  225. package/docs/concepts/openclaw-sdk.md +323 -0
  226. package/docs/concepts/parallel-specialist-lanes.md +127 -0
  227. package/docs/concepts/personal-agent-benchmark-pack.md +74 -0
  228. package/docs/concepts/presence.md +117 -0
  229. package/docs/concepts/progress-drafts.md +362 -0
  230. package/docs/concepts/qa-e2e-automation.md +820 -0
  231. package/docs/concepts/qa-matrix.md +139 -0
  232. package/docs/concepts/queue-steering.md +90 -0
  233. package/docs/concepts/queue.md +122 -0
  234. package/docs/concepts/retry.md +86 -0
  235. package/docs/concepts/session-pruning.md +104 -0
  236. package/docs/concepts/session-tool.md +190 -0
  237. package/docs/concepts/session.md +164 -0
  238. package/docs/concepts/soul.md +116 -0
  239. package/docs/concepts/streaming.md +251 -0
  240. package/docs/concepts/system-prompt.md +310 -0
  241. package/docs/concepts/timezone.md +47 -0
  242. package/docs/concepts/typebox.md +309 -0
  243. package/docs/concepts/typing-indicators.md +88 -0
  244. package/docs/concepts/usage-tracking.md +66 -0
  245. package/docs/date-time.md +126 -0
  246. package/docs/debug/node-issue.md +90 -0
  247. package/docs/diagnostics/flags.md +138 -0
  248. package/docs/docs.json +1832 -0
  249. package/docs/gateway/authentication.md +239 -0
  250. package/docs/gateway/background-process.md +147 -0
  251. package/docs/gateway/bonjour.md +303 -0
  252. package/docs/gateway/bridge-protocol.md +94 -0
  253. package/docs/gateway/cli-backends.md +420 -0
  254. package/docs/gateway/config-agents.md +1514 -0
  255. package/docs/gateway/config-channels.md +945 -0
  256. package/docs/gateway/config-tools.md +769 -0
  257. package/docs/gateway/configuration-examples.md +705 -0
  258. package/docs/gateway/configuration-reference.md +1393 -0
  259. package/docs/gateway/configuration.md +737 -0
  260. package/docs/gateway/diagnostics.md +213 -0
  261. package/docs/gateway/discovery.md +154 -0
  262. package/docs/gateway/doctor.md +574 -0
  263. package/docs/gateway/gateway-lock.md +37 -0
  264. package/docs/gateway/health.md +73 -0
  265. package/docs/gateway/heartbeat.md +493 -0
  266. package/docs/gateway/index.md +383 -0
  267. package/docs/gateway/local-model-services.md +205 -0
  268. package/docs/gateway/local-models.md +355 -0
  269. package/docs/gateway/logging.md +149 -0
  270. package/docs/gateway/multiple-gateways.md +178 -0
  271. package/docs/gateway/network-model.md +15 -0
  272. package/docs/gateway/openai-http-api.md +350 -0
  273. package/docs/gateway/openresponses-http-api.md +347 -0
  274. package/docs/gateway/openshell.md +316 -0
  275. package/docs/gateway/opentelemetry.md +404 -0
  276. package/docs/gateway/operator-scopes.md +111 -0
  277. package/docs/gateway/pairing.md +207 -0
  278. package/docs/gateway/prometheus.md +230 -0
  279. package/docs/gateway/protocol.md +803 -0
  280. package/docs/gateway/remote-gateway-readme.md +169 -0
  281. package/docs/gateway/remote.md +280 -0
  282. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +146 -0
  283. package/docs/gateway/sandboxing.md +545 -0
  284. package/docs/gateway/secrets-plan-contract.md +114 -0
  285. package/docs/gateway/secrets.md +609 -0
  286. package/docs/gateway/security/audit-checks.md +127 -0
  287. package/docs/gateway/security/index.md +1326 -0
  288. package/docs/gateway/security/secure-file-operations.md +76 -0
  289. package/docs/gateway/tailscale.md +156 -0
  290. package/docs/gateway/tools-invoke-http-api.md +169 -0
  291. package/docs/gateway/troubleshooting.md +772 -0
  292. package/docs/gateway/trusted-proxy-auth.md +451 -0
  293. package/docs/help/debugging.md +344 -0
  294. package/docs/help/environment.md +214 -0
  295. package/docs/help/faq-first-run.md +867 -0
  296. package/docs/help/faq-models.md +553 -0
  297. package/docs/help/faq.md +1975 -0
  298. package/docs/help/gpt55-codex-agentic-parity-maintainers.md +196 -0
  299. package/docs/help/gpt55-codex-agentic-parity.md +230 -0
  300. package/docs/help/index.md +39 -0
  301. package/docs/help/scripts.md +56 -0
  302. package/docs/help/testing-live.md +580 -0
  303. package/docs/help/testing-updates-plugins.md +291 -0
  304. package/docs/help/testing.md +928 -0
  305. package/docs/help/troubleshooting.md +424 -0
  306. package/docs/images/configure-model-picker-unsearchable.png +0 -0
  307. package/docs/images/feishu-get-group-id.png +0 -0
  308. package/docs/images/groups-flow.svg +52 -0
  309. package/docs/images/mobile-ui-screenshot.png +0 -0
  310. package/docs/index.md +196 -0
  311. package/docs/install/ansible.md +233 -0
  312. package/docs/install/azure.md +315 -0
  313. package/docs/install/bun.md +59 -0
  314. package/docs/install/clawdock.md +112 -0
  315. package/docs/install/development-channels.md +135 -0
  316. package/docs/install/digitalocean.md +174 -0
  317. package/docs/install/docker-vm-runtime.md +154 -0
  318. package/docs/install/docker.md +562 -0
  319. package/docs/install/exe-dev.md +201 -0
  320. package/docs/install/fly.md +524 -0
  321. package/docs/install/gcp.md +418 -0
  322. package/docs/install/hetzner.md +285 -0
  323. package/docs/install/hostinger.md +98 -0
  324. package/docs/install/index.md +221 -0
  325. package/docs/install/installer.md +455 -0
  326. package/docs/install/kubernetes.md +196 -0
  327. package/docs/install/macos-vm.md +281 -0
  328. package/docs/install/migrating-claude.md +165 -0
  329. package/docs/install/migrating-hermes.md +177 -0
  330. package/docs/install/migrating.md +137 -0
  331. package/docs/install/nix.md +112 -0
  332. package/docs/install/node.md +142 -0
  333. package/docs/install/northflank.mdx +44 -0
  334. package/docs/install/oracle.md +218 -0
  335. package/docs/install/podman.md +210 -0
  336. package/docs/install/railway.mdx +92 -0
  337. package/docs/install/raspberry-pi.md +234 -0
  338. package/docs/install/render.mdx +167 -0
  339. package/docs/install/uninstall.md +131 -0
  340. package/docs/install/updating.md +280 -0
  341. package/docs/logging.md +318 -0
  342. package/docs/nav-tabs-underline.js +100 -0
  343. package/docs/network.md +72 -0
  344. package/docs/nodes/audio.md +215 -0
  345. package/docs/nodes/camera.md +166 -0
  346. package/docs/nodes/images.md +77 -0
  347. package/docs/nodes/index.md +439 -0
  348. package/docs/nodes/location-command.md +102 -0
  349. package/docs/nodes/media-understanding.md +469 -0
  350. package/docs/nodes/talk.md +154 -0
  351. package/docs/nodes/troubleshooting.md +123 -0
  352. package/docs/nodes/voicewake.md +93 -0
  353. package/docs/perplexity.md +11 -0
  354. package/docs/pi-dev.md +82 -0
  355. package/docs/pi.md +573 -0
  356. package/docs/plan/codex-context-engine-harness.md +624 -0
  357. package/docs/plan/ui-channels.md +284 -0
  358. package/docs/platforms/android.md +285 -0
  359. package/docs/platforms/digitalocean.md +12 -0
  360. package/docs/platforms/index.md +60 -0
  361. package/docs/platforms/ios.md +283 -0
  362. package/docs/platforms/linux.md +141 -0
  363. package/docs/platforms/mac/bundled-gateway.md +79 -0
  364. package/docs/platforms/mac/canvas.md +128 -0
  365. package/docs/platforms/mac/child-process.md +72 -0
  366. package/docs/platforms/mac/dev-setup.md +112 -0
  367. package/docs/platforms/mac/health.md +39 -0
  368. package/docs/platforms/mac/icon.md +36 -0
  369. package/docs/platforms/mac/logging.md +62 -0
  370. package/docs/platforms/mac/menu-bar.md +93 -0
  371. package/docs/platforms/mac/peekaboo.md +92 -0
  372. package/docs/platforms/mac/permissions.md +53 -0
  373. package/docs/platforms/mac/remote.md +123 -0
  374. package/docs/platforms/mac/signing.md +52 -0
  375. package/docs/platforms/mac/skills.md +43 -0
  376. package/docs/platforms/mac/voice-overlay.md +66 -0
  377. package/docs/platforms/mac/voicewake.md +73 -0
  378. package/docs/platforms/mac/webchat.md +54 -0
  379. package/docs/platforms/mac/xpc.md +66 -0
  380. package/docs/platforms/macos.md +226 -0
  381. package/docs/platforms/oracle.md +12 -0
  382. package/docs/platforms/raspberry-pi.md +13 -0
  383. package/docs/platforms/windows.md +286 -0
  384. package/docs/plugins/adding-capabilities.md +133 -0
  385. package/docs/plugins/admin-http-rpc.md +216 -0
  386. package/docs/plugins/agent-tools.md +13 -0
  387. package/docs/plugins/architecture-internals.md +1195 -0
  388. package/docs/plugins/architecture.md +481 -0
  389. package/docs/plugins/building-extensions.md +13 -0
  390. package/docs/plugins/building-plugins.md +330 -0
  391. package/docs/plugins/bundles.md +310 -0
  392. package/docs/plugins/cli-backend-plugins.md +310 -0
  393. package/docs/plugins/codex-computer-use.md +293 -0
  394. package/docs/plugins/codex-harness-reference.md +409 -0
  395. package/docs/plugins/codex-harness-runtime.md +247 -0
  396. package/docs/plugins/codex-harness.md +746 -0
  397. package/docs/plugins/codex-native-plugins.md +276 -0
  398. package/docs/plugins/community.md +77 -0
  399. package/docs/plugins/compatibility.md +164 -0
  400. package/docs/plugins/dependency-resolution.md +143 -0
  401. package/docs/plugins/google-meet.md +1737 -0
  402. package/docs/plugins/hooks.md +459 -0
  403. package/docs/plugins/install-overrides.md +80 -0
  404. package/docs/plugins/manage-plugins.md +210 -0
  405. package/docs/plugins/manifest.md +1359 -0
  406. package/docs/plugins/memory-lancedb.md +385 -0
  407. package/docs/plugins/memory-wiki.md +529 -0
  408. package/docs/plugins/message-presentation.md +473 -0
  409. package/docs/plugins/oc-path.md +166 -0
  410. package/docs/plugins/plugin-inventory.md +182 -0
  411. package/docs/plugins/reference/acpx.md +23 -0
  412. package/docs/plugins/reference/admin-http-rpc.md +23 -0
  413. package/docs/plugins/reference/alibaba.md +23 -0
  414. package/docs/plugins/reference/amazon-bedrock-mantle.md +23 -0
  415. package/docs/plugins/reference/amazon-bedrock.md +23 -0
  416. package/docs/plugins/reference/anthropic-vertex.md +19 -0
  417. package/docs/plugins/reference/anthropic.md +23 -0
  418. package/docs/plugins/reference/arcee.md +23 -0
  419. package/docs/plugins/reference/azure-speech.md +23 -0
  420. package/docs/plugins/reference/bonjour.md +19 -0
  421. package/docs/plugins/reference/brave.md +23 -0
  422. package/docs/plugins/reference/browser.md +23 -0
  423. package/docs/plugins/reference/byteplus.md +19 -0
  424. package/docs/plugins/reference/canvas.md +19 -0
  425. package/docs/plugins/reference/cerebras.md +23 -0
  426. package/docs/plugins/reference/chutes.md +23 -0
  427. package/docs/plugins/reference/clickclack.md +23 -0
  428. package/docs/plugins/reference/cloudflare-ai-gateway.md +23 -0
  429. package/docs/plugins/reference/codex.md +23 -0
  430. package/docs/plugins/reference/comfy.md +23 -0
  431. package/docs/plugins/reference/copilot-proxy.md +19 -0
  432. package/docs/plugins/reference/deepgram.md +23 -0
  433. package/docs/plugins/reference/deepinfra.md +23 -0
  434. package/docs/plugins/reference/deepseek.md +23 -0
  435. package/docs/plugins/reference/diagnostics-otel.md +19 -0
  436. package/docs/plugins/reference/diagnostics-prometheus.md +19 -0
  437. package/docs/plugins/reference/diffs.md +19 -0
  438. package/docs/plugins/reference/discord.md +23 -0
  439. package/docs/plugins/reference/document-extract.md +23 -0
  440. package/docs/plugins/reference/duckduckgo.md +23 -0
  441. package/docs/plugins/reference/elevenlabs.md +23 -0
  442. package/docs/plugins/reference/exa.md +23 -0
  443. package/docs/plugins/reference/fal.md +23 -0
  444. package/docs/plugins/reference/feishu.md +23 -0
  445. package/docs/plugins/reference/file-transfer.md +19 -0
  446. package/docs/plugins/reference/firecrawl.md +23 -0
  447. package/docs/plugins/reference/fireworks.md +23 -0
  448. package/docs/plugins/reference/github-copilot.md +23 -0
  449. package/docs/plugins/reference/google-meet.md +23 -0
  450. package/docs/plugins/reference/google.md +23 -0
  451. package/docs/plugins/reference/googlechat.md +23 -0
  452. package/docs/plugins/reference/gradium.md +23 -0
  453. package/docs/plugins/reference/groq.md +23 -0
  454. package/docs/plugins/reference/huggingface.md +23 -0
  455. package/docs/plugins/reference/imessage.md +23 -0
  456. package/docs/plugins/reference/inworld.md +23 -0
  457. package/docs/plugins/reference/irc.md +23 -0
  458. package/docs/plugins/reference/kilocode.md +23 -0
  459. package/docs/plugins/reference/kimi.md +23 -0
  460. package/docs/plugins/reference/line.md +23 -0
  461. package/docs/plugins/reference/litellm.md +23 -0
  462. package/docs/plugins/reference/llm-task.md +19 -0
  463. package/docs/plugins/reference/lmstudio.md +23 -0
  464. package/docs/plugins/reference/lobster.md +19 -0
  465. package/docs/plugins/reference/matrix.md +23 -0
  466. package/docs/plugins/reference/mattermost.md +23 -0
  467. package/docs/plugins/reference/memory-core.md +19 -0
  468. package/docs/plugins/reference/memory-lancedb.md +23 -0
  469. package/docs/plugins/reference/memory-wiki.md +23 -0
  470. package/docs/plugins/reference/microsoft-foundry.md +19 -0
  471. package/docs/plugins/reference/microsoft.md +19 -0
  472. package/docs/plugins/reference/migrate-claude.md +19 -0
  473. package/docs/plugins/reference/migrate-hermes.md +19 -0
  474. package/docs/plugins/reference/minimax.md +23 -0
  475. package/docs/plugins/reference/mistral.md +23 -0
  476. package/docs/plugins/reference/moonshot.md +23 -0
  477. package/docs/plugins/reference/msteams.md +23 -0
  478. package/docs/plugins/reference/nextcloud-talk.md +23 -0
  479. package/docs/plugins/reference/nostr.md +23 -0
  480. package/docs/plugins/reference/nvidia.md +23 -0
  481. package/docs/plugins/reference/oc-path.md +23 -0
  482. package/docs/plugins/reference/ollama.md +23 -0
  483. package/docs/plugins/reference/open-prose.md +19 -0
  484. package/docs/plugins/reference/openai.md +23 -0
  485. package/docs/plugins/reference/opencode-go.md +23 -0
  486. package/docs/plugins/reference/opencode.md +23 -0
  487. package/docs/plugins/reference/openrouter.md +23 -0
  488. package/docs/plugins/reference/openshell.md +19 -0
  489. package/docs/plugins/reference/perplexity.md +23 -0
  490. package/docs/plugins/reference/policy.md +23 -0
  491. package/docs/plugins/reference/qa-channel.md +23 -0
  492. package/docs/plugins/reference/qa-lab.md +19 -0
  493. package/docs/plugins/reference/qa-matrix.md +19 -0
  494. package/docs/plugins/reference/qianfan.md +23 -0
  495. package/docs/plugins/reference/qqbot.md +23 -0
  496. package/docs/plugins/reference/qwen.md +23 -0
  497. package/docs/plugins/reference/runway.md +23 -0
  498. package/docs/plugins/reference/searxng.md +19 -0
  499. package/docs/plugins/reference/senseaudio.md +23 -0
  500. package/docs/plugins/reference/sglang.md +23 -0
  501. package/docs/plugins/reference/signal.md +23 -0
  502. package/docs/plugins/reference/skill-workshop.md +23 -0
  503. package/docs/plugins/reference/slack.md +23 -0
  504. package/docs/plugins/reference/stepfun.md +23 -0
  505. package/docs/plugins/reference/synology-chat.md +23 -0
  506. package/docs/plugins/reference/synthetic.md +23 -0
  507. package/docs/plugins/reference/tavily.md +23 -0
  508. package/docs/plugins/reference/telegram.md +23 -0
  509. package/docs/plugins/reference/tencent.md +23 -0
  510. package/docs/plugins/reference/tlon.md +23 -0
  511. package/docs/plugins/reference/together.md +23 -0
  512. package/docs/plugins/reference/tokenjuice.md +23 -0
  513. package/docs/plugins/reference/tts-local-cli.md +19 -0
  514. package/docs/plugins/reference/twitch.md +23 -0
  515. package/docs/plugins/reference/venice.md +23 -0
  516. package/docs/plugins/reference/vercel-ai-gateway.md +23 -0
  517. package/docs/plugins/reference/vllm.md +23 -0
  518. package/docs/plugins/reference/voice-call.md +23 -0
  519. package/docs/plugins/reference/volcengine.md +23 -0
  520. package/docs/plugins/reference/voyage.md +19 -0
  521. package/docs/plugins/reference/vydra.md +23 -0
  522. package/docs/plugins/reference/web-readability.md +19 -0
  523. package/docs/plugins/reference/webhooks.md +23 -0
  524. package/docs/plugins/reference/whatsapp.md +23 -0
  525. package/docs/plugins/reference/xai.md +23 -0
  526. package/docs/plugins/reference/xiaomi.md +23 -0
  527. package/docs/plugins/reference/zai.md +23 -0
  528. package/docs/plugins/reference/zalo.md +23 -0
  529. package/docs/plugins/reference/zalouser.md +24 -0
  530. package/docs/plugins/reference.md +138 -0
  531. package/docs/plugins/sdk-agent-harness.md +339 -0
  532. package/docs/plugins/sdk-channel-ingress.md +137 -0
  533. package/docs/plugins/sdk-channel-message.md +458 -0
  534. package/docs/plugins/sdk-channel-plugins.md +762 -0
  535. package/docs/plugins/sdk-channel-turn.md +580 -0
  536. package/docs/plugins/sdk-entrypoints.md +333 -0
  537. package/docs/plugins/sdk-migration.md +949 -0
  538. package/docs/plugins/sdk-overview.md +501 -0
  539. package/docs/plugins/sdk-provider-plugins.md +807 -0
  540. package/docs/plugins/sdk-runtime.md +676 -0
  541. package/docs/plugins/sdk-setup.md +550 -0
  542. package/docs/plugins/sdk-subpaths.md +396 -0
  543. package/docs/plugins/sdk-testing.md +401 -0
  544. package/docs/plugins/skill-workshop.md +713 -0
  545. package/docs/plugins/tool-plugins.md +411 -0
  546. package/docs/plugins/voice-call.md +943 -0
  547. package/docs/plugins/webhooks.md +192 -0
  548. package/docs/plugins/zalouser.md +86 -0
  549. package/docs/prose.md +137 -0
  550. package/docs/providers/alibaba.md +158 -0
  551. package/docs/providers/anthropic.md +344 -0
  552. package/docs/providers/arcee.md +144 -0
  553. package/docs/providers/azure-speech.md +119 -0
  554. package/docs/providers/bedrock-mantle.md +211 -0
  555. package/docs/providers/bedrock.md +414 -0
  556. package/docs/providers/cerebras.md +130 -0
  557. package/docs/providers/chutes.md +153 -0
  558. package/docs/providers/claude-max-api-proxy.md +188 -0
  559. package/docs/providers/cloudflare-ai-gateway.md +119 -0
  560. package/docs/providers/comfy.md +362 -0
  561. package/docs/providers/deepgram.md +184 -0
  562. package/docs/providers/deepinfra.md +87 -0
  563. package/docs/providers/deepseek.md +146 -0
  564. package/docs/providers/ds4.md +309 -0
  565. package/docs/providers/elevenlabs.md +130 -0
  566. package/docs/providers/fal.md +204 -0
  567. package/docs/providers/fireworks.md +144 -0
  568. package/docs/providers/github-copilot.md +225 -0
  569. package/docs/providers/glm.md +137 -0
  570. package/docs/providers/google.md +472 -0
  571. package/docs/providers/gradium.md +123 -0
  572. package/docs/providers/groq.md +180 -0
  573. package/docs/providers/huggingface.md +235 -0
  574. package/docs/providers/index.md +102 -0
  575. package/docs/providers/inferrs.md +272 -0
  576. package/docs/providers/inworld.md +120 -0
  577. package/docs/providers/kilocode.md +135 -0
  578. package/docs/providers/litellm.md +234 -0
  579. package/docs/providers/lmstudio.md +224 -0
  580. package/docs/providers/minimax.md +505 -0
  581. package/docs/providers/mistral.md +235 -0
  582. package/docs/providers/models.md +65 -0
  583. package/docs/providers/moonshot.md +413 -0
  584. package/docs/providers/nvidia.md +140 -0
  585. package/docs/providers/ollama.md +1180 -0
  586. package/docs/providers/openai.md +1057 -0
  587. package/docs/providers/opencode-go.md +123 -0
  588. package/docs/providers/opencode.md +149 -0
  589. package/docs/providers/openrouter.md +349 -0
  590. package/docs/providers/perplexity-provider.md +123 -0
  591. package/docs/providers/qianfan.md +132 -0
  592. package/docs/providers/qwen.md +332 -0
  593. package/docs/providers/runway.md +103 -0
  594. package/docs/providers/senseaudio.md +68 -0
  595. package/docs/providers/sglang.md +161 -0
  596. package/docs/providers/stepfun.md +229 -0
  597. package/docs/providers/synthetic.md +154 -0
  598. package/docs/providers/tencent.md +130 -0
  599. package/docs/providers/together.md +141 -0
  600. package/docs/providers/venice.md +315 -0
  601. package/docs/providers/vercel-ai-gateway.md +128 -0
  602. package/docs/providers/vllm.md +383 -0
  603. package/docs/providers/volcengine.md +199 -0
  604. package/docs/providers/vydra.md +180 -0
  605. package/docs/providers/xai.md +560 -0
  606. package/docs/providers/xiaomi.md +188 -0
  607. package/docs/providers/zai.md +203 -0
  608. package/docs/refactor/access.md +9 -0
  609. package/docs/refactor/acp.md +298 -0
  610. package/docs/refactor/canvas.md +131 -0
  611. package/docs/refactor/ingress-core.md +341 -0
  612. package/docs/reference/AGENTS.default.md +129 -0
  613. package/docs/reference/RELEASING.md +767 -0
  614. package/docs/reference/api-usage-costs.md +202 -0
  615. package/docs/reference/application-modernization-plan.md +208 -0
  616. package/docs/reference/code-mode.md +757 -0
  617. package/docs/reference/credits.md +33 -0
  618. package/docs/reference/device-models.md +50 -0
  619. package/docs/reference/full-release-validation.md +202 -0
  620. package/docs/reference/memory-config.md +630 -0
  621. package/docs/reference/openclaw-sdk-api-design.md +390 -0
  622. package/docs/reference/prompt-caching.md +358 -0
  623. package/docs/reference/rich-output-protocol.md +79 -0
  624. package/docs/reference/rpc.md +43 -0
  625. package/docs/reference/secretref-credential-surface.md +159 -0
  626. package/docs/reference/secretref-user-supplied-credentials-matrix.json +663 -0
  627. package/docs/reference/session-management-compaction.md +461 -0
  628. package/docs/reference/templates/AGENTS.dev.md +89 -0
  629. package/docs/reference/templates/AGENTS.md +225 -0
  630. package/docs/reference/templates/BOOT.md +16 -0
  631. package/docs/reference/templates/BOOTSTRAP.md +66 -0
  632. package/docs/reference/templates/HEARTBEAT.md +16 -0
  633. package/docs/reference/templates/IDENTITY.dev.md +52 -0
  634. package/docs/reference/templates/IDENTITY.md +34 -0
  635. package/docs/reference/templates/SOUL.dev.md +82 -0
  636. package/docs/reference/templates/SOUL.md +49 -0
  637. package/docs/reference/templates/TOOLS.dev.md +29 -0
  638. package/docs/reference/templates/TOOLS.md +51 -0
  639. package/docs/reference/templates/USER.dev.md +23 -0
  640. package/docs/reference/templates/USER.md +28 -0
  641. package/docs/reference/test.md +239 -0
  642. package/docs/reference/token-use.md +233 -0
  643. package/docs/reference/transcript-hygiene.md +214 -0
  644. package/docs/reference/wizard.md +252 -0
  645. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +101 -0
  646. package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
  647. package/docs/security/formal-verification.md +170 -0
  648. package/docs/security/incident-response.md +59 -0
  649. package/docs/security/network-proxy.md +268 -0
  650. package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +12 -0
  651. package/docs/snippets/plugin-publish/minimal-package.json +16 -0
  652. package/docs/start/bootstrapping.md +49 -0
  653. package/docs/start/docs-directory.md +69 -0
  654. package/docs/start/getting-started.md +152 -0
  655. package/docs/start/hubs.md +201 -0
  656. package/docs/start/lore.md +223 -0
  657. package/docs/start/onboarding-overview.md +72 -0
  658. package/docs/start/onboarding.md +95 -0
  659. package/docs/start/openclaw.md +244 -0
  660. package/docs/start/quickstart.md +25 -0
  661. package/docs/start/setup.md +178 -0
  662. package/docs/start/showcase.md +383 -0
  663. package/docs/start/wizard-cli-automation.md +232 -0
  664. package/docs/start/wizard-cli-reference.md +331 -0
  665. package/docs/start/wizard.md +141 -0
  666. package/docs/style.css +184 -0
  667. package/docs/superpowers/specs/2026-04-22-tweakcn-custom-theme-import-design.md +316 -0
  668. package/docs/tools/acp-agents-setup.md +352 -0
  669. package/docs/tools/acp-agents.md +847 -0
  670. package/docs/tools/agent-send.md +112 -0
  671. package/docs/tools/apply-patch.md +64 -0
  672. package/docs/tools/brave-search.md +139 -0
  673. package/docs/tools/browser-control.md +391 -0
  674. package/docs/tools/browser-linux-troubleshooting.md +173 -0
  675. package/docs/tools/browser-login.md +77 -0
  676. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +219 -0
  677. package/docs/tools/browser.md +769 -0
  678. package/docs/tools/btw.md +159 -0
  679. package/docs/tools/capability-cookbook.md +12 -0
  680. package/docs/tools/clawhub.md +5 -0
  681. package/docs/tools/code-execution.md +173 -0
  682. package/docs/tools/creating-skills.md +120 -0
  683. package/docs/tools/diffs.md +506 -0
  684. package/docs/tools/duckduckgo-search.md +109 -0
  685. package/docs/tools/elevated.md +128 -0
  686. package/docs/tools/exa-search.md +152 -0
  687. package/docs/tools/exec-approvals-advanced.md +360 -0
  688. package/docs/tools/exec-approvals.md +474 -0
  689. package/docs/tools/exec.md +282 -0
  690. package/docs/tools/firecrawl.md +155 -0
  691. package/docs/tools/gemini-search.md +114 -0
  692. package/docs/tools/grok-search.md +113 -0
  693. package/docs/tools/image-generation.md +433 -0
  694. package/docs/tools/index.md +178 -0
  695. package/docs/tools/kimi-search.md +105 -0
  696. package/docs/tools/llm-task.md +137 -0
  697. package/docs/tools/lobster.md +365 -0
  698. package/docs/tools/loop-detection.md +154 -0
  699. package/docs/tools/media-overview.md +157 -0
  700. package/docs/tools/minimax-search.md +102 -0
  701. package/docs/tools/multi-agent-sandbox-tools.md +409 -0
  702. package/docs/tools/music-generation.md +371 -0
  703. package/docs/tools/ollama-search.md +153 -0
  704. package/docs/tools/pdf.md +195 -0
  705. package/docs/tools/perplexity-search.md +220 -0
  706. package/docs/tools/plugin.md +327 -0
  707. package/docs/tools/reactions.md +100 -0
  708. package/docs/tools/searxng-search.md +141 -0
  709. package/docs/tools/skills-config.md +195 -0
  710. package/docs/tools/skills.md +535 -0
  711. package/docs/tools/slash-commands.md +488 -0
  712. package/docs/tools/steer.md +84 -0
  713. package/docs/tools/subagents.md +650 -0
  714. package/docs/tools/tavily.md +162 -0
  715. package/docs/tools/thinking.md +140 -0
  716. package/docs/tools/tokenjuice.md +81 -0
  717. package/docs/tools/tool-search.md +269 -0
  718. package/docs/tools/trajectory.md +229 -0
  719. package/docs/tools/tts.md +1004 -0
  720. package/docs/tools/video-generation.md +552 -0
  721. package/docs/tools/web-fetch.md +195 -0
  722. package/docs/tools/web.md +459 -0
  723. package/docs/tts.md +11 -0
  724. package/docs/vps.md +139 -0
  725. package/docs/web/control-ui.md +503 -0
  726. package/docs/web/dashboard.md +107 -0
  727. package/docs/web/index.md +133 -0
  728. package/docs/web/tui.md +246 -0
  729. package/docs/web/webchat.md +99 -0
  730. package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
  731. package/docs/whatsapp-openclaw.jpg +0 -0
  732. package/nodmix.mjs +487 -0
  733. package/package.json +1852 -0
  734. package/patches/.gitkeep +0 -0
  735. package/patches/@agentclientprotocol__claude-agent-acp@0.36.1.patch +41 -0
  736. package/pnpm-workspace.yaml +63 -0
  737. package/scripts/crabbox-wrapper.mjs +353 -0
  738. package/scripts/lib/official-external-channel-catalog.json +559 -0
  739. package/scripts/lib/official-external-plugin-catalog.json +192 -0
  740. package/scripts/lib/official-external-provider-catalog.json +117 -0
  741. package/scripts/lib/package-dist-imports.mjs +171 -0
  742. package/scripts/npm-runner.mjs +91 -0
  743. package/scripts/postinstall-bundled-plugins.mjs +978 -0
  744. package/scripts/preinstall-package-manager-warning.mjs +64 -0
  745. package/scripts/windows-cmd-helpers.mjs +20 -0
  746. package/skills/1password/SKILL.md +70 -0
  747. package/skills/1password/references/cli-examples.md +29 -0
  748. package/skills/1password/references/get-started.md +17 -0
  749. package/skills/apple-notes/SKILL.md +77 -0
  750. package/skills/apple-reminders/SKILL.md +118 -0
  751. package/skills/bear-notes/SKILL.md +107 -0
  752. package/skills/blogwatcher/SKILL.md +69 -0
  753. package/skills/blucli/SKILL.md +47 -0
  754. package/skills/camsnap/SKILL.md +45 -0
  755. package/skills/canvas/SKILL.md +78 -0
  756. package/skills/clawhub/SKILL.md +77 -0
  757. package/skills/coding-agent/SKILL.md +149 -0
  758. package/skills/diagram-maker/SKILL.md +53 -0
  759. package/skills/diagram-maker/references/excalidraw-patterns.md +85 -0
  760. package/skills/diagram-maker/references/svg-template.md +112 -0
  761. package/skills/discord/SKILL.md +136 -0
  762. package/skills/eightctl/SKILL.md +50 -0
  763. package/skills/gemini/SKILL.md +47 -0
  764. package/skills/gh-issues/SKILL.md +213 -0
  765. package/skills/gifgrep/SKILL.md +85 -0
  766. package/skills/github/SKILL.md +84 -0
  767. package/skills/gog/SKILL.md +116 -0
  768. package/skills/goplaces/SKILL.md +52 -0
  769. package/skills/healthcheck/SKILL.md +105 -0
  770. package/skills/himalaya/SKILL.md +80 -0
  771. package/skills/himalaya/references/configuration.md +184 -0
  772. package/skills/himalaya/references/message-composition.md +199 -0
  773. package/skills/imsg/SKILL.md +122 -0
  774. package/skills/mcporter/SKILL.md +61 -0
  775. package/skills/meme-maker/SKILL.md +42 -0
  776. package/skills/meme-maker/references/templates.json +358 -0
  777. package/skills/meme-maker/scripts/meme.mjs +398 -0
  778. package/skills/model-usage/SKILL.md +69 -0
  779. package/skills/model-usage/references/codexbar-cli.md +33 -0
  780. package/skills/model-usage/scripts/model_usage.py +319 -0
  781. package/skills/model-usage/scripts/test_model_usage.py +40 -0
  782. package/skills/nano-pdf/SKILL.md +38 -0
  783. package/skills/node-connect/SKILL.md +142 -0
  784. package/skills/node-inspect-debugger/SKILL.md +85 -0
  785. package/skills/notion/SKILL.md +150 -0
  786. package/skills/obsidian/SKILL.md +119 -0
  787. package/skills/openai-whisper/SKILL.md +38 -0
  788. package/skills/openai-whisper-api/SKILL.md +71 -0
  789. package/skills/openai-whisper-api/scripts/transcribe.sh +154 -0
  790. package/skills/openhue/SKILL.md +112 -0
  791. package/skills/oracle/SKILL.md +126 -0
  792. package/skills/ordercli/SKILL.md +78 -0
  793. package/skills/peekaboo/SKILL.md +190 -0
  794. package/skills/pyproject.toml +10 -0
  795. package/skills/python-debugpy/SKILL.md +73 -0
  796. package/skills/sag/SKILL.md +87 -0
  797. package/skills/session-logs/SKILL.md +151 -0
  798. package/skills/sherpa-onnx-tts/SKILL.md +109 -0
  799. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  800. package/skills/skill-creator/SKILL.md +78 -0
  801. package/skills/skill-creator/license.txt +202 -0
  802. package/skills/skill-creator/scripts/init_skill.py +378 -0
  803. package/skills/skill-creator/scripts/package_skill.py +139 -0
  804. package/skills/skill-creator/scripts/quick_validate.py +169 -0
  805. package/skills/skill-creator/scripts/test_package_skill.py +161 -0
  806. package/skills/skill-creator/scripts/test_quick_validate.py +116 -0
  807. package/skills/slack/SKILL.md +78 -0
  808. package/skills/songsee/SKILL.md +49 -0
  809. package/skills/sonoscli/SKILL.md +65 -0
  810. package/skills/spike/SKILL.md +51 -0
  811. package/skills/spotify-player/SKILL.md +64 -0
  812. package/skills/summarize/SKILL.md +87 -0
  813. package/skills/taskflow/SKILL.md +149 -0
  814. package/skills/taskflow/examples/inbox-triage.lobster +33 -0
  815. package/skills/taskflow/examples/pr-intake.lobster +32 -0
  816. package/skills/taskflow-inbox-triage/SKILL.md +119 -0
  817. package/skills/things-mac/SKILL.md +86 -0
  818. package/skills/tmux/SKILL.md +91 -0
  819. package/skills/tmux/scripts/find-sessions.sh +112 -0
  820. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  821. package/skills/trello/SKILL.md +108 -0
  822. package/skills/video-frames/SKILL.md +46 -0
  823. package/skills/video-frames/scripts/frame.sh +81 -0
  824. package/skills/voice-call/SKILL.md +45 -0
  825. package/skills/wacli/SKILL.md +72 -0
  826. package/skills/weather/SKILL.md +64 -0
  827. package/skills/xurl/SKILL.md +120 -0
@@ -0,0 +1,949 @@
1
+ ---
2
+ summary: "Migrate from the legacy backwards-compatibility layer to the modern plugin SDK"
3
+ title: "Plugin SDK migration"
4
+ sidebarTitle: "Migrate to SDK"
5
+ read_when:
6
+ - You see the NODMIX_PLUGIN_SDK_COMPAT_DEPRECATED warning
7
+ - You see the NODMIX_EXTENSION_API_DEPRECATED warning
8
+ - You used api.registerEmbeddedExtensionFactory before Nodmix 2026.4.25
9
+ - You are updating a plugin to the modern plugin architecture
10
+ - You maintain an external Nodmix plugin
11
+ ---
12
+
13
+ Nodmix has moved from a broad backwards-compatibility layer to a modern plugin
14
+ architecture with focused, documented imports. If your plugin was built before
15
+ the new architecture, this guide helps you migrate.
16
+
17
+ ## What is changing
18
+
19
+ The old plugin system provided two wide-open surfaces that let plugins import
20
+ anything they needed from a single entry point:
21
+
22
+ - **`nodmix/plugin-sdk/compat`** - a single import that re-exported dozens of
23
+ helpers. It was introduced to keep older hook-based plugins working while the
24
+ new plugin architecture was being built.
25
+ - **`nodmix/plugin-sdk/infra-runtime`** - a broad runtime helper barrel that
26
+ mixed system events, heartbeat state, delivery queues, fetch/proxy helpers,
27
+ file helpers, approval types, and unrelated utilities.
28
+ - **`nodmix/plugin-sdk/config-runtime`** - a broad config compatibility barrel
29
+ that still carries deprecated direct load/write helpers during the migration
30
+ window.
31
+ - **`nodmix/extension-api`** - a bridge that gave plugins direct access to
32
+ host-side helpers like the embedded agent runner.
33
+ - **`api.registerEmbeddedExtensionFactory(...)`** - a removed Pi-only bundled
34
+ extension hook that could observe embedded-runner events such as
35
+ `tool_result`.
36
+
37
+ The broad import surfaces are now **deprecated**. They still work at runtime,
38
+ but new plugins must not use them, and existing plugins should migrate before
39
+ the next major release removes them. The Pi-only embedded extension factory
40
+ registration API has been removed; use tool-result middleware instead.
41
+
42
+ Nodmix does not remove or reinterpret documented plugin behavior in the same
43
+ change that introduces a replacement. Breaking contract changes must first go
44
+ through a compatibility adapter, diagnostics, docs, and a deprecation window.
45
+ That applies to SDK imports, manifest fields, setup APIs, hooks, and runtime
46
+ registration behavior.
47
+
48
+ <Warning>
49
+ The backwards-compatibility layer will be removed in a future major release.
50
+ Plugins that still import from these surfaces will break when that happens.
51
+ Pi-only embedded extension factory registrations already no longer load.
52
+ </Warning>
53
+
54
+ ## Why this changed
55
+
56
+ The old approach caused problems:
57
+
58
+ - **Slow startup** - importing one helper loaded dozens of unrelated modules
59
+ - **Circular dependencies** - broad re-exports made it easy to create import cycles
60
+ - **Unclear API surface** - no way to tell which exports were stable vs internal
61
+
62
+ The modern plugin SDK fixes this: each import path (`nodmix/plugin-sdk/\<subpath\>`)
63
+ is a small, self-contained module with a clear purpose and documented contract.
64
+
65
+ Legacy provider convenience seams for bundled channels are also gone.
66
+ Channel-branded helper seams were private mono-repo shortcuts, not stable
67
+ plugin contracts. Use narrow generic SDK subpaths instead. Inside the bundled
68
+ plugin workspace, keep provider-owned helpers in that plugin's own `api.ts` or
69
+ `runtime-api.ts`.
70
+
71
+ Current bundled provider examples:
72
+
73
+ - Anthropic keeps Claude-specific stream helpers in its own `api.ts` /
74
+ `contract-api.ts` seam
75
+ - OpenAI keeps provider builders, default-model helpers, and realtime provider
76
+ builders in its own `api.ts`
77
+ - OpenRouter keeps provider builder and onboarding/config helpers in its own
78
+ `api.ts`
79
+
80
+ ## Talk and realtime voice migration plan
81
+
82
+ Realtime voice, telephony, meeting, and browser Talk code is moving from
83
+ surface-local turn bookkeeping to a shared Talk session controller exported by
84
+ `nodmix/plugin-sdk/realtime-voice`. The new controller owns the common Talk
85
+ event envelope, active turn state, capture state, output-audio state, recent
86
+ event history, and stale-turn rejection. Provider plugins should keep owning
87
+ vendor-specific realtime sessions; surface plugins should keep owning capture,
88
+ playback, telephony, and meeting quirks.
89
+
90
+ This Talk migration is intentionally breaking-clean:
91
+
92
+ 1. Keep the shared controller/runtime primitives in
93
+ `plugin-sdk/realtime-voice`.
94
+ 2. Move bundled surfaces onto the shared controller: browser relay,
95
+ managed-room handoff, voice-call realtime, voice-call streaming STT, Google
96
+ Meet realtime, and native push-to-talk.
97
+ 3. Replace old Talk RPC families with the final `talk.session.*` and
98
+ `talk.client.*` API.
99
+ 4. Advertise one live Talk event channel in Gateway
100
+ `hello-ok.features.events`: `talk.event`.
101
+ 5. Delete the old realtime HTTP endpoint and any request-time instruction
102
+ override path.
103
+
104
+ New code should not call `createTalkEventSequencer(...)` directly unless it is
105
+ implementing a low-level adapter or test fixture. Prefer the shared controller
106
+ so turn-scoped events cannot be emitted without a turn id, stale `turnEnd` /
107
+ `turnCancel` calls cannot clear a newer active turn, and output-audio lifecycle
108
+ events stay consistent across telephony, meetings, browser relay, managed-room
109
+ handoff, and native Talk clients.
110
+
111
+ The target public API shape is:
112
+
113
+ ```typescript
114
+ // Gateway-owned Talk session API.
115
+ await gateway.request("talk.session.create", {
116
+ mode: "realtime",
117
+ transport: "gateway-relay",
118
+ brain: "agent-consult",
119
+ sessionKey: "main",
120
+ });
121
+ await gateway.request("talk.session.appendAudio", { sessionId, audioBase64 });
122
+ await gateway.request("talk.session.cancelOutput", { sessionId, reason: "barge-in" });
123
+ await gateway.request("talk.session.submitToolResult", {
124
+ sessionId,
125
+ callId,
126
+ result: { status: "working" },
127
+ options: { willContinue: true },
128
+ });
129
+ await gateway.request("talk.session.submitToolResult", {
130
+ sessionId,
131
+ callId,
132
+ result: { status: "already_delivered" },
133
+ options: { suppressResponse: true },
134
+ });
135
+ await gateway.request("talk.session.submitToolResult", { sessionId, callId, result });
136
+ await gateway.request("talk.session.close", { sessionId });
137
+
138
+ // Client-owned provider session API.
139
+ await gateway.request("talk.client.create", {
140
+ mode: "realtime",
141
+ transport: "webrtc",
142
+ brain: "agent-consult",
143
+ sessionKey: "main",
144
+ });
145
+ await gateway.request("talk.client.toolCall", { sessionKey, callId, name, args });
146
+ ```
147
+
148
+ Browser-owned WebRTC/provider-websocket sessions use `talk.client.create`,
149
+ because the browser owns the provider negotiation and media transport while the
150
+ Gateway owns credentials, instructions, and tool policy. `talk.session.*` is the
151
+ common Gateway-managed surface for gateway-relay realtime, gateway-relay
152
+ transcription, and managed-room native STT/TTS sessions.
153
+
154
+ Legacy configs that placed realtime selectors beside `talk.provider` /
155
+ `talk.providers` should be repaired with `nodmix doctor --fix`; runtime Talk
156
+ does not reinterpret speech/TTS provider config as realtime provider config.
157
+
158
+ The supported `talk.session.create` combinations are intentionally small:
159
+
160
+ | Mode | Transport | Brain | Owner | Notes |
161
+ | --------------- | --------------- | --------------- | ------------------ | ------------------------------------------------------------------------------------------------------------------ |
162
+ | `realtime` | `gateway-relay` | `agent-consult` | Gateway | Full-duplex provider audio bridged through the Gateway; tool calls are routed through the agent-consult tool. |
163
+ | `transcription` | `gateway-relay` | `none` | Gateway | Streaming STT only; callers send input audio and receive transcript events. |
164
+ | `stt-tts` | `managed-room` | `agent-consult` | Native/client room | Push-to-talk and walkie-talkie style rooms where the client owns capture/playback and the Gateway owns turn state. |
165
+ | `stt-tts` | `managed-room` | `direct-tools` | Native/client room | Admin-only room mode for trusted first-party surfaces that execute Gateway tool actions directly. |
166
+
167
+ Removed method map:
168
+
169
+ | Old | New |
170
+ | -------------------------------- | -------------------------------------------------------- |
171
+ | `talk.realtime.session` | `talk.client.create` |
172
+ | `talk.realtime.toolCall` | `talk.client.toolCall` |
173
+ | `talk.realtime.relayAudio` | `talk.session.appendAudio` |
174
+ | `talk.realtime.relayCancel` | `talk.session.cancelOutput` or `talk.session.cancelTurn` |
175
+ | `talk.realtime.relayToolResult` | `talk.session.submitToolResult` |
176
+ | `talk.realtime.relayStop` | `talk.session.close` |
177
+ | `talk.transcription.session` | `talk.session.create({ mode: "transcription" })` |
178
+ | `talk.transcription.relayAudio` | `talk.session.appendAudio` |
179
+ | `talk.transcription.relayCancel` | `talk.session.cancelTurn` |
180
+ | `talk.transcription.relayStop` | `talk.session.close` |
181
+ | `talk.handoff.create` | `talk.session.create({ transport: "managed-room" })` |
182
+ | `talk.handoff.join` | `talk.session.join` |
183
+ | `talk.handoff.revoke` | `talk.session.close` |
184
+
185
+ The unified control vocabulary is also deliberately narrow:
186
+
187
+ | Method | Applies to | Contract |
188
+ | ------------------------------- | ------------------------------------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
189
+ | `talk.session.appendAudio` | `realtime/gateway-relay`, `transcription/gateway-relay` | Append a base64 PCM audio chunk to the provider session owned by the same Gateway connection. |
190
+ | `talk.session.startTurn` | `stt-tts/managed-room` | Start a managed-room user turn. |
191
+ | `talk.session.endTurn` | `stt-tts/managed-room` | End the active turn after stale-turn validation. |
192
+ | `talk.session.cancelTurn` | all Gateway-owned sessions | Cancel active capture/provider/agent/TTS work for a turn. |
193
+ | `talk.session.cancelOutput` | `realtime/gateway-relay` | Stop assistant audio output without necessarily ending the user turn. |
194
+ | `talk.session.submitToolResult` | `realtime/gateway-relay` | Complete a provider tool call emitted by the relay; pass `options.willContinue` for interim output or `options.suppressResponse` to satisfy the call without another assistant response. |
195
+ | `talk.session.close` | all unified sessions | Stop relay sessions or revoke managed-room state, then forget the unified session id. |
196
+
197
+ Do not introduce provider or platform special cases in core to make this work.
198
+ Core owns Talk session semantics. Provider plugins own vendor session setup.
199
+ Voice-call and Google Meet own telephony/meeting adapters. Browser and native
200
+ apps own device capture/playback UX.
201
+
202
+ ## Compatibility policy
203
+
204
+ For external plugins, compatibility work follows this order:
205
+
206
+ 1. add the new contract
207
+ 2. keep the old behavior wired through a compatibility adapter
208
+ 3. emit a diagnostic or warning that names the old path and replacement
209
+ 4. cover both paths in tests
210
+ 5. document the deprecation and migration path
211
+ 6. remove only after the announced migration window, usually in a major release
212
+
213
+ Maintainers can audit the current migration queue with
214
+ `pnpm plugins:boundary-report`. Use `pnpm plugins:boundary-report:summary` for
215
+ compact counts, `--owner <id>` for one plugin or compatibility owner, and
216
+ `pnpm plugins:boundary-report:ci` when a CI gate should fail on due
217
+ compatibility records, cross-owner reserved SDK imports, or unused reserved SDK
218
+ subpaths. The report groups deprecated
219
+ compatibility records by removal date, counts local code/docs references,
220
+ surfaces cross-owner reserved SDK imports, and summarizes the private
221
+ memory-host SDK bridge so compatibility cleanup stays explicit instead of
222
+ relying on ad hoc searches. Reserved SDK subpaths must have tracked owner usage;
223
+ unused reserved helper exports should be removed from the public SDK.
224
+
225
+ If a manifest field is still accepted, plugin authors can keep using it until
226
+ the docs and diagnostics say otherwise. New code should prefer the documented
227
+ replacement, but existing plugins should not break during ordinary minor
228
+ releases.
229
+
230
+ ## How to migrate
231
+
232
+ <Steps>
233
+ <Step title="Migrate runtime config load/write helpers">
234
+ Bundled plugins should stop calling
235
+ `api.runtime.config.loadConfig()` and
236
+ `api.runtime.config.writeConfigFile(...)` directly. Prefer config that was
237
+ already passed into the active call path. Long-lived handlers that need the
238
+ current process snapshot can use `api.runtime.config.current()`. Long-lived
239
+ agent tools should use the tool context's `ctx.getRuntimeConfig()` inside
240
+ `execute` so a tool created before a config write still sees the refreshed
241
+ runtime config.
242
+
243
+ Config writes must go through the transactional helpers and choose an
244
+ after-write policy:
245
+
246
+ ```typescript
247
+ await api.runtime.config.mutateConfigFile({
248
+ afterWrite: { mode: "auto" },
249
+ mutate(draft) {
250
+ draft.plugins ??= {};
251
+ },
252
+ });
253
+ ```
254
+
255
+ Use `afterWrite: { mode: "restart", reason: "..." }` when the caller knows
256
+ the change requires a clean gateway restart, and
257
+ `afterWrite: { mode: "none", reason: "..." }` only when the caller owns the
258
+ follow-up and deliberately wants to suppress the reload planner.
259
+ Mutation results include a typed `followUp` summary for tests and logging;
260
+ the gateway remains responsible for applying or scheduling the restart.
261
+ `loadConfig` and `writeConfigFile` remain as deprecated compatibility
262
+ helpers for external plugins during the migration window and warn once with
263
+ the `runtime-config-load-write` compatibility code. Bundled plugins and repo
264
+ runtime code are protected by scanner guardrails in
265
+ `pnpm check:deprecated-api-usage` and
266
+ `pnpm check:no-runtime-action-load-config`: new production plugin usage
267
+ fails outright, direct config writes fail, gateway server methods must use
268
+ the request runtime snapshot, runtime channel send/action/client helpers
269
+ must receive config from their boundary, and long-lived runtime modules have
270
+ zero allowed ambient `loadConfig()` calls.
271
+
272
+ New plugin code should also avoid importing the broad
273
+ `nodmix/plugin-sdk/config-runtime` compatibility barrel. Use the narrow
274
+ SDK subpath that matches the job:
275
+
276
+ | Need | Import |
277
+ | --- | --- |
278
+ | Config types such as `NodmixConfig` | `nodmix/plugin-sdk/config-contracts` |
279
+ | Already-loaded config assertions and plugin-entry config lookup | `nodmix/plugin-sdk/plugin-config-runtime` |
280
+ | Current runtime snapshot reads | `nodmix/plugin-sdk/runtime-config-snapshot` |
281
+ | Config writes | `nodmix/plugin-sdk/config-mutation` |
282
+ | Session store helpers | `nodmix/plugin-sdk/session-store-runtime` |
283
+ | Markdown table config | `nodmix/plugin-sdk/markdown-table-runtime` |
284
+ | Group policy runtime helpers | `nodmix/plugin-sdk/runtime-group-policy` |
285
+ | Secret input resolution | `nodmix/plugin-sdk/secret-input-runtime` |
286
+ | Model/session overrides | `nodmix/plugin-sdk/model-session-runtime` |
287
+
288
+ Bundled plugins and their tests are scanner-guarded against the broad
289
+ barrel so imports and mocks stay local to the behavior they need. The broad
290
+ barrel still exists for external compatibility, but new code should not
291
+ depend on it.
292
+
293
+ </Step>
294
+
295
+ <Step title="Migrate Pi tool-result extensions to middleware">
296
+ Bundled plugins must replace Pi-only
297
+ `api.registerEmbeddedExtensionFactory(...)` tool-result handlers with
298
+ runtime-neutral middleware.
299
+
300
+ ```typescript
301
+ // Pi and Codex runtime dynamic tools
302
+ api.registerAgentToolResultMiddleware(async (event) => {
303
+ return compactToolResult(event);
304
+ }, {
305
+ runtimes: ["pi", "codex"],
306
+ });
307
+ ```
308
+
309
+ Update the plugin manifest at the same time:
310
+
311
+ ```json
312
+ {
313
+ "contracts": {
314
+ "agentToolResultMiddleware": ["pi", "codex"]
315
+ }
316
+ }
317
+ ```
318
+
319
+ External plugins cannot register tool-result middleware because it can
320
+ rewrite high-trust tool output before the model sees it.
321
+
322
+ </Step>
323
+
324
+ <Step title="Migrate approval-native handlers to capability facts">
325
+ Approval-capable channel plugins now expose native approval behavior through
326
+ `approvalCapability.nativeRuntime` plus the shared runtime-context registry.
327
+
328
+ Key changes:
329
+
330
+ - Replace `approvalCapability.handler.loadRuntime(...)` with
331
+ `approvalCapability.nativeRuntime`
332
+ - Move approval-specific auth/delivery off legacy `plugin.auth` /
333
+ `plugin.approvals` wiring and onto `approvalCapability`
334
+ - `ChannelPlugin.approvals` has been removed from the public channel-plugin
335
+ contract; move delivery/native/render fields onto `approvalCapability`
336
+ - `plugin.auth` remains for channel login/logout flows only; approval auth
337
+ hooks there are no longer read by core
338
+ - Register channel-owned runtime objects such as clients, tokens, or Bolt
339
+ apps through `nodmix/plugin-sdk/channel-runtime-context`
340
+ - Do not send plugin-owned reroute notices from native approval handlers;
341
+ core now owns routed-elsewhere notices from actual delivery results
342
+ - When passing `channelRuntime` into `createChannelManager(...)`, provide a
343
+ real `createPluginRuntime().channel` surface. Partial stubs are rejected.
344
+
345
+ See `/plugins/sdk-channel-plugins` for the current approval capability
346
+ layout.
347
+
348
+ </Step>
349
+
350
+ <Step title="Audit Windows wrapper fallback behavior">
351
+ If your plugin uses `nodmix/plugin-sdk/windows-spawn`, unresolved Windows
352
+ `.cmd`/`.bat` wrappers now fail closed unless you explicitly pass
353
+ `allowShellFallback: true`.
354
+
355
+ ```typescript
356
+ // Before
357
+ const program = applyWindowsSpawnProgramPolicy({ candidate });
358
+
359
+ // After
360
+ const program = applyWindowsSpawnProgramPolicy({
361
+ candidate,
362
+ // Only set this for trusted compatibility callers that intentionally
363
+ // accept shell-mediated fallback.
364
+ allowShellFallback: true,
365
+ });
366
+ ```
367
+
368
+ If your caller does not intentionally rely on shell fallback, do not set
369
+ `allowShellFallback` and handle the thrown error instead.
370
+
371
+ </Step>
372
+
373
+ <Step title="Find deprecated imports">
374
+ Search your plugin for imports from either deprecated surface:
375
+
376
+ ```bash
377
+ grep -r "plugin-sdk/compat" my-plugin/
378
+ grep -r "plugin-sdk/infra-runtime" my-plugin/
379
+ grep -r "plugin-sdk/config-runtime" my-plugin/
380
+ grep -r "nodmix/extension-api" my-plugin/
381
+ ```
382
+
383
+ </Step>
384
+
385
+ <Step title="Replace with focused imports">
386
+ Each export from the old surface maps to a specific modern import path:
387
+
388
+ ```typescript
389
+ // Before (deprecated backwards-compatibility layer)
390
+ import {
391
+ createChannelReplyPipeline,
392
+ createPluginRuntimeStore,
393
+ resolveControlCommandGate,
394
+ } from "nodmix/plugin-sdk/compat";
395
+
396
+ // After (modern focused imports)
397
+ import { createChannelReplyPipeline } from "nodmix/plugin-sdk/channel-reply-pipeline";
398
+ import { createPluginRuntimeStore } from "nodmix/plugin-sdk/runtime-store";
399
+ import { resolveControlCommandGate } from "nodmix/plugin-sdk/command-auth";
400
+ ```
401
+
402
+ For host-side helpers, use the injected plugin runtime instead of importing
403
+ directly:
404
+
405
+ ```typescript
406
+ // Before (deprecated extension-api bridge)
407
+ import { runEmbeddedPiAgent } from "nodmix/extension-api";
408
+ const result = await runEmbeddedPiAgent({ sessionId, prompt });
409
+
410
+ // After (injected runtime)
411
+ const result = await api.runtime.agent.runEmbeddedPiAgent({ sessionId, prompt });
412
+ ```
413
+
414
+ The same pattern applies to other legacy bridge helpers:
415
+
416
+ | Old import | Modern equivalent |
417
+ | --- | --- |
418
+ | `resolveAgentDir` | `api.runtime.agent.resolveAgentDir` |
419
+ | `resolveAgentWorkspaceDir` | `api.runtime.agent.resolveAgentWorkspaceDir` |
420
+ | `resolveAgentIdentity` | `api.runtime.agent.resolveAgentIdentity` |
421
+ | `resolveThinkingDefault` | `api.runtime.agent.resolveThinkingDefault` |
422
+ | `resolveAgentTimeoutMs` | `api.runtime.agent.resolveAgentTimeoutMs` |
423
+ | `ensureAgentWorkspace` | `api.runtime.agent.ensureAgentWorkspace` |
424
+ | session store helpers | `api.runtime.agent.session.*` |
425
+
426
+ </Step>
427
+
428
+ <Step title="Replace broad infra-runtime imports">
429
+ `nodmix/plugin-sdk/infra-runtime` still exists for external
430
+ compatibility, but new code should import the focused helper surface it
431
+ actually needs:
432
+
433
+ | Need | Import |
434
+ | --- | --- |
435
+ | System event queue helpers | `nodmix/plugin-sdk/system-event-runtime` |
436
+ | Heartbeat wake, event, and visibility helpers | `nodmix/plugin-sdk/heartbeat-runtime` |
437
+ | Pending delivery queue drain | `nodmix/plugin-sdk/delivery-queue-runtime` |
438
+ | Channel activity telemetry | `nodmix/plugin-sdk/channel-activity-runtime` |
439
+ | In-memory dedupe caches | `nodmix/plugin-sdk/dedupe-runtime` |
440
+ | Safe local-file/media path helpers | `nodmix/plugin-sdk/file-access-runtime` |
441
+ | Dispatcher-aware fetch | `nodmix/plugin-sdk/runtime-fetch` |
442
+ | Proxy and guarded fetch helpers | `nodmix/plugin-sdk/fetch-runtime` |
443
+ | SSRF dispatcher policy types | `nodmix/plugin-sdk/ssrf-dispatcher` |
444
+ | Approval request/resolution types | `nodmix/plugin-sdk/approval-runtime` |
445
+ | Approval reply payload and command helpers | `nodmix/plugin-sdk/approval-reply-runtime` |
446
+ | Error formatting helpers | `nodmix/plugin-sdk/error-runtime` |
447
+ | Transport readiness waits | `nodmix/plugin-sdk/transport-ready-runtime` |
448
+ | Secure token helpers | `nodmix/plugin-sdk/secure-random-runtime` |
449
+ | Bounded async task concurrency | `nodmix/plugin-sdk/concurrency-runtime` |
450
+ | Numeric coercion | `nodmix/plugin-sdk/number-runtime` |
451
+ | Process-local async lock | `nodmix/plugin-sdk/async-lock-runtime` |
452
+ | File locks | `nodmix/plugin-sdk/file-lock` |
453
+
454
+ Bundled plugins are scanner-guarded against `infra-runtime`, so repo code
455
+ cannot regress to the broad barrel.
456
+
457
+ </Step>
458
+
459
+ <Step title="Migrate channel route helpers">
460
+ New channel route code should use `nodmix/plugin-sdk/channel-route`.
461
+ The older route-key and comparable-target names remain as compatibility
462
+ aliases during the migration window, but new plugins should use the route
463
+ names that describe the behavior directly:
464
+
465
+ | Old helper | Modern helper |
466
+ | --- | --- |
467
+ | `channelRouteIdentityKey(...)` | `channelRouteDedupeKey(...)` |
468
+ | `channelRouteKey(...)` | `channelRouteCompactKey(...)` |
469
+ | `ComparableChannelTarget` | `ChannelRouteParsedTarget` |
470
+ | `resolveComparableTargetForChannel(...)` | `resolveRouteTargetForChannel(...)` |
471
+ | `resolveComparableTargetForLoadedChannel(...)` | `resolveRouteTargetForLoadedChannel(...)` |
472
+ | `comparableChannelTargetsMatch(...)` | `channelRouteTargetsMatchExact(...)` |
473
+ | `comparableChannelTargetsShareRoute(...)` | `channelRouteTargetsShareConversation(...)` |
474
+
475
+ The modern route helpers normalize `{ channel, to, accountId, threadId }`
476
+ consistently across native approvals, reply suppression, inbound dedupe,
477
+ cron delivery, and session routing. If your plugin owns custom target
478
+ grammar, use `resolveChannelRouteTargetWithParser(...)` to adapt that
479
+ parser into the same route target contract.
480
+
481
+ </Step>
482
+
483
+ <Step title="Build and test">
484
+ ```bash
485
+ pnpm build
486
+ pnpm test -- my-plugin/
487
+ ```
488
+ </Step>
489
+ </Steps>
490
+
491
+ ## Import path reference
492
+
493
+ <Accordion title="Common import path table">
494
+ | Import path | Purpose | Key exports |
495
+ | --- | --- | --- |
496
+ | `plugin-sdk/plugin-entry` | Canonical plugin entry helper | `definePluginEntry` |
497
+ | `plugin-sdk/core` | Legacy umbrella re-export for channel entry definitions/builders | `defineChannelPluginEntry`, `createChatChannelPlugin` |
498
+ | `plugin-sdk/config-schema` | Root config schema export | `NodmixSchema` |
499
+ | `plugin-sdk/provider-entry` | Single-provider entry helper | `defineSingleProviderPluginEntry` |
500
+ | `plugin-sdk/channel-core` | Focused channel entry definitions and builders | `defineChannelPluginEntry`, `defineSetupPluginEntry`, `createChatChannelPlugin`, `createChannelPluginBase` |
501
+ | `plugin-sdk/setup` | Shared setup wizard helpers | Setup translator, allowlist prompts, setup status builders |
502
+ | `plugin-sdk/setup-runtime` | Setup-time runtime helpers | `createSetupTranslator`, import-safe setup patch adapters, lookup-note helpers, `promptResolvedAllowFrom`, `splitSetupEntries`, delegated setup proxies |
503
+ | `plugin-sdk/setup-adapter-runtime` | Deprecated setup adapter alias | Use `plugin-sdk/setup-runtime` |
504
+ | `plugin-sdk/setup-tools` | Setup tooling helpers | `formatCliCommand`, `detectBinary`, `extractArchive`, `resolveBrewExecutable`, `formatDocsLink`, `CONFIG_DIR` |
505
+ | `plugin-sdk/account-core` | Multi-account helpers | Account list/config/action-gate helpers |
506
+ | `plugin-sdk/account-id` | Account-id helpers | `DEFAULT_ACCOUNT_ID`, account-id normalization |
507
+ | `plugin-sdk/account-resolution` | Account lookup helpers | Account lookup + default-fallback helpers |
508
+ | `plugin-sdk/account-helpers` | Narrow account helpers | Account list/account-action helpers |
509
+ | `plugin-sdk/channel-setup` | Setup wizard adapters | `createOptionalChannelSetupSurface`, `createOptionalChannelSetupAdapter`, `createOptionalChannelSetupWizard`, plus `DEFAULT_ACCOUNT_ID`, `createTopLevelChannelDmPolicy`, `setSetupChannelEnabled`, `splitSetupEntries` |
510
+ | `plugin-sdk/channel-pairing` | DM pairing primitives | `createChannelPairingController` |
511
+ | `plugin-sdk/channel-reply-pipeline` | Reply prefix, typing, and source-delivery wiring | `createChannelReplyPipeline`, `resolveChannelSourceReplyDeliveryMode` |
512
+ | `plugin-sdk/channel-config-helpers` | Config adapter factories and DM access helpers | `createHybridChannelConfigAdapter`, `resolveChannelDmAccess`, `resolveChannelDmAllowFrom`, `resolveChannelDmPolicy`, `normalizeChannelDmPolicy`, `normalizeLegacyDmAliases` |
513
+ | `plugin-sdk/channel-config-schema` | Config schema builders | Shared channel config schema primitives and the generic builder only |
514
+ | `plugin-sdk/bundled-channel-config-schema` | Bundled config schemas | Nodmix-maintained bundled plugins only; new plugins must define plugin-local schemas |
515
+ | `plugin-sdk/channel-config-schema-legacy` | Deprecated bundled config schemas | Compatibility alias only; use `plugin-sdk/bundled-channel-config-schema` for maintained bundled plugins |
516
+ | `plugin-sdk/telegram-command-config` | Telegram command config helpers | Command-name normalization, description trimming, duplicate/conflict validation |
517
+ | `plugin-sdk/channel-policy` | Group/DM policy resolution | `resolveChannelGroupRequireMention` |
518
+ | `plugin-sdk/channel-lifecycle` | Account status and draft stream lifecycle helpers | `createAccountStatusSink`, draft preview finalization helpers |
519
+ | `plugin-sdk/inbound-envelope` | Inbound envelope helpers | Shared route + envelope builder helpers |
520
+ | `plugin-sdk/inbound-reply-dispatch` | Inbound reply helpers | Shared record-and-dispatch helpers |
521
+ | `plugin-sdk/messaging-targets` | Messaging target parsing | Target parsing/matching helpers |
522
+ | `plugin-sdk/outbound-media` | Outbound media helpers | Shared outbound media loading |
523
+ | `plugin-sdk/outbound-send-deps` | Outbound send dependency helpers | Lightweight `resolveOutboundSendDep` lookup without importing the full outbound runtime |
524
+ | `plugin-sdk/outbound-runtime` | Outbound runtime helpers | Outbound delivery, identity/send delegate, session, formatting, and payload planning helpers |
525
+ | `plugin-sdk/thread-bindings-runtime` | Thread-binding helpers | Thread-binding lifecycle and adapter helpers |
526
+ | `plugin-sdk/agent-media-payload` | Legacy media payload helpers | Agent media payload builder for legacy field layouts |
527
+ | `plugin-sdk/channel-runtime` | Deprecated compatibility shim | Legacy channel runtime utilities only |
528
+ | `plugin-sdk/channel-send-result` | Send result types | Reply result types |
529
+ | `plugin-sdk/runtime-store` | Persistent plugin storage | `createPluginRuntimeStore` |
530
+ | `plugin-sdk/runtime` | Broad runtime helpers | Runtime/logging/backup/plugin-install helpers |
531
+ | `plugin-sdk/runtime-env` | Narrow runtime env helpers | Logger/runtime env, timeout, retry, and backoff helpers |
532
+ | `plugin-sdk/plugin-runtime` | Shared plugin runtime helpers | Plugin commands/hooks/http/interactive helpers |
533
+ | `plugin-sdk/hook-runtime` | Hook pipeline helpers | Shared webhook/internal hook pipeline helpers |
534
+ | `plugin-sdk/lazy-runtime` | Lazy runtime helpers | `createLazyRuntimeModule`, `createLazyRuntimeMethod`, `createLazyRuntimeMethodBinder`, `createLazyRuntimeNamedExport`, `createLazyRuntimeSurface` |
535
+ | `plugin-sdk/process-runtime` | Process helpers | Shared exec helpers |
536
+ | `plugin-sdk/cli-runtime` | CLI runtime helpers | Command formatting, waits, version helpers |
537
+ | `plugin-sdk/gateway-runtime` | Gateway helpers | Gateway client, event-loop-ready start helper, and channel-status patch helpers |
538
+ | `plugin-sdk/config-runtime` | Deprecated config compatibility shim | Prefer `config-contracts`, `plugin-config-runtime`, `runtime-config-snapshot`, and `config-mutation` |
539
+ | `plugin-sdk/telegram-command-config` | Telegram command helpers | Fallback-stable Telegram command validation helpers when the bundled Telegram contract surface is unavailable |
540
+ | `plugin-sdk/approval-runtime` | Approval prompt helpers | Exec/plugin approval payload, approval capability/profile helpers, native approval routing/runtime helpers, and structured approval display path formatting |
541
+ | `plugin-sdk/approval-auth-runtime` | Approval auth helpers | Approver resolution, same-chat action auth |
542
+ | `plugin-sdk/approval-client-runtime` | Approval client helpers | Native exec approval profile/filter helpers |
543
+ | `plugin-sdk/approval-delivery-runtime` | Approval delivery helpers | Native approval capability/delivery adapters |
544
+ | `plugin-sdk/approval-gateway-runtime` | Approval gateway helpers | Shared approval gateway-resolution helper |
545
+ | `plugin-sdk/approval-handler-adapter-runtime` | Approval adapter helpers | Lightweight native approval adapter loading helpers for hot channel entrypoints |
546
+ | `plugin-sdk/approval-handler-runtime` | Approval handler helpers | Broader approval handler runtime helpers; prefer the narrower adapter/gateway seams when they are enough |
547
+ | `plugin-sdk/approval-native-runtime` | Approval target helpers | Native approval target/account binding helpers |
548
+ | `plugin-sdk/approval-reply-runtime` | Approval reply helpers | Exec/plugin approval reply payload helpers |
549
+ | `plugin-sdk/channel-runtime-context` | Channel runtime-context helpers | Generic channel runtime-context register/get/watch helpers |
550
+ | `plugin-sdk/security-runtime` | Security helpers | Shared trust, DM gating, root-bounded file/path helpers, external-content, and secret-collection helpers |
551
+ | `plugin-sdk/ssrf-policy` | SSRF policy helpers | Host allowlist and private-network policy helpers |
552
+ | `plugin-sdk/ssrf-runtime` | SSRF runtime helpers | Pinned-dispatcher, guarded fetch, SSRF policy helpers |
553
+ | `plugin-sdk/system-event-runtime` | System event helpers | `enqueueSystemEvent`, `peekSystemEventEntries` |
554
+ | `plugin-sdk/heartbeat-runtime` | Heartbeat helpers | Heartbeat wake, event, and visibility helpers |
555
+ | `plugin-sdk/delivery-queue-runtime` | Delivery queue helpers | `drainPendingDeliveries` |
556
+ | `plugin-sdk/channel-activity-runtime` | Channel activity helpers | `recordChannelActivity` |
557
+ | `plugin-sdk/dedupe-runtime` | Dedupe helpers | In-memory dedupe caches |
558
+ | `plugin-sdk/file-access-runtime` | File access helpers | Safe local-file/media path helpers |
559
+ | `plugin-sdk/transport-ready-runtime` | Transport readiness helpers | `waitForTransportReady` |
560
+ | `plugin-sdk/collection-runtime` | Bounded cache helpers | `pruneMapToMaxSize` |
561
+ | `plugin-sdk/diagnostic-runtime` | Diagnostic gating helpers | `isDiagnosticFlagEnabled`, `isDiagnosticsEnabled` |
562
+ | `plugin-sdk/error-runtime` | Error formatting helpers | `formatUncaughtError`, `isApprovalNotFoundError`, error graph helpers |
563
+ | `plugin-sdk/fetch-runtime` | Wrapped fetch/proxy helpers | `resolveFetch`, proxy helpers, EnvHttpProxyAgent option helpers |
564
+ | `plugin-sdk/host-runtime` | Host normalization helpers | `normalizeHostname`, `normalizeScpRemoteHost` |
565
+ | `plugin-sdk/retry-runtime` | Retry helpers | `RetryConfig`, `retryAsync`, policy runners |
566
+ | `plugin-sdk/allow-from` | Allowlist formatting | `formatAllowFromLowercase` |
567
+ | `plugin-sdk/allowlist-resolution` | Allowlist input mapping | `mapAllowlistResolutionInputs` |
568
+ | `plugin-sdk/command-auth` | Command gating and command-surface helpers | `resolveControlCommandGate`, sender-authorization helpers, command registry helpers including dynamic argument menu formatting |
569
+ | `plugin-sdk/command-status` | Command status/help renderers | `buildCommandsMessage`, `buildCommandsMessagePaginated`, `buildHelpMessage` |
570
+ | `plugin-sdk/secret-input` | Secret input parsing | Secret input helpers |
571
+ | `plugin-sdk/webhook-ingress` | Webhook request helpers | Webhook target utilities |
572
+ | `plugin-sdk/webhook-request-guards` | Webhook body guard helpers | Request body read/limit helpers |
573
+ | `plugin-sdk/reply-runtime` | Shared reply runtime | Inbound dispatch, heartbeat, reply planner, chunking |
574
+ | `plugin-sdk/reply-dispatch-runtime` | Narrow reply dispatch helpers | Finalize, provider dispatch, and conversation-label helpers |
575
+ | `plugin-sdk/reply-history` | Reply-history helpers | `createChannelHistoryWindow`; deprecated map-helper compatibility exports such as `buildPendingHistoryContextFromMap`, `recordPendingHistoryEntry`, and `clearHistoryEntriesIfEnabled` |
576
+ | `plugin-sdk/reply-reference` | Reply reference planning | `createReplyReferencePlanner` |
577
+ | `plugin-sdk/reply-chunking` | Reply chunk helpers | Text/markdown chunking helpers |
578
+ | `plugin-sdk/session-store-runtime` | Session store helpers | Store path + updated-at helpers |
579
+ | `plugin-sdk/state-paths` | State path helpers | State and OAuth dir helpers |
580
+ | `plugin-sdk/routing` | Routing/session-key helpers | `resolveAgentRoute`, `buildAgentSessionKey`, `resolveDefaultAgentBoundAccountId`, session-key normalization helpers |
581
+ | `plugin-sdk/status-helpers` | Channel status helpers | Channel/account status summary builders, runtime-state defaults, issue metadata helpers |
582
+ | `plugin-sdk/target-resolver-runtime` | Target resolver helpers | Shared target resolver helpers |
583
+ | `plugin-sdk/string-normalization-runtime` | String normalization helpers | Slug/string normalization helpers |
584
+ | `plugin-sdk/request-url` | Request URL helpers | Extract string URLs from request-like inputs |
585
+ | `plugin-sdk/run-command` | Timed command helpers | Timed command runner with normalized stdout/stderr |
586
+ | `plugin-sdk/param-readers` | Param readers | Common tool/CLI param readers |
587
+ | `plugin-sdk/tool-payload` | Tool payload extraction | Extract normalized payloads from tool result objects |
588
+ | `plugin-sdk/tool-send` | Tool send extraction | Extract canonical send target fields from tool args |
589
+ | `plugin-sdk/temp-path` | Temp path helpers | Shared temp-download path helpers |
590
+ | `plugin-sdk/logging-core` | Logging helpers | Subsystem logger and redaction helpers |
591
+ | `plugin-sdk/markdown-table-runtime` | Markdown-table helpers | Markdown table mode helpers |
592
+ | `plugin-sdk/reply-payload` | Message reply types | Reply payload types |
593
+ | `plugin-sdk/provider-setup` | Curated local/self-hosted provider setup helpers | Self-hosted provider discovery/config helpers |
594
+ | `plugin-sdk/self-hosted-provider-setup` | Focused OpenAI-compatible self-hosted provider setup helpers | Same self-hosted provider discovery/config helpers |
595
+ | `plugin-sdk/provider-auth-runtime` | Provider runtime auth helpers | Runtime API-key resolution helpers |
596
+ | `plugin-sdk/provider-auth-api-key` | Provider API-key setup helpers | API-key onboarding/profile-write helpers |
597
+ | `plugin-sdk/provider-auth-result` | Provider auth-result helpers | Standard OAuth auth-result builder |
598
+ | `plugin-sdk/provider-selection-runtime` | Provider selection helpers | Configured-or-auto provider selection and raw provider config merging |
599
+ | `plugin-sdk/provider-env-vars` | Provider env-var helpers | Provider auth env-var lookup helpers |
600
+ | `plugin-sdk/provider-model-shared` | Shared provider model/replay helpers | `ProviderReplayFamily`, `buildProviderReplayFamilyHooks`, `normalizeModelCompat`, shared replay-policy builders, provider-endpoint helpers, and model-id normalization helpers |
601
+ | `plugin-sdk/provider-catalog-shared` | Shared provider catalog helpers | `findCatalogTemplate`, `buildSingleProviderApiKeyCatalog`, `buildManifestModelProviderConfig`, `supportsNativeStreamingUsageCompat`, `applyProviderNativeStreamingUsageCompat` |
602
+ | `plugin-sdk/provider-onboard` | Provider onboarding patches | Onboarding config helpers |
603
+ | `plugin-sdk/provider-http` | Provider HTTP helpers | Generic provider HTTP/endpoint capability helpers, including audio transcription multipart form helpers |
604
+ | `plugin-sdk/provider-web-fetch` | Provider web-fetch helpers | Web-fetch provider registration/cache helpers |
605
+ | `plugin-sdk/provider-web-search-config-contract` | Provider web-search config helpers | Narrow web-search config/credential helpers for providers that do not need plugin-enable wiring |
606
+ | `plugin-sdk/provider-web-search-contract` | Provider web-search contract helpers | Narrow web-search config/credential contract helpers such as `createWebSearchProviderContractFields`, `enablePluginInConfig`, `resolveProviderWebSearchPluginConfig`, and scoped credential setters/getters |
607
+ | `plugin-sdk/provider-web-search` | Provider web-search helpers | Web-search provider registration/cache/runtime helpers |
608
+ | `plugin-sdk/provider-tools` | Provider tool/schema compat helpers | `ProviderToolCompatFamily`, `buildProviderToolCompatFamilyHooks`, and DeepSeek/Gemini/OpenAI schema cleanup + diagnostics |
609
+ | `plugin-sdk/provider-usage` | Provider usage helpers | `fetchClaudeUsage`, `fetchGeminiUsage`, `fetchGithubCopilotUsage`, and other provider usage helpers |
610
+ | `plugin-sdk/provider-stream` | Provider stream wrapper helpers | `ProviderStreamFamily`, `buildProviderStreamFamilyHooks`, `composeProviderStreamWrappers`, stream wrapper types, and shared Anthropic/Bedrock/DeepSeek V4/Google/Kilocode/Moonshot/OpenAI/OpenRouter/Z.A.I/MiniMax/Copilot wrapper helpers |
611
+ | `plugin-sdk/provider-transport-runtime` | Provider transport helpers | Native provider transport helpers such as guarded fetch, transport message transforms, and writable transport event streams |
612
+ | `plugin-sdk/keyed-async-queue` | Ordered async queue | `KeyedAsyncQueue` |
613
+ | `plugin-sdk/media-runtime` | Shared media helpers | Media fetch/transform/store helpers, ffprobe-backed video dimension probing, and media payload builders |
614
+ | `plugin-sdk/media-generation-runtime` | Shared media-generation helpers | Shared failover helpers, candidate selection, and missing-model messaging for image/video/music generation |
615
+ | `plugin-sdk/media-understanding` | Media-understanding helpers | Media understanding provider types plus provider-facing image/audio helper exports |
616
+ | `plugin-sdk/text-runtime` | Deprecated broad text compatibility export | Use `string-coerce-runtime`, `text-chunking`, `text-utility-runtime`, and `logging-core` |
617
+ | `plugin-sdk/text-chunking` | Text chunking helpers | Outbound text chunking helper |
618
+ | `plugin-sdk/speech` | Speech helpers | Speech provider types plus provider-facing directive, registry, validation helpers, and OpenAI-compatible TTS builder |
619
+ | `plugin-sdk/speech-core` | Shared speech core | Speech provider types, registry, directives, normalization |
620
+ | `plugin-sdk/realtime-transcription` | Realtime transcription helpers | Provider types, registry helpers, and shared WebSocket session helper |
621
+ | `plugin-sdk/realtime-voice` | Realtime voice helpers | Provider types, registry/resolution helpers, bridge session helpers, shared agent talk-back queues, transcript/event health, echo suppression, and fast context consult helpers |
622
+ | `plugin-sdk/image-generation` | Image-generation helpers | Image generation provider types plus image asset/data URL helpers and the OpenAI-compatible image provider builder |
623
+ | `plugin-sdk/image-generation-core` | Shared image-generation core | Image-generation types, failover, auth, and registry helpers |
624
+ | `plugin-sdk/music-generation` | Music-generation helpers | Music-generation provider/request/result types |
625
+ | `plugin-sdk/music-generation-core` | Shared music-generation core | Music-generation types, failover helpers, provider lookup, and model-ref parsing |
626
+ | `plugin-sdk/video-generation` | Video-generation helpers | Video-generation provider/request/result types |
627
+ | `plugin-sdk/video-generation-core` | Shared video-generation core | Video-generation types, failover helpers, provider lookup, and model-ref parsing |
628
+ | `plugin-sdk/interactive-runtime` | Interactive reply helpers | Interactive reply payload normalization/reduction |
629
+ | `plugin-sdk/channel-config-primitives` | Channel config primitives | Narrow channel config-schema primitives |
630
+ | `plugin-sdk/channel-config-writes` | Channel config-write helpers | Channel config-write authorization helpers |
631
+ | `plugin-sdk/channel-plugin-common` | Shared channel prelude | Shared channel plugin prelude exports |
632
+ | `plugin-sdk/channel-status` | Channel status helpers | Shared channel status snapshot/summary helpers |
633
+ | `plugin-sdk/allowlist-config-edit` | Allowlist config helpers | Allowlist config edit/read helpers |
634
+ | `plugin-sdk/group-access` | Group access helpers | Shared group-access decision helpers |
635
+ | `plugin-sdk/direct-dm` | Direct-DM helpers | Shared direct-DM auth/guard helpers |
636
+ | `plugin-sdk/extension-shared` | Shared extension helpers | Passive-channel/status and ambient proxy helper primitives |
637
+ | `plugin-sdk/webhook-targets` | Webhook target helpers | Webhook target registry and route-install helpers |
638
+ | `plugin-sdk/webhook-path` | Deprecated webhook path alias | Use `plugin-sdk/webhook-ingress` |
639
+ | `plugin-sdk/web-media` | Shared web media helpers | Remote/local media loading helpers |
640
+ | `plugin-sdk/zod` | Deprecated Zod compatibility re-export | Import `zod` from `zod` directly |
641
+ | `plugin-sdk/memory-core` | Bundled memory-core helpers | Memory manager/config/file/CLI helper surface |
642
+ | `plugin-sdk/memory-core-engine-runtime` | Memory engine runtime facade | Memory index/search runtime facade |
643
+ | `plugin-sdk/memory-core-host-engine-foundation` | Memory host foundation engine | Memory host foundation engine exports |
644
+ | `plugin-sdk/memory-core-host-engine-embeddings` | Memory host embedding engine | Memory embedding contracts, registry access, local provider, and generic batch/remote helpers; concrete remote providers live in their owning plugins |
645
+ | `plugin-sdk/memory-core-host-engine-qmd` | Memory host QMD engine | Memory host QMD engine exports |
646
+ | `plugin-sdk/memory-core-host-engine-storage` | Memory host storage engine | Memory host storage engine exports |
647
+ | `plugin-sdk/memory-core-host-multimodal` | Memory host multimodal helpers | Memory host multimodal helpers |
648
+ | `plugin-sdk/memory-core-host-query` | Memory host query helpers | Memory host query helpers |
649
+ | `plugin-sdk/memory-core-host-secret` | Memory host secret helpers | Memory host secret helpers |
650
+ | `plugin-sdk/memory-core-host-events` | Deprecated memory event alias | Use `plugin-sdk/memory-host-events` |
651
+ | `plugin-sdk/memory-core-host-status` | Memory host status helpers | Memory host status helpers |
652
+ | `plugin-sdk/memory-core-host-runtime-cli` | Memory host CLI runtime | Memory host CLI runtime helpers |
653
+ | `plugin-sdk/memory-core-host-runtime-core` | Memory host core runtime | Memory host core runtime helpers |
654
+ | `plugin-sdk/memory-core-host-runtime-files` | Memory host file/runtime helpers | Memory host file/runtime helpers |
655
+ | `plugin-sdk/memory-host-core` | Memory host core runtime alias | Vendor-neutral alias for memory host core runtime helpers |
656
+ | `plugin-sdk/memory-host-events` | Memory host event journal alias | Vendor-neutral alias for memory host event journal helpers |
657
+ | `plugin-sdk/memory-host-files` | Deprecated memory file/runtime alias | Use `plugin-sdk/memory-core-host-runtime-files` |
658
+ | `plugin-sdk/memory-host-markdown` | Managed markdown helpers | Shared managed-markdown helpers for memory-adjacent plugins |
659
+ | `plugin-sdk/memory-host-search` | Active memory search facade | Lazy active-memory search-manager runtime facade |
660
+ | `plugin-sdk/memory-host-status` | Deprecated memory host status alias | Use `plugin-sdk/memory-core-host-status` |
661
+ | `plugin-sdk/testing` | Test utilities | Repo-local deprecated compatibility barrel; use focused repo-local test subpaths such as `plugin-sdk/plugin-test-runtime`, `plugin-sdk/channel-test-helpers`, `plugin-sdk/channel-target-testing`, `plugin-sdk/test-env`, and `plugin-sdk/test-fixtures` |
662
+ </Accordion>
663
+
664
+ This table is intentionally the common migration subset, not the full SDK
665
+ surface. The compiler entrypoint inventory lives in
666
+ `scripts/lib/plugin-sdk-entrypoints.json`; package exports are generated from
667
+ the public subset.
668
+
669
+ Reserved bundled-plugin helper seams have been retired from the public SDK
670
+ export map except for explicitly documented compatibility facades such as the
671
+ deprecated `plugin-sdk/discord` shim retained for the published
672
+ `@nodmix/discord@2026.3.13` package. Owner-specific helpers live inside the
673
+ owning plugin package; shared host behavior should move through generic SDK
674
+ contracts such as `plugin-sdk/gateway-runtime`, `plugin-sdk/security-runtime`,
675
+ and `plugin-sdk/plugin-config-runtime`.
676
+
677
+ Use the narrowest import that matches the job. If you cannot find an export,
678
+ check the source at `src/plugin-sdk/` or ask maintainers which generic contract
679
+ should own it.
680
+
681
+ ## Active deprecations
682
+
683
+ Narrower deprecations that apply across the plugin SDK, provider contract,
684
+ runtime surface, and manifest. Each one still works today but will be removed
685
+ in a future major release. The entry below every item maps the old API to its
686
+ canonical replacement.
687
+
688
+ <AccordionGroup>
689
+ <Accordion title="command-auth help builders → command-status">
690
+ **Old (`nodmix/plugin-sdk/command-auth`)**: `buildCommandsMessage`,
691
+ `buildCommandsMessagePaginated`, `buildHelpMessage`.
692
+
693
+ **New (`nodmix/plugin-sdk/command-status`)**: same signatures, same
694
+ exports - just imported from the narrower subpath. `command-auth`
695
+ re-exports them as compat stubs.
696
+
697
+ ```typescript
698
+ // Before
699
+ import { buildHelpMessage } from "nodmix/plugin-sdk/command-auth";
700
+
701
+ // After
702
+ import { buildHelpMessage } from "nodmix/plugin-sdk/command-status";
703
+ ```
704
+
705
+ </Accordion>
706
+
707
+ <Accordion title="Mention gating helpers → resolveInboundMentionDecision">
708
+ **Old**: `resolveInboundMentionRequirement({ facts, policy })` and
709
+ `shouldDropInboundForMention(...)` from
710
+ `nodmix/plugin-sdk/channel-inbound` or
711
+ `nodmix/plugin-sdk/channel-mention-gating`.
712
+
713
+ **New**: `resolveInboundMentionDecision({ facts, policy })` - returns a
714
+ single decision object instead of two split calls.
715
+
716
+ Downstream channel plugins (Slack, Discord, Matrix, MS Teams) have already
717
+ switched.
718
+
719
+ </Accordion>
720
+
721
+ <Accordion title="Channel runtime shim and channel actions helpers">
722
+ `nodmix/plugin-sdk/channel-runtime` is a compatibility shim for older
723
+ channel plugins. Do not import it from new code; use
724
+ `nodmix/plugin-sdk/channel-runtime-context` for registering runtime
725
+ objects.
726
+
727
+ `channelActions*` helpers in `nodmix/plugin-sdk/channel-actions` are
728
+ deprecated alongside raw "actions" channel exports. Expose capabilities
729
+ through the semantic `presentation` surface instead - channel plugins
730
+ declare what they render (cards, buttons, selects) rather than which raw
731
+ action names they accept.
732
+
733
+ </Accordion>
734
+
735
+ <Accordion title="Web search provider tool() helper → createTool() on the plugin">
736
+ **Old**: `tool()` factory from `nodmix/plugin-sdk/provider-web-search`.
737
+
738
+ **New**: implement `createTool(...)` directly on the provider plugin.
739
+ Nodmix no longer needs the SDK helper to register the tool wrapper.
740
+
741
+ </Accordion>
742
+
743
+ <Accordion title="Plaintext channel envelopes → BodyForAgent">
744
+ **Old**: `formatInboundEnvelope(...)` (and
745
+ `ChannelMessageForAgent.channelEnvelope`) to build a flat plaintext prompt
746
+ envelope from inbound channel messages.
747
+
748
+ **New**: `BodyForAgent` plus structured user-context blocks. Channel
749
+ plugins attach routing metadata (thread, topic, reply-to, reactions) as
750
+ typed fields instead of concatenating them into a prompt string. The
751
+ `formatAgentEnvelope(...)` helper is still supported for synthesized
752
+ assistant-facing envelopes, but inbound plaintext envelopes are on the
753
+ way out.
754
+
755
+ Affected areas: `inbound_claim`, `message_received`, and any custom
756
+ channel plugin that post-processed `channelEnvelope` text.
757
+
758
+ </Accordion>
759
+
760
+ <Accordion title="deactivate hook → gateway_stop">
761
+ **Old**: `api.on("deactivate", handler)`.
762
+
763
+ **New**: `api.on("gateway_stop", handler)`. The event and context are the
764
+ same shutdown cleanup contract; only the hook name changes.
765
+
766
+ ```typescript
767
+ // Before
768
+ api.on("deactivate", async (event, ctx) => {
769
+ await stopPluginService(ctx);
770
+ });
771
+
772
+ // After
773
+ api.on("gateway_stop", async (event, ctx) => {
774
+ await stopPluginService(ctx);
775
+ });
776
+ ```
777
+
778
+ `deactivate` remains wired as a deprecated compatibility alias until after
779
+ 2026-08-16.
780
+
781
+ </Accordion>
782
+
783
+ <Accordion title="Provider discovery types → provider catalog types">
784
+ Four discovery type aliases are now thin wrappers over the
785
+ catalog-era types:
786
+
787
+ | Old alias | New type |
788
+ | ------------------------- | ------------------------- |
789
+ | `ProviderDiscoveryOrder` | `ProviderCatalogOrder` |
790
+ | `ProviderDiscoveryContext`| `ProviderCatalogContext` |
791
+ | `ProviderDiscoveryResult` | `ProviderCatalogResult` |
792
+ | `ProviderPluginDiscovery` | `ProviderPluginCatalog` |
793
+
794
+ Plus the legacy `ProviderCapabilities` static bag - provider plugins
795
+ should use explicit provider hooks such as `buildReplayPolicy`,
796
+ `normalizeToolSchemas`, and `wrapStreamFn` rather than a static object.
797
+
798
+ </Accordion>
799
+
800
+ <Accordion title="Thinking policy hooks → resolveThinkingProfile">
801
+ **Old** (three separate hooks on `ProviderThinkingPolicy`):
802
+ `isBinaryThinking(ctx)`, `supportsXHighThinking(ctx)`, and
803
+ `resolveDefaultThinkingLevel(ctx)`.
804
+
805
+ **New**: a single `resolveThinkingProfile(ctx)` that returns a
806
+ `ProviderThinkingProfile` with the canonical `id`, optional `label`, and
807
+ ranked level list. Nodmix downgrades stale stored values by profile
808
+ rank automatically.
809
+
810
+ Implement one hook instead of three. The legacy hooks keep working during
811
+ the deprecation window but are not composed with the profile result.
812
+
813
+ </Accordion>
814
+
815
+ <Accordion title="External OAuth provider fallback → contracts.externalAuthProviders">
816
+ **Old**: implementing `resolveExternalOAuthProfiles(...)` without
817
+ declaring the provider in the plugin manifest.
818
+
819
+ **New**: declare `contracts.externalAuthProviders` in the plugin manifest
820
+ **and** implement `resolveExternalAuthProfiles(...)`. The old "auth
821
+ fallback" path emits a warning at runtime and will be removed.
822
+
823
+ ```json
824
+ {
825
+ "contracts": {
826
+ "externalAuthProviders": ["anthropic", "openai"]
827
+ }
828
+ }
829
+ ```
830
+
831
+ </Accordion>
832
+
833
+ <Accordion title="Provider env-var lookup → setup.providers[].envVars">
834
+ **Old** manifest field: `providerAuthEnvVars: { anthropic: ["ANTHROPIC_API_KEY"] }`.
835
+
836
+ **New**: mirror the same env-var lookup into `setup.providers[].envVars`
837
+ on the manifest. This consolidates setup/status env metadata in one
838
+ place and avoids booting the plugin runtime just to answer env-var
839
+ lookups.
840
+
841
+ `providerAuthEnvVars` remains supported through a compatibility adapter
842
+ until the deprecation window closes.
843
+
844
+ </Accordion>
845
+
846
+ <Accordion title="Memory plugin registration → registerMemoryCapability">
847
+ **Old**: three separate calls -
848
+ `api.registerMemoryPromptSection(...)`,
849
+ `api.registerMemoryFlushPlan(...)`,
850
+ `api.registerMemoryRuntime(...)`.
851
+
852
+ **New**: one call on the memory-state API -
853
+ `registerMemoryCapability(pluginId, { promptBuilder, flushPlanResolver, runtime })`.
854
+
855
+ Same slots, single registration call. Additive memory helpers
856
+ (`registerMemoryPromptSupplement`, `registerMemoryCorpusSupplement`,
857
+ `registerMemoryEmbeddingProvider`) are not affected.
858
+
859
+ </Accordion>
860
+
861
+ <Accordion title="Subagent session messages types renamed">
862
+ Two legacy type aliases still exported from `src/plugins/runtime/types.ts`:
863
+
864
+ | Old | New |
865
+ | ----------------------------- | ------------------------------- |
866
+ | `SubagentReadSessionParams` | `SubagentGetSessionMessagesParams` |
867
+ | `SubagentReadSessionResult` | `SubagentGetSessionMessagesResult` |
868
+
869
+ The runtime method `readSession` is deprecated in favor of
870
+ `getSessionMessages`. Same signature; the old method calls through to the
871
+ new one.
872
+
873
+ </Accordion>
874
+
875
+ <Accordion title="runtime.tasks.flow → runtime.tasks.managedFlows">
876
+ **Old**: `runtime.tasks.flow` (singular) returned a live task-flow accessor.
877
+
878
+ **New**: `runtime.tasks.managedFlows` keeps the managed TaskFlow mutation
879
+ runtime for plugins that create, update, cancel, or run child tasks from a
880
+ flow. Use `runtime.tasks.flows` when the plugin only needs DTO-based reads.
881
+
882
+ ```typescript
883
+ // Before
884
+ const flow = api.runtime.tasks.flow.fromToolContext(ctx);
885
+ // After
886
+ const flow = api.runtime.tasks.managedFlows.fromToolContext(ctx);
887
+ ```
888
+
889
+ </Accordion>
890
+
891
+ <Accordion title="Embedded extension factories → agent tool-result middleware">
892
+ Covered in "How to migrate → Migrate Pi tool-result extensions to
893
+ middleware" above. Included here for completeness: the removed Pi-only
894
+ `api.registerEmbeddedExtensionFactory(...)` path is replaced by
895
+ `api.registerAgentToolResultMiddleware(...)` with an explicit runtime
896
+ list in `contracts.agentToolResultMiddleware`.
897
+ </Accordion>
898
+
899
+ <Accordion title="NodmixSchemaType alias → NodmixConfig">
900
+ `NodmixSchemaType` re-exported from `nodmix/plugin-sdk` is now a
901
+ one-line alias for `NodmixConfig`. Prefer the canonical name.
902
+
903
+ ```typescript
904
+ // Before
905
+ import type { NodmixSchemaType } from "nodmix/plugin-sdk";
906
+ // After
907
+ import type { NodmixConfig } from "nodmix/plugin-sdk/config-schema";
908
+ ```
909
+
910
+ </Accordion>
911
+ </AccordionGroup>
912
+
913
+ <Note>
914
+ Extension-level deprecations (inside bundled channel/provider plugins under
915
+ `extensions/`) are tracked inside their own `api.ts` and `runtime-api.ts`
916
+ barrels. They do not affect third-party plugin contracts and are not listed
917
+ here. If you consume a bundled plugin's local barrel directly, read the
918
+ deprecation comments in that barrel before upgrading.
919
+ </Note>
920
+
921
+ ## Removal timeline
922
+
923
+ | When | What happens |
924
+ | ---------------------- | ----------------------------------------------------------------------- |
925
+ | **Now** | Deprecated surfaces emit runtime warnings |
926
+ | **Next major release** | Deprecated surfaces will be removed; plugins still using them will fail |
927
+
928
+ All core plugins have already been migrated. External plugins should migrate
929
+ before the next major release.
930
+
931
+ ## Suppressing the warnings temporarily
932
+
933
+ Set these environment variables while you work on migrating:
934
+
935
+ ```bash
936
+ NODMIX_SUPPRESS_PLUGIN_SDK_COMPAT_WARNING=1 nodmix gateway run
937
+ NODMIX_SUPPRESS_EXTENSION_API_WARNING=1 nodmix gateway run
938
+ ```
939
+
940
+ This is a temporary escape hatch, not a permanent solution.
941
+
942
+ ## Related
943
+
944
+ - [Getting Started](/plugins/building-plugins) - build your first plugin
945
+ - [SDK Overview](/plugins/sdk-overview) - full subpath import reference
946
+ - [Channel Plugins](/plugins/sdk-channel-plugins) - building channel plugins
947
+ - [Provider Plugins](/plugins/sdk-provider-plugins) - building provider plugins
948
+ - [Plugin Internals](/plugins/architecture) - architecture deep dive
949
+ - [Plugin Manifest](/plugins/manifest) - manifest schema reference