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,698 @@
1
+ ---
2
+ summary: "Configuration overview: common tasks, quick setup, and links to the full reference"
3
+ read_when:
4
+ - Setting up Durar for the first time
5
+ - Looking for common configuration patterns
6
+ - Navigating to specific config sections
7
+ title: "Configuration"
8
+ ---
9
+
10
+ # Configuration
11
+
12
+ Durar reads an optional <Tooltip tip="JSON5 supports comments and trailing commas">**JSON5**</Tooltip> config from `~/.Durar/Durar.json`.
13
+
14
+ If the file is missing, Durar uses safe defaults. Common reasons to add a config:
15
+
16
+ - Connect channels and control who can message the bot
17
+ - Set models, tools, sandboxing, or automation (cron, hooks)
18
+ - Tune sessions, media, networking, or UI
19
+
20
+ See the [full reference](/gateway/configuration-reference) for every available field.
21
+
22
+ <Tip>
23
+ **New to configuration?** Start with `Durar onboard` for interactive setup, or check out the [Configuration Examples](/gateway/configuration-examples) guide for complete copy-paste configs.
24
+ </Tip>
25
+
26
+ ## Minimal config
27
+
28
+ ```json5
29
+ // ~/.Durar/Durar.json
30
+ {
31
+ agents: { defaults: { workspace: "~/.Durar/workspace" } },
32
+ channels: { whatsapp: { allowFrom: ["+15555550123"] } },
33
+ }
34
+ ```
35
+
36
+ ## Editing config
37
+
38
+ <Tabs>
39
+ <Tab title="Interactive wizard">
40
+ ```bash
41
+ Durar onboard # full onboarding flow
42
+ Durar configure # config wizard
43
+ ```
44
+ </Tab>
45
+ <Tab title="CLI (one-liners)">
46
+ ```bash
47
+ Durar config get agents.defaults.workspace
48
+ Durar config set agents.defaults.heartbeat.every "2h"
49
+ Durar config unset plugins.entries.brave.config.webSearch.apiKey
50
+ ```
51
+ </Tab>
52
+ <Tab title="Control UI">
53
+ Open [http://127.0.0.1:18789](http://127.0.0.1:18789) and use the **Config** tab.
54
+ The Control UI renders a form from the live config schema, including field
55
+ `title` / `description` docs metadata plus plugin and channel schemas when
56
+ available, with a **Raw JSON** editor as an escape hatch. For drill-down
57
+ UIs and other tooling, the gateway also exposes `config.schema.lookup` to
58
+ fetch one path-scoped schema node plus immediate child summaries.
59
+ </Tab>
60
+ <Tab title="Direct edit">
61
+ Edit `~/.Durar/Durar.json` directly. The Gateway watches the file and applies changes automatically (see [hot reload](#config-hot-reload)).
62
+ </Tab>
63
+ </Tabs>
64
+
65
+ ## Strict validation
66
+
67
+ <Warning>
68
+ Durar only accepts configurations that fully match the schema. Unknown keys, malformed types, or invalid values cause the Gateway to **refuse to start**. The only root-level exception is `$schema` (string), so editors can attach JSON Schema metadata.
69
+ </Warning>
70
+
71
+ Schema tooling notes:
72
+
73
+ - `Durar config schema` prints the same JSON Schema family used by Control UI
74
+ and config validation.
75
+ - Field `title` and `description` values are carried into the schema output for
76
+ editor and form tooling.
77
+ - Nested object, wildcard (`*`), and array-item (`[]`) entries inherit the same
78
+ docs metadata where matching field documentation exists.
79
+ - `anyOf` / `oneOf` / `allOf` composition branches inherit the same docs
80
+ metadata too, so union/intersection variants keep the same field help.
81
+ - `config.schema.lookup` returns one normalized config path with a shallow
82
+ schema node (`title`, `description`, `type`, `enum`, `const`, common bounds,
83
+ and similar validation fields), matched UI hint metadata, and immediate child
84
+ summaries for drill-down tooling.
85
+ - Runtime plugin/channel schemas are merged in when the gateway can load the
86
+ current manifest registry.
87
+
88
+ When validation fails:
89
+
90
+ - The Gateway does not boot
91
+ - Only diagnostic commands work (`Durar doctor`, `Durar logs`, `Durar health`, `Durar status`)
92
+ - Run `Durar doctor` to see exact issues
93
+ - Run `Durar doctor --fix` (or `--yes`) to apply repairs
94
+
95
+ ## Common tasks
96
+
97
+ <AccordionGroup>
98
+ <Accordion title="Set up a channel (WhatsApp, Telegram, Discord, etc.)">
99
+ Each channel has its own config section under `channels.<provider>`. See the dedicated channel page for setup steps:
100
+
101
+ - [WhatsApp](/channels/whatsapp) — `channels.whatsapp`
102
+ - [Telegram](/channels/telegram) — `channels.telegram`
103
+ - [Discord](/channels/discord) — `channels.discord`
104
+ - [Feishu](/channels/feishu) — `channels.feishu`
105
+ - [Google Chat](/channels/googlechat) — `channels.googlechat`
106
+ - [Microsoft Teams](/channels/msteams) — `channels.msteams`
107
+ - [Slack](/channels/slack) — `channels.slack`
108
+ - [Signal](/channels/signal) — `channels.signal`
109
+ - [iMessage](/channels/imessage) — `channels.imessage`
110
+ - [Mattermost](/channels/mattermost) — `channels.mattermost`
111
+
112
+ All channels share the same DM policy pattern:
113
+
114
+ ```json5
115
+ {
116
+ channels: {
117
+ telegram: {
118
+ enabled: true,
119
+ botToken: "123:abc",
120
+ dmPolicy: "pairing", // pairing | allowlist | open | disabled
121
+ allowFrom: ["tg:123"], // only for allowlist/open
122
+ },
123
+ },
124
+ }
125
+ ```
126
+
127
+ </Accordion>
128
+
129
+ <Accordion title="Choose and configure models">
130
+ Set the primary model and optional fallbacks:
131
+
132
+ ```json5
133
+ {
134
+ agents: {
135
+ defaults: {
136
+ model: {
137
+ primary: "anthropic/claude-sonnet-4-6",
138
+ fallbacks: ["openai/gpt-5.4"],
139
+ },
140
+ models: {
141
+ "anthropic/claude-sonnet-4-6": { alias: "Sonnet" },
142
+ "openai/gpt-5.4": { alias: "GPT" },
143
+ },
144
+ },
145
+ },
146
+ }
147
+ ```
148
+
149
+ - `agents.defaults.models` defines the model catalog and acts as the allowlist for `/model`.
150
+ - Model refs use `provider/model` format (e.g. `anthropic/claude-opus-4-6`).
151
+ - `agents.defaults.imageMaxDimensionPx` controls transcript/tool image downscaling (default `1200`); lower values usually reduce vision-token usage on screenshot-heavy runs.
152
+ - See [Models CLI](/concepts/models) for switching models in chat and [Model Failover](/concepts/model-failover) for auth rotation and fallback behavior.
153
+ - For custom/self-hosted providers, see [Custom providers](/gateway/configuration-reference#custom-providers-and-base-urls) in the reference.
154
+
155
+ </Accordion>
156
+
157
+ <Accordion title="Control who can message the bot">
158
+ DM access is controlled per channel via `dmPolicy`:
159
+
160
+ - `"pairing"` (default): unknown senders get a one-time pairing code to approve
161
+ - `"allowlist"`: only senders in `allowFrom` (or the paired allow store)
162
+ - `"open"`: allow all inbound DMs (requires `allowFrom: ["*"]`)
163
+ - `"disabled"`: ignore all DMs
164
+
165
+ For groups, use `groupPolicy` + `groupAllowFrom` or channel-specific allowlists.
166
+
167
+ See the [full reference](/gateway/configuration-reference#dm-and-group-access) for per-channel details.
168
+
169
+ </Accordion>
170
+
171
+ <Accordion title="Set up group chat mention gating">
172
+ Group messages default to **require mention**. Configure patterns per agent:
173
+
174
+ ```json5
175
+ {
176
+ agents: {
177
+ list: [
178
+ {
179
+ id: "main",
180
+ groupChat: {
181
+ mentionPatterns: ["@Durar", "Durar"],
182
+ },
183
+ },
184
+ ],
185
+ },
186
+ channels: {
187
+ whatsapp: {
188
+ groups: { "*": { requireMention: true } },
189
+ },
190
+ },
191
+ }
192
+ ```
193
+
194
+ - **Metadata mentions**: native @-mentions (WhatsApp tap-to-mention, Telegram @bot, etc.)
195
+ - **Text patterns**: safe regex patterns in `mentionPatterns`
196
+ - See [full reference](/gateway/configuration-reference#group-chat-mention-gating) for per-channel overrides and self-chat mode.
197
+
198
+ </Accordion>
199
+
200
+ <Accordion title="Restrict skills per agent">
201
+ Use `agents.defaults.skills` for a shared baseline, then override specific
202
+ agents with `agents.list[].skills`:
203
+
204
+ ```json5
205
+ {
206
+ agents: {
207
+ defaults: {
208
+ skills: ["github", "weather"],
209
+ },
210
+ list: [
211
+ { id: "writer" }, // inherits github, weather
212
+ { id: "docs", skills: ["docs-search"] }, // replaces defaults
213
+ { id: "locked-down", skills: [] }, // no skills
214
+ ],
215
+ },
216
+ }
217
+ ```
218
+
219
+ - Omit `agents.defaults.skills` for unrestricted skills by default.
220
+ - Omit `agents.list[].skills` to inherit the defaults.
221
+ - Set `agents.list[].skills: []` for no skills.
222
+ - See [Skills](/tools/skills), [Skills config](/tools/skills-config), and
223
+ the [Configuration Reference](/gateway/configuration-reference#agentsdefaultsskills).
224
+
225
+ </Accordion>
226
+
227
+ <Accordion title="Tune gateway channel health monitoring">
228
+ Control how aggressively the gateway restarts channels that look stale:
229
+
230
+ ```json5
231
+ {
232
+ gateway: {
233
+ channelHealthCheckMinutes: 5,
234
+ channelStaleEventThresholdMinutes: 30,
235
+ channelMaxRestartsPerHour: 10,
236
+ },
237
+ channels: {
238
+ telegram: {
239
+ healthMonitor: { enabled: false },
240
+ accounts: {
241
+ alerts: {
242
+ healthMonitor: { enabled: true },
243
+ },
244
+ },
245
+ },
246
+ },
247
+ }
248
+ ```
249
+
250
+ - Set `gateway.channelHealthCheckMinutes: 0` to disable health-monitor restarts globally.
251
+ - `channelStaleEventThresholdMinutes` should be greater than or equal to the check interval.
252
+ - Use `channels.<provider>.healthMonitor.enabled` or `channels.<provider>.accounts.<id>.healthMonitor.enabled` to disable auto-restarts for one channel or account without disabling the global monitor.
253
+ - See [Health Checks](/gateway/health) for operational debugging and the [full reference](/gateway/configuration-reference#gateway) for all fields.
254
+
255
+ </Accordion>
256
+
257
+ <Accordion title="Configure sessions and resets">
258
+ Sessions control conversation continuity and isolation:
259
+
260
+ ```json5
261
+ {
262
+ session: {
263
+ dmScope: "per-channel-peer", // recommended for multi-user
264
+ threadBindings: {
265
+ enabled: true,
266
+ idleHours: 24,
267
+ maxAgeHours: 0,
268
+ },
269
+ reset: {
270
+ mode: "daily",
271
+ atHour: 4,
272
+ idleMinutes: 120,
273
+ },
274
+ },
275
+ }
276
+ ```
277
+
278
+ - `dmScope`: `main` (shared) | `per-peer` | `per-channel-peer` | `per-account-channel-peer`
279
+ - `threadBindings`: global defaults for thread-bound session routing (Discord supports `/focus`, `/unfocus`, `/agents`, `/session idle`, and `/session max-age`).
280
+ - See [Session Management](/concepts/session) for scoping, identity links, and send policy.
281
+ - See [full reference](/gateway/configuration-reference#session) for all fields.
282
+
283
+ </Accordion>
284
+
285
+ <Accordion title="Enable sandboxing">
286
+ Run agent sessions in isolated Docker containers:
287
+
288
+ ```json5
289
+ {
290
+ agents: {
291
+ defaults: {
292
+ sandbox: {
293
+ mode: "non-main", // off | non-main | all
294
+ scope: "agent", // session | agent | shared
295
+ },
296
+ },
297
+ },
298
+ }
299
+ ```
300
+
301
+ Build the image first: `scripts/sandbox-setup.sh`
302
+
303
+ See [Sandboxing](/gateway/sandboxing) for the full guide and [full reference](/gateway/configuration-reference#agentsdefaultssandbox) for all options.
304
+
305
+ </Accordion>
306
+
307
+ <Accordion title="Enable relay-backed push for official iOS builds">
308
+ Relay-backed push is configured in `Durar.json`.
309
+
310
+ Set this in gateway config:
311
+
312
+ ```json5
313
+ {
314
+ gateway: {
315
+ push: {
316
+ apns: {
317
+ relay: {
318
+ baseUrl: "https://relay.example.com",
319
+ // Optional. Default: 10000
320
+ timeoutMs: 10000,
321
+ },
322
+ },
323
+ },
324
+ },
325
+ }
326
+ ```
327
+
328
+ CLI equivalent:
329
+
330
+ ```bash
331
+ Durar config set gateway.push.apns.relay.baseUrl https://relay.example.com
332
+ ```
333
+
334
+ What this does:
335
+
336
+ - Lets the gateway send `push.test`, wake nudges, and reconnect wakes through the external relay.
337
+ - Uses a registration-scoped send grant forwarded by the paired iOS app. The gateway does not need a deployment-wide relay token.
338
+ - Binds each relay-backed registration to the gateway identity that the iOS app paired with, so another gateway cannot reuse the stored registration.
339
+ - Keeps local/manual iOS builds on direct APNs. Relay-backed sends apply only to official distributed builds that registered through the relay.
340
+ - Must match the relay base URL baked into the official/TestFlight iOS build, so registration and send traffic reach the same relay deployment.
341
+
342
+ End-to-end flow:
343
+
344
+ 1. Install an official/TestFlight iOS build that was compiled with the same relay base URL.
345
+ 2. Configure `gateway.push.apns.relay.baseUrl` on the gateway.
346
+ 3. Pair the iOS app to the gateway and let both node and operator sessions connect.
347
+ 4. The iOS app fetches the gateway identity, registers with the relay using App Attest plus the app receipt, and then publishes the relay-backed `push.apns.register` payload to the paired gateway.
348
+ 5. The gateway stores the relay handle and send grant, then uses them for `push.test`, wake nudges, and reconnect wakes.
349
+
350
+ Operational notes:
351
+
352
+ - If you switch the iOS app to a different gateway, reconnect the app so it can publish a new relay registration bound to that gateway.
353
+ - If you ship a new iOS build that points at a different relay deployment, the app refreshes its cached relay registration instead of reusing the old relay origin.
354
+
355
+ Compatibility note:
356
+
357
+ - `Durar_APNS_RELAY_BASE_URL` and `Durar_APNS_RELAY_TIMEOUT_MS` still work as temporary env overrides.
358
+ - `Durar_APNS_RELAY_ALLOW_HTTP=true` remains a loopback-only development escape hatch; do not persist HTTP relay URLs in config.
359
+
360
+ See [iOS App](/platforms/ios#relay-backed-push-for-official-builds) for the end-to-end flow and [Authentication and trust flow](/platforms/ios#authentication-and-trust-flow) for the relay security model.
361
+
362
+ </Accordion>
363
+
364
+ <Accordion title="Set up heartbeat (periodic check-ins)">
365
+ ```json5
366
+ {
367
+ agents: {
368
+ defaults: {
369
+ heartbeat: {
370
+ every: "30m",
371
+ target: "last",
372
+ },
373
+ },
374
+ },
375
+ }
376
+ ```
377
+
378
+ - `every`: duration string (`30m`, `2h`). Set `0m` to disable.
379
+ - `target`: `last` | `none` | `<channel-id>` (for example `discord`, `matrix`, `telegram`, or `whatsapp`)
380
+ - `directPolicy`: `allow` (default) or `block` for DM-style heartbeat targets
381
+ - See [Heartbeat](/gateway/heartbeat) for the full guide.
382
+
383
+ </Accordion>
384
+
385
+ <Accordion title="Configure cron jobs">
386
+ ```json5
387
+ {
388
+ cron: {
389
+ enabled: true,
390
+ maxConcurrentRuns: 2,
391
+ sessionRetention: "24h",
392
+ runLog: {
393
+ maxBytes: "2mb",
394
+ keepLines: 2000,
395
+ },
396
+ },
397
+ }
398
+ ```
399
+
400
+ - `sessionRetention`: prune completed isolated run sessions from `sessions.json` (default `24h`; set `false` to disable).
401
+ - `runLog`: prune `cron/runs/<jobId>.jsonl` by size and retained lines.
402
+ - See [Cron jobs](/automation/cron-jobs) for feature overview and CLI examples.
403
+
404
+ </Accordion>
405
+
406
+ <Accordion title="Set up webhooks (hooks)">
407
+ Enable HTTP webhook endpoints on the Gateway:
408
+
409
+ ```json5
410
+ {
411
+ hooks: {
412
+ enabled: true,
413
+ token: "shared-secret",
414
+ path: "/hooks",
415
+ defaultSessionKey: "hook:ingress",
416
+ allowRequestSessionKey: false,
417
+ allowedSessionKeyPrefixes: ["hook:"],
418
+ mappings: [
419
+ {
420
+ match: { path: "gmail" },
421
+ action: "agent",
422
+ agentId: "main",
423
+ deliver: true,
424
+ },
425
+ ],
426
+ },
427
+ }
428
+ ```
429
+
430
+ Security note:
431
+ - Treat all hook/webhook payload content as untrusted input.
432
+ - Use a dedicated `hooks.token`; do not reuse the shared Gateway token.
433
+ - Hook auth is header-only (`Authorization: Bearer ...` or `x-Durar-token`); query-string tokens are rejected.
434
+ - `hooks.path` cannot be `/`; keep webhook ingress on a dedicated subpath such as `/hooks`.
435
+ - Keep unsafe-content bypass flags disabled (`hooks.gmail.allowUnsafeExternalContent`, `hooks.mappings[].allowUnsafeExternalContent`) unless doing tightly scoped debugging.
436
+ - If you enable `hooks.allowRequestSessionKey`, also set `hooks.allowedSessionKeyPrefixes` to bound caller-selected session keys.
437
+ - For hook-driven agents, prefer strong modern model tiers and strict tool policy (for example messaging-only plus sandboxing where possible).
438
+
439
+ See [full reference](/gateway/configuration-reference#hooks) for all mapping options and Gmail integration.
440
+
441
+ </Accordion>
442
+
443
+ <Accordion title="Configure multi-agent routing">
444
+ Run multiple isolated agents with separate workspaces and sessions:
445
+
446
+ ```json5
447
+ {
448
+ agents: {
449
+ list: [
450
+ { id: "home", default: true, workspace: "~/.Durar/workspace-home" },
451
+ { id: "work", workspace: "~/.Durar/workspace-work" },
452
+ ],
453
+ },
454
+ bindings: [
455
+ { agentId: "home", match: { channel: "whatsapp", accountId: "personal" } },
456
+ { agentId: "work", match: { channel: "whatsapp", accountId: "biz" } },
457
+ ],
458
+ }
459
+ ```
460
+
461
+ See [Multi-Agent](/concepts/multi-agent) and [full reference](/gateway/configuration-reference#multi-agent-routing) for binding rules and per-agent access profiles.
462
+
463
+ </Accordion>
464
+
465
+ <Accordion title="Split config into multiple files ($include)">
466
+ Use `$include` to organize large configs:
467
+
468
+ ```json5
469
+ // ~/.Durar/Durar.json
470
+ {
471
+ gateway: { port: 18789 },
472
+ agents: { $include: "./agents.json5" },
473
+ broadcast: {
474
+ $include: ["./clients/a.json5", "./clients/b.json5"],
475
+ },
476
+ }
477
+ ```
478
+
479
+ - **Single file**: replaces the containing object
480
+ - **Array of files**: deep-merged in order (later wins)
481
+ - **Sibling keys**: merged after includes (override included values)
482
+ - **Nested includes**: supported up to 10 levels deep
483
+ - **Relative paths**: resolved relative to the including file
484
+ - **Error handling**: clear errors for missing files, parse errors, and circular includes
485
+
486
+ </Accordion>
487
+ </AccordionGroup>
488
+
489
+ ## Config hot reload
490
+
491
+ The Gateway watches `~/.Durar/Durar.json` and applies changes automatically — no manual restart needed for most settings.
492
+
493
+ ### Reload modes
494
+
495
+ | Mode | Behavior |
496
+ | ---------------------- | --------------------------------------------------------------------------------------- |
497
+ | **`hybrid`** (default) | Hot-applies safe changes instantly. Automatically restarts for critical ones. |
498
+ | **`hot`** | Hot-applies safe changes only. Logs a warning when a restart is needed — you handle it. |
499
+ | **`restart`** | Restarts the Gateway on any config change, safe or not. |
500
+ | **`off`** | Disables file watching. Changes take effect on the next manual restart. |
501
+
502
+ ```json5
503
+ {
504
+ gateway: {
505
+ reload: { mode: "hybrid", debounceMs: 300 },
506
+ },
507
+ }
508
+ ```
509
+
510
+ ### What hot-applies vs what needs a restart
511
+
512
+ Most fields hot-apply without downtime. In `hybrid` mode, restart-required changes are handled automatically.
513
+
514
+ | Category | Fields | Restart needed? |
515
+ | ------------------- | -------------------------------------------------------------------- | --------------- |
516
+ | Channels | `channels.*`, `web` (WhatsApp) — all built-in and extension channels | No |
517
+ | Agent & models | `agent`, `agents`, `models`, `routing` | No |
518
+ | Automation | `hooks`, `cron`, `agent.heartbeat` | No |
519
+ | Sessions & messages | `session`, `messages` | No |
520
+ | Tools & media | `tools`, `browser`, `skills`, `audio`, `talk` | No |
521
+ | UI & misc | `ui`, `logging`, `identity`, `bindings` | No |
522
+ | Gateway server | `gateway.*` (port, bind, auth, tailscale, TLS, HTTP) | **Yes** |
523
+ | Infrastructure | `discovery`, `canvasHost`, `plugins` | **Yes** |
524
+
525
+ <Note>
526
+ `gateway.reload` and `gateway.remote` are exceptions — changing them does **not** trigger a restart.
527
+ </Note>
528
+
529
+ ## Config RPC (programmatic updates)
530
+
531
+ <Note>
532
+ Control-plane write RPCs (`config.apply`, `config.patch`, `update.run`) are rate-limited to **3 requests per 60 seconds** per `deviceId+clientIp`. When limited, the RPC returns `UNAVAILABLE` with `retryAfterMs`.
533
+ </Note>
534
+
535
+ Safe/default flow:
536
+
537
+ - `config.schema.lookup`: inspect one path-scoped config subtree with a shallow
538
+ schema node, matched hint metadata, and immediate child summaries
539
+ - `config.get`: fetch the current snapshot + hash
540
+ - `config.patch`: preferred partial update path
541
+ - `config.apply`: full-config replacement only
542
+ - `update.run`: explicit self-update + restart
543
+
544
+ When you are not replacing the entire config, prefer `config.schema.lookup`
545
+ then `config.patch`.
546
+
547
+ <AccordionGroup>
548
+ <Accordion title="config.apply (full replace)">
549
+ Validates + writes the full config and restarts the Gateway in one step.
550
+
551
+ <Warning>
552
+ `config.apply` replaces the **entire config**. Use `config.patch` for partial updates, or `Durar config set` for single keys.
553
+ </Warning>
554
+
555
+ Params:
556
+
557
+ - `raw` (string) — JSON5 payload for the entire config
558
+ - `baseHash` (optional) — config hash from `config.get` (required when config exists)
559
+ - `sessionKey` (optional) — session key for the post-restart wake-up ping
560
+ - `note` (optional) — note for the restart sentinel
561
+ - `restartDelayMs` (optional) — delay before restart (default 2000)
562
+
563
+ Restart requests are coalesced while one is already pending/in-flight, and a 30-second cooldown applies between restart cycles.
564
+
565
+ ```bash
566
+ Durar gateway call config.get --params '{}' # capture payload.hash
567
+ Durar gateway call config.apply --params '{
568
+ "raw": "{ agents: { defaults: { workspace: \"~/.Durar/workspace\" } } }",
569
+ "baseHash": "<hash>",
570
+ "sessionKey": "agent:main:whatsapp:direct:+15555550123"
571
+ }'
572
+ ```
573
+
574
+ </Accordion>
575
+
576
+ <Accordion title="config.patch (partial update)">
577
+ Merges a partial update into the existing config (JSON merge patch semantics):
578
+
579
+ - Objects merge recursively
580
+ - `null` deletes a key
581
+ - Arrays replace
582
+
583
+ Params:
584
+
585
+ - `raw` (string) — JSON5 with just the keys to change
586
+ - `baseHash` (required) — config hash from `config.get`
587
+ - `sessionKey`, `note`, `restartDelayMs` — same as `config.apply`
588
+
589
+ Restart behavior matches `config.apply`: coalesced pending restarts plus a 30-second cooldown between restart cycles.
590
+
591
+ ```bash
592
+ Durar gateway call config.patch --params '{
593
+ "raw": "{ channels: { telegram: { groups: { \"*\": { requireMention: false } } } } }",
594
+ "baseHash": "<hash>"
595
+ }'
596
+ ```
597
+
598
+ </Accordion>
599
+ </AccordionGroup>
600
+
601
+ ## Environment variables
602
+
603
+ Durar reads env vars from the parent process plus:
604
+
605
+ - `.env` from the current working directory (if present)
606
+ - `~/.Durar/.env` (global fallback)
607
+
608
+ Neither file overrides existing env vars. You can also set inline env vars in config:
609
+
610
+ ```json5
611
+ {
612
+ env: {
613
+ OPENROUTER_API_KEY: "sk-or-...",
614
+ vars: { GROQ_API_KEY: "gsk-..." },
615
+ },
616
+ }
617
+ ```
618
+
619
+ <Accordion title="Shell env import (optional)">
620
+ If enabled and expected keys aren't set, Durar runs your login shell and imports only the missing keys:
621
+
622
+ ```json5
623
+ {
624
+ env: {
625
+ shellEnv: { enabled: true, timeoutMs: 15000 },
626
+ },
627
+ }
628
+ ```
629
+
630
+ Env var equivalent: `Durar_LOAD_SHELL_ENV=1`
631
+ </Accordion>
632
+
633
+ <Accordion title="Env var substitution in config values">
634
+ Reference env vars in any config string value with `${VAR_NAME}`:
635
+
636
+ ```json5
637
+ {
638
+ gateway: { auth: { token: "${Durar_GATEWAY_TOKEN}" } },
639
+ models: { providers: { custom: { apiKey: "${CUSTOM_API_KEY}" } } },
640
+ }
641
+ ```
642
+
643
+ Rules:
644
+
645
+ - Only uppercase names matched: `[A-Z_][A-Z0-9_]*`
646
+ - Missing/empty vars throw an error at load time
647
+ - Escape with `$${VAR}` for literal output
648
+ - Works inside `$include` files
649
+ - Inline substitution: `"${BASE}/v1"` → `"https://api.example.com/v1"`
650
+
651
+ </Accordion>
652
+
653
+ <Accordion title="Secret refs (env, file, exec)">
654
+ For fields that support SecretRef objects, you can use:
655
+
656
+ ```json5
657
+ {
658
+ models: {
659
+ providers: {
660
+ openai: { apiKey: { source: "env", provider: "default", id: "OPENAI_API_KEY" } },
661
+ },
662
+ },
663
+ skills: {
664
+ entries: {
665
+ "image-lab": {
666
+ apiKey: {
667
+ source: "file",
668
+ provider: "filemain",
669
+ id: "/skills/entries/image-lab/apiKey",
670
+ },
671
+ },
672
+ },
673
+ },
674
+ channels: {
675
+ googlechat: {
676
+ serviceAccountRef: {
677
+ source: "exec",
678
+ provider: "vault",
679
+ id: "channels/googlechat/serviceAccount",
680
+ },
681
+ },
682
+ },
683
+ }
684
+ ```
685
+
686
+ SecretRef details (including `secrets.providers` for `env`/`file`/`exec`) are in [Secrets Management](/gateway/secrets).
687
+ Supported credential paths are listed in [SecretRef Credential Surface](/reference/secretref-credential-surface).
688
+ </Accordion>
689
+
690
+ See [Environment](/help/environment) for full precedence and sources.
691
+
692
+ ## Full reference
693
+
694
+ For the complete field-by-field reference, see **[Configuration Reference](/gateway/configuration-reference)**.
695
+
696
+ ---
697
+
698
+ _Related: [Configuration Examples](/gateway/configuration-examples) · [Configuration Reference](/gateway/configuration-reference) · [Doctor](/gateway/doctor)_