vilvona 1.0.0

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 (812) hide show
  1. package/CHANGELOG.md +12331 -0
  2. package/LICENSE +24 -0
  3. package/README.md +314 -0
  4. package/THIRD_PARTY_NOTICES.md +37 -0
  5. package/docs/.i18n/README.md +81 -0
  6. package/docs/.i18n/ar-navigation.json +18 -0
  7. package/docs/.i18n/de-navigation.json +18 -0
  8. package/docs/.i18n/es-navigation.json +18 -0
  9. package/docs/.i18n/fr-navigation.json +18 -0
  10. package/docs/.i18n/glossary.ar.json +82 -0
  11. package/docs/.i18n/glossary.de.json +82 -0
  12. package/docs/.i18n/glossary.es.json +82 -0
  13. package/docs/.i18n/glossary.fa.json +82 -0
  14. package/docs/.i18n/glossary.fr.json +82 -0
  15. package/docs/.i18n/glossary.id.json +82 -0
  16. package/docs/.i18n/glossary.it.json +82 -0
  17. package/docs/.i18n/glossary.ja-JP.json +102 -0
  18. package/docs/.i18n/glossary.ko.json +82 -0
  19. package/docs/.i18n/glossary.nl.json +82 -0
  20. package/docs/.i18n/glossary.pl.json +82 -0
  21. package/docs/.i18n/glossary.pt-BR.json +82 -0
  22. package/docs/.i18n/glossary.th.json +82 -0
  23. package/docs/.i18n/glossary.tr.json +82 -0
  24. package/docs/.i18n/glossary.uk.json +82 -0
  25. package/docs/.i18n/glossary.vi.json +82 -0
  26. package/docs/.i18n/glossary.zh-CN.json +1182 -0
  27. package/docs/.i18n/glossary.zh-TW.json +162 -0
  28. package/docs/.i18n/id-navigation.json +18 -0
  29. package/docs/.i18n/it-navigation.json +18 -0
  30. package/docs/.i18n/ja-navigation.json +18 -0
  31. package/docs/.i18n/ko-navigation.json +18 -0
  32. package/docs/.i18n/pl-navigation.json +18 -0
  33. package/docs/.i18n/pt-BR-navigation.json +18 -0
  34. package/docs/.i18n/tr-navigation.json +18 -0
  35. package/docs/.i18n/translation-workflow.md +111 -0
  36. package/docs/.i18n/zh-Hans-navigation.json +552 -0
  37. package/docs/AGENTS.md +36 -0
  38. package/docs/agent-runtime-architecture.md +48 -0
  39. package/docs/announcements/bluebubbles-imessage.md +79 -0
  40. package/docs/auth-credential-semantics.md +124 -0
  41. package/docs/automation/auth-monitoring.md +11 -0
  42. package/docs/automation/clawflow.md +12 -0
  43. package/docs/automation/cron-jobs.md +569 -0
  44. package/docs/automation/cron-vs-heartbeat.md +11 -0
  45. package/docs/automation/gmail-pubsub.md +11 -0
  46. package/docs/automation/hooks.md +387 -0
  47. package/docs/automation/index.md +135 -0
  48. package/docs/automation/poll.md +12 -0
  49. package/docs/automation/standing-orders.md +250 -0
  50. package/docs/automation/taskflow.md +155 -0
  51. package/docs/automation/tasks.md +374 -0
  52. package/docs/automation/troubleshooting.md +12 -0
  53. package/docs/automation/webhook.md +12 -0
  54. package/docs/brave-search.md +11 -0
  55. package/docs/channels/access-groups.md +201 -0
  56. package/docs/channels/ambient-room-events.md +214 -0
  57. package/docs/channels/bot-loop-protection.md +131 -0
  58. package/docs/channels/broadcast-groups.md +472 -0
  59. package/docs/channels/channel-routing.md +162 -0
  60. package/docs/channels/clickclack.md +146 -0
  61. package/docs/channels/discord.md +1758 -0
  62. package/docs/channels/feishu.md +654 -0
  63. package/docs/channels/googlechat.md +286 -0
  64. package/docs/channels/group-messages.md +95 -0
  65. package/docs/channels/groups.md +610 -0
  66. package/docs/channels/imessage-from-bluebubbles.md +259 -0
  67. package/docs/channels/imessage.md +864 -0
  68. package/docs/channels/index.md +65 -0
  69. package/docs/channels/irc.md +253 -0
  70. package/docs/channels/line.md +243 -0
  71. package/docs/channels/location.md +71 -0
  72. package/docs/channels/matrix-migration.md +375 -0
  73. package/docs/channels/matrix-presentation.md +77 -0
  74. package/docs/channels/matrix-push-rules.md +150 -0
  75. package/docs/channels/matrix.md +935 -0
  76. package/docs/channels/mattermost.md +542 -0
  77. package/docs/channels/msteams.md +1097 -0
  78. package/docs/channels/nextcloud-talk.md +176 -0
  79. package/docs/channels/nostr.md +253 -0
  80. package/docs/channels/pairing.md +214 -0
  81. package/docs/channels/qqbot.md +317 -0
  82. package/docs/channels/signal.md +417 -0
  83. package/docs/channels/slack.md +1623 -0
  84. package/docs/channels/sms.md +380 -0
  85. package/docs/channels/synology-chat.md +187 -0
  86. package/docs/channels/telegram.md +1121 -0
  87. package/docs/channels/tlon.md +296 -0
  88. package/docs/channels/troubleshooting.md +162 -0
  89. package/docs/channels/twitch.md +431 -0
  90. package/docs/channels/wechat.md +171 -0
  91. package/docs/channels/whatsapp.md +796 -0
  92. package/docs/channels/yuanbao.md +416 -0
  93. package/docs/channels/zalo.md +253 -0
  94. package/docs/channels/zalouser.md +217 -0
  95. package/docs/ci.md +665 -0
  96. package/docs/clawhub/cli.md +82 -0
  97. package/docs/clawhub/publishing.md +96 -0
  98. package/docs/cli/acp.md +370 -0
  99. package/docs/cli/agent.md +109 -0
  100. package/docs/cli/agents.md +253 -0
  101. package/docs/cli/approvals.md +193 -0
  102. package/docs/cli/backup.md +98 -0
  103. package/docs/cli/browser.md +322 -0
  104. package/docs/cli/channels.md +154 -0
  105. package/docs/cli/clawbot.md +25 -0
  106. package/docs/cli/commitments.md +90 -0
  107. package/docs/cli/completion.md +39 -0
  108. package/docs/cli/config.md +504 -0
  109. package/docs/cli/configure.md +77 -0
  110. package/docs/cli/crestodian.md +337 -0
  111. package/docs/cli/cron.md +344 -0
  112. package/docs/cli/daemon.md +67 -0
  113. package/docs/cli/dashboard.md +33 -0
  114. package/docs/cli/devices.md +240 -0
  115. package/docs/cli/directory.md +68 -0
  116. package/docs/cli/dns.md +53 -0
  117. package/docs/cli/docs.md +63 -0
  118. package/docs/cli/doctor.md +254 -0
  119. package/docs/cli/flows.md +52 -0
  120. package/docs/cli/gateway.md +572 -0
  121. package/docs/cli/health.md +43 -0
  122. package/docs/cli/hooks.md +345 -0
  123. package/docs/cli/index.md +406 -0
  124. package/docs/cli/infer.md +364 -0
  125. package/docs/cli/logs.md +68 -0
  126. package/docs/cli/mcp.md +851 -0
  127. package/docs/cli/memory.md +183 -0
  128. package/docs/cli/message.md +317 -0
  129. package/docs/cli/migrate.md +334 -0
  130. package/docs/cli/models.md +239 -0
  131. package/docs/cli/node.md +178 -0
  132. package/docs/cli/nodes.md +76 -0
  133. package/docs/cli/onboard.md +251 -0
  134. package/docs/cli/pairing.md +77 -0
  135. package/docs/cli/path.md +511 -0
  136. package/docs/cli/plugins.md +480 -0
  137. package/docs/cli/policy.md +929 -0
  138. package/docs/cli/proxy.md +89 -0
  139. package/docs/cli/qr.md +56 -0
  140. package/docs/cli/reset.md +39 -0
  141. package/docs/cli/sandbox.md +208 -0
  142. package/docs/cli/secrets.md +202 -0
  143. package/docs/cli/security.md +135 -0
  144. package/docs/cli/sessions.md +178 -0
  145. package/docs/cli/setup.md +60 -0
  146. package/docs/cli/skills.md +156 -0
  147. package/docs/cli/status.md +45 -0
  148. package/docs/cli/system.md +89 -0
  149. package/docs/cli/tasks.md +111 -0
  150. package/docs/cli/transcripts.md +151 -0
  151. package/docs/cli/tui.md +92 -0
  152. package/docs/cli/uninstall.md +45 -0
  153. package/docs/cli/update.md +283 -0
  154. package/docs/cli/voicecall.md +204 -0
  155. package/docs/cli/webhooks.md +117 -0
  156. package/docs/cli/wiki.md +256 -0
  157. package/docs/cli/workboard.md +228 -0
  158. package/docs/concepts/active-memory.md +856 -0
  159. package/docs/concepts/agent-loop.md +185 -0
  160. package/docs/concepts/agent-runtimes.md +276 -0
  161. package/docs/concepts/agent-workspace.md +230 -0
  162. package/docs/concepts/agent.md +142 -0
  163. package/docs/concepts/architecture.md +154 -0
  164. package/docs/concepts/channel-docking.md +145 -0
  165. package/docs/concepts/commitments.md +150 -0
  166. package/docs/concepts/compaction.md +203 -0
  167. package/docs/concepts/context-engine.md +347 -0
  168. package/docs/concepts/context.md +199 -0
  169. package/docs/concepts/delegate-architecture.md +319 -0
  170. package/docs/concepts/dreaming.md +279 -0
  171. package/docs/concepts/experimental-features.md +111 -0
  172. package/docs/concepts/features.md +91 -0
  173. package/docs/concepts/mantis-slack-desktop-runbook.md +231 -0
  174. package/docs/concepts/mantis.md +744 -0
  175. package/docs/concepts/markdown-formatting.md +139 -0
  176. package/docs/concepts/memory-builtin.md +151 -0
  177. package/docs/concepts/memory-honcho.md +144 -0
  178. package/docs/concepts/memory-qmd.md +277 -0
  179. package/docs/concepts/memory-search.md +175 -0
  180. package/docs/concepts/memory.md +299 -0
  181. package/docs/concepts/message-lifecycle-refactor.md +1126 -0
  182. package/docs/concepts/messages.md +216 -0
  183. package/docs/concepts/model-failover.md +405 -0
  184. package/docs/concepts/model-providers.md +719 -0
  185. package/docs/concepts/models.md +371 -0
  186. package/docs/concepts/multi-agent.md +625 -0
  187. package/docs/concepts/oauth.md +218 -0
  188. package/docs/concepts/parallel-specialist-lanes.md +127 -0
  189. package/docs/concepts/personal-agent-benchmark-pack.md +74 -0
  190. package/docs/concepts/presence.md +117 -0
  191. package/docs/concepts/progress-drafts.md +406 -0
  192. package/docs/concepts/qa-e2e-automation.md +979 -0
  193. package/docs/concepts/qa-matrix.md +139 -0
  194. package/docs/concepts/queue-steering.md +90 -0
  195. package/docs/concepts/queue.md +136 -0
  196. package/docs/concepts/retry.md +86 -0
  197. package/docs/concepts/session-pruning.md +104 -0
  198. package/docs/concepts/session-tool.md +201 -0
  199. package/docs/concepts/session.md +164 -0
  200. package/docs/concepts/soul.md +116 -0
  201. package/docs/concepts/streaming.md +258 -0
  202. package/docs/concepts/system-prompt.md +330 -0
  203. package/docs/concepts/timezone.md +47 -0
  204. package/docs/concepts/typebox.md +309 -0
  205. package/docs/concepts/typing-indicators.md +88 -0
  206. package/docs/concepts/usage-tracking.md +72 -0
  207. package/docs/date-time.md +126 -0
  208. package/docs/debug/node-issue.md +90 -0
  209. package/docs/diagnostics/flags.md +182 -0
  210. package/docs/docs.json +1885 -0
  211. package/docs/gateway/authentication.md +286 -0
  212. package/docs/gateway/background-process.md +147 -0
  213. package/docs/gateway/bonjour.md +303 -0
  214. package/docs/gateway/bridge-protocol.md +97 -0
  215. package/docs/gateway/cli-backends.md +463 -0
  216. package/docs/gateway/config-agents.md +1525 -0
  217. package/docs/gateway/config-channels.md +942 -0
  218. package/docs/gateway/config-tools.md +806 -0
  219. package/docs/gateway/configuration-examples.md +706 -0
  220. package/docs/gateway/configuration-reference.md +1449 -0
  221. package/docs/gateway/configuration.md +748 -0
  222. package/docs/gateway/diagnostics.md +213 -0
  223. package/docs/gateway/discovery.md +154 -0
  224. package/docs/gateway/doctor.md +576 -0
  225. package/docs/gateway/external-apps.md +86 -0
  226. package/docs/gateway/gateway-lock.md +37 -0
  227. package/docs/gateway/health.md +73 -0
  228. package/docs/gateway/heartbeat.md +498 -0
  229. package/docs/gateway/index.md +385 -0
  230. package/docs/gateway/local-model-services.md +205 -0
  231. package/docs/gateway/local-models.md +355 -0
  232. package/docs/gateway/logging.md +149 -0
  233. package/docs/gateway/multiple-gateways.md +178 -0
  234. package/docs/gateway/network-model.md +15 -0
  235. package/docs/gateway/openai-http-api.md +379 -0
  236. package/docs/gateway/openresponses-http-api.md +349 -0
  237. package/docs/gateway/openshell.md +316 -0
  238. package/docs/gateway/opentelemetry.md +440 -0
  239. package/docs/gateway/operator-scopes.md +119 -0
  240. package/docs/gateway/pairing.md +207 -0
  241. package/docs/gateway/prometheus.md +249 -0
  242. package/docs/gateway/protocol.md +839 -0
  243. package/docs/gateway/remote-gateway-readme.md +169 -0
  244. package/docs/gateway/remote.md +280 -0
  245. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +148 -0
  246. package/docs/gateway/sandboxing.md +546 -0
  247. package/docs/gateway/secrets-plan-contract.md +159 -0
  248. package/docs/gateway/secrets.md +805 -0
  249. package/docs/gateway/security/audit-checks.md +127 -0
  250. package/docs/gateway/security/exposure-runbook.md +212 -0
  251. package/docs/gateway/security/index.md +1344 -0
  252. package/docs/gateway/security/secure-file-operations.md +76 -0
  253. package/docs/gateway/security/shrinkwrap.md +111 -0
  254. package/docs/gateway/tailscale.md +180 -0
  255. package/docs/gateway/tools-invoke-http-api.md +175 -0
  256. package/docs/gateway/troubleshooting.md +881 -0
  257. package/docs/gateway/trusted-proxy-auth.md +483 -0
  258. package/docs/help/debugging.md +341 -0
  259. package/docs/help/environment.md +240 -0
  260. package/docs/help/faq-first-run.md +872 -0
  261. package/docs/help/faq-models.md +557 -0
  262. package/docs/help/faq.md +2115 -0
  263. package/docs/help/index.md +39 -0
  264. package/docs/help/scripts.md +56 -0
  265. package/docs/help/testing-live.md +592 -0
  266. package/docs/help/testing-updates-plugins.md +299 -0
  267. package/docs/help/testing.md +977 -0
  268. package/docs/help/troubleshooting.md +500 -0
  269. package/docs/index.md +196 -0
  270. package/docs/install/ansible.md +233 -0
  271. package/docs/install/azure.md +315 -0
  272. package/docs/install/bun.md +59 -0
  273. package/docs/install/clawdock.md +112 -0
  274. package/docs/install/development-channels.md +148 -0
  275. package/docs/install/digitalocean.md +174 -0
  276. package/docs/install/docker-vm-runtime.md +154 -0
  277. package/docs/install/docker.md +564 -0
  278. package/docs/install/exe-dev.md +201 -0
  279. package/docs/install/fly.md +524 -0
  280. package/docs/install/gcp.md +418 -0
  281. package/docs/install/hetzner.md +285 -0
  282. package/docs/install/hostinger.md +98 -0
  283. package/docs/install/index.md +236 -0
  284. package/docs/install/installer.md +447 -0
  285. package/docs/install/kubernetes.md +196 -0
  286. package/docs/install/macos-vm.md +281 -0
  287. package/docs/install/migrating-claude.md +165 -0
  288. package/docs/install/migrating-hermes.md +178 -0
  289. package/docs/install/migrating.md +137 -0
  290. package/docs/install/nix.md +112 -0
  291. package/docs/install/node.md +142 -0
  292. package/docs/install/northflank.mdx +44 -0
  293. package/docs/install/oracle.md +218 -0
  294. package/docs/install/podman.md +216 -0
  295. package/docs/install/railway.mdx +92 -0
  296. package/docs/install/raspberry-pi.md +234 -0
  297. package/docs/install/render.mdx +167 -0
  298. package/docs/install/uninstall.md +140 -0
  299. package/docs/install/updating.md +284 -0
  300. package/docs/install/upstash.md +96 -0
  301. package/docs/logging.md +322 -0
  302. package/docs/maturity-scores.yaml +5361 -0
  303. package/docs/nav-tabs-underline.js +104 -0
  304. package/docs/network.md +72 -0
  305. package/docs/nodes/audio.md +216 -0
  306. package/docs/nodes/camera.md +166 -0
  307. package/docs/nodes/images.md +77 -0
  308. package/docs/nodes/index.md +444 -0
  309. package/docs/nodes/location-command.md +102 -0
  310. package/docs/nodes/media-understanding.md +495 -0
  311. package/docs/nodes/talk.md +160 -0
  312. package/docs/nodes/troubleshooting.md +123 -0
  313. package/docs/nodes/voicewake.md +93 -0
  314. package/docs/openclaw-agent-runtime.md +82 -0
  315. package/docs/perplexity.md +11 -0
  316. package/docs/plan/codex-context-engine-harness.md +624 -0
  317. package/docs/plan/ui-channels.md +284 -0
  318. package/docs/platforms/android.md +286 -0
  319. package/docs/platforms/digitalocean.md +12 -0
  320. package/docs/platforms/easyrunner.md +109 -0
  321. package/docs/platforms/index.md +65 -0
  322. package/docs/platforms/ios.md +287 -0
  323. package/docs/platforms/linux.md +141 -0
  324. package/docs/platforms/mac/bundled-gateway.md +79 -0
  325. package/docs/platforms/mac/canvas.md +128 -0
  326. package/docs/platforms/mac/child-process.md +72 -0
  327. package/docs/platforms/mac/dev-setup.md +112 -0
  328. package/docs/platforms/mac/health.md +39 -0
  329. package/docs/platforms/mac/icon.md +36 -0
  330. package/docs/platforms/mac/logging.md +62 -0
  331. package/docs/platforms/mac/menu-bar.md +93 -0
  332. package/docs/platforms/mac/peekaboo.md +96 -0
  333. package/docs/platforms/mac/permissions.md +73 -0
  334. package/docs/platforms/mac/remote.md +123 -0
  335. package/docs/platforms/mac/signing.md +52 -0
  336. package/docs/platforms/mac/skills.md +45 -0
  337. package/docs/platforms/mac/voice-overlay.md +66 -0
  338. package/docs/platforms/mac/voicewake.md +79 -0
  339. package/docs/platforms/mac/webchat.md +54 -0
  340. package/docs/platforms/mac/xpc.md +66 -0
  341. package/docs/platforms/macos.md +228 -0
  342. package/docs/platforms/oracle.md +12 -0
  343. package/docs/platforms/raspberry-pi.md +13 -0
  344. package/docs/platforms/windows.md +304 -0
  345. package/docs/plugins/adding-capabilities.md +146 -0
  346. package/docs/plugins/admin-http-rpc.md +216 -0
  347. package/docs/plugins/agent-tools.md +13 -0
  348. package/docs/plugins/architecture-internals.md +1203 -0
  349. package/docs/plugins/architecture.md +483 -0
  350. package/docs/plugins/building-extensions.md +13 -0
  351. package/docs/plugins/building-plugins.md +343 -0
  352. package/docs/plugins/bundles.md +310 -0
  353. package/docs/plugins/cli-backend-plugins.md +328 -0
  354. package/docs/plugins/codex-computer-use.md +297 -0
  355. package/docs/plugins/codex-harness-reference.md +480 -0
  356. package/docs/plugins/codex-harness-runtime.md +268 -0
  357. package/docs/plugins/codex-harness.md +800 -0
  358. package/docs/plugins/codex-native-plugins.md +280 -0
  359. package/docs/plugins/community.md +77 -0
  360. package/docs/plugins/compatibility.md +198 -0
  361. package/docs/plugins/copilot.md +355 -0
  362. package/docs/plugins/dependency-resolution.md +176 -0
  363. package/docs/plugins/google-meet.md +1737 -0
  364. package/docs/plugins/hooks.md +525 -0
  365. package/docs/plugins/install-overrides.md +80 -0
  366. package/docs/plugins/llama-cpp.md +58 -0
  367. package/docs/plugins/manage-plugins.md +214 -0
  368. package/docs/plugins/manifest.md +1468 -0
  369. package/docs/plugins/memory-lancedb.md +385 -0
  370. package/docs/plugins/memory-wiki.md +529 -0
  371. package/docs/plugins/message-presentation.md +487 -0
  372. package/docs/plugins/oc-path.md +166 -0
  373. package/docs/plugins/plugin-inventory.md +318 -0
  374. package/docs/plugins/plugin-permission-requests.md +193 -0
  375. package/docs/plugins/reference/acpx.md +23 -0
  376. package/docs/plugins/reference/admin-http-rpc.md +23 -0
  377. package/docs/plugins/reference/alibaba.md +23 -0
  378. package/docs/plugins/reference/amazon-bedrock-mantle.md +23 -0
  379. package/docs/plugins/reference/amazon-bedrock.md +23 -0
  380. package/docs/plugins/reference/anthropic-vertex.md +29 -0
  381. package/docs/plugins/reference/anthropic.md +23 -0
  382. package/docs/plugins/reference/arcee.md +23 -0
  383. package/docs/plugins/reference/azure-speech.md +23 -0
  384. package/docs/plugins/reference/bonjour.md +19 -0
  385. package/docs/plugins/reference/brave.md +23 -0
  386. package/docs/plugins/reference/browser.md +23 -0
  387. package/docs/plugins/reference/byteplus.md +19 -0
  388. package/docs/plugins/reference/canvas.md +19 -0
  389. package/docs/plugins/reference/cerebras.md +23 -0
  390. package/docs/plugins/reference/chutes.md +23 -0
  391. package/docs/plugins/reference/clickclack.md +23 -0
  392. package/docs/plugins/reference/cloudflare-ai-gateway.md +23 -0
  393. package/docs/plugins/reference/codex-supervisor.md +27 -0
  394. package/docs/plugins/reference/codex.md +23 -0
  395. package/docs/plugins/reference/comfy.md +23 -0
  396. package/docs/plugins/reference/copilot-proxy.md +19 -0
  397. package/docs/plugins/reference/copilot.md +23 -0
  398. package/docs/plugins/reference/deepgram.md +23 -0
  399. package/docs/plugins/reference/deepinfra.md +23 -0
  400. package/docs/plugins/reference/deepseek.md +23 -0
  401. package/docs/plugins/reference/diagnostics-otel.md +19 -0
  402. package/docs/plugins/reference/diagnostics-prometheus.md +19 -0
  403. package/docs/plugins/reference/diffs-language-pack.md +31 -0
  404. package/docs/plugins/reference/diffs.md +19 -0
  405. package/docs/plugins/reference/discord.md +23 -0
  406. package/docs/plugins/reference/document-extract.md +23 -0
  407. package/docs/plugins/reference/duckduckgo.md +23 -0
  408. package/docs/plugins/reference/elevenlabs.md +23 -0
  409. package/docs/plugins/reference/exa.md +23 -0
  410. package/docs/plugins/reference/fal.md +23 -0
  411. package/docs/plugins/reference/feishu.md +23 -0
  412. package/docs/plugins/reference/file-transfer.md +19 -0
  413. package/docs/plugins/reference/firecrawl.md +23 -0
  414. package/docs/plugins/reference/fireworks.md +23 -0
  415. package/docs/plugins/reference/github-copilot.md +23 -0
  416. package/docs/plugins/reference/gmi.md +23 -0
  417. package/docs/plugins/reference/google-meet.md +23 -0
  418. package/docs/plugins/reference/google.md +23 -0
  419. package/docs/plugins/reference/googlechat.md +23 -0
  420. package/docs/plugins/reference/gradium.md +23 -0
  421. package/docs/plugins/reference/groq.md +23 -0
  422. package/docs/plugins/reference/huggingface.md +23 -0
  423. package/docs/plugins/reference/imessage.md +23 -0
  424. package/docs/plugins/reference/inworld.md +23 -0
  425. package/docs/plugins/reference/irc.md +23 -0
  426. package/docs/plugins/reference/kilocode.md +23 -0
  427. package/docs/plugins/reference/kimi.md +23 -0
  428. package/docs/plugins/reference/line.md +23 -0
  429. package/docs/plugins/reference/litellm.md +23 -0
  430. package/docs/plugins/reference/llama-cpp.md +23 -0
  431. package/docs/plugins/reference/llm-task.md +19 -0
  432. package/docs/plugins/reference/lmstudio.md +23 -0
  433. package/docs/plugins/reference/lobster.md +19 -0
  434. package/docs/plugins/reference/matrix.md +23 -0
  435. package/docs/plugins/reference/mattermost.md +23 -0
  436. package/docs/plugins/reference/memory-core.md +19 -0
  437. package/docs/plugins/reference/memory-lancedb.md +23 -0
  438. package/docs/plugins/reference/memory-wiki.md +23 -0
  439. package/docs/plugins/reference/microsoft-foundry.md +113 -0
  440. package/docs/plugins/reference/microsoft.md +19 -0
  441. package/docs/plugins/reference/migrate-claude.md +19 -0
  442. package/docs/plugins/reference/migrate-hermes.md +19 -0
  443. package/docs/plugins/reference/minimax.md +23 -0
  444. package/docs/plugins/reference/mistral.md +23 -0
  445. package/docs/plugins/reference/moonshot.md +23 -0
  446. package/docs/plugins/reference/msteams.md +23 -0
  447. package/docs/plugins/reference/nextcloud-talk.md +23 -0
  448. package/docs/plugins/reference/nostr.md +23 -0
  449. package/docs/plugins/reference/novita.md +23 -0
  450. package/docs/plugins/reference/nvidia.md +23 -0
  451. package/docs/plugins/reference/oc-path.md +23 -0
  452. package/docs/plugins/reference/ollama.md +24 -0
  453. package/docs/plugins/reference/open-prose.md +19 -0
  454. package/docs/plugins/reference/openai.md +23 -0
  455. package/docs/plugins/reference/opencode-go.md +23 -0
  456. package/docs/plugins/reference/opencode.md +23 -0
  457. package/docs/plugins/reference/openrouter.md +23 -0
  458. package/docs/plugins/reference/openshell.md +19 -0
  459. package/docs/plugins/reference/perplexity.md +23 -0
  460. package/docs/plugins/reference/pixverse.md +23 -0
  461. package/docs/plugins/reference/policy.md +79 -0
  462. package/docs/plugins/reference/qa-channel.md +23 -0
  463. package/docs/plugins/reference/qa-lab.md +19 -0
  464. package/docs/plugins/reference/qa-matrix.md +19 -0
  465. package/docs/plugins/reference/qianfan.md +23 -0
  466. package/docs/plugins/reference/qqbot.md +23 -0
  467. package/docs/plugins/reference/qwen.md +24 -0
  468. package/docs/plugins/reference/runway.md +23 -0
  469. package/docs/plugins/reference/searxng.md +19 -0
  470. package/docs/plugins/reference/senseaudio.md +23 -0
  471. package/docs/plugins/reference/sglang.md +23 -0
  472. package/docs/plugins/reference/signal.md +23 -0
  473. package/docs/plugins/reference/slack.md +23 -0
  474. package/docs/plugins/reference/sms.md +23 -0
  475. package/docs/plugins/reference/stepfun.md +23 -0
  476. package/docs/plugins/reference/synology-chat.md +23 -0
  477. package/docs/plugins/reference/synthetic.md +23 -0
  478. package/docs/plugins/reference/tavily.md +23 -0
  479. package/docs/plugins/reference/telegram.md +23 -0
  480. package/docs/plugins/reference/tencent.md +23 -0
  481. package/docs/plugins/reference/tlon.md +23 -0
  482. package/docs/plugins/reference/together.md +23 -0
  483. package/docs/plugins/reference/tokenjuice.md +23 -0
  484. package/docs/plugins/reference/tts-local-cli.md +19 -0
  485. package/docs/plugins/reference/twitch.md +23 -0
  486. package/docs/plugins/reference/venice.md +23 -0
  487. package/docs/plugins/reference/vercel-ai-gateway.md +23 -0
  488. package/docs/plugins/reference/vllm.md +23 -0
  489. package/docs/plugins/reference/voice-call.md +23 -0
  490. package/docs/plugins/reference/volcengine.md +23 -0
  491. package/docs/plugins/reference/voyage.md +19 -0
  492. package/docs/plugins/reference/vydra.md +23 -0
  493. package/docs/plugins/reference/web-readability.md +19 -0
  494. package/docs/plugins/reference/webhooks.md +23 -0
  495. package/docs/plugins/reference/whatsapp.md +23 -0
  496. package/docs/plugins/reference/workboard.md +23 -0
  497. package/docs/plugins/reference/xai.md +23 -0
  498. package/docs/plugins/reference/xiaomi.md +23 -0
  499. package/docs/plugins/reference/zai.md +23 -0
  500. package/docs/plugins/reference/zalo.md +23 -0
  501. package/docs/plugins/reference/zalouser.md +24 -0
  502. package/docs/plugins/reference.md +19 -0
  503. package/docs/plugins/sdk-agent-harness.md +339 -0
  504. package/docs/plugins/sdk-channel-inbound.md +70 -0
  505. package/docs/plugins/sdk-channel-ingress.md +137 -0
  506. package/docs/plugins/sdk-channel-message.md +18 -0
  507. package/docs/plugins/sdk-channel-outbound.md +113 -0
  508. package/docs/plugins/sdk-channel-plugins.md +770 -0
  509. package/docs/plugins/sdk-channel-turn.md +9 -0
  510. package/docs/plugins/sdk-entrypoints.md +344 -0
  511. package/docs/plugins/sdk-migration.md +1011 -0
  512. package/docs/plugins/sdk-overview.md +525 -0
  513. package/docs/plugins/sdk-provider-plugins.md +1019 -0
  514. package/docs/plugins/sdk-runtime.md +683 -0
  515. package/docs/plugins/sdk-setup.md +550 -0
  516. package/docs/plugins/sdk-subpaths.md +401 -0
  517. package/docs/plugins/sdk-testing.md +403 -0
  518. package/docs/plugins/tool-plugins.md +411 -0
  519. package/docs/plugins/voice-call.md +942 -0
  520. package/docs/plugins/webhooks.md +192 -0
  521. package/docs/plugins/workboard.md +402 -0
  522. package/docs/plugins/zalouser.md +86 -0
  523. package/docs/prose.md +191 -0
  524. package/docs/providers/alibaba.md +158 -0
  525. package/docs/providers/anthropic.md +386 -0
  526. package/docs/providers/arcee.md +144 -0
  527. package/docs/providers/azure-speech.md +119 -0
  528. package/docs/providers/bedrock-mantle.md +224 -0
  529. package/docs/providers/bedrock.md +433 -0
  530. package/docs/providers/cerebras.md +130 -0
  531. package/docs/providers/chutes.md +153 -0
  532. package/docs/providers/claude-max-api-proxy.md +191 -0
  533. package/docs/providers/cloudflare-ai-gateway.md +119 -0
  534. package/docs/providers/comfy.md +362 -0
  535. package/docs/providers/deepgram.md +184 -0
  536. package/docs/providers/deepinfra.md +92 -0
  537. package/docs/providers/deepseek.md +146 -0
  538. package/docs/providers/ds4.md +309 -0
  539. package/docs/providers/elevenlabs.md +130 -0
  540. package/docs/providers/fal.md +240 -0
  541. package/docs/providers/fireworks.md +144 -0
  542. package/docs/providers/github-copilot.md +257 -0
  543. package/docs/providers/gmi.md +92 -0
  544. package/docs/providers/google.md +472 -0
  545. package/docs/providers/gradium.md +123 -0
  546. package/docs/providers/groq.md +171 -0
  547. package/docs/providers/huggingface.md +235 -0
  548. package/docs/providers/index.md +105 -0
  549. package/docs/providers/inferrs.md +272 -0
  550. package/docs/providers/inworld.md +120 -0
  551. package/docs/providers/kilocode.md +135 -0
  552. package/docs/providers/litellm.md +234 -0
  553. package/docs/providers/lmstudio.md +224 -0
  554. package/docs/providers/minimax.md +518 -0
  555. package/docs/providers/mistral.md +235 -0
  556. package/docs/providers/models.md +64 -0
  557. package/docs/providers/moonshot.md +413 -0
  558. package/docs/providers/novita.md +92 -0
  559. package/docs/providers/nvidia.md +208 -0
  560. package/docs/providers/ollama-cloud.md +115 -0
  561. package/docs/providers/ollama.md +1225 -0
  562. package/docs/providers/openai.md +1091 -0
  563. package/docs/providers/opencode-go.md +123 -0
  564. package/docs/providers/opencode.md +149 -0
  565. package/docs/providers/openrouter.md +390 -0
  566. package/docs/providers/perplexity-provider.md +123 -0
  567. package/docs/providers/pixverse.md +165 -0
  568. package/docs/providers/qianfan.md +132 -0
  569. package/docs/providers/qwen-oauth.md +115 -0
  570. package/docs/providers/qwen.md +364 -0
  571. package/docs/providers/runway.md +103 -0
  572. package/docs/providers/senseaudio.md +68 -0
  573. package/docs/providers/sglang.md +161 -0
  574. package/docs/providers/stepfun.md +229 -0
  575. package/docs/providers/synthetic.md +154 -0
  576. package/docs/providers/tencent.md +130 -0
  577. package/docs/providers/together.md +140 -0
  578. package/docs/providers/venice.md +312 -0
  579. package/docs/providers/vercel-ai-gateway.md +128 -0
  580. package/docs/providers/vllm.md +407 -0
  581. package/docs/providers/volcengine.md +199 -0
  582. package/docs/providers/vydra.md +180 -0
  583. package/docs/providers/xai.md +571 -0
  584. package/docs/providers/xiaomi.md +286 -0
  585. package/docs/providers/zai.md +224 -0
  586. package/docs/refactor/access.md +9 -0
  587. package/docs/refactor/acp.md +298 -0
  588. package/docs/refactor/canvas.md +131 -0
  589. package/docs/refactor/database-first.md +2263 -0
  590. package/docs/refactor/ingress-core.md +341 -0
  591. package/docs/reference/AGENTS.default.md +131 -0
  592. package/docs/reference/RELEASING.md +844 -0
  593. package/docs/reference/api-usage-costs.md +208 -0
  594. package/docs/reference/application-modernization-plan.md +208 -0
  595. package/docs/reference/code-mode.md +1058 -0
  596. package/docs/reference/credits.md +33 -0
  597. package/docs/reference/device-models.md +50 -0
  598. package/docs/reference/full-release-validation.md +206 -0
  599. package/docs/reference/memory-config.md +630 -0
  600. package/docs/reference/prompt-caching.md +358 -0
  601. package/docs/reference/release-performance-sweep.md +347 -0
  602. package/docs/reference/rich-output-protocol.md +93 -0
  603. package/docs/reference/rpc.md +43 -0
  604. package/docs/reference/secret-placeholder-conventions.md +33 -0
  605. package/docs/reference/secretref-credential-surface.md +163 -0
  606. package/docs/reference/secretref-user-supplied-credentials-matrix.json +691 -0
  607. package/docs/reference/session-management-compaction.md +474 -0
  608. package/docs/reference/templates/AGENTS.dev.md +90 -0
  609. package/docs/reference/templates/AGENTS.md +227 -0
  610. package/docs/reference/templates/BOOT.md +16 -0
  611. package/docs/reference/templates/BOOTSTRAP.md +66 -0
  612. package/docs/reference/templates/HEARTBEAT.md +24 -0
  613. package/docs/reference/templates/IDENTITY.dev.md +52 -0
  614. package/docs/reference/templates/IDENTITY.md +34 -0
  615. package/docs/reference/templates/SOUL.dev.md +82 -0
  616. package/docs/reference/templates/SOUL.md +49 -0
  617. package/docs/reference/templates/TOOLS.dev.md +29 -0
  618. package/docs/reference/templates/TOOLS.md +51 -0
  619. package/docs/reference/templates/USER.dev.md +23 -0
  620. package/docs/reference/templates/USER.md +28 -0
  621. package/docs/reference/test.md +248 -0
  622. package/docs/reference/token-use.md +246 -0
  623. package/docs/reference/transcript-hygiene.md +226 -0
  624. package/docs/reference/wizard.md +252 -0
  625. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +101 -0
  626. package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
  627. package/docs/security/formal-verification.md +170 -0
  628. package/docs/security/incident-response.md +59 -0
  629. package/docs/security/network-proxy.md +268 -0
  630. package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +12 -0
  631. package/docs/snippets/plugin-publish/minimal-package.json +16 -0
  632. package/docs/specs/claw-supervisor.md +247 -0
  633. package/docs/start/bootstrapping.md +49 -0
  634. package/docs/start/docs-directory.md +69 -0
  635. package/docs/start/getting-started.md +152 -0
  636. package/docs/start/hubs.md +201 -0
  637. package/docs/start/lore.md +223 -0
  638. package/docs/start/onboarding-overview.md +72 -0
  639. package/docs/start/onboarding.md +98 -0
  640. package/docs/start/openclaw.md +246 -0
  641. package/docs/start/quickstart.md +25 -0
  642. package/docs/start/setup.md +178 -0
  643. package/docs/start/showcase.md +371 -0
  644. package/docs/start/wizard-cli-automation.md +232 -0
  645. package/docs/start/wizard-cli-reference.md +331 -0
  646. package/docs/start/wizard.md +142 -0
  647. package/docs/style.css +137 -0
  648. package/docs/tools/acp-agents-setup.md +356 -0
  649. package/docs/tools/acp-agents.md +865 -0
  650. package/docs/tools/agent-send.md +130 -0
  651. package/docs/tools/apply-patch.md +64 -0
  652. package/docs/tools/brave-search.md +139 -0
  653. package/docs/tools/browser-control.md +405 -0
  654. package/docs/tools/browser-linux-troubleshooting.md +173 -0
  655. package/docs/tools/browser-login.md +77 -0
  656. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +219 -0
  657. package/docs/tools/browser.md +866 -0
  658. package/docs/tools/btw.md +159 -0
  659. package/docs/tools/capability-cookbook.md +12 -0
  660. package/docs/tools/clawhub.md +5 -0
  661. package/docs/tools/code-execution.md +173 -0
  662. package/docs/tools/creating-skills.md +271 -0
  663. package/docs/tools/diffs.md +527 -0
  664. package/docs/tools/duckduckgo-search.md +109 -0
  665. package/docs/tools/elevated.md +128 -0
  666. package/docs/tools/exa-search.md +152 -0
  667. package/docs/tools/exec-approvals-advanced.md +457 -0
  668. package/docs/tools/exec-approvals.md +520 -0
  669. package/docs/tools/exec.md +294 -0
  670. package/docs/tools/firecrawl.md +155 -0
  671. package/docs/tools/gemini-search.md +114 -0
  672. package/docs/tools/goal.md +217 -0
  673. package/docs/tools/grok-search.md +129 -0
  674. package/docs/tools/image-generation.md +538 -0
  675. package/docs/tools/index.md +176 -0
  676. package/docs/tools/kimi-search.md +105 -0
  677. package/docs/tools/llm-task.md +137 -0
  678. package/docs/tools/lobster.md +365 -0
  679. package/docs/tools/loop-detection.md +154 -0
  680. package/docs/tools/media-overview.md +161 -0
  681. package/docs/tools/minimax-search.md +102 -0
  682. package/docs/tools/multi-agent-sandbox-tools.md +409 -0
  683. package/docs/tools/music-generation.md +372 -0
  684. package/docs/tools/ollama-search.md +153 -0
  685. package/docs/tools/parallel-search.md +154 -0
  686. package/docs/tools/pdf.md +213 -0
  687. package/docs/tools/permission-modes.md +111 -0
  688. package/docs/tools/perplexity-search.md +220 -0
  689. package/docs/tools/plugin.md +378 -0
  690. package/docs/tools/reactions.md +100 -0
  691. package/docs/tools/searxng-search.md +141 -0
  692. package/docs/tools/skill-workshop.md +283 -0
  693. package/docs/tools/skills-config.md +457 -0
  694. package/docs/tools/skills.md +591 -0
  695. package/docs/tools/slash-commands.md +518 -0
  696. package/docs/tools/steer.md +77 -0
  697. package/docs/tools/subagents.md +652 -0
  698. package/docs/tools/tavily.md +162 -0
  699. package/docs/tools/thinking.md +142 -0
  700. package/docs/tools/tokenjuice.md +84 -0
  701. package/docs/tools/tool-search.md +269 -0
  702. package/docs/tools/trajectory.md +229 -0
  703. package/docs/tools/tts.md +1013 -0
  704. package/docs/tools/video-generation.md +555 -0
  705. package/docs/tools/web-fetch.md +210 -0
  706. package/docs/tools/web.md +476 -0
  707. package/docs/tts.md +11 -0
  708. package/docs/vps.md +139 -0
  709. package/docs/web/control-ui.md +530 -0
  710. package/docs/web/dashboard.md +107 -0
  711. package/docs/web/index.md +133 -0
  712. package/docs/web/tui.md +258 -0
  713. package/docs/web/webchat.md +102 -0
  714. package/npm-shrinkwrap.json +3485 -0
  715. package/openclaw.mjs +661 -0
  716. package/package.json +1971 -0
  717. package/patches/.gitkeep +0 -0
  718. package/patches/@agentclientprotocol__claude-agent-acp@0.39.0.patch +40 -0
  719. package/pnpm-workspace.yaml +124 -0
  720. package/scripts/crabbox-wrapper.mjs +2470 -0
  721. package/scripts/lib/official-external-channel-catalog.json +570 -0
  722. package/scripts/lib/official-external-plugin-catalog.json +284 -0
  723. package/scripts/lib/official-external-provider-catalog.json +158 -0
  724. package/scripts/lib/package-dist-imports.mjs +174 -0
  725. package/scripts/npm-runner.mjs +95 -0
  726. package/scripts/postinstall-bundled-plugins.mjs +978 -0
  727. package/scripts/preinstall-package-manager-warning.mjs +74 -0
  728. package/scripts/prepare-git-hooks.mjs +73 -0
  729. package/scripts/windows-cmd-helpers.mjs +29 -0
  730. package/skills/1password/SKILL.md +70 -0
  731. package/skills/1password/references/cli-examples.md +29 -0
  732. package/skills/1password/references/get-started.md +17 -0
  733. package/skills/apple-notes/SKILL.md +77 -0
  734. package/skills/apple-reminders/SKILL.md +118 -0
  735. package/skills/bear-notes/SKILL.md +107 -0
  736. package/skills/blogwatcher/SKILL.md +69 -0
  737. package/skills/blucli/SKILL.md +47 -0
  738. package/skills/camsnap/SKILL.md +45 -0
  739. package/skills/canvas/SKILL.md +78 -0
  740. package/skills/clawhub/SKILL.md +77 -0
  741. package/skills/coding-agent/SKILL.md +143 -0
  742. package/skills/diagram-maker/SKILL.md +53 -0
  743. package/skills/diagram-maker/references/excalidraw-patterns.md +85 -0
  744. package/skills/diagram-maker/references/svg-template.md +112 -0
  745. package/skills/discord/SKILL.md +136 -0
  746. package/skills/eightctl/SKILL.md +50 -0
  747. package/skills/gemini/SKILL.md +47 -0
  748. package/skills/gh-issues/SKILL.md +213 -0
  749. package/skills/gifgrep/SKILL.md +85 -0
  750. package/skills/github/SKILL.md +84 -0
  751. package/skills/gog/SKILL.md +116 -0
  752. package/skills/goplaces/SKILL.md +52 -0
  753. package/skills/healthcheck/SKILL.md +105 -0
  754. package/skills/himalaya/SKILL.md +80 -0
  755. package/skills/himalaya/references/configuration.md +184 -0
  756. package/skills/himalaya/references/message-composition.md +199 -0
  757. package/skills/imsg/SKILL.md +122 -0
  758. package/skills/mcporter/SKILL.md +61 -0
  759. package/skills/meme-maker/SKILL.md +42 -0
  760. package/skills/meme-maker/references/templates.json +358 -0
  761. package/skills/meme-maker/scripts/meme.mjs +398 -0
  762. package/skills/model-usage/SKILL.md +71 -0
  763. package/skills/model-usage/references/codexbar-cli.md +33 -0
  764. package/skills/model-usage/scripts/model_usage.py +319 -0
  765. package/skills/model-usage/scripts/test_model_usage.py +40 -0
  766. package/skills/nano-pdf/SKILL.md +38 -0
  767. package/skills/node-connect/SKILL.md +143 -0
  768. package/skills/node-inspect-debugger/SKILL.md +85 -0
  769. package/skills/notion/SKILL.md +150 -0
  770. package/skills/obsidian/SKILL.md +119 -0
  771. package/skills/openai-whisper/SKILL.md +38 -0
  772. package/skills/openai-whisper-api/SKILL.md +71 -0
  773. package/skills/openai-whisper-api/scripts/transcribe.sh +154 -0
  774. package/skills/openhue/SKILL.md +112 -0
  775. package/skills/oracle/SKILL.md +126 -0
  776. package/skills/ordercli/SKILL.md +78 -0
  777. package/skills/peekaboo/SKILL.md +198 -0
  778. package/skills/pyproject.toml +10 -0
  779. package/skills/python-debugpy/SKILL.md +73 -0
  780. package/skills/sag/SKILL.md +87 -0
  781. package/skills/session-logs/SKILL.md +151 -0
  782. package/skills/sherpa-onnx-tts/SKILL.md +109 -0
  783. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  784. package/skills/skill-creator/SKILL.md +78 -0
  785. package/skills/skill-creator/license.txt +202 -0
  786. package/skills/skill-creator/scripts/init_skill.py +378 -0
  787. package/skills/skill-creator/scripts/package_skill.py +144 -0
  788. package/skills/skill-creator/scripts/quick_validate.py +169 -0
  789. package/skills/skill-creator/scripts/test_package_skill.py +199 -0
  790. package/skills/skill-creator/scripts/test_quick_validate.py +116 -0
  791. package/skills/slack/SKILL.md +78 -0
  792. package/skills/songsee/SKILL.md +49 -0
  793. package/skills/sonoscli/SKILL.md +65 -0
  794. package/skills/spike/SKILL.md +51 -0
  795. package/skills/spotify-player/SKILL.md +64 -0
  796. package/skills/summarize/SKILL.md +87 -0
  797. package/skills/taskflow/SKILL.md +149 -0
  798. package/skills/taskflow/examples/inbox-triage.lobster +33 -0
  799. package/skills/taskflow/examples/pr-intake.lobster +32 -0
  800. package/skills/taskflow-inbox-triage/SKILL.md +119 -0
  801. package/skills/things-mac/SKILL.md +86 -0
  802. package/skills/tmux/SKILL.md +91 -0
  803. package/skills/tmux/scripts/find-sessions.sh +112 -0
  804. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  805. package/skills/trello/SKILL.md +108 -0
  806. package/skills/video-frames/SKILL.md +46 -0
  807. package/skills/video-frames/scripts/frame.sh +81 -0
  808. package/skills/voice-call/SKILL.md +45 -0
  809. package/skills/wacli/SKILL.md +72 -0
  810. package/skills/weather/SKILL.md +87 -0
  811. package/skills/xurl/SKILL.md +120 -0
  812. package/src/agents/templates/HEARTBEAT.md +5 -0
@@ -0,0 +1,525 @@
1
+ ---
2
+ summary: "Import map, registration API reference, and SDK architecture"
3
+ title: "Plugin SDK overview"
4
+ sidebarTitle: "Plugin SDK overview"
5
+ read_when:
6
+ - You need to know which SDK subpath to import from
7
+ - You want a reference for all registration methods on OpenClawPluginApi
8
+ - You are looking up a specific SDK export
9
+ ---
10
+
11
+ The plugin SDK is the typed contract between plugins and core. This page is the
12
+ reference for **what to import** and **what you can register**.
13
+
14
+ <Note>
15
+ This page is for plugin authors using `openclaw/plugin-sdk/*` inside
16
+ OpenClaw. For external apps, scripts, dashboards, CI jobs, and IDE extensions
17
+ that want to run agents through the Gateway, use
18
+ [Gateway integrations for external apps](/gateway/external-apps) instead.
19
+ </Note>
20
+
21
+ <Tip>
22
+ Looking for a how-to guide instead? Start with [Building plugins](/plugins/building-plugins), use [Channel plugins](/plugins/sdk-channel-plugins) for channel plugins, [Provider plugins](/plugins/sdk-provider-plugins) for provider plugins, [CLI backend plugins](/plugins/cli-backend-plugins) for local AI CLI backends, and [Plugin hooks](/plugins/hooks) for tool or lifecycle hook plugins.
23
+ </Tip>
24
+
25
+ ## Import convention
26
+
27
+ Always import from a specific subpath:
28
+
29
+ ```typescript
30
+ import { definePluginEntry } from "openclaw/plugin-sdk/plugin-entry";
31
+ import { defineChannelPluginEntry } from "openclaw/plugin-sdk/channel-core";
32
+ ```
33
+
34
+ Each subpath is a small, self-contained module. This keeps startup fast and
35
+ prevents circular dependency issues. For channel-specific entry/build helpers,
36
+ prefer `openclaw/plugin-sdk/channel-core`; keep `openclaw/plugin-sdk/core` for
37
+ the broader umbrella surface and shared helpers such as
38
+ `buildChannelConfigSchema`.
39
+
40
+ For channel config, publish the channel-owned JSON Schema through
41
+ `openclaw.plugin.json#channelConfigs`. The `plugin-sdk/channel-config-schema`
42
+ subpath is for shared schema primitives and the generic builder. OpenClaw's
43
+ bundled plugins use `plugin-sdk/bundled-channel-config-schema` for retained
44
+ bundled-channel schemas. Deprecated compatibility exports remain on
45
+ `plugin-sdk/channel-config-schema-legacy`; neither bundled schema subpath is a
46
+ pattern for new plugins.
47
+
48
+ <Warning>
49
+ Do not import provider- or channel-branded convenience seams (for example
50
+ `openclaw/plugin-sdk/slack`, `.../discord`, `.../signal`, `.../whatsapp`).
51
+ Bundled plugins compose generic SDK subpaths inside their own `api.ts` /
52
+ `runtime-api.ts` barrels; core consumers should either use those plugin-local
53
+ barrels or add a narrow generic SDK contract when a need is truly
54
+ cross-channel.
55
+
56
+ A small set of bundled-plugin helper seams still appear in the generated export
57
+ map when they have tracked owner usage. They exist for bundled-plugin
58
+ maintenance only and are not recommended import paths for new third-party
59
+ plugins.
60
+
61
+ `openclaw/plugin-sdk/discord` and `openclaw/plugin-sdk/telegram-account` are
62
+ also kept as deprecated compatibility facades for tracked owner usage. Do not
63
+ copy those import paths into new plugins; use injected runtime helpers and
64
+ generic channel SDK subpaths instead.
65
+ </Warning>
66
+
67
+ ## Subpath reference
68
+
69
+ The plugin SDK is exposed as a set of narrow subpaths grouped by area (plugin
70
+ entry, channel, provider, auth, runtime, capability, memory, and reserved
71
+ bundled-plugin helpers). For the full catalog — grouped and linked — see
72
+ [Plugin SDK subpaths](/plugins/sdk-subpaths).
73
+
74
+ The compiler entrypoint inventory lives in
75
+ `scripts/lib/plugin-sdk-entrypoints.json`; package exports are generated from
76
+ the public subset after subtracting repo-local test/internal subpaths listed in
77
+ `scripts/lib/plugin-sdk-private-local-only-subpaths.json`. Run
78
+ `pnpm plugin-sdk:surface` to audit the public export count. Deprecated public
79
+ subpaths that are old enough and unused by bundled extension production code are
80
+ tracked in `scripts/lib/plugin-sdk-deprecated-public-subpaths.json`; broad
81
+ deprecated re-export barrels are tracked in
82
+ `scripts/lib/plugin-sdk-deprecated-barrel-subpaths.json`.
83
+
84
+ ## Registration API
85
+
86
+ The `register(api)` callback receives an `OpenClawPluginApi` object with these
87
+ methods:
88
+
89
+ ### Capability registration
90
+
91
+ | Method | What it registers |
92
+ | ------------------------------------------------ | ------------------------------------- |
93
+ | `api.registerProvider(...)` | Text inference (LLM) |
94
+ | `api.registerAgentHarness(...)` | Experimental low-level agent executor |
95
+ | `api.registerCliBackend(...)` | Local CLI inference backend |
96
+ | `api.registerChannel(...)` | Messaging channel |
97
+ | `api.registerEmbeddingProvider(...)` | Reusable vector embedding provider |
98
+ | `api.registerSpeechProvider(...)` | Text-to-speech / STT synthesis |
99
+ | `api.registerRealtimeTranscriptionProvider(...)` | Streaming realtime transcription |
100
+ | `api.registerRealtimeVoiceProvider(...)` | Duplex realtime voice sessions |
101
+ | `api.registerMediaUnderstandingProvider(...)` | Image/audio/video analysis |
102
+ | `api.registerImageGenerationProvider(...)` | Image generation |
103
+ | `api.registerMusicGenerationProvider(...)` | Music generation |
104
+ | `api.registerVideoGenerationProvider(...)` | Video generation |
105
+ | `api.registerWebFetchProvider(...)` | Web fetch / scrape provider |
106
+ | `api.registerWebSearchProvider(...)` | Web search |
107
+
108
+ Embedding providers registered with `api.registerEmbeddingProvider(...)` must
109
+ also be listed in `contracts.embeddingProviders` in the plugin manifest. This
110
+ is the generic embedding surface for reusable vector generation. Memory search
111
+ can consume this generic provider surface. The older
112
+ `api.registerMemoryEmbeddingProvider(...)` and
113
+ `contracts.memoryEmbeddingProviders` seam is deprecated compatibility while
114
+ existing memory-specific providers migrate.
115
+
116
+ Memory-specific providers that still expose a runtime `batchEmbed(...)` stay on
117
+ the existing per-file batching contract unless their runtime explicitly sets
118
+ `sourceWideBatchEmbed: true`. That opt-in lets the memory host submit chunks from
119
+ multiple dirty memory files and enabled sources in one `batchEmbed(...)` call up
120
+ to the host batch limits. Batch adapters that upload JSONL request files must
121
+ split provider jobs before their upload-size cap as well as their request-count
122
+ cap. The provider must return one embedding per input chunk in the same order as
123
+ `batch.chunks`; omit the flag when the provider expects file-local batches or
124
+ cannot preserve input ordering across a larger source-wide job.
125
+
126
+ ### Tools and commands
127
+
128
+ Use [`defineToolPlugin`](/plugins/tool-plugins) for simple tool-only plugins
129
+ with fixed tool names. Use `api.registerTool(...)` directly for mixed plugins
130
+ or fully dynamic tool registration.
131
+
132
+ | Method | What it registers |
133
+ | ------------------------------- | --------------------------------------------- |
134
+ | `api.registerTool(tool, opts?)` | Agent tool (required or `{ optional: true }`) |
135
+ | `api.registerCommand(def)` | Custom command (bypasses the LLM) |
136
+
137
+ Plugin commands can set `agentPromptGuidance` when the agent needs a short,
138
+ command-owned routing hint. Keep that text about the command itself; do not add
139
+ provider- or plugin-specific policy to core prompt builders.
140
+
141
+ Guidance entries may be legacy strings, which apply to every prompt surface, or
142
+ structured entries:
143
+
144
+ ```ts
145
+ agentPromptGuidance: [
146
+ "Global command hint.",
147
+ { text: "Only show this in the main OpenClaw prompt.", surfaces: ["openclaw_main"] },
148
+ ];
149
+ ```
150
+
151
+ Structured `surfaces` may include `openclaw_main`, `codex_app_server`,
152
+ `cli_backend`, `acp_backend`, or `subagent`. `pi_main` remains a deprecated alias
153
+ for `openclaw_main`. Omit `surfaces` for intentional all-surface guidance. Do
154
+ not pass an empty `surfaces` array; it is rejected so accidental scope loss does
155
+ not become global prompt text.
156
+
157
+ Native Codex app-server developer instructions are stricter than other prompt
158
+ surfaces: only guidance explicitly scoped to `codex_app_server` is promoted into
159
+ that higher-priority lane. Legacy string guidance and unscoped structured
160
+ guidance remain available to non-Codex prompt surfaces for compatibility.
161
+
162
+ ### Infrastructure
163
+
164
+ | Method | What it registers |
165
+ | ---------------------------------------------- | --------------------------------------- |
166
+ | `api.registerHook(events, handler, opts?)` | Event hook |
167
+ | `api.registerHttpRoute(params)` | Gateway HTTP endpoint |
168
+ | `api.registerGatewayMethod(name, handler)` | Gateway RPC method |
169
+ | `api.registerGatewayDiscoveryService(service)` | Local Gateway discovery advertiser |
170
+ | `api.registerCli(registrar, opts?)` | CLI subcommand |
171
+ | `api.registerNodeCliFeature(registrar, opts?)` | Node feature CLI under `openclaw nodes` |
172
+ | `api.registerService(service)` | Background service |
173
+ | `api.registerInteractiveHandler(registration)` | Interactive handler |
174
+ | `api.registerAgentToolResultMiddleware(...)` | Runtime tool-result middleware |
175
+ | `api.registerMemoryPromptSupplement(builder)` | Additive memory-adjacent prompt section |
176
+ | `api.registerMemoryCorpusSupplement(adapter)` | Additive memory search/read corpus |
177
+
178
+ ### Host hooks for workflow plugins
179
+
180
+ Host hooks are the SDK seams for plugins that need to participate in the host
181
+ lifecycle rather than only adding a provider, channel, or tool. They are
182
+ generic contracts; Plan Mode can use them, but so can approval workflows,
183
+ workspace policy gates, background monitors, setup wizards, and UI companion
184
+ plugins.
185
+
186
+ | Method | Contract it owns |
187
+ | ------------------------------------------------------------------------------------ | --------------------------------------------------------------------------------------------------------------------------------- |
188
+ | `api.session.state.registerSessionExtension(...)` | Plugin-owned, JSON-compatible session state projected through Gateway sessions |
189
+ | `api.session.workflow.enqueueNextTurnInjection(...)` | Durable exactly-once context injected into the next agent turn for one session |
190
+ | `api.registerTrustedToolPolicy(...)` | Manifest-gated trusted pre-plugin tool policy that can block or rewrite tool params |
191
+ | `api.registerToolMetadata(...)` | Tool catalog display metadata without changing the tool implementation |
192
+ | `api.registerCommand(...)` | Scoped plugin commands; command results can set `continueAgent: true`; Discord native commands support `descriptionLocalizations` |
193
+ | `api.session.controls.registerControlUiDescriptor(...)` | Control UI contribution descriptors for session, tool, run, or settings surfaces |
194
+ | `api.lifecycle.registerRuntimeLifecycle(...)` | Cleanup callbacks for plugin-owned runtime resources on reset/delete/reload paths |
195
+ | `api.agent.events.registerAgentEventSubscription(...)` | Sanitized event subscriptions for workflow state and monitors |
196
+ | `api.runContext.setRunContext(...)` / `getRunContext(...)` / `clearRunContext(...)` | Per-run plugin scratch state cleared on terminal run lifecycle |
197
+ | `api.session.workflow.registerSessionSchedulerJob(...)` | Cleanup metadata for plugin-owned scheduler jobs; does not schedule work or create task records |
198
+ | `api.session.workflow.sendSessionAttachment(...)` | Bundled-only host-mediated file attachment delivery to the active direct-outbound session route |
199
+ | `api.session.workflow.scheduleSessionTurn(...)` / `unscheduleSessionTurnsByTag(...)` | Bundled-only Cron-backed scheduled session turns plus tag-based cleanup |
200
+ | `api.session.controls.registerSessionAction(...)` | Typed session actions clients can dispatch through the Gateway |
201
+
202
+ Use the grouped namespaces for new plugin code:
203
+
204
+ - `api.session.state.registerSessionExtension(...)`
205
+ - `api.session.workflow.enqueueNextTurnInjection(...)`
206
+ - `api.session.workflow.registerSessionSchedulerJob(...)`
207
+ - `api.session.workflow.sendSessionAttachment(...)`
208
+ - `api.session.workflow.scheduleSessionTurn(...)`
209
+ - `api.session.workflow.unscheduleSessionTurnsByTag(...)`
210
+ - `api.session.controls.registerSessionAction(...)`
211
+ - `api.session.controls.registerControlUiDescriptor(...)`
212
+ - `api.agent.events.registerAgentEventSubscription(...)`
213
+ - `api.agent.events.emitAgentEvent(...)`
214
+ - `api.runContext.setRunContext(...)` / `getRunContext(...)` / `clearRunContext(...)`
215
+ - `api.lifecycle.registerRuntimeLifecycle(...)`
216
+
217
+ The equivalent flat methods remain available as deprecated compatibility
218
+ aliases for existing plugins. Do not add new plugin code that calls
219
+ `api.registerSessionExtension`, `api.enqueueNextTurnInjection`,
220
+ `api.registerControlUiDescriptor`, `api.registerRuntimeLifecycle`,
221
+ `api.registerAgentEventSubscription`, `api.emitAgentEvent`,
222
+ `api.setRunContext`, `api.getRunContext`, `api.clearRunContext`,
223
+ `api.registerSessionSchedulerJob`, `api.registerSessionAction`,
224
+ `api.sendSessionAttachment`, `api.scheduleSessionTurn`, or
225
+ `api.unscheduleSessionTurnsByTag` directly.
226
+
227
+ `scheduleSessionTurn(...)` is a session-scoped convenience over the Gateway
228
+ Cron scheduler. Cron owns timing and creates the background task record when the
229
+ turn runs; the Plugin SDK only constrains the target session, plugin-owned
230
+ naming, and cleanup. Use `api.runtime.tasks.managedFlows` inside the scheduled
231
+ turn when the work itself needs durable multi-step Task Flow state.
232
+
233
+ The contracts intentionally split authority:
234
+
235
+ - External plugins can own session extensions, UI descriptors, commands, tool
236
+ metadata, next-turn injections, and normal hooks.
237
+ - Trusted tool policies run before ordinary `before_tool_call` hooks and are
238
+ host-trusted. Bundled policies run first; installed-plugin policies require
239
+ explicit enablement plus their local ids in
240
+ `contracts.trustedToolPolicies`, and run next in plugin-load order. Policy ids
241
+ are scoped to the registering plugin.
242
+ - Reserved command ownership is bundled-only. External plugins should use their
243
+ own command names or aliases.
244
+ - `allowPromptInjection=false` disables prompt-mutating hooks including
245
+ `agent_turn_prepare`, `before_prompt_build`, `heartbeat_prompt_contribution`,
246
+ prompt fields from legacy `before_agent_start`, and
247
+ `enqueueNextTurnInjection`.
248
+
249
+ Examples of non-Plan consumers:
250
+
251
+ | Plugin archetype | Hooks used |
252
+ | ---------------------------- | -------------------------------------------------------------------------------------------------------------------------------------- |
253
+ | Approval workflow | Session extension, command continuation, next-turn injection, UI descriptor |
254
+ | Budget/workspace policy gate | Trusted tool policy, tool metadata, session projection |
255
+ | Background lifecycle monitor | Runtime lifecycle cleanup, agent event subscription, session scheduler ownership/cleanup, heartbeat prompt contribution, UI descriptor |
256
+ | Setup or onboarding wizard | Session extension, scoped commands, Control UI descriptor |
257
+
258
+ <Note>
259
+ Reserved core admin namespaces (`config.*`, `exec.approvals.*`, `wizard.*`,
260
+ `update.*`) always stay `operator.admin`, even if a plugin tries to assign a
261
+ narrower gateway method scope. Prefer plugin-specific prefixes for
262
+ plugin-owned methods.
263
+ </Note>
264
+
265
+ <Accordion title="When to use tool-result middleware">
266
+ Bundled plugins and explicitly enabled installed plugins with matching
267
+ manifest contracts can use `api.registerAgentToolResultMiddleware(...)` when
268
+ they need to rewrite a tool result after execution and before the runtime
269
+ feeds that result back into the model. This is the trusted runtime-neutral
270
+ seam for async output reducers such as tokenjuice.
271
+
272
+ Plugins must declare `contracts.agentToolResultMiddleware` for each targeted
273
+ runtime, for example `["openclaw", "codex"]`. Installed plugins without that
274
+ contract, or without explicit enablement, cannot register this middleware; keep
275
+ normal OpenClaw plugin hooks for work that does not need pre-model tool-result
276
+ timing. The old
277
+ embedded-runner-only extension factory registration path has been removed.
278
+ </Accordion>
279
+
280
+ ### Gateway discovery registration
281
+
282
+ `api.registerGatewayDiscoveryService(...)` lets a plugin advertise the active
283
+ Gateway on a local discovery transport such as mDNS/Bonjour. OpenClaw calls the
284
+ service during Gateway startup when local discovery is enabled, passes the
285
+ current Gateway ports and non-secret TXT hint data, and calls the returned
286
+ `stop` handler during Gateway shutdown.
287
+
288
+ ```typescript
289
+ api.registerGatewayDiscoveryService({
290
+ id: "my-discovery",
291
+ async advertise(ctx) {
292
+ const handle = await startMyAdvertiser({
293
+ gatewayPort: ctx.gatewayPort,
294
+ tls: ctx.gatewayTlsEnabled,
295
+ displayName: ctx.machineDisplayName,
296
+ });
297
+ return { stop: () => handle.stop() };
298
+ },
299
+ });
300
+ ```
301
+
302
+ Gateway discovery plugins must not treat advertised TXT values as secrets or
303
+ authentication. Discovery is a routing hint; Gateway auth and TLS pinning still
304
+ own trust.
305
+
306
+ ### CLI registration metadata
307
+
308
+ `api.registerCli(registrar, opts?)` accepts two kinds of command metadata:
309
+
310
+ - `commands`: explicit command names owned by the registrar
311
+ - `descriptors`: parse-time command descriptors used for CLI help,
312
+ routing, and lazy plugin CLI registration
313
+ - `parentPath`: optional parent command path for nested command groups, such as
314
+ `["nodes"]`
315
+
316
+ For paired-node features, prefer
317
+ `api.registerNodeCliFeature(registrar, opts?)`. It is a small wrapper around
318
+ `api.registerCli(..., { parentPath: ["nodes"] })` and makes commands such as
319
+ `openclaw nodes canvas` explicit plugin-owned node features.
320
+
321
+ If you want a plugin command to stay lazy-loaded in the normal root CLI path,
322
+ provide `descriptors` that cover every top-level command root exposed by that
323
+ registrar.
324
+
325
+ ```typescript
326
+ api.registerCli(
327
+ async ({ program }) => {
328
+ const { registerMatrixCli } = await import("./src/cli.js");
329
+ registerMatrixCli({ program });
330
+ },
331
+ {
332
+ descriptors: [
333
+ {
334
+ name: "matrix",
335
+ description: "Manage Matrix accounts, verification, devices, and profile state",
336
+ hasSubcommands: true,
337
+ },
338
+ ],
339
+ },
340
+ );
341
+ ```
342
+
343
+ Nested commands receive the resolved parent command as `program`:
344
+
345
+ ```typescript
346
+ api.registerCli(
347
+ async ({ program }) => {
348
+ const { registerNodesCanvasCommands } = await import("./src/cli.js");
349
+ registerNodesCanvasCommands(program);
350
+ },
351
+ {
352
+ parentPath: ["nodes"],
353
+ descriptors: [
354
+ {
355
+ name: "canvas",
356
+ description: "Capture or render canvas content from a paired node",
357
+ hasSubcommands: true,
358
+ },
359
+ ],
360
+ },
361
+ );
362
+ ```
363
+
364
+ Use `commands` by itself only when you do not need lazy root CLI registration.
365
+ That eager compatibility path remains supported, but it does not install
366
+ descriptor-backed placeholders for parse-time lazy loading.
367
+
368
+ ### CLI backend registration
369
+
370
+ `api.registerCliBackend(...)` lets a plugin own the default config for a local
371
+ AI CLI backend such as `claude-cli` or `my-cli`.
372
+
373
+ - The backend `id` becomes the provider prefix in model refs like `my-cli/gpt-5`.
374
+ - The backend `config` uses the same shape as `agents.defaults.cliBackends.<id>`.
375
+ - User config still wins. OpenClaw merges `agents.defaults.cliBackends.<id>` over the
376
+ plugin default before running the CLI.
377
+ - Use `normalizeConfig` when a backend needs compatibility rewrites after merge
378
+ (for example normalizing old flag shapes).
379
+ - Use `resolveExecutionArgs` for request-scoped argv rewrites that belong to
380
+ the CLI dialect, such as mapping OpenClaw thinking levels to a native effort
381
+ flag.
382
+
383
+ For an end-to-end authoring guide, see
384
+ [CLI backend plugins](/plugins/cli-backend-plugins).
385
+
386
+ ### Exclusive slots
387
+
388
+ | Method | What it registers |
389
+ | ------------------------------------------ | --------------------------------------------------------------------------------------------------------------------------------------------------------- |
390
+ | `api.registerContextEngine(id, factory)` | Context engine (one active at a time). The `assemble()` callback receives `availableTools` and `citationsMode` so the engine can tailor prompt additions. |
391
+ | `api.registerMemoryCapability(capability)` | Unified memory capability |
392
+ | `api.registerMemoryPromptSection(builder)` | Memory prompt section builder |
393
+ | `api.registerMemoryFlushPlan(resolver)` | Memory flush plan resolver |
394
+ | `api.registerMemoryRuntime(runtime)` | Memory runtime adapter |
395
+
396
+ ### Deprecated memory embedding adapters
397
+
398
+ | Method | What it registers |
399
+ | ---------------------------------------------- | ---------------------------------------------- |
400
+ | `api.registerMemoryEmbeddingProvider(adapter)` | Memory embedding adapter for the active plugin |
401
+
402
+ - `registerMemoryCapability` is the preferred exclusive memory-plugin API.
403
+ - `registerMemoryCapability` may also expose `publicArtifacts.listArtifacts(...)`
404
+ so companion plugins can consume exported memory artifacts through
405
+ `openclaw/plugin-sdk/memory-host-core` instead of reaching into a specific
406
+ memory plugin's private layout.
407
+ - `registerMemoryPromptSection`, `registerMemoryFlushPlan`, and
408
+ `registerMemoryRuntime` are legacy-compatible exclusive memory-plugin APIs.
409
+ - `MemoryFlushPlan.model` can pin the flush turn to an exact `provider/model`
410
+ reference, such as `ollama/qwen3:8b`, without inheriting the active fallback
411
+ chain.
412
+ - `registerMemoryEmbeddingProvider` is deprecated. New embedding providers
413
+ should use `api.registerEmbeddingProvider(...)` and
414
+ `contracts.embeddingProviders`.
415
+ - Existing memory-specific providers continue to work during the migration
416
+ window, but plugin inspection reports this as compatibility debt for
417
+ non-bundled plugins.
418
+
419
+ ### Events and lifecycle
420
+
421
+ | Method | What it does |
422
+ | -------------------------------------------- | ----------------------------- |
423
+ | `api.on(hookName, handler, opts?)` | Typed lifecycle hook |
424
+ | `api.onConversationBindingResolved(handler)` | Conversation binding callback |
425
+
426
+ See [Plugin hooks](/plugins/hooks) for examples, common hook names, and guard
427
+ semantics.
428
+
429
+ ### Hook decision semantics
430
+
431
+ - `before_tool_call`: returning `{ block: true }` is terminal. Once any handler sets it, lower-priority handlers are skipped.
432
+ - `before_tool_call`: returning `{ block: false }` is treated as no decision (same as omitting `block`), not as an override.
433
+ - `before_install`: returning `{ block: true }` is terminal. Once any handler sets it, lower-priority handlers are skipped.
434
+ - `before_install`: returning `{ block: false }` is treated as no decision (same as omitting `block`), not as an override.
435
+ - `reply_dispatch`: returning `{ handled: true, ... }` is terminal. Once any handler claims dispatch, lower-priority handlers and the default model dispatch path are skipped.
436
+ - `message_sending`: returning `{ cancel: true }` is terminal. Once any handler sets it, lower-priority handlers are skipped.
437
+ - `message_sending`: returning `{ cancel: false }` is treated as no decision (same as omitting `cancel`), not as an override.
438
+ - `message_received`: use the typed `threadId` field when you need inbound thread/topic routing. Keep `metadata` for channel-specific extras.
439
+ - `message_sending`: use typed `replyToId` / `threadId` routing fields before falling back to channel-specific `metadata`.
440
+ - `gateway_start`: use `ctx.config`, `ctx.workspaceDir`, and `ctx.getCron?.()` for gateway-owned startup state instead of relying on internal `gateway:startup` hooks.
441
+ - `cron_changed`: observe gateway-owned cron lifecycle changes. Use `event.job?.state?.nextRunAtMs` and `ctx.getCron?.()` when syncing external wake schedulers, and keep OpenClaw as the source of truth for due checks and execution.
442
+
443
+ ### API object fields
444
+
445
+ | Field | Type | Description |
446
+ | ------------------------ | ------------------------- | ------------------------------------------------------------------------------------------- |
447
+ | `api.id` | `string` | Plugin id |
448
+ | `api.name` | `string` | Display name |
449
+ | `api.version` | `string?` | Plugin version (optional) |
450
+ | `api.description` | `string?` | Plugin description (optional) |
451
+ | `api.source` | `string` | Plugin source path |
452
+ | `api.rootDir` | `string?` | Plugin root directory (optional) |
453
+ | `api.config` | `OpenClawConfig` | Current config snapshot (active in-memory runtime snapshot when available) |
454
+ | `api.pluginConfig` | `Record<string, unknown>` | Plugin-specific config from `plugins.entries.<id>.config` |
455
+ | `api.runtime` | `PluginRuntime` | [Runtime helpers](/plugins/sdk-runtime) |
456
+ | `api.logger` | `PluginLogger` | Scoped logger (`debug`, `info`, `warn`, `error`) |
457
+ | `api.registrationMode` | `PluginRegistrationMode` | Current load mode; `"setup-runtime"` is the lightweight pre-full-entry startup/setup window |
458
+ | `api.resolvePath(input)` | `(string) => string` | Resolve path relative to plugin root |
459
+
460
+ ## Internal module convention
461
+
462
+ Within your plugin, use local barrel files for internal imports:
463
+
464
+ ```
465
+ my-plugin/
466
+ api.ts # Public exports for external consumers
467
+ runtime-api.ts # Internal-only runtime exports
468
+ index.ts # Plugin entry point
469
+ setup-entry.ts # Lightweight setup-only entry (optional)
470
+ ```
471
+
472
+ <Warning>
473
+ Never import your own plugin through `openclaw/plugin-sdk/<your-plugin>`
474
+ from production code. Route internal imports through `./api.ts` or
475
+ `./runtime-api.ts`. The SDK path is the external contract only.
476
+ </Warning>
477
+
478
+ Facade-loaded bundled plugin public surfaces (`api.ts`, `runtime-api.ts`,
479
+ `index.ts`, `setup-entry.ts`, and similar public entry files) prefer the
480
+ active runtime config snapshot when OpenClaw is already running. If no runtime
481
+ snapshot exists yet, they fall back to the resolved config file on disk.
482
+ Packaged bundled plugin facades should be loaded through OpenClaw's plugin
483
+ facade loaders; direct imports from `dist/extensions/...` bypass the manifest
484
+ and runtime sidecar checks that packaged installs use for plugin-owned code.
485
+
486
+ Provider plugins can expose a narrow plugin-local contract barrel when a
487
+ helper is intentionally provider-specific and does not belong in a generic SDK
488
+ subpath yet. Bundled examples:
489
+
490
+ - **Anthropic**: public `api.ts` / `contract-api.ts` seam for Claude
491
+ beta-header and `service_tier` stream helpers.
492
+ - **`@openclaw/openai-provider`**: `api.ts` exports provider builders,
493
+ default-model helpers, and realtime provider builders.
494
+ - **`@openclaw/openrouter-provider`**: `api.ts` exports the provider builder
495
+ plus onboarding/config helpers.
496
+
497
+ <Warning>
498
+ Extension production code should also avoid `openclaw/plugin-sdk/<other-plugin>`
499
+ imports. If a helper is truly shared, promote it to a neutral SDK subpath
500
+ such as `openclaw/plugin-sdk/speech`, `.../provider-model-shared`, or another
501
+ capability-oriented surface instead of coupling two plugins together.
502
+ </Warning>
503
+
504
+ ## Related
505
+
506
+ <CardGroup cols={2}>
507
+ <Card title="Entry points" icon="door-open" href="/plugins/sdk-entrypoints">
508
+ `definePluginEntry` and `defineChannelPluginEntry` options.
509
+ </Card>
510
+ <Card title="Runtime helpers" icon="gears" href="/plugins/sdk-runtime">
511
+ Full `api.runtime` namespace reference.
512
+ </Card>
513
+ <Card title="Setup and config" icon="sliders" href="/plugins/sdk-setup">
514
+ Packaging, manifests, and config schemas.
515
+ </Card>
516
+ <Card title="Testing" icon="vial" href="/plugins/sdk-testing">
517
+ Test utilities and lint rules.
518
+ </Card>
519
+ <Card title="SDK migration" icon="arrows-turn-right" href="/plugins/sdk-migration">
520
+ Migrating from deprecated surfaces.
521
+ </Card>
522
+ <Card title="Plugin internals" icon="diagram-project" href="/plugins/architecture">
523
+ Deep architecture and capability model.
524
+ </Card>
525
+ </CardGroup>