durar-ai 2026.4.4

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 (571) hide show
  1. package/CHANGELOG.md +5497 -0
  2. package/LICENSE +21 -0
  3. package/README.md +614 -0
  4. package/assets/avatar-placeholder.svg +19 -0
  5. package/assets/chrome-extension/icons/icon128.png +0 -0
  6. package/assets/chrome-extension/icons/icon16.png +0 -0
  7. package/assets/chrome-extension/icons/icon32.png +0 -0
  8. package/assets/chrome-extension/icons/icon48.png +0 -0
  9. package/assets/dmg-background-small.png +0 -0
  10. package/assets/dmg-background.png +0 -0
  11. package/docs/.i18n/README.md +72 -0
  12. package/docs/.i18n/ar-navigation.json +18 -0
  13. package/docs/.i18n/de-navigation.json +18 -0
  14. package/docs/.i18n/es-navigation.json +18 -0
  15. package/docs/.i18n/fr-navigation.json +18 -0
  16. package/docs/.i18n/glossary.ar.json +5 -0
  17. package/docs/.i18n/glossary.de.json +5 -0
  18. package/docs/.i18n/glossary.es.json +5 -0
  19. package/docs/.i18n/glossary.fr.json +5 -0
  20. package/docs/.i18n/glossary.id.json +5 -0
  21. package/docs/.i18n/glossary.it.json +5 -0
  22. package/docs/.i18n/glossary.ja-JP.json +14 -0
  23. package/docs/.i18n/glossary.ko.json +5 -0
  24. package/docs/.i18n/glossary.pl.json +5 -0
  25. package/docs/.i18n/glossary.pt-BR.json +5 -0
  26. package/docs/.i18n/glossary.tr.json +5 -0
  27. package/docs/.i18n/glossary.zh-CN.json +358 -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/zh-Hans-navigation.json +544 -0
  36. package/docs/assets/install-script.svg +1 -0
  37. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  38. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  39. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  40. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  41. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  42. package/docs/assets/openclaw-logo-text-dark.png +0 -0
  43. package/docs/assets/openclaw-logo-text-dark.svg +418 -0
  44. package/docs/assets/openclaw-logo-text.png +0 -0
  45. package/docs/assets/openclaw-logo-text.svg +418 -0
  46. package/docs/assets/pixel-lobster.svg +60 -0
  47. package/docs/assets/showcase/agents-ui.jpg +0 -0
  48. package/docs/assets/showcase/bambu-cli.png +0 -0
  49. package/docs/assets/showcase/codexmonitor.png +0 -0
  50. package/docs/assets/showcase/gohome-grafana.png +0 -0
  51. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  52. package/docs/assets/showcase/oura-health.png +0 -0
  53. package/docs/assets/showcase/padel-cli.svg +11 -0
  54. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  55. package/docs/assets/showcase/papla-tts.jpg +0 -0
  56. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  57. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  58. package/docs/assets/showcase/roborock-status.svg +13 -0
  59. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  60. package/docs/assets/showcase/snag.png +0 -0
  61. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  62. package/docs/assets/showcase/wienerlinien.png +0 -0
  63. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  64. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  65. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  66. package/docs/assets/sponsors/blacksmith-light.svg +14 -0
  67. package/docs/assets/sponsors/blacksmith.svg +14 -0
  68. package/docs/assets/sponsors/convex-light.svg +16 -0
  69. package/docs/assets/sponsors/convex.svg +16 -0
  70. package/docs/assets/sponsors/github-light.svg +3 -0
  71. package/docs/assets/sponsors/github.svg +3 -0
  72. package/docs/assets/sponsors/nvidia-dark.svg +9 -0
  73. package/docs/assets/sponsors/nvidia.svg +9 -0
  74. package/docs/assets/sponsors/openai-light.svg +3 -0
  75. package/docs/assets/sponsors/openai.svg +3 -0
  76. package/docs/assets/sponsors/vercel-light.svg +5 -0
  77. package/docs/assets/sponsors/vercel.svg +5 -0
  78. package/docs/auth-credential-semantics.md +80 -0
  79. package/docs/automation/auth-monitoring.md +8 -0
  80. package/docs/automation/clawflow.md +8 -0
  81. package/docs/automation/cron-jobs.md +410 -0
  82. package/docs/automation/cron-vs-heartbeat.md +8 -0
  83. package/docs/automation/gmail-pubsub.md +8 -0
  84. package/docs/automation/hooks.md +303 -0
  85. package/docs/automation/index.md +115 -0
  86. package/docs/automation/poll.md +8 -0
  87. package/docs/automation/standing-orders.md +254 -0
  88. package/docs/automation/taskflow.md +82 -0
  89. package/docs/automation/tasks.md +323 -0
  90. package/docs/automation/troubleshooting.md +8 -0
  91. package/docs/automation/webhook.md +8 -0
  92. package/docs/brave-search.md +103 -0
  93. package/docs/channels/bluebubbles.md +435 -0
  94. package/docs/channels/broadcast-groups.md +442 -0
  95. package/docs/channels/channel-routing.md +139 -0
  96. package/docs/channels/discord.md +1254 -0
  97. package/docs/channels/feishu.md +793 -0
  98. package/docs/channels/googlechat.md +270 -0
  99. package/docs/channels/group-messages.md +84 -0
  100. package/docs/channels/groups.md +410 -0
  101. package/docs/channels/imessage.md +427 -0
  102. package/docs/channels/index.md +50 -0
  103. package/docs/channels/irc.md +252 -0
  104. package/docs/channels/line.md +225 -0
  105. package/docs/channels/location.md +56 -0
  106. package/docs/channels/matrix.md +869 -0
  107. package/docs/channels/mattermost.md +472 -0
  108. package/docs/channels/msteams.md +805 -0
  109. package/docs/channels/nextcloud-talk.md +149 -0
  110. package/docs/channels/nostr.md +252 -0
  111. package/docs/channels/pairing.md +129 -0
  112. package/docs/channels/qqbot.md +193 -0
  113. package/docs/channels/signal.md +337 -0
  114. package/docs/channels/slack.md +681 -0
  115. package/docs/channels/synology-chat.md +185 -0
  116. package/docs/channels/telegram.md +1072 -0
  117. package/docs/channels/tlon.md +290 -0
  118. package/docs/channels/troubleshooting.md +133 -0
  119. package/docs/channels/twitch.md +394 -0
  120. package/docs/channels/whatsapp.md +488 -0
  121. package/docs/channels/zalo.md +254 -0
  122. package/docs/channels/zalouser.md +195 -0
  123. package/docs/ci.md +66 -0
  124. package/docs/cli/acp.md +316 -0
  125. package/docs/cli/agent.md +57 -0
  126. package/docs/cli/agents.md +220 -0
  127. package/docs/cli/approvals.md +136 -0
  128. package/docs/cli/backup.md +84 -0
  129. package/docs/cli/browser.md +233 -0
  130. package/docs/cli/channels.md +131 -0
  131. package/docs/cli/clawbot.md +21 -0
  132. package/docs/cli/completion.md +35 -0
  133. package/docs/cli/config.md +353 -0
  134. package/docs/cli/configure.md +70 -0
  135. package/docs/cli/cron.md +167 -0
  136. package/docs/cli/daemon.md +57 -0
  137. package/docs/cli/dashboard.md +22 -0
  138. package/docs/cli/devices.md +171 -0
  139. package/docs/cli/directory.md +63 -0
  140. package/docs/cli/dns.md +48 -0
  141. package/docs/cli/docs.md +28 -0
  142. package/docs/cli/doctor.md +63 -0
  143. package/docs/cli/flows.md +18 -0
  144. package/docs/cli/gateway.md +307 -0
  145. package/docs/cli/health.md +36 -0
  146. package/docs/cli/hooks.md +337 -0
  147. package/docs/cli/index.md +1836 -0
  148. package/docs/cli/logs.md +59 -0
  149. package/docs/cli/mcp.md +505 -0
  150. package/docs/cli/memory.md +139 -0
  151. package/docs/cli/message.md +300 -0
  152. package/docs/cli/models.md +136 -0
  153. package/docs/cli/node.md +137 -0
  154. package/docs/cli/nodes.md +66 -0
  155. package/docs/cli/onboard.md +171 -0
  156. package/docs/cli/pairing.md +65 -0
  157. package/docs/cli/plugins.md +305 -0
  158. package/docs/cli/qr.md +52 -0
  159. package/docs/cli/reset.md +35 -0
  160. package/docs/cli/sandbox.md +197 -0
  161. package/docs/cli/secrets.md +197 -0
  162. package/docs/cli/security.md +86 -0
  163. package/docs/cli/sessions.md +113 -0
  164. package/docs/cli/setup.md +45 -0
  165. package/docs/cli/skills.md +59 -0
  166. package/docs/cli/status.md +35 -0
  167. package/docs/cli/system.md +71 -0
  168. package/docs/cli/tui.md +30 -0
  169. package/docs/cli/uninstall.md +39 -0
  170. package/docs/cli/update.md +113 -0
  171. package/docs/cli/voicecall.md +34 -0
  172. package/docs/cli/webhooks.md +91 -0
  173. package/docs/concepts/agent-loop.md +168 -0
  174. package/docs/concepts/agent-workspace.md +246 -0
  175. package/docs/concepts/agent.md +129 -0
  176. package/docs/concepts/architecture.md +156 -0
  177. package/docs/concepts/compaction.md +122 -0
  178. package/docs/concepts/context-engine.md +274 -0
  179. package/docs/concepts/context.md +179 -0
  180. package/docs/concepts/delegate-architecture.md +307 -0
  181. package/docs/concepts/dreaming.md +173 -0
  182. package/docs/concepts/features.md +76 -0
  183. package/docs/concepts/markdown-formatting.md +130 -0
  184. package/docs/concepts/memory-builtin.md +105 -0
  185. package/docs/concepts/memory-honcho.md +140 -0
  186. package/docs/concepts/memory-qmd.md +163 -0
  187. package/docs/concepts/memory-search.md +141 -0
  188. package/docs/concepts/memory.md +121 -0
  189. package/docs/concepts/messages.md +161 -0
  190. package/docs/concepts/model-failover.md +349 -0
  191. package/docs/concepts/model-providers.md +799 -0
  192. package/docs/concepts/models.md +255 -0
  193. package/docs/concepts/multi-agent.md +615 -0
  194. package/docs/concepts/oauth.md +225 -0
  195. package/docs/concepts/presence.md +102 -0
  196. package/docs/concepts/queue.md +89 -0
  197. package/docs/concepts/retry.md +69 -0
  198. package/docs/concepts/session-pruning.md +92 -0
  199. package/docs/concepts/session-tool.md +141 -0
  200. package/docs/concepts/session.md +116 -0
  201. package/docs/concepts/soul.md +110 -0
  202. package/docs/concepts/streaming.md +161 -0
  203. package/docs/concepts/system-prompt.md +182 -0
  204. package/docs/concepts/timezone.md +97 -0
  205. package/docs/concepts/typebox.md +307 -0
  206. package/docs/concepts/typing-indicators.md +69 -0
  207. package/docs/concepts/usage-tracking.md +59 -0
  208. package/docs/date-time.md +128 -0
  209. package/docs/debug/node-issue.md +85 -0
  210. package/docs/diagnostics/flags.md +91 -0
  211. package/docs/docs.json +1601 -0
  212. package/docs/gateway/authentication.md +218 -0
  213. package/docs/gateway/background-process.md +131 -0
  214. package/docs/gateway/bonjour.md +179 -0
  215. package/docs/gateway/bridge-protocol.md +89 -0
  216. package/docs/gateway/cli-backends.md +310 -0
  217. package/docs/gateway/configuration-examples.md +631 -0
  218. package/docs/gateway/configuration-reference.md +3618 -0
  219. package/docs/gateway/configuration.md +698 -0
  220. package/docs/gateway/discovery.md +141 -0
  221. package/docs/gateway/doctor.md +494 -0
  222. package/docs/gateway/gateway-lock.md +37 -0
  223. package/docs/gateway/health.md +61 -0
  224. package/docs/gateway/heartbeat.md +443 -0
  225. package/docs/gateway/index.md +367 -0
  226. package/docs/gateway/local-models.md +163 -0
  227. package/docs/gateway/logging.md +113 -0
  228. package/docs/gateway/multiple-gateways.md +120 -0
  229. package/docs/gateway/network-model.md +25 -0
  230. package/docs/gateway/openai-http-api.md +280 -0
  231. package/docs/gateway/openresponses-http-api.md +340 -0
  232. package/docs/gateway/openshell.md +307 -0
  233. package/docs/gateway/pairing.md +138 -0
  234. package/docs/gateway/protocol.md +588 -0
  235. package/docs/gateway/remote-gateway-readme.md +164 -0
  236. package/docs/gateway/remote.md +251 -0
  237. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +141 -0
  238. package/docs/gateway/sandboxing.md +473 -0
  239. package/docs/gateway/secrets-plan-contract.md +116 -0
  240. package/docs/gateway/secrets.md +541 -0
  241. package/docs/gateway/security/index.md +1362 -0
  242. package/docs/gateway/tailscale.md +136 -0
  243. package/docs/gateway/tools-invoke-http-api.md +161 -0
  244. package/docs/gateway/troubleshooting.md +451 -0
  245. package/docs/gateway/trusted-proxy-auth.md +399 -0
  246. package/docs/help/debugging.md +168 -0
  247. package/docs/help/environment.md +165 -0
  248. package/docs/help/faq.md +3244 -0
  249. package/docs/help/index.md +28 -0
  250. package/docs/help/scripts.md +27 -0
  251. package/docs/help/testing.md +640 -0
  252. package/docs/help/troubleshooting.md +372 -0
  253. package/docs/images/configure-model-picker-unsearchable.png +0 -0
  254. package/docs/images/feishu-step2-create-app.png +0 -0
  255. package/docs/images/feishu-step3-credentials.png +0 -0
  256. package/docs/images/feishu-step4-permissions.png +0 -0
  257. package/docs/images/feishu-step5-bot-capability.png +0 -0
  258. package/docs/images/feishu-step6-event-subscription.png +0 -0
  259. package/docs/images/feishu-verification-token.png +0 -0
  260. package/docs/images/groups-flow.svg +52 -0
  261. package/docs/images/mobile-ui-screenshot.png +0 -0
  262. package/docs/index.md +196 -0
  263. package/docs/install/ansible.md +230 -0
  264. package/docs/install/azure.md +311 -0
  265. package/docs/install/bun.md +55 -0
  266. package/docs/install/clawdock.md +106 -0
  267. package/docs/install/development-channels.md +131 -0
  268. package/docs/install/digitalocean.md +129 -0
  269. package/docs/install/docker-vm-runtime.md +142 -0
  270. package/docs/install/docker.md +412 -0
  271. package/docs/install/exe-dev.md +133 -0
  272. package/docs/install/fly.md +504 -0
  273. package/docs/install/gcp.md +412 -0
  274. package/docs/install/hetzner.md +259 -0
  275. package/docs/install/index.md +212 -0
  276. package/docs/install/installer.md +443 -0
  277. package/docs/install/kubernetes.md +192 -0
  278. package/docs/install/macos-vm.md +281 -0
  279. package/docs/install/migrating-matrix.md +349 -0
  280. package/docs/install/migrating.md +112 -0
  281. package/docs/install/nix.md +89 -0
  282. package/docs/install/node.md +144 -0
  283. package/docs/install/northflank.mdx +42 -0
  284. package/docs/install/oracle.md +158 -0
  285. package/docs/install/podman.md +210 -0
  286. package/docs/install/railway.mdx +90 -0
  287. package/docs/install/raspberry-pi.md +159 -0
  288. package/docs/install/render.mdx +165 -0
  289. package/docs/install/uninstall.md +128 -0
  290. package/docs/install/updating.md +142 -0
  291. package/docs/logging.md +389 -0
  292. package/docs/nav-tabs-underline.js +100 -0
  293. package/docs/network.md +69 -0
  294. package/docs/nodes/audio.md +191 -0
  295. package/docs/nodes/camera.md +162 -0
  296. package/docs/nodes/images.md +73 -0
  297. package/docs/nodes/index.md +408 -0
  298. package/docs/nodes/location-command.md +98 -0
  299. package/docs/nodes/media-understanding.md +432 -0
  300. package/docs/nodes/talk.md +92 -0
  301. package/docs/nodes/troubleshooting.md +123 -0
  302. package/docs/nodes/voicewake.md +66 -0
  303. package/docs/perplexity.md +181 -0
  304. package/docs/pi-dev.md +80 -0
  305. package/docs/pi.md +570 -0
  306. package/docs/platforms/android.md +244 -0
  307. package/docs/platforms/digitalocean.md +266 -0
  308. package/docs/platforms/index.md +55 -0
  309. package/docs/platforms/ios.md +223 -0
  310. package/docs/platforms/linux.md +100 -0
  311. package/docs/platforms/mac/bundled-gateway.md +75 -0
  312. package/docs/platforms/mac/canvas.md +125 -0
  313. package/docs/platforms/mac/child-process.md +69 -0
  314. package/docs/platforms/mac/dev-setup.md +107 -0
  315. package/docs/platforms/mac/health.md +34 -0
  316. package/docs/platforms/mac/icon.md +31 -0
  317. package/docs/platforms/mac/logging.md +57 -0
  318. package/docs/platforms/mac/menu-bar.md +81 -0
  319. package/docs/platforms/mac/peekaboo.md +65 -0
  320. package/docs/platforms/mac/permissions.md +50 -0
  321. package/docs/platforms/mac/remote.md +84 -0
  322. package/docs/platforms/mac/signing.md +47 -0
  323. package/docs/platforms/mac/skills.md +40 -0
  324. package/docs/platforms/mac/voice-overlay.md +60 -0
  325. package/docs/platforms/mac/voicewake.md +67 -0
  326. package/docs/platforms/mac/webchat.md +51 -0
  327. package/docs/platforms/mac/xpc.md +61 -0
  328. package/docs/platforms/macos.md +229 -0
  329. package/docs/platforms/oracle.md +305 -0
  330. package/docs/platforms/raspberry-pi.md +420 -0
  331. package/docs/platforms/windows.md +241 -0
  332. package/docs/plugins/agent-tools.md +10 -0
  333. package/docs/plugins/architecture.md +1609 -0
  334. package/docs/plugins/building-extensions.md +10 -0
  335. package/docs/plugins/building-plugins.md +319 -0
  336. package/docs/plugins/bundles.md +292 -0
  337. package/docs/plugins/community.md +149 -0
  338. package/docs/plugins/manifest.md +412 -0
  339. package/docs/plugins/sdk-channel-plugins.md +508 -0
  340. package/docs/plugins/sdk-entrypoints.md +210 -0
  341. package/docs/plugins/sdk-migration.md +359 -0
  342. package/docs/plugins/sdk-overview.md +475 -0
  343. package/docs/plugins/sdk-provider-plugins.md +712 -0
  344. package/docs/plugins/sdk-runtime.md +381 -0
  345. package/docs/plugins/sdk-setup.md +516 -0
  346. package/docs/plugins/sdk-testing.md +263 -0
  347. package/docs/plugins/voice-call.md +466 -0
  348. package/docs/plugins/zalouser.md +78 -0
  349. package/docs/prose.md +134 -0
  350. package/docs/providers/anthropic.md +402 -0
  351. package/docs/providers/bedrock-mantle.md +91 -0
  352. package/docs/providers/bedrock.md +273 -0
  353. package/docs/providers/chutes.md +103 -0
  354. package/docs/providers/claude-max-api-proxy.md +163 -0
  355. package/docs/providers/cloudflare-ai-gateway.md +71 -0
  356. package/docs/providers/deepgram.md +93 -0
  357. package/docs/providers/deepseek.md +53 -0
  358. package/docs/providers/fireworks.md +69 -0
  359. package/docs/providers/github-copilot.md +80 -0
  360. package/docs/providers/glm.md +68 -0
  361. package/docs/providers/google.md +149 -0
  362. package/docs/providers/groq.md +105 -0
  363. package/docs/providers/huggingface.md +193 -0
  364. package/docs/providers/index.md +81 -0
  365. package/docs/providers/kilocode.md +89 -0
  366. package/docs/providers/litellm.md +159 -0
  367. package/docs/providers/minimax.md +281 -0
  368. package/docs/providers/mistral.md +68 -0
  369. package/docs/providers/models.md +56 -0
  370. package/docs/providers/moonshot.md +224 -0
  371. package/docs/providers/nvidia.md +58 -0
  372. package/docs/providers/ollama.md +379 -0
  373. package/docs/providers/openai.md +472 -0
  374. package/docs/providers/opencode-go.md +45 -0
  375. package/docs/providers/opencode.md +68 -0
  376. package/docs/providers/openrouter.md +59 -0
  377. package/docs/providers/perplexity-provider.md +62 -0
  378. package/docs/providers/qianfan.md +90 -0
  379. package/docs/providers/qwen.md +128 -0
  380. package/docs/providers/qwen_modelstudio.md +137 -0
  381. package/docs/providers/sglang.md +115 -0
  382. package/docs/providers/stepfun.md +152 -0
  383. package/docs/providers/synthetic.md +101 -0
  384. package/docs/providers/together.md +70 -0
  385. package/docs/providers/venice.md +282 -0
  386. package/docs/providers/vercel-ai-gateway.md +60 -0
  387. package/docs/providers/vllm.md +103 -0
  388. package/docs/providers/volcengine.md +94 -0
  389. package/docs/providers/xai.md +94 -0
  390. package/docs/providers/xiaomi.md +89 -0
  391. package/docs/providers/zai.md +75 -0
  392. package/docs/reference/AGENTS.default.md +126 -0
  393. package/docs/reference/RELEASING.md +138 -0
  394. package/docs/reference/api-usage-costs.md +198 -0
  395. package/docs/reference/credits.md +30 -0
  396. package/docs/reference/device-models.md +47 -0
  397. package/docs/reference/memory-config.md +421 -0
  398. package/docs/reference/prompt-caching.md +344 -0
  399. package/docs/reference/rpc.md +43 -0
  400. package/docs/reference/secretref-credential-surface.md +148 -0
  401. package/docs/reference/secretref-user-supplied-credentials-matrix.json +607 -0
  402. package/docs/reference/session-management-compaction.md +352 -0
  403. package/docs/reference/templates/AGENTS.dev.md +84 -0
  404. package/docs/reference/templates/AGENTS.md +219 -0
  405. package/docs/reference/templates/BOOT.md +12 -0
  406. package/docs/reference/templates/BOOTSTRAP.md +62 -0
  407. package/docs/reference/templates/CLAUDE.md +1 -0
  408. package/docs/reference/templates/HEARTBEAT.md +14 -0
  409. package/docs/reference/templates/IDENTITY.dev.md +48 -0
  410. package/docs/reference/templates/IDENTITY.md +30 -0
  411. package/docs/reference/templates/SOUL.dev.md +77 -0
  412. package/docs/reference/templates/SOUL.md +45 -0
  413. package/docs/reference/templates/TOOLS.dev.md +25 -0
  414. package/docs/reference/templates/TOOLS.md +47 -0
  415. package/docs/reference/templates/USER.dev.md +19 -0
  416. package/docs/reference/templates/USER.md +24 -0
  417. package/docs/reference/test.md +119 -0
  418. package/docs/reference/token-use.md +197 -0
  419. package/docs/reference/transcript-hygiene.md +151 -0
  420. package/docs/reference/wizard.md +245 -0
  421. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +98 -0
  422. package/docs/security/THREAT-MODEL-ATLAS.md +608 -0
  423. package/docs/security/formal-verification.md +167 -0
  424. package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +9 -0
  425. package/docs/snippets/plugin-publish/minimal-package.json +16 -0
  426. package/docs/start/bootstrapping.md +41 -0
  427. package/docs/start/docs-directory.md +67 -0
  428. package/docs/start/getting-started.md +148 -0
  429. package/docs/start/hubs.md +199 -0
  430. package/docs/start/lore.md +219 -0
  431. package/docs/start/onboarding-overview.md +69 -0
  432. package/docs/start/onboarding.md +92 -0
  433. package/docs/start/openclaw.md +225 -0
  434. package/docs/start/quickstart.md +22 -0
  435. package/docs/start/setup.md +172 -0
  436. package/docs/start/showcase.md +418 -0
  437. package/docs/start/wizard-cli-automation.md +233 -0
  438. package/docs/start/wizard-cli-reference.md +324 -0
  439. package/docs/start/wizard.md +127 -0
  440. package/docs/style.css +37 -0
  441. package/docs/tools/acp-agents.md +837 -0
  442. package/docs/tools/agent-send.md +100 -0
  443. package/docs/tools/apply-patch.md +52 -0
  444. package/docs/tools/brave-search.md +107 -0
  445. package/docs/tools/browser-linux-troubleshooting.md +145 -0
  446. package/docs/tools/browser-login.md +73 -0
  447. package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +221 -0
  448. package/docs/tools/browser.md +890 -0
  449. package/docs/tools/btw.md +142 -0
  450. package/docs/tools/capability-cookbook.md +119 -0
  451. package/docs/tools/clawhub.md +348 -0
  452. package/docs/tools/code-execution.md +90 -0
  453. package/docs/tools/creating-skills.md +119 -0
  454. package/docs/tools/diffs.md +434 -0
  455. package/docs/tools/duckduckgo-search.md +102 -0
  456. package/docs/tools/elevated.md +116 -0
  457. package/docs/tools/exa-search.md +127 -0
  458. package/docs/tools/exec-approvals.md +635 -0
  459. package/docs/tools/exec.md +237 -0
  460. package/docs/tools/firecrawl.md +147 -0
  461. package/docs/tools/gemini-search.md +98 -0
  462. package/docs/tools/grok-search.md +102 -0
  463. package/docs/tools/image-generation.md +139 -0
  464. package/docs/tools/index.md +174 -0
  465. package/docs/tools/kimi-search.md +98 -0
  466. package/docs/tools/llm-task.md +119 -0
  467. package/docs/tools/lobster.md +348 -0
  468. package/docs/tools/loop-detection.md +100 -0
  469. package/docs/tools/minimax-search.md +99 -0
  470. package/docs/tools/multi-agent-sandbox-tools.md +373 -0
  471. package/docs/tools/ollama-search.md +100 -0
  472. package/docs/tools/pdf.md +176 -0
  473. package/docs/tools/perplexity-search.md +185 -0
  474. package/docs/tools/plugin.md +348 -0
  475. package/docs/tools/reactions.md +78 -0
  476. package/docs/tools/searxng-search.md +132 -0
  477. package/docs/tools/skills-config.md +133 -0
  478. package/docs/tools/skills.md +377 -0
  479. package/docs/tools/slash-commands.md +322 -0
  480. package/docs/tools/subagents.md +341 -0
  481. package/docs/tools/tavily.md +129 -0
  482. package/docs/tools/thinking.md +102 -0
  483. package/docs/tools/tts.md +452 -0
  484. package/docs/tools/web-fetch.md +159 -0
  485. package/docs/tools/web.md +417 -0
  486. package/docs/tts.md +452 -0
  487. package/docs/vps.md +115 -0
  488. package/docs/web/control-ui.md +318 -0
  489. package/docs/web/dashboard.md +93 -0
  490. package/docs/web/index.md +126 -0
  491. package/docs/web/tui.md +176 -0
  492. package/docs/web/webchat.md +77 -0
  493. package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
  494. package/docs/whatsapp-openclaw.jpg +0 -0
  495. package/durar.mjs +180 -0
  496. package/package.json +1259 -0
  497. package/scripts/npm-runner.mjs +111 -0
  498. package/scripts/postinstall-bundled-plugins.mjs +188 -0
  499. package/skills/1password/SKILL.md +70 -0
  500. package/skills/1password/references/cli-examples.md +29 -0
  501. package/skills/1password/references/get-started.md +17 -0
  502. package/skills/apple-notes/SKILL.md +77 -0
  503. package/skills/apple-reminders/SKILL.md +118 -0
  504. package/skills/bear-notes/SKILL.md +107 -0
  505. package/skills/blogwatcher/SKILL.md +69 -0
  506. package/skills/blucli/SKILL.md +47 -0
  507. package/skills/bluebubbles/SKILL.md +131 -0
  508. package/skills/camsnap/SKILL.md +45 -0
  509. package/skills/canvas/SKILL.md +199 -0
  510. package/skills/clawhub/SKILL.md +77 -0
  511. package/skills/coding-agent/SKILL.md +316 -0
  512. package/skills/discord/SKILL.md +197 -0
  513. package/skills/eightctl/SKILL.md +50 -0
  514. package/skills/gemini/SKILL.md +43 -0
  515. package/skills/gh-issues/SKILL.md +885 -0
  516. package/skills/gifgrep/SKILL.md +79 -0
  517. package/skills/github/SKILL.md +163 -0
  518. package/skills/gog/SKILL.md +116 -0
  519. package/skills/goplaces/SKILL.md +52 -0
  520. package/skills/healthcheck/SKILL.md +245 -0
  521. package/skills/himalaya/SKILL.md +257 -0
  522. package/skills/himalaya/references/configuration.md +184 -0
  523. package/skills/himalaya/references/message-composition.md +199 -0
  524. package/skills/imsg/SKILL.md +122 -0
  525. package/skills/mcporter/SKILL.md +61 -0
  526. package/skills/model-usage/SKILL.md +69 -0
  527. package/skills/model-usage/references/codexbar-cli.md +33 -0
  528. package/skills/model-usage/scripts/model_usage.py +320 -0
  529. package/skills/model-usage/scripts/test_model_usage.py +40 -0
  530. package/skills/nano-pdf/SKILL.md +38 -0
  531. package/skills/node-connect/SKILL.md +142 -0
  532. package/skills/notion/SKILL.md +174 -0
  533. package/skills/obsidian/SKILL.md +81 -0
  534. package/skills/openai-whisper/SKILL.md +38 -0
  535. package/skills/openai-whisper-api/SKILL.md +62 -0
  536. package/skills/openai-whisper-api/scripts/transcribe.sh +88 -0
  537. package/skills/openhue/SKILL.md +112 -0
  538. package/skills/oracle/SKILL.md +125 -0
  539. package/skills/ordercli/SKILL.md +78 -0
  540. package/skills/peekaboo/SKILL.md +190 -0
  541. package/skills/sag/SKILL.md +87 -0
  542. package/skills/session-logs/SKILL.md +151 -0
  543. package/skills/sherpa-onnx-tts/SKILL.md +109 -0
  544. package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
  545. package/skills/skill-creator/SKILL.md +372 -0
  546. package/skills/skill-creator/license.txt +202 -0
  547. package/skills/skill-creator/scripts/init_skill.py +378 -0
  548. package/skills/skill-creator/scripts/package_skill.py +139 -0
  549. package/skills/skill-creator/scripts/quick_validate.py +159 -0
  550. package/skills/skill-creator/scripts/test_package_skill.py +160 -0
  551. package/skills/skill-creator/scripts/test_quick_validate.py +72 -0
  552. package/skills/slack/SKILL.md +144 -0
  553. package/skills/songsee/SKILL.md +49 -0
  554. package/skills/sonoscli/SKILL.md +65 -0
  555. package/skills/spotify-player/SKILL.md +64 -0
  556. package/skills/summarize/SKILL.md +87 -0
  557. package/skills/taskflow/SKILL.md +149 -0
  558. package/skills/taskflow/examples/inbox-triage.lobster +33 -0
  559. package/skills/taskflow/examples/pr-intake.lobster +32 -0
  560. package/skills/taskflow-inbox-triage/SKILL.md +119 -0
  561. package/skills/things-mac/SKILL.md +86 -0
  562. package/skills/tmux/SKILL.md +170 -0
  563. package/skills/tmux/scripts/find-sessions.sh +112 -0
  564. package/skills/tmux/scripts/wait-for-text.sh +83 -0
  565. package/skills/trello/SKILL.md +108 -0
  566. package/skills/video-frames/SKILL.md +46 -0
  567. package/skills/video-frames/scripts/frame.sh +81 -0
  568. package/skills/voice-call/SKILL.md +45 -0
  569. package/skills/wacli/SKILL.md +72 -0
  570. package/skills/weather/SKILL.md +129 -0
  571. package/skills/xurl/SKILL.md +461 -0
@@ -0,0 +1,107 @@
1
+ ---
2
+ name: bear-notes
3
+ description: Create, search, and manage Bear notes via grizzly CLI.
4
+ homepage: https://bear.app
5
+ metadata:
6
+ {
7
+ "openclaw":
8
+ {
9
+ "emoji": "🐻",
10
+ "os": ["darwin"],
11
+ "requires": { "bins": ["grizzly"] },
12
+ "install":
13
+ [
14
+ {
15
+ "id": "go",
16
+ "kind": "go",
17
+ "module": "github.com/tylerwince/grizzly/cmd/grizzly@latest",
18
+ "bins": ["grizzly"],
19
+ "label": "Install grizzly (go)",
20
+ },
21
+ ],
22
+ },
23
+ }
24
+ ---
25
+
26
+ # Bear Notes
27
+
28
+ Use `grizzly` to create, read, and manage notes in Bear on macOS.
29
+
30
+ Requirements
31
+
32
+ - Bear app installed and running
33
+ - For some operations (add-text, tags, open-note --selected), a Bear app token (stored in `~/.config/grizzly/token`)
34
+
35
+ ## Getting a Bear Token
36
+
37
+ For operations that require a token (add-text, tags, open-note --selected), you need an authentication token:
38
+
39
+ 1. Open Bear → Help → API Token → Copy Token
40
+ 2. Save it: `echo "YOUR_TOKEN" > ~/.config/grizzly/token`
41
+
42
+ ## Common Commands
43
+
44
+ Create a note
45
+
46
+ ```bash
47
+ echo "Note content here" | grizzly create --title "My Note" --tag work
48
+ grizzly create --title "Quick Note" --tag inbox < /dev/null
49
+ ```
50
+
51
+ Open/read a note by ID
52
+
53
+ ```bash
54
+ grizzly open-note --id "NOTE_ID" --enable-callback --json
55
+ ```
56
+
57
+ Append text to a note
58
+
59
+ ```bash
60
+ echo "Additional content" | grizzly add-text --id "NOTE_ID" --mode append --token-file ~/.config/grizzly/token
61
+ ```
62
+
63
+ List all tags
64
+
65
+ ```bash
66
+ grizzly tags --enable-callback --json --token-file ~/.config/grizzly/token
67
+ ```
68
+
69
+ Search notes (via open-tag)
70
+
71
+ ```bash
72
+ grizzly open-tag --name "work" --enable-callback --json
73
+ ```
74
+
75
+ ## Options
76
+
77
+ Common flags:
78
+
79
+ - `--dry-run` — Preview the URL without executing
80
+ - `--print-url` — Show the x-callback-url
81
+ - `--enable-callback` — Wait for Bear's response (needed for reading data)
82
+ - `--json` — Output as JSON (when using callbacks)
83
+ - `--token-file PATH` — Path to Bear API token file
84
+
85
+ ## Configuration
86
+
87
+ Grizzly reads config from (in priority order):
88
+
89
+ 1. CLI flags
90
+ 2. Environment variables (`GRIZZLY_TOKEN_FILE`, `GRIZZLY_CALLBACK_URL`, `GRIZZLY_TIMEOUT`)
91
+ 3. `.grizzly.toml` in current directory
92
+ 4. `~/.config/grizzly/config.toml`
93
+
94
+ Example `~/.config/grizzly/config.toml`:
95
+
96
+ ```toml
97
+ token_file = "~/.config/grizzly/token"
98
+ callback_url = "http://127.0.0.1:42123/success"
99
+ timeout = "5s"
100
+ ```
101
+
102
+ ## Notes
103
+
104
+ - Bear must be running for commands to work
105
+ - Note IDs are Bear's internal identifiers (visible in note info or via callbacks)
106
+ - Use `--enable-callback` when you need to read data back from Bear
107
+ - Some operations require a valid token (add-text, tags, open-note --selected)
@@ -0,0 +1,69 @@
1
+ ---
2
+ name: blogwatcher
3
+ description: Monitor blogs and RSS/Atom feeds for updates using the blogwatcher CLI.
4
+ homepage: https://github.com/Hyaxia/blogwatcher
5
+ metadata:
6
+ {
7
+ "openclaw":
8
+ {
9
+ "emoji": "📰",
10
+ "requires": { "bins": ["blogwatcher"] },
11
+ "install":
12
+ [
13
+ {
14
+ "id": "go",
15
+ "kind": "go",
16
+ "module": "github.com/Hyaxia/blogwatcher/cmd/blogwatcher@latest",
17
+ "bins": ["blogwatcher"],
18
+ "label": "Install blogwatcher (go)",
19
+ },
20
+ ],
21
+ },
22
+ }
23
+ ---
24
+
25
+ # blogwatcher
26
+
27
+ Track blog and RSS/Atom feed updates with the `blogwatcher` CLI.
28
+
29
+ Install
30
+
31
+ - Go: `go install github.com/Hyaxia/blogwatcher/cmd/blogwatcher@latest`
32
+
33
+ Quick start
34
+
35
+ - `blogwatcher --help`
36
+
37
+ Common commands
38
+
39
+ - Add a blog: `blogwatcher add "My Blog" https://example.com`
40
+ - List blogs: `blogwatcher blogs`
41
+ - Scan for updates: `blogwatcher scan`
42
+ - List articles: `blogwatcher articles`
43
+ - Mark an article read: `blogwatcher read 1`
44
+ - Mark all articles read: `blogwatcher read-all`
45
+ - Remove a blog: `blogwatcher remove "My Blog"`
46
+
47
+ Example output
48
+
49
+ ```
50
+ $ blogwatcher blogs
51
+ Tracked blogs (1):
52
+
53
+ xkcd
54
+ URL: https://xkcd.com
55
+ ```
56
+
57
+ ```
58
+ $ blogwatcher scan
59
+ Scanning 1 blog(s)...
60
+
61
+ xkcd
62
+ Source: RSS | Found: 4 | New: 4
63
+
64
+ Found 4 new article(s) total!
65
+ ```
66
+
67
+ Notes
68
+
69
+ - Use `blogwatcher <command> --help` to discover flags and options.
@@ -0,0 +1,47 @@
1
+ ---
2
+ name: blucli
3
+ description: BluOS CLI (blu) for discovery, playback, grouping, and volume.
4
+ homepage: https://blucli.sh
5
+ metadata:
6
+ {
7
+ "openclaw":
8
+ {
9
+ "emoji": "🫐",
10
+ "requires": { "bins": ["blu"] },
11
+ "install":
12
+ [
13
+ {
14
+ "id": "go",
15
+ "kind": "go",
16
+ "module": "github.com/steipete/blucli/cmd/blu@latest",
17
+ "bins": ["blu"],
18
+ "label": "Install blucli (go)",
19
+ },
20
+ ],
21
+ },
22
+ }
23
+ ---
24
+
25
+ # blucli (blu)
26
+
27
+ Use `blu` to control Bluesound/NAD players.
28
+
29
+ Quick start
30
+
31
+ - `blu devices` (pick target)
32
+ - `blu --device <id> status`
33
+ - `blu play|pause|stop`
34
+ - `blu volume set 15`
35
+
36
+ Target selection (in priority order)
37
+
38
+ - `--device <id|name|alias>`
39
+ - `BLU_DEVICE`
40
+ - config default (if set)
41
+
42
+ Common tasks
43
+
44
+ - Grouping: `blu group status|add|remove`
45
+ - TuneIn search/play: `blu tunein search "query"`, `blu tunein play "query"`
46
+
47
+ Prefer `--json` for scripts. Confirm the target device before changing playback.
@@ -0,0 +1,131 @@
1
+ ---
2
+ name: bluebubbles
3
+ description: Use when you need to send or manage iMessages via BlueBubbles (recommended iMessage integration). Calls go through the generic message tool with channel="bluebubbles".
4
+ metadata: { "openclaw": { "emoji": "🫧", "requires": { "config": ["channels.bluebubbles"] } } }
5
+ ---
6
+
7
+ # BlueBubbles Actions
8
+
9
+ ## Overview
10
+
11
+ BlueBubbles is OpenClaw’s recommended iMessage integration. Use the `message` tool with `channel: "bluebubbles"` to send messages and manage iMessage conversations: send texts and attachments, react (tapbacks), edit/unsend, reply in threads, and manage group participants/names/icons.
12
+
13
+ ## Inputs to collect
14
+
15
+ - `target` (prefer `chat_guid:...`; also `+15551234567` in E.164 or `user@example.com`)
16
+ - `message` text for send/edit/reply
17
+ - `messageId` for react/edit/unsend/reply
18
+ - Attachment `path` for local files, or `buffer` + `filename` for base64
19
+
20
+ If the user is vague ("text my mom"), ask for the recipient handle or chat guid and the exact message content.
21
+
22
+ ## Actions
23
+
24
+ ### Send a message
25
+
26
+ ```json
27
+ {
28
+ "action": "send",
29
+ "channel": "bluebubbles",
30
+ "target": "+15551234567",
31
+ "message": "hello from OpenClaw"
32
+ }
33
+ ```
34
+
35
+ ### React (tapback)
36
+
37
+ ```json
38
+ {
39
+ "action": "react",
40
+ "channel": "bluebubbles",
41
+ "target": "+15551234567",
42
+ "messageId": "<message-guid>",
43
+ "emoji": "❤️"
44
+ }
45
+ ```
46
+
47
+ ### Remove a reaction
48
+
49
+ ```json
50
+ {
51
+ "action": "react",
52
+ "channel": "bluebubbles",
53
+ "target": "+15551234567",
54
+ "messageId": "<message-guid>",
55
+ "emoji": "❤️",
56
+ "remove": true
57
+ }
58
+ ```
59
+
60
+ ### Edit a previously sent message
61
+
62
+ ```json
63
+ {
64
+ "action": "edit",
65
+ "channel": "bluebubbles",
66
+ "target": "+15551234567",
67
+ "messageId": "<message-guid>",
68
+ "message": "updated text"
69
+ }
70
+ ```
71
+
72
+ ### Unsend a message
73
+
74
+ ```json
75
+ {
76
+ "action": "unsend",
77
+ "channel": "bluebubbles",
78
+ "target": "+15551234567",
79
+ "messageId": "<message-guid>"
80
+ }
81
+ ```
82
+
83
+ ### Reply to a specific message
84
+
85
+ ```json
86
+ {
87
+ "action": "reply",
88
+ "channel": "bluebubbles",
89
+ "target": "+15551234567",
90
+ "replyTo": "<message-guid>",
91
+ "message": "replying to that"
92
+ }
93
+ ```
94
+
95
+ ### Send an attachment
96
+
97
+ ```json
98
+ {
99
+ "action": "sendAttachment",
100
+ "channel": "bluebubbles",
101
+ "target": "+15551234567",
102
+ "path": "/tmp/photo.jpg",
103
+ "caption": "here you go"
104
+ }
105
+ ```
106
+
107
+ ### Send with an iMessage effect
108
+
109
+ ```json
110
+ {
111
+ "action": "sendWithEffect",
112
+ "channel": "bluebubbles",
113
+ "target": "+15551234567",
114
+ "message": "big news",
115
+ "effect": "balloons"
116
+ }
117
+ ```
118
+
119
+ ## Notes
120
+
121
+ - Requires gateway config `channels.bluebubbles` (serverUrl/password/webhookPath).
122
+ - Prefer `chat_guid` targets when you have them (especially for group chats).
123
+ - BlueBubbles supports rich actions, but some are macOS-version dependent (for example, edit may be broken on macOS 26 Tahoe).
124
+ - The gateway may expose both short and full message ids; full ids are more durable across restarts.
125
+ - Developer reference for the underlying plugin lives in the BlueBubbles plugin package README.
126
+
127
+ ## Ideas to try
128
+
129
+ - React with a tapback to acknowledge a request.
130
+ - Reply in-thread when a user references a specific message.
131
+ - Send a file attachment with a short caption.
@@ -0,0 +1,45 @@
1
+ ---
2
+ name: camsnap
3
+ description: Capture frames or clips from RTSP/ONVIF cameras.
4
+ homepage: https://camsnap.ai
5
+ metadata:
6
+ {
7
+ "openclaw":
8
+ {
9
+ "emoji": "📸",
10
+ "requires": { "bins": ["camsnap"] },
11
+ "install":
12
+ [
13
+ {
14
+ "id": "brew",
15
+ "kind": "brew",
16
+ "formula": "steipete/tap/camsnap",
17
+ "bins": ["camsnap"],
18
+ "label": "Install camsnap (brew)",
19
+ },
20
+ ],
21
+ },
22
+ }
23
+ ---
24
+
25
+ # camsnap
26
+
27
+ Use `camsnap` to grab snapshots, clips, or motion events from configured cameras.
28
+
29
+ Setup
30
+
31
+ - Config file: `~/.config/camsnap/config.yaml`
32
+ - Add camera: `camsnap add --name kitchen --host 192.168.0.10 --user user --pass pass`
33
+
34
+ Common commands
35
+
36
+ - Discover: `camsnap discover --info`
37
+ - Snapshot: `camsnap snap kitchen --out shot.jpg`
38
+ - Clip: `camsnap clip kitchen --dur 5s --out clip.mp4`
39
+ - Motion watch: `camsnap watch kitchen --threshold 0.2 --action '...'`
40
+ - Doctor: `camsnap doctor --probe`
41
+
42
+ Notes
43
+
44
+ - Requires `ffmpeg` on PATH.
45
+ - Prefer a short test capture before longer clips.
@@ -0,0 +1,199 @@
1
+ # Canvas Skill
2
+
3
+ Display HTML content on connected OpenClaw nodes (Mac app, iOS, Android).
4
+
5
+ ## Overview
6
+
7
+ The canvas tool lets you present web content on any connected node's canvas view. Great for:
8
+
9
+ - Displaying games, visualizations, dashboards
10
+ - Showing generated HTML content
11
+ - Interactive demos
12
+
13
+ ## How It Works
14
+
15
+ ### Architecture
16
+
17
+ ```
18
+ ┌─────────────────┐ ┌──────────────────┐ ┌─────────────┐
19
+ │ Canvas Host │────▶│ Node Bridge │────▶│ Node App │
20
+ │ (HTTP Server) │ │ (TCP Server) │ │ (Mac/iOS/ │
21
+ │ Port 18793 │ │ Port 18790 │ │ Android) │
22
+ └─────────────────┘ └──────────────────┘ └─────────────┘
23
+ ```
24
+
25
+ 1. **Canvas Host Server**: Serves static HTML/CSS/JS files from `canvasHost.root` directory
26
+ 2. **Node Bridge**: Communicates canvas URLs to connected nodes
27
+ 3. **Node Apps**: Render the content in a WebView
28
+
29
+ ### Tailscale Integration
30
+
31
+ The canvas host server binds based on `gateway.bind` setting:
32
+
33
+ | Bind Mode | Server Binds To | Canvas URL Uses |
34
+ | ---------- | ------------------- | -------------------------- |
35
+ | `loopback` | 127.0.0.1 | localhost (local only) |
36
+ | `lan` | LAN interface | LAN IP address |
37
+ | `tailnet` | Tailscale interface | Tailscale hostname |
38
+ | `auto` | Best available | Tailscale > LAN > loopback |
39
+
40
+ **Key insight:** The `canvasHostHostForBridge` is derived from `bridgeHost`. When bound to Tailscale, nodes receive URLs like:
41
+
42
+ ```
43
+ http://<tailscale-hostname>:18793/__openclaw__/canvas/<file>.html
44
+ ```
45
+
46
+ This is why localhost URLs don't work - the node receives the Tailscale hostname from the bridge!
47
+
48
+ ## Actions
49
+
50
+ | Action | Description |
51
+ | ---------- | ------------------------------------ |
52
+ | `present` | Show canvas with optional target URL |
53
+ | `hide` | Hide the canvas |
54
+ | `navigate` | Navigate to a new URL |
55
+ | `eval` | Execute JavaScript in the canvas |
56
+ | `snapshot` | Capture screenshot of canvas |
57
+
58
+ ## Configuration
59
+
60
+ In the active OpenClaw config file (`$OPENCLAW_CONFIG_PATH`, default `~/.openclaw/openclaw.json`):
61
+
62
+ ```json
63
+ {
64
+ "canvasHost": {
65
+ "enabled": true,
66
+ "port": 18793,
67
+ "root": "/Users/you/clawd/canvas",
68
+ "liveReload": true
69
+ },
70
+ "gateway": {
71
+ "bind": "auto"
72
+ }
73
+ }
74
+ ```
75
+
76
+ ### Live Reload
77
+
78
+ When `liveReload: true` (default), the canvas host:
79
+
80
+ - Watches the root directory for changes (via chokidar)
81
+ - Injects a WebSocket client into HTML files
82
+ - Automatically reloads connected canvases when files change
83
+
84
+ Great for development!
85
+
86
+ ## Workflow
87
+
88
+ ### 1. Create HTML content
89
+
90
+ Place files in the canvas root directory (default `~/clawd/canvas/`):
91
+
92
+ ```bash
93
+ cat > ~/clawd/canvas/my-game.html << 'HTML'
94
+ <!DOCTYPE html>
95
+ <html>
96
+ <head><title>My Game</title></head>
97
+ <body>
98
+ <h1>Hello Canvas!</h1>
99
+ </body>
100
+ </html>
101
+ HTML
102
+ ```
103
+
104
+ ### 2. Find your canvas host URL
105
+
106
+ Check how your gateway is bound:
107
+
108
+ ```bash
109
+ CONFIG_PATH="${OPENCLAW_CONFIG_PATH:-${OPENCLAW_STATE_DIR:-$HOME/.openclaw}/openclaw.json}"
110
+ cat "$CONFIG_PATH" | jq '.gateway.bind'
111
+ ```
112
+
113
+ Then construct the URL:
114
+
115
+ - **loopback**: `http://127.0.0.1:18793/__openclaw__/canvas/<file>.html`
116
+ - **lan/tailnet/auto**: `http://<hostname>:18793/__openclaw__/canvas/<file>.html`
117
+
118
+ Find your Tailscale hostname:
119
+
120
+ ```bash
121
+ tailscale status --json | jq -r '.Self.DNSName' | sed 's/\.$//'
122
+ ```
123
+
124
+ ### 3. Find connected nodes
125
+
126
+ ```bash
127
+ openclaw nodes list
128
+ ```
129
+
130
+ Look for Mac/iOS/Android nodes with canvas capability.
131
+
132
+ ### 4. Present content
133
+
134
+ ```
135
+ canvas action:present node:<node-id> target:<full-url>
136
+ ```
137
+
138
+ **Example:**
139
+
140
+ ```
141
+ canvas action:present node:mac-63599bc4-b54d-4392-9048-b97abd58343a target:http://peters-mac-studio-1.sheep-coho.ts.net:18793/__openclaw__/canvas/snake.html
142
+ ```
143
+
144
+ ### 5. Navigate, snapshot, or hide
145
+
146
+ ```
147
+ canvas action:navigate node:<node-id> url:<new-url>
148
+ canvas action:snapshot node:<node-id>
149
+ canvas action:hide node:<node-id>
150
+ ```
151
+
152
+ ## Debugging
153
+
154
+ ### White screen / content not loading
155
+
156
+ **Cause:** URL mismatch between server bind and node expectation.
157
+
158
+ **Debug steps:**
159
+
160
+ 1. Check server bind: `CONFIG_PATH="${OPENCLAW_CONFIG_PATH:-${OPENCLAW_STATE_DIR:-$HOME/.openclaw}/openclaw.json}"; cat "$CONFIG_PATH" | jq '.gateway.bind'`
161
+ 2. Check what port canvas is on: `lsof -i :18793`
162
+ 3. Test URL directly: `curl http://<hostname>:18793/__openclaw__/canvas/<file>.html`
163
+
164
+ **Solution:** Use the full hostname matching your bind mode, not localhost.
165
+
166
+ ### "node required" error
167
+
168
+ Always specify `node:<node-id>` parameter.
169
+
170
+ ### "node not connected" error
171
+
172
+ Node is offline. Use `openclaw nodes list` to find online nodes.
173
+
174
+ ### Content not updating
175
+
176
+ If live reload isn't working:
177
+
178
+ 1. Check `liveReload: true` in config
179
+ 2. Ensure file is in the canvas root directory
180
+ 3. Check for watcher errors in logs
181
+
182
+ ## URL Path Structure
183
+
184
+ The canvas host serves from `/__openclaw__/canvas/` prefix:
185
+
186
+ ```
187
+ http://<host>:18793/__openclaw__/canvas/index.html → ~/clawd/canvas/index.html
188
+ http://<host>:18793/__openclaw__/canvas/games/snake.html → ~/clawd/canvas/games/snake.html
189
+ ```
190
+
191
+ The `/__openclaw__/canvas/` prefix is defined by `CANVAS_HOST_PATH` constant.
192
+
193
+ ## Tips
194
+
195
+ - Keep HTML self-contained (inline CSS/JS) for best results
196
+ - Use the default index.html as a test page (has bridge diagnostics)
197
+ - The canvas persists until you `hide` it or navigate away
198
+ - Live reload makes development fast - just save and it updates!
199
+ - A2UI JSON push is WIP - use HTML files for now
@@ -0,0 +1,77 @@
1
+ ---
2
+ name: clawhub
3
+ description: Use the ClawHub CLI to search, install, update, and publish agent skills from clawhub.com. Use when you need to fetch new skills on the fly, sync installed skills to latest or a specific version, or publish new/updated skill folders with the npm-installed clawhub CLI.
4
+ metadata:
5
+ {
6
+ "openclaw":
7
+ {
8
+ "requires": { "bins": ["clawhub"] },
9
+ "install":
10
+ [
11
+ {
12
+ "id": "node",
13
+ "kind": "node",
14
+ "package": "clawhub",
15
+ "bins": ["clawhub"],
16
+ "label": "Install ClawHub CLI (npm)",
17
+ },
18
+ ],
19
+ },
20
+ }
21
+ ---
22
+
23
+ # ClawHub CLI
24
+
25
+ Install
26
+
27
+ ```bash
28
+ npm i -g clawhub
29
+ ```
30
+
31
+ Auth (publish)
32
+
33
+ ```bash
34
+ clawhub login
35
+ clawhub whoami
36
+ ```
37
+
38
+ Search
39
+
40
+ ```bash
41
+ clawhub search "postgres backups"
42
+ ```
43
+
44
+ Install
45
+
46
+ ```bash
47
+ clawhub install my-skill
48
+ clawhub install my-skill --version 1.2.3
49
+ ```
50
+
51
+ Update (hash-based match + upgrade)
52
+
53
+ ```bash
54
+ clawhub update my-skill
55
+ clawhub update my-skill --version 1.2.3
56
+ clawhub update --all
57
+ clawhub update my-skill --force
58
+ clawhub update --all --no-input --force
59
+ ```
60
+
61
+ List
62
+
63
+ ```bash
64
+ clawhub list
65
+ ```
66
+
67
+ Publish
68
+
69
+ ```bash
70
+ clawhub publish ./my-skill --slug my-skill --name "My Skill" --version 1.2.0 --changelog "Fixes + docs"
71
+ ```
72
+
73
+ Notes
74
+
75
+ - Default registry: https://clawhub.com (override with CLAWHUB_REGISTRY or --registry)
76
+ - Default workdir: cwd (falls back to OpenClaw workspace); install dir: ./skills (override with --workdir / --dir / CLAWHUB_WORKDIR)
77
+ - Update command hashes local files, resolves matching version, and upgrades to latest unless --version is set