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,284 @@
1
+ ---
2
+ summary: Decouple semantic message presentation from channel native UI renderers.
3
+ title: Channel presentation refactor plan
4
+ read_when:
5
+ - Refactoring channel message UI, interactive payloads, or native channel renderers
6
+ - Changing message tool capabilities, delivery hints, or cross-context markers
7
+ - Debugging Discord Carbon import fanout or channel plugin runtime laziness
8
+ ---
9
+
10
+ ## Status
11
+
12
+ Implemented for the shared agent, CLI, plugin capability, and outbound delivery surfaces:
13
+
14
+ - `ReplyPayload.presentation` carries semantic message UI.
15
+ - `ReplyPayload.delivery.pin` carries sent-message pin requests.
16
+ - Shared message actions expose `presentation`, `delivery`, and `pin` instead of provider-native `components`, `blocks`, `buttons`, or `card`.
17
+ - Core renders or auto-degrades presentation through plugin-declared outbound capabilities.
18
+ - Discord, Slack, Telegram, Mattermost, MS Teams, and Feishu renderers consume the generic contract.
19
+ - Discord channel control-plane code no longer imports Carbon-backed UI containers.
20
+
21
+ Canonical docs now live in [Message Presentation](/plugins/message-presentation).
22
+ Keep this plan as historical implementation context; update the canonical guide
23
+ for contract, renderer, or fallback behavior changes.
24
+
25
+ ## Problem
26
+
27
+ Channel UI is currently split across several incompatible surfaces:
28
+
29
+ - Core owns a Discord-shaped cross-context renderer hook through `buildCrossContextComponents`.
30
+ - Discord `channel.ts` can import native Carbon UI through `DiscordUiContainer`, which pulls runtime UI dependencies into the channel plugin control plane.
31
+ - The agent and CLI expose native payload escape hatches such as Discord `components`, Slack `blocks`, Telegram or Mattermost `buttons`, and Teams or Feishu `card`.
32
+ - `ReplyPayload.channelData` carries both transport hints and native UI envelopes.
33
+ - The generic `interactive` model exists, but it is narrower than the richer layouts already used by Discord, Slack, Teams, Feishu, LINE, Telegram, and Mattermost.
34
+
35
+ This makes core aware of native UI shapes, weakens plugin runtime laziness, and gives agents too many provider-specific ways to express the same message intent.
36
+
37
+ ## Goals
38
+
39
+ - Core decides the best semantic presentation for a message from declared capabilities.
40
+ - Extensions declare capabilities and render semantic presentation into native transport payloads.
41
+ - Web Control UI remains separate from chat native UI.
42
+ - Native channel payloads are not exposed through the shared agent or CLI message surface.
43
+ - Unsupported presentation features auto-degrade to the best text representation.
44
+ - Delivery behavior such as pinning a sent message is generic delivery metadata, not presentation.
45
+
46
+ ## Non goals
47
+
48
+ - No backwards compatibility shim for `buildCrossContextComponents`.
49
+ - No public native escape hatches for `components`, `blocks`, `buttons`, or `card`.
50
+ - No core imports of channel-native UI libraries.
51
+ - No provider-specific SDK seams for bundled channels.
52
+
53
+ ## Target model
54
+
55
+ Add a core-owned `presentation` field to `ReplyPayload`.
56
+
57
+ ```ts
58
+ type MessagePresentationTone = "neutral" | "info" | "success" | "warning" | "danger";
59
+
60
+ type MessagePresentation = {
61
+ tone?: MessagePresentationTone;
62
+ title?: string;
63
+ blocks: MessagePresentationBlock[];
64
+ };
65
+
66
+ type MessagePresentationBlock =
67
+ | { type: "text"; text: string }
68
+ | { type: "context"; text: string }
69
+ | { type: "divider" }
70
+ | { type: "buttons"; buttons: MessagePresentationButton[] }
71
+ | { type: "select"; placeholder?: string; options: MessagePresentationOption[] };
72
+
73
+ type MessagePresentationButton = {
74
+ label: string;
75
+ value?: string;
76
+ url?: string;
77
+ style?: "primary" | "secondary" | "success" | "danger";
78
+ };
79
+
80
+ type MessagePresentationOption = {
81
+ label: string;
82
+ value: string;
83
+ };
84
+ ```
85
+
86
+ `interactive` becomes a subset of `presentation` during migration:
87
+
88
+ - `interactive` text block maps to `presentation.blocks[].type = "text"`.
89
+ - `interactive` buttons block maps to `presentation.blocks[].type = "buttons"`.
90
+ - `interactive` select block maps to `presentation.blocks[].type = "select"`.
91
+
92
+ The external agent and CLI schemas now use `presentation`; `interactive` remains an internal legacy parser/rendering helper for existing reply producers.
93
+ The public producer-facing API treats `interactive` as deprecated. Runtime
94
+ support remains so existing approval helpers and older plugins continue to
95
+ work while new code emits `presentation`.
96
+
97
+ ## Delivery metadata
98
+
99
+ Add a core-owned `delivery` field for send behavior that is not UI.
100
+
101
+ ```ts
102
+ type ReplyPayloadDelivery = {
103
+ pin?:
104
+ | boolean
105
+ | {
106
+ enabled: boolean;
107
+ notify?: boolean;
108
+ required?: boolean;
109
+ };
110
+ };
111
+ ```
112
+
113
+ Semantics:
114
+
115
+ - `delivery.pin = true` means pin the first successfully delivered message.
116
+ - `notify` defaults to `false`.
117
+ - `required` defaults to `false`; unsupported channels or failed pinning auto-degrade by continuing delivery.
118
+ - Manual `pin`, `unpin`, and `list-pins` message actions remain for existing messages.
119
+
120
+ Current Telegram ACP topic binding should move from `channelData.telegram.pin = true` to `delivery.pin = true`.
121
+
122
+ ## Runtime capability contract
123
+
124
+ Add presentation and delivery render hooks to the runtime outbound adapter, not the control-plane channel plugin.
125
+
126
+ ```ts
127
+ type ChannelPresentationCapabilities = {
128
+ supported: boolean;
129
+ buttons?: boolean;
130
+ selects?: boolean;
131
+ context?: boolean;
132
+ divider?: boolean;
133
+ tones?: MessagePresentationTone[];
134
+ limits?: {
135
+ actions?: {
136
+ maxActions?: number;
137
+ maxActionsPerRow?: number;
138
+ maxRows?: number;
139
+ maxLabelLength?: number;
140
+ maxValueBytes?: number;
141
+ supportsStyles?: boolean;
142
+ supportsDisabled?: boolean;
143
+ supportsLayoutHints?: boolean;
144
+ };
145
+ selects?: {
146
+ maxOptions?: number;
147
+ maxLabelLength?: number;
148
+ maxValueBytes?: number;
149
+ };
150
+ text?: {
151
+ maxLength?: number;
152
+ encoding?: "characters" | "utf8-bytes" | "utf16-units";
153
+ markdownDialect?: "plain" | "markdown" | "html" | "slack-mrkdwn" | "discord-markdown";
154
+ supportsEdit?: boolean;
155
+ };
156
+ };
157
+ };
158
+
159
+ type ChannelDeliveryCapabilities = {
160
+ pinSentMessage?: boolean;
161
+ };
162
+
163
+ type ChannelOutboundAdapter = {
164
+ presentationCapabilities?: ChannelPresentationCapabilities;
165
+
166
+ renderPresentation?: (params: {
167
+ payload: ReplyPayload;
168
+ presentation: MessagePresentation;
169
+ ctx: ChannelOutboundSendContext;
170
+ }) => ReplyPayload | null;
171
+
172
+ deliveryCapabilities?: ChannelDeliveryCapabilities;
173
+
174
+ pinDeliveredMessage?: (params: {
175
+ cfg: OpenClawConfig;
176
+ accountId?: string | null;
177
+ to: string;
178
+ threadId?: string | number | null;
179
+ messageId: string;
180
+ notify: boolean;
181
+ }) => Promise<void>;
182
+ };
183
+ ```
184
+
185
+ Core behavior:
186
+
187
+ - Resolve target channel and runtime adapter.
188
+ - Ask for presentation capabilities.
189
+ - Degrade unsupported blocks and apply generic capability limits before
190
+ rendering.
191
+ - Call `renderPresentation`.
192
+ - If no renderer exists, convert presentation to text fallback.
193
+ - After successful send, call `pinDeliveredMessage` when `delivery.pin` is requested and supported.
194
+
195
+ ## Channel mapping
196
+
197
+ Discord:
198
+
199
+ - Render `presentation` to components v2 and Carbon containers in runtime-only modules.
200
+ - Keep accent color helpers in light modules.
201
+ - Remove `DiscordUiContainer` imports from channel plugin control-plane code.
202
+
203
+ Slack:
204
+
205
+ - Render `presentation` to Block Kit.
206
+ - Remove agent and CLI `blocks` input.
207
+
208
+ Telegram:
209
+
210
+ - Render text, context, and dividers as text.
211
+ - Render actions and select as inline keyboards when configured and allowed for the target surface.
212
+ - Use text fallback when inline buttons are disabled.
213
+ - Move ACP topic pinning to `delivery.pin`.
214
+
215
+ Mattermost:
216
+
217
+ - Render actions as interactive buttons where configured.
218
+ - Render other blocks as text fallback.
219
+
220
+ MS Teams:
221
+
222
+ - Render `presentation` to Adaptive Cards.
223
+ - Keep manual pin/unpin/list-pins actions.
224
+ - Optionally implement `pinDeliveredMessage` if Graph support is reliable for the target conversation.
225
+
226
+ Feishu:
227
+
228
+ - Render `presentation` to interactive cards.
229
+ - Keep manual pin/unpin/list-pins actions.
230
+ - Optionally implement `pinDeliveredMessage` for sent-message pinning if API behavior is reliable.
231
+
232
+ LINE:
233
+
234
+ - Render `presentation` to Flex or template messages where possible.
235
+ - Fall back to text for unsupported blocks.
236
+ - Remove LINE UI payloads from `channelData`.
237
+
238
+ Plain or limited channels:
239
+
240
+ - Convert presentation to text with conservative formatting.
241
+
242
+ ## Refactor steps
243
+
244
+ 1. Reapply the Discord release fix that splits `ui-colors.ts` from Carbon-backed UI and removes `DiscordUiContainer` from `extensions/discord/src/channel.ts`.
245
+ 2. Add `presentation` and `delivery` to `ReplyPayload`, outbound payload normalization, delivery summaries, and hook payloads.
246
+ 3. Add `MessagePresentation` schema and parser helpers in a narrow SDK/runtime subpath.
247
+ 4. Replace message capabilities `buttons`, `cards`, `components`, and `blocks` with semantic presentation capabilities.
248
+ 5. Add runtime outbound adapter hooks for presentation render and delivery pinning.
249
+ 6. Replace cross-context component construction with `buildCrossContextPresentation`.
250
+ 7. Delete `src/infra/outbound/channel-adapters.ts` and remove `buildCrossContextComponents` from channel plugin types.
251
+ 8. Change `maybeApplyCrossContextMarker` to attach `presentation` instead of native params.
252
+ 9. Update plugin-dispatch send paths to consume only semantic presentation and delivery metadata.
253
+ 10. Remove agent and CLI native payload params: `components`, `blocks`, `buttons`, and `card`.
254
+ 11. Remove SDK helpers that create native message-tool schemas, replacing them with presentation schema helpers.
255
+ 12. Remove UI/native envelopes from `channelData`; keep only transport metadata until each remaining field is reviewed.
256
+ 13. Migrate Discord, Slack, Telegram, Mattermost, MS Teams, Feishu, and LINE renderers.
257
+ 14. Update docs for message CLI, channel pages, plugin SDK, and capability cookbook.
258
+ 15. Run import fanout profiling for Discord and affected channel entrypoints.
259
+
260
+ Steps 1-11 and 13-14 are implemented in this refactor for the shared agent, CLI, plugin capability, and outbound adapter contracts. Step 12 remains a deeper internal cleanup pass for provider-private `channelData` transport envelopes. Step 15 remains follow-up validation if we want quantified import-fanout numbers beyond the type/test gate.
261
+
262
+ ## Tests
263
+
264
+ Add or update:
265
+
266
+ - Presentation normalization tests.
267
+ - Presentation auto-degrade tests for unsupported blocks.
268
+ - Cross-context marker tests for plugin dispatch and core delivery paths.
269
+ - Channel render matrix tests for Discord, Slack, Telegram, Mattermost, MS Teams, Feishu, LINE, and text fallback.
270
+ - Message tool schema tests proving native fields are gone.
271
+ - CLI tests proving native flags are gone.
272
+ - Discord entrypoint import-laziness regression covering Carbon.
273
+ - Delivery pin tests covering Telegram and generic fallback.
274
+
275
+ ## Open questions
276
+
277
+ - Should `delivery.pin` be implemented for Discord, Slack, MS Teams, and Feishu in the first pass, or only Telegram first?
278
+ - Should `delivery` eventually absorb existing fields such as `replyToId`, `replyToCurrent`, `silent`, and `audioAsVoice`, or stay focused on post-send behaviors?
279
+ - Should presentation support images or file references directly, or should media remain separate from UI layout for now?
280
+
281
+ ## Related
282
+
283
+ - [Channels overview](/channels)
284
+ - [Message presentation](/plugins/message-presentation)
@@ -0,0 +1,286 @@
1
+ ---
2
+ summary: "Android app (node): connection runbook + Connect/Chat/Voice/Canvas command surface"
3
+ read_when:
4
+ - Pairing or reconnecting the Android node
5
+ - Debugging Android gateway discovery or auth
6
+ - Verifying chat history parity across clients
7
+ title: "Android app"
8
+ ---
9
+
10
+ <Note>
11
+ The official Android app is available on [Google Play](https://play.google.com/store/apps/details?id=ai.openclaw.app&hl=en_IN). It is a companion node and requires a running OpenClaw Gateway. The source code is also available in the [OpenClaw repository](https://github.com/openclaw/openclaw) under `apps/android`; see [apps/android/README.md](https://github.com/openclaw/openclaw/blob/main/apps/android/README.md) for build instructions.
12
+ </Note>
13
+
14
+ ## Support snapshot
15
+
16
+ - Role: companion node app (Android does not host the Gateway).
17
+ - Gateway required: yes (run it on macOS, Linux, or Windows via WSL2).
18
+ - Install: [Google Play](https://play.google.com/store/apps/details?id=ai.openclaw.app&hl=en_IN) for the app, [Getting Started](/start/getting-started) for the Gateway, then [Pairing](/channels/pairing).
19
+ - Gateway: [Runbook](/gateway) + [Configuration](/gateway/configuration).
20
+ - Protocols: [Gateway protocol](/gateway/protocol) (nodes + control plane).
21
+
22
+ ## System control
23
+
24
+ System control (launchd/systemd) lives on the Gateway host. See [Gateway](/gateway).
25
+
26
+ ## Connection runbook
27
+
28
+ Android node app ⇄ (mDNS/NSD + WebSocket) ⇄ **Gateway**
29
+
30
+ Android connects directly to the Gateway WebSocket and uses device pairing (`role: node`).
31
+
32
+ For Tailscale or public hosts, Android requires a secure endpoint:
33
+
34
+ - Preferred: Tailscale Serve / Funnel with `https://<magicdns>` / `wss://<magicdns>`
35
+ - Also supported: any other `wss://` Gateway URL with a real TLS endpoint
36
+ - Cleartext `ws://` remains supported on private LAN addresses / `.local` hosts, plus `localhost`, `127.0.0.1`, and the Android emulator bridge (`10.0.2.2`)
37
+
38
+ ### Prerequisites
39
+
40
+ - You can run the Gateway on the "master" machine.
41
+ - Android device/emulator can reach the gateway WebSocket:
42
+ - Same LAN with mDNS/NSD, **or**
43
+ - Same Tailscale tailnet using Wide-Area Bonjour / unicast DNS-SD (see below), **or**
44
+ - Manual gateway host/port (fallback)
45
+ - Tailnet/public mobile pairing does **not** use raw tailnet IP `ws://` endpoints. Use Tailscale Serve or another `wss://` URL instead.
46
+ - You can run the CLI (`openclaw`) on the gateway machine (or via SSH).
47
+
48
+ ### 1) Start the Gateway
49
+
50
+ ```bash
51
+ openclaw gateway --port 18789 --verbose
52
+ ```
53
+
54
+ Confirm in logs you see something like:
55
+
56
+ - `listening on ws://0.0.0.0:18789`
57
+
58
+ For remote Android access over Tailscale, prefer Serve/Funnel instead of a raw tailnet bind:
59
+
60
+ ```bash
61
+ openclaw gateway --tailscale serve
62
+ ```
63
+
64
+ This gives Android a secure `wss://` / `https://` endpoint. A plain `gateway.bind: "tailnet"` setup is not enough for first-time remote Android pairing unless you also terminate TLS separately.
65
+
66
+ ### 2) Verify discovery (optional)
67
+
68
+ From the gateway machine:
69
+
70
+ ```bash
71
+ dns-sd -B _openclaw-gw._tcp local.
72
+ ```
73
+
74
+ More debugging notes: [Bonjour](/gateway/bonjour).
75
+
76
+ If you also configured a wide-area discovery domain, compare against:
77
+
78
+ ```bash
79
+ openclaw gateway discover --json
80
+ ```
81
+
82
+ That shows `local.` plus the configured wide-area domain in one pass and uses the resolved
83
+ service endpoint instead of TXT-only hints.
84
+
85
+ #### Tailnet (Vienna ⇄ London) discovery via unicast DNS-SD
86
+
87
+ Android NSD/mDNS discovery won't cross networks. If your Android node and the gateway are on different networks but connected via Tailscale, use Wide-Area Bonjour / unicast DNS-SD instead.
88
+
89
+ Discovery alone is not sufficient for tailnet/public Android pairing. The discovered route still needs a secure endpoint (`wss://` or Tailscale Serve):
90
+
91
+ 1. Set up a DNS-SD zone (example `openclaw.internal.`) on the gateway host and publish `_openclaw-gw._tcp` records.
92
+ 2. Configure Tailscale split DNS for your chosen domain pointing at that DNS server.
93
+
94
+ Details and example CoreDNS config: [Bonjour](/gateway/bonjour).
95
+
96
+ ### 3) Connect from Android
97
+
98
+ In the Android app:
99
+
100
+ - The app keeps its gateway connection alive via a **foreground service** (persistent notification).
101
+ - Open the **Connect** tab.
102
+ - Use **Setup Code** or **Manual** mode.
103
+ - If discovery is blocked, use manual host/port in **Advanced controls**. For private LAN hosts, `ws://` still works. For Tailscale/public hosts, turn on TLS and use a `wss://` / Tailscale Serve endpoint.
104
+
105
+ After the first successful pairing, Android auto-reconnects on launch:
106
+
107
+ - Manual endpoint (if enabled), otherwise
108
+ - The last discovered gateway (best-effort).
109
+
110
+ ### Presence alive beacons
111
+
112
+ After the authenticated node session connects, and when the app moves to the background while the
113
+ foreground service is still connected, Android calls `node.event` with
114
+ `event: "node.presence.alive"`. The gateway records this as `lastSeenAtMs`/`lastSeenReason` on the
115
+ paired node/device metadata only after the authenticated node device identity is known.
116
+
117
+ The app counts the beacon as successfully recorded only when the gateway response includes
118
+ `handled: true`. Older gateways may acknowledge `node.event` with `{ "ok": true }`; that response is
119
+ compatible but does not count as a durable last-seen update.
120
+
121
+ ### 4) Approve pairing (CLI)
122
+
123
+ On the gateway machine:
124
+
125
+ ```bash
126
+ openclaw devices list
127
+ openclaw devices approve <requestId>
128
+ openclaw devices reject <requestId>
129
+ ```
130
+
131
+ Pairing details: [Pairing](/channels/pairing).
132
+
133
+ Optional: if the Android node always connects from a tightly controlled subnet,
134
+ you can opt in to first-time node auto-approval with explicit CIDRs or exact IPs:
135
+
136
+ ```json5
137
+ {
138
+ gateway: {
139
+ nodes: {
140
+ pairing: {
141
+ autoApproveCidrs: ["192.168.1.0/24"],
142
+ },
143
+ },
144
+ },
145
+ }
146
+ ```
147
+
148
+ This is disabled by default. It applies only to fresh `role: node` pairing with
149
+ no requested scopes. Operator/browser pairing and any role, scope, metadata, or
150
+ public-key change still require manual approval.
151
+
152
+ ### 5) Verify the node is connected
153
+
154
+ - Via nodes status:
155
+
156
+ ```bash
157
+ openclaw nodes status
158
+ ```
159
+
160
+ - Via Gateway:
161
+
162
+ ```bash
163
+ openclaw gateway call node.list --params "{}"
164
+ ```
165
+
166
+ ### 6) Chat + history
167
+
168
+ The Android Chat tab supports session selection (default `main`, plus other existing sessions):
169
+
170
+ - History: `chat.history` (display-normalized; inline directive tags are
171
+ stripped from visible text, plain-text tool-call XML payloads (including
172
+ `<tool_call>...</tool_call>`, `<function_call>...</function_call>`,
173
+ `<tool_calls>...</tool_calls>`, `<function_calls>...</function_calls>`, and
174
+ truncated tool-call blocks) and leaked ASCII/full-width model control tokens
175
+ are stripped, pure silent-token assistant rows such as exact `NO_REPLY` /
176
+ `no_reply` are omitted, and oversized rows can be replaced with placeholders)
177
+ - Send: `chat.send`
178
+ - Push updates (best-effort): `chat.subscribe` → `event:"chat"`
179
+
180
+ ### 7) Canvas + camera
181
+
182
+ #### Gateway Canvas Host (recommended for web content)
183
+
184
+ If you want the node to show real HTML/CSS/JS that the agent can edit on disk, point the node at the Gateway canvas host.
185
+
186
+ <Note>
187
+ Nodes load canvas from the Gateway HTTP server (same port as `gateway.port`, default `18789`).
188
+ </Note>
189
+
190
+ 1. Create `~/.openclaw/workspace/canvas/index.html` on the gateway host.
191
+
192
+ 2. Navigate the node to it (LAN):
193
+
194
+ ```bash
195
+ openclaw nodes invoke --node "<Android Node>" --command canvas.navigate --params '{"url":"http://<gateway-hostname>.local:18789/__openclaw__/canvas/"}'
196
+ ```
197
+
198
+ Tailnet (optional): if both devices are on Tailscale, use a MagicDNS name or tailnet IP instead of `.local`, e.g. `http://<gateway-magicdns>:18789/__openclaw__/canvas/`.
199
+
200
+ This server injects a live-reload client into HTML and reloads on file changes.
201
+ The Gateway also serves `/__openclaw__/a2ui/`, but the Android app treats remote A2UI pages as render-only. Action-capable A2UI commands use the bundled app-owned A2UI page before applying messages.
202
+
203
+ Canvas commands (foreground only):
204
+
205
+ - `canvas.eval`, `canvas.snapshot`, `canvas.navigate` (use `{"url":""}` or `{"url":"/"}` to return to the default scaffold). `canvas.snapshot` returns `{ format, base64 }` (default `format="jpeg"`).
206
+ - A2UI: `canvas.a2ui.push`, `canvas.a2ui.reset` (`canvas.a2ui.pushJSONL` legacy alias). These commands use the bundled app-owned A2UI page for action-capable rendering.
207
+
208
+ Camera commands (foreground only; permission-gated):
209
+
210
+ - `camera.snap` (jpg)
211
+ - `camera.clip` (mp4)
212
+
213
+ See [Camera node](/nodes/camera) for parameters and CLI helpers.
214
+
215
+ ### 8) Voice + expanded Android command surface
216
+
217
+ - Voice tab: Android has two explicit capture modes. **Mic** is a manual Voice-tab session that sends each pause as a chat turn and stops when the app leaves the foreground or the user leaves the Voice tab. **Talk** is continuous Talk Mode and keeps listening until toggled off or the node disconnects.
218
+ - Talk Mode promotes the existing foreground service from `connectedDevice` to `connectedDevice|microphone` before capture starts, then demotes it when Talk Mode stops. The node service declares `FOREGROUND_SERVICE_CONNECTED_DEVICE` with `CHANGE_NETWORK_STATE`; Android 14+ also requires the `FOREGROUND_SERVICE_MICROPHONE` declaration, the `RECORD_AUDIO` runtime grant, and the microphone service type at runtime.
219
+ - By default, Android Talk uses native speech recognition, Gateway chat, and `talk.speak` through the configured gateway Talk provider. Local system TTS is used only when `talk.speak` is unavailable.
220
+ - Android Talk uses realtime Gateway relay only when `talk.realtime.mode` is `realtime` and `talk.realtime.transport` is `gateway-relay`.
221
+ - Voice wake remains disabled in the Android UX/runtime.
222
+ - Additional Android command families (availability depends on device, permissions, and user settings):
223
+ - `device.status`, `device.info`, `device.permissions`, `device.health`
224
+ - `device.apps` only when **Settings > Phone Capabilities > Installed Apps** is enabled; it lists launcher-visible apps by default.
225
+ - `notifications.list`, `notifications.actions` (see [Notification forwarding](#notification-forwarding) below)
226
+ - `photos.latest`
227
+ - `contacts.search`, `contacts.add`
228
+ - `calendar.events`, `calendar.add`
229
+ - `callLog.search`
230
+ - `sms.search`
231
+ - `motion.activity`, `motion.pedometer`
232
+
233
+ ## Assistant entrypoints
234
+
235
+ Android supports launching OpenClaw from the system assistant trigger (Google
236
+ Assistant). When configured, holding the home button or saying "Hey Google, ask
237
+ OpenClaw..." opens the app and hands the prompt into the chat composer.
238
+
239
+ This uses Android **App Actions** metadata declared in the app manifest. No
240
+ extra configuration is needed on the gateway side -- the assistant intent is
241
+ handled entirely by the Android app and forwarded as a normal chat message.
242
+
243
+ <Note>
244
+ App Actions availability depends on the device, Google Play Services version,
245
+ and whether the user has set OpenClaw as the default assistant app.
246
+ </Note>
247
+
248
+ ## Notification forwarding
249
+
250
+ Android can forward device notifications to the gateway as events. Several controls let you scope which notifications are forwarded and when.
251
+
252
+ | Key | Type | Description |
253
+ | -------------------------------- | -------------- | ------------------------------------------------------------------------------------------------- |
254
+ | `notifications.allowPackages` | string[] | Only forward notifications from these package names. If set, all other packages are ignored. |
255
+ | `notifications.denyPackages` | string[] | Never forward notifications from these package names. Applied after `allowPackages`. |
256
+ | `notifications.quietHours.start` | string (HH:mm) | Start of quiet hours window (local device time). Notifications are suppressed during this window. |
257
+ | `notifications.quietHours.end` | string (HH:mm) | End of quiet hours window. |
258
+ | `notifications.rateLimit` | number | Maximum forwarded notifications per package per minute. Excess notifications are dropped. |
259
+
260
+ The notification picker also uses safer behavior for forwarded notification events, preventing accidental forwarding of sensitive system notifications.
261
+
262
+ Example configuration:
263
+
264
+ ```json5
265
+ {
266
+ notifications: {
267
+ allowPackages: ["com.slack", "com.whatsapp"],
268
+ denyPackages: ["com.android.systemui"],
269
+ quietHours: {
270
+ start: "22:00",
271
+ end: "07:00",
272
+ },
273
+ rateLimit: 5,
274
+ },
275
+ }
276
+ ```
277
+
278
+ <Note>
279
+ Notification forwarding requires the Android Notification Listener permission. The app prompts for this during setup.
280
+ </Note>
281
+
282
+ ## Related
283
+
284
+ - [iOS app](/platforms/ios)
285
+ - [Nodes](/nodes)
286
+ - [Android node troubleshooting](/nodes/troubleshooting)
@@ -0,0 +1,12 @@
1
+ ---
2
+ summary: "Redirect to /install/digitalocean"
3
+ title: "DigitalOcean (platform)"
4
+ redirect: /install/digitalocean
5
+ ---
6
+
7
+ This page has moved to [DigitalOcean](/install/digitalocean).
8
+
9
+ ## Related
10
+
11
+ - [Install overview](/install)
12
+ - [VPS hosting](/vps)
@@ -0,0 +1,109 @@
1
+ ---
2
+ summary: "Run the OpenClaw Gateway on EasyRunner with Podman and Caddy"
3
+ read_when:
4
+ - Deploying OpenClaw on EasyRunner
5
+ - Running the Gateway behind EasyRunner's Caddy proxy
6
+ - Choosing persistent volumes and auth for a hosted Gateway
7
+ title: "EasyRunner"
8
+ ---
9
+
10
+ EasyRunner can host the OpenClaw Gateway as a small containerized app behind its
11
+ Caddy proxy. This guide assumes an EasyRunner host that runs Podman-compatible
12
+ Compose apps and exposes HTTPS through Caddy.
13
+
14
+ ## Before you begin
15
+
16
+ - An EasyRunner server with a domain routed to it.
17
+ - A built or published OpenClaw container image.
18
+ - A persistent config volume for `/home/node/.openclaw`.
19
+ - A persistent workspace volume for `/workspace`.
20
+ - A strong Gateway token or password.
21
+
22
+ Keep device auth enabled when possible. If your reverse proxy deployment cannot
23
+ carry device identity correctly, fix trusted-proxy settings first; use
24
+ dangerous auth bypasses only for a fully private, operator-controlled network.
25
+
26
+ ## Compose app
27
+
28
+ Create an EasyRunner app with a Compose file shaped like this:
29
+
30
+ ```yaml
31
+ services:
32
+ openclaw:
33
+ image: ghcr.io/openclaw/openclaw:latest
34
+ restart: unless-stopped
35
+ environment:
36
+ OPENCLAW_GATEWAY_TOKEN: ${OPENCLAW_GATEWAY_TOKEN}
37
+ OPENCLAW_HOME: /home/node
38
+ OPENCLAW_STATE_DIR: /home/node/.openclaw
39
+ OPENCLAW_CONFIG_PATH: /home/node/.openclaw/openclaw.json
40
+ OPENCLAW_WORKSPACE_DIR: /workspace
41
+ volumes:
42
+ - openclaw-config:/home/node/.openclaw
43
+ - openclaw-workspace:/workspace
44
+ labels:
45
+ caddy: openclaw.example.com
46
+ caddy.reverse_proxy: "{{upstreams 1455}}"
47
+ command: ["openclaw", "gateway", "--bind", "lan", "--port", "1455"]
48
+
49
+ volumes:
50
+ openclaw-config:
51
+ openclaw-workspace:
52
+ ```
53
+
54
+ Replace `openclaw.example.com` with your Gateway hostname. Store
55
+ `OPENCLAW_GATEWAY_TOKEN` in EasyRunner's secret/environment manager instead of
56
+ committing it to the app definition.
57
+
58
+ ## Configure OpenClaw
59
+
60
+ Inside the persistent config volume, keep the Gateway reachable only through
61
+ the proxy and require auth:
62
+
63
+ ```json5
64
+ {
65
+ gateway: {
66
+ bind: "lan",
67
+ port: 1455,
68
+ auth: {
69
+ token: "${OPENCLAW_GATEWAY_TOKEN}",
70
+ },
71
+ },
72
+ }
73
+ ```
74
+
75
+ If Caddy terminates TLS for the Gateway, configure trusted proxy settings for
76
+ the exact proxy path rather than disabling auth checks globally. See
77
+ [Trusted proxy auth](/gateway/trusted-proxy-auth).
78
+
79
+ ## Verify
80
+
81
+ From your workstation:
82
+
83
+ ```bash
84
+ openclaw gateway probe --url https://openclaw.example.com --token <token>
85
+ openclaw gateway status --url https://openclaw.example.com --token <token>
86
+ ```
87
+
88
+ From the EasyRunner host, check the app logs for a listening Gateway and no
89
+ startup SecretRef, plugin, or channel auth failures.
90
+
91
+ ## Updates and backups
92
+
93
+ - Pull or build the new OpenClaw image, then redeploy the EasyRunner app.
94
+ - Back up the `openclaw-config` volume before updates.
95
+ - Back up `openclaw-workspace` if agents write durable project data there.
96
+ - Run `openclaw doctor` after major updates to catch config migrations and
97
+ service warnings.
98
+
99
+ ## Troubleshooting
100
+
101
+ - `gateway probe` cannot connect: confirm the Caddy hostname points at the app
102
+ and that the container listens on `0.0.0.0:1455`.
103
+ - Auth fails: rotate the token in EasyRunner secrets and the local client
104
+ command together.
105
+ - Files are root-owned after restore: repair the mounted volumes so the
106
+ container user can write `/home/node/.openclaw` and `/workspace`.
107
+ - Browser or channel plugins fail: check whether the required external
108
+ binaries, network egress, and mounted credentials are available inside the
109
+ container.