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,230 @@
1
+ ---
2
+ summary: "Agent workspace: location, layout, and backup strategy"
3
+ read_when:
4
+ - You need to explain the agent workspace or its file layout
5
+ - You want to back up or migrate an agent workspace
6
+ title: "Agent workspace"
7
+ sidebarTitle: "Agent workspace"
8
+ ---
9
+
10
+ The workspace is the agent's home. It is the only working directory used for file tools and for workspace context. Keep it private and treat it as memory.
11
+
12
+ This is separate from `~/.openclaw/`, which stores config, credentials, and sessions.
13
+
14
+ <Warning>
15
+ The workspace is the **default cwd**, not a hard sandbox. Tools resolve relative paths against the workspace, but absolute paths can still reach elsewhere on the host unless sandboxing is enabled. If you need isolation, use [`agents.defaults.sandbox`](/gateway/sandboxing) (and/or per-agent sandbox config).
16
+
17
+ When sandboxing is enabled and `workspaceAccess` is not `"rw"`, tools operate inside a sandbox workspace under `~/.openclaw/sandboxes`, not your host workspace.
18
+ </Warning>
19
+
20
+ ## Default location
21
+
22
+ - Default: `~/.openclaw/workspace`
23
+ - If `OPENCLAW_PROFILE` is set and not `"default"`, the default becomes `~/.openclaw/workspace-<profile>`.
24
+ - Override in `~/.openclaw/openclaw.json`:
25
+
26
+ ```json5
27
+ {
28
+ agents: {
29
+ defaults: {
30
+ workspace: "~/.openclaw/workspace",
31
+ },
32
+ },
33
+ }
34
+ ```
35
+
36
+ `openclaw onboard`, `openclaw configure`, or `openclaw setup` will create the workspace and seed the bootstrap files if they are missing.
37
+
38
+ <Note>
39
+ Sandbox seed copies only accept regular in-workspace files; symlink/hardlink aliases that resolve outside the source workspace are ignored.
40
+ </Note>
41
+
42
+ If you already manage the workspace files yourself, you can disable bootstrap file creation:
43
+
44
+ ```json5
45
+ { agents: { defaults: { skipBootstrap: true } } }
46
+ ```
47
+
48
+ ## Extra workspace folders
49
+
50
+ Older installs may have created `~/openclaw`. Keeping multiple workspace directories around can cause confusing auth or state drift, because only one workspace is active at a time.
51
+
52
+ <Note>
53
+ **Recommendation:** keep a single active workspace. If you no longer use the extra folders, archive or move them to Trash (for example `trash ~/openclaw`). If you intentionally keep multiple workspaces, make sure `agents.defaults.workspace` points to the active one.
54
+
55
+ `openclaw doctor` warns when it detects extra workspace directories.
56
+ </Note>
57
+
58
+ ## Workspace file map
59
+
60
+ These are the standard files OpenClaw expects inside the workspace:
61
+
62
+ <AccordionGroup>
63
+ <Accordion title="AGENTS.md - operating instructions">
64
+ Operating instructions for the agent and how it should use memory. Loaded at the start of every session. Good place for rules, priorities, and "how to behave" details.
65
+ </Accordion>
66
+ <Accordion title="SOUL.md - persona and tone">
67
+ Persona, tone, and boundaries. Loaded every session. Guide: [SOUL.md personality guide](/concepts/soul).
68
+ </Accordion>
69
+ <Accordion title="USER.md - who the user is">
70
+ Who the user is and how to address them. Loaded every session.
71
+ </Accordion>
72
+ <Accordion title="IDENTITY.md - name, vibe, emoji">
73
+ The agent's name, vibe, and emoji. Created/updated during the bootstrap ritual.
74
+ </Accordion>
75
+ <Accordion title="TOOLS.md - local tool conventions">
76
+ Notes about your local tools and conventions. Does not control tool availability; it is only guidance.
77
+ </Accordion>
78
+ <Accordion title="HEARTBEAT.md - heartbeat checklist">
79
+ Optional tiny checklist for heartbeat runs. Keep it short to avoid token burn.
80
+ </Accordion>
81
+ <Accordion title="BOOT.md - startup checklist">
82
+ Optional startup checklist run automatically on gateway restart (when [internal hooks](/automation/hooks) are enabled). Keep it short; use the message tool for outbound sends.
83
+ </Accordion>
84
+ <Accordion title="BOOTSTRAP.md - first-run ritual">
85
+ One-time first-run ritual. Only created for a brand-new workspace. Delete it after the ritual is complete.
86
+ </Accordion>
87
+ <Accordion title="memory/YYYY-MM-DD.md - daily memory log">
88
+ Daily memory log (one file per day). Recommended to read today + yesterday on session start.
89
+ </Accordion>
90
+ <Accordion title="MEMORY.md - curated long-term memory (optional)">
91
+ Curated long-term memory: durable facts, preferences, decisions, and short summaries. Keep detailed logs in `memory/YYYY-MM-DD.md` so memory tools can retrieve them on demand without injecting them into every prompt. Only load `MEMORY.md` in the main, private session (not shared/group contexts). See [Memory](/concepts/memory) for the workflow and automatic memory flush.
92
+ </Accordion>
93
+ <Accordion title="skills/ - workspace skills (optional)">
94
+ Workspace-specific skills. Highest-precedence skill location for that workspace. Overrides project agent skills, personal agent skills, managed skills, bundled skills, and `skills.load.extraDirs` when names collide.
95
+ </Accordion>
96
+ <Accordion title="canvas/ - Canvas UI files (optional)">
97
+ Canvas UI files for node displays (for example `canvas/index.html`).
98
+ </Accordion>
99
+ </AccordionGroup>
100
+
101
+ <Note>
102
+ If any bootstrap file is missing, OpenClaw injects a "missing file" marker into the session and continues. Large bootstrap files are truncated when injected; adjust limits with `agents.defaults.bootstrapMaxChars` (default: 20000) and `agents.defaults.bootstrapTotalMaxChars` (default: 60000). `openclaw setup` can recreate missing defaults without overwriting existing files.
103
+ </Note>
104
+
105
+ ## What is NOT in the workspace
106
+
107
+ These live under `~/.openclaw/` and should NOT be committed to the workspace repo:
108
+
109
+ - `~/.openclaw/openclaw.json` (config)
110
+ - `~/.openclaw/agents/<agentId>/agent/auth-profiles.json` (model auth profiles: OAuth + API keys)
111
+ - `~/.openclaw/agents/<agentId>/agent/codex-home/` (per-agent Codex runtime account, config, skills, plugins, and native thread state)
112
+ - `~/.openclaw/credentials/` (channel/provider state plus legacy OAuth import data)
113
+ - `~/.openclaw/agents/<agentId>/sessions/` (session transcripts + metadata)
114
+ - `~/.openclaw/skills/` (managed skills)
115
+
116
+ If you need to migrate sessions or config, copy them separately and keep them out of version control.
117
+
118
+ ## Git backup (recommended, private)
119
+
120
+ Treat the workspace as private memory. Put it in a **private** git repo so it is backed up and recoverable.
121
+
122
+ Run these steps on the machine where the Gateway runs (that is where the workspace lives).
123
+
124
+ <Steps>
125
+ <Step title="Initialize the repo">
126
+ If git is installed, brand-new workspaces are initialized automatically. If this workspace is not already a repo, run:
127
+
128
+ ```bash
129
+ cd ~/.openclaw/workspace
130
+ git init
131
+ git add AGENTS.md SOUL.md TOOLS.md IDENTITY.md USER.md HEARTBEAT.md memory/
132
+ git commit -m "Add agent workspace"
133
+ ```
134
+
135
+ </Step>
136
+ <Step title="Add a private remote">
137
+ <Tabs>
138
+ <Tab title="GitHub web UI">
139
+ 1. Create a new **private** repository on GitHub.
140
+ 2. Do not initialize with a README (avoids merge conflicts).
141
+ 3. Copy the HTTPS remote URL.
142
+ 4. Add the remote and push:
143
+
144
+ ```bash
145
+ git branch -M main
146
+ git remote add origin <https-url>
147
+ git push -u origin main
148
+ ```
149
+ </Tab>
150
+ <Tab title="GitHub CLI (gh)">
151
+ ```bash
152
+ gh auth login
153
+ gh repo create openclaw-workspace --private --source . --remote origin --push
154
+ ```
155
+ </Tab>
156
+ <Tab title="GitLab web UI">
157
+ 1. Create a new **private** repository on GitLab.
158
+ 2. Do not initialize with a README (avoids merge conflicts).
159
+ 3. Copy the HTTPS remote URL.
160
+ 4. Add the remote and push:
161
+
162
+ ```bash
163
+ git branch -M main
164
+ git remote add origin <https-url>
165
+ git push -u origin main
166
+ ```
167
+ </Tab>
168
+ </Tabs>
169
+
170
+ </Step>
171
+ <Step title="Ongoing updates">
172
+ ```bash
173
+ git status
174
+ git add .
175
+ git commit -m "Update memory"
176
+ git push
177
+ ```
178
+ </Step>
179
+ </Steps>
180
+
181
+ ## Do not commit secrets
182
+
183
+ <Warning>
184
+ Even in a private repo, avoid storing secrets in the workspace:
185
+
186
+ - API keys, OAuth tokens, passwords, or private credentials.
187
+ - Anything under `~/.openclaw/`.
188
+ - Raw dumps of chats or sensitive attachments.
189
+
190
+ If you must store sensitive references, use placeholders and keep the real secret elsewhere (password manager, environment variables, or `~/.openclaw/`).
191
+ </Warning>
192
+
193
+ Suggested `.gitignore` starter:
194
+
195
+ ```gitignore
196
+ .DS_Store
197
+ .env
198
+ **/*.key
199
+ **/*.pem
200
+ **/secrets*
201
+ ```
202
+
203
+ ## Moving the workspace to a new machine
204
+
205
+ <Steps>
206
+ <Step title="Clone the repo">
207
+ Clone the repo to the desired path (default `~/.openclaw/workspace`).
208
+ </Step>
209
+ <Step title="Update config">
210
+ Set `agents.defaults.workspace` to that path in `~/.openclaw/openclaw.json`.
211
+ </Step>
212
+ <Step title="Seed missing files">
213
+ Run `openclaw setup --workspace <path>` to seed any missing files.
214
+ </Step>
215
+ <Step title="Copy sessions (optional)">
216
+ If you need sessions, copy `~/.openclaw/agents/<agentId>/sessions/` from the old machine separately.
217
+ </Step>
218
+ </Steps>
219
+
220
+ ## Advanced notes
221
+
222
+ - Multi-agent routing can use different workspaces per agent. See [Channel routing](/channels/channel-routing) for routing configuration.
223
+ - If `agents.defaults.sandbox` is enabled, non-main sessions can use per-session sandbox workspaces under `agents.defaults.sandbox.workspaceRoot`.
224
+
225
+ ## Related
226
+
227
+ - [Heartbeat](/gateway/heartbeat) - HEARTBEAT.md workspace file
228
+ - [Sandboxing](/gateway/sandboxing) - workspace access in sandboxed environments
229
+ - [Session](/concepts/session) - session storage paths
230
+ - [Standing orders](/automation/standing-orders) - persistent instructions in workspace files
@@ -0,0 +1,142 @@
1
+ ---
2
+ summary: "Agent runtime, workspace contract, and session bootstrap"
3
+ read_when:
4
+ - Changing agent runtime, workspace bootstrap, or session behavior
5
+ title: "Agent runtime"
6
+ ---
7
+
8
+ OpenClaw runs a **single embedded agent runtime** - one agent process per
9
+ Gateway, with its own workspace, bootstrap files, and session store. This page
10
+ covers that runtime contract: what the workspace must contain, which files get
11
+ injected, and how sessions bootstrap against it.
12
+
13
+ ## Workspace (required)
14
+
15
+ OpenClaw uses a single agent workspace directory (`agents.defaults.workspace`) as the agent's **only** working directory (`cwd`) for tools and context.
16
+
17
+ Recommended: use `openclaw setup` to create `~/.openclaw/openclaw.json` if missing and initialize the workspace files.
18
+
19
+ Full workspace layout + backup guide: [Agent workspace](/concepts/agent-workspace)
20
+
21
+ If `agents.defaults.sandbox` is enabled, non-main sessions can override this with
22
+ per-session workspaces under `agents.defaults.sandbox.workspaceRoot` (see
23
+ [Gateway configuration](/gateway/configuration)).
24
+
25
+ ## Bootstrap files (injected)
26
+
27
+ Inside `agents.defaults.workspace`, OpenClaw expects these user-editable files:
28
+
29
+ - `AGENTS.md` - operating instructions + "memory"
30
+ - `SOUL.md` - persona, boundaries, tone
31
+ - `TOOLS.md` - user-maintained tool notes (e.g. `imsg`, `sag`, conventions)
32
+ - `BOOTSTRAP.md` - one-time first-run ritual (deleted after completion)
33
+ - `IDENTITY.md` - agent name/vibe/emoji
34
+ - `USER.md` - user profile + preferred address
35
+
36
+ On the first turn of a new session, OpenClaw injects the contents of these files into the system prompt's Project Context.
37
+
38
+ Blank files are skipped. Large files are trimmed and truncated with a marker so prompts stay lean (read the file for full content).
39
+
40
+ If a file is missing, OpenClaw injects a single "missing file" marker line (and `openclaw setup` will create a safe default template).
41
+
42
+ `BOOTSTRAP.md` is only created for a **brand new workspace** (no other bootstrap files present). While it is pending, OpenClaw keeps it in Project Context and adds system-prompt bootstrap guidance for the initial ritual instead of copying it into the user message. If you delete it after completing the ritual, it should not be recreated on later restarts.
43
+
44
+ After a workspace has been observed, OpenClaw also keeps a state-dir attestation marker for the workspace path. If a recently attested workspace disappears or is wiped, startup refuses to silently re-seed `BOOTSTRAP.md`; restore the workspace or use a full onboard reset so the workspace and marker are cleared together.
45
+
46
+ To disable bootstrap file creation entirely (for pre-seeded workspaces), set:
47
+
48
+ ```json5
49
+ { agents: { defaults: { skipBootstrap: true } } }
50
+ ```
51
+
52
+ ## Built-in tools
53
+
54
+ Core tools (read/exec/edit/write and related system tools) are always available,
55
+ subject to tool policy. `apply_patch` is optional and gated by
56
+ `tools.exec.applyPatch`. `TOOLS.md` does **not** control which tools exist; it's
57
+ guidance for how _you_ want them used.
58
+
59
+ ## Skills
60
+
61
+ OpenClaw loads skills from these locations (highest precedence first):
62
+
63
+ - Workspace: `<workspace>/skills`
64
+ - Project agent skills: `<workspace>/.agents/skills`
65
+ - Personal agent skills: `~/.agents/skills`
66
+ - Managed/local: `~/.openclaw/skills`
67
+ - Bundled (shipped with the install)
68
+ - Extra skill folders: `skills.load.extraDirs`
69
+
70
+ Skill roots can contain grouped folders such as
71
+ `<workspace>/skills/personal/foo/SKILL.md`; the skill is still exposed by its
72
+ flat frontmatter name, for example `foo`.
73
+
74
+ Skills can be gated by config/env (see `skills` in [Gateway configuration](/gateway/configuration)).
75
+
76
+ ## Runtime boundaries
77
+
78
+ The embedded agent runtime is OpenClaw-owned: model discovery, tool wiring,
79
+ prompt assembly, session management, and channel delivery share one integrated
80
+ runtime surface.
81
+
82
+ ## Sessions
83
+
84
+ Session transcripts are stored as JSONL at:
85
+
86
+ - `~/.openclaw/agents/<agentId>/sessions/<SessionId>.jsonl`
87
+
88
+ The session ID is stable and chosen by OpenClaw.
89
+ Legacy session folders from other tools are not read.
90
+
91
+ ## Steering while streaming
92
+
93
+ Inbound prompts that arrive mid-run are steered into the current run by default.
94
+ Steering is delivered **after the current assistant turn finishes executing its
95
+ tool calls**, before the next LLM call, and no longer skips remaining tool calls
96
+ from the current assistant message.
97
+
98
+ `/queue steer` is the default active-run behavior. `/queue followup` and
99
+ `/queue collect` make messages wait for a later turn instead of steering.
100
+ `/queue interrupt` aborts the active run instead. See [Queue](/concepts/queue)
101
+ and [Steering queue](/concepts/queue-steering) for queue and boundary behavior.
102
+
103
+ Block streaming sends completed assistant blocks as soon as they finish; it is
104
+ **off by default** (`agents.defaults.blockStreamingDefault: "off"`).
105
+ Tune the boundary via `agents.defaults.blockStreamingBreak` (`text_end` vs `message_end`; defaults to text_end).
106
+ Control soft block chunking with `agents.defaults.blockStreamingChunk` (defaults to
107
+ 800-1200 chars; prefers paragraph breaks, then newlines; sentences last).
108
+ Coalesce streamed chunks with `agents.defaults.blockStreamingCoalesce` to reduce
109
+ single-line spam (idle-based merging before send). Non-Telegram channels require
110
+ explicit `*.blockStreaming: true` to enable block replies.
111
+ Verbose tool summaries are emitted at tool start (no debounce); Control UI
112
+ streams tool output via agent events when available.
113
+ More details: [Streaming + chunking](/concepts/streaming).
114
+
115
+ ## Model refs
116
+
117
+ Model refs in config (for example `agents.defaults.model` and `agents.defaults.models`) are parsed by splitting on the **first** `/`.
118
+
119
+ - Use `provider/model` when configuring models.
120
+ - If the model ID itself contains `/` (OpenRouter-style), include the provider prefix (example: `openrouter/moonshotai/kimi-k2`).
121
+ - If you omit the provider, OpenClaw tries an alias first, then a unique
122
+ configured-provider match for that exact model id, and only then falls back
123
+ to the configured default provider. If that provider no longer exposes the
124
+ configured default model, OpenClaw falls back to the first configured
125
+ provider/model instead of surfacing a stale removed-provider default.
126
+
127
+ ## Configuration (minimal)
128
+
129
+ At minimum, set:
130
+
131
+ - `agents.defaults.workspace`
132
+ - `channels.whatsapp.allowFrom` (strongly recommended)
133
+
134
+ ---
135
+
136
+ _Next: [Group Chats](/channels/group-messages)_ 🦞
137
+
138
+ ## Related
139
+
140
+ - [Agent workspace](/concepts/agent-workspace)
141
+ - [Multi-agent routing](/concepts/multi-agent)
142
+ - [Session management](/concepts/session)
@@ -0,0 +1,154 @@
1
+ ---
2
+ summary: "WebSocket gateway architecture, components, and client flows"
3
+ read_when:
4
+ - Working on gateway protocol, clients, or transports
5
+ title: "Gateway architecture"
6
+ ---
7
+
8
+ ## Overview
9
+
10
+ - A single long-lived **Gateway** owns all messaging surfaces (WhatsApp via
11
+ Baileys, Telegram via grammY, Slack, Discord, Signal, iMessage, WebChat).
12
+ - Control-plane clients (macOS app, CLI, web UI, automations) connect to the
13
+ Gateway over **WebSocket** on the configured bind host (default
14
+ `127.0.0.1:18789`).
15
+ - **Nodes** (macOS/iOS/Android/headless) also connect over **WebSocket**, but
16
+ declare `role: node` with explicit caps/commands.
17
+ - One Gateway per host; it is the only place that opens a WhatsApp session.
18
+ - The **canvas host** is served by the Gateway HTTP server under:
19
+ - `/__openclaw__/canvas/` (agent-editable HTML/CSS/JS)
20
+ - `/__openclaw__/a2ui/` (A2UI host)
21
+ It uses the same port as the Gateway (default `18789`).
22
+
23
+ ## Components and flows
24
+
25
+ ### Gateway (daemon)
26
+
27
+ - Maintains provider connections.
28
+ - Exposes a typed WS API (requests, responses, server-push events).
29
+ - Validates inbound frames against JSON Schema.
30
+ - Emits events like `agent`, `chat`, `presence`, `health`, `heartbeat`, `cron`.
31
+
32
+ ### Clients (mac app / CLI / web admin)
33
+
34
+ - One WS connection per client.
35
+ - Send requests (`health`, `status`, `send`, `agent`, `system-presence`).
36
+ - Subscribe to events (`tick`, `agent`, `presence`, `shutdown`).
37
+
38
+ ### Nodes (macOS / iOS / Android / headless)
39
+
40
+ - Connect to the **same WS server** with `role: node`.
41
+ - Provide a device identity in `connect`; pairing is **device-based** (role `node`) and
42
+ approval lives in the device pairing store.
43
+ - Expose commands like `canvas.*`, `camera.*`, `screen.record`, `location.get`.
44
+
45
+ Protocol details:
46
+
47
+ - [Gateway protocol](/gateway/protocol)
48
+
49
+ ### WebChat
50
+
51
+ - Static UI that uses the Gateway WS API for chat history and sends.
52
+ - In remote setups, connects through the same SSH/Tailscale tunnel as other
53
+ clients.
54
+
55
+ ## Connection lifecycle (single client)
56
+
57
+ ```mermaid
58
+ sequenceDiagram
59
+ participant Client
60
+ participant Gateway
61
+
62
+ Client->>Gateway: req:connect
63
+ Gateway-->>Client: res (ok)
64
+ Note right of Gateway: or res error + close
65
+ Note left of Client: payload=hello-ok<br>snapshot: presence + health
66
+
67
+ Gateway-->>Client: event:presence
68
+ Gateway-->>Client: event:tick
69
+
70
+ Client->>Gateway: req:agent
71
+ Gateway-->>Client: res:agent<br>ack {runId, status:"accepted"}
72
+ Gateway-->>Client: event:agent<br>(streaming)
73
+ Gateway-->>Client: res:agent<br>final {runId, status, summary}
74
+ ```
75
+
76
+ ## Wire protocol (summary)
77
+
78
+ - Transport: WebSocket, text frames with JSON payloads.
79
+ - First frame **must** be `connect`.
80
+ - After handshake:
81
+ - Requests: `{type:"req", id, method, params}` → `{type:"res", id, ok, payload|error}`
82
+ - Events: `{type:"event", event, payload, seq?, stateVersion?}`
83
+ - `hello-ok.features.methods` / `events` are discovery metadata, not a
84
+ generated dump of every callable helper route.
85
+ - Shared-secret auth uses `connect.params.auth.token` or
86
+ `connect.params.auth.password`, depending on the configured gateway auth mode.
87
+ - Identity-bearing modes such as Tailscale Serve
88
+ (`gateway.auth.allowTailscale: true`) or non-loopback
89
+ `gateway.auth.mode: "trusted-proxy"` satisfy auth from request headers
90
+ instead of `connect.params.auth.*`.
91
+ - Private-ingress `gateway.auth.mode: "none"` disables shared-secret auth
92
+ entirely; keep that mode off public/untrusted ingress.
93
+ - Idempotency keys are required for side-effecting methods (`send`, `agent`) to
94
+ safely retry; the server keeps a short-lived dedupe cache.
95
+ - Nodes must include `role: "node"` plus caps/commands/permissions in `connect`.
96
+
97
+ ## Pairing + local trust
98
+
99
+ - All WS clients (operators + nodes) include a **device identity** on `connect`.
100
+ - New device IDs require pairing approval; the Gateway issues a **device token**
101
+ for subsequent connects.
102
+ - Direct local loopback connects can be auto-approved to keep same-host UX
103
+ smooth.
104
+ - OpenClaw also has a narrow backend/container-local self-connect path for
105
+ trusted shared-secret helper flows.
106
+ - Tailnet and LAN connects, including same-host tailnet binds, still require
107
+ explicit pairing approval.
108
+ - All connects must sign the `connect.challenge` nonce.
109
+ - Signature payload `v3` also binds `platform` + `deviceFamily`; the gateway
110
+ pins paired metadata on reconnect and requires repair pairing for metadata
111
+ changes.
112
+ - **Non-local** connects still require explicit approval.
113
+ - Gateway auth (`gateway.auth.*`) still applies to **all** connections, local or
114
+ remote.
115
+
116
+ Details: [Gateway protocol](/gateway/protocol), [Pairing](/channels/pairing),
117
+ [Security](/gateway/security).
118
+
119
+ ## Protocol typing and codegen
120
+
121
+ - TypeBox schemas define the protocol.
122
+ - JSON Schema is generated from those schemas.
123
+ - Swift models are generated from the JSON Schema.
124
+
125
+ ## Remote access
126
+
127
+ - Preferred: Tailscale or VPN.
128
+ - Alternative: SSH tunnel
129
+
130
+ ```bash
131
+ ssh -N -L 18789:127.0.0.1:18789 user@host
132
+ ```
133
+
134
+ - The same handshake + auth token apply over the tunnel.
135
+ - TLS + optional pinning can be enabled for WS in remote setups.
136
+
137
+ ## Operations snapshot
138
+
139
+ - Start: `openclaw gateway` (foreground, logs to stdout).
140
+ - Health: `health` over WS (also included in `hello-ok`).
141
+ - Supervision: launchd/systemd for auto-restart.
142
+
143
+ ## Invariants
144
+
145
+ - Exactly one Gateway controls a single Baileys session per host.
146
+ - Handshake is mandatory; any non-JSON or non-connect first frame is a hard close.
147
+ - Events are not replayed; clients must refresh on gaps.
148
+
149
+ ## Related
150
+
151
+ - [Agent Loop](/concepts/agent-loop) — detailed agent execution cycle
152
+ - [Gateway Protocol](/gateway/protocol) — WebSocket protocol contract
153
+ - [Queue](/concepts/queue) — command queue and concurrency
154
+ - [Security](/gateway/security) — trust model and hardening
@@ -0,0 +1,145 @@
1
+ ---
2
+ summary: "Move one OpenClaw session's reply route between linked chat channels"
3
+ title: "Channel docking"
4
+ read_when:
5
+ - You want replies for one active session to move from Telegram to Discord, Slack, Mattermost, or another linked channel
6
+ - You are configuring session.identityLinks for cross-channel direct messages
7
+ - A /dock command says the sender is not linked or no active session exists
8
+ ---
9
+
10
+ Channel docking is call forwarding for one OpenClaw session.
11
+
12
+ It keeps the same conversation context, but changes where future replies for
13
+ that session are delivered.
14
+
15
+ ## Example
16
+
17
+ Alice can message OpenClaw on Telegram and Discord:
18
+
19
+ ```json5
20
+ {
21
+ session: {
22
+ identityLinks: {
23
+ alice: ["telegram:123", "discord:456"],
24
+ },
25
+ },
26
+ }
27
+ ```
28
+
29
+ If Alice sends this from Telegram:
30
+
31
+ ```text
32
+ /dock_discord
33
+ ```
34
+
35
+ OpenClaw keeps the current session context and changes the reply route:
36
+
37
+ | Before docking | After `/dock_discord` |
38
+ | ---------------------------- | --------------------------- |
39
+ | Replies go to Telegram `123` | Replies go to Discord `456` |
40
+
41
+ The session is not recreated. The transcript history stays attached to the
42
+ same session.
43
+
44
+ ## Why use it
45
+
46
+ Use docking when a task starts in one chat app but the next replies should land
47
+ somewhere else.
48
+
49
+ Common flow:
50
+
51
+ 1. Start an agent task from Telegram.
52
+ 2. Move to Discord where you are coordinating work.
53
+ 3. Send `/dock_discord` from the Telegram session.
54
+ 4. Keep the same OpenClaw session, but receive future replies in Discord.
55
+
56
+ ## Required config
57
+
58
+ Docking requires `session.identityLinks`. The source sender and target peer
59
+ must be in the same identity group:
60
+
61
+ ```json5
62
+ {
63
+ session: {
64
+ identityLinks: {
65
+ alice: ["telegram:123", "discord:456", "slack:U123"],
66
+ },
67
+ },
68
+ }
69
+ ```
70
+
71
+ The values are channel-prefixed peer ids:
72
+
73
+ | Value | Meaning |
74
+ | -------------- | ---------------------------- |
75
+ | `telegram:123` | Telegram sender id `123` |
76
+ | `discord:456` | Discord direct peer id `456` |
77
+ | `slack:U123` | Slack user id `U123` |
78
+
79
+ The canonical key (`alice` above) is only the shared identity group name. Dock
80
+ commands use the channel-prefixed values to prove that the source sender and
81
+ target peer are the same person.
82
+
83
+ ## Commands
84
+
85
+ Dock commands are generated from loaded channel plugins that support native
86
+ commands. Current bundled commands:
87
+
88
+ | Target channel | Command | Alias |
89
+ | -------------- | ------------------ | ------------------ |
90
+ | Discord | `/dock-discord` | `/dock_discord` |
91
+ | Mattermost | `/dock-mattermost` | `/dock_mattermost` |
92
+ | Slack | `/dock-slack` | `/dock_slack` |
93
+ | Telegram | `/dock-telegram` | `/dock_telegram` |
94
+
95
+ The underscore aliases are useful on native command surfaces such as Telegram.
96
+
97
+ ## What changes
98
+
99
+ Docking updates the active session delivery fields:
100
+
101
+ | Session field | Example after `/dock_discord` |
102
+ | --------------- | ---------------------------------------- |
103
+ | `lastChannel` | `discord` |
104
+ | `lastTo` | `456` |
105
+ | `lastAccountId` | the target channel account, or `default` |
106
+
107
+ Those fields are persisted in the session store and used by later reply
108
+ delivery for that session.
109
+
110
+ ## What does not change
111
+
112
+ Docking does not:
113
+
114
+ - create channel accounts
115
+ - connect a new Discord, Telegram, Slack, or Mattermost bot
116
+ - grant access to a user
117
+ - bypass channel allowlists or DM policies
118
+ - move transcript history to another session
119
+ - make unrelated users share a session
120
+
121
+ It only changes the delivery route for the current session.
122
+
123
+ ## Troubleshooting
124
+
125
+ **The command says the sender is not linked.**
126
+
127
+ Add both the current sender and the target peer to the same
128
+ `session.identityLinks` group. For example, if Telegram sender `123` should dock
129
+ to Discord peer `456`, include both `telegram:123` and `discord:456`.
130
+
131
+ **The command says no active session exists.**
132
+
133
+ Dock from an existing direct-chat session. The command needs an active session
134
+ entry so it can persist the new route.
135
+
136
+ **Replies still go to the old channel.**
137
+
138
+ Check that the command replied with a success message, and confirm the target
139
+ peer id matches the id used by that channel. Docking only changes the active
140
+ session route; another session may still route elsewhere.
141
+
142
+ **I need to switch back.**
143
+
144
+ Send the matching command for the original channel, such as `/dock_telegram` or
145
+ `/dock-telegram`, from a linked sender.