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,1836 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Durar CLI reference for `Durar` commands, subcommands, and options"
|
|
3
|
+
read_when:
|
|
4
|
+
- Adding or modifying CLI commands or options
|
|
5
|
+
- Documenting new command surfaces
|
|
6
|
+
title: "CLI Reference"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# CLI reference
|
|
10
|
+
|
|
11
|
+
This page describes the current CLI behavior. If commands change, update this doc.
|
|
12
|
+
|
|
13
|
+
## Command pages
|
|
14
|
+
|
|
15
|
+
- [`setup`](/cli/setup)
|
|
16
|
+
- [`onboard`](/cli/onboard)
|
|
17
|
+
- [`configure`](/cli/configure)
|
|
18
|
+
- [`config`](/cli/config)
|
|
19
|
+
- [`completion`](/cli/completion)
|
|
20
|
+
- [`doctor`](/cli/doctor)
|
|
21
|
+
- [`dashboard`](/cli/dashboard)
|
|
22
|
+
- [`backup`](/cli/backup)
|
|
23
|
+
- [`reset`](/cli/reset)
|
|
24
|
+
- [`uninstall`](/cli/uninstall)
|
|
25
|
+
- [`update`](/cli/update)
|
|
26
|
+
- [`message`](/cli/message)
|
|
27
|
+
- [`agent`](/cli/agent)
|
|
28
|
+
- [`agents`](/cli/agents)
|
|
29
|
+
- [`acp`](/cli/acp)
|
|
30
|
+
- [`mcp`](/cli/mcp)
|
|
31
|
+
- [`status`](/cli/status)
|
|
32
|
+
- [`health`](/cli/health)
|
|
33
|
+
- [`sessions`](/cli/sessions)
|
|
34
|
+
- [`gateway`](/cli/gateway)
|
|
35
|
+
- [`logs`](/cli/logs)
|
|
36
|
+
- [`system`](/cli/system)
|
|
37
|
+
- [`models`](/cli/models)
|
|
38
|
+
- [`memory`](/cli/memory)
|
|
39
|
+
- [`directory`](/cli/directory)
|
|
40
|
+
- [`nodes`](/cli/nodes)
|
|
41
|
+
- [`devices`](/cli/devices)
|
|
42
|
+
- [`node`](/cli/node)
|
|
43
|
+
- [`approvals`](/cli/approvals)
|
|
44
|
+
- [`sandbox`](/cli/sandbox)
|
|
45
|
+
- [`tui`](/cli/tui)
|
|
46
|
+
- [`browser`](/cli/browser)
|
|
47
|
+
- [`cron`](/cli/cron)
|
|
48
|
+
- [`tasks`](/cli/index#tasks)
|
|
49
|
+
- [`flows`](/cli/flows)
|
|
50
|
+
- [`dns`](/cli/dns)
|
|
51
|
+
- [`docs`](/cli/docs)
|
|
52
|
+
- [`hooks`](/cli/hooks)
|
|
53
|
+
- [`webhooks`](/cli/webhooks)
|
|
54
|
+
- [`pairing`](/cli/pairing)
|
|
55
|
+
- [`qr`](/cli/qr)
|
|
56
|
+
- [`plugins`](/cli/plugins) (plugin commands)
|
|
57
|
+
- [`channels`](/cli/channels)
|
|
58
|
+
- [`security`](/cli/security)
|
|
59
|
+
- [`secrets`](/cli/secrets)
|
|
60
|
+
- [`skills`](/cli/skills)
|
|
61
|
+
- [`daemon`](/cli/daemon) (legacy alias for gateway service commands)
|
|
62
|
+
- [`clawbot`](/cli/clawbot) (legacy alias namespace)
|
|
63
|
+
- [`voicecall`](/cli/voicecall) (plugin; if installed)
|
|
64
|
+
|
|
65
|
+
## Global flags
|
|
66
|
+
|
|
67
|
+
- `--dev`: isolate state under `~/.Durar-dev` and shift default ports.
|
|
68
|
+
- `--profile <name>`: isolate state under `~/.Durar-<name>`.
|
|
69
|
+
- `--container <name>`: target a named container for execution.
|
|
70
|
+
- `--no-color`: disable ANSI colors.
|
|
71
|
+
- `--update`: shorthand for `Durar update` (source installs only).
|
|
72
|
+
- `-V`, `--version`, `-v`: print version and exit.
|
|
73
|
+
|
|
74
|
+
## Output styling
|
|
75
|
+
|
|
76
|
+
- ANSI colors and progress indicators only render in TTY sessions.
|
|
77
|
+
- OSC-8 hyperlinks render as clickable links in supported terminals; otherwise we fall back to plain URLs.
|
|
78
|
+
- `--json` (and `--plain` where supported) disables styling for clean output.
|
|
79
|
+
- `--no-color` disables ANSI styling; `NO_COLOR=1` is also respected.
|
|
80
|
+
- Long-running commands show a progress indicator (OSC 9;4 when supported).
|
|
81
|
+
|
|
82
|
+
## Color palette
|
|
83
|
+
|
|
84
|
+
Durar uses a lobster palette for CLI output.
|
|
85
|
+
|
|
86
|
+
- `accent` (#FF5A2D): headings, labels, primary highlights.
|
|
87
|
+
- `accentBright` (#FF7A3D): command names, emphasis.
|
|
88
|
+
- `accentDim` (#D14A22): secondary highlight text.
|
|
89
|
+
- `info` (#FF8A5B): informational values.
|
|
90
|
+
- `success` (#2FBF71): success states.
|
|
91
|
+
- `warn` (#FFB020): warnings, fallbacks, attention.
|
|
92
|
+
- `error` (#E23D2D): errors, failures.
|
|
93
|
+
- `muted` (#8B7F77): de-emphasis, metadata.
|
|
94
|
+
|
|
95
|
+
Palette source of truth: `src/terminal/palette.ts` (the “lobster palette”).
|
|
96
|
+
|
|
97
|
+
## Command tree
|
|
98
|
+
|
|
99
|
+
```
|
|
100
|
+
Durar [--dev] [--profile <name>] <command>
|
|
101
|
+
setup
|
|
102
|
+
onboard
|
|
103
|
+
configure
|
|
104
|
+
config
|
|
105
|
+
get
|
|
106
|
+
set
|
|
107
|
+
unset
|
|
108
|
+
file
|
|
109
|
+
schema
|
|
110
|
+
validate
|
|
111
|
+
completion
|
|
112
|
+
doctor
|
|
113
|
+
dashboard
|
|
114
|
+
backup
|
|
115
|
+
create
|
|
116
|
+
verify
|
|
117
|
+
security
|
|
118
|
+
audit
|
|
119
|
+
secrets
|
|
120
|
+
reload
|
|
121
|
+
audit
|
|
122
|
+
configure
|
|
123
|
+
apply
|
|
124
|
+
reset
|
|
125
|
+
uninstall
|
|
126
|
+
update
|
|
127
|
+
wizard
|
|
128
|
+
status
|
|
129
|
+
channels
|
|
130
|
+
list
|
|
131
|
+
status
|
|
132
|
+
capabilities
|
|
133
|
+
resolve
|
|
134
|
+
logs
|
|
135
|
+
add
|
|
136
|
+
remove
|
|
137
|
+
login
|
|
138
|
+
logout
|
|
139
|
+
directory
|
|
140
|
+
self
|
|
141
|
+
peers list
|
|
142
|
+
groups list|members
|
|
143
|
+
skills
|
|
144
|
+
search
|
|
145
|
+
install
|
|
146
|
+
update
|
|
147
|
+
list
|
|
148
|
+
info
|
|
149
|
+
check
|
|
150
|
+
plugins
|
|
151
|
+
list
|
|
152
|
+
inspect
|
|
153
|
+
install
|
|
154
|
+
uninstall
|
|
155
|
+
update
|
|
156
|
+
enable
|
|
157
|
+
disable
|
|
158
|
+
doctor
|
|
159
|
+
marketplace list
|
|
160
|
+
memory
|
|
161
|
+
status
|
|
162
|
+
index
|
|
163
|
+
search
|
|
164
|
+
message
|
|
165
|
+
send
|
|
166
|
+
broadcast
|
|
167
|
+
poll
|
|
168
|
+
react
|
|
169
|
+
reactions
|
|
170
|
+
read
|
|
171
|
+
edit
|
|
172
|
+
delete
|
|
173
|
+
pin
|
|
174
|
+
unpin
|
|
175
|
+
pins
|
|
176
|
+
permissions
|
|
177
|
+
search
|
|
178
|
+
thread create|list|reply
|
|
179
|
+
emoji list|upload
|
|
180
|
+
sticker send|upload
|
|
181
|
+
role info|add|remove
|
|
182
|
+
channel info|list
|
|
183
|
+
member info
|
|
184
|
+
voice status
|
|
185
|
+
event list|create
|
|
186
|
+
timeout
|
|
187
|
+
kick
|
|
188
|
+
ban
|
|
189
|
+
agent
|
|
190
|
+
agents
|
|
191
|
+
list
|
|
192
|
+
add
|
|
193
|
+
delete
|
|
194
|
+
bindings
|
|
195
|
+
bind
|
|
196
|
+
unbind
|
|
197
|
+
set-identity
|
|
198
|
+
acp
|
|
199
|
+
mcp
|
|
200
|
+
serve
|
|
201
|
+
list
|
|
202
|
+
show
|
|
203
|
+
set
|
|
204
|
+
unset
|
|
205
|
+
status
|
|
206
|
+
health
|
|
207
|
+
sessions
|
|
208
|
+
cleanup
|
|
209
|
+
tasks
|
|
210
|
+
list
|
|
211
|
+
audit
|
|
212
|
+
maintenance
|
|
213
|
+
show
|
|
214
|
+
notify
|
|
215
|
+
cancel
|
|
216
|
+
flow list|show|cancel
|
|
217
|
+
gateway
|
|
218
|
+
call
|
|
219
|
+
usage-cost
|
|
220
|
+
health
|
|
221
|
+
status
|
|
222
|
+
probe
|
|
223
|
+
discover
|
|
224
|
+
install
|
|
225
|
+
uninstall
|
|
226
|
+
start
|
|
227
|
+
stop
|
|
228
|
+
restart
|
|
229
|
+
run
|
|
230
|
+
daemon
|
|
231
|
+
status
|
|
232
|
+
install
|
|
233
|
+
uninstall
|
|
234
|
+
start
|
|
235
|
+
stop
|
|
236
|
+
restart
|
|
237
|
+
logs
|
|
238
|
+
system
|
|
239
|
+
event
|
|
240
|
+
heartbeat last|enable|disable
|
|
241
|
+
presence
|
|
242
|
+
models
|
|
243
|
+
list
|
|
244
|
+
status
|
|
245
|
+
set
|
|
246
|
+
set-image
|
|
247
|
+
aliases list|add|remove
|
|
248
|
+
fallbacks list|add|remove|clear
|
|
249
|
+
image-fallbacks list|add|remove|clear
|
|
250
|
+
scan
|
|
251
|
+
auth add|login|login-github-copilot|setup-token|paste-token
|
|
252
|
+
auth order get|set|clear
|
|
253
|
+
sandbox
|
|
254
|
+
list
|
|
255
|
+
recreate
|
|
256
|
+
explain
|
|
257
|
+
cron
|
|
258
|
+
status
|
|
259
|
+
list
|
|
260
|
+
add
|
|
261
|
+
edit
|
|
262
|
+
rm
|
|
263
|
+
enable
|
|
264
|
+
disable
|
|
265
|
+
runs
|
|
266
|
+
run
|
|
267
|
+
nodes
|
|
268
|
+
status
|
|
269
|
+
describe
|
|
270
|
+
list
|
|
271
|
+
pending
|
|
272
|
+
approve
|
|
273
|
+
reject
|
|
274
|
+
rename
|
|
275
|
+
invoke
|
|
276
|
+
notify
|
|
277
|
+
push
|
|
278
|
+
canvas snapshot|present|hide|navigate|eval
|
|
279
|
+
canvas a2ui push|reset
|
|
280
|
+
camera list|snap|clip
|
|
281
|
+
screen record
|
|
282
|
+
location get
|
|
283
|
+
devices
|
|
284
|
+
list
|
|
285
|
+
remove
|
|
286
|
+
clear
|
|
287
|
+
approve
|
|
288
|
+
reject
|
|
289
|
+
rotate
|
|
290
|
+
revoke
|
|
291
|
+
node
|
|
292
|
+
run
|
|
293
|
+
status
|
|
294
|
+
install
|
|
295
|
+
uninstall
|
|
296
|
+
stop
|
|
297
|
+
restart
|
|
298
|
+
approvals
|
|
299
|
+
get
|
|
300
|
+
set
|
|
301
|
+
allowlist add|remove
|
|
302
|
+
browser
|
|
303
|
+
status
|
|
304
|
+
start
|
|
305
|
+
stop
|
|
306
|
+
reset-profile
|
|
307
|
+
tabs
|
|
308
|
+
open
|
|
309
|
+
focus
|
|
310
|
+
close
|
|
311
|
+
profiles
|
|
312
|
+
create-profile
|
|
313
|
+
delete-profile
|
|
314
|
+
screenshot
|
|
315
|
+
snapshot
|
|
316
|
+
navigate
|
|
317
|
+
resize
|
|
318
|
+
click
|
|
319
|
+
type
|
|
320
|
+
press
|
|
321
|
+
hover
|
|
322
|
+
drag
|
|
323
|
+
select
|
|
324
|
+
upload
|
|
325
|
+
fill
|
|
326
|
+
dialog
|
|
327
|
+
wait
|
|
328
|
+
evaluate
|
|
329
|
+
console
|
|
330
|
+
pdf
|
|
331
|
+
hooks
|
|
332
|
+
list
|
|
333
|
+
info
|
|
334
|
+
check
|
|
335
|
+
enable
|
|
336
|
+
disable
|
|
337
|
+
install
|
|
338
|
+
update
|
|
339
|
+
webhooks
|
|
340
|
+
gmail setup|run
|
|
341
|
+
pairing
|
|
342
|
+
list
|
|
343
|
+
approve
|
|
344
|
+
qr
|
|
345
|
+
clawbot
|
|
346
|
+
qr
|
|
347
|
+
docs
|
|
348
|
+
dns
|
|
349
|
+
setup
|
|
350
|
+
tui
|
|
351
|
+
```
|
|
352
|
+
|
|
353
|
+
Note: plugins can add additional top-level commands (for example `Durar voicecall`).
|
|
354
|
+
|
|
355
|
+
## Security
|
|
356
|
+
|
|
357
|
+
- `Durar security audit` — audit config + local state for common security foot-guns.
|
|
358
|
+
- `Durar security audit --deep` — best-effort live Gateway probe.
|
|
359
|
+
- `Durar security audit --fix` — tighten safe defaults and state/config permissions.
|
|
360
|
+
|
|
361
|
+
## Secrets
|
|
362
|
+
|
|
363
|
+
### `secrets`
|
|
364
|
+
|
|
365
|
+
Manage SecretRefs and related runtime/config hygiene.
|
|
366
|
+
|
|
367
|
+
Subcommands:
|
|
368
|
+
|
|
369
|
+
- `secrets reload`
|
|
370
|
+
- `secrets audit`
|
|
371
|
+
- `secrets configure`
|
|
372
|
+
- `secrets apply --from <path>`
|
|
373
|
+
|
|
374
|
+
`secrets reload` options:
|
|
375
|
+
|
|
376
|
+
- `--url`, `--token`, `--timeout`, `--expect-final`, `--json`
|
|
377
|
+
|
|
378
|
+
`secrets audit` options:
|
|
379
|
+
|
|
380
|
+
- `--check`
|
|
381
|
+
- `--allow-exec`
|
|
382
|
+
- `--json`
|
|
383
|
+
|
|
384
|
+
`secrets configure` options:
|
|
385
|
+
|
|
386
|
+
- `--apply`
|
|
387
|
+
- `--yes`
|
|
388
|
+
- `--providers-only`
|
|
389
|
+
- `--skip-provider-setup`
|
|
390
|
+
- `--agent <id>`
|
|
391
|
+
- `--allow-exec`
|
|
392
|
+
- `--plan-out <path>`
|
|
393
|
+
- `--json`
|
|
394
|
+
|
|
395
|
+
`secrets apply --from <path>` options:
|
|
396
|
+
|
|
397
|
+
- `--dry-run`
|
|
398
|
+
- `--allow-exec`
|
|
399
|
+
- `--json`
|
|
400
|
+
|
|
401
|
+
Notes:
|
|
402
|
+
|
|
403
|
+
- `reload` is a Gateway RPC and keeps the last-known-good runtime snapshot when resolution fails.
|
|
404
|
+
- `audit --check` returns non-zero on findings; unresolved refs use a higher-priority non-zero exit code.
|
|
405
|
+
- Dry-run exec checks are skipped by default; use `--allow-exec` to opt in.
|
|
406
|
+
|
|
407
|
+
## Plugins
|
|
408
|
+
|
|
409
|
+
Manage extensions and their config:
|
|
410
|
+
|
|
411
|
+
- `Durar plugins list` — discover plugins (use `--json` for machine output).
|
|
412
|
+
- `Durar plugins inspect <id>` — show details for a plugin (`info` is an alias).
|
|
413
|
+
- `Durar plugins install <path|.tgz|npm-spec|plugin@marketplace>` — install a plugin (or add a plugin path to `plugins.load.paths`; use `--force` to overwrite an existing install target).
|
|
414
|
+
- `Durar plugins marketplace list <marketplace>` — list marketplace entries before install.
|
|
415
|
+
- `Durar plugins enable <id>` / `disable <id>` — toggle `plugins.entries.<id>.enabled`.
|
|
416
|
+
- `Durar plugins doctor` — report plugin load errors.
|
|
417
|
+
|
|
418
|
+
Most plugin changes require a gateway restart. See [/plugin](/tools/plugin).
|
|
419
|
+
|
|
420
|
+
## Memory
|
|
421
|
+
|
|
422
|
+
Vector search over `MEMORY.md` + `memory/*.md`:
|
|
423
|
+
|
|
424
|
+
- `Durar memory status` — show index stats; use `--deep` for vector + embedding readiness checks or `--fix` to repair stale recall/promotion artifacts.
|
|
425
|
+
- `Durar memory index` — reindex memory files.
|
|
426
|
+
- `Durar memory search "<query>"` (or `--query "<query>"`) — semantic search over memory.
|
|
427
|
+
- `Durar memory promote` — rank short-term recalls and optionally append top entries into `MEMORY.md`.
|
|
428
|
+
|
|
429
|
+
## Sandbox
|
|
430
|
+
|
|
431
|
+
Manage sandbox runtimes for isolated agent execution. See [/cli/sandbox](/cli/sandbox).
|
|
432
|
+
|
|
433
|
+
Subcommands:
|
|
434
|
+
|
|
435
|
+
- `sandbox list [--browser] [--json]`
|
|
436
|
+
- `sandbox recreate [--all] [--session <key>] [--agent <id>] [--browser] [--force]`
|
|
437
|
+
- `sandbox explain [--session <key>] [--agent <id>] [--json]`
|
|
438
|
+
|
|
439
|
+
Notes:
|
|
440
|
+
|
|
441
|
+
- `sandbox recreate` removes existing runtimes so the next use seeds them again with current config.
|
|
442
|
+
- For `ssh` and OpenShell `remote` backends, recreate deletes the canonical remote workspace for the selected scope.
|
|
443
|
+
|
|
444
|
+
## Chat slash commands
|
|
445
|
+
|
|
446
|
+
Chat messages support `/...` commands (text and native). See [/tools/slash-commands](/tools/slash-commands).
|
|
447
|
+
|
|
448
|
+
Highlights:
|
|
449
|
+
|
|
450
|
+
- `/status` for quick diagnostics.
|
|
451
|
+
- `/config` for persisted config changes.
|
|
452
|
+
- `/debug` for runtime-only config overrides (memory, not disk; requires `commands.debug: true`).
|
|
453
|
+
|
|
454
|
+
## Setup + onboarding
|
|
455
|
+
|
|
456
|
+
### `completion`
|
|
457
|
+
|
|
458
|
+
Generate shell-completion scripts and optionally install them into your shell profile.
|
|
459
|
+
|
|
460
|
+
Options:
|
|
461
|
+
|
|
462
|
+
- `-s, --shell <zsh|bash|powershell|fish>`
|
|
463
|
+
- `-i, --install`
|
|
464
|
+
- `--write-state`
|
|
465
|
+
- `-y, --yes`
|
|
466
|
+
|
|
467
|
+
Notes:
|
|
468
|
+
|
|
469
|
+
- Without `--install` or `--write-state`, `completion` prints the script to stdout.
|
|
470
|
+
- `--install` writes an `Durar Completion` block into your shell profile and points it at the cached script under the Durar state directory.
|
|
471
|
+
|
|
472
|
+
### `setup`
|
|
473
|
+
|
|
474
|
+
Initialize config + workspace.
|
|
475
|
+
|
|
476
|
+
Options:
|
|
477
|
+
|
|
478
|
+
- `--workspace <dir>`: agent workspace path (default `~/.Durar/workspace`).
|
|
479
|
+
- `--wizard`: run onboarding.
|
|
480
|
+
- `--non-interactive`: run onboarding without prompts.
|
|
481
|
+
- `--mode <local|remote>`: onboard mode.
|
|
482
|
+
- `--remote-url <url>`: remote Gateway URL.
|
|
483
|
+
- `--remote-token <token>`: remote Gateway token.
|
|
484
|
+
|
|
485
|
+
Onboarding auto-runs when any onboarding flags are present (`--non-interactive`, `--mode`, `--remote-url`, `--remote-token`).
|
|
486
|
+
|
|
487
|
+
### `onboard`
|
|
488
|
+
|
|
489
|
+
Interactive onboarding for gateway, workspace, and skills.
|
|
490
|
+
|
|
491
|
+
Options:
|
|
492
|
+
|
|
493
|
+
- `--workspace <dir>`
|
|
494
|
+
- `--reset` (reset config + credentials + sessions before onboarding)
|
|
495
|
+
- `--reset-scope <config|config+creds+sessions|full>` (default `config+creds+sessions`; use `full` to also remove workspace)
|
|
496
|
+
- `--non-interactive`
|
|
497
|
+
- `--mode <local|remote>`
|
|
498
|
+
- `--flow <quickstart|advanced|manual>` (manual is an alias for advanced)
|
|
499
|
+
- `--auth-choice <choice>` where `<choice>` is one of:
|
|
500
|
+
`chutes`, `deepseek-api-key`, `openai-codex`, `openai-api-key`,
|
|
501
|
+
`openrouter-api-key`, `kilocode-api-key`, `litellm-api-key`, `ai-gateway-api-key`,
|
|
502
|
+
`cloudflare-ai-gateway-api-key`, `moonshot-api-key`, `moonshot-api-key-cn`,
|
|
503
|
+
`kimi-code-api-key`, `synthetic-api-key`, `venice-api-key`, `together-api-key`,
|
|
504
|
+
`huggingface-api-key`, `apiKey`, `gemini-api-key`, `google-gemini-cli`, `zai-api-key`,
|
|
505
|
+
`zai-coding-global`, `zai-coding-cn`, `zai-global`, `zai-cn`, `xiaomi-api-key`,
|
|
506
|
+
`minimax-global-oauth`, `minimax-global-api`, `minimax-cn-oauth`, `minimax-cn-api`,
|
|
507
|
+
`opencode-zen`, `opencode-go`, `github-copilot`, `copilot-proxy`, `xai-api-key`,
|
|
508
|
+
`mistral-api-key`, `volcengine-api-key`, `byteplus-api-key`, `qianfan-api-key`,
|
|
509
|
+
`qwen-standard-api-key-cn`, `qwen-standard-api-key`, `qwen-api-key-cn`, `qwen-api-key`,
|
|
510
|
+
`modelstudio-standard-api-key-cn`, `modelstudio-standard-api-key`,
|
|
511
|
+
`modelstudio-api-key-cn`, `modelstudio-api-key`, `custom-api-key`, `skip`
|
|
512
|
+
- Qwen note: `qwen-*` is the canonical auth-choice family. `modelstudio-*`
|
|
513
|
+
ids remain accepted as legacy compatibility aliases only.
|
|
514
|
+
- `--secret-input-mode <plaintext|ref>` (default `plaintext`; use `ref` to store provider default env refs instead of plaintext keys)
|
|
515
|
+
- `--anthropic-api-key <key>`
|
|
516
|
+
- `--openai-api-key <key>`
|
|
517
|
+
- `--mistral-api-key <key>`
|
|
518
|
+
- `--openrouter-api-key <key>`
|
|
519
|
+
- `--ai-gateway-api-key <key>`
|
|
520
|
+
- `--moonshot-api-key <key>`
|
|
521
|
+
- `--kimi-code-api-key <key>`
|
|
522
|
+
- `--gemini-api-key <key>`
|
|
523
|
+
- `--zai-api-key <key>`
|
|
524
|
+
- `--minimax-api-key <key>`
|
|
525
|
+
- `--opencode-zen-api-key <key>`
|
|
526
|
+
- `--opencode-go-api-key <key>`
|
|
527
|
+
- `--custom-base-url <url>` (non-interactive; used with `--auth-choice custom-api-key`)
|
|
528
|
+
- `--custom-model-id <id>` (non-interactive; used with `--auth-choice custom-api-key`)
|
|
529
|
+
- `--custom-api-key <key>` (non-interactive; optional; used with `--auth-choice custom-api-key`; falls back to `CUSTOM_API_KEY` when omitted)
|
|
530
|
+
- `--custom-provider-id <id>` (non-interactive; optional custom provider id)
|
|
531
|
+
- `--custom-compatibility <openai|anthropic>` (non-interactive; optional; default `openai`)
|
|
532
|
+
- `--gateway-port <port>`
|
|
533
|
+
- `--gateway-bind <loopback|lan|tailnet|auto|custom>`
|
|
534
|
+
- `--gateway-auth <token|password>`
|
|
535
|
+
- `--gateway-token <token>`
|
|
536
|
+
- `--gateway-token-ref-env <name>` (non-interactive; store `gateway.auth.token` as an env SecretRef; requires that env var to be set; cannot be combined with `--gateway-token`)
|
|
537
|
+
- `--gateway-password <password>`
|
|
538
|
+
- `--remote-url <url>`
|
|
539
|
+
- `--remote-token <token>`
|
|
540
|
+
- `--tailscale <off|serve|funnel>`
|
|
541
|
+
- `--tailscale-reset-on-exit`
|
|
542
|
+
- `--install-daemon`
|
|
543
|
+
- `--no-install-daemon` (alias: `--skip-daemon`)
|
|
544
|
+
- `--daemon-runtime <node|bun>`
|
|
545
|
+
- `--skip-channels`
|
|
546
|
+
- `--skip-skills`
|
|
547
|
+
- `--skip-search`
|
|
548
|
+
- `--skip-health`
|
|
549
|
+
- `--skip-ui`
|
|
550
|
+
- `--cloudflare-ai-gateway-account-id <id>`
|
|
551
|
+
- `--cloudflare-ai-gateway-gateway-id <id>`
|
|
552
|
+
- `--node-manager <npm|pnpm|bun>` (setup/onboarding node manager for skills; pnpm recommended, bun also supported)
|
|
553
|
+
- `--json`
|
|
554
|
+
|
|
555
|
+
### `configure`
|
|
556
|
+
|
|
557
|
+
Interactive configuration wizard (models, channels, skills, gateway).
|
|
558
|
+
|
|
559
|
+
Options:
|
|
560
|
+
|
|
561
|
+
- `--section <section>` (repeatable; limit the wizard to specific sections)
|
|
562
|
+
|
|
563
|
+
### `config`
|
|
564
|
+
|
|
565
|
+
Non-interactive config helpers (get/set/unset/file/schema/validate). Running `Durar config` with no
|
|
566
|
+
subcommand launches the wizard.
|
|
567
|
+
|
|
568
|
+
Subcommands:
|
|
569
|
+
|
|
570
|
+
- `config get <path>`: print a config value (dot/bracket path).
|
|
571
|
+
- `config set`: supports four assignment modes:
|
|
572
|
+
- value mode: `config set <path> <value>` (JSON5-or-string parsing)
|
|
573
|
+
- SecretRef builder mode: `config set <path> --ref-provider <provider> --ref-source <source> --ref-id <id>`
|
|
574
|
+
- provider builder mode: `config set secrets.providers.<alias> --provider-source <env|file|exec> ...`
|
|
575
|
+
- batch mode: `config set --batch-json '<json>'` or `config set --batch-file <path>`
|
|
576
|
+
- `config set --dry-run`: validate assignments without writing `Durar.json` (exec SecretRef checks are skipped by default).
|
|
577
|
+
- `config set --allow-exec --dry-run`: opt in to exec SecretRef dry-run checks (may execute provider commands).
|
|
578
|
+
- `config set --dry-run --json`: emit machine-readable dry-run output (checks + completeness signal, operations, refs checked/skipped, errors).
|
|
579
|
+
- `config set --strict-json`: require JSON5 parsing for path/value input. `--json` remains a legacy alias for strict parsing outside dry-run output mode.
|
|
580
|
+
- `config unset <path>`: remove a value.
|
|
581
|
+
- `config file`: print the active config file path.
|
|
582
|
+
- `config schema`: print the generated JSON schema for `Durar.json`, including propagated field `title` / `description` docs metadata across nested object, wildcard, array-item, and composition branches, plus best-effort live plugin/channel schema metadata.
|
|
583
|
+
- `config validate`: validate the current config against the schema without starting the gateway.
|
|
584
|
+
- `config validate --json`: emit machine-readable JSON output.
|
|
585
|
+
|
|
586
|
+
### `doctor`
|
|
587
|
+
|
|
588
|
+
Health checks + quick fixes (config + gateway + legacy services).
|
|
589
|
+
|
|
590
|
+
Options:
|
|
591
|
+
|
|
592
|
+
- `--no-workspace-suggestions`: disable workspace memory hints.
|
|
593
|
+
- `--yes`: accept defaults without prompting (headless).
|
|
594
|
+
- `--non-interactive`: skip prompts; apply safe migrations only.
|
|
595
|
+
- `--deep`: scan system services for extra gateway installs.
|
|
596
|
+
- `--repair` (alias: `--fix`): attempt automatic repairs for detected issues.
|
|
597
|
+
- `--force`: force repairs even when not strictly needed.
|
|
598
|
+
- `--generate-gateway-token`: generate a new gateway auth token.
|
|
599
|
+
|
|
600
|
+
### `dashboard`
|
|
601
|
+
|
|
602
|
+
Open the Control UI with your current token.
|
|
603
|
+
|
|
604
|
+
Options:
|
|
605
|
+
|
|
606
|
+
- `--no-open`: print the URL but do not launch a browser
|
|
607
|
+
|
|
608
|
+
Notes:
|
|
609
|
+
|
|
610
|
+
- For SecretRef-managed gateway tokens, `dashboard` prints or opens a non-tokenized URL instead of exposing the secret in terminal output or browser launch arguments.
|
|
611
|
+
|
|
612
|
+
### `update`
|
|
613
|
+
|
|
614
|
+
Update the installed CLI.
|
|
615
|
+
|
|
616
|
+
Root options:
|
|
617
|
+
|
|
618
|
+
- `--json`
|
|
619
|
+
- `--no-restart`
|
|
620
|
+
- `--dry-run`
|
|
621
|
+
- `--channel <stable|beta|dev>`
|
|
622
|
+
- `--tag <dist-tag|version|spec>`
|
|
623
|
+
- `--timeout <seconds>`
|
|
624
|
+
- `--yes`
|
|
625
|
+
|
|
626
|
+
Subcommands:
|
|
627
|
+
|
|
628
|
+
- `update status`
|
|
629
|
+
- `update wizard`
|
|
630
|
+
|
|
631
|
+
`update status` options:
|
|
632
|
+
|
|
633
|
+
- `--json`
|
|
634
|
+
- `--timeout <seconds>`
|
|
635
|
+
|
|
636
|
+
`update wizard` options:
|
|
637
|
+
|
|
638
|
+
- `--timeout <seconds>`
|
|
639
|
+
|
|
640
|
+
Notes:
|
|
641
|
+
|
|
642
|
+
- `Durar --update` rewrites to `Durar update`.
|
|
643
|
+
|
|
644
|
+
### `backup`
|
|
645
|
+
|
|
646
|
+
Create and verify local backup archives for Durar state.
|
|
647
|
+
|
|
648
|
+
Subcommands:
|
|
649
|
+
|
|
650
|
+
- `backup create`
|
|
651
|
+
- `backup verify <archive>`
|
|
652
|
+
|
|
653
|
+
`backup create` options:
|
|
654
|
+
|
|
655
|
+
- `--output <path>`
|
|
656
|
+
- `--json`
|
|
657
|
+
- `--dry-run`
|
|
658
|
+
- `--verify`
|
|
659
|
+
- `--only-config`
|
|
660
|
+
- `--no-include-workspace`
|
|
661
|
+
|
|
662
|
+
`backup verify <archive>` options:
|
|
663
|
+
|
|
664
|
+
- `--json`
|
|
665
|
+
|
|
666
|
+
## Channel helpers
|
|
667
|
+
|
|
668
|
+
### `channels`
|
|
669
|
+
|
|
670
|
+
Manage chat channel accounts (WhatsApp/Telegram/Discord/Google Chat/Slack/Mattermost (plugin)/Signal/iMessage/Microsoft Teams).
|
|
671
|
+
|
|
672
|
+
Subcommands:
|
|
673
|
+
|
|
674
|
+
- `channels list`: show configured channels and auth profiles.
|
|
675
|
+
- `channels status`: check gateway reachability and channel health (`--probe` runs live per-account probe/audit checks when the gateway is reachable; if not, it falls back to config-only channel summaries. Use `Durar health` or `Durar status --deep` for broader gateway health probes).
|
|
676
|
+
- Tip: `channels status` prints warnings with suggested fixes when it can detect common misconfigurations (then points you to `Durar doctor`).
|
|
677
|
+
- `channels logs`: show recent channel logs from the gateway log file.
|
|
678
|
+
- `channels add`: wizard-style setup when no flags are passed; flags switch to non-interactive mode.
|
|
679
|
+
- When adding a non-default account to a channel still using single-account top-level config, Durar promotes account-scoped values into the channel account map before writing the new account. Most channels use `accounts.default`; Matrix can preserve an existing matching named/default target instead.
|
|
680
|
+
- Non-interactive `channels add` does not auto-create/upgrade bindings; channel-only bindings continue to match the default account.
|
|
681
|
+
- `channels remove`: disable by default; pass `--delete` to remove config entries without prompts.
|
|
682
|
+
- `channels login`: interactive channel login (WhatsApp Web only).
|
|
683
|
+
- `channels logout`: log out of a channel session (if supported).
|
|
684
|
+
|
|
685
|
+
Common options:
|
|
686
|
+
|
|
687
|
+
- `--channel <name>`: `whatsapp|telegram|discord|googlechat|slack|mattermost|signal|imessage|msteams`
|
|
688
|
+
- `--account <id>`: channel account id (default `default`)
|
|
689
|
+
- `--name <label>`: display name for the account
|
|
690
|
+
|
|
691
|
+
`channels login` options:
|
|
692
|
+
|
|
693
|
+
- `--channel <channel>` (default `whatsapp`; supports `whatsapp`/`web`)
|
|
694
|
+
- `--account <id>`
|
|
695
|
+
- `--verbose`
|
|
696
|
+
|
|
697
|
+
`channels logout` options:
|
|
698
|
+
|
|
699
|
+
- `--channel <channel>` (default `whatsapp`)
|
|
700
|
+
- `--account <id>`
|
|
701
|
+
|
|
702
|
+
`channels list` options:
|
|
703
|
+
|
|
704
|
+
- `--no-usage`: skip model provider usage/quota snapshots (OAuth/API-backed only).
|
|
705
|
+
- `--json`: output JSON (includes usage unless `--no-usage` is set).
|
|
706
|
+
|
|
707
|
+
`channels status` options:
|
|
708
|
+
|
|
709
|
+
- `--probe`
|
|
710
|
+
- `--timeout <ms>`
|
|
711
|
+
- `--json`
|
|
712
|
+
|
|
713
|
+
`channels capabilities` options:
|
|
714
|
+
|
|
715
|
+
- `--channel <name>`
|
|
716
|
+
- `--account <id>` (only with `--channel`)
|
|
717
|
+
- `--target <dest>`
|
|
718
|
+
- `--timeout <ms>`
|
|
719
|
+
- `--json`
|
|
720
|
+
|
|
721
|
+
`channels resolve` options:
|
|
722
|
+
|
|
723
|
+
- `<entries...>`
|
|
724
|
+
- `--channel <name>`
|
|
725
|
+
- `--account <id>`
|
|
726
|
+
- `--kind <auto|user|group>`
|
|
727
|
+
- `--json`
|
|
728
|
+
|
|
729
|
+
`channels logs` options:
|
|
730
|
+
|
|
731
|
+
- `--channel <name|all>` (default `all`)
|
|
732
|
+
- `--lines <n>` (default `200`)
|
|
733
|
+
- `--json`
|
|
734
|
+
|
|
735
|
+
Notes:
|
|
736
|
+
|
|
737
|
+
- `channels login` supports `--verbose`.
|
|
738
|
+
- `channels capabilities --account` only applies when `--channel` is set.
|
|
739
|
+
- `channels status --probe` can show transport state plus probe/audit results such as `works`, `probe failed`, `audit ok`, or `audit failed`, depending on channel support.
|
|
740
|
+
|
|
741
|
+
More detail: [/concepts/oauth](/concepts/oauth)
|
|
742
|
+
|
|
743
|
+
Examples:
|
|
744
|
+
|
|
745
|
+
```bash
|
|
746
|
+
Durar channels add --channel telegram --account alerts --name "Alerts Bot" --token $TELEGRAM_BOT_TOKEN
|
|
747
|
+
Durar channels add --channel discord --account work --name "Work Bot" --token $DISCORD_BOT_TOKEN
|
|
748
|
+
Durar channels remove --channel discord --account work --delete
|
|
749
|
+
Durar channels status --probe
|
|
750
|
+
Durar status --deep
|
|
751
|
+
```
|
|
752
|
+
|
|
753
|
+
### `directory`
|
|
754
|
+
|
|
755
|
+
Look up self, peer, and group IDs for channels that expose a directory surface. See [`Durar directory`](/cli/directory).
|
|
756
|
+
|
|
757
|
+
Common options:
|
|
758
|
+
|
|
759
|
+
- `--channel <name>`
|
|
760
|
+
- `--account <id>`
|
|
761
|
+
- `--json`
|
|
762
|
+
|
|
763
|
+
Subcommands:
|
|
764
|
+
|
|
765
|
+
- `directory self`
|
|
766
|
+
- `directory peers list [--query <text>] [--limit <n>]`
|
|
767
|
+
- `directory groups list [--query <text>] [--limit <n>]`
|
|
768
|
+
- `directory groups members --group-id <id> [--limit <n>]`
|
|
769
|
+
|
|
770
|
+
### `skills`
|
|
771
|
+
|
|
772
|
+
List and inspect available skills plus readiness info.
|
|
773
|
+
|
|
774
|
+
Subcommands:
|
|
775
|
+
|
|
776
|
+
- `skills search [query...]`: search Durar Gateway skills.
|
|
777
|
+
- `skills search --limit <n> --json`: cap search results or emit machine-readable output.
|
|
778
|
+
- `skills install <slug>`: install a skill from Durar Gateway into the active workspace.
|
|
779
|
+
- `skills install <slug> --version <version>`: install a specific Durar Gateway version.
|
|
780
|
+
- `skills install <slug> --force`: overwrite an existing workspace skill folder.
|
|
781
|
+
- `skills update <slug|--all>`: update tracked Durar Gateway skills.
|
|
782
|
+
- `skills list`: list skills (default when no subcommand).
|
|
783
|
+
- `skills list --json`: emit machine-readable skill inventory on stdout.
|
|
784
|
+
- `skills list --verbose`: include missing requirements in the table.
|
|
785
|
+
- `skills info <name>`: show details for one skill.
|
|
786
|
+
- `skills info <name> --json`: emit machine-readable details on stdout.
|
|
787
|
+
- `skills check`: summary of ready vs missing requirements.
|
|
788
|
+
- `skills check --json`: emit machine-readable readiness output on stdout.
|
|
789
|
+
|
|
790
|
+
Options:
|
|
791
|
+
|
|
792
|
+
- `--eligible`: show only ready skills.
|
|
793
|
+
- `--json`: output JSON (no styling).
|
|
794
|
+
- `-v`, `--verbose`: include missing requirements detail.
|
|
795
|
+
|
|
796
|
+
Tip: use `Durar skills search`, `Durar skills install`, and `Durar skills update` for Durar Gateway-backed skills.
|
|
797
|
+
|
|
798
|
+
### `pairing`
|
|
799
|
+
|
|
800
|
+
Approve DM pairing requests across channels.
|
|
801
|
+
|
|
802
|
+
Subcommands:
|
|
803
|
+
|
|
804
|
+
- `pairing list [channel] [--channel <channel>] [--account <id>] [--json]`
|
|
805
|
+
- `pairing approve <channel> <code> [--account <id>] [--notify]`
|
|
806
|
+
- `pairing approve --channel <channel> [--account <id>] <code> [--notify]`
|
|
807
|
+
|
|
808
|
+
Notes:
|
|
809
|
+
|
|
810
|
+
- If exactly one pairing-capable channel is configured, `pairing approve <code>` is also allowed.
|
|
811
|
+
- `list` and `approve` both support `--account <id>` for multi-account channels.
|
|
812
|
+
|
|
813
|
+
### `devices`
|
|
814
|
+
|
|
815
|
+
Manage gateway device pairing entries and per-role device tokens.
|
|
816
|
+
|
|
817
|
+
Subcommands:
|
|
818
|
+
|
|
819
|
+
- `devices list [--json]`
|
|
820
|
+
- `devices approve [requestId] [--latest]`
|
|
821
|
+
- `devices reject <requestId>`
|
|
822
|
+
- `devices remove <deviceId>`
|
|
823
|
+
- `devices clear --yes [--pending]`
|
|
824
|
+
- `devices rotate --device <id> --role <role> [--scope <scope...>]`
|
|
825
|
+
- `devices revoke --device <id> --role <role>`
|
|
826
|
+
|
|
827
|
+
Notes:
|
|
828
|
+
|
|
829
|
+
- `devices list` and `devices approve` can fall back to local pairing files on local loopback when direct pairing scope is unavailable.
|
|
830
|
+
- `devices approve` auto-selects the newest pending request when no `requestId` is passed or `--latest` is set.
|
|
831
|
+
- Stored-token reconnects reuse the token's cached approved scopes; explicit
|
|
832
|
+
`devices rotate --scope ...` updates that stored scope set for future
|
|
833
|
+
cached-token reconnects.
|
|
834
|
+
- `devices rotate` and `devices revoke` return JSON payloads.
|
|
835
|
+
|
|
836
|
+
### `qr`
|
|
837
|
+
|
|
838
|
+
Generate a mobile pairing QR and setup code from the current Gateway config. See [`Durar qr`](/cli/qr).
|
|
839
|
+
|
|
840
|
+
Options:
|
|
841
|
+
|
|
842
|
+
- `--remote`
|
|
843
|
+
- `--url <url>`
|
|
844
|
+
- `--public-url <url>`
|
|
845
|
+
- `--token <token>`
|
|
846
|
+
- `--password <password>`
|
|
847
|
+
- `--setup-code-only`
|
|
848
|
+
- `--no-ascii`
|
|
849
|
+
- `--json`
|
|
850
|
+
|
|
851
|
+
Notes:
|
|
852
|
+
|
|
853
|
+
- `--token` and `--password` are mutually exclusive.
|
|
854
|
+
- The setup code carries a short-lived bootstrap token, not the shared gateway token/password.
|
|
855
|
+
- Built-in bootstrap handoff keeps the primary node token at `scopes: []`.
|
|
856
|
+
- Any handed-off operator bootstrap token stays bounded to `operator.approvals`, `operator.read`, `operator.talk.secrets`, and `operator.write`.
|
|
857
|
+
- Bootstrap scope checks are role-prefixed, so that operator allowlist only satisfies operator requests; non-operator roles still need scopes under their own role prefix.
|
|
858
|
+
- `--remote` can use `gateway.remote.url` or the active Tailscale Serve/Funnel URL.
|
|
859
|
+
- After scanning, approve the request with `Durar devices list` / `Durar devices approve <requestId>`.
|
|
860
|
+
|
|
861
|
+
### `clawbot`
|
|
862
|
+
|
|
863
|
+
Legacy alias namespace. Currently supports `Durar clawbot qr`, which maps to [`Durar qr`](/cli/qr).
|
|
864
|
+
|
|
865
|
+
### `hooks`
|
|
866
|
+
|
|
867
|
+
Manage internal agent hooks.
|
|
868
|
+
|
|
869
|
+
Subcommands:
|
|
870
|
+
|
|
871
|
+
- `hooks list`
|
|
872
|
+
- `hooks info <name>`
|
|
873
|
+
- `hooks check`
|
|
874
|
+
- `hooks enable <name>`
|
|
875
|
+
- `hooks disable <name>`
|
|
876
|
+
- `hooks install <path-or-spec>` (deprecated alias for `Durar plugins install`)
|
|
877
|
+
- `hooks update [id]` (deprecated alias for `Durar plugins update`)
|
|
878
|
+
|
|
879
|
+
Common options:
|
|
880
|
+
|
|
881
|
+
- `--json`
|
|
882
|
+
- `--eligible`
|
|
883
|
+
- `-v`, `--verbose`
|
|
884
|
+
|
|
885
|
+
Notes:
|
|
886
|
+
|
|
887
|
+
- Plugin-managed hooks cannot be enabled or disabled through `Durar hooks`; enable or disable the owning plugin instead.
|
|
888
|
+
- `hooks install` and `hooks update` still work as compatibility aliases, but they print deprecation warnings and forward to the plugin commands.
|
|
889
|
+
|
|
890
|
+
### `webhooks`
|
|
891
|
+
|
|
892
|
+
Webhook helpers. Current built-in surface is Gmail Pub/Sub setup + runner:
|
|
893
|
+
|
|
894
|
+
- `webhooks gmail setup`
|
|
895
|
+
- `webhooks gmail run`
|
|
896
|
+
|
|
897
|
+
### `webhooks gmail`
|
|
898
|
+
|
|
899
|
+
Gmail Pub/Sub hook setup + runner. See [Gmail Pub/Sub](/automation/cron-jobs#gmail-pubsub-integration).
|
|
900
|
+
|
|
901
|
+
Subcommands:
|
|
902
|
+
|
|
903
|
+
- `webhooks gmail setup` (requires `--account <email>`; supports `--project`, `--topic`, `--subscription`, `--label`, `--hook-url`, `--hook-token`, `--push-token`, `--bind`, `--port`, `--path`, `--include-body`, `--max-bytes`, `--renew-minutes`, `--tailscale`, `--tailscale-path`, `--tailscale-target`, `--push-endpoint`, `--json`)
|
|
904
|
+
- `webhooks gmail run` (runtime overrides for the same flags)
|
|
905
|
+
|
|
906
|
+
Notes:
|
|
907
|
+
|
|
908
|
+
- `setup` configures the Gmail watch plus the Durar-facing push path.
|
|
909
|
+
- `run` starts the local Gmail watcher/renew loop with optional runtime overrides.
|
|
910
|
+
|
|
911
|
+
### `dns`
|
|
912
|
+
|
|
913
|
+
Wide-area discovery DNS helpers (CoreDNS + Tailscale). Current built-in surface:
|
|
914
|
+
|
|
915
|
+
- `dns setup [--domain <domain>] [--apply]`
|
|
916
|
+
|
|
917
|
+
### `dns setup`
|
|
918
|
+
|
|
919
|
+
Wide-area discovery DNS helper (CoreDNS + Tailscale). See [/gateway/discovery](/gateway/discovery).
|
|
920
|
+
|
|
921
|
+
Options:
|
|
922
|
+
|
|
923
|
+
- `--domain <domain>`
|
|
924
|
+
- `--apply`: install/update CoreDNS config (requires sudo; macOS only).
|
|
925
|
+
|
|
926
|
+
Notes:
|
|
927
|
+
|
|
928
|
+
- Without `--apply`, this is a planning helper that prints the recommended Durar + Tailscale DNS config.
|
|
929
|
+
- `--apply` currently supports macOS with Homebrew CoreDNS only.
|
|
930
|
+
|
|
931
|
+
## Messaging + agent
|
|
932
|
+
|
|
933
|
+
### `message`
|
|
934
|
+
|
|
935
|
+
Unified outbound messaging + channel actions.
|
|
936
|
+
|
|
937
|
+
See: [/cli/message](/cli/message)
|
|
938
|
+
|
|
939
|
+
Subcommands:
|
|
940
|
+
|
|
941
|
+
- `message send|poll|react|reactions|read|edit|delete|pin|unpin|pins|permissions|search|timeout|kick|ban`
|
|
942
|
+
- `message thread <create|list|reply>`
|
|
943
|
+
- `message emoji <list|upload>`
|
|
944
|
+
- `message sticker <send|upload>`
|
|
945
|
+
- `message role <info|add|remove>`
|
|
946
|
+
- `message channel <info|list>`
|
|
947
|
+
- `message member info`
|
|
948
|
+
- `message voice status`
|
|
949
|
+
- `message event <list|create>`
|
|
950
|
+
|
|
951
|
+
Examples:
|
|
952
|
+
|
|
953
|
+
- `Durar message send --target +15555550123 --message "Hi"`
|
|
954
|
+
- `Durar message poll --channel discord --target channel:123 --poll-question "Snack?" --poll-option Pizza --poll-option Sushi`
|
|
955
|
+
|
|
956
|
+
### `agent`
|
|
957
|
+
|
|
958
|
+
Run one agent turn via the Gateway (or `--local` embedded).
|
|
959
|
+
|
|
960
|
+
Pass at least one session selector: `--to`, `--session-id`, or `--agent`.
|
|
961
|
+
|
|
962
|
+
Required:
|
|
963
|
+
|
|
964
|
+
- `-m, --message <text>`
|
|
965
|
+
|
|
966
|
+
Options:
|
|
967
|
+
|
|
968
|
+
- `-t, --to <dest>` (for session key and optional delivery)
|
|
969
|
+
- `--session-id <id>`
|
|
970
|
+
- `--agent <id>` (agent id; overrides routing bindings)
|
|
971
|
+
- `--thinking <off|minimal|low|medium|high|xhigh>` (provider support varies; not model-gated at CLI level)
|
|
972
|
+
- `--verbose <on|off>`
|
|
973
|
+
- `--channel <channel>` (delivery channel; omit to use the main session channel)
|
|
974
|
+
- `--reply-to <target>` (delivery target override, separate from session routing)
|
|
975
|
+
- `--reply-channel <channel>` (delivery channel override)
|
|
976
|
+
- `--reply-account <id>` (delivery account id override)
|
|
977
|
+
- `--local` (embedded run; plugin registry still preloads first)
|
|
978
|
+
- `--deliver`
|
|
979
|
+
- `--json`
|
|
980
|
+
- `--timeout <seconds>`
|
|
981
|
+
|
|
982
|
+
Notes:
|
|
983
|
+
|
|
984
|
+
- Gateway mode falls back to the embedded agent when the Gateway request fails.
|
|
985
|
+
- `--local` still preloads the plugin registry, so plugin-provided providers, tools, and channels remain available during embedded runs.
|
|
986
|
+
- `--channel`, `--reply-channel`, and `--reply-account` affect reply delivery, not routing.
|
|
987
|
+
|
|
988
|
+
### `agents`
|
|
989
|
+
|
|
990
|
+
Manage isolated agents (workspaces + auth + routing).
|
|
991
|
+
|
|
992
|
+
Running `Durar agents` with no subcommand is equivalent to `Durar agents list`.
|
|
993
|
+
|
|
994
|
+
#### `agents list`
|
|
995
|
+
|
|
996
|
+
List configured agents.
|
|
997
|
+
|
|
998
|
+
Options:
|
|
999
|
+
|
|
1000
|
+
- `--json`
|
|
1001
|
+
- `--bindings`
|
|
1002
|
+
|
|
1003
|
+
#### `agents add [name]`
|
|
1004
|
+
|
|
1005
|
+
Add a new isolated agent. Runs the guided wizard unless flags (or `--non-interactive`) are passed; `--workspace` is required in non-interactive mode.
|
|
1006
|
+
|
|
1007
|
+
Options:
|
|
1008
|
+
|
|
1009
|
+
- `--workspace <dir>`
|
|
1010
|
+
- `--model <id>`
|
|
1011
|
+
- `--agent-dir <dir>`
|
|
1012
|
+
- `--bind <channel[:accountId]>` (repeatable)
|
|
1013
|
+
- `--non-interactive`
|
|
1014
|
+
- `--json`
|
|
1015
|
+
|
|
1016
|
+
Binding specs use `channel[:accountId]`. When `accountId` is omitted, Durar may resolve account scope via channel defaults/plugin hooks; otherwise it is a channel binding without explicit account scope.
|
|
1017
|
+
Passing any explicit add flags switches the command into the non-interactive path. `main` is reserved and cannot be used as the new agent id.
|
|
1018
|
+
|
|
1019
|
+
#### `agents bindings`
|
|
1020
|
+
|
|
1021
|
+
List routing bindings.
|
|
1022
|
+
|
|
1023
|
+
Options:
|
|
1024
|
+
|
|
1025
|
+
- `--agent <id>`
|
|
1026
|
+
- `--json`
|
|
1027
|
+
|
|
1028
|
+
#### `agents bind`
|
|
1029
|
+
|
|
1030
|
+
Add routing bindings for an agent.
|
|
1031
|
+
|
|
1032
|
+
Options:
|
|
1033
|
+
|
|
1034
|
+
- `--agent <id>` (defaults to the current default agent)
|
|
1035
|
+
- `--bind <channel[:accountId]>` (repeatable)
|
|
1036
|
+
- `--json`
|
|
1037
|
+
|
|
1038
|
+
#### `agents unbind`
|
|
1039
|
+
|
|
1040
|
+
Remove routing bindings for an agent.
|
|
1041
|
+
|
|
1042
|
+
Options:
|
|
1043
|
+
|
|
1044
|
+
- `--agent <id>` (defaults to the current default agent)
|
|
1045
|
+
- `--bind <channel[:accountId]>` (repeatable)
|
|
1046
|
+
- `--all`
|
|
1047
|
+
- `--json`
|
|
1048
|
+
|
|
1049
|
+
Use either `--all` or `--bind`, not both.
|
|
1050
|
+
|
|
1051
|
+
#### `agents delete <id>`
|
|
1052
|
+
|
|
1053
|
+
Delete an agent and prune its workspace + state.
|
|
1054
|
+
|
|
1055
|
+
Options:
|
|
1056
|
+
|
|
1057
|
+
- `--force`
|
|
1058
|
+
- `--json`
|
|
1059
|
+
|
|
1060
|
+
Notes:
|
|
1061
|
+
|
|
1062
|
+
- `main` cannot be deleted.
|
|
1063
|
+
- Without `--force`, interactive confirmation is required.
|
|
1064
|
+
|
|
1065
|
+
#### `agents set-identity`
|
|
1066
|
+
|
|
1067
|
+
Update an agent identity (name/theme/emoji/avatar).
|
|
1068
|
+
|
|
1069
|
+
Options:
|
|
1070
|
+
|
|
1071
|
+
- `--agent <id>`
|
|
1072
|
+
- `--workspace <dir>`
|
|
1073
|
+
- `--identity-file <path>`
|
|
1074
|
+
- `--from-identity`
|
|
1075
|
+
- `--name <name>`
|
|
1076
|
+
- `--theme <theme>`
|
|
1077
|
+
- `--emoji <emoji>`
|
|
1078
|
+
- `--avatar <value>`
|
|
1079
|
+
- `--json`
|
|
1080
|
+
|
|
1081
|
+
Notes:
|
|
1082
|
+
|
|
1083
|
+
- `--agent` or `--workspace` can be used to select the target agent.
|
|
1084
|
+
- When no explicit identity fields are provided, the command reads `IDENTITY.md`.
|
|
1085
|
+
|
|
1086
|
+
### `acp`
|
|
1087
|
+
|
|
1088
|
+
Run the ACP bridge that connects IDEs to the Gateway.
|
|
1089
|
+
|
|
1090
|
+
Root options:
|
|
1091
|
+
|
|
1092
|
+
- `--url <url>`
|
|
1093
|
+
- `--token <token>`
|
|
1094
|
+
- `--token-file <path>`
|
|
1095
|
+
- `--password <password>`
|
|
1096
|
+
- `--password-file <path>`
|
|
1097
|
+
- `--session <key>`
|
|
1098
|
+
- `--session-label <label>`
|
|
1099
|
+
- `--require-existing`
|
|
1100
|
+
- `--reset-session`
|
|
1101
|
+
- `--no-prefix-cwd`
|
|
1102
|
+
- `--provenance <off|meta|meta+receipt>`
|
|
1103
|
+
- `--verbose`
|
|
1104
|
+
|
|
1105
|
+
#### `acp client`
|
|
1106
|
+
|
|
1107
|
+
Interactive ACP client for bridge debugging.
|
|
1108
|
+
|
|
1109
|
+
Options:
|
|
1110
|
+
|
|
1111
|
+
- `--cwd <dir>`
|
|
1112
|
+
- `--server <command>`
|
|
1113
|
+
- `--server-args <args...>`
|
|
1114
|
+
- `--server-verbose`
|
|
1115
|
+
- `--verbose`
|
|
1116
|
+
|
|
1117
|
+
See [`acp`](/cli/acp) for full behavior, security notes, and examples.
|
|
1118
|
+
|
|
1119
|
+
### `mcp`
|
|
1120
|
+
|
|
1121
|
+
Manage saved MCP server definitions and expose Durar channels over MCP stdio.
|
|
1122
|
+
|
|
1123
|
+
#### `mcp serve`
|
|
1124
|
+
|
|
1125
|
+
Expose routed Durar channel conversations over MCP stdio.
|
|
1126
|
+
|
|
1127
|
+
Options:
|
|
1128
|
+
|
|
1129
|
+
- `--url <url>`
|
|
1130
|
+
- `--token <token>`
|
|
1131
|
+
- `--token-file <path>`
|
|
1132
|
+
- `--password <password>`
|
|
1133
|
+
- `--password-file <path>`
|
|
1134
|
+
- `--claude-channel-mode <auto|on|off>`
|
|
1135
|
+
- `--verbose`
|
|
1136
|
+
|
|
1137
|
+
#### `mcp list`
|
|
1138
|
+
|
|
1139
|
+
List saved MCP server definitions.
|
|
1140
|
+
|
|
1141
|
+
Options:
|
|
1142
|
+
|
|
1143
|
+
- `--json`
|
|
1144
|
+
|
|
1145
|
+
#### `mcp show [name]`
|
|
1146
|
+
|
|
1147
|
+
Show one saved MCP server definition or the full saved MCP server object.
|
|
1148
|
+
|
|
1149
|
+
Options:
|
|
1150
|
+
|
|
1151
|
+
- `--json`
|
|
1152
|
+
|
|
1153
|
+
#### `mcp set <name> <value>`
|
|
1154
|
+
|
|
1155
|
+
Save one MCP server definition from a JSON object.
|
|
1156
|
+
|
|
1157
|
+
#### `mcp unset <name>`
|
|
1158
|
+
|
|
1159
|
+
Remove one saved MCP server definition.
|
|
1160
|
+
|
|
1161
|
+
### `approvals`
|
|
1162
|
+
|
|
1163
|
+
Manage exec approvals. Alias: `exec-approvals`.
|
|
1164
|
+
|
|
1165
|
+
#### `approvals get`
|
|
1166
|
+
|
|
1167
|
+
Fetch the exec approvals snapshot and effective policy.
|
|
1168
|
+
|
|
1169
|
+
Options:
|
|
1170
|
+
|
|
1171
|
+
- `--node <node>`
|
|
1172
|
+
- `--gateway`
|
|
1173
|
+
- `--json`
|
|
1174
|
+
- node RPC options from `Durar nodes`
|
|
1175
|
+
|
|
1176
|
+
#### `approvals set`
|
|
1177
|
+
|
|
1178
|
+
Replace exec approvals with JSON from a file or stdin.
|
|
1179
|
+
|
|
1180
|
+
Options:
|
|
1181
|
+
|
|
1182
|
+
- `--node <node>`
|
|
1183
|
+
- `--gateway`
|
|
1184
|
+
- `--file <path>`
|
|
1185
|
+
- `--stdin`
|
|
1186
|
+
- `--json`
|
|
1187
|
+
- node RPC options from `Durar nodes`
|
|
1188
|
+
|
|
1189
|
+
#### `approvals allowlist add|remove`
|
|
1190
|
+
|
|
1191
|
+
Edit the per-agent exec allowlist.
|
|
1192
|
+
|
|
1193
|
+
Options:
|
|
1194
|
+
|
|
1195
|
+
- `--node <node>`
|
|
1196
|
+
- `--gateway`
|
|
1197
|
+
- `--agent <id>` (defaults to `*`)
|
|
1198
|
+
- `--json`
|
|
1199
|
+
- node RPC options from `Durar nodes`
|
|
1200
|
+
|
|
1201
|
+
### `status`
|
|
1202
|
+
|
|
1203
|
+
Show linked session health and recent recipients.
|
|
1204
|
+
|
|
1205
|
+
Options:
|
|
1206
|
+
|
|
1207
|
+
- `--json`
|
|
1208
|
+
- `--all` (full diagnosis; read-only, pasteable)
|
|
1209
|
+
- `--deep` (ask the gateway for a live health probe, including channel probes when supported)
|
|
1210
|
+
- `--usage` (show model provider usage/quota)
|
|
1211
|
+
- `--timeout <ms>`
|
|
1212
|
+
- `--verbose`
|
|
1213
|
+
- `--debug` (alias for `--verbose`)
|
|
1214
|
+
|
|
1215
|
+
Notes:
|
|
1216
|
+
|
|
1217
|
+
- Overview includes Gateway + node host service status when available.
|
|
1218
|
+
- `--usage` prints normalized provider usage windows as `X% left`.
|
|
1219
|
+
|
|
1220
|
+
### Usage tracking
|
|
1221
|
+
|
|
1222
|
+
Durar can surface provider usage/quota when OAuth/API creds are available.
|
|
1223
|
+
|
|
1224
|
+
Surfaces:
|
|
1225
|
+
|
|
1226
|
+
- `/status` (adds a short provider usage line when available)
|
|
1227
|
+
- `Durar status --usage` (prints full provider breakdown)
|
|
1228
|
+
- macOS menu bar (Usage section under Context)
|
|
1229
|
+
|
|
1230
|
+
Notes:
|
|
1231
|
+
|
|
1232
|
+
- Data comes directly from provider usage endpoints (no estimates).
|
|
1233
|
+
- Human-readable output is normalized to `X% left` across providers.
|
|
1234
|
+
- Providers with current usage windows: Anthropic, GitHub Copilot, Gemini CLI, OpenAI Codex, MiniMax, Xiaomi, and z.ai.
|
|
1235
|
+
- MiniMax note: raw `usage_percent` / `usagePercent` means remaining quota, so Durar inverts it before display; count-based fields still win when present. `model_remains` responses prefer the chat-model entry, derive the window label from timestamps when needed, and include the model name in the plan label.
|
|
1236
|
+
- Usage auth comes from provider-specific hooks when available; otherwise Durar falls back to matching OAuth/API-key credentials from auth profiles, env, or config. If none resolve, usage is hidden.
|
|
1237
|
+
- Details: see [Usage tracking](/concepts/usage-tracking).
|
|
1238
|
+
|
|
1239
|
+
### `health`
|
|
1240
|
+
|
|
1241
|
+
Fetch health from the running Gateway.
|
|
1242
|
+
|
|
1243
|
+
Options:
|
|
1244
|
+
|
|
1245
|
+
- `--json`
|
|
1246
|
+
- `--timeout <ms>`
|
|
1247
|
+
- `--verbose` (force a live probe and print gateway connection details)
|
|
1248
|
+
- `--debug` (alias for `--verbose`)
|
|
1249
|
+
|
|
1250
|
+
Notes:
|
|
1251
|
+
|
|
1252
|
+
- Default `health` can return a fresh cached gateway snapshot.
|
|
1253
|
+
- `health --verbose` forces a live probe and expands human-readable output across all configured accounts and agents.
|
|
1254
|
+
|
|
1255
|
+
### `sessions`
|
|
1256
|
+
|
|
1257
|
+
List stored conversation sessions.
|
|
1258
|
+
|
|
1259
|
+
Options:
|
|
1260
|
+
|
|
1261
|
+
- `--json`
|
|
1262
|
+
- `--verbose`
|
|
1263
|
+
- `--store <path>`
|
|
1264
|
+
- `--active <minutes>`
|
|
1265
|
+
- `--agent <id>` (filter sessions by agent)
|
|
1266
|
+
- `--all-agents` (show sessions across all agents)
|
|
1267
|
+
|
|
1268
|
+
Subcommands:
|
|
1269
|
+
|
|
1270
|
+
- `sessions cleanup` — remove expired or orphaned sessions
|
|
1271
|
+
|
|
1272
|
+
Notes:
|
|
1273
|
+
|
|
1274
|
+
- `sessions cleanup` also supports `--fix-missing` to prune entries whose transcript files are gone.
|
|
1275
|
+
|
|
1276
|
+
## Reset / Uninstall
|
|
1277
|
+
|
|
1278
|
+
### `reset`
|
|
1279
|
+
|
|
1280
|
+
Reset local config/state (keeps the CLI installed).
|
|
1281
|
+
|
|
1282
|
+
Options:
|
|
1283
|
+
|
|
1284
|
+
- `--scope <config|config+creds+sessions|full>`
|
|
1285
|
+
- `--yes`
|
|
1286
|
+
- `--non-interactive`
|
|
1287
|
+
- `--dry-run`
|
|
1288
|
+
|
|
1289
|
+
Notes:
|
|
1290
|
+
|
|
1291
|
+
- `--non-interactive` requires `--scope` and `--yes`.
|
|
1292
|
+
|
|
1293
|
+
### `uninstall`
|
|
1294
|
+
|
|
1295
|
+
Uninstall the gateway service + local data (CLI remains).
|
|
1296
|
+
|
|
1297
|
+
Options:
|
|
1298
|
+
|
|
1299
|
+
- `--service`
|
|
1300
|
+
- `--state`
|
|
1301
|
+
- `--workspace`
|
|
1302
|
+
- `--app`
|
|
1303
|
+
- `--all`
|
|
1304
|
+
- `--yes`
|
|
1305
|
+
- `--non-interactive`
|
|
1306
|
+
- `--dry-run`
|
|
1307
|
+
|
|
1308
|
+
Notes:
|
|
1309
|
+
|
|
1310
|
+
- `--non-interactive` requires `--yes` and explicit scopes (or `--all`).
|
|
1311
|
+
- `--all` removes service, state, workspace, and app together.
|
|
1312
|
+
|
|
1313
|
+
### `tasks`
|
|
1314
|
+
|
|
1315
|
+
List and manage [background task](/automation/tasks) runs across agents.
|
|
1316
|
+
|
|
1317
|
+
- `tasks list` — show active and recent task runs
|
|
1318
|
+
- `tasks show <id>` — show details for a specific task run
|
|
1319
|
+
- `tasks notify <id>` — change notification policy for a task run
|
|
1320
|
+
- `tasks cancel <id>` — cancel a running task
|
|
1321
|
+
- `tasks audit` — surface operational issues (stale, lost, delivery failures)
|
|
1322
|
+
- `tasks maintenance [--apply] [--json]` — preview or apply tasks and TaskFlow cleanup/reconciliation (ACP/subagent child sessions, active cron jobs, live CLI runs)
|
|
1323
|
+
- `tasks flow list` — list active and recent Task Flow flows
|
|
1324
|
+
- `tasks flow show <lookup>` — inspect a flow by id or lookup key
|
|
1325
|
+
- `tasks flow cancel <lookup>` — cancel a running flow and its active tasks
|
|
1326
|
+
|
|
1327
|
+
### `flows`
|
|
1328
|
+
|
|
1329
|
+
Legacy docs shortcut. Flow commands live under `Durar tasks flow`:
|
|
1330
|
+
|
|
1331
|
+
- `tasks flow list [--json]`
|
|
1332
|
+
- `tasks flow show <lookup>`
|
|
1333
|
+
- `tasks flow cancel <lookup>`
|
|
1334
|
+
|
|
1335
|
+
## Gateway
|
|
1336
|
+
|
|
1337
|
+
### `gateway`
|
|
1338
|
+
|
|
1339
|
+
Run the WebSocket Gateway.
|
|
1340
|
+
|
|
1341
|
+
Options:
|
|
1342
|
+
|
|
1343
|
+
- `--port <port>`
|
|
1344
|
+
- `--bind <loopback|tailnet|lan|auto|custom>`
|
|
1345
|
+
- `--token <token>`
|
|
1346
|
+
- `--auth <token|password>`
|
|
1347
|
+
- `--password <password>`
|
|
1348
|
+
- `--password-file <path>`
|
|
1349
|
+
- `--tailscale <off|serve|funnel>`
|
|
1350
|
+
- `--tailscale-reset-on-exit`
|
|
1351
|
+
- `--allow-unconfigured`
|
|
1352
|
+
- `--dev`
|
|
1353
|
+
- `--reset` (reset dev config + credentials + sessions + workspace)
|
|
1354
|
+
- `--force` (kill existing listener on port)
|
|
1355
|
+
- `--verbose`
|
|
1356
|
+
- `--cli-backend-logs`
|
|
1357
|
+
- `--claude-cli-logs` (deprecated alias)
|
|
1358
|
+
- `--ws-log <auto|full|compact>`
|
|
1359
|
+
- `--compact` (alias for `--ws-log compact`)
|
|
1360
|
+
- `--raw-stream`
|
|
1361
|
+
- `--raw-stream-path <path>`
|
|
1362
|
+
|
|
1363
|
+
### `gateway service`
|
|
1364
|
+
|
|
1365
|
+
Manage the Gateway service (launchd/systemd/schtasks).
|
|
1366
|
+
|
|
1367
|
+
Subcommands:
|
|
1368
|
+
|
|
1369
|
+
- `gateway status` (probes the Gateway RPC by default)
|
|
1370
|
+
- `gateway install` (service install)
|
|
1371
|
+
- `gateway uninstall`
|
|
1372
|
+
- `gateway start`
|
|
1373
|
+
- `gateway stop`
|
|
1374
|
+
- `gateway restart`
|
|
1375
|
+
|
|
1376
|
+
Notes:
|
|
1377
|
+
|
|
1378
|
+
- `gateway status` probes the Gateway RPC by default using the service’s resolved port/config (override with `--url/--token/--password`).
|
|
1379
|
+
- `gateway status` supports `--no-probe`, `--deep`, `--require-rpc`, and `--json` for scripting.
|
|
1380
|
+
- `gateway status` also surfaces legacy or extra gateway services when it can detect them (`--deep` adds system-level scans). Profile-named Durar services are treated as first-class and aren't flagged as "extra".
|
|
1381
|
+
- `gateway status` stays available for diagnostics even when the local CLI config is missing or invalid.
|
|
1382
|
+
- `gateway status` prints the resolved file log path, the CLI-vs-service config paths/validity snapshot, and the resolved probe target URL.
|
|
1383
|
+
- If gateway auth SecretRefs are unresolved in the current command path, `gateway status --json` reports `rpc.authWarning` only when probe connectivity/auth fails (warnings are suppressed when probe succeeds).
|
|
1384
|
+
- On Linux systemd installs, status token-drift checks include both `Environment=` and `EnvironmentFile=` unit sources.
|
|
1385
|
+
- `gateway install|uninstall|start|stop|restart` support `--json` for scripting (default output stays human-friendly).
|
|
1386
|
+
- `gateway install` defaults to Node runtime; bun is **not recommended** (WhatsApp/Telegram bugs).
|
|
1387
|
+
- `gateway install` options: `--port`, `--runtime`, `--token`, `--force`, `--json`.
|
|
1388
|
+
|
|
1389
|
+
### `daemon`
|
|
1390
|
+
|
|
1391
|
+
Legacy alias for the Gateway service-management commands. See [/cli/daemon](/cli/daemon).
|
|
1392
|
+
|
|
1393
|
+
Subcommands:
|
|
1394
|
+
|
|
1395
|
+
- `daemon status`
|
|
1396
|
+
- `daemon install`
|
|
1397
|
+
- `daemon uninstall`
|
|
1398
|
+
- `daemon start`
|
|
1399
|
+
- `daemon stop`
|
|
1400
|
+
- `daemon restart`
|
|
1401
|
+
|
|
1402
|
+
Common options:
|
|
1403
|
+
|
|
1404
|
+
- `status`: `--url`, `--token`, `--password`, `--timeout`, `--no-probe`, `--require-rpc`, `--deep`, `--json`
|
|
1405
|
+
- `install`: `--port`, `--runtime <node|bun>`, `--token`, `--force`, `--json`
|
|
1406
|
+
- `uninstall|start|stop|restart`: `--json`
|
|
1407
|
+
|
|
1408
|
+
### `logs`
|
|
1409
|
+
|
|
1410
|
+
Tail Gateway file logs via RPC.
|
|
1411
|
+
|
|
1412
|
+
Options:
|
|
1413
|
+
|
|
1414
|
+
- `--limit <n>`: maximum number of log lines to return
|
|
1415
|
+
- `--max-bytes <n>`: maximum bytes to read from the log file
|
|
1416
|
+
- `--follow`: follow the log file (tail -f style)
|
|
1417
|
+
- `--interval <ms>`: polling interval in ms when following
|
|
1418
|
+
- `--local-time`: display timestamps in local time
|
|
1419
|
+
- `--json`: emit line-delimited JSON
|
|
1420
|
+
- `--plain`: disable structured formatting
|
|
1421
|
+
- `--no-color`: disable ANSI colors
|
|
1422
|
+
- `--url <url>`: explicit Gateway WebSocket URL
|
|
1423
|
+
- `--token <token>`: Gateway token
|
|
1424
|
+
- `--timeout <ms>`: Gateway RPC timeout
|
|
1425
|
+
- `--expect-final`: wait for a final response when needed
|
|
1426
|
+
|
|
1427
|
+
Examples:
|
|
1428
|
+
|
|
1429
|
+
```bash
|
|
1430
|
+
Durar logs --follow
|
|
1431
|
+
Durar logs --limit 200
|
|
1432
|
+
Durar logs --plain
|
|
1433
|
+
Durar logs --json
|
|
1434
|
+
Durar logs --no-color
|
|
1435
|
+
```
|
|
1436
|
+
|
|
1437
|
+
Notes:
|
|
1438
|
+
|
|
1439
|
+
- If you pass `--url`, the CLI does not auto-apply config or environment credentials.
|
|
1440
|
+
- Local loopback pairing failures fall back to the configured local log file; explicit `--url` targets do not.
|
|
1441
|
+
|
|
1442
|
+
### `gateway <subcommand>`
|
|
1443
|
+
|
|
1444
|
+
Gateway CLI helpers (use `--url`, `--token`, `--password`, `--timeout`, `--expect-final` for RPC subcommands).
|
|
1445
|
+
When you pass `--url`, the CLI does not auto-apply config or environment credentials.
|
|
1446
|
+
Include `--token` or `--password` explicitly. Missing explicit credentials is an error.
|
|
1447
|
+
|
|
1448
|
+
Subcommands:
|
|
1449
|
+
|
|
1450
|
+
- `gateway call <method> [--params <json>] [--url <url>] [--token <token>] [--password <password>] [--timeout <ms>] [--expect-final] [--json]`
|
|
1451
|
+
- `gateway health`
|
|
1452
|
+
- `gateway status`
|
|
1453
|
+
- `gateway probe`
|
|
1454
|
+
- `gateway discover`
|
|
1455
|
+
- `gateway install|uninstall|start|stop|restart`
|
|
1456
|
+
- `gateway run`
|
|
1457
|
+
|
|
1458
|
+
Notes:
|
|
1459
|
+
|
|
1460
|
+
- `gateway status --deep` adds a system-level service scan. Use `gateway probe`,
|
|
1461
|
+
`health --verbose`, or top-level `status --deep` for deeper runtime probe detail.
|
|
1462
|
+
|
|
1463
|
+
Common RPCs:
|
|
1464
|
+
|
|
1465
|
+
- `config.schema.lookup` (inspect one config subtree with a shallow schema node, matched hint metadata, and immediate child summaries)
|
|
1466
|
+
- `config.get` (read current config snapshot + hash)
|
|
1467
|
+
- `config.set` (validate + write full config; use `baseHash` for optimistic concurrency)
|
|
1468
|
+
- `config.apply` (validate + write config + restart + wake)
|
|
1469
|
+
- `config.patch` (merge a partial update + restart + wake)
|
|
1470
|
+
- `update.run` (run update + restart + wake)
|
|
1471
|
+
|
|
1472
|
+
Tip: when calling `config.set`/`config.apply`/`config.patch` directly, pass `baseHash` from
|
|
1473
|
+
`config.get` if a config already exists.
|
|
1474
|
+
Tip: for partial edits, inspect with `config.schema.lookup` first and prefer `config.patch`.
|
|
1475
|
+
Tip: these config write RPCs preflight active SecretRef resolution for refs in the submitted config payload and reject writes when an effectively active submitted ref is unresolved.
|
|
1476
|
+
Tip: the owner-only `gateway` runtime tool still refuses to rewrite `tools.exec.ask` or `tools.exec.security`; legacy `tools.bash.*` aliases normalize to the same protected exec paths.
|
|
1477
|
+
|
|
1478
|
+
## Models
|
|
1479
|
+
|
|
1480
|
+
See [/concepts/models](/concepts/models) for fallback behavior and scanning strategy.
|
|
1481
|
+
|
|
1482
|
+
Billing note: We believe Claude Code CLI fallback is likely allowed for local,
|
|
1483
|
+
user-managed automation based on Anthropic's public CLI docs. That said,
|
|
1484
|
+
Anthropic's third-party harness policy creates enough ambiguity around
|
|
1485
|
+
subscription-backed use in external products that we do not recommend it for
|
|
1486
|
+
production. Anthropic also notified Durar users on **April 4, 2026 at
|
|
1487
|
+
12:00 PM PT / 8:00 PM BST** that the **Durar** Claude-login path counts as
|
|
1488
|
+
third-party harness usage and requires **Extra Usage** billed separately from
|
|
1489
|
+
the subscription. For production, prefer an Anthropic API key or another supported
|
|
1490
|
+
subscription-style provider such as OpenAI Codex, Alibaba Cloud Model Studio
|
|
1491
|
+
Coding Plan, MiniMax Coding Plan, or Z.AI / GLM Coding Plan.
|
|
1492
|
+
|
|
1493
|
+
Anthropic Claude CLI migration:
|
|
1494
|
+
|
|
1495
|
+
```bash
|
|
1496
|
+
Durar models auth login --provider anthropic --method cli --set-default
|
|
1497
|
+
```
|
|
1498
|
+
|
|
1499
|
+
Onboarding shortcut: `Durar onboard --auth-choice anthropic-cli`
|
|
1500
|
+
|
|
1501
|
+
Anthropic setup-token is also available again as a legacy/manual auth path.
|
|
1502
|
+
Use it only with the expectation that Anthropic told Durar users the
|
|
1503
|
+
Durar Claude-login path requires **Extra Usage**.
|
|
1504
|
+
|
|
1505
|
+
Legacy alias note: `claude-cli` is the deprecated onboarding auth-choice alias.
|
|
1506
|
+
Use `anthropic-cli` for onboarding, or use `models auth login` directly.
|
|
1507
|
+
|
|
1508
|
+
### `models` (root)
|
|
1509
|
+
|
|
1510
|
+
`Durar models` is an alias for `models status`.
|
|
1511
|
+
|
|
1512
|
+
Root options:
|
|
1513
|
+
|
|
1514
|
+
- `--status-json` (alias for `models status --json`)
|
|
1515
|
+
- `--status-plain` (alias for `models status --plain`)
|
|
1516
|
+
|
|
1517
|
+
### `models list`
|
|
1518
|
+
|
|
1519
|
+
Options:
|
|
1520
|
+
|
|
1521
|
+
- `--all`
|
|
1522
|
+
- `--local`
|
|
1523
|
+
- `--provider <name>`
|
|
1524
|
+
- `--json`
|
|
1525
|
+
- `--plain`
|
|
1526
|
+
|
|
1527
|
+
### `models status`
|
|
1528
|
+
|
|
1529
|
+
Options:
|
|
1530
|
+
|
|
1531
|
+
- `--json`
|
|
1532
|
+
- `--plain`
|
|
1533
|
+
- `--check` (exit 1=expired/missing, 2=expiring)
|
|
1534
|
+
- `--probe` (live probe of configured auth profiles)
|
|
1535
|
+
- `--probe-provider <name>`
|
|
1536
|
+
- `--probe-profile <id>` (repeat or comma-separated)
|
|
1537
|
+
- `--probe-timeout <ms>`
|
|
1538
|
+
- `--probe-concurrency <n>`
|
|
1539
|
+
- `--probe-max-tokens <n>`
|
|
1540
|
+
- `--agent <id>`
|
|
1541
|
+
|
|
1542
|
+
Always includes the auth overview and OAuth expiry status for profiles in the auth store.
|
|
1543
|
+
`--probe` runs live requests (may consume tokens and trigger rate limits).
|
|
1544
|
+
Probe rows can come from auth profiles, env credentials, or `models.json`.
|
|
1545
|
+
Expect probe statuses like `ok`, `auth`, `rate_limit`, `billing`, `timeout`,
|
|
1546
|
+
`format`, `unknown`, and `no_model`.
|
|
1547
|
+
When an explicit `auth.order.<provider>` omits a stored profile, probe reports
|
|
1548
|
+
`excluded_by_auth_order` instead of silently trying that profile.
|
|
1549
|
+
|
|
1550
|
+
### `models set <model>`
|
|
1551
|
+
|
|
1552
|
+
Set `agents.defaults.model.primary`.
|
|
1553
|
+
|
|
1554
|
+
### `models set-image <model>`
|
|
1555
|
+
|
|
1556
|
+
Set `agents.defaults.imageModel.primary`.
|
|
1557
|
+
|
|
1558
|
+
### `models aliases list|add|remove`
|
|
1559
|
+
|
|
1560
|
+
Options:
|
|
1561
|
+
|
|
1562
|
+
- `list`: `--json`, `--plain`
|
|
1563
|
+
- `add <alias> <model>`
|
|
1564
|
+
- `remove <alias>`
|
|
1565
|
+
|
|
1566
|
+
### `models fallbacks list|add|remove|clear`
|
|
1567
|
+
|
|
1568
|
+
Options:
|
|
1569
|
+
|
|
1570
|
+
- `list`: `--json`, `--plain`
|
|
1571
|
+
- `add <model>`
|
|
1572
|
+
- `remove <model>`
|
|
1573
|
+
- `clear`
|
|
1574
|
+
|
|
1575
|
+
### `models image-fallbacks list|add|remove|clear`
|
|
1576
|
+
|
|
1577
|
+
Options:
|
|
1578
|
+
|
|
1579
|
+
- `list`: `--json`, `--plain`
|
|
1580
|
+
- `add <model>`
|
|
1581
|
+
- `remove <model>`
|
|
1582
|
+
- `clear`
|
|
1583
|
+
|
|
1584
|
+
### `models scan`
|
|
1585
|
+
|
|
1586
|
+
Options:
|
|
1587
|
+
|
|
1588
|
+
- `--min-params <b>`
|
|
1589
|
+
- `--max-age-days <days>`
|
|
1590
|
+
- `--provider <name>`
|
|
1591
|
+
- `--max-candidates <n>`
|
|
1592
|
+
- `--timeout <ms>`
|
|
1593
|
+
- `--concurrency <n>`
|
|
1594
|
+
- `--no-probe`
|
|
1595
|
+
- `--yes`
|
|
1596
|
+
- `--no-input`
|
|
1597
|
+
- `--set-default`
|
|
1598
|
+
- `--set-image`
|
|
1599
|
+
- `--json`
|
|
1600
|
+
|
|
1601
|
+
### `models auth add|login|login-github-copilot|setup-token|paste-token`
|
|
1602
|
+
|
|
1603
|
+
Options:
|
|
1604
|
+
|
|
1605
|
+
- `add`: interactive auth helper (provider auth flow or token paste)
|
|
1606
|
+
- `login`: `--provider <name>`, `--method <method>`, `--set-default`
|
|
1607
|
+
- `login-github-copilot`: GitHub Copilot OAuth login flow (`--yes`)
|
|
1608
|
+
- `setup-token`: `--provider <name>`, `--yes`
|
|
1609
|
+
- `paste-token`: `--provider <name>`, `--profile-id <id>`, `--expires-in <duration>`
|
|
1610
|
+
|
|
1611
|
+
Notes:
|
|
1612
|
+
|
|
1613
|
+
- `setup-token` and `paste-token` are generic token commands for providers that expose token auth methods.
|
|
1614
|
+
- `setup-token` requires an interactive TTY and runs the provider's token-auth method.
|
|
1615
|
+
- `paste-token` prompts for the token value and defaults to auth profile id `<provider>:manual` when `--profile-id` is omitted.
|
|
1616
|
+
- Anthropic `setup-token` / `paste-token` are available again as a legacy/manual Durar path. Anthropic told Durar users this path requires **Extra Usage** on the Claude account.
|
|
1617
|
+
|
|
1618
|
+
### `models auth order get|set|clear`
|
|
1619
|
+
|
|
1620
|
+
Options:
|
|
1621
|
+
|
|
1622
|
+
- `get`: `--provider <name>`, `--agent <id>`, `--json`
|
|
1623
|
+
- `set`: `--provider <name>`, `--agent <id>`, `<profileIds...>`
|
|
1624
|
+
- `clear`: `--provider <name>`, `--agent <id>`
|
|
1625
|
+
|
|
1626
|
+
## System
|
|
1627
|
+
|
|
1628
|
+
### `system event`
|
|
1629
|
+
|
|
1630
|
+
Enqueue a system event and optionally trigger a heartbeat (Gateway RPC).
|
|
1631
|
+
|
|
1632
|
+
Required:
|
|
1633
|
+
|
|
1634
|
+
- `--text <text>`
|
|
1635
|
+
|
|
1636
|
+
Options:
|
|
1637
|
+
|
|
1638
|
+
- `--mode <now|next-heartbeat>`
|
|
1639
|
+
- `--json`
|
|
1640
|
+
- `--url`, `--token`, `--timeout`, `--expect-final`
|
|
1641
|
+
|
|
1642
|
+
### `system heartbeat last|enable|disable`
|
|
1643
|
+
|
|
1644
|
+
Heartbeat controls (Gateway RPC).
|
|
1645
|
+
|
|
1646
|
+
Options:
|
|
1647
|
+
|
|
1648
|
+
- `--json`
|
|
1649
|
+
- `--url`, `--token`, `--timeout`, `--expect-final`
|
|
1650
|
+
|
|
1651
|
+
### `system presence`
|
|
1652
|
+
|
|
1653
|
+
List system presence entries (Gateway RPC).
|
|
1654
|
+
|
|
1655
|
+
Options:
|
|
1656
|
+
|
|
1657
|
+
- `--json`
|
|
1658
|
+
- `--url`, `--token`, `--timeout`, `--expect-final`
|
|
1659
|
+
|
|
1660
|
+
## Cron
|
|
1661
|
+
|
|
1662
|
+
Manage scheduled jobs (Gateway RPC). See [/automation/cron-jobs](/automation/cron-jobs).
|
|
1663
|
+
|
|
1664
|
+
Subcommands:
|
|
1665
|
+
|
|
1666
|
+
- `cron status [--json]`
|
|
1667
|
+
- `cron list [--all] [--json]` (table output by default; use `--json` for raw)
|
|
1668
|
+
- `cron add` (alias: `create`; requires `--name` and exactly one of `--at` | `--every` | `--cron`, and exactly one payload of `--system-event` | `--message`)
|
|
1669
|
+
- `cron edit <id>` (patch fields)
|
|
1670
|
+
- `cron rm <id>` (aliases: `remove`, `delete`)
|
|
1671
|
+
- `cron enable <id>`
|
|
1672
|
+
- `cron disable <id>`
|
|
1673
|
+
- `cron runs --id <id> [--limit <n>]`
|
|
1674
|
+
- `cron run <id> [--due]`
|
|
1675
|
+
|
|
1676
|
+
All `cron` commands accept `--url`, `--token`, `--timeout`, `--expect-final`.
|
|
1677
|
+
|
|
1678
|
+
`cron add|edit --model ...` uses that selected allowed model for the job. If
|
|
1679
|
+
the model is not allowed, cron warns and falls back to the job's agent/default
|
|
1680
|
+
model selection instead. Configured fallback chains still apply, but a plain
|
|
1681
|
+
model override with no explicit per-job fallback list no longer appends the
|
|
1682
|
+
agent primary as a hidden extra retry target.
|
|
1683
|
+
|
|
1684
|
+
## Node host
|
|
1685
|
+
|
|
1686
|
+
### `node`
|
|
1687
|
+
|
|
1688
|
+
`node` runs a **headless node host** or manages it as a background service. See
|
|
1689
|
+
[`Durar node`](/cli/node).
|
|
1690
|
+
|
|
1691
|
+
Subcommands:
|
|
1692
|
+
|
|
1693
|
+
- `node run --host <gateway-host> --port 18789`
|
|
1694
|
+
- `node status`
|
|
1695
|
+
- `node install [--host <gateway-host>] [--port <port>] [--tls] [--tls-fingerprint <sha256>] [--node-id <id>] [--display-name <name>] [--runtime <node|bun>] [--force]`
|
|
1696
|
+
- `node uninstall`
|
|
1697
|
+
- `node stop`
|
|
1698
|
+
- `node restart`
|
|
1699
|
+
|
|
1700
|
+
Auth notes:
|
|
1701
|
+
|
|
1702
|
+
- `node` resolves gateway auth from env/config (no `--token`/`--password` flags): `Durar_GATEWAY_TOKEN` / `Durar_GATEWAY_PASSWORD`, then `gateway.auth.*`. In local mode, node host intentionally ignores `gateway.remote.*`; in `gateway.mode=remote`, `gateway.remote.*` participates per remote precedence rules.
|
|
1703
|
+
- Node-host auth resolution only honors `Durar_GATEWAY_*` env vars.
|
|
1704
|
+
|
|
1705
|
+
## Nodes
|
|
1706
|
+
|
|
1707
|
+
`nodes` talks to the Gateway and targets paired nodes. See [/nodes](/nodes).
|
|
1708
|
+
|
|
1709
|
+
Common options:
|
|
1710
|
+
|
|
1711
|
+
- `--url`, `--token`, `--timeout`, `--json`
|
|
1712
|
+
|
|
1713
|
+
Subcommands:
|
|
1714
|
+
|
|
1715
|
+
- `nodes status [--connected] [--last-connected <duration>]`
|
|
1716
|
+
- `nodes describe --node <id|name|ip>`
|
|
1717
|
+
- `nodes list [--connected] [--last-connected <duration>]`
|
|
1718
|
+
- `nodes pending`
|
|
1719
|
+
- `nodes approve <requestId>`
|
|
1720
|
+
- `nodes reject <requestId>`
|
|
1721
|
+
- `nodes rename --node <id|name|ip> --name <displayName>`
|
|
1722
|
+
- `nodes invoke --node <id|name|ip> --command <command> [--params <json>] [--invoke-timeout <ms>] [--idempotency-key <key>]`
|
|
1723
|
+
- `nodes notify --node <id|name|ip> [--title <text>] [--body <text>] [--sound <name>] [--priority <passive|active|timeSensitive>] [--delivery <system|overlay|auto>] [--invoke-timeout <ms>]` (mac only)
|
|
1724
|
+
|
|
1725
|
+
Camera:
|
|
1726
|
+
|
|
1727
|
+
- `nodes camera list --node <id|name|ip>`
|
|
1728
|
+
- `nodes camera snap --node <id|name|ip> [--facing front|back|both] [--device-id <id>] [--max-width <px>] [--quality <0-1>] [--delay-ms <ms>] [--invoke-timeout <ms>]`
|
|
1729
|
+
- `nodes camera clip --node <id|name|ip> [--facing front|back] [--device-id <id>] [--duration <ms|10s|1m>] [--no-audio] [--invoke-timeout <ms>]`
|
|
1730
|
+
|
|
1731
|
+
Canvas + screen:
|
|
1732
|
+
|
|
1733
|
+
- `nodes canvas snapshot --node <id|name|ip> [--format png|jpg|jpeg] [--max-width <px>] [--quality <0-1>] [--invoke-timeout <ms>]`
|
|
1734
|
+
- `nodes canvas present --node <id|name|ip> [--target <urlOrPath>] [--x <px>] [--y <px>] [--width <px>] [--height <px>] [--invoke-timeout <ms>]`
|
|
1735
|
+
- `nodes canvas hide --node <id|name|ip> [--invoke-timeout <ms>]`
|
|
1736
|
+
- `nodes canvas navigate <url> --node <id|name|ip> [--invoke-timeout <ms>]`
|
|
1737
|
+
- `nodes canvas eval [<js>] --node <id|name|ip> [--js <code>] [--invoke-timeout <ms>]`
|
|
1738
|
+
- `nodes canvas a2ui push --node <id|name|ip> (--jsonl <path> | --text <text>) [--invoke-timeout <ms>]`
|
|
1739
|
+
- `nodes canvas a2ui reset --node <id|name|ip> [--invoke-timeout <ms>]`
|
|
1740
|
+
- `nodes screen record --node <id|name|ip> [--screen <index>] [--duration <ms|10s>] [--fps <n>] [--no-audio] [--out <path>] [--invoke-timeout <ms>]`
|
|
1741
|
+
|
|
1742
|
+
Location:
|
|
1743
|
+
|
|
1744
|
+
- `nodes location get --node <id|name|ip> [--max-age <ms>] [--accuracy <coarse|balanced|precise>] [--location-timeout <ms>] [--invoke-timeout <ms>]`
|
|
1745
|
+
|
|
1746
|
+
## Browser
|
|
1747
|
+
|
|
1748
|
+
Browser control CLI (dedicated Chrome/Brave/Edge/Chromium). See [`Durar browser`](/cli/browser) and the [Browser tool](/tools/browser).
|
|
1749
|
+
|
|
1750
|
+
Common options:
|
|
1751
|
+
|
|
1752
|
+
- `--url`, `--token`, `--timeout`, `--expect-final`, `--json`
|
|
1753
|
+
- `--browser-profile <name>`
|
|
1754
|
+
|
|
1755
|
+
Manage:
|
|
1756
|
+
|
|
1757
|
+
- `browser status`
|
|
1758
|
+
- `browser start`
|
|
1759
|
+
- `browser stop`
|
|
1760
|
+
- `browser reset-profile`
|
|
1761
|
+
- `browser tabs`
|
|
1762
|
+
- `browser open <url>`
|
|
1763
|
+
- `browser focus <targetId>`
|
|
1764
|
+
- `browser close [targetId]`
|
|
1765
|
+
- `browser profiles`
|
|
1766
|
+
- `browser create-profile --name <name> [--color <hex>] [--cdp-url <url>] [--driver existing-session] [--user-data-dir <path>]`
|
|
1767
|
+
- `browser delete-profile --name <name>`
|
|
1768
|
+
|
|
1769
|
+
Inspect:
|
|
1770
|
+
|
|
1771
|
+
- `browser screenshot [targetId] [--full-page] [--ref <ref>] [--element <selector>] [--type png|jpeg]`
|
|
1772
|
+
- `browser snapshot [--format aria|ai] [--target-id <id>] [--limit <n>] [--interactive] [--compact] [--depth <n>] [--selector <sel>] [--out <path>]`
|
|
1773
|
+
|
|
1774
|
+
Actions:
|
|
1775
|
+
|
|
1776
|
+
- `browser navigate <url> [--target-id <id>]`
|
|
1777
|
+
- `browser resize <width> <height> [--target-id <id>]`
|
|
1778
|
+
- `browser click <ref> [--double] [--button <left|right|middle>] [--modifiers <csv>] [--target-id <id>]`
|
|
1779
|
+
- `browser type <ref> <text> [--submit] [--slowly] [--target-id <id>]`
|
|
1780
|
+
- `browser press <key> [--target-id <id>]`
|
|
1781
|
+
- `browser hover <ref> [--target-id <id>]`
|
|
1782
|
+
- `browser drag <startRef> <endRef> [--target-id <id>]`
|
|
1783
|
+
- `browser select <ref> <values...> [--target-id <id>]`
|
|
1784
|
+
- `browser upload <paths...> [--ref <ref>] [--input-ref <ref>] [--element <selector>] [--target-id <id>] [--timeout-ms <ms>]`
|
|
1785
|
+
- `browser fill [--fields <json>] [--fields-file <path>] [--target-id <id>]`
|
|
1786
|
+
- `browser dialog --accept|--dismiss [--prompt <text>] [--target-id <id>] [--timeout-ms <ms>]`
|
|
1787
|
+
- `browser wait [--time <ms>] [--text <value>] [--text-gone <value>] [--target-id <id>]`
|
|
1788
|
+
- `browser evaluate --fn <code> [--ref <ref>] [--target-id <id>]`
|
|
1789
|
+
- `browser console [--level <error|warn|info>] [--target-id <id>]`
|
|
1790
|
+
- `browser pdf [--target-id <id>]`
|
|
1791
|
+
|
|
1792
|
+
## Voice call
|
|
1793
|
+
|
|
1794
|
+
### `voicecall`
|
|
1795
|
+
|
|
1796
|
+
Plugin-provided voice-call utilities. Only appears when the voice-call plugin is installed and enabled. See [`Durar voicecall`](/cli/voicecall).
|
|
1797
|
+
|
|
1798
|
+
Common commands:
|
|
1799
|
+
|
|
1800
|
+
- `voicecall call --to <phone> --message <text> [--mode notify|conversation]`
|
|
1801
|
+
- `voicecall start --to <phone> [--message <text>] [--mode notify|conversation]`
|
|
1802
|
+
- `voicecall continue --call-id <id> --message <text>`
|
|
1803
|
+
- `voicecall speak --call-id <id> --message <text>`
|
|
1804
|
+
- `voicecall end --call-id <id>`
|
|
1805
|
+
- `voicecall status --call-id <id>`
|
|
1806
|
+
- `voicecall tail [--file <path>] [--since <n>] [--poll <ms>]`
|
|
1807
|
+
- `voicecall latency [--file <path>] [--last <n>]`
|
|
1808
|
+
- `voicecall expose [--mode off|serve|funnel] [--path <path>] [--port <port>] [--serve-path <path>]`
|
|
1809
|
+
|
|
1810
|
+
## Docs search
|
|
1811
|
+
|
|
1812
|
+
### `docs`
|
|
1813
|
+
|
|
1814
|
+
Search the live Durar docs index.
|
|
1815
|
+
|
|
1816
|
+
### `docs [query...]`
|
|
1817
|
+
|
|
1818
|
+
Search the live docs index.
|
|
1819
|
+
|
|
1820
|
+
## TUI
|
|
1821
|
+
|
|
1822
|
+
### `tui`
|
|
1823
|
+
|
|
1824
|
+
Open the terminal UI connected to the Gateway.
|
|
1825
|
+
|
|
1826
|
+
Options:
|
|
1827
|
+
|
|
1828
|
+
- `--url <url>`
|
|
1829
|
+
- `--token <token>`
|
|
1830
|
+
- `--password <password>`
|
|
1831
|
+
- `--session <key>`
|
|
1832
|
+
- `--deliver`
|
|
1833
|
+
- `--thinking <level>`
|
|
1834
|
+
- `--message <text>`
|
|
1835
|
+
- `--timeout-ms <ms>` (defaults to `agents.defaults.timeoutSeconds`)
|
|
1836
|
+
- `--history-limit <n>`
|