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,61 @@
1
+ ---
2
+ summary: "Health check commands and gateway health monitoring"
3
+ read_when:
4
+ - Diagnosing channel connectivity or gateway health
5
+ - Understanding health check CLI commands and options
6
+ title: "Health Checks"
7
+ ---
8
+
9
+ # Health Checks (CLI)
10
+
11
+ Short guide to verify channel connectivity without guessing.
12
+
13
+ ## Quick checks
14
+
15
+ - `Durar status` — local summary: gateway reachability/mode, update hint, linked channel auth age, sessions + recent activity.
16
+ - `Durar status --all` — full local diagnosis (read-only, color, safe to paste for debugging).
17
+ - `Durar status --deep` — asks the running gateway for a live health probe (`health` with `probe:true`), including per-account channel probes when supported.
18
+ - `Durar health` — asks the running gateway for its health snapshot (WS-only; no direct channel sockets from the CLI).
19
+ - `Durar health --verbose` — forces a live health probe and prints gateway connection details.
20
+ - `Durar health --json` — machine-readable health snapshot output.
21
+ - Send `/status` as a standalone message in WhatsApp/WebChat to get a status reply without invoking the agent.
22
+ - Logs: tail `/tmp/Durar/Durar-*.log` and filter for `web-heartbeat`, `web-reconnect`, `web-auto-reply`, `web-inbound`.
23
+
24
+ ## Deep diagnostics
25
+
26
+ - Creds on disk: `ls -l ~/.Durar/credentials/whatsapp/<accountId>/creds.json` (mtime should be recent).
27
+ - Session store: `ls -l ~/.Durar/agents/<agentId>/sessions/sessions.json` (path can be overridden in config). Count and recent recipients are surfaced via `status`.
28
+ - Relink flow: `Durar channels logout && Durar channels login --verbose` when status codes 409–515 or `loggedOut` appear in logs. (Note: the QR login flow auto-restarts once for status 515 after pairing.)
29
+
30
+ ## Health monitor config
31
+
32
+ - `gateway.channelHealthCheckMinutes`: how often the gateway checks channel health. Default: `5`. Set `0` to disable health-monitor restarts globally.
33
+ - `gateway.channelStaleEventThresholdMinutes`: how long a connected channel can stay idle before the health monitor treats it as stale and restarts it. Default: `30`. Keep this greater than or equal to `gateway.channelHealthCheckMinutes`.
34
+ - `gateway.channelMaxRestartsPerHour`: rolling one-hour cap for health-monitor restarts per channel/account. Default: `10`.
35
+ - `channels.<provider>.healthMonitor.enabled`: disable health-monitor restarts for a specific channel while leaving global monitoring enabled.
36
+ - `channels.<provider>.accounts.<accountId>.healthMonitor.enabled`: multi-account override that wins over the channel-level setting.
37
+ - These per-channel overrides apply to the built-in channel monitors that expose them today: Discord, Google Chat, iMessage, Microsoft Teams, Signal, Slack, Telegram, and WhatsApp.
38
+
39
+ ## When something fails
40
+
41
+ - `logged out` or status 409–515 → relink with `Durar channels logout` then `Durar channels login`.
42
+ - Gateway unreachable → start it: `Durar gateway --port 18789` (use `--force` if the port is busy).
43
+ - No inbound messages → confirm linked phone is online and the sender is allowed (`channels.whatsapp.allowFrom`); for group chats, ensure allowlist + mention rules match (`channels.whatsapp.groups`, `agents.list[].groupChat.mentionPatterns`).
44
+
45
+ ## Dedicated "health" command
46
+
47
+ `Durar health` asks the running gateway for its health snapshot (no direct channel
48
+ sockets from the CLI). By default it can return a fresh cached gateway snapshot; the
49
+ gateway then refreshes that cache in the background. `Durar health --verbose` forces
50
+ a live probe instead. The command reports linked creds/auth age when available,
51
+ per-channel probe summaries, session-store summary, and a probe duration. It exits
52
+ non-zero if the gateway is unreachable or the probe fails/timeouts.
53
+
54
+ Options:
55
+
56
+ - `--json`: machine-readable JSON output
57
+ - `--timeout <ms>`: override the default 10s probe timeout
58
+ - `--verbose`: force a live probe and print gateway connection details
59
+ - `--debug`: alias for `--verbose`
60
+
61
+ The health snapshot includes: `ok` (boolean), `ts` (timestamp), `durationMs` (probe time), per-channel status, agent availability, and session-store summary.
@@ -0,0 +1,443 @@
1
+ ---
2
+ summary: "Heartbeat polling messages and notification rules"
3
+ read_when:
4
+ - Adjusting heartbeat cadence or messaging
5
+ - Deciding between heartbeat and cron for scheduled tasks
6
+ title: "Heartbeat"
7
+ ---
8
+
9
+ # Heartbeat (Gateway)
10
+
11
+ > **Heartbeat vs Cron?** See [Automation & Tasks](/automation) for guidance on when to use each.
12
+
13
+ Heartbeat runs **periodic agent turns** in the main session so the model can
14
+ surface anything that needs attention without spamming you.
15
+
16
+ Heartbeat is a scheduled main-session turn — it does **not** create [background task](/automation/tasks) records.
17
+ Task records are for detached work (ACP runs, subagents, isolated cron jobs).
18
+
19
+ Troubleshooting: [Scheduled Tasks](/automation/cron-jobs#troubleshooting)
20
+
21
+ ## Quick start (beginner)
22
+
23
+ 1. Leave heartbeats enabled (default is `30m`, or `1h` for Anthropic OAuth/token auth, including Claude CLI reuse) or set your own cadence.
24
+ 2. Create a tiny `HEARTBEAT.md` checklist or `tasks:` block in the agent workspace (optional but recommended).
25
+ 3. Decide where heartbeat messages should go (`target: "none"` is the default; set `target: "last"` to route to the last contact).
26
+ 4. Optional: enable heartbeat reasoning delivery for transparency.
27
+ 5. Optional: use lightweight bootstrap context if heartbeat runs only need `HEARTBEAT.md`.
28
+ 6. Optional: enable isolated sessions to avoid sending full conversation history each heartbeat.
29
+ 7. Optional: restrict heartbeats to active hours (local time).
30
+
31
+ Example config:
32
+
33
+ ```json5
34
+ {
35
+ agents: {
36
+ defaults: {
37
+ heartbeat: {
38
+ every: "30m",
39
+ target: "last", // explicit delivery to last contact (default is "none")
40
+ directPolicy: "allow", // default: allow direct/DM targets; set "block" to suppress
41
+ lightContext: true, // optional: only inject HEARTBEAT.md from bootstrap files
42
+ isolatedSession: true, // optional: fresh session each run (no conversation history)
43
+ // activeHours: { start: "08:00", end: "24:00" },
44
+ // includeReasoning: true, // optional: send separate `Reasoning:` message too
45
+ },
46
+ },
47
+ },
48
+ }
49
+ ```
50
+
51
+ ## Defaults
52
+
53
+ - Interval: `30m` (or `1h` when Anthropic OAuth/token auth is the detected auth mode, including Claude CLI reuse). Set `agents.defaults.heartbeat.every` or per-agent `agents.list[].heartbeat.every`; use `0m` to disable.
54
+ - Prompt body (configurable via `agents.defaults.heartbeat.prompt`):
55
+ `Read HEARTBEAT.md if it exists (workspace context). Follow it strictly. Do not infer or repeat old tasks from prior chats. If nothing needs attention, reply HEARTBEAT_OK.`
56
+ - The heartbeat prompt is sent **verbatim** as the user message. The system
57
+ prompt includes a “Heartbeat” section and the run is flagged internally.
58
+ - Active hours (`heartbeat.activeHours`) are checked in the configured timezone.
59
+ Outside the window, heartbeats are skipped until the next tick inside the window.
60
+
61
+ ## What the heartbeat prompt is for
62
+
63
+ The default prompt is intentionally broad:
64
+
65
+ - **Background tasks**: “Consider outstanding tasks” nudges the agent to review
66
+ follow-ups (inbox, calendar, reminders, queued work) and surface anything urgent.
67
+ - **Human check-in**: “Checkup sometimes on your human during day time” nudges an
68
+ occasional lightweight “anything you need?” message, but avoids night-time spam
69
+ by using your configured local timezone (see [/concepts/timezone](/concepts/timezone)).
70
+
71
+ Heartbeat can react to completed [background tasks](/automation/tasks), but a heartbeat run itself does not create a task record.
72
+
73
+ If you want a heartbeat to do something very specific (e.g. “check Gmail PubSub
74
+ stats” or “verify gateway health”), set `agents.defaults.heartbeat.prompt` (or
75
+ `agents.list[].heartbeat.prompt`) to a custom body (sent verbatim).
76
+
77
+ ## Response contract
78
+
79
+ - If nothing needs attention, reply with **`HEARTBEAT_OK`**.
80
+ - During heartbeat runs, Durar treats `HEARTBEAT_OK` as an ack when it appears
81
+ at the **start or end** of the reply. The token is stripped and the reply is
82
+ dropped if the remaining content is **≤ `ackMaxChars`** (default: 300).
83
+ - If `HEARTBEAT_OK` appears in the **middle** of a reply, it is not treated
84
+ specially.
85
+ - For alerts, **do not** include `HEARTBEAT_OK`; return only the alert text.
86
+
87
+ Outside heartbeats, stray `HEARTBEAT_OK` at the start/end of a message is stripped
88
+ and logged; a message that is only `HEARTBEAT_OK` is dropped.
89
+
90
+ ## Config
91
+
92
+ ```json5
93
+ {
94
+ agents: {
95
+ defaults: {
96
+ heartbeat: {
97
+ every: "30m", // default: 30m (0m disables)
98
+ model: "anthropic/claude-opus-4-6",
99
+ includeReasoning: false, // default: false (deliver separate Reasoning: message when available)
100
+ lightContext: false, // default: false; true keeps only HEARTBEAT.md from workspace bootstrap files
101
+ isolatedSession: false, // default: false; true runs each heartbeat in a fresh session (no conversation history)
102
+ target: "last", // default: none | options: last | none | <channel id> (core or plugin, e.g. "bluebubbles")
103
+ to: "+15551234567", // optional channel-specific override
104
+ accountId: "ops-bot", // optional multi-account channel id
105
+ prompt: "Read HEARTBEAT.md if it exists (workspace context). Follow it strictly. Do not infer or repeat old tasks from prior chats. If nothing needs attention, reply HEARTBEAT_OK.",
106
+ ackMaxChars: 300, // max chars allowed after HEARTBEAT_OK
107
+ },
108
+ },
109
+ },
110
+ }
111
+ ```
112
+
113
+ ### Scope and precedence
114
+
115
+ - `agents.defaults.heartbeat` sets global heartbeat behavior.
116
+ - `agents.list[].heartbeat` merges on top; if any agent has a `heartbeat` block, **only those agents** run heartbeats.
117
+ - `channels.defaults.heartbeat` sets visibility defaults for all channels.
118
+ - `channels.<channel>.heartbeat` overrides channel defaults.
119
+ - `channels.<channel>.accounts.<id>.heartbeat` (multi-account channels) overrides per-channel settings.
120
+
121
+ ### Per-agent heartbeats
122
+
123
+ If any `agents.list[]` entry includes a `heartbeat` block, **only those agents**
124
+ run heartbeats. The per-agent block merges on top of `agents.defaults.heartbeat`
125
+ (so you can set shared defaults once and override per agent).
126
+
127
+ Example: two agents, only the second agent runs heartbeats.
128
+
129
+ ```json5
130
+ {
131
+ agents: {
132
+ defaults: {
133
+ heartbeat: {
134
+ every: "30m",
135
+ target: "last", // explicit delivery to last contact (default is "none")
136
+ },
137
+ },
138
+ list: [
139
+ { id: "main", default: true },
140
+ {
141
+ id: "ops",
142
+ heartbeat: {
143
+ every: "1h",
144
+ target: "whatsapp",
145
+ to: "+15551234567",
146
+ prompt: "Read HEARTBEAT.md if it exists (workspace context). Follow it strictly. Do not infer or repeat old tasks from prior chats. If nothing needs attention, reply HEARTBEAT_OK.",
147
+ },
148
+ },
149
+ ],
150
+ },
151
+ }
152
+ ```
153
+
154
+ ### Active hours example
155
+
156
+ Restrict heartbeats to business hours in a specific timezone:
157
+
158
+ ```json5
159
+ {
160
+ agents: {
161
+ defaults: {
162
+ heartbeat: {
163
+ every: "30m",
164
+ target: "last", // explicit delivery to last contact (default is "none")
165
+ activeHours: {
166
+ start: "09:00",
167
+ end: "22:00",
168
+ timezone: "America/New_York", // optional; uses your userTimezone if set, otherwise host tz
169
+ },
170
+ },
171
+ },
172
+ },
173
+ }
174
+ ```
175
+
176
+ Outside this window (before 9am or after 10pm Eastern), heartbeats are skipped. The next scheduled tick inside the window will run normally.
177
+
178
+ ### 24/7 setup
179
+
180
+ If you want heartbeats to run all day, use one of these patterns:
181
+
182
+ - Omit `activeHours` entirely (no time-window restriction; this is the default behavior).
183
+ - Set a full-day window: `activeHours: { start: "00:00", end: "24:00" }`.
184
+
185
+ Do not set the same `start` and `end` time (for example `08:00` to `08:00`).
186
+ That is treated as a zero-width window, so heartbeats are always skipped.
187
+
188
+ ### Multi account example
189
+
190
+ Use `accountId` to target a specific account on multi-account channels like Telegram:
191
+
192
+ ```json5
193
+ {
194
+ agents: {
195
+ list: [
196
+ {
197
+ id: "ops",
198
+ heartbeat: {
199
+ every: "1h",
200
+ target: "telegram",
201
+ to: "12345678:topic:42", // optional: route to a specific topic/thread
202
+ accountId: "ops-bot",
203
+ },
204
+ },
205
+ ],
206
+ },
207
+ channels: {
208
+ telegram: {
209
+ accounts: {
210
+ "ops-bot": { botToken: "YOUR_TELEGRAM_BOT_TOKEN" },
211
+ },
212
+ },
213
+ },
214
+ }
215
+ ```
216
+
217
+ ### Field notes
218
+
219
+ - `every`: heartbeat interval (duration string; default unit = minutes).
220
+ - `model`: optional model override for heartbeat runs (`provider/model`).
221
+ - `includeReasoning`: when enabled, also deliver the separate `Reasoning:` message when available (same shape as `/reasoning on`).
222
+ - `lightContext`: when true, heartbeat runs use lightweight bootstrap context and keep only `HEARTBEAT.md` from workspace bootstrap files.
223
+ - `isolatedSession`: when true, each heartbeat runs in a fresh session with no prior conversation history. Uses the same isolation pattern as cron `sessionTarget: "isolated"`. Dramatically reduces per-heartbeat token cost. Combine with `lightContext: true` for maximum savings. Delivery routing still uses the main session context.
224
+ - `session`: optional session key for heartbeat runs.
225
+ - `main` (default): agent main session.
226
+ - Explicit session key (copy from `Durar sessions --json` or the [sessions CLI](/cli/sessions)).
227
+ - Session key formats: see [Sessions](/concepts/session) and [Groups](/channels/groups).
228
+ - `target`:
229
+ - `last`: deliver to the last used external channel.
230
+ - explicit channel: any configured channel or plugin id, for example `discord`, `matrix`, `telegram`, or `whatsapp`.
231
+ - `none` (default): run the heartbeat but **do not deliver** externally.
232
+ - `directPolicy`: controls direct/DM delivery behavior:
233
+ - `allow` (default): allow direct/DM heartbeat delivery.
234
+ - `block`: suppress direct/DM delivery (`reason=dm-blocked`).
235
+ - `to`: optional recipient override (channel-specific id, e.g. E.164 for WhatsApp or a Telegram chat id). For Telegram topics/threads, use `<chatId>:topic:<messageThreadId>`.
236
+ - `accountId`: optional account id for multi-account channels. When `target: "last"`, the account id applies to the resolved last channel if it supports accounts; otherwise it is ignored. If the account id does not match a configured account for the resolved channel, delivery is skipped.
237
+ - `prompt`: overrides the default prompt body (not merged).
238
+ - `ackMaxChars`: max chars allowed after `HEARTBEAT_OK` before delivery.
239
+ - `suppressToolErrorWarnings`: when true, suppresses tool error warning payloads during heartbeat runs.
240
+ - `activeHours`: restricts heartbeat runs to a time window. Object with `start` (HH:MM, inclusive; use `00:00` for start-of-day), `end` (HH:MM exclusive; `24:00` allowed for end-of-day), and optional `timezone`.
241
+ - Omitted or `"user"`: uses your `agents.defaults.userTimezone` if set, otherwise falls back to the host system timezone.
242
+ - `"local"`: always uses the host system timezone.
243
+ - Any IANA identifier (e.g. `America/New_York`): used directly; if invalid, falls back to the `"user"` behavior above.
244
+ - `start` and `end` must not be equal for an active window; equal values are treated as zero-width (always outside the window).
245
+ - Outside the active window, heartbeats are skipped until the next tick inside the window.
246
+
247
+ ## Delivery behavior
248
+
249
+ - Heartbeats run in the agent’s main session by default (`agent:<id>:<mainKey>`),
250
+ or `global` when `session.scope = "global"`. Set `session` to override to a
251
+ specific channel session (Discord/WhatsApp/etc.).
252
+ - `session` only affects the run context; delivery is controlled by `target` and `to`.
253
+ - To deliver to a specific channel/recipient, set `target` + `to`. With
254
+ `target: "last"`, delivery uses the last external channel for that session.
255
+ - Heartbeat deliveries allow direct/DM targets by default. Set `directPolicy: "block"` to suppress direct-target sends while still running the heartbeat turn.
256
+ - If the main queue is busy, the heartbeat is skipped and retried later.
257
+ - If `target` resolves to no external destination, the run still happens but no
258
+ outbound message is sent.
259
+ - If `showOk`, `showAlerts`, and `useIndicator` are all disabled, the run is skipped up front as `reason=alerts-disabled`.
260
+ - If only alert delivery is disabled, Durar can still run the heartbeat, update due-task timestamps, restore the session idle timestamp, and suppress the outward alert payload.
261
+ - Heartbeat-only replies do **not** keep the session alive; the last `updatedAt`
262
+ is restored so idle expiry behaves normally.
263
+ - Detached [background tasks](/automation/tasks) can enqueue a system event and wake heartbeat when the main session should notice something quickly. That wake does not make the heartbeat run a background task.
264
+
265
+ ## Visibility controls
266
+
267
+ By default, `HEARTBEAT_OK` acknowledgments are suppressed while alert content is
268
+ delivered. You can adjust this per channel or per account:
269
+
270
+ ```yaml
271
+ channels:
272
+ defaults:
273
+ heartbeat:
274
+ showOk: false # Hide HEARTBEAT_OK (default)
275
+ showAlerts: true # Show alert messages (default)
276
+ useIndicator: true # Emit indicator events (default)
277
+ telegram:
278
+ heartbeat:
279
+ showOk: true # Show OK acknowledgments on Telegram
280
+ whatsapp:
281
+ accounts:
282
+ work:
283
+ heartbeat:
284
+ showAlerts: false # Suppress alert delivery for this account
285
+ ```
286
+
287
+ Precedence: per-account → per-channel → channel defaults → built-in defaults.
288
+
289
+ ### What each flag does
290
+
291
+ - `showOk`: sends a `HEARTBEAT_OK` acknowledgment when the model returns an OK-only reply.
292
+ - `showAlerts`: sends the alert content when the model returns a non-OK reply.
293
+ - `useIndicator`: emits indicator events for UI status surfaces.
294
+
295
+ If **all three** are false, Durar skips the heartbeat run entirely (no model call).
296
+
297
+ ### Per-channel vs per-account examples
298
+
299
+ ```yaml
300
+ channels:
301
+ defaults:
302
+ heartbeat:
303
+ showOk: false
304
+ showAlerts: true
305
+ useIndicator: true
306
+ slack:
307
+ heartbeat:
308
+ showOk: true # all Slack accounts
309
+ accounts:
310
+ ops:
311
+ heartbeat:
312
+ showAlerts: false # suppress alerts for the ops account only
313
+ telegram:
314
+ heartbeat:
315
+ showOk: true
316
+ ```
317
+
318
+ ### Common patterns
319
+
320
+ | Goal | Config |
321
+ | ---------------------------------------- | ---------------------------------------------------------------------------------------- |
322
+ | Default behavior (silent OKs, alerts on) | _(no config needed)_ |
323
+ | Fully silent (no messages, no indicator) | `channels.defaults.heartbeat: { showOk: false, showAlerts: false, useIndicator: false }` |
324
+ | Indicator-only (no messages) | `channels.defaults.heartbeat: { showOk: false, showAlerts: false, useIndicator: true }` |
325
+ | OKs in one channel only | `channels.telegram.heartbeat: { showOk: true }` |
326
+
327
+ ## HEARTBEAT.md (optional)
328
+
329
+ If a `HEARTBEAT.md` file exists in the workspace, the default prompt tells the
330
+ agent to read it. Think of it as your “heartbeat checklist”: small, stable, and
331
+ safe to include every 30 minutes.
332
+
333
+ If `HEARTBEAT.md` exists but is effectively empty (only blank lines and markdown
334
+ headers like `# Heading`), Durar skips the heartbeat run to save API calls.
335
+ That skip is reported as `reason=empty-heartbeat-file`.
336
+ If the file is missing, the heartbeat still runs and the model decides what to do.
337
+
338
+ Keep it tiny (short checklist or reminders) to avoid prompt bloat.
339
+
340
+ Example `HEARTBEAT.md`:
341
+
342
+ ```md
343
+ # Heartbeat checklist
344
+
345
+ - Quick scan: anything urgent in inboxes?
346
+ - If it’s daytime, do a lightweight check-in if nothing else is pending.
347
+ - If a task is blocked, write down _what is missing_ and ask Peter next time.
348
+ ```
349
+
350
+ ### `tasks:` blocks
351
+
352
+ `HEARTBEAT.md` also supports a small structured `tasks:` block for interval-based
353
+ checks inside heartbeat itself.
354
+
355
+ Example:
356
+
357
+ ```md
358
+ tasks:
359
+
360
+ - name: inbox-triage
361
+ interval: 30m
362
+ prompt: "Check for urgent unread emails and flag anything time sensitive."
363
+ - name: calendar-scan
364
+ interval: 2h
365
+ prompt: "Check for upcoming meetings that need prep or follow-up."
366
+
367
+ # Additional instructions
368
+
369
+ - Keep alerts short.
370
+ - If nothing needs attention after all due tasks, reply HEARTBEAT_OK.
371
+ ```
372
+
373
+ Behavior:
374
+
375
+ - Durar parses the `tasks:` block and checks each task against its own `interval`.
376
+ - Only **due** tasks are included in the heartbeat prompt for that tick.
377
+ - If no tasks are due, the heartbeat is skipped entirely (`reason=no-tasks-due`) to avoid a wasted model call.
378
+ - Non-task content in `HEARTBEAT.md` is preserved and appended as additional context after the due-task list.
379
+ - Task last-run timestamps are stored in session state (`heartbeatTaskState`), so intervals survive normal restarts.
380
+ - Task timestamps are only advanced after a heartbeat run completes its normal reply path. Skipped `empty-heartbeat-file` / `no-tasks-due` runs do not mark tasks as completed.
381
+
382
+ Task mode is useful when you want one heartbeat file to hold several periodic checks without paying for all of them every tick.
383
+
384
+ ### Can the agent update HEARTBEAT.md?
385
+
386
+ Yes — if you ask it to.
387
+
388
+ `HEARTBEAT.md` is just a normal file in the agent workspace, so you can tell the
389
+ agent (in a normal chat) something like:
390
+
391
+ - “Update `HEARTBEAT.md` to add a daily calendar check.”
392
+ - “Rewrite `HEARTBEAT.md` so it’s shorter and focused on inbox follow-ups.”
393
+
394
+ If you want this to happen proactively, you can also include an explicit line in
395
+ your heartbeat prompt like: “If the checklist becomes stale, update HEARTBEAT.md
396
+ with a better one.”
397
+
398
+ Safety note: don’t put secrets (API keys, phone numbers, private tokens) into
399
+ `HEARTBEAT.md` — it becomes part of the prompt context.
400
+
401
+ ## Manual wake (on-demand)
402
+
403
+ You can enqueue a system event and trigger an immediate heartbeat with:
404
+
405
+ ```bash
406
+ Durar system event --text "Check for urgent follow-ups" --mode now
407
+ ```
408
+
409
+ If multiple agents have `heartbeat` configured, a manual wake runs each of those
410
+ agent heartbeats immediately.
411
+
412
+ Use `--mode next-heartbeat` to wait for the next scheduled tick.
413
+
414
+ ## Reasoning delivery (optional)
415
+
416
+ By default, heartbeats deliver only the final “answer” payload.
417
+
418
+ If you want transparency, enable:
419
+
420
+ - `agents.defaults.heartbeat.includeReasoning: true`
421
+
422
+ When enabled, heartbeats will also deliver a separate message prefixed
423
+ `Reasoning:` (same shape as `/reasoning on`). This can be useful when the agent
424
+ is managing multiple sessions/codexes and you want to see why it decided to ping
425
+ you — but it can also leak more internal detail than you want. Prefer keeping it
426
+ off in group chats.
427
+
428
+ ## Cost awareness
429
+
430
+ Heartbeats run full agent turns. Shorter intervals burn more tokens. To reduce cost:
431
+
432
+ - Use `isolatedSession: true` to avoid sending full conversation history (~100K tokens down to ~2-5K per run).
433
+ - Use `lightContext: true` to limit bootstrap files to just `HEARTBEAT.md`.
434
+ - Set a cheaper `model` (e.g. `ollama/llama3.2:1b`).
435
+ - Keep `HEARTBEAT.md` small.
436
+ - Use `target: "none"` if you only want internal state updates.
437
+
438
+ ## Related
439
+
440
+ - [Automation & Tasks](/automation) — all automation mechanisms at a glance
441
+ - [Background Tasks](/automation/tasks) — how detached work is tracked
442
+ - [Timezone](/concepts/timezone) — how timezone affects heartbeat scheduling
443
+ - [Troubleshooting](/automation/cron-jobs#troubleshooting) — debugging automation issues