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,340 @@
1
+ ---
2
+ summary: "Expose an OpenResponses-compatible /v1/responses HTTP endpoint from the Gateway"
3
+ read_when:
4
+ - Integrating clients that speak the OpenResponses API
5
+ - You want item-based inputs, client tool calls, or SSE events
6
+ title: "OpenResponses API"
7
+ ---
8
+
9
+ # OpenResponses API (HTTP)
10
+
11
+ Durar’s Gateway can serve an OpenResponses-compatible `POST /v1/responses` endpoint.
12
+
13
+ This endpoint is **disabled by default**. Enable it in config first.
14
+
15
+ - `POST /v1/responses`
16
+ - Same port as the Gateway (WS + HTTP multiplex): `http://<gateway-host>:<port>/v1/responses`
17
+
18
+ Under the hood, requests are executed as a normal Gateway agent run (same codepath as
19
+ `Durar agent`), so routing/permissions/config match your Gateway.
20
+
21
+ ## Authentication, security, and routing
22
+
23
+ Operational behavior matches [OpenAI Chat Completions](/gateway/openai-http-api):
24
+
25
+ - use the matching Gateway HTTP auth path:
26
+ - shared-secret auth (`gateway.auth.mode="token"` or `"password"`): `Authorization: Bearer <token-or-password>`
27
+ - trusted-proxy auth (`gateway.auth.mode="trusted-proxy"`): identity-aware proxy headers from a configured non-loopback trusted proxy source
28
+ - private-ingress open auth (`gateway.auth.mode="none"`): no auth header
29
+ - treat the endpoint as full operator access for the gateway instance
30
+ - for shared-secret auth modes (`token` and `password`), ignore narrower bearer-declared `x-Durar-scopes` values and restore the normal full operator defaults
31
+ - for trusted identity-bearing HTTP modes (for example trusted proxy auth or `gateway.auth.mode="none"`), honor `x-Durar-scopes` when present and otherwise fall back to the normal operator default scope set
32
+ - select agents with `model: "Durar"`, `model: "Durar/default"`, `model: "Durar/<agentId>"`, or `x-Durar-agent-id`
33
+ - use `x-Durar-model` when you want to override the selected agent's backend model
34
+ - use `x-Durar-session-key` for explicit session routing
35
+ - use `x-Durar-message-channel` when you want a non-default synthetic ingress channel context
36
+
37
+ Auth matrix:
38
+
39
+ - `gateway.auth.mode="token"` or `"password"` + `Authorization: Bearer ...`
40
+ - proves possession of the shared gateway operator secret
41
+ - ignores narrower `x-Durar-scopes`
42
+ - restores the full default operator scope set:
43
+ `operator.admin`, `operator.approvals`, `operator.pairing`,
44
+ `operator.read`, `operator.talk.secrets`, `operator.write`
45
+ - treats chat turns on this endpoint as owner-sender turns
46
+ - trusted identity-bearing HTTP modes (for example trusted proxy auth, or `gateway.auth.mode="none"` on private ingress)
47
+ - honor `x-Durar-scopes` when the header is present
48
+ - fall back to the normal operator default scope set when the header is absent
49
+ - only lose owner semantics when the caller explicitly narrows scopes and omits `operator.admin`
50
+
51
+ Enable or disable this endpoint with `gateway.http.endpoints.responses.enabled`.
52
+
53
+ The same compatibility surface also includes:
54
+
55
+ - `GET /v1/models`
56
+ - `GET /v1/models/{id}`
57
+ - `POST /v1/embeddings`
58
+ - `POST /v1/chat/completions`
59
+
60
+ For the canonical explanation of how agent-target models, `Durar/default`, embeddings pass-through, and backend model overrides fit together, see [OpenAI Chat Completions](/gateway/openai-http-api#agent-first-model-contract) and [Model list and agent routing](/gateway/openai-http-api#model-list-and-agent-routing).
61
+
62
+ ## Session behavior
63
+
64
+ By default the endpoint is **stateless per request** (a new session key is generated each call).
65
+
66
+ If the request includes an OpenResponses `user` string, the Gateway derives a stable session key
67
+ from it, so repeated calls can share an agent session.
68
+
69
+ ## Request shape (supported)
70
+
71
+ The request follows the OpenResponses API with item-based input. Current support:
72
+
73
+ - `input`: string or array of item objects.
74
+ - `instructions`: merged into the system prompt.
75
+ - `tools`: client tool definitions (function tools).
76
+ - `tool_choice`: filter or require client tools.
77
+ - `stream`: enables SSE streaming.
78
+ - `max_output_tokens`: best-effort output limit (provider dependent).
79
+ - `user`: stable session routing.
80
+
81
+ Accepted but **currently ignored**:
82
+
83
+ - `max_tool_calls`
84
+ - `reasoning`
85
+ - `metadata`
86
+ - `store`
87
+ - `truncation`
88
+
89
+ Supported:
90
+
91
+ - `previous_response_id`: Durar reuses the earlier response session when the request stays within the same agent/user/requested-session scope.
92
+
93
+ ## Items (input)
94
+
95
+ ### `message`
96
+
97
+ Roles: `system`, `developer`, `user`, `assistant`.
98
+
99
+ - `system` and `developer` are appended to the system prompt.
100
+ - The most recent `user` or `function_call_output` item becomes the “current message.”
101
+ - Earlier user/assistant messages are included as history for context.
102
+
103
+ ### `function_call_output` (turn-based tools)
104
+
105
+ Send tool results back to the model:
106
+
107
+ ```json
108
+ {
109
+ "type": "function_call_output",
110
+ "call_id": "call_123",
111
+ "output": "{\"temperature\": \"72F\"}"
112
+ }
113
+ ```
114
+
115
+ ### `reasoning` and `item_reference`
116
+
117
+ Accepted for schema compatibility but ignored when building the prompt.
118
+
119
+ ## Tools (client-side function tools)
120
+
121
+ Provide tools with `tools: [{ type: "function", function: { name, description?, parameters? } }]`.
122
+
123
+ If the agent decides to call a tool, the response returns a `function_call` output item.
124
+ You then send a follow-up request with `function_call_output` to continue the turn.
125
+
126
+ ## Images (`input_image`)
127
+
128
+ Supports base64 or URL sources:
129
+
130
+ ```json
131
+ {
132
+ "type": "input_image",
133
+ "source": { "type": "url", "url": "https://example.com/image.png" }
134
+ }
135
+ ```
136
+
137
+ Allowed MIME types (current): `image/jpeg`, `image/png`, `image/gif`, `image/webp`, `image/heic`, `image/heif`.
138
+ Max size (current): 10MB.
139
+
140
+ ## Files (`input_file`)
141
+
142
+ Supports base64 or URL sources:
143
+
144
+ ```json
145
+ {
146
+ "type": "input_file",
147
+ "source": {
148
+ "type": "base64",
149
+ "media_type": "text/plain",
150
+ "data": "SGVsbG8gV29ybGQh",
151
+ "filename": "hello.txt"
152
+ }
153
+ }
154
+ ```
155
+
156
+ Allowed MIME types (current): `text/plain`, `text/markdown`, `text/html`, `text/csv`,
157
+ `application/json`, `application/pdf`.
158
+
159
+ Max size (current): 5MB.
160
+
161
+ Current behavior:
162
+
163
+ - File content is decoded and added to the **system prompt**, not the user message,
164
+ so it stays ephemeral (not persisted in session history).
165
+ - Decoded file text is wrapped as **untrusted external content** before it is added,
166
+ so file bytes are treated as data, not trusted instructions.
167
+ - The injected block uses explicit boundary markers like
168
+ `<<<EXTERNAL_UNTRUSTED_CONTENT id="...">>>` /
169
+ `<<<END_EXTERNAL_UNTRUSTED_CONTENT id="...">>>` and includes a
170
+ `Source: External` metadata line.
171
+ - This file-input path intentionally omits the long `SECURITY NOTICE:` banner to
172
+ preserve prompt budget; the boundary markers and metadata still stay in place.
173
+ - PDFs are parsed for text first. If little text is found, the first pages are
174
+ rasterized into images and passed to the model, and the injected file block uses
175
+ the placeholder `[PDF content rendered to images]`.
176
+
177
+ PDF parsing uses the Node-friendly `pdfjs-dist` legacy build (no worker). The modern
178
+ PDF.js build expects browser workers/DOM globals, so it is not used in the Gateway.
179
+
180
+ URL fetch defaults:
181
+
182
+ - `files.allowUrl`: `true`
183
+ - `images.allowUrl`: `true`
184
+ - `maxUrlParts`: `8` (total URL-based `input_file` + `input_image` parts per request)
185
+ - Requests are guarded (DNS resolution, private IP blocking, redirect caps, timeouts).
186
+ - Optional hostname allowlists are supported per input type (`files.urlAllowlist`, `images.urlAllowlist`).
187
+ - Exact host: `"cdn.example.com"`
188
+ - Wildcard subdomains: `"*.assets.example.com"` (does not match apex)
189
+ - Empty or omitted allowlists mean no hostname allowlist restriction.
190
+ - To disable URL-based fetches entirely, set `files.allowUrl: false` and/or `images.allowUrl: false`.
191
+
192
+ ## File + image limits (config)
193
+
194
+ Defaults can be tuned under `gateway.http.endpoints.responses`:
195
+
196
+ ```json5
197
+ {
198
+ gateway: {
199
+ http: {
200
+ endpoints: {
201
+ responses: {
202
+ enabled: true,
203
+ maxBodyBytes: 20000000,
204
+ maxUrlParts: 8,
205
+ files: {
206
+ allowUrl: true,
207
+ urlAllowlist: ["cdn.example.com", "*.assets.example.com"],
208
+ allowedMimes: [
209
+ "text/plain",
210
+ "text/markdown",
211
+ "text/html",
212
+ "text/csv",
213
+ "application/json",
214
+ "application/pdf",
215
+ ],
216
+ maxBytes: 5242880,
217
+ maxChars: 200000,
218
+ maxRedirects: 3,
219
+ timeoutMs: 10000,
220
+ pdf: {
221
+ maxPages: 4,
222
+ maxPixels: 4000000,
223
+ minTextChars: 200,
224
+ },
225
+ },
226
+ images: {
227
+ allowUrl: true,
228
+ urlAllowlist: ["images.example.com"],
229
+ allowedMimes: [
230
+ "image/jpeg",
231
+ "image/png",
232
+ "image/gif",
233
+ "image/webp",
234
+ "image/heic",
235
+ "image/heif",
236
+ ],
237
+ maxBytes: 10485760,
238
+ maxRedirects: 3,
239
+ timeoutMs: 10000,
240
+ },
241
+ },
242
+ },
243
+ },
244
+ },
245
+ }
246
+ ```
247
+
248
+ Defaults when omitted:
249
+
250
+ - `maxBodyBytes`: 20MB
251
+ - `maxUrlParts`: 8
252
+ - `files.maxBytes`: 5MB
253
+ - `files.maxChars`: 200k
254
+ - `files.maxRedirects`: 3
255
+ - `files.timeoutMs`: 10s
256
+ - `files.pdf.maxPages`: 4
257
+ - `files.pdf.maxPixels`: 4,000,000
258
+ - `files.pdf.minTextChars`: 200
259
+ - `images.maxBytes`: 10MB
260
+ - `images.maxRedirects`: 3
261
+ - `images.timeoutMs`: 10s
262
+ - HEIC/HEIF `input_image` sources are accepted and normalized to JPEG before provider delivery.
263
+
264
+ Security note:
265
+
266
+ - URL allowlists are enforced before fetch and on redirect hops.
267
+ - Allowlisting a hostname does not bypass private/internal IP blocking.
268
+ - For internet-exposed gateways, apply network egress controls in addition to app-level guards.
269
+ See [Security](/gateway/security).
270
+
271
+ ## Streaming (SSE)
272
+
273
+ Set `stream: true` to receive Server-Sent Events (SSE):
274
+
275
+ - `Content-Type: text/event-stream`
276
+ - Each event line is `event: <type>` and `data: <json>`
277
+ - Stream ends with `data: [DONE]`
278
+
279
+ Event types currently emitted:
280
+
281
+ - `response.created`
282
+ - `response.in_progress`
283
+ - `response.output_item.added`
284
+ - `response.content_part.added`
285
+ - `response.output_text.delta`
286
+ - `response.output_text.done`
287
+ - `response.content_part.done`
288
+ - `response.output_item.done`
289
+ - `response.completed`
290
+ - `response.failed` (on error)
291
+
292
+ ## Usage
293
+
294
+ `usage` is populated when the underlying provider reports token counts.
295
+ Durar normalizes common OpenAI-style aliases before those counters reach
296
+ downstream status/session surfaces, including `input_tokens` / `output_tokens`
297
+ and `prompt_tokens` / `completion_tokens`.
298
+
299
+ ## Errors
300
+
301
+ Errors use a JSON object like:
302
+
303
+ ```json
304
+ { "error": { "message": "...", "type": "invalid_request_error" } }
305
+ ```
306
+
307
+ Common cases:
308
+
309
+ - `401` missing/invalid auth
310
+ - `400` invalid request body
311
+ - `405` wrong method
312
+
313
+ ## Examples
314
+
315
+ Non-streaming:
316
+
317
+ ```bash
318
+ curl -sS http://127.0.0.1:18789/v1/responses \
319
+ -H 'Authorization: Bearer YOUR_TOKEN' \
320
+ -H 'Content-Type: application/json' \
321
+ -H 'x-Durar-agent-id: main' \
322
+ -d '{
323
+ "model": "Durar",
324
+ "input": "hi"
325
+ }'
326
+ ```
327
+
328
+ Streaming:
329
+
330
+ ```bash
331
+ curl -N http://127.0.0.1:18789/v1/responses \
332
+ -H 'Authorization: Bearer YOUR_TOKEN' \
333
+ -H 'Content-Type: application/json' \
334
+ -H 'x-Durar-agent-id: main' \
335
+ -d '{
336
+ "model": "Durar",
337
+ "stream": true,
338
+ "input": "hi"
339
+ }'
340
+ ```
@@ -0,0 +1,307 @@
1
+ ---
2
+ title: OpenShell
3
+ summary: "Use OpenShell as a managed sandbox backend for Durar agents"
4
+ read_when:
5
+ - You want cloud-managed sandboxes instead of local Docker
6
+ - You are setting up the OpenShell plugin
7
+ - You need to choose between mirror and remote workspace modes
8
+ ---
9
+
10
+ # OpenShell
11
+
12
+ OpenShell is a managed sandbox backend for Durar. Instead of running Docker
13
+ containers locally, Durar delegates sandbox lifecycle to the `openshell` CLI,
14
+ which provisions remote environments with SSH-based command execution.
15
+
16
+ The OpenShell plugin reuses the same core SSH transport and remote filesystem
17
+ bridge as the generic [SSH backend](/gateway/sandboxing#ssh-backend). It adds
18
+ OpenShell-specific lifecycle (`sandbox create/get/delete`, `sandbox ssh-config`)
19
+ and an optional `mirror` workspace mode.
20
+
21
+ ## Prerequisites
22
+
23
+ - The `openshell` CLI installed and on `PATH` (or set a custom path via
24
+ `plugins.entries.openshell.config.command`)
25
+ - An OpenShell account with sandbox access
26
+ - Durar Gateway running on the host
27
+
28
+ ## Quick start
29
+
30
+ 1. Enable the plugin and set the sandbox backend:
31
+
32
+ ```json5
33
+ {
34
+ agents: {
35
+ defaults: {
36
+ sandbox: {
37
+ mode: "all",
38
+ backend: "openshell",
39
+ scope: "session",
40
+ workspaceAccess: "rw",
41
+ },
42
+ },
43
+ },
44
+ plugins: {
45
+ entries: {
46
+ openshell: {
47
+ enabled: true,
48
+ config: {
49
+ from: "Durar",
50
+ mode: "remote",
51
+ },
52
+ },
53
+ },
54
+ },
55
+ }
56
+ ```
57
+
58
+ 2. Restart the Gateway. On the next agent turn, Durar creates an OpenShell
59
+ sandbox and routes tool execution through it.
60
+
61
+ 3. Verify:
62
+
63
+ ```bash
64
+ Durar sandbox list
65
+ Durar sandbox explain
66
+ ```
67
+
68
+ ## Workspace modes
69
+
70
+ This is the most important decision when using OpenShell.
71
+
72
+ ### `mirror`
73
+
74
+ Use `plugins.entries.openshell.config.mode: "mirror"` when you want the **local
75
+ workspace to stay canonical**.
76
+
77
+ Behavior:
78
+
79
+ - Before `exec`, Durar syncs the local workspace into the OpenShell sandbox.
80
+ - After `exec`, Durar syncs the remote workspace back to the local workspace.
81
+ - File tools still operate through the sandbox bridge, but the local workspace
82
+ remains the source of truth between turns.
83
+
84
+ Best for:
85
+
86
+ - You edit files locally outside Durar and want those changes visible in the
87
+ sandbox automatically.
88
+ - You want the OpenShell sandbox to behave as much like the Docker backend as
89
+ possible.
90
+ - You want the host workspace to reflect sandbox writes after each exec turn.
91
+
92
+ Tradeoff: extra sync cost before and after each exec.
93
+
94
+ ### `remote`
95
+
96
+ Use `plugins.entries.openshell.config.mode: "remote"` when you want the
97
+ **OpenShell workspace to become canonical**.
98
+
99
+ Behavior:
100
+
101
+ - When the sandbox is first created, Durar seeds the remote workspace from
102
+ the local workspace once.
103
+ - After that, `exec`, `read`, `write`, `edit`, and `apply_patch` operate
104
+ directly against the remote OpenShell workspace.
105
+ - Durar does **not** sync remote changes back into the local workspace.
106
+ - Prompt-time media reads still work because file and media tools read through
107
+ the sandbox bridge.
108
+
109
+ Best for:
110
+
111
+ - The sandbox should live primarily on the remote side.
112
+ - You want lower per-turn sync overhead.
113
+ - You do not want host-local edits to silently overwrite remote sandbox state.
114
+
115
+ Important: if you edit files on the host outside Durar after the initial seed,
116
+ the remote sandbox does **not** see those changes. Use
117
+ `Durar sandbox recreate` to re-seed.
118
+
119
+ ### Choosing a mode
120
+
121
+ | | `mirror` | `remote` |
122
+ | ------------------------ | -------------------------- | ------------------------- |
123
+ | **Canonical workspace** | Local host | Remote OpenShell |
124
+ | **Sync direction** | Bidirectional (each exec) | One-time seed |
125
+ | **Per-turn overhead** | Higher (upload + download) | Lower (direct remote ops) |
126
+ | **Local edits visible?** | Yes, on next exec | No, until recreate |
127
+ | **Best for** | Development workflows | Long-running agents, CI |
128
+
129
+ ## Configuration reference
130
+
131
+ All OpenShell config lives under `plugins.entries.openshell.config`:
132
+
133
+ | Key | Type | Default | Description |
134
+ | ------------------------- | ------------------------ | ------------- | ----------------------------------------------------- |
135
+ | `mode` | `"mirror"` or `"remote"` | `"mirror"` | Workspace sync mode |
136
+ | `command` | `string` | `"openshell"` | Path or name of the `openshell` CLI |
137
+ | `from` | `string` | `"Durar"` | Sandbox source for first-time create |
138
+ | `gateway` | `string` | — | OpenShell gateway name (`--gateway`) |
139
+ | `gatewayEndpoint` | `string` | — | OpenShell gateway endpoint URL (`--gateway-endpoint`) |
140
+ | `policy` | `string` | — | OpenShell policy ID for sandbox creation |
141
+ | `providers` | `string[]` | `[]` | Provider names to attach when sandbox is created |
142
+ | `gpu` | `boolean` | `false` | Request GPU resources |
143
+ | `autoProviders` | `boolean` | `true` | Pass `--auto-providers` during sandbox create |
144
+ | `remoteWorkspaceDir` | `string` | `"/sandbox"` | Primary writable workspace inside the sandbox |
145
+ | `remoteAgentWorkspaceDir` | `string` | `"/agent"` | Agent workspace mount path (for read-only access) |
146
+ | `timeoutSeconds` | `number` | `120` | Timeout for `openshell` CLI operations |
147
+
148
+ Sandbox-level settings (`mode`, `scope`, `workspaceAccess`) are configured under
149
+ `agents.defaults.sandbox` as with any backend. See
150
+ [Sandboxing](/gateway/sandboxing) for the full matrix.
151
+
152
+ ## Examples
153
+
154
+ ### Minimal remote setup
155
+
156
+ ```json5
157
+ {
158
+ agents: {
159
+ defaults: {
160
+ sandbox: {
161
+ mode: "all",
162
+ backend: "openshell",
163
+ },
164
+ },
165
+ },
166
+ plugins: {
167
+ entries: {
168
+ openshell: {
169
+ enabled: true,
170
+ config: {
171
+ from: "Durar",
172
+ mode: "remote",
173
+ },
174
+ },
175
+ },
176
+ },
177
+ }
178
+ ```
179
+
180
+ ### Mirror mode with GPU
181
+
182
+ ```json5
183
+ {
184
+ agents: {
185
+ defaults: {
186
+ sandbox: {
187
+ mode: "all",
188
+ backend: "openshell",
189
+ scope: "agent",
190
+ workspaceAccess: "rw",
191
+ },
192
+ },
193
+ },
194
+ plugins: {
195
+ entries: {
196
+ openshell: {
197
+ enabled: true,
198
+ config: {
199
+ from: "Durar",
200
+ mode: "mirror",
201
+ gpu: true,
202
+ providers: ["openai"],
203
+ timeoutSeconds: 180,
204
+ },
205
+ },
206
+ },
207
+ },
208
+ }
209
+ ```
210
+
211
+ ### Per-agent OpenShell with custom gateway
212
+
213
+ ```json5
214
+ {
215
+ agents: {
216
+ defaults: {
217
+ sandbox: { mode: "off" },
218
+ },
219
+ list: [
220
+ {
221
+ id: "researcher",
222
+ sandbox: {
223
+ mode: "all",
224
+ backend: "openshell",
225
+ scope: "agent",
226
+ workspaceAccess: "rw",
227
+ },
228
+ },
229
+ ],
230
+ },
231
+ plugins: {
232
+ entries: {
233
+ openshell: {
234
+ enabled: true,
235
+ config: {
236
+ from: "Durar",
237
+ mode: "remote",
238
+ gateway: "lab",
239
+ gatewayEndpoint: "https://lab.example",
240
+ policy: "strict",
241
+ },
242
+ },
243
+ },
244
+ },
245
+ }
246
+ ```
247
+
248
+ ## Lifecycle management
249
+
250
+ OpenShell sandboxes are managed through the normal sandbox CLI:
251
+
252
+ ```bash
253
+ # List all sandbox runtimes (Docker + OpenShell)
254
+ Durar sandbox list
255
+
256
+ # Inspect effective policy
257
+ Durar sandbox explain
258
+
259
+ # Recreate (deletes remote workspace, re-seeds on next use)
260
+ Durar sandbox recreate --all
261
+ ```
262
+
263
+ For `remote` mode, **recreate is especially important**: it deletes the canonical
264
+ remote workspace for that scope. The next use seeds a fresh remote workspace from
265
+ the local workspace.
266
+
267
+ For `mirror` mode, recreate mainly resets the remote execution environment because
268
+ the local workspace remains canonical.
269
+
270
+ ### When to recreate
271
+
272
+ Recreate after changing any of these:
273
+
274
+ - `agents.defaults.sandbox.backend`
275
+ - `plugins.entries.openshell.config.from`
276
+ - `plugins.entries.openshell.config.mode`
277
+ - `plugins.entries.openshell.config.policy`
278
+
279
+ ```bash
280
+ Durar sandbox recreate --all
281
+ ```
282
+
283
+ ## Current limitations
284
+
285
+ - Sandbox browser is not supported on the OpenShell backend.
286
+ - `sandbox.docker.binds` does not apply to OpenShell.
287
+ - Docker-specific runtime knobs under `sandbox.docker.*` apply only to the Docker
288
+ backend.
289
+
290
+ ## How it works
291
+
292
+ 1. Durar calls `openshell sandbox create` (with `--from`, `--gateway`,
293
+ `--policy`, `--providers`, `--gpu` flags as configured).
294
+ 2. Durar calls `openshell sandbox ssh-config <name>` to get SSH connection
295
+ details for the sandbox.
296
+ 3. Core writes the SSH config to a temp file and opens an SSH session using the
297
+ same remote filesystem bridge as the generic SSH backend.
298
+ 4. In `mirror` mode: sync local to remote before exec, run, sync back after exec.
299
+ 5. In `remote` mode: seed once on create, then operate directly on the remote
300
+ workspace.
301
+
302
+ ## See also
303
+
304
+ - [Sandboxing](/gateway/sandboxing) -- modes, scopes, and backend comparison
305
+ - [Sandbox vs Tool Policy vs Elevated](/gateway/sandbox-vs-tool-policy-vs-elevated) -- debugging blocked tools
306
+ - [Multi-Agent Sandbox and Tools](/tools/multi-agent-sandbox-tools) -- per-agent overrides
307
+ - [Sandbox CLI](/cli/sandbox) -- `Durar sandbox` commands