@quantumclaw/quantumclaw 2026.3.22
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 +4601 -0
- package/LICENSE +21 -0
- package/README.md +559 -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 +31 -0
- package/docs/.i18n/glossary.ja-JP.json +14 -0
- package/docs/.i18n/glossary.zh-CN.json +302 -0
- package/docs/.i18n/ja-JP.tm.jsonl +0 -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/pixel-lobster.svg +60 -0
- package/docs/assets/quantumclaw-logo-text-dark.png +0 -0
- package/docs/assets/quantumclaw-logo-text-dark.svg +418 -0
- package/docs/assets/quantumclaw-logo-text.png +0 -0
- package/docs/assets/quantumclaw-logo-text.svg +418 -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.svg +14 -0
- package/docs/assets/sponsors/convex.svg +16 -0
- package/docs/assets/sponsors/openai.svg +3 -0
- package/docs/assets/sponsors/vercel.svg +5 -0
- package/docs/auth-credential-semantics.md +53 -0
- package/docs/automation/auth-monitoring.md +44 -0
- package/docs/automation/cron-jobs.md +727 -0
- package/docs/automation/cron-vs-heartbeat.md +286 -0
- package/docs/automation/gmail-pubsub.md +256 -0
- package/docs/automation/hooks.md +1056 -0
- package/docs/automation/poll.md +86 -0
- package/docs/automation/standing-orders.md +251 -0
- package/docs/automation/troubleshooting.md +122 -0
- package/docs/automation/webhook.md +217 -0
- package/docs/brave-search.md +93 -0
- package/docs/channels/bluebubbles.md +347 -0
- package/docs/channels/broadcast-groups.md +442 -0
- package/docs/channels/channel-routing.md +139 -0
- package/docs/channels/discord.md +1229 -0
- package/docs/channels/feishu.md +747 -0
- package/docs/channels/googlechat.md +261 -0
- package/docs/channels/group-messages.md +84 -0
- package/docs/channels/groups.md +379 -0
- package/docs/channels/imessage.md +367 -0
- package/docs/channels/index.md +47 -0
- package/docs/channels/irc.md +242 -0
- package/docs/channels/line.md +194 -0
- package/docs/channels/location.md +56 -0
- package/docs/channels/matrix.md +677 -0
- package/docs/channels/mattermost.md +427 -0
- package/docs/channels/msteams.md +780 -0
- package/docs/channels/nextcloud-talk.md +138 -0
- package/docs/channels/nostr.md +249 -0
- package/docs/channels/pairing.md +114 -0
- package/docs/channels/signal.md +329 -0
- package/docs/channels/slack.md +603 -0
- package/docs/channels/synology-chat.md +134 -0
- package/docs/channels/telegram.md +987 -0
- package/docs/channels/tlon.md +276 -0
- package/docs/channels/troubleshooting.md +118 -0
- package/docs/channels/twitch.md +379 -0
- package/docs/channels/whatsapp.md +460 -0
- package/docs/channels/zalo.md +243 -0
- package/docs/channels/zalouser.md +181 -0
- package/docs/ci.md +55 -0
- package/docs/cli/acp.md +288 -0
- package/docs/cli/agent.md +29 -0
- package/docs/cli/agents.md +123 -0
- package/docs/cli/approvals.md +50 -0
- package/docs/cli/backup.md +76 -0
- package/docs/cli/browser.md +106 -0
- package/docs/cli/channels.md +102 -0
- package/docs/cli/clawbot.md +21 -0
- package/docs/cli/completion.md +35 -0
- package/docs/cli/config.md +295 -0
- package/docs/cli/configure.md +36 -0
- package/docs/cli/cron.md +77 -0
- package/docs/cli/daemon.md +53 -0
- package/docs/cli/dashboard.md +22 -0
- package/docs/cli/devices.md +139 -0
- package/docs/cli/directory.md +63 -0
- package/docs/cli/dns.md +23 -0
- package/docs/cli/docs.md +15 -0
- package/docs/cli/doctor.md +48 -0
- package/docs/cli/gateway.md +235 -0
- package/docs/cli/health.md +21 -0
- package/docs/cli/hooks.md +329 -0
- package/docs/cli/index.md +1150 -0
- package/docs/cli/logs.md +28 -0
- package/docs/cli/memory.md +66 -0
- package/docs/cli/message.md +278 -0
- package/docs/cli/models.md +81 -0
- package/docs/cli/node.md +127 -0
- package/docs/cli/nodes.md +75 -0
- package/docs/cli/onboard.md +157 -0
- package/docs/cli/pairing.md +32 -0
- package/docs/cli/plugins.md +210 -0
- package/docs/cli/qr.md +46 -0
- package/docs/cli/reset.md +20 -0
- package/docs/cli/sandbox.md +197 -0
- package/docs/cli/secrets.md +188 -0
- package/docs/cli/security.md +79 -0
- package/docs/cli/sessions.md +110 -0
- package/docs/cli/setup.md +29 -0
- package/docs/cli/skills.md +36 -0
- package/docs/cli/status.md +30 -0
- package/docs/cli/system.md +60 -0
- package/docs/cli/tui.md +30 -0
- package/docs/cli/uninstall.md +20 -0
- package/docs/cli/update.md +103 -0
- package/docs/cli/voicecall.md +34 -0
- package/docs/cli/webhooks.md +25 -0
- package/docs/concepts/agent-loop.md +148 -0
- package/docs/concepts/agent-workspace.md +236 -0
- package/docs/concepts/agent.md +122 -0
- package/docs/concepts/architecture.md +137 -0
- package/docs/concepts/compaction.md +123 -0
- package/docs/concepts/context-engine.md +268 -0
- package/docs/concepts/context.md +172 -0
- package/docs/concepts/delegate-architecture.md +296 -0
- package/docs/concepts/features.md +73 -0
- package/docs/concepts/markdown-formatting.md +130 -0
- package/docs/concepts/memory.md +108 -0
- package/docs/concepts/messages.md +154 -0
- package/docs/concepts/model-failover.md +152 -0
- package/docs/concepts/model-providers.md +607 -0
- package/docs/concepts/models.md +225 -0
- package/docs/concepts/multi-agent.md +552 -0
- package/docs/concepts/oauth.md +158 -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 +121 -0
- package/docs/concepts/session-tool.md +242 -0
- package/docs/concepts/session.md +310 -0
- package/docs/concepts/streaming.md +155 -0
- package/docs/concepts/system-prompt.md +132 -0
- package/docs/concepts/timezone.md +91 -0
- package/docs/concepts/typebox.md +291 -0
- package/docs/concepts/typing-indicators.md +68 -0
- package/docs/concepts/usage-tracking.md +35 -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 +2078 -0
- package/docs/gateway/authentication.md +179 -0
- package/docs/gateway/background-process.md +97 -0
- package/docs/gateway/bonjour.md +177 -0
- package/docs/gateway/bridge-protocol.md +91 -0
- package/docs/gateway/cli-backends.md +225 -0
- package/docs/gateway/configuration-examples.md +651 -0
- package/docs/gateway/configuration-reference.md +3123 -0
- package/docs/gateway/configuration.md +633 -0
- package/docs/gateway/discovery.md +123 -0
- package/docs/gateway/doctor.md +362 -0
- package/docs/gateway/gateway-lock.md +34 -0
- package/docs/gateway/health.md +44 -0
- package/docs/gateway/heartbeat.md +393 -0
- package/docs/gateway/index.md +261 -0
- package/docs/gateway/local-models.md +152 -0
- package/docs/gateway/logging.md +113 -0
- package/docs/gateway/multiple-gateways.md +112 -0
- package/docs/gateway/network-model.md +22 -0
- package/docs/gateway/openai-http-api.md +132 -0
- package/docs/gateway/openresponses-http-api.md +295 -0
- package/docs/gateway/openshell.md +307 -0
- package/docs/gateway/pairing.md +99 -0
- package/docs/gateway/protocol.md +267 -0
- package/docs/gateway/remote-gateway-readme.md +158 -0
- package/docs/gateway/remote.md +153 -0
- package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +134 -0
- package/docs/gateway/sandboxing.md +469 -0
- package/docs/gateway/secrets-plan-contract.md +116 -0
- package/docs/gateway/secrets.md +503 -0
- package/docs/gateway/security/index.md +1220 -0
- package/docs/gateway/tailscale.md +132 -0
- package/docs/gateway/tools-invoke-http-api.md +118 -0
- package/docs/gateway/troubleshooting.md +378 -0
- package/docs/gateway/trusted-proxy-auth.md +330 -0
- package/docs/help/debugging.md +168 -0
- package/docs/help/environment.md +163 -0
- package/docs/help/faq.md +2997 -0
- package/docs/help/index.md +28 -0
- package/docs/help/scripts.md +28 -0
- package/docs/help/testing.md +526 -0
- package/docs/help/troubleshooting.md +297 -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/development-channels.md +120 -0
- package/docs/install/digitalocean.md +129 -0
- package/docs/install/docker-vm-runtime.md +142 -0
- package/docs/install/docker.md +375 -0
- package/docs/install/exe-dev.md +126 -0
- package/docs/install/fly.md +501 -0
- package/docs/install/gcp.md +402 -0
- package/docs/install/hetzner.md +251 -0
- package/docs/install/index.md +183 -0
- package/docs/install/installer.md +415 -0
- package/docs/install/kubernetes.md +191 -0
- package/docs/install/macos-vm.md +281 -0
- package/docs/install/migrating-matrix.md +346 -0
- package/docs/install/migrating.md +110 -0
- package/docs/install/nix.md +89 -0
- package/docs/install/node.md +138 -0
- package/docs/install/northflank.mdx +54 -0
- package/docs/install/oracle.md +156 -0
- package/docs/install/podman.md +133 -0
- package/docs/install/railway.mdx +100 -0
- package/docs/install/raspberry-pi.md +159 -0
- package/docs/install/render.mdx +169 -0
- package/docs/install/uninstall.md +128 -0
- package/docs/install/updating.md +128 -0
- package/docs/ja-JP/index.md +186 -0
- package/docs/ja-JP/start/getting-started.md +125 -0
- package/docs/ja-JP/start/wizard.md +77 -0
- package/docs/logging.md +352 -0
- package/docs/nav-tabs-underline.js +100 -0
- package/docs/network.md +54 -0
- package/docs/nodes/audio.md +187 -0
- package/docs/nodes/camera.md +162 -0
- package/docs/nodes/images.md +72 -0
- package/docs/nodes/index.md +393 -0
- package/docs/nodes/location-command.md +98 -0
- package/docs/nodes/media-understanding.md +394 -0
- package/docs/nodes/talk.md +92 -0
- package/docs/nodes/troubleshooting.md +114 -0
- package/docs/nodes/voicewake.md +66 -0
- package/docs/perplexity.md +174 -0
- package/docs/pi-dev.md +80 -0
- package/docs/pi.md +567 -0
- package/docs/platforms/android.md +168 -0
- package/docs/platforms/digitalocean.md +266 -0
- package/docs/platforms/index.md +54 -0
- package/docs/platforms/ios.md +220 -0
- package/docs/platforms/linux.md +94 -0
- package/docs/platforms/mac/bundled-gateway.md +73 -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 +104 -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 +33 -0
- package/docs/platforms/mac/voice-overlay.md +60 -0
- package/docs/platforms/mac/voicewake.md +67 -0
- package/docs/platforms/mac/webchat.md +43 -0
- package/docs/platforms/mac/xpc.md +61 -0
- package/docs/platforms/macos.md +226 -0
- package/docs/platforms/oracle.md +303 -0
- package/docs/platforms/raspberry-pi.md +412 -0
- package/docs/platforms/windows.md +241 -0
- package/docs/plugins/agent-tools.md +10 -0
- package/docs/plugins/architecture.md +1366 -0
- package/docs/plugins/building-extensions.md +10 -0
- package/docs/plugins/building-plugins.md +239 -0
- package/docs/plugins/bundles.md +181 -0
- package/docs/plugins/community.md +145 -0
- package/docs/plugins/manifest.md +241 -0
- package/docs/plugins/sdk-channel-plugins.md +370 -0
- package/docs/plugins/sdk-entrypoints.md +161 -0
- package/docs/plugins/sdk-migration.md +172 -0
- package/docs/plugins/sdk-overview.md +196 -0
- package/docs/plugins/sdk-provider-plugins.md +370 -0
- package/docs/plugins/sdk-runtime.md +345 -0
- package/docs/plugins/sdk-setup.md +331 -0
- package/docs/plugins/sdk-testing.md +263 -0
- package/docs/plugins/voice-call.md +380 -0
- package/docs/plugins/zalouser.md +77 -0
- package/docs/prose.md +134 -0
- package/docs/providers/anthropic.md +259 -0
- package/docs/providers/bedrock.md +176 -0
- package/docs/providers/claude-max-api-proxy.md +154 -0
- package/docs/providers/cloudflare-ai-gateway.md +71 -0
- package/docs/providers/deepgram.md +93 -0
- package/docs/providers/github-copilot.md +72 -0
- package/docs/providers/glm.md +43 -0
- package/docs/providers/google.md +78 -0
- package/docs/providers/groq.md +96 -0
- package/docs/providers/huggingface.md +209 -0
- package/docs/providers/index.md +69 -0
- package/docs/providers/kilocode.md +74 -0
- package/docs/providers/litellm.md +154 -0
- package/docs/providers/minimax.md +224 -0
- package/docs/providers/mistral.md +54 -0
- package/docs/providers/models.md +45 -0
- package/docs/providers/modelstudio.md +66 -0
- package/docs/providers/moonshot.md +175 -0
- package/docs/providers/nvidia.md +55 -0
- package/docs/providers/ollama.md +352 -0
- package/docs/providers/openai.md +303 -0
- package/docs/providers/opencode-go.md +45 -0
- package/docs/providers/opencode.md +64 -0
- package/docs/providers/openrouter.md +37 -0
- package/docs/providers/perplexity-provider.md +62 -0
- package/docs/providers/qianfan.md +38 -0
- package/docs/providers/qwen.md +53 -0
- package/docs/providers/sglang.md +104 -0
- package/docs/providers/synthetic.md +99 -0
- package/docs/providers/together.md +66 -0
- package/docs/providers/venice.md +282 -0
- package/docs/providers/vercel-ai-gateway.md +60 -0
- package/docs/providers/vllm.md +92 -0
- package/docs/providers/volcengine.md +74 -0
- package/docs/providers/xai.md +60 -0
- package/docs/providers/xiaomi.md +86 -0
- package/docs/providers/zai.md +46 -0
- package/docs/reference/AGENTS.default.md +126 -0
- package/docs/reference/RELEASING.md +42 -0
- package/docs/reference/api-usage-costs.md +144 -0
- package/docs/reference/credits.md +30 -0
- package/docs/reference/device-models.md +47 -0
- package/docs/reference/memory-config.md +711 -0
- package/docs/reference/prompt-caching.md +185 -0
- package/docs/reference/rpc.md +43 -0
- package/docs/reference/secretref-credential-surface.md +140 -0
- package/docs/reference/secretref-user-supplied-credentials-matrix.json +563 -0
- package/docs/reference/session-management-compaction.md +324 -0
- package/docs/reference/templates/AGENTS.dev.md +83 -0
- package/docs/reference/templates/AGENTS.md +219 -0
- package/docs/reference/templates/BOOT.md +11 -0
- package/docs/reference/templates/BOOTSTRAP.md +62 -0
- package/docs/reference/templates/HEARTBEAT.md +14 -0
- package/docs/reference/templates/IDENTITY.dev.md +47 -0
- package/docs/reference/templates/IDENTITY.md +29 -0
- package/docs/reference/templates/SOUL.dev.md +76 -0
- package/docs/reference/templates/SOUL.md +43 -0
- package/docs/reference/templates/TOOLS.dev.md +24 -0
- package/docs/reference/templates/TOOLS.md +47 -0
- package/docs/reference/templates/USER.dev.md +18 -0
- package/docs/reference/templates/USER.md +23 -0
- package/docs/reference/test.md +90 -0
- package/docs/reference/token-use.md +175 -0
- package/docs/reference/transcript-hygiene.md +151 -0
- package/docs/reference/wizard.md +235 -0
- package/docs/security/CONTRIBUTING-THREAT-MODEL.md +98 -0
- package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
- package/docs/security/formal-verification.md +167 -0
- package/docs/start/bootstrapping.md +41 -0
- package/docs/start/docs-directory.md +66 -0
- package/docs/start/getting-started.md +116 -0
- package/docs/start/hubs.md +198 -0
- package/docs/start/lore.md +219 -0
- package/docs/start/onboarding-overview.md +67 -0
- package/docs/start/onboarding.md +91 -0
- package/docs/start/openclaw.md +221 -0
- package/docs/start/quickstart.md +22 -0
- package/docs/start/setup.md +164 -0
- package/docs/start/showcase.md +418 -0
- package/docs/start/wizard-cli-automation.md +215 -0
- package/docs/start/wizard-cli-reference.md +299 -0
- package/docs/start/wizard.md +125 -0
- package/docs/style.css +37 -0
- package/docs/tools/acp-agents.md +623 -0
- package/docs/tools/agent-send.md +100 -0
- package/docs/tools/apply-patch.md +51 -0
- package/docs/tools/brave-search.md +93 -0
- package/docs/tools/browser-linux-troubleshooting.md +138 -0
- package/docs/tools/browser-login.md +73 -0
- package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +211 -0
- package/docs/tools/browser.md +731 -0
- package/docs/tools/btw.md +142 -0
- package/docs/tools/capability-cookbook.md +119 -0
- package/docs/tools/clawhub.md +298 -0
- package/docs/tools/creating-skills.md +117 -0
- package/docs/tools/diffs.md +386 -0
- package/docs/tools/elevated.md +114 -0
- package/docs/tools/exec-approvals.md +430 -0
- package/docs/tools/exec.md +207 -0
- package/docs/tools/firecrawl.md +140 -0
- package/docs/tools/index.md +137 -0
- package/docs/tools/llm-task.md +119 -0
- package/docs/tools/lobster.md +340 -0
- package/docs/tools/loop-detection.md +100 -0
- package/docs/tools/multi-agent-sandbox-tools.md +364 -0
- package/docs/tools/pdf.md +156 -0
- package/docs/tools/perplexity-search.md +174 -0
- package/docs/tools/plugin.md +255 -0
- package/docs/tools/reactions.md +64 -0
- package/docs/tools/skills-config.md +86 -0
- package/docs/tools/skills.md +309 -0
- package/docs/tools/slash-commands.md +294 -0
- package/docs/tools/subagents.md +295 -0
- package/docs/tools/tavily.md +125 -0
- package/docs/tools/thinking.md +96 -0
- package/docs/tools/tts.md +406 -0
- package/docs/tools/web.md +516 -0
- package/docs/tts.md +406 -0
- package/docs/vps.md +112 -0
- package/docs/web/control-ui.md +275 -0
- package/docs/web/dashboard.md +54 -0
- package/docs/web/index.md +120 -0
- package/docs/web/tui.md +170 -0
- package/docs/web/webchat.md +61 -0
- package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
- package/docs/whatsapp-openclaw.jpg +0 -0
- package/docs/zh-CN/AGENTS.md +61 -0
- package/docs/zh-CN/automation/auth-monitoring.md +47 -0
- package/docs/zh-CN/automation/cron-jobs.md +435 -0
- package/docs/zh-CN/automation/cron-vs-heartbeat.md +286 -0
- package/docs/zh-CN/automation/gmail-pubsub.md +249 -0
- package/docs/zh-CN/automation/hooks.md +1051 -0
- package/docs/zh-CN/automation/poll.md +76 -0
- package/docs/zh-CN/automation/troubleshooting.md +8 -0
- package/docs/zh-CN/automation/webhook.md +163 -0
- package/docs/zh-CN/brave-search.md +60 -0
- package/docs/zh-CN/channels/bluebubbles.md +354 -0
- package/docs/zh-CN/channels/broadcast-groups.md +449 -0
- package/docs/zh-CN/channels/channel-routing.md +117 -0
- package/docs/zh-CN/channels/discord.md +468 -0
- package/docs/zh-CN/channels/feishu.md +728 -0
- package/docs/zh-CN/channels/googlechat.md +257 -0
- package/docs/zh-CN/channels/grammy.md +38 -0
- package/docs/zh-CN/channels/group-messages.md +91 -0
- package/docs/zh-CN/channels/groups.md +379 -0
- package/docs/zh-CN/channels/imessage.md +302 -0
- package/docs/zh-CN/channels/index.md +53 -0
- package/docs/zh-CN/channels/line.md +180 -0
- package/docs/zh-CN/channels/location.md +63 -0
- package/docs/zh-CN/channels/matrix.md +221 -0
- package/docs/zh-CN/channels/mattermost.md +144 -0
- package/docs/zh-CN/channels/msteams.md +775 -0
- package/docs/zh-CN/channels/nextcloud-talk.md +142 -0
- package/docs/zh-CN/channels/nostr.md +249 -0
- package/docs/zh-CN/channels/pairing.md +89 -0
- package/docs/zh-CN/channels/signal.md +209 -0
- package/docs/zh-CN/channels/slack.md +531 -0
- package/docs/zh-CN/channels/synology-chat.md +138 -0
- package/docs/zh-CN/channels/telegram.md +751 -0
- package/docs/zh-CN/channels/tlon.md +136 -0
- package/docs/zh-CN/channels/troubleshooting.md +36 -0
- package/docs/zh-CN/channels/twitch.md +385 -0
- package/docs/zh-CN/channels/whatsapp.md +411 -0
- package/docs/zh-CN/channels/zalo.md +196 -0
- package/docs/zh-CN/channels/zalouser.md +147 -0
- package/docs/zh-CN/cli/acp.md +173 -0
- package/docs/zh-CN/cli/agent.md +30 -0
- package/docs/zh-CN/cli/agents.md +82 -0
- package/docs/zh-CN/cli/approvals.md +57 -0
- package/docs/zh-CN/cli/browser.md +114 -0
- package/docs/zh-CN/cli/channels.md +86 -0
- package/docs/zh-CN/cli/config.md +57 -0
- package/docs/zh-CN/cli/configure.md +38 -0
- package/docs/zh-CN/cli/cron.md +43 -0
- package/docs/zh-CN/cli/dashboard.md +23 -0
- package/docs/zh-CN/cli/devices.md +74 -0
- package/docs/zh-CN/cli/directory.md +70 -0
- package/docs/zh-CN/cli/dns.md +30 -0
- package/docs/zh-CN/cli/docs.md +22 -0
- package/docs/zh-CN/cli/doctor.md +48 -0
- package/docs/zh-CN/cli/gateway.md +206 -0
- package/docs/zh-CN/cli/health.md +28 -0
- package/docs/zh-CN/cli/hooks.md +298 -0
- package/docs/zh-CN/cli/index.md +1143 -0
- package/docs/zh-CN/cli/logs.md +31 -0
- package/docs/zh-CN/cli/memory.md +52 -0
- package/docs/zh-CN/cli/message.md +246 -0
- package/docs/zh-CN/cli/models.md +85 -0
- package/docs/zh-CN/cli/node.md +115 -0
- package/docs/zh-CN/cli/nodes.md +80 -0
- package/docs/zh-CN/cli/onboard.md +164 -0
- package/docs/zh-CN/cli/pairing.md +28 -0
- package/docs/zh-CN/cli/plugins.md +66 -0
- package/docs/zh-CN/cli/reset.md +24 -0
- package/docs/zh-CN/cli/sandbox.md +158 -0
- package/docs/zh-CN/cli/security.md +33 -0
- package/docs/zh-CN/cli/sessions.md +23 -0
- package/docs/zh-CN/cli/setup.md +36 -0
- package/docs/zh-CN/cli/skills.md +33 -0
- package/docs/zh-CN/cli/status.md +33 -0
- package/docs/zh-CN/cli/system.md +63 -0
- package/docs/zh-CN/cli/tui.md +30 -0
- package/docs/zh-CN/cli/uninstall.md +24 -0
- package/docs/zh-CN/cli/update.md +101 -0
- package/docs/zh-CN/cli/voicecall.md +41 -0
- package/docs/zh-CN/cli/webhooks.md +32 -0
- package/docs/zh-CN/concepts/agent-loop.md +146 -0
- package/docs/zh-CN/concepts/agent-workspace.md +219 -0
- package/docs/zh-CN/concepts/agent.md +115 -0
- package/docs/zh-CN/concepts/architecture.md +123 -0
- package/docs/zh-CN/concepts/compaction.md +67 -0
- package/docs/zh-CN/concepts/context.md +168 -0
- package/docs/zh-CN/concepts/features.md +59 -0
- package/docs/zh-CN/concepts/markdown-formatting.md +117 -0
- package/docs/zh-CN/concepts/memory.md +412 -0
- package/docs/zh-CN/concepts/messages.md +141 -0
- package/docs/zh-CN/concepts/model-failover.md +145 -0
- package/docs/zh-CN/concepts/model-providers.md +606 -0
- package/docs/zh-CN/concepts/models.md +225 -0
- package/docs/zh-CN/concepts/multi-agent.md +372 -0
- package/docs/zh-CN/concepts/oauth.md +164 -0
- package/docs/zh-CN/concepts/presence.md +99 -0
- package/docs/zh-CN/concepts/queue.md +94 -0
- package/docs/zh-CN/concepts/retry.md +76 -0
- package/docs/zh-CN/concepts/session-pruning.md +129 -0
- package/docs/zh-CN/concepts/session-tool.md +200 -0
- package/docs/zh-CN/concepts/session.md +166 -0
- package/docs/zh-CN/concepts/streaming.md +133 -0
- package/docs/zh-CN/concepts/system-prompt.md +101 -0
- package/docs/zh-CN/concepts/timezone.md +96 -0
- package/docs/zh-CN/concepts/typebox.md +284 -0
- package/docs/zh-CN/concepts/typing-indicators.md +74 -0
- package/docs/zh-CN/concepts/usage-tracking.md +42 -0
- package/docs/zh-CN/date-time.md +129 -0
- package/docs/zh-CN/debug/node-issue.md +90 -0
- package/docs/zh-CN/diagnostics/flags.md +98 -0
- package/docs/zh-CN/gateway/authentication.md +184 -0
- package/docs/zh-CN/gateway/background-process.md +100 -0
- package/docs/zh-CN/gateway/bonjour.md +174 -0
- package/docs/zh-CN/gateway/bridge-protocol.md +86 -0
- package/docs/zh-CN/gateway/cli-backends.md +213 -0
- package/docs/zh-CN/gateway/configuration-examples.md +587 -0
- package/docs/zh-CN/gateway/configuration-reference.md +3103 -0
- package/docs/zh-CN/gateway/configuration.md +640 -0
- package/docs/zh-CN/gateway/discovery.md +123 -0
- package/docs/zh-CN/gateway/doctor.md +238 -0
- package/docs/zh-CN/gateway/gateway-lock.md +41 -0
- package/docs/zh-CN/gateway/health.md +42 -0
- package/docs/zh-CN/gateway/heartbeat.md +274 -0
- package/docs/zh-CN/gateway/index.md +335 -0
- package/docs/zh-CN/gateway/local-models.md +159 -0
- package/docs/zh-CN/gateway/logging.md +114 -0
- package/docs/zh-CN/gateway/multiple-gateways.md +119 -0
- package/docs/zh-CN/gateway/network-model.md +23 -0
- package/docs/zh-CN/gateway/openai-http-api.md +125 -0
- package/docs/zh-CN/gateway/openresponses-http-api.md +317 -0
- package/docs/zh-CN/gateway/pairing.md +99 -0
- package/docs/zh-CN/gateway/protocol.md +220 -0
- package/docs/zh-CN/gateway/remote-gateway-readme.md +164 -0
- package/docs/zh-CN/gateway/remote.md +133 -0
- package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +135 -0
- package/docs/zh-CN/gateway/sandboxing.md +188 -0
- package/docs/zh-CN/gateway/security/index.md +777 -0
- package/docs/zh-CN/gateway/tailscale.md +124 -0
- package/docs/zh-CN/gateway/tools-invoke-http-api.md +92 -0
- package/docs/zh-CN/gateway/troubleshooting.md +771 -0
- package/docs/zh-CN/help/debugging.md +160 -0
- package/docs/zh-CN/help/environment.md +88 -0
- package/docs/zh-CN/help/faq.md +2640 -0
- package/docs/zh-CN/help/index.md +28 -0
- package/docs/zh-CN/help/scripts.md +35 -0
- package/docs/zh-CN/help/testing.md +375 -0
- package/docs/zh-CN/help/troubleshooting.md +104 -0
- package/docs/zh-CN/index.md +186 -0
- package/docs/zh-CN/install/ansible.md +215 -0
- package/docs/zh-CN/install/bun.md +65 -0
- package/docs/zh-CN/install/development-channels.md +81 -0
- package/docs/zh-CN/install/docker.md +532 -0
- package/docs/zh-CN/install/exe-dev.md +133 -0
- package/docs/zh-CN/install/fly.md +490 -0
- package/docs/zh-CN/install/gcp.md +510 -0
- package/docs/zh-CN/install/hetzner.md +337 -0
- package/docs/zh-CN/install/index.md +235 -0
- package/docs/zh-CN/install/installer.md +422 -0
- package/docs/zh-CN/install/macos-vm.md +288 -0
- package/docs/zh-CN/install/migrating.md +199 -0
- package/docs/zh-CN/install/nix.md +99 -0
- package/docs/zh-CN/install/node.md +8 -0
- package/docs/zh-CN/install/northflank.mdx +60 -0
- package/docs/zh-CN/install/railway.mdx +106 -0
- package/docs/zh-CN/install/render.mdx +169 -0
- package/docs/zh-CN/install/uninstall.md +135 -0
- package/docs/zh-CN/install/updating.md +233 -0
- package/docs/zh-CN/logging.md +329 -0
- package/docs/zh-CN/network.md +59 -0
- package/docs/zh-CN/nodes/audio.md +120 -0
- package/docs/zh-CN/nodes/camera.md +162 -0
- package/docs/zh-CN/nodes/images.md +79 -0
- package/docs/zh-CN/nodes/index.md +348 -0
- package/docs/zh-CN/nodes/location-command.md +120 -0
- package/docs/zh-CN/nodes/media-understanding.md +380 -0
- package/docs/zh-CN/nodes/talk.md +97 -0
- package/docs/zh-CN/nodes/troubleshooting.md +8 -0
- package/docs/zh-CN/nodes/voicewake.md +72 -0
- package/docs/zh-CN/perplexity.md +102 -0
- package/docs/zh-CN/pi-dev.md +77 -0
- package/docs/zh-CN/pi.md +619 -0
- package/docs/zh-CN/platforms/android.md +155 -0
- package/docs/zh-CN/platforms/digitalocean.md +273 -0
- package/docs/zh-CN/platforms/index.md +60 -0
- package/docs/zh-CN/platforms/ios.md +114 -0
- package/docs/zh-CN/platforms/linux.md +100 -0
- package/docs/zh-CN/platforms/mac/bundled-gateway.md +75 -0
- package/docs/zh-CN/platforms/mac/canvas.md +128 -0
- package/docs/zh-CN/platforms/mac/child-process.md +73 -0
- package/docs/zh-CN/platforms/mac/dev-setup.md +109 -0
- package/docs/zh-CN/platforms/mac/health.md +41 -0
- package/docs/zh-CN/platforms/mac/icon.md +38 -0
- package/docs/zh-CN/platforms/mac/logging.md +64 -0
- package/docs/zh-CN/platforms/mac/menu-bar.md +88 -0
- package/docs/zh-CN/platforms/mac/peekaboo.md +62 -0
- package/docs/zh-CN/platforms/mac/permissions.md +46 -0
- package/docs/zh-CN/platforms/mac/remote.md +90 -0
- package/docs/zh-CN/platforms/mac/signing.md +54 -0
- package/docs/zh-CN/platforms/mac/skills.md +40 -0
- package/docs/zh-CN/platforms/mac/voice-overlay.md +67 -0
- package/docs/zh-CN/platforms/mac/voicewake.md +74 -0
- package/docs/zh-CN/platforms/mac/webchat.md +43 -0
- package/docs/zh-CN/platforms/mac/xpc.md +68 -0
- package/docs/zh-CN/platforms/macos.md +193 -0
- package/docs/zh-CN/platforms/oracle.md +310 -0
- package/docs/zh-CN/platforms/raspberry-pi.md +416 -0
- package/docs/zh-CN/platforms/windows.md +247 -0
- package/docs/zh-CN/plugins/agent-tools.md +99 -0
- package/docs/zh-CN/plugins/manifest.md +68 -0
- package/docs/zh-CN/plugins/voice-call.md +250 -0
- package/docs/zh-CN/plugins/zalouser.md +88 -0
- package/docs/zh-CN/prose.md +141 -0
- package/docs/zh-CN/providers/anthropic.md +265 -0
- package/docs/zh-CN/providers/bedrock.md +170 -0
- package/docs/zh-CN/providers/claude-max-api-proxy.md +155 -0
- package/docs/zh-CN/providers/cloudflare-ai-gateway.md +78 -0
- package/docs/zh-CN/providers/deepgram.md +97 -0
- package/docs/zh-CN/providers/github-copilot.md +67 -0
- package/docs/zh-CN/providers/glm.md +50 -0
- package/docs/zh-CN/providers/huggingface.md +216 -0
- package/docs/zh-CN/providers/index.md +69 -0
- package/docs/zh-CN/providers/kilocode.md +80 -0
- package/docs/zh-CN/providers/litellm.md +160 -0
- package/docs/zh-CN/providers/minimax.md +222 -0
- package/docs/zh-CN/providers/mistral.md +61 -0
- package/docs/zh-CN/providers/models.md +51 -0
- package/docs/zh-CN/providers/moonshot.md +182 -0
- package/docs/zh-CN/providers/nvidia.md +62 -0
- package/docs/zh-CN/providers/ollama.md +359 -0
- package/docs/zh-CN/providers/openai.md +308 -0
- package/docs/zh-CN/providers/opencode-go.md +52 -0
- package/docs/zh-CN/providers/opencode.md +71 -0
- package/docs/zh-CN/providers/openrouter.md +44 -0
- package/docs/zh-CN/providers/qianfan.md +45 -0
- package/docs/zh-CN/providers/qwen.md +55 -0
- package/docs/zh-CN/providers/sglang.md +111 -0
- package/docs/zh-CN/providers/synthetic.md +106 -0
- package/docs/zh-CN/providers/together.md +72 -0
- package/docs/zh-CN/providers/venice.md +289 -0
- package/docs/zh-CN/providers/vercel-ai-gateway.md +66 -0
- package/docs/zh-CN/providers/xiaomi.md +93 -0
- package/docs/zh-CN/providers/zai.md +53 -0
- package/docs/zh-CN/reference/AGENTS.default.md +131 -0
- package/docs/zh-CN/reference/RELEASING.md +48 -0
- package/docs/zh-CN/reference/api-usage-costs.md +141 -0
- package/docs/zh-CN/reference/credits.md +34 -0
- package/docs/zh-CN/reference/device-models.md +54 -0
- package/docs/zh-CN/reference/rpc.md +48 -0
- package/docs/zh-CN/reference/session-management-compaction.md +287 -0
- package/docs/zh-CN/reference/templates/AGENTS.dev.md +89 -0
- package/docs/zh-CN/reference/templates/AGENTS.md +225 -0
- package/docs/zh-CN/reference/templates/BOOT.md +17 -0
- package/docs/zh-CN/reference/templates/BOOTSTRAP.md +68 -0
- package/docs/zh-CN/reference/templates/HEARTBEAT.md +18 -0
- package/docs/zh-CN/reference/templates/IDENTITY.dev.md +54 -0
- package/docs/zh-CN/reference/templates/IDENTITY.md +36 -0
- package/docs/zh-CN/reference/templates/SOUL.dev.md +83 -0
- package/docs/zh-CN/reference/templates/SOUL.md +49 -0
- package/docs/zh-CN/reference/templates/TOOLS.dev.md +31 -0
- package/docs/zh-CN/reference/templates/TOOLS.md +53 -0
- package/docs/zh-CN/reference/templates/USER.dev.md +25 -0
- package/docs/zh-CN/reference/templates/USER.md +30 -0
- package/docs/zh-CN/reference/test.md +57 -0
- package/docs/zh-CN/reference/token-use.md +119 -0
- package/docs/zh-CN/reference/transcript-hygiene.md +109 -0
- package/docs/zh-CN/reference/wizard.md +242 -0
- package/docs/zh-CN/security/formal-verification.md +171 -0
- package/docs/zh-CN/start/bootstrapping.md +9 -0
- package/docs/zh-CN/start/docs-directory.md +70 -0
- package/docs/zh-CN/start/getting-started.md +143 -0
- package/docs/zh-CN/start/hubs.md +194 -0
- package/docs/zh-CN/start/lore.md +226 -0
- package/docs/zh-CN/start/onboarding-overview.md +58 -0
- package/docs/zh-CN/start/onboarding.md +105 -0
- package/docs/zh-CN/start/openclaw.md +248 -0
- package/docs/zh-CN/start/quickstart.md +88 -0
- package/docs/zh-CN/start/setup.md +153 -0
- package/docs/zh-CN/start/showcase.md +423 -0
- package/docs/zh-CN/start/wizard-cli-automation.md +222 -0
- package/docs/zh-CN/start/wizard-cli-reference.md +306 -0
- package/docs/zh-CN/start/wizard.md +132 -0
- package/docs/zh-CN/tools/agent-send.md +59 -0
- package/docs/zh-CN/tools/apply-patch.md +57 -0
- package/docs/zh-CN/tools/browser-linux-troubleshooting.md +144 -0
- package/docs/zh-CN/tools/browser-login.md +75 -0
- package/docs/zh-CN/tools/browser.md +553 -0
- package/docs/zh-CN/tools/chrome-extension.md +183 -0
- package/docs/zh-CN/tools/clawhub.md +209 -0
- package/docs/zh-CN/tools/creating-skills.md +61 -0
- package/docs/zh-CN/tools/elevated.md +64 -0
- package/docs/zh-CN/tools/exec-approvals.md +234 -0
- package/docs/zh-CN/tools/exec.md +169 -0
- package/docs/zh-CN/tools/firecrawl.md +68 -0
- package/docs/zh-CN/tools/index.md +515 -0
- package/docs/zh-CN/tools/llm-task.md +117 -0
- package/docs/zh-CN/tools/lobster.md +349 -0
- package/docs/zh-CN/tools/multi-agent-sandbox-tools.md +401 -0
- package/docs/zh-CN/tools/plugin.md +1612 -0
- package/docs/zh-CN/tools/reactions.md +29 -0
- package/docs/zh-CN/tools/skills-config.md +78 -0
- package/docs/zh-CN/tools/skills.md +279 -0
- package/docs/zh-CN/tools/slash-commands.md +205 -0
- package/docs/zh-CN/tools/subagents.md +167 -0
- package/docs/zh-CN/tools/thinking.md +80 -0
- package/docs/zh-CN/tools/web.md +289 -0
- package/docs/zh-CN/tts.md +375 -0
- package/docs/zh-CN/vps.md +47 -0
- package/docs/zh-CN/web/control-ui.md +191 -0
- package/docs/zh-CN/web/dashboard.md +53 -0
- package/docs/zh-CN/web/index.md +118 -0
- package/docs/zh-CN/web/tui.md +166 -0
- package/docs/zh-CN/web/webchat.md +56 -0
- package/package.json +841 -0
- package/quantumclaw.mjs +135 -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 +198 -0
- package/skills/clawhub/SKILL.md +77 -0
- package/skills/coding-agent/SKILL.md +295 -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 +865 -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-image-gen/SKILL.md +92 -0
- package/skills/openai-image-gen/scripts/gen.py +328 -0
- package/skills/openai-image-gen/scripts/test_gen.py +140 -0
- package/skills/openai-whisper/SKILL.md +38 -0
- package/skills/openai-whisper-api/SKILL.md +52 -0
- package/skills/openai-whisper-api/scripts/transcribe.sh +85 -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 +115 -0
- package/skills/sherpa-onnx-tts/SKILL.md +103 -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/things-mac/SKILL.md +86 -0
- package/skills/tmux/SKILL.md +153 -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 +95 -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 +112 -0
- package/skills/xurl/SKILL.md +461 -0
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Contract for `secrets apply` plans: target validation, path matching, and `auth-profiles.json` target scope"
|
|
3
|
+
read_when:
|
|
4
|
+
- Generating or reviewing `quantumclaw secrets apply` plans
|
|
5
|
+
- Debugging `Invalid plan target path` errors
|
|
6
|
+
- Understanding target type and path validation behavior
|
|
7
|
+
title: "Secrets Apply Plan Contract"
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# Secrets apply plan contract
|
|
11
|
+
|
|
12
|
+
This page defines the strict contract enforced by `quantumclaw secrets apply`.
|
|
13
|
+
|
|
14
|
+
If a target does not match these rules, apply fails before mutating configuration.
|
|
15
|
+
|
|
16
|
+
## Plan file shape
|
|
17
|
+
|
|
18
|
+
`quantumclaw secrets apply --from <plan.json>` expects a `targets` array of plan targets:
|
|
19
|
+
|
|
20
|
+
```json5
|
|
21
|
+
{
|
|
22
|
+
version: 1,
|
|
23
|
+
protocolVersion: 1,
|
|
24
|
+
targets: [
|
|
25
|
+
{
|
|
26
|
+
type: "models.providers.apiKey",
|
|
27
|
+
path: "models.providers.openai.apiKey",
|
|
28
|
+
pathSegments: ["models", "providers", "openai", "apiKey"],
|
|
29
|
+
providerId: "openai",
|
|
30
|
+
ref: { source: "env", provider: "default", id: "OPENAI_API_KEY" },
|
|
31
|
+
},
|
|
32
|
+
{
|
|
33
|
+
type: "auth-profiles.api_key.key",
|
|
34
|
+
path: "profiles.openai:default.key",
|
|
35
|
+
pathSegments: ["profiles", "openai:default", "key"],
|
|
36
|
+
agentId: "main",
|
|
37
|
+
ref: { source: "env", provider: "default", id: "OPENAI_API_KEY" },
|
|
38
|
+
},
|
|
39
|
+
],
|
|
40
|
+
}
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
## Supported target scope
|
|
44
|
+
|
|
45
|
+
Plan targets are accepted for supported credential paths in:
|
|
46
|
+
|
|
47
|
+
- [SecretRef Credential Surface](/reference/secretref-credential-surface)
|
|
48
|
+
|
|
49
|
+
## Target type behavior
|
|
50
|
+
|
|
51
|
+
General rule:
|
|
52
|
+
|
|
53
|
+
- `target.type` must be recognized and must match the normalized `target.path` shape.
|
|
54
|
+
|
|
55
|
+
Compatibility aliases remain accepted for existing plans:
|
|
56
|
+
|
|
57
|
+
- `models.providers.apiKey`
|
|
58
|
+
- `skills.entries.apiKey`
|
|
59
|
+
- `channels.googlechat.serviceAccount`
|
|
60
|
+
|
|
61
|
+
## Path validation rules
|
|
62
|
+
|
|
63
|
+
Each target is validated with all of the following:
|
|
64
|
+
|
|
65
|
+
- `type` must be a recognized target type.
|
|
66
|
+
- `path` must be a non-empty dot path.
|
|
67
|
+
- `pathSegments` can be omitted. If provided, it must normalize to exactly the same path as `path`.
|
|
68
|
+
- Forbidden segments are rejected: `__proto__`, `prototype`, `constructor`.
|
|
69
|
+
- The normalized path must match the registered path shape for the target type.
|
|
70
|
+
- If `providerId` or `accountId` is set, it must match the id encoded in the path.
|
|
71
|
+
- `auth-profiles.json` targets require `agentId`.
|
|
72
|
+
- When creating a new `auth-profiles.json` mapping, include `authProfileProvider`.
|
|
73
|
+
|
|
74
|
+
## Failure behavior
|
|
75
|
+
|
|
76
|
+
If a target fails validation, apply exits with an error like:
|
|
77
|
+
|
|
78
|
+
```text
|
|
79
|
+
Invalid plan target path for models.providers.apiKey: models.providers.openai.baseUrl
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
No writes are committed for an invalid plan.
|
|
83
|
+
|
|
84
|
+
## Exec provider consent behavior
|
|
85
|
+
|
|
86
|
+
- `--dry-run` skips exec SecretRef checks by default.
|
|
87
|
+
- Plans containing exec SecretRefs/providers are rejected in write mode unless `--allow-exec` is set.
|
|
88
|
+
- When validating/applying exec-containing plans, pass `--allow-exec` in both dry-run and write commands.
|
|
89
|
+
|
|
90
|
+
## Runtime and audit scope notes
|
|
91
|
+
|
|
92
|
+
- Ref-only `auth-profiles.json` entries (`keyRef`/`tokenRef`) are included in runtime resolution and audit coverage.
|
|
93
|
+
- `secrets apply` writes supported `quantumclaw.json` targets, supported `auth-profiles.json` targets, and optional scrub targets.
|
|
94
|
+
|
|
95
|
+
## Operator checks
|
|
96
|
+
|
|
97
|
+
```bash
|
|
98
|
+
# Validate plan without writes
|
|
99
|
+
quantumclaw secrets apply --from /tmp/quantumclaw-secrets-plan.json --dry-run
|
|
100
|
+
|
|
101
|
+
# Then apply for real
|
|
102
|
+
quantumclaw secrets apply --from /tmp/quantumclaw-secrets-plan.json
|
|
103
|
+
|
|
104
|
+
# For exec-containing plans, opt in explicitly in both modes
|
|
105
|
+
quantumclaw secrets apply --from /tmp/quantumclaw-secrets-plan.json --dry-run --allow-exec
|
|
106
|
+
quantumclaw secrets apply --from /tmp/quantumclaw-secrets-plan.json --allow-exec
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
If apply fails with an invalid target path message, regenerate the plan with `quantumclaw secrets configure` or fix the target path to a supported shape above.
|
|
110
|
+
|
|
111
|
+
## Related docs
|
|
112
|
+
|
|
113
|
+
- [Secrets Management](/gateway/secrets)
|
|
114
|
+
- [CLI `secrets`](/cli/secrets)
|
|
115
|
+
- [SecretRef Credential Surface](/reference/secretref-credential-surface)
|
|
116
|
+
- [Configuration Reference](/gateway/configuration-reference)
|
|
@@ -0,0 +1,503 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Secrets management: SecretRef contract, runtime snapshot behavior, and safe one-way scrubbing"
|
|
3
|
+
read_when:
|
|
4
|
+
- Configuring SecretRefs for provider credentials and `auth-profiles.json` refs
|
|
5
|
+
- Operating secrets reload, audit, configure, and apply safely in production
|
|
6
|
+
- Understanding startup fail-fast, inactive-surface filtering, and last-known-good behavior
|
|
7
|
+
title: "Secrets Management"
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# Secrets management
|
|
11
|
+
|
|
12
|
+
QuantumClaw supports additive SecretRefs so supported credentials do not need to be stored as plaintext in configuration.
|
|
13
|
+
|
|
14
|
+
Plaintext still works. SecretRefs are opt-in per credential.
|
|
15
|
+
|
|
16
|
+
## Goals and runtime model
|
|
17
|
+
|
|
18
|
+
Secrets are resolved into an in-memory runtime snapshot.
|
|
19
|
+
|
|
20
|
+
- Resolution is eager during activation, not lazy on request paths.
|
|
21
|
+
- Startup fails fast when an effectively active SecretRef cannot be resolved.
|
|
22
|
+
- Reload uses atomic swap: full success, or keep the last-known-good snapshot.
|
|
23
|
+
- Runtime requests read from the active in-memory snapshot only.
|
|
24
|
+
- Outbound delivery paths also read from that active snapshot (for example Discord reply/thread delivery and Telegram action sends); they do not re-resolve SecretRefs on each send.
|
|
25
|
+
|
|
26
|
+
This keeps secret-provider outages off hot request paths.
|
|
27
|
+
|
|
28
|
+
## Active-surface filtering
|
|
29
|
+
|
|
30
|
+
SecretRefs are validated only on effectively active surfaces.
|
|
31
|
+
|
|
32
|
+
- Enabled surfaces: unresolved refs block startup/reload.
|
|
33
|
+
- Inactive surfaces: unresolved refs do not block startup/reload.
|
|
34
|
+
- Inactive refs emit non-fatal diagnostics with code `SECRETS_REF_IGNORED_INACTIVE_SURFACE`.
|
|
35
|
+
|
|
36
|
+
Examples of inactive surfaces:
|
|
37
|
+
|
|
38
|
+
- Disabled channel/account entries.
|
|
39
|
+
- Top-level channel credentials that no enabled account inherits.
|
|
40
|
+
- Disabled tool/feature surfaces.
|
|
41
|
+
- Web search provider-specific keys that are not selected by `tools.web.search.provider`.
|
|
42
|
+
In auto mode (provider unset), keys are consulted by precedence for provider auto-detection until one resolves.
|
|
43
|
+
After selection, non-selected provider keys are treated as inactive until selected.
|
|
44
|
+
- Sandbox SSH auth material (`agents.defaults.sandbox.ssh.identityData`,
|
|
45
|
+
`certificateData`, `knownHostsData`, plus per-agent overrides) is active only
|
|
46
|
+
when the effective sandbox backend is `ssh` for the default agent or an enabled agent.
|
|
47
|
+
- `gateway.remote.token` / `gateway.remote.password` SecretRefs are active if one of these is true:
|
|
48
|
+
- `gateway.mode=remote`
|
|
49
|
+
- `gateway.remote.url` is configured
|
|
50
|
+
- `gateway.tailscale.mode` is `serve` or `funnel`
|
|
51
|
+
- In local mode without those remote surfaces:
|
|
52
|
+
- `gateway.remote.token` is active when token auth can win and no env/auth token is configured.
|
|
53
|
+
- `gateway.remote.password` is active only when password auth can win and no env/auth password is configured.
|
|
54
|
+
- `gateway.auth.token` SecretRef is inactive for startup auth resolution when `QUANTUMCLAW_GATEWAY_TOKEN` (or `CLAWDBOT_GATEWAY_TOKEN`) is set, because env token input wins for that runtime.
|
|
55
|
+
|
|
56
|
+
## Gateway auth surface diagnostics
|
|
57
|
+
|
|
58
|
+
When a SecretRef is configured on `gateway.auth.token`, `gateway.auth.password`,
|
|
59
|
+
`gateway.remote.token`, or `gateway.remote.password`, gateway startup/reload logs the
|
|
60
|
+
surface state explicitly:
|
|
61
|
+
|
|
62
|
+
- `active`: the SecretRef is part of the effective auth surface and must resolve.
|
|
63
|
+
- `inactive`: the SecretRef is ignored for this runtime because another auth surface wins, or
|
|
64
|
+
because remote auth is disabled/not active.
|
|
65
|
+
|
|
66
|
+
These entries are logged with `SECRETS_GATEWAY_AUTH_SURFACE` and include the reason used by the
|
|
67
|
+
active-surface policy, so you can see why a credential was treated as active or inactive.
|
|
68
|
+
|
|
69
|
+
## Onboarding reference preflight
|
|
70
|
+
|
|
71
|
+
When onboarding runs in interactive mode and you choose SecretRef storage, QuantumClaw runs preflight validation before saving:
|
|
72
|
+
|
|
73
|
+
- Env refs: validates env var name and confirms a non-empty value is visible during setup.
|
|
74
|
+
- Provider refs (`file` or `exec`): validates provider selection, resolves `id`, and checks resolved value type.
|
|
75
|
+
- Quickstart reuse path: when `gateway.auth.token` is already a SecretRef, onboarding resolves it before probe/dashboard bootstrap (for `env`, `file`, and `exec` refs) using the same fail-fast gate.
|
|
76
|
+
|
|
77
|
+
If validation fails, onboarding shows the error and lets you retry.
|
|
78
|
+
|
|
79
|
+
## SecretRef contract
|
|
80
|
+
|
|
81
|
+
Use one object shape everywhere:
|
|
82
|
+
|
|
83
|
+
```json5
|
|
84
|
+
{ source: "env" | "file" | "exec", provider: "default", id: "..." }
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
### `source: "env"`
|
|
88
|
+
|
|
89
|
+
```json5
|
|
90
|
+
{ source: "env", provider: "default", id: "OPENAI_API_KEY" }
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
Validation:
|
|
94
|
+
|
|
95
|
+
- `provider` must match `^[a-z][a-z0-9_-]{0,63}$`
|
|
96
|
+
- `id` must match `^[A-Z][A-Z0-9_]{0,127}$`
|
|
97
|
+
|
|
98
|
+
### `source: "file"`
|
|
99
|
+
|
|
100
|
+
```json5
|
|
101
|
+
{ source: "file", provider: "filemain", id: "/providers/openai/apiKey" }
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
Validation:
|
|
105
|
+
|
|
106
|
+
- `provider` must match `^[a-z][a-z0-9_-]{0,63}$`
|
|
107
|
+
- `id` must be an absolute JSON pointer (`/...`)
|
|
108
|
+
- RFC6901 escaping in segments: `~` => `~0`, `/` => `~1`
|
|
109
|
+
|
|
110
|
+
### `source: "exec"`
|
|
111
|
+
|
|
112
|
+
```json5
|
|
113
|
+
{ source: "exec", provider: "vault", id: "providers/openai/apiKey" }
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
Validation:
|
|
117
|
+
|
|
118
|
+
- `provider` must match `^[a-z][a-z0-9_-]{0,63}$`
|
|
119
|
+
- `id` must match `^[A-Za-z0-9][A-Za-z0-9._:/-]{0,255}$`
|
|
120
|
+
- `id` must not contain `.` or `..` as slash-delimited path segments (for example `a/../b` is rejected)
|
|
121
|
+
|
|
122
|
+
## Provider config
|
|
123
|
+
|
|
124
|
+
Define providers under `secrets.providers`:
|
|
125
|
+
|
|
126
|
+
```json5
|
|
127
|
+
{
|
|
128
|
+
secrets: {
|
|
129
|
+
providers: {
|
|
130
|
+
default: { source: "env" },
|
|
131
|
+
filemain: {
|
|
132
|
+
source: "file",
|
|
133
|
+
path: "~/.quantumclaw/secrets.json",
|
|
134
|
+
mode: "json", // or "singleValue"
|
|
135
|
+
},
|
|
136
|
+
vault: {
|
|
137
|
+
source: "exec",
|
|
138
|
+
command: "/usr/local/bin/quantumclaw-vault-resolver",
|
|
139
|
+
args: ["--profile", "prod"],
|
|
140
|
+
passEnv: ["PATH", "VAULT_ADDR"],
|
|
141
|
+
jsonOnly: true,
|
|
142
|
+
},
|
|
143
|
+
},
|
|
144
|
+
defaults: {
|
|
145
|
+
env: "default",
|
|
146
|
+
file: "filemain",
|
|
147
|
+
exec: "vault",
|
|
148
|
+
},
|
|
149
|
+
resolution: {
|
|
150
|
+
maxProviderConcurrency: 4,
|
|
151
|
+
maxRefsPerProvider: 512,
|
|
152
|
+
maxBatchBytes: 262144,
|
|
153
|
+
},
|
|
154
|
+
},
|
|
155
|
+
}
|
|
156
|
+
```
|
|
157
|
+
|
|
158
|
+
### Env provider
|
|
159
|
+
|
|
160
|
+
- Optional allowlist via `allowlist`.
|
|
161
|
+
- Missing/empty env values fail resolution.
|
|
162
|
+
|
|
163
|
+
### File provider
|
|
164
|
+
|
|
165
|
+
- Reads local file from `path`.
|
|
166
|
+
- `mode: "json"` expects JSON object payload and resolves `id` as pointer.
|
|
167
|
+
- `mode: "singleValue"` expects ref id `"value"` and returns file contents.
|
|
168
|
+
- Path must pass ownership/permission checks.
|
|
169
|
+
- Windows fail-closed note: if ACL verification is unavailable for a path, resolution fails. For trusted paths only, set `allowInsecurePath: true` on that provider to bypass path security checks.
|
|
170
|
+
|
|
171
|
+
### Exec provider
|
|
172
|
+
|
|
173
|
+
- Runs configured absolute binary path, no shell.
|
|
174
|
+
- By default, `command` must point to a regular file (not a symlink).
|
|
175
|
+
- Set `allowSymlinkCommand: true` to allow symlink command paths (for example Homebrew shims). QuantumClaw validates the resolved target path.
|
|
176
|
+
- Pair `allowSymlinkCommand` with `trustedDirs` for package-manager paths (for example `["/opt/homebrew"]`).
|
|
177
|
+
- Supports timeout, no-output timeout, output byte limits, env allowlist, and trusted dirs.
|
|
178
|
+
- Windows fail-closed note: if ACL verification is unavailable for the command path, resolution fails. For trusted paths only, set `allowInsecurePath: true` on that provider to bypass path security checks.
|
|
179
|
+
|
|
180
|
+
Request payload (stdin):
|
|
181
|
+
|
|
182
|
+
```json
|
|
183
|
+
{ "protocolVersion": 1, "provider": "vault", "ids": ["providers/openai/apiKey"] }
|
|
184
|
+
```
|
|
185
|
+
|
|
186
|
+
Response payload (stdout):
|
|
187
|
+
|
|
188
|
+
```jsonc
|
|
189
|
+
{ "protocolVersion": 1, "values": { "providers/openai/apiKey": "<openai-api-key>" } } // pragma: allowlist secret
|
|
190
|
+
```
|
|
191
|
+
|
|
192
|
+
Optional per-id errors:
|
|
193
|
+
|
|
194
|
+
```json
|
|
195
|
+
{
|
|
196
|
+
"protocolVersion": 1,
|
|
197
|
+
"values": {},
|
|
198
|
+
"errors": { "providers/openai/apiKey": { "message": "not found" } }
|
|
199
|
+
}
|
|
200
|
+
```
|
|
201
|
+
|
|
202
|
+
## Exec integration examples
|
|
203
|
+
|
|
204
|
+
### 1Password CLI
|
|
205
|
+
|
|
206
|
+
```json5
|
|
207
|
+
{
|
|
208
|
+
secrets: {
|
|
209
|
+
providers: {
|
|
210
|
+
onepassword_openai: {
|
|
211
|
+
source: "exec",
|
|
212
|
+
command: "/opt/homebrew/bin/op",
|
|
213
|
+
allowSymlinkCommand: true, // required for Homebrew symlinked binaries
|
|
214
|
+
trustedDirs: ["/opt/homebrew"],
|
|
215
|
+
args: ["read", "op://Personal/QuantumClaw QA API Key/password"],
|
|
216
|
+
passEnv: ["HOME"],
|
|
217
|
+
jsonOnly: false,
|
|
218
|
+
},
|
|
219
|
+
},
|
|
220
|
+
},
|
|
221
|
+
models: {
|
|
222
|
+
providers: {
|
|
223
|
+
openai: {
|
|
224
|
+
baseUrl: "https://api.openai.com/v1",
|
|
225
|
+
models: [{ id: "gpt-5", name: "gpt-5" }],
|
|
226
|
+
apiKey: { source: "exec", provider: "onepassword_openai", id: "value" },
|
|
227
|
+
},
|
|
228
|
+
},
|
|
229
|
+
},
|
|
230
|
+
}
|
|
231
|
+
```
|
|
232
|
+
|
|
233
|
+
### HashiCorp Vault CLI
|
|
234
|
+
|
|
235
|
+
```json5
|
|
236
|
+
{
|
|
237
|
+
secrets: {
|
|
238
|
+
providers: {
|
|
239
|
+
vault_openai: {
|
|
240
|
+
source: "exec",
|
|
241
|
+
command: "/opt/homebrew/bin/vault",
|
|
242
|
+
allowSymlinkCommand: true, // required for Homebrew symlinked binaries
|
|
243
|
+
trustedDirs: ["/opt/homebrew"],
|
|
244
|
+
args: ["kv", "get", "-field=OPENAI_API_KEY", "secret/quantumclaw"],
|
|
245
|
+
passEnv: ["VAULT_ADDR", "VAULT_TOKEN"],
|
|
246
|
+
jsonOnly: false,
|
|
247
|
+
},
|
|
248
|
+
},
|
|
249
|
+
},
|
|
250
|
+
models: {
|
|
251
|
+
providers: {
|
|
252
|
+
openai: {
|
|
253
|
+
baseUrl: "https://api.openai.com/v1",
|
|
254
|
+
models: [{ id: "gpt-5", name: "gpt-5" }],
|
|
255
|
+
apiKey: { source: "exec", provider: "vault_openai", id: "value" },
|
|
256
|
+
},
|
|
257
|
+
},
|
|
258
|
+
},
|
|
259
|
+
}
|
|
260
|
+
```
|
|
261
|
+
|
|
262
|
+
### `sops`
|
|
263
|
+
|
|
264
|
+
```json5
|
|
265
|
+
{
|
|
266
|
+
secrets: {
|
|
267
|
+
providers: {
|
|
268
|
+
sops_openai: {
|
|
269
|
+
source: "exec",
|
|
270
|
+
command: "/opt/homebrew/bin/sops",
|
|
271
|
+
allowSymlinkCommand: true, // required for Homebrew symlinked binaries
|
|
272
|
+
trustedDirs: ["/opt/homebrew"],
|
|
273
|
+
args: ["-d", "--extract", '["providers"]["openai"]["apiKey"]', "/path/to/secrets.enc.json"],
|
|
274
|
+
passEnv: ["SOPS_AGE_KEY_FILE"],
|
|
275
|
+
jsonOnly: false,
|
|
276
|
+
},
|
|
277
|
+
},
|
|
278
|
+
},
|
|
279
|
+
models: {
|
|
280
|
+
providers: {
|
|
281
|
+
openai: {
|
|
282
|
+
baseUrl: "https://api.openai.com/v1",
|
|
283
|
+
models: [{ id: "gpt-5", name: "gpt-5" }],
|
|
284
|
+
apiKey: { source: "exec", provider: "sops_openai", id: "value" },
|
|
285
|
+
},
|
|
286
|
+
},
|
|
287
|
+
},
|
|
288
|
+
}
|
|
289
|
+
```
|
|
290
|
+
|
|
291
|
+
## Sandbox SSH auth material
|
|
292
|
+
|
|
293
|
+
The core `ssh` sandbox backend also supports SecretRefs for SSH auth material:
|
|
294
|
+
|
|
295
|
+
```json5
|
|
296
|
+
{
|
|
297
|
+
agents: {
|
|
298
|
+
defaults: {
|
|
299
|
+
sandbox: {
|
|
300
|
+
mode: "all",
|
|
301
|
+
backend: "ssh",
|
|
302
|
+
ssh: {
|
|
303
|
+
target: "user@gateway-host:22",
|
|
304
|
+
identityData: { source: "env", provider: "default", id: "SSH_IDENTITY" },
|
|
305
|
+
certificateData: { source: "env", provider: "default", id: "SSH_CERTIFICATE" },
|
|
306
|
+
knownHostsData: { source: "env", provider: "default", id: "SSH_KNOWN_HOSTS" },
|
|
307
|
+
},
|
|
308
|
+
},
|
|
309
|
+
},
|
|
310
|
+
},
|
|
311
|
+
}
|
|
312
|
+
```
|
|
313
|
+
|
|
314
|
+
Runtime behavior:
|
|
315
|
+
|
|
316
|
+
- QuantumClaw resolves these refs during sandbox activation, not lazily during each SSH call.
|
|
317
|
+
- Resolved values are written to temp files with restrictive permissions and used in generated SSH config.
|
|
318
|
+
- If the effective sandbox backend is not `ssh`, these refs stay inactive and do not block startup.
|
|
319
|
+
|
|
320
|
+
## Supported credential surface
|
|
321
|
+
|
|
322
|
+
Canonical supported and unsupported credentials are listed in:
|
|
323
|
+
|
|
324
|
+
- [SecretRef Credential Surface](/reference/secretref-credential-surface)
|
|
325
|
+
|
|
326
|
+
Runtime-minted or rotating credentials and OAuth refresh material are intentionally excluded from read-only SecretRef resolution.
|
|
327
|
+
|
|
328
|
+
## Required behavior and precedence
|
|
329
|
+
|
|
330
|
+
- Field without a ref: unchanged.
|
|
331
|
+
- Field with a ref: required on active surfaces during activation.
|
|
332
|
+
- If both plaintext and ref are present, ref takes precedence on supported precedence paths.
|
|
333
|
+
|
|
334
|
+
Warning and audit signals:
|
|
335
|
+
|
|
336
|
+
- `SECRETS_REF_OVERRIDES_PLAINTEXT` (runtime warning)
|
|
337
|
+
- `REF_SHADOWED` (audit finding when `auth-profiles.json` credentials take precedence over `quantumclaw.json` refs)
|
|
338
|
+
|
|
339
|
+
Google Chat compatibility behavior:
|
|
340
|
+
|
|
341
|
+
- `serviceAccountRef` takes precedence over plaintext `serviceAccount`.
|
|
342
|
+
- Plaintext value is ignored when sibling ref is set.
|
|
343
|
+
|
|
344
|
+
## Activation triggers
|
|
345
|
+
|
|
346
|
+
Secret activation runs on:
|
|
347
|
+
|
|
348
|
+
- Startup (preflight plus final activation)
|
|
349
|
+
- Config reload hot-apply path
|
|
350
|
+
- Config reload restart-check path
|
|
351
|
+
- Manual reload via `secrets.reload`
|
|
352
|
+
|
|
353
|
+
Activation contract:
|
|
354
|
+
|
|
355
|
+
- Success swaps the snapshot atomically.
|
|
356
|
+
- Startup failure aborts gateway startup.
|
|
357
|
+
- Runtime reload failure keeps the last-known-good snapshot.
|
|
358
|
+
- Providing an explicit per-call channel token to an outbound helper/tool call does not trigger SecretRef activation; activation points remain startup, reload, and explicit `secrets.reload`.
|
|
359
|
+
|
|
360
|
+
## Degraded and recovered signals
|
|
361
|
+
|
|
362
|
+
When reload-time activation fails after a healthy state, QuantumClaw enters degraded secrets state.
|
|
363
|
+
|
|
364
|
+
One-shot system event and log codes:
|
|
365
|
+
|
|
366
|
+
- `SECRETS_RELOADER_DEGRADED`
|
|
367
|
+
- `SECRETS_RELOADER_RECOVERED`
|
|
368
|
+
|
|
369
|
+
Behavior:
|
|
370
|
+
|
|
371
|
+
- Degraded: runtime keeps last-known-good snapshot.
|
|
372
|
+
- Recovered: emitted once after the next successful activation.
|
|
373
|
+
- Repeated failures while already degraded log warnings but do not spam events.
|
|
374
|
+
- Startup fail-fast does not emit degraded events because runtime never became active.
|
|
375
|
+
|
|
376
|
+
## Command-path resolution
|
|
377
|
+
|
|
378
|
+
Command paths can opt into supported SecretRef resolution via gateway snapshot RPC.
|
|
379
|
+
|
|
380
|
+
There are two broad behaviors:
|
|
381
|
+
|
|
382
|
+
- Strict command paths (for example `quantumclaw memory` remote-memory paths and `quantumclaw qr --remote`) read from the active snapshot and fail fast when a required SecretRef is unavailable.
|
|
383
|
+
- Read-only command paths (for example `quantumclaw status`, `quantumclaw status --all`, `quantumclaw channels status`, `quantumclaw channels resolve`, `quantumclaw security audit`, and read-only doctor/config repair flows) also prefer the active snapshot, but degrade instead of aborting when a targeted SecretRef is unavailable in that command path.
|
|
384
|
+
|
|
385
|
+
Read-only behavior:
|
|
386
|
+
|
|
387
|
+
- When the gateway is running, these commands read from the active snapshot first.
|
|
388
|
+
- If gateway resolution is incomplete or the gateway is unavailable, they attempt targeted local fallback for the specific command surface.
|
|
389
|
+
- If a targeted SecretRef is still unavailable, the command continues with degraded read-only output and explicit diagnostics such as “configured but unavailable in this command path”.
|
|
390
|
+
- This degraded behavior is command-local only. It does not weaken runtime startup, reload, or send/auth paths.
|
|
391
|
+
|
|
392
|
+
Other notes:
|
|
393
|
+
|
|
394
|
+
- Snapshot refresh after backend secret rotation is handled by `quantumclaw secrets reload`.
|
|
395
|
+
- Gateway RPC method used by these command paths: `secrets.resolve`.
|
|
396
|
+
|
|
397
|
+
## Audit and configure workflow
|
|
398
|
+
|
|
399
|
+
Default operator flow:
|
|
400
|
+
|
|
401
|
+
```bash
|
|
402
|
+
quantumclaw secrets audit --check
|
|
403
|
+
quantumclaw secrets configure
|
|
404
|
+
quantumclaw secrets audit --check
|
|
405
|
+
```
|
|
406
|
+
|
|
407
|
+
### `secrets audit`
|
|
408
|
+
|
|
409
|
+
Findings include:
|
|
410
|
+
|
|
411
|
+
- plaintext values at rest (`quantumclaw.json`, `auth-profiles.json`, `.env`, and generated `agents/*/agent/models.json`)
|
|
412
|
+
- plaintext sensitive provider header residues in generated `models.json` entries
|
|
413
|
+
- unresolved refs
|
|
414
|
+
- precedence shadowing (`auth-profiles.json` taking priority over `quantumclaw.json` refs)
|
|
415
|
+
- legacy residues (`auth.json`, OAuth reminders)
|
|
416
|
+
|
|
417
|
+
Exec note:
|
|
418
|
+
|
|
419
|
+
- By default, audit skips exec SecretRef resolvability checks to avoid command side effects.
|
|
420
|
+
- Use `quantumclaw secrets audit --allow-exec` to execute exec providers during audit.
|
|
421
|
+
|
|
422
|
+
Header residue note:
|
|
423
|
+
|
|
424
|
+
- Sensitive provider header detection is name-heuristic based (common auth/credential header names and fragments such as `authorization`, `x-api-key`, `token`, `secret`, `password`, and `credential`).
|
|
425
|
+
|
|
426
|
+
### `secrets configure`
|
|
427
|
+
|
|
428
|
+
Interactive helper that:
|
|
429
|
+
|
|
430
|
+
- configures `secrets.providers` first (`env`/`file`/`exec`, add/edit/remove)
|
|
431
|
+
- lets you select supported secret-bearing fields in `quantumclaw.json` plus `auth-profiles.json` for one agent scope
|
|
432
|
+
- can create a new `auth-profiles.json` mapping directly in the target picker
|
|
433
|
+
- captures SecretRef details (`source`, `provider`, `id`)
|
|
434
|
+
- runs preflight resolution
|
|
435
|
+
- can apply immediately
|
|
436
|
+
|
|
437
|
+
Exec note:
|
|
438
|
+
|
|
439
|
+
- Preflight skips exec SecretRef checks unless `--allow-exec` is set.
|
|
440
|
+
- If you apply directly from `configure --apply` and the plan includes exec refs/providers, keep `--allow-exec` set for the apply step too.
|
|
441
|
+
|
|
442
|
+
Helpful modes:
|
|
443
|
+
|
|
444
|
+
- `quantumclaw secrets configure --providers-only`
|
|
445
|
+
- `quantumclaw secrets configure --skip-provider-setup`
|
|
446
|
+
- `quantumclaw secrets configure --agent <id>`
|
|
447
|
+
|
|
448
|
+
`configure` apply defaults:
|
|
449
|
+
|
|
450
|
+
- scrub matching static credentials from `auth-profiles.json` for targeted providers
|
|
451
|
+
- scrub legacy static `api_key` entries from `auth.json`
|
|
452
|
+
- scrub matching known secret lines from `<config-dir>/.env`
|
|
453
|
+
|
|
454
|
+
### `secrets apply`
|
|
455
|
+
|
|
456
|
+
Apply a saved plan:
|
|
457
|
+
|
|
458
|
+
```bash
|
|
459
|
+
quantumclaw secrets apply --from /tmp/quantumclaw-secrets-plan.json
|
|
460
|
+
quantumclaw secrets apply --from /tmp/quantumclaw-secrets-plan.json --allow-exec
|
|
461
|
+
quantumclaw secrets apply --from /tmp/quantumclaw-secrets-plan.json --dry-run
|
|
462
|
+
quantumclaw secrets apply --from /tmp/quantumclaw-secrets-plan.json --dry-run --allow-exec
|
|
463
|
+
```
|
|
464
|
+
|
|
465
|
+
Exec note:
|
|
466
|
+
|
|
467
|
+
- dry-run skips exec checks unless `--allow-exec` is set.
|
|
468
|
+
- write mode rejects plans containing exec SecretRefs/providers unless `--allow-exec` is set.
|
|
469
|
+
|
|
470
|
+
For strict target/path contract details and exact rejection rules, see:
|
|
471
|
+
|
|
472
|
+
- [Secrets Apply Plan Contract](/gateway/secrets-plan-contract)
|
|
473
|
+
|
|
474
|
+
## One-way safety policy
|
|
475
|
+
|
|
476
|
+
QuantumClaw intentionally does not write rollback backups containing historical plaintext secret values.
|
|
477
|
+
|
|
478
|
+
Safety model:
|
|
479
|
+
|
|
480
|
+
- preflight must succeed before write mode
|
|
481
|
+
- runtime activation is validated before commit
|
|
482
|
+
- apply updates files using atomic file replacement and best-effort restore on failure
|
|
483
|
+
|
|
484
|
+
## Legacy auth compatibility notes
|
|
485
|
+
|
|
486
|
+
For static credentials, runtime no longer depends on plaintext legacy auth storage.
|
|
487
|
+
|
|
488
|
+
- Runtime credential source is the resolved in-memory snapshot.
|
|
489
|
+
- Legacy static `api_key` entries are scrubbed when discovered.
|
|
490
|
+
- OAuth-related compatibility behavior remains separate.
|
|
491
|
+
|
|
492
|
+
## Web UI note
|
|
493
|
+
|
|
494
|
+
Some SecretInput unions are easier to configure in raw editor mode than in form mode.
|
|
495
|
+
|
|
496
|
+
## Related docs
|
|
497
|
+
|
|
498
|
+
- CLI commands: [secrets](/cli/secrets)
|
|
499
|
+
- Plan contract details: [Secrets Apply Plan Contract](/gateway/secrets-plan-contract)
|
|
500
|
+
- Credential surface: [SecretRef Credential Surface](/reference/secretref-credential-surface)
|
|
501
|
+
- Auth setup: [Authentication](/gateway/authentication)
|
|
502
|
+
- Security posture: [Security](/gateway/security)
|
|
503
|
+
- Environment precedence: [Environment Variables](/help/environment)
|