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.
- package/CHANGELOG.md +5497 -0
- package/LICENSE +21 -0
- package/README.md +614 -0
- package/assets/avatar-placeholder.svg +19 -0
- package/assets/chrome-extension/icons/icon128.png +0 -0
- package/assets/chrome-extension/icons/icon16.png +0 -0
- package/assets/chrome-extension/icons/icon32.png +0 -0
- package/assets/chrome-extension/icons/icon48.png +0 -0
- package/assets/dmg-background-small.png +0 -0
- package/assets/dmg-background.png +0 -0
- package/docs/.i18n/README.md +72 -0
- package/docs/.i18n/ar-navigation.json +18 -0
- package/docs/.i18n/de-navigation.json +18 -0
- package/docs/.i18n/es-navigation.json +18 -0
- package/docs/.i18n/fr-navigation.json +18 -0
- package/docs/.i18n/glossary.ar.json +5 -0
- package/docs/.i18n/glossary.de.json +5 -0
- package/docs/.i18n/glossary.es.json +5 -0
- package/docs/.i18n/glossary.fr.json +5 -0
- package/docs/.i18n/glossary.id.json +5 -0
- package/docs/.i18n/glossary.it.json +5 -0
- package/docs/.i18n/glossary.ja-JP.json +14 -0
- package/docs/.i18n/glossary.ko.json +5 -0
- package/docs/.i18n/glossary.pl.json +5 -0
- package/docs/.i18n/glossary.pt-BR.json +5 -0
- package/docs/.i18n/glossary.tr.json +5 -0
- package/docs/.i18n/glossary.zh-CN.json +358 -0
- package/docs/.i18n/id-navigation.json +18 -0
- package/docs/.i18n/it-navigation.json +18 -0
- package/docs/.i18n/ja-navigation.json +18 -0
- package/docs/.i18n/ko-navigation.json +18 -0
- package/docs/.i18n/pl-navigation.json +18 -0
- package/docs/.i18n/pt-BR-navigation.json +18 -0
- package/docs/.i18n/tr-navigation.json +18 -0
- package/docs/.i18n/zh-Hans-navigation.json +544 -0
- package/docs/assets/install-script.svg +1 -0
- package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
- package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
- package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
- package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
- package/docs/assets/macos-onboarding/05-permissions.png +0 -0
- package/docs/assets/openclaw-logo-text-dark.png +0 -0
- package/docs/assets/openclaw-logo-text-dark.svg +418 -0
- package/docs/assets/openclaw-logo-text.png +0 -0
- package/docs/assets/openclaw-logo-text.svg +418 -0
- package/docs/assets/pixel-lobster.svg +60 -0
- package/docs/assets/showcase/agents-ui.jpg +0 -0
- package/docs/assets/showcase/bambu-cli.png +0 -0
- package/docs/assets/showcase/codexmonitor.png +0 -0
- package/docs/assets/showcase/gohome-grafana.png +0 -0
- package/docs/assets/showcase/ios-testflight.jpg +0 -0
- package/docs/assets/showcase/oura-health.png +0 -0
- package/docs/assets/showcase/padel-cli.svg +11 -0
- package/docs/assets/showcase/padel-screenshot.jpg +0 -0
- package/docs/assets/showcase/papla-tts.jpg +0 -0
- package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
- package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
- package/docs/assets/showcase/roborock-status.svg +13 -0
- package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
- package/docs/assets/showcase/snag.png +0 -0
- package/docs/assets/showcase/tesco-shop.jpg +0 -0
- package/docs/assets/showcase/wienerlinien.png +0 -0
- package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
- package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
- package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
- package/docs/assets/sponsors/blacksmith-light.svg +14 -0
- package/docs/assets/sponsors/blacksmith.svg +14 -0
- package/docs/assets/sponsors/convex-light.svg +16 -0
- package/docs/assets/sponsors/convex.svg +16 -0
- package/docs/assets/sponsors/github-light.svg +3 -0
- package/docs/assets/sponsors/github.svg +3 -0
- package/docs/assets/sponsors/nvidia-dark.svg +9 -0
- package/docs/assets/sponsors/nvidia.svg +9 -0
- package/docs/assets/sponsors/openai-light.svg +3 -0
- package/docs/assets/sponsors/openai.svg +3 -0
- package/docs/assets/sponsors/vercel-light.svg +5 -0
- package/docs/assets/sponsors/vercel.svg +5 -0
- package/docs/auth-credential-semantics.md +80 -0
- package/docs/automation/auth-monitoring.md +8 -0
- package/docs/automation/clawflow.md +8 -0
- package/docs/automation/cron-jobs.md +410 -0
- package/docs/automation/cron-vs-heartbeat.md +8 -0
- package/docs/automation/gmail-pubsub.md +8 -0
- package/docs/automation/hooks.md +303 -0
- package/docs/automation/index.md +115 -0
- package/docs/automation/poll.md +8 -0
- package/docs/automation/standing-orders.md +254 -0
- package/docs/automation/taskflow.md +82 -0
- package/docs/automation/tasks.md +323 -0
- package/docs/automation/troubleshooting.md +8 -0
- package/docs/automation/webhook.md +8 -0
- package/docs/brave-search.md +103 -0
- package/docs/channels/bluebubbles.md +435 -0
- package/docs/channels/broadcast-groups.md +442 -0
- package/docs/channels/channel-routing.md +139 -0
- package/docs/channels/discord.md +1254 -0
- package/docs/channels/feishu.md +793 -0
- package/docs/channels/googlechat.md +270 -0
- package/docs/channels/group-messages.md +84 -0
- package/docs/channels/groups.md +410 -0
- package/docs/channels/imessage.md +427 -0
- package/docs/channels/index.md +50 -0
- package/docs/channels/irc.md +252 -0
- package/docs/channels/line.md +225 -0
- package/docs/channels/location.md +56 -0
- package/docs/channels/matrix.md +869 -0
- package/docs/channels/mattermost.md +472 -0
- package/docs/channels/msteams.md +805 -0
- package/docs/channels/nextcloud-talk.md +149 -0
- package/docs/channels/nostr.md +252 -0
- package/docs/channels/pairing.md +129 -0
- package/docs/channels/qqbot.md +193 -0
- package/docs/channels/signal.md +337 -0
- package/docs/channels/slack.md +681 -0
- package/docs/channels/synology-chat.md +185 -0
- package/docs/channels/telegram.md +1072 -0
- package/docs/channels/tlon.md +290 -0
- package/docs/channels/troubleshooting.md +133 -0
- package/docs/channels/twitch.md +394 -0
- package/docs/channels/whatsapp.md +488 -0
- package/docs/channels/zalo.md +254 -0
- package/docs/channels/zalouser.md +195 -0
- package/docs/ci.md +66 -0
- package/docs/cli/acp.md +316 -0
- package/docs/cli/agent.md +57 -0
- package/docs/cli/agents.md +220 -0
- package/docs/cli/approvals.md +136 -0
- package/docs/cli/backup.md +84 -0
- package/docs/cli/browser.md +233 -0
- package/docs/cli/channels.md +131 -0
- package/docs/cli/clawbot.md +21 -0
- package/docs/cli/completion.md +35 -0
- package/docs/cli/config.md +353 -0
- package/docs/cli/configure.md +70 -0
- package/docs/cli/cron.md +167 -0
- package/docs/cli/daemon.md +57 -0
- package/docs/cli/dashboard.md +22 -0
- package/docs/cli/devices.md +171 -0
- package/docs/cli/directory.md +63 -0
- package/docs/cli/dns.md +48 -0
- package/docs/cli/docs.md +28 -0
- package/docs/cli/doctor.md +63 -0
- package/docs/cli/flows.md +18 -0
- package/docs/cli/gateway.md +307 -0
- package/docs/cli/health.md +36 -0
- package/docs/cli/hooks.md +337 -0
- package/docs/cli/index.md +1836 -0
- package/docs/cli/logs.md +59 -0
- package/docs/cli/mcp.md +505 -0
- package/docs/cli/memory.md +139 -0
- package/docs/cli/message.md +300 -0
- package/docs/cli/models.md +136 -0
- package/docs/cli/node.md +137 -0
- package/docs/cli/nodes.md +66 -0
- package/docs/cli/onboard.md +171 -0
- package/docs/cli/pairing.md +65 -0
- package/docs/cli/plugins.md +305 -0
- package/docs/cli/qr.md +52 -0
- package/docs/cli/reset.md +35 -0
- package/docs/cli/sandbox.md +197 -0
- package/docs/cli/secrets.md +197 -0
- package/docs/cli/security.md +86 -0
- package/docs/cli/sessions.md +113 -0
- package/docs/cli/setup.md +45 -0
- package/docs/cli/skills.md +59 -0
- package/docs/cli/status.md +35 -0
- package/docs/cli/system.md +71 -0
- package/docs/cli/tui.md +30 -0
- package/docs/cli/uninstall.md +39 -0
- package/docs/cli/update.md +113 -0
- package/docs/cli/voicecall.md +34 -0
- package/docs/cli/webhooks.md +91 -0
- package/docs/concepts/agent-loop.md +168 -0
- package/docs/concepts/agent-workspace.md +246 -0
- package/docs/concepts/agent.md +129 -0
- package/docs/concepts/architecture.md +156 -0
- package/docs/concepts/compaction.md +122 -0
- package/docs/concepts/context-engine.md +274 -0
- package/docs/concepts/context.md +179 -0
- package/docs/concepts/delegate-architecture.md +307 -0
- package/docs/concepts/dreaming.md +173 -0
- package/docs/concepts/features.md +76 -0
- package/docs/concepts/markdown-formatting.md +130 -0
- package/docs/concepts/memory-builtin.md +105 -0
- package/docs/concepts/memory-honcho.md +140 -0
- package/docs/concepts/memory-qmd.md +163 -0
- package/docs/concepts/memory-search.md +141 -0
- package/docs/concepts/memory.md +121 -0
- package/docs/concepts/messages.md +161 -0
- package/docs/concepts/model-failover.md +349 -0
- package/docs/concepts/model-providers.md +799 -0
- package/docs/concepts/models.md +255 -0
- package/docs/concepts/multi-agent.md +615 -0
- package/docs/concepts/oauth.md +225 -0
- package/docs/concepts/presence.md +102 -0
- package/docs/concepts/queue.md +89 -0
- package/docs/concepts/retry.md +69 -0
- package/docs/concepts/session-pruning.md +92 -0
- package/docs/concepts/session-tool.md +141 -0
- package/docs/concepts/session.md +116 -0
- package/docs/concepts/soul.md +110 -0
- package/docs/concepts/streaming.md +161 -0
- package/docs/concepts/system-prompt.md +182 -0
- package/docs/concepts/timezone.md +97 -0
- package/docs/concepts/typebox.md +307 -0
- package/docs/concepts/typing-indicators.md +69 -0
- package/docs/concepts/usage-tracking.md +59 -0
- package/docs/date-time.md +128 -0
- package/docs/debug/node-issue.md +85 -0
- package/docs/diagnostics/flags.md +91 -0
- package/docs/docs.json +1601 -0
- package/docs/gateway/authentication.md +218 -0
- package/docs/gateway/background-process.md +131 -0
- package/docs/gateway/bonjour.md +179 -0
- package/docs/gateway/bridge-protocol.md +89 -0
- package/docs/gateway/cli-backends.md +310 -0
- package/docs/gateway/configuration-examples.md +631 -0
- package/docs/gateway/configuration-reference.md +3618 -0
- package/docs/gateway/configuration.md +698 -0
- package/docs/gateway/discovery.md +141 -0
- package/docs/gateway/doctor.md +494 -0
- package/docs/gateway/gateway-lock.md +37 -0
- package/docs/gateway/health.md +61 -0
- package/docs/gateway/heartbeat.md +443 -0
- package/docs/gateway/index.md +367 -0
- package/docs/gateway/local-models.md +163 -0
- package/docs/gateway/logging.md +113 -0
- package/docs/gateway/multiple-gateways.md +120 -0
- package/docs/gateway/network-model.md +25 -0
- package/docs/gateway/openai-http-api.md +280 -0
- package/docs/gateway/openresponses-http-api.md +340 -0
- package/docs/gateway/openshell.md +307 -0
- package/docs/gateway/pairing.md +138 -0
- package/docs/gateway/protocol.md +588 -0
- package/docs/gateway/remote-gateway-readme.md +164 -0
- package/docs/gateway/remote.md +251 -0
- package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +141 -0
- package/docs/gateway/sandboxing.md +473 -0
- package/docs/gateway/secrets-plan-contract.md +116 -0
- package/docs/gateway/secrets.md +541 -0
- package/docs/gateway/security/index.md +1362 -0
- package/docs/gateway/tailscale.md +136 -0
- package/docs/gateway/tools-invoke-http-api.md +161 -0
- package/docs/gateway/troubleshooting.md +451 -0
- package/docs/gateway/trusted-proxy-auth.md +399 -0
- package/docs/help/debugging.md +168 -0
- package/docs/help/environment.md +165 -0
- package/docs/help/faq.md +3244 -0
- package/docs/help/index.md +28 -0
- package/docs/help/scripts.md +27 -0
- package/docs/help/testing.md +640 -0
- package/docs/help/troubleshooting.md +372 -0
- package/docs/images/configure-model-picker-unsearchable.png +0 -0
- package/docs/images/feishu-step2-create-app.png +0 -0
- package/docs/images/feishu-step3-credentials.png +0 -0
- package/docs/images/feishu-step4-permissions.png +0 -0
- package/docs/images/feishu-step5-bot-capability.png +0 -0
- package/docs/images/feishu-step6-event-subscription.png +0 -0
- package/docs/images/feishu-verification-token.png +0 -0
- package/docs/images/groups-flow.svg +52 -0
- package/docs/images/mobile-ui-screenshot.png +0 -0
- package/docs/index.md +196 -0
- package/docs/install/ansible.md +230 -0
- package/docs/install/azure.md +311 -0
- package/docs/install/bun.md +55 -0
- package/docs/install/clawdock.md +106 -0
- package/docs/install/development-channels.md +131 -0
- package/docs/install/digitalocean.md +129 -0
- package/docs/install/docker-vm-runtime.md +142 -0
- package/docs/install/docker.md +412 -0
- package/docs/install/exe-dev.md +133 -0
- package/docs/install/fly.md +504 -0
- package/docs/install/gcp.md +412 -0
- package/docs/install/hetzner.md +259 -0
- package/docs/install/index.md +212 -0
- package/docs/install/installer.md +443 -0
- package/docs/install/kubernetes.md +192 -0
- package/docs/install/macos-vm.md +281 -0
- package/docs/install/migrating-matrix.md +349 -0
- package/docs/install/migrating.md +112 -0
- package/docs/install/nix.md +89 -0
- package/docs/install/node.md +144 -0
- package/docs/install/northflank.mdx +42 -0
- package/docs/install/oracle.md +158 -0
- package/docs/install/podman.md +210 -0
- package/docs/install/railway.mdx +90 -0
- package/docs/install/raspberry-pi.md +159 -0
- package/docs/install/render.mdx +165 -0
- package/docs/install/uninstall.md +128 -0
- package/docs/install/updating.md +142 -0
- package/docs/logging.md +389 -0
- package/docs/nav-tabs-underline.js +100 -0
- package/docs/network.md +69 -0
- package/docs/nodes/audio.md +191 -0
- package/docs/nodes/camera.md +162 -0
- package/docs/nodes/images.md +73 -0
- package/docs/nodes/index.md +408 -0
- package/docs/nodes/location-command.md +98 -0
- package/docs/nodes/media-understanding.md +432 -0
- package/docs/nodes/talk.md +92 -0
- package/docs/nodes/troubleshooting.md +123 -0
- package/docs/nodes/voicewake.md +66 -0
- package/docs/perplexity.md +181 -0
- package/docs/pi-dev.md +80 -0
- package/docs/pi.md +570 -0
- package/docs/platforms/android.md +244 -0
- package/docs/platforms/digitalocean.md +266 -0
- package/docs/platforms/index.md +55 -0
- package/docs/platforms/ios.md +223 -0
- package/docs/platforms/linux.md +100 -0
- package/docs/platforms/mac/bundled-gateway.md +75 -0
- package/docs/platforms/mac/canvas.md +125 -0
- package/docs/platforms/mac/child-process.md +69 -0
- package/docs/platforms/mac/dev-setup.md +107 -0
- package/docs/platforms/mac/health.md +34 -0
- package/docs/platforms/mac/icon.md +31 -0
- package/docs/platforms/mac/logging.md +57 -0
- package/docs/platforms/mac/menu-bar.md +81 -0
- package/docs/platforms/mac/peekaboo.md +65 -0
- package/docs/platforms/mac/permissions.md +50 -0
- package/docs/platforms/mac/remote.md +84 -0
- package/docs/platforms/mac/signing.md +47 -0
- package/docs/platforms/mac/skills.md +40 -0
- package/docs/platforms/mac/voice-overlay.md +60 -0
- package/docs/platforms/mac/voicewake.md +67 -0
- package/docs/platforms/mac/webchat.md +51 -0
- package/docs/platforms/mac/xpc.md +61 -0
- package/docs/platforms/macos.md +229 -0
- package/docs/platforms/oracle.md +305 -0
- package/docs/platforms/raspberry-pi.md +420 -0
- package/docs/platforms/windows.md +241 -0
- package/docs/plugins/agent-tools.md +10 -0
- package/docs/plugins/architecture.md +1609 -0
- package/docs/plugins/building-extensions.md +10 -0
- package/docs/plugins/building-plugins.md +319 -0
- package/docs/plugins/bundles.md +292 -0
- package/docs/plugins/community.md +149 -0
- package/docs/plugins/manifest.md +412 -0
- package/docs/plugins/sdk-channel-plugins.md +508 -0
- package/docs/plugins/sdk-entrypoints.md +210 -0
- package/docs/plugins/sdk-migration.md +359 -0
- package/docs/plugins/sdk-overview.md +475 -0
- package/docs/plugins/sdk-provider-plugins.md +712 -0
- package/docs/plugins/sdk-runtime.md +381 -0
- package/docs/plugins/sdk-setup.md +516 -0
- package/docs/plugins/sdk-testing.md +263 -0
- package/docs/plugins/voice-call.md +466 -0
- package/docs/plugins/zalouser.md +78 -0
- package/docs/prose.md +134 -0
- package/docs/providers/anthropic.md +402 -0
- package/docs/providers/bedrock-mantle.md +91 -0
- package/docs/providers/bedrock.md +273 -0
- package/docs/providers/chutes.md +103 -0
- package/docs/providers/claude-max-api-proxy.md +163 -0
- package/docs/providers/cloudflare-ai-gateway.md +71 -0
- package/docs/providers/deepgram.md +93 -0
- package/docs/providers/deepseek.md +53 -0
- package/docs/providers/fireworks.md +69 -0
- package/docs/providers/github-copilot.md +80 -0
- package/docs/providers/glm.md +68 -0
- package/docs/providers/google.md +149 -0
- package/docs/providers/groq.md +105 -0
- package/docs/providers/huggingface.md +193 -0
- package/docs/providers/index.md +81 -0
- package/docs/providers/kilocode.md +89 -0
- package/docs/providers/litellm.md +159 -0
- package/docs/providers/minimax.md +281 -0
- package/docs/providers/mistral.md +68 -0
- package/docs/providers/models.md +56 -0
- package/docs/providers/moonshot.md +224 -0
- package/docs/providers/nvidia.md +58 -0
- package/docs/providers/ollama.md +379 -0
- package/docs/providers/openai.md +472 -0
- package/docs/providers/opencode-go.md +45 -0
- package/docs/providers/opencode.md +68 -0
- package/docs/providers/openrouter.md +59 -0
- package/docs/providers/perplexity-provider.md +62 -0
- package/docs/providers/qianfan.md +90 -0
- package/docs/providers/qwen.md +128 -0
- package/docs/providers/qwen_modelstudio.md +137 -0
- package/docs/providers/sglang.md +115 -0
- package/docs/providers/stepfun.md +152 -0
- package/docs/providers/synthetic.md +101 -0
- package/docs/providers/together.md +70 -0
- package/docs/providers/venice.md +282 -0
- package/docs/providers/vercel-ai-gateway.md +60 -0
- package/docs/providers/vllm.md +103 -0
- package/docs/providers/volcengine.md +94 -0
- package/docs/providers/xai.md +94 -0
- package/docs/providers/xiaomi.md +89 -0
- package/docs/providers/zai.md +75 -0
- package/docs/reference/AGENTS.default.md +126 -0
- package/docs/reference/RELEASING.md +138 -0
- package/docs/reference/api-usage-costs.md +198 -0
- package/docs/reference/credits.md +30 -0
- package/docs/reference/device-models.md +47 -0
- package/docs/reference/memory-config.md +421 -0
- package/docs/reference/prompt-caching.md +344 -0
- package/docs/reference/rpc.md +43 -0
- package/docs/reference/secretref-credential-surface.md +148 -0
- package/docs/reference/secretref-user-supplied-credentials-matrix.json +607 -0
- package/docs/reference/session-management-compaction.md +352 -0
- package/docs/reference/templates/AGENTS.dev.md +84 -0
- package/docs/reference/templates/AGENTS.md +219 -0
- package/docs/reference/templates/BOOT.md +12 -0
- package/docs/reference/templates/BOOTSTRAP.md +62 -0
- package/docs/reference/templates/CLAUDE.md +1 -0
- package/docs/reference/templates/HEARTBEAT.md +14 -0
- package/docs/reference/templates/IDENTITY.dev.md +48 -0
- package/docs/reference/templates/IDENTITY.md +30 -0
- package/docs/reference/templates/SOUL.dev.md +77 -0
- package/docs/reference/templates/SOUL.md +45 -0
- package/docs/reference/templates/TOOLS.dev.md +25 -0
- package/docs/reference/templates/TOOLS.md +47 -0
- package/docs/reference/templates/USER.dev.md +19 -0
- package/docs/reference/templates/USER.md +24 -0
- package/docs/reference/test.md +119 -0
- package/docs/reference/token-use.md +197 -0
- package/docs/reference/transcript-hygiene.md +151 -0
- package/docs/reference/wizard.md +245 -0
- package/docs/security/CONTRIBUTING-THREAT-MODEL.md +98 -0
- package/docs/security/THREAT-MODEL-ATLAS.md +608 -0
- package/docs/security/formal-verification.md +167 -0
- package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +9 -0
- package/docs/snippets/plugin-publish/minimal-package.json +16 -0
- package/docs/start/bootstrapping.md +41 -0
- package/docs/start/docs-directory.md +67 -0
- package/docs/start/getting-started.md +148 -0
- package/docs/start/hubs.md +199 -0
- package/docs/start/lore.md +219 -0
- package/docs/start/onboarding-overview.md +69 -0
- package/docs/start/onboarding.md +92 -0
- package/docs/start/openclaw.md +225 -0
- package/docs/start/quickstart.md +22 -0
- package/docs/start/setup.md +172 -0
- package/docs/start/showcase.md +418 -0
- package/docs/start/wizard-cli-automation.md +233 -0
- package/docs/start/wizard-cli-reference.md +324 -0
- package/docs/start/wizard.md +127 -0
- package/docs/style.css +37 -0
- package/docs/tools/acp-agents.md +837 -0
- package/docs/tools/agent-send.md +100 -0
- package/docs/tools/apply-patch.md +52 -0
- package/docs/tools/brave-search.md +107 -0
- package/docs/tools/browser-linux-troubleshooting.md +145 -0
- package/docs/tools/browser-login.md +73 -0
- package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +221 -0
- package/docs/tools/browser.md +890 -0
- package/docs/tools/btw.md +142 -0
- package/docs/tools/capability-cookbook.md +119 -0
- package/docs/tools/clawhub.md +348 -0
- package/docs/tools/code-execution.md +90 -0
- package/docs/tools/creating-skills.md +119 -0
- package/docs/tools/diffs.md +434 -0
- package/docs/tools/duckduckgo-search.md +102 -0
- package/docs/tools/elevated.md +116 -0
- package/docs/tools/exa-search.md +127 -0
- package/docs/tools/exec-approvals.md +635 -0
- package/docs/tools/exec.md +237 -0
- package/docs/tools/firecrawl.md +147 -0
- package/docs/tools/gemini-search.md +98 -0
- package/docs/tools/grok-search.md +102 -0
- package/docs/tools/image-generation.md +139 -0
- package/docs/tools/index.md +174 -0
- package/docs/tools/kimi-search.md +98 -0
- package/docs/tools/llm-task.md +119 -0
- package/docs/tools/lobster.md +348 -0
- package/docs/tools/loop-detection.md +100 -0
- package/docs/tools/minimax-search.md +99 -0
- package/docs/tools/multi-agent-sandbox-tools.md +373 -0
- package/docs/tools/ollama-search.md +100 -0
- package/docs/tools/pdf.md +176 -0
- package/docs/tools/perplexity-search.md +185 -0
- package/docs/tools/plugin.md +348 -0
- package/docs/tools/reactions.md +78 -0
- package/docs/tools/searxng-search.md +132 -0
- package/docs/tools/skills-config.md +133 -0
- package/docs/tools/skills.md +377 -0
- package/docs/tools/slash-commands.md +322 -0
- package/docs/tools/subagents.md +341 -0
- package/docs/tools/tavily.md +129 -0
- package/docs/tools/thinking.md +102 -0
- package/docs/tools/tts.md +452 -0
- package/docs/tools/web-fetch.md +159 -0
- package/docs/tools/web.md +417 -0
- package/docs/tts.md +452 -0
- package/docs/vps.md +115 -0
- package/docs/web/control-ui.md +318 -0
- package/docs/web/dashboard.md +93 -0
- package/docs/web/index.md +126 -0
- package/docs/web/tui.md +176 -0
- package/docs/web/webchat.md +77 -0
- package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
- package/docs/whatsapp-openclaw.jpg +0 -0
- package/durar.mjs +180 -0
- package/package.json +1259 -0
- package/scripts/npm-runner.mjs +111 -0
- package/scripts/postinstall-bundled-plugins.mjs +188 -0
- package/skills/1password/SKILL.md +70 -0
- package/skills/1password/references/cli-examples.md +29 -0
- package/skills/1password/references/get-started.md +17 -0
- package/skills/apple-notes/SKILL.md +77 -0
- package/skills/apple-reminders/SKILL.md +118 -0
- package/skills/bear-notes/SKILL.md +107 -0
- package/skills/blogwatcher/SKILL.md +69 -0
- package/skills/blucli/SKILL.md +47 -0
- package/skills/bluebubbles/SKILL.md +131 -0
- package/skills/camsnap/SKILL.md +45 -0
- package/skills/canvas/SKILL.md +199 -0
- package/skills/clawhub/SKILL.md +77 -0
- package/skills/coding-agent/SKILL.md +316 -0
- package/skills/discord/SKILL.md +197 -0
- package/skills/eightctl/SKILL.md +50 -0
- package/skills/gemini/SKILL.md +43 -0
- package/skills/gh-issues/SKILL.md +885 -0
- package/skills/gifgrep/SKILL.md +79 -0
- package/skills/github/SKILL.md +163 -0
- package/skills/gog/SKILL.md +116 -0
- package/skills/goplaces/SKILL.md +52 -0
- package/skills/healthcheck/SKILL.md +245 -0
- package/skills/himalaya/SKILL.md +257 -0
- package/skills/himalaya/references/configuration.md +184 -0
- package/skills/himalaya/references/message-composition.md +199 -0
- package/skills/imsg/SKILL.md +122 -0
- package/skills/mcporter/SKILL.md +61 -0
- package/skills/model-usage/SKILL.md +69 -0
- package/skills/model-usage/references/codexbar-cli.md +33 -0
- package/skills/model-usage/scripts/model_usage.py +320 -0
- package/skills/model-usage/scripts/test_model_usage.py +40 -0
- package/skills/nano-pdf/SKILL.md +38 -0
- package/skills/node-connect/SKILL.md +142 -0
- package/skills/notion/SKILL.md +174 -0
- package/skills/obsidian/SKILL.md +81 -0
- package/skills/openai-whisper/SKILL.md +38 -0
- package/skills/openai-whisper-api/SKILL.md +62 -0
- package/skills/openai-whisper-api/scripts/transcribe.sh +88 -0
- package/skills/openhue/SKILL.md +112 -0
- package/skills/oracle/SKILL.md +125 -0
- package/skills/ordercli/SKILL.md +78 -0
- package/skills/peekaboo/SKILL.md +190 -0
- package/skills/sag/SKILL.md +87 -0
- package/skills/session-logs/SKILL.md +151 -0
- package/skills/sherpa-onnx-tts/SKILL.md +109 -0
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
- package/skills/skill-creator/SKILL.md +372 -0
- package/skills/skill-creator/license.txt +202 -0
- package/skills/skill-creator/scripts/init_skill.py +378 -0
- package/skills/skill-creator/scripts/package_skill.py +139 -0
- package/skills/skill-creator/scripts/quick_validate.py +159 -0
- package/skills/skill-creator/scripts/test_package_skill.py +160 -0
- package/skills/skill-creator/scripts/test_quick_validate.py +72 -0
- package/skills/slack/SKILL.md +144 -0
- package/skills/songsee/SKILL.md +49 -0
- package/skills/sonoscli/SKILL.md +65 -0
- package/skills/spotify-player/SKILL.md +64 -0
- package/skills/summarize/SKILL.md +87 -0
- package/skills/taskflow/SKILL.md +149 -0
- package/skills/taskflow/examples/inbox-triage.lobster +33 -0
- package/skills/taskflow/examples/pr-intake.lobster +32 -0
- package/skills/taskflow-inbox-triage/SKILL.md +119 -0
- package/skills/things-mac/SKILL.md +86 -0
- package/skills/tmux/SKILL.md +170 -0
- package/skills/tmux/scripts/find-sessions.sh +112 -0
- package/skills/tmux/scripts/wait-for-text.sh +83 -0
- package/skills/trello/SKILL.md +108 -0
- package/skills/video-frames/SKILL.md +46 -0
- package/skills/video-frames/scripts/frame.sh +81 -0
- package/skills/voice-call/SKILL.md +45 -0
- package/skills/wacli/SKILL.md +72 -0
- package/skills/weather/SKILL.md +129 -0
- 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
|