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,541 @@
1
+ ---
2
+ summary: "Secrets management: SecretRef contract, runtime snapshot behavior, and safe one-way scrubbing"
3
+ read_when:
4
+ - Configuring SecretRefs for provider credentials and `auth-profiles.json` refs
5
+ - Operating secrets reload, audit, configure, and apply safely in production
6
+ - Understanding startup fail-fast, inactive-surface filtering, and last-known-good behavior
7
+ title: "Secrets Management"
8
+ ---
9
+
10
+ # Secrets management
11
+
12
+ Durar supports additive SecretRefs so supported credentials do not need to be stored as plaintext in configuration.
13
+
14
+ Plaintext still works. SecretRefs are opt-in per credential.
15
+
16
+ ## Goals and runtime model
17
+
18
+ Secrets are resolved into an in-memory runtime snapshot.
19
+
20
+ - Resolution is eager during activation, not lazy on request paths.
21
+ - Startup fails fast when an effectively active SecretRef cannot be resolved.
22
+ - Reload uses atomic swap: full success, or keep the last-known-good snapshot.
23
+ - SecretRef policy violations (for example OAuth-mode auth profiles combined with SecretRef input) fail activation before runtime swap.
24
+ - Runtime requests read from the active in-memory snapshot only.
25
+ - After the first successful config activation/load, runtime code paths keep reading that active in-memory snapshot until a successful reload swaps it.
26
+ - Outbound delivery paths also read from that active snapshot (for example Discord reply/thread delivery and Telegram action sends); they do not re-resolve SecretRefs on each send.
27
+
28
+ This keeps secret-provider outages off hot request paths.
29
+
30
+ ## Active-surface filtering
31
+
32
+ SecretRefs are validated only on effectively active surfaces.
33
+
34
+ - Enabled surfaces: unresolved refs block startup/reload.
35
+ - Inactive surfaces: unresolved refs do not block startup/reload.
36
+ - Inactive refs emit non-fatal diagnostics with code `SECRETS_REF_IGNORED_INACTIVE_SURFACE`.
37
+
38
+ Examples of inactive surfaces:
39
+
40
+ - Disabled channel/account entries.
41
+ - Top-level channel credentials that no enabled account inherits.
42
+ - Disabled tool/feature surfaces.
43
+ - Web search provider-specific keys that are not selected by `tools.web.search.provider`.
44
+ In auto mode (provider unset), keys are consulted by precedence for provider auto-detection until one resolves.
45
+ After selection, non-selected provider keys are treated as inactive until selected.
46
+ - Sandbox SSH auth material (`agents.defaults.sandbox.ssh.identityData`,
47
+ `certificateData`, `knownHostsData`, plus per-agent overrides) is active only
48
+ when the effective sandbox backend is `ssh` for the default agent or an enabled agent.
49
+ - `gateway.remote.token` / `gateway.remote.password` SecretRefs are active if one of these is true:
50
+ - `gateway.mode=remote`
51
+ - `gateway.remote.url` is configured
52
+ - `gateway.tailscale.mode` is `serve` or `funnel`
53
+ - In local mode without those remote surfaces:
54
+ - `gateway.remote.token` is active when token auth can win and no env/auth token is configured.
55
+ - `gateway.remote.password` is active only when password auth can win and no env/auth password is configured.
56
+ - `gateway.auth.token` SecretRef is inactive for startup auth resolution when `Durar_GATEWAY_TOKEN` is set, because env token input wins for that runtime.
57
+
58
+ ## Gateway auth surface diagnostics
59
+
60
+ When a SecretRef is configured on `gateway.auth.token`, `gateway.auth.password`,
61
+ `gateway.remote.token`, or `gateway.remote.password`, gateway startup/reload logs the
62
+ surface state explicitly:
63
+
64
+ - `active`: the SecretRef is part of the effective auth surface and must resolve.
65
+ - `inactive`: the SecretRef is ignored for this runtime because another auth surface wins, or
66
+ because remote auth is disabled/not active.
67
+
68
+ These entries are logged with `SECRETS_GATEWAY_AUTH_SURFACE` and include the reason used by the
69
+ active-surface policy, so you can see why a credential was treated as active or inactive.
70
+
71
+ ## Onboarding reference preflight
72
+
73
+ When onboarding runs in interactive mode and you choose SecretRef storage, Durar runs preflight validation before saving:
74
+
75
+ - Env refs: validates env var name and confirms a non-empty value is visible during setup.
76
+ - Provider refs (`file` or `exec`): validates provider selection, resolves `id`, and checks resolved value type.
77
+ - Quickstart reuse path: when `gateway.auth.token` is already a SecretRef, onboarding resolves it before probe/dashboard bootstrap (for `env`, `file`, and `exec` refs) using the same fail-fast gate.
78
+
79
+ If validation fails, onboarding shows the error and lets you retry.
80
+
81
+ ## SecretRef contract
82
+
83
+ Use one object shape everywhere:
84
+
85
+ ```json5
86
+ { source: "env" | "file" | "exec", provider: "default", id: "..." }
87
+ ```
88
+
89
+ ### `source: "env"`
90
+
91
+ ```json5
92
+ { source: "env", provider: "default", id: "OPENAI_API_KEY" }
93
+ ```
94
+
95
+ Validation:
96
+
97
+ - `provider` must match `^[a-z][a-z0-9_-]{0,63}$`
98
+ - `id` must match `^[A-Z][A-Z0-9_]{0,127}$`
99
+
100
+ ### `source: "file"`
101
+
102
+ ```json5
103
+ { source: "file", provider: "filemain", id: "/providers/openai/apiKey" }
104
+ ```
105
+
106
+ Validation:
107
+
108
+ - `provider` must match `^[a-z][a-z0-9_-]{0,63}$`
109
+ - `id` must be an absolute JSON pointer (`/...`)
110
+ - RFC6901 escaping in segments: `~` => `~0`, `/` => `~1`
111
+
112
+ ### `source: "exec"`
113
+
114
+ ```json5
115
+ { source: "exec", provider: "vault", id: "providers/openai/apiKey" }
116
+ ```
117
+
118
+ Validation:
119
+
120
+ - `provider` must match `^[a-z][a-z0-9_-]{0,63}$`
121
+ - `id` must match `^[A-Za-z0-9][A-Za-z0-9._:/-]{0,255}$`
122
+ - `id` must not contain `.` or `..` as slash-delimited path segments (for example `a/../b` is rejected)
123
+
124
+ ## Provider config
125
+
126
+ Define providers under `secrets.providers`:
127
+
128
+ ```json5
129
+ {
130
+ secrets: {
131
+ providers: {
132
+ default: { source: "env" },
133
+ filemain: {
134
+ source: "file",
135
+ path: "~/.Durar/secrets.json",
136
+ mode: "json", // or "singleValue"
137
+ },
138
+ vault: {
139
+ source: "exec",
140
+ command: "/usr/local/bin/Durar-vault-resolver",
141
+ args: ["--profile", "prod"],
142
+ passEnv: ["PATH", "VAULT_ADDR"],
143
+ jsonOnly: true,
144
+ },
145
+ },
146
+ defaults: {
147
+ env: "default",
148
+ file: "filemain",
149
+ exec: "vault",
150
+ },
151
+ resolution: {
152
+ maxProviderConcurrency: 4,
153
+ maxRefsPerProvider: 512,
154
+ maxBatchBytes: 262144,
155
+ },
156
+ },
157
+ }
158
+ ```
159
+
160
+ ### Env provider
161
+
162
+ - Optional allowlist via `allowlist`.
163
+ - Missing/empty env values fail resolution.
164
+
165
+ ### File provider
166
+
167
+ - Reads local file from `path`.
168
+ - `mode: "json"` expects JSON object payload and resolves `id` as pointer.
169
+ - `mode: "singleValue"` expects ref id `"value"` and returns file contents.
170
+ - Path must pass ownership/permission checks.
171
+ - Windows fail-closed note: if ACL verification is unavailable for a path, resolution fails. For trusted paths only, set `allowInsecurePath: true` on that provider to bypass path security checks.
172
+
173
+ ### Exec provider
174
+
175
+ - Runs configured absolute binary path, no shell.
176
+ - By default, `command` must point to a regular file (not a symlink).
177
+ - Set `allowSymlinkCommand: true` to allow symlink command paths (for example Homebrew shims). Durar validates the resolved target path.
178
+ - Pair `allowSymlinkCommand` with `trustedDirs` for package-manager paths (for example `["/opt/homebrew"]`).
179
+ - Supports timeout, no-output timeout, output byte limits, env allowlist, and trusted dirs.
180
+ - Windows fail-closed note: if ACL verification is unavailable for the command path, resolution fails. For trusted paths only, set `allowInsecurePath: true` on that provider to bypass path security checks.
181
+
182
+ Request payload (stdin):
183
+
184
+ ```json
185
+ { "protocolVersion": 1, "provider": "vault", "ids": ["providers/openai/apiKey"] }
186
+ ```
187
+
188
+ Response payload (stdout):
189
+
190
+ ```jsonc
191
+ { "protocolVersion": 1, "values": { "providers/openai/apiKey": "<openai-api-key>" } } // pragma: allowlist secret
192
+ ```
193
+
194
+ Optional per-id errors:
195
+
196
+ ```json
197
+ {
198
+ "protocolVersion": 1,
199
+ "values": {},
200
+ "errors": { "providers/openai/apiKey": { "message": "not found" } }
201
+ }
202
+ ```
203
+
204
+ ## Exec integration examples
205
+
206
+ ### 1Password CLI
207
+
208
+ ```json5
209
+ {
210
+ secrets: {
211
+ providers: {
212
+ onepassword_openai: {
213
+ source: "exec",
214
+ command: "/opt/homebrew/bin/op",
215
+ allowSymlinkCommand: true, // required for Homebrew symlinked binaries
216
+ trustedDirs: ["/opt/homebrew"],
217
+ args: ["read", "op://Personal/Durar QA API Key/password"],
218
+ passEnv: ["HOME"],
219
+ jsonOnly: false,
220
+ },
221
+ },
222
+ },
223
+ models: {
224
+ providers: {
225
+ openai: {
226
+ baseUrl: "https://api.openai.com/v1",
227
+ models: [{ id: "gpt-5", name: "gpt-5" }],
228
+ apiKey: { source: "exec", provider: "onepassword_openai", id: "value" },
229
+ },
230
+ },
231
+ },
232
+ }
233
+ ```
234
+
235
+ ### HashiCorp Vault CLI
236
+
237
+ ```json5
238
+ {
239
+ secrets: {
240
+ providers: {
241
+ vault_openai: {
242
+ source: "exec",
243
+ command: "/opt/homebrew/bin/vault",
244
+ allowSymlinkCommand: true, // required for Homebrew symlinked binaries
245
+ trustedDirs: ["/opt/homebrew"],
246
+ args: ["kv", "get", "-field=OPENAI_API_KEY", "secret/Durar"],
247
+ passEnv: ["VAULT_ADDR", "VAULT_TOKEN"],
248
+ jsonOnly: false,
249
+ },
250
+ },
251
+ },
252
+ models: {
253
+ providers: {
254
+ openai: {
255
+ baseUrl: "https://api.openai.com/v1",
256
+ models: [{ id: "gpt-5", name: "gpt-5" }],
257
+ apiKey: { source: "exec", provider: "vault_openai", id: "value" },
258
+ },
259
+ },
260
+ },
261
+ }
262
+ ```
263
+
264
+ ### `sops`
265
+
266
+ ```json5
267
+ {
268
+ secrets: {
269
+ providers: {
270
+ sops_openai: {
271
+ source: "exec",
272
+ command: "/opt/homebrew/bin/sops",
273
+ allowSymlinkCommand: true, // required for Homebrew symlinked binaries
274
+ trustedDirs: ["/opt/homebrew"],
275
+ args: ["-d", "--extract", '["providers"]["openai"]["apiKey"]', "/path/to/secrets.enc.json"],
276
+ passEnv: ["SOPS_AGE_KEY_FILE"],
277
+ jsonOnly: false,
278
+ },
279
+ },
280
+ },
281
+ models: {
282
+ providers: {
283
+ openai: {
284
+ baseUrl: "https://api.openai.com/v1",
285
+ models: [{ id: "gpt-5", name: "gpt-5" }],
286
+ apiKey: { source: "exec", provider: "sops_openai", id: "value" },
287
+ },
288
+ },
289
+ },
290
+ }
291
+ ```
292
+
293
+ ## MCP server environment variables
294
+
295
+ MCP server env vars configured via `plugins.entries.acpx.config.mcpServers` support SecretInput. This keeps API keys and tokens out of plaintext config:
296
+
297
+ ```json5
298
+ {
299
+ plugins: {
300
+ entries: {
301
+ acpx: {
302
+ enabled: true,
303
+ config: {
304
+ mcpServers: {
305
+ github: {
306
+ command: "npx",
307
+ args: ["-y", "@modelcontextprotocol/server-github"],
308
+ env: {
309
+ GITHUB_PERSONAL_ACCESS_TOKEN: {
310
+ source: "env",
311
+ provider: "default",
312
+ id: "MCP_GITHUB_PAT",
313
+ },
314
+ },
315
+ },
316
+ },
317
+ },
318
+ },
319
+ },
320
+ },
321
+ }
322
+ ```
323
+
324
+ Plaintext string values still work. Env-template refs like `${MCP_SERVER_API_KEY}` and SecretRef objects are resolved during gateway activation before the MCP server process is spawned. As with other SecretRef surfaces, unresolved refs only block activation when the `acpx` plugin is effectively active.
325
+
326
+ ## Sandbox SSH auth material
327
+
328
+ The core `ssh` sandbox backend also supports SecretRefs for SSH auth material:
329
+
330
+ ```json5
331
+ {
332
+ agents: {
333
+ defaults: {
334
+ sandbox: {
335
+ mode: "all",
336
+ backend: "ssh",
337
+ ssh: {
338
+ target: "user@gateway-host:22",
339
+ identityData: { source: "env", provider: "default", id: "SSH_IDENTITY" },
340
+ certificateData: { source: "env", provider: "default", id: "SSH_CERTIFICATE" },
341
+ knownHostsData: { source: "env", provider: "default", id: "SSH_KNOWN_HOSTS" },
342
+ },
343
+ },
344
+ },
345
+ },
346
+ }
347
+ ```
348
+
349
+ Runtime behavior:
350
+
351
+ - Durar resolves these refs during sandbox activation, not lazily during each SSH call.
352
+ - Resolved values are written to temp files with restrictive permissions and used in generated SSH config.
353
+ - If the effective sandbox backend is not `ssh`, these refs stay inactive and do not block startup.
354
+
355
+ ## Supported credential surface
356
+
357
+ Canonical supported and unsupported credentials are listed in:
358
+
359
+ - [SecretRef Credential Surface](/reference/secretref-credential-surface)
360
+
361
+ Runtime-minted or rotating credentials and OAuth refresh material are intentionally excluded from read-only SecretRef resolution.
362
+
363
+ ## Required behavior and precedence
364
+
365
+ - Field without a ref: unchanged.
366
+ - Field with a ref: required on active surfaces during activation.
367
+ - If both plaintext and ref are present, ref takes precedence on supported precedence paths.
368
+ - The redaction sentinel `__Durar_REDACTED__` is reserved for internal config redaction/restore and is rejected as literal submitted config data.
369
+
370
+ Warning and audit signals:
371
+
372
+ - `SECRETS_REF_OVERRIDES_PLAINTEXT` (runtime warning)
373
+ - `REF_SHADOWED` (audit finding when `auth-profiles.json` credentials take precedence over `Durar.json` refs)
374
+
375
+ Google Chat compatibility behavior:
376
+
377
+ - `serviceAccountRef` takes precedence over plaintext `serviceAccount`.
378
+ - Plaintext value is ignored when sibling ref is set.
379
+
380
+ ## Activation triggers
381
+
382
+ Secret activation runs on:
383
+
384
+ - Startup (preflight plus final activation)
385
+ - Config reload hot-apply path
386
+ - Config reload restart-check path
387
+ - Manual reload via `secrets.reload`
388
+ - Gateway config write RPC preflight (`config.set` / `config.apply` / `config.patch`) for active-surface SecretRef resolvability within the submitted config payload before persisting edits
389
+
390
+ Activation contract:
391
+
392
+ - Success swaps the snapshot atomically.
393
+ - Startup failure aborts gateway startup.
394
+ - Runtime reload failure keeps the last-known-good snapshot.
395
+ - Write-RPC preflight failure rejects the submitted config and keeps both disk config and active runtime snapshot unchanged.
396
+ - Providing an explicit per-call channel token to an outbound helper/tool call does not trigger SecretRef activation; activation points remain startup, reload, and explicit `secrets.reload`.
397
+
398
+ ## Degraded and recovered signals
399
+
400
+ When reload-time activation fails after a healthy state, Durar enters degraded secrets state.
401
+
402
+ One-shot system event and log codes:
403
+
404
+ - `SECRETS_RELOADER_DEGRADED`
405
+ - `SECRETS_RELOADER_RECOVERED`
406
+
407
+ Behavior:
408
+
409
+ - Degraded: runtime keeps last-known-good snapshot.
410
+ - Recovered: emitted once after the next successful activation.
411
+ - Repeated failures while already degraded log warnings but do not spam events.
412
+ - Startup fail-fast does not emit degraded events because runtime never became active.
413
+
414
+ ## Command-path resolution
415
+
416
+ Command paths can opt into supported SecretRef resolution via gateway snapshot RPC.
417
+
418
+ There are two broad behaviors:
419
+
420
+ - Strict command paths (for example `Durar memory` remote-memory paths and `Durar qr --remote` when it needs remote shared-secret refs) read from the active snapshot and fail fast when a required SecretRef is unavailable.
421
+ - Read-only command paths (for example `Durar status`, `Durar status --all`, `Durar channels status`, `Durar channels resolve`, `Durar security audit`, and read-only doctor/config repair flows) also prefer the active snapshot, but degrade instead of aborting when a targeted SecretRef is unavailable in that command path.
422
+
423
+ Read-only behavior:
424
+
425
+ - When the gateway is running, these commands read from the active snapshot first.
426
+ - If gateway resolution is incomplete or the gateway is unavailable, they attempt targeted local fallback for the specific command surface.
427
+ - If a targeted SecretRef is still unavailable, the command continues with degraded read-only output and explicit diagnostics such as “configured but unavailable in this command path”.
428
+ - This degraded behavior is command-local only. It does not weaken runtime startup, reload, or send/auth paths.
429
+
430
+ Other notes:
431
+
432
+ - Snapshot refresh after backend secret rotation is handled by `Durar secrets reload`.
433
+ - Gateway RPC method used by these command paths: `secrets.resolve`.
434
+
435
+ ## Audit and configure workflow
436
+
437
+ Default operator flow:
438
+
439
+ ```bash
440
+ Durar secrets audit --check
441
+ Durar secrets configure
442
+ Durar secrets audit --check
443
+ ```
444
+
445
+ ### `secrets audit`
446
+
447
+ Findings include:
448
+
449
+ - plaintext values at rest (`Durar.json`, `auth-profiles.json`, `.env`, and generated `agents/*/agent/models.json`)
450
+ - plaintext sensitive provider header residues in generated `models.json` entries
451
+ - unresolved refs
452
+ - precedence shadowing (`auth-profiles.json` taking priority over `Durar.json` refs)
453
+ - legacy residues (`auth.json`, OAuth reminders)
454
+
455
+ Exec note:
456
+
457
+ - By default, audit skips exec SecretRef resolvability checks to avoid command side effects.
458
+ - Use `Durar secrets audit --allow-exec` to execute exec providers during audit.
459
+
460
+ Header residue note:
461
+
462
+ - Sensitive provider header detection is name-heuristic based (common auth/credential header names and fragments such as `authorization`, `x-api-key`, `token`, `secret`, `password`, and `credential`).
463
+
464
+ ### `secrets configure`
465
+
466
+ Interactive helper that:
467
+
468
+ - configures `secrets.providers` first (`env`/`file`/`exec`, add/edit/remove)
469
+ - lets you select supported secret-bearing fields in `Durar.json` plus `auth-profiles.json` for one agent scope
470
+ - can create a new `auth-profiles.json` mapping directly in the target picker
471
+ - captures SecretRef details (`source`, `provider`, `id`)
472
+ - runs preflight resolution
473
+ - can apply immediately
474
+
475
+ Exec note:
476
+
477
+ - Preflight skips exec SecretRef checks unless `--allow-exec` is set.
478
+ - If you apply directly from `configure --apply` and the plan includes exec refs/providers, keep `--allow-exec` set for the apply step too.
479
+
480
+ Helpful modes:
481
+
482
+ - `Durar secrets configure --providers-only`
483
+ - `Durar secrets configure --skip-provider-setup`
484
+ - `Durar secrets configure --agent <id>`
485
+
486
+ `configure` apply defaults:
487
+
488
+ - scrub matching static credentials from `auth-profiles.json` for targeted providers
489
+ - scrub legacy static `api_key` entries from `auth.json`
490
+ - scrub matching known secret lines from `<config-dir>/.env`
491
+
492
+ ### `secrets apply`
493
+
494
+ Apply a saved plan:
495
+
496
+ ```bash
497
+ Durar secrets apply --from /tmp/Durar-secrets-plan.json
498
+ Durar secrets apply --from /tmp/Durar-secrets-plan.json --allow-exec
499
+ Durar secrets apply --from /tmp/Durar-secrets-plan.json --dry-run
500
+ Durar secrets apply --from /tmp/Durar-secrets-plan.json --dry-run --allow-exec
501
+ ```
502
+
503
+ Exec note:
504
+
505
+ - dry-run skips exec checks unless `--allow-exec` is set.
506
+ - write mode rejects plans containing exec SecretRefs/providers unless `--allow-exec` is set.
507
+
508
+ For strict target/path contract details and exact rejection rules, see:
509
+
510
+ - [Secrets Apply Plan Contract](/gateway/secrets-plan-contract)
511
+
512
+ ## One-way safety policy
513
+
514
+ Durar intentionally does not write rollback backups containing historical plaintext secret values.
515
+
516
+ Safety model:
517
+
518
+ - preflight must succeed before write mode
519
+ - runtime activation is validated before commit
520
+ - apply updates files using atomic file replacement and best-effort restore on failure
521
+
522
+ ## Legacy auth compatibility notes
523
+
524
+ For static credentials, runtime no longer depends on plaintext legacy auth storage.
525
+
526
+ - Runtime credential source is the resolved in-memory snapshot.
527
+ - Legacy static `api_key` entries are scrubbed when discovered.
528
+ - OAuth-related compatibility behavior remains separate.
529
+
530
+ ## Web UI note
531
+
532
+ Some SecretInput unions are easier to configure in raw editor mode than in form mode.
533
+
534
+ ## Related docs
535
+
536
+ - CLI commands: [secrets](/cli/secrets)
537
+ - Plan contract details: [Secrets Apply Plan Contract](/gateway/secrets-plan-contract)
538
+ - Credential surface: [SecretRef Credential Surface](/reference/secretref-credential-surface)
539
+ - Auth setup: [Authentication](/gateway/authentication)
540
+ - Security posture: [Security](/gateway/security)
541
+ - Environment precedence: [Environment Variables](/help/environment)