@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,164 @@
|
|
|
1
|
+
---
|
|
2
|
+
read_when: Connecting the macOS app to a remote gateway over SSH
|
|
3
|
+
summary: QuantumClaw.app 连接远程 Gateway 网关的 SSH 隧道设置
|
|
4
|
+
title: 远程 Gateway 网关设置
|
|
5
|
+
x-i18n:
|
|
6
|
+
generated_at: "2026-02-03T07:48:37Z"
|
|
7
|
+
model: claude-opus-4-5
|
|
8
|
+
provider: pi
|
|
9
|
+
source_hash: b1ae266a7cb4911b82ae3ec6cb98b1b57aca592aeb1dc8b74bbce9b0ea9dd1d1
|
|
10
|
+
source_path: gateway/remote-gateway-readme.md
|
|
11
|
+
workflow: 15
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
# 使用远程 Gateway 网关运行 QuantumClaw.app
|
|
15
|
+
|
|
16
|
+
QuantumClaw.app 使用 SSH 隧道连接到远程 Gateway 网关。本指南向你展示如何设置。
|
|
17
|
+
|
|
18
|
+
## 概述
|
|
19
|
+
|
|
20
|
+
```
|
|
21
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
22
|
+
│ Client Machine │
|
|
23
|
+
│ │
|
|
24
|
+
│ QuantumClaw.app ──► ws://127.0.0.1:18789 (local port) │
|
|
25
|
+
│ │ │
|
|
26
|
+
│ ▼ │
|
|
27
|
+
│ SSH Tunnel ────────────────────────────────────────────────│
|
|
28
|
+
│ │ │
|
|
29
|
+
└─────────────────────┼──────────────────────────────────────┘
|
|
30
|
+
│
|
|
31
|
+
▼
|
|
32
|
+
┌─────────────────────────────────────────────────────────────┐
|
|
33
|
+
│ Remote Machine │
|
|
34
|
+
│ │
|
|
35
|
+
│ Gateway WebSocket ──► ws://127.0.0.1:18789 ──► │
|
|
36
|
+
│ │
|
|
37
|
+
└─────────────────────────────────────────────────────────────┘
|
|
38
|
+
```
|
|
39
|
+
|
|
40
|
+
## 快速设置
|
|
41
|
+
|
|
42
|
+
### 步骤 1:添加 SSH 配置
|
|
43
|
+
|
|
44
|
+
编辑 `~/.ssh/config` 并添加:
|
|
45
|
+
|
|
46
|
+
```ssh
|
|
47
|
+
Host remote-gateway
|
|
48
|
+
HostName <REMOTE_IP> # e.g., 172.27.187.184
|
|
49
|
+
User <REMOTE_USER> # e.g., jefferson
|
|
50
|
+
LocalForward 18789 127.0.0.1:18789
|
|
51
|
+
IdentityFile ~/.ssh/id_rsa
|
|
52
|
+
```
|
|
53
|
+
|
|
54
|
+
将 `<REMOTE_IP>` 和 `<REMOTE_USER>` 替换为你的值。
|
|
55
|
+
|
|
56
|
+
### 步骤 2:复制 SSH 密钥
|
|
57
|
+
|
|
58
|
+
将你的公钥复制到远程机器(输入一次密码):
|
|
59
|
+
|
|
60
|
+
```bash
|
|
61
|
+
ssh-copy-id -i ~/.ssh/id_rsa <REMOTE_USER>@<REMOTE_IP>
|
|
62
|
+
```
|
|
63
|
+
|
|
64
|
+
### 步骤 3:设置 Gateway 网关令牌
|
|
65
|
+
|
|
66
|
+
```bash
|
|
67
|
+
launchctl setenv QUANTUMCLAW_GATEWAY_TOKEN "<your-token>"
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
### 步骤 4:启动 SSH 隧道
|
|
71
|
+
|
|
72
|
+
```bash
|
|
73
|
+
ssh -N remote-gateway &
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
### 步骤 5:重启 QuantumClaw.app
|
|
77
|
+
|
|
78
|
+
```bash
|
|
79
|
+
# Quit QuantumClaw.app (⌘Q), then reopen:
|
|
80
|
+
open /path/to/QuantumClaw.app
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
应用现在将通过 SSH 隧道连接到远程 Gateway 网关。
|
|
84
|
+
|
|
85
|
+
---
|
|
86
|
+
|
|
87
|
+
## 登录时自动启动隧道
|
|
88
|
+
|
|
89
|
+
要在登录时自动启动 SSH 隧道,请创建一个 Launch Agent。
|
|
90
|
+
|
|
91
|
+
### 创建 PLIST 文件
|
|
92
|
+
|
|
93
|
+
将此保存为 `~/Library/LaunchAgents/bot.molt.ssh-tunnel.plist`:
|
|
94
|
+
|
|
95
|
+
```xml
|
|
96
|
+
<?xml version="1.0" encoding="UTF-8"?>
|
|
97
|
+
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
|
|
98
|
+
<plist version="1.0">
|
|
99
|
+
<dict>
|
|
100
|
+
<key>Label</key>
|
|
101
|
+
<string>bot.molt.ssh-tunnel</string>
|
|
102
|
+
<key>ProgramArguments</key>
|
|
103
|
+
<array>
|
|
104
|
+
<string>/usr/bin/ssh</string>
|
|
105
|
+
<string>-N</string>
|
|
106
|
+
<string>remote-gateway</string>
|
|
107
|
+
</array>
|
|
108
|
+
<key>KeepAlive</key>
|
|
109
|
+
<true/>
|
|
110
|
+
<key>RunAtLoad</key>
|
|
111
|
+
<true/>
|
|
112
|
+
</dict>
|
|
113
|
+
</plist>
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
### 加载 Launch Agent
|
|
117
|
+
|
|
118
|
+
```bash
|
|
119
|
+
launchctl bootstrap gui/$UID ~/Library/LaunchAgents/bot.molt.ssh-tunnel.plist
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
隧道现在将:
|
|
123
|
+
|
|
124
|
+
- 登录时自动启动
|
|
125
|
+
- 崩溃时重新启动
|
|
126
|
+
- 在后台持续运行
|
|
127
|
+
|
|
128
|
+
旧版注意事项:如果存在任何遗留的 `com.quantumclaw.ssh-tunnel` LaunchAgent,请将其删除。
|
|
129
|
+
|
|
130
|
+
---
|
|
131
|
+
|
|
132
|
+
## 故障排除
|
|
133
|
+
|
|
134
|
+
**检查隧道是否正在运行:**
|
|
135
|
+
|
|
136
|
+
```bash
|
|
137
|
+
ps aux | grep "ssh -N remote-gateway" | grep -v grep
|
|
138
|
+
lsof -i :18789
|
|
139
|
+
```
|
|
140
|
+
|
|
141
|
+
**重启隧道:**
|
|
142
|
+
|
|
143
|
+
```bash
|
|
144
|
+
launchctl kickstart -k gui/$UID/bot.molt.ssh-tunnel
|
|
145
|
+
```
|
|
146
|
+
|
|
147
|
+
**停止隧道:**
|
|
148
|
+
|
|
149
|
+
```bash
|
|
150
|
+
launchctl bootout gui/$UID/bot.molt.ssh-tunnel
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
---
|
|
154
|
+
|
|
155
|
+
## 工作原理
|
|
156
|
+
|
|
157
|
+
| 组件 | 功能 |
|
|
158
|
+
| ------------------------------------ | ------------------------------------- |
|
|
159
|
+
| `LocalForward 18789 127.0.0.1:18789` | 将本地端口 18789 转发到远程端口 18789 |
|
|
160
|
+
| `ssh -N` | SSH 不执行远程命令(仅端口转发) |
|
|
161
|
+
| `KeepAlive` | 隧道崩溃时自动重启 |
|
|
162
|
+
| `RunAtLoad` | 代理加载时启动隧道 |
|
|
163
|
+
|
|
164
|
+
QuantumClaw.app 连接到你的客户端机器上的 `ws://127.0.0.1:18789`。SSH 隧道将该连接转发到运行 Gateway 网关的远程机器的端口 18789。
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
---
|
|
2
|
+
read_when:
|
|
3
|
+
- 运行或排查远程 Gateway 网关设置问题
|
|
4
|
+
summary: 使用 SSH 隧道(Gateway WS)和 tailnet 进行远程访问
|
|
5
|
+
title: 远程访问
|
|
6
|
+
x-i18n:
|
|
7
|
+
generated_at: "2026-02-03T07:48:40Z"
|
|
8
|
+
model: claude-opus-4-5
|
|
9
|
+
provider: pi
|
|
10
|
+
source_hash: 7e00bd2e048dfbd829913bef0f40a791b8d8c3e2f8a115fc0a13b03f136ebc93
|
|
11
|
+
source_path: gateway/remote.md
|
|
12
|
+
workflow: 15
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
# 远程访问(SSH、隧道和 tailnet)
|
|
16
|
+
|
|
17
|
+
本仓库通过在专用主机(桌面/服务器)上运行单个 Gateway 网关(主节点)并让客户端连接到它来支持"SSH 远程"。
|
|
18
|
+
|
|
19
|
+
- 对于**操作员(你/macOS 应用)**:SSH 隧道是通用的回退方案。
|
|
20
|
+
- 对于**节点(iOS/Android 和未来的设备)**:连接到 Gateway **WebSocket**(LAN/tailnet 或根据需要通过 SSH 隧道)。
|
|
21
|
+
|
|
22
|
+
## 核心理念
|
|
23
|
+
|
|
24
|
+
- Gateway WebSocket 绑定到你配置端口的 **loopback**(默认为 18789)。
|
|
25
|
+
- 对于远程使用,你通过 SSH 转发该 loopback 端口(或使用 tailnet/VPN 减少隧道需求)。
|
|
26
|
+
|
|
27
|
+
## 常见的 VPN/tailnet 设置(智能体所在位置)
|
|
28
|
+
|
|
29
|
+
将 **Gateway 网关主机**视为"智能体所在的位置"。它拥有会话、身份验证配置文件、渠道和状态。
|
|
30
|
+
你的笔记本电脑/桌面(和节点)连接到该主机。
|
|
31
|
+
|
|
32
|
+
### 1) tailnet 中始终在线的 Gateway 网关(VPS 或家庭服务器)
|
|
33
|
+
|
|
34
|
+
在持久主机上运行 Gateway 网关,并通过 **Tailscale** 或 SSH 访问它。
|
|
35
|
+
|
|
36
|
+
- **最佳用户体验:** 保持 `gateway.bind: "loopback"` 并使用 **Tailscale Serve** 作为控制 UI。
|
|
37
|
+
- **回退方案:** 保持 loopback + 从任何需要访问的机器建立 SSH 隧道。
|
|
38
|
+
- **示例:** [exe.dev](/install/exe-dev)(简易 VM)或 [Hetzner](/install/hetzner)(生产 VPS)。
|
|
39
|
+
|
|
40
|
+
当你的笔记本电脑经常休眠但你希望智能体始终在线时,这是理想的选择。
|
|
41
|
+
|
|
42
|
+
### 2) 家庭桌面运行 Gateway 网关,笔记本电脑作为远程控制
|
|
43
|
+
|
|
44
|
+
笔记本电脑**不**运行智能体。它远程连接:
|
|
45
|
+
|
|
46
|
+
- 使用 macOS 应用的 **Remote over SSH** 模式(设置 → 通用 → "QuantumClaw runs")。
|
|
47
|
+
- 应用打开并管理隧道,因此 WebChat + 健康检查"直接工作"。
|
|
48
|
+
|
|
49
|
+
操作手册:[macOS 远程访问](/platforms/mac/remote)。
|
|
50
|
+
|
|
51
|
+
### 3) 笔记本电脑运行 Gateway 网关,从其他机器远程访问
|
|
52
|
+
|
|
53
|
+
保持 Gateway 网关在本地但安全地暴露它:
|
|
54
|
+
|
|
55
|
+
- 从其他机器到笔记本电脑的 SSH 隧道,或
|
|
56
|
+
- Tailscale Serve 控制 UI 并保持 Gateway 网关仅 loopback。
|
|
57
|
+
|
|
58
|
+
指南:[Tailscale](/gateway/tailscale) 和 [Web 概览](/web)。
|
|
59
|
+
|
|
60
|
+
## 命令流(什么在哪里运行)
|
|
61
|
+
|
|
62
|
+
一个 Gateway 网关服务拥有状态 + 渠道。节点是外围设备。
|
|
63
|
+
|
|
64
|
+
流程示例(Telegram → 节点):
|
|
65
|
+
|
|
66
|
+
- Telegram 消息到达 **Gateway 网关**。
|
|
67
|
+
- Gateway 网关运行**智能体**并决定是否调用节点工具。
|
|
68
|
+
- Gateway 网关通过 Gateway WebSocket 调用**节点**(`node.*` RPC)。
|
|
69
|
+
- 节点返回结果;Gateway 网关回复到 Telegram。
|
|
70
|
+
|
|
71
|
+
说明:
|
|
72
|
+
|
|
73
|
+
- **节点不运行 Gateway 网关服务。** 除非你有意运行隔离的配置文件,否则每台主机只应运行一个 Gateway 网关(参见[多 Gateway 网关](/gateway/multiple-gateways))。
|
|
74
|
+
- macOS 应用的"节点模式"只是通过 Gateway WebSocket 的节点客户端。
|
|
75
|
+
|
|
76
|
+
## SSH 隧道(CLI + 工具)
|
|
77
|
+
|
|
78
|
+
创建到远程 Gateway WS 的本地隧道:
|
|
79
|
+
|
|
80
|
+
```bash
|
|
81
|
+
ssh -N -L 18789:127.0.0.1:18789 user@host
|
|
82
|
+
```
|
|
83
|
+
|
|
84
|
+
隧道建立后:
|
|
85
|
+
|
|
86
|
+
- `quantumclaw health` 和 `quantumclaw status --deep` 现在通过 `ws://127.0.0.1:18789` 访问远程 Gateway 网关。
|
|
87
|
+
- `quantumclaw gateway {status,health,send,agent,call}` 在需要时也可以通过 `--url` 指定转发的 URL。
|
|
88
|
+
|
|
89
|
+
注意:将 `18789` 替换为你配置的 `gateway.port`(或 `--port`/`QUANTUMCLAW_GATEWAY_PORT`)。
|
|
90
|
+
|
|
91
|
+
## CLI 远程默认值
|
|
92
|
+
|
|
93
|
+
你可以持久化远程目标,以便 CLI 命令默认使用它:
|
|
94
|
+
|
|
95
|
+
```json5
|
|
96
|
+
{
|
|
97
|
+
gateway: {
|
|
98
|
+
mode: "remote",
|
|
99
|
+
remote: {
|
|
100
|
+
url: "ws://127.0.0.1:18789",
|
|
101
|
+
token: "your-token",
|
|
102
|
+
},
|
|
103
|
+
},
|
|
104
|
+
}
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
当 Gateway 网关仅限 loopback 时,保持 URL 为 `ws://127.0.0.1:18789` 并先打开 SSH 隧道。
|
|
108
|
+
|
|
109
|
+
## 通过 SSH 的聊天 UI
|
|
110
|
+
|
|
111
|
+
WebChat 不再使用单独的 HTTP 端口。SwiftUI 聊天 UI 直接连接到 Gateway WebSocket。
|
|
112
|
+
|
|
113
|
+
- 通过 SSH 转发 `18789`(见上文),然后让客户端连接到 `ws://127.0.0.1:18789`。
|
|
114
|
+
- 在 macOS 上,优先使用应用的"Remote over SSH"模式,它会自动管理隧道。
|
|
115
|
+
|
|
116
|
+
## macOS 应用"Remote over SSH"
|
|
117
|
+
|
|
118
|
+
macOS 菜单栏应用可以端到端驱动相同的设置(远程状态检查、WebChat 和语音唤醒转发)。
|
|
119
|
+
|
|
120
|
+
操作手册:[macOS 远程访问](/platforms/mac/remote)。
|
|
121
|
+
|
|
122
|
+
## 安全规则(远程/VPN)
|
|
123
|
+
|
|
124
|
+
简短版本:**保持 Gateway 网关仅 loopback**,除非你确定需要绑定。
|
|
125
|
+
|
|
126
|
+
- **Loopback + SSH/Tailscale Serve** 是最安全的默认设置(无公开暴露)。
|
|
127
|
+
- **非 loopback 绑定**(`lan`/`tailnet`/`custom`,或当 loopback 不可用时的 `auto`)必须使用身份验证令牌/密码。
|
|
128
|
+
- `gateway.remote.token` **仅**用于远程 CLI 调用——它**不**启用本地身份验证。
|
|
129
|
+
- `gateway.remote.tlsFingerprint` 在使用 `wss://` 时固定远程 TLS 证书。
|
|
130
|
+
- 当 `gateway.auth.allowTailscale: true` 时,**Tailscale Serve** 可以通过身份标头进行身份验证。如果你想使用令牌/密码,请将其设置为 `false`。
|
|
131
|
+
- 将浏览器控制视为操作员访问:仅限 tailnet + 有意的节点配对。
|
|
132
|
+
|
|
133
|
+
深入了解:[安全](/gateway/security)。
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
---
|
|
2
|
+
read_when: You hit 'sandbox jail' or see a tool/elevated refusal and want the exact config key to change.
|
|
3
|
+
status: active
|
|
4
|
+
summary: 工具被阻止的原因:沙箱运行时、工具允许/拒绝策略和提权 exec 限制
|
|
5
|
+
title: 沙箱 vs 工具策略 vs 提权
|
|
6
|
+
x-i18n:
|
|
7
|
+
generated_at: "2026-02-03T07:48:55Z"
|
|
8
|
+
model: claude-opus-4-5
|
|
9
|
+
provider: pi
|
|
10
|
+
source_hash: 863ea5e6d137dfb61f12bd686b9557d6df1fd0c13ba5f15861bf72248bc975f1
|
|
11
|
+
source_path: gateway/sandbox-vs-tool-policy-vs-elevated.md
|
|
12
|
+
workflow: 15
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
# 沙箱 vs 工具策略 vs 提权
|
|
16
|
+
|
|
17
|
+
QuantumClaw 有三个相关(但不同)的控制:
|
|
18
|
+
|
|
19
|
+
1. **沙箱**(`agents.defaults.sandbox.*` / `agents.list[].sandbox.*`)决定**工具在哪里运行**(Docker vs 主机)。
|
|
20
|
+
2. **工具策略**(`tools.*`、`tools.sandbox.tools.*`、`agents.list[].tools.*`)决定**哪些工具可用/允许**。
|
|
21
|
+
3. **提权**(`tools.elevated.*`、`agents.list[].tools.elevated.*`)是一个**仅限 exec 的逃逸通道**,允许在沙箱隔离时在主机上运行。
|
|
22
|
+
|
|
23
|
+
## 快速调试
|
|
24
|
+
|
|
25
|
+
使用检查器查看 QuantumClaw *实际*在做什么:
|
|
26
|
+
|
|
27
|
+
```bash
|
|
28
|
+
quantumclaw sandbox explain
|
|
29
|
+
quantumclaw sandbox explain --session agent:main:main
|
|
30
|
+
quantumclaw sandbox explain --agent work
|
|
31
|
+
quantumclaw sandbox explain --json
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
它会打印:
|
|
35
|
+
|
|
36
|
+
- 生效的沙箱模式/范围/工作区访问
|
|
37
|
+
- 会话当前是否被沙箱隔离(主 vs 非主)
|
|
38
|
+
- 生效的沙箱工具允许/拒绝(以及它来自智能体/全局/默认哪里)
|
|
39
|
+
- 提权限制和修复键路径
|
|
40
|
+
|
|
41
|
+
## 沙箱:工具在哪里运行
|
|
42
|
+
|
|
43
|
+
沙箱隔离由 `agents.defaults.sandbox.mode` 控制:
|
|
44
|
+
|
|
45
|
+
- `"off"`:所有内容在主机上运行。
|
|
46
|
+
- `"non-main"`:仅非主会话被沙箱隔离(群组/渠道的常见"意外")。
|
|
47
|
+
- `"all"`:所有内容都被沙箱隔离。
|
|
48
|
+
|
|
49
|
+
参见[沙箱隔离](/gateway/sandboxing)了解完整矩阵(范围、工作区挂载、镜像)。
|
|
50
|
+
|
|
51
|
+
### 绑定挂载(安全快速检查)
|
|
52
|
+
|
|
53
|
+
- `docker.binds` *穿透*沙箱文件系统:你挂载的任何内容在容器内以你设置的模式(`:ro` 或 `:rw`)可见。
|
|
54
|
+
- 如果省略模式,默认为读写;对于源代码/密钥优先使用 `:ro`。
|
|
55
|
+
- `scope: "shared"` 忽略每个智能体的绑定(仅全局绑定适用)。
|
|
56
|
+
- 绑定 `/var/run/docker.sock` 实际上将主机控制权交给沙箱;只有在有意为之时才这样做。
|
|
57
|
+
- 工作区访问(`workspaceAccess: "ro"`/`"rw"`)独立于绑定模式。
|
|
58
|
+
|
|
59
|
+
## 工具策略:哪些工具存在/可调用
|
|
60
|
+
|
|
61
|
+
两个层次很重要:
|
|
62
|
+
|
|
63
|
+
- **工具配置文件**:`tools.profile` 和 `agents.list[].tools.profile`(基础允许列表)
|
|
64
|
+
- **提供商工具配置文件**:`tools.byProvider[provider].profile` 和 `agents.list[].tools.byProvider[provider].profile`
|
|
65
|
+
- **全局/每个智能体工具策略**:`tools.allow`/`tools.deny` 和 `agents.list[].tools.allow`/`agents.list[].tools.deny`
|
|
66
|
+
- **提供商工具策略**:`tools.byProvider[provider].allow/deny` 和 `agents.list[].tools.byProvider[provider].allow/deny`
|
|
67
|
+
- **沙箱工具策略**(仅在沙箱隔离时适用):`tools.sandbox.tools.allow`/`tools.sandbox.tools.deny` 和 `agents.list[].tools.sandbox.tools.*`
|
|
68
|
+
|
|
69
|
+
经验法则:
|
|
70
|
+
|
|
71
|
+
- `deny` 始终优先。
|
|
72
|
+
- 如果 `allow` 非空,其他所有内容都被视为阻止。
|
|
73
|
+
- 工具策略是硬性停止:`/exec` 无法覆盖被拒绝的 `exec` 工具。
|
|
74
|
+
- `/exec` 仅为授权发送者更改会话默认值;它不授予工具访问权限。
|
|
75
|
+
提供商工具键接受 `provider`(例如 `google-antigravity`)或 `provider/model`(例如 `openai/gpt-5.2`)。
|
|
76
|
+
|
|
77
|
+
### 工具组(简写)
|
|
78
|
+
|
|
79
|
+
工具策略(全局、智能体、沙箱)支持 `group:*` 条目,它们会展开为多个工具:
|
|
80
|
+
|
|
81
|
+
```json5
|
|
82
|
+
{
|
|
83
|
+
tools: {
|
|
84
|
+
sandbox: {
|
|
85
|
+
tools: {
|
|
86
|
+
allow: ["group:runtime", "group:fs", "group:sessions", "group:memory"],
|
|
87
|
+
},
|
|
88
|
+
},
|
|
89
|
+
},
|
|
90
|
+
}
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
可用的组:
|
|
94
|
+
|
|
95
|
+
- `group:runtime`:`exec`、`bash`、`process`
|
|
96
|
+
- `group:fs`:`read`、`write`、`edit`、`apply_patch`
|
|
97
|
+
- `group:sessions`:`sessions_list`、`sessions_history`、`sessions_send`、`sessions_spawn`、`session_status`
|
|
98
|
+
- `group:memory`:`memory_search`、`memory_get`
|
|
99
|
+
- `group:ui`:`browser`、`canvas`
|
|
100
|
+
- `group:automation`:`cron`、`gateway`
|
|
101
|
+
- `group:messaging`:`message`
|
|
102
|
+
- `group:nodes`:`nodes`
|
|
103
|
+
- `group:quantumclaw`:所有内置 QuantumClaw 工具(不包括提供商插件)
|
|
104
|
+
|
|
105
|
+
## 提权:仅限 exec 的"在主机上运行"
|
|
106
|
+
|
|
107
|
+
提权**不会**授予额外工具;它仅影响 `exec`。
|
|
108
|
+
|
|
109
|
+
- 如果你被沙箱隔离,`/elevated on`(或带 `elevated: true` 的 `exec`)在主机上运行(审批可能仍然适用)。
|
|
110
|
+
- 使用 `/elevated full` 跳过该会话的 exec 审批。
|
|
111
|
+
- 如果你已经直接运行,提权实际上是空操作(仍然受限)。
|
|
112
|
+
- 提权**不是** skill 范围的,**不会**覆盖工具允许/拒绝。
|
|
113
|
+
- `/exec` 与提权是分开的。它仅为授权发送者调整每个会话的 exec 默认值。
|
|
114
|
+
|
|
115
|
+
限制:
|
|
116
|
+
|
|
117
|
+
- 启用:`tools.elevated.enabled`(以及可选的 `agents.list[].tools.elevated.enabled`)
|
|
118
|
+
- 发送者允许列表:`tools.elevated.allowFrom.<provider>`(以及可选的 `agents.list[].tools.elevated.allowFrom.<provider>`)
|
|
119
|
+
|
|
120
|
+
参见[提权模式](/tools/elevated)。
|
|
121
|
+
|
|
122
|
+
## 常见"沙箱困境"修复
|
|
123
|
+
|
|
124
|
+
### "工具 X 被沙箱工具策略阻止"
|
|
125
|
+
|
|
126
|
+
修复键(选一个):
|
|
127
|
+
|
|
128
|
+
- 禁用沙箱:`agents.defaults.sandbox.mode=off`(或每个智能体 `agents.list[].sandbox.mode=off`)
|
|
129
|
+
- 在沙箱内允许该工具:
|
|
130
|
+
- 从 `tools.sandbox.tools.deny` 中移除它(或每个智能体 `agents.list[].tools.sandbox.tools.deny`)
|
|
131
|
+
- 或将它添加到 `tools.sandbox.tools.allow`(或每个智能体 allow)
|
|
132
|
+
|
|
133
|
+
### "我以为这是主会话,为什么被沙箱隔离了?"
|
|
134
|
+
|
|
135
|
+
在 `"non-main"` 模式下,群组/渠道键*不是*主会话。使用主会话键(由 `sandbox explain` 显示)或将模式切换为 `"off"`。
|
|
@@ -0,0 +1,188 @@
|
|
|
1
|
+
---
|
|
2
|
+
read_when: You want a dedicated explanation of sandboxing or need to tune agents.defaults.sandbox.
|
|
3
|
+
status: active
|
|
4
|
+
summary: QuantumClaw 沙箱隔离的工作原理:模式、作用域、工作区访问和镜像
|
|
5
|
+
title: 沙箱隔离
|
|
6
|
+
x-i18n:
|
|
7
|
+
generated_at: "2026-02-03T07:49:29Z"
|
|
8
|
+
model: claude-opus-4-5
|
|
9
|
+
provider: pi
|
|
10
|
+
source_hash: 184fc53001fc6b2847bbb1963cc9c54475d62f74555a581a262a448a0333a209
|
|
11
|
+
source_path: gateway/sandboxing.md
|
|
12
|
+
workflow: 15
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
# 沙箱隔离
|
|
16
|
+
|
|
17
|
+
QuantumClaw 可以**在 Docker 容器内运行工具**以减少影响范围。
|
|
18
|
+
这是**可选的**,由配置控制(`agents.defaults.sandbox` 或 `agents.list[].sandbox`)。如果沙箱隔离关闭,工具在主机上运行。
|
|
19
|
+
Gateway 网关保留在主机上;启用时工具执行在隔离的沙箱中运行。
|
|
20
|
+
|
|
21
|
+
这不是完美的安全边界,但当模型做出愚蠢行为时,它实质性地限制了文件系统和进程访问。
|
|
22
|
+
|
|
23
|
+
## 什么会被沙箱隔离
|
|
24
|
+
|
|
25
|
+
- 工具执行(`exec`、`read`、`write`、`edit`、`apply_patch`、`process` 等)。
|
|
26
|
+
- 可选的沙箱浏览器(`agents.defaults.sandbox.browser`)。
|
|
27
|
+
- 默认情况下,当浏览器工具需要时,沙箱浏览器会自动启动(确保 CDP 可达)。
|
|
28
|
+
通过 `agents.defaults.sandbox.browser.autoStart` 和 `agents.defaults.sandbox.browser.autoStartTimeoutMs` 配置。
|
|
29
|
+
- `agents.defaults.sandbox.browser.allowHostControl` 允许沙箱会话显式定位主机浏览器。
|
|
30
|
+
- 可选的允许列表限制 `target: "custom"`:`allowedControlUrls`、`allowedControlHosts`、`allowedControlPorts`。
|
|
31
|
+
|
|
32
|
+
不被沙箱隔离:
|
|
33
|
+
|
|
34
|
+
- Gateway 网关进程本身。
|
|
35
|
+
- 任何明确允许在主机上运行的工具(例如 `tools.elevated`)。
|
|
36
|
+
- **提权 exec 在主机上运行并绕过沙箱隔离。**
|
|
37
|
+
- 如果沙箱隔离关闭,`tools.elevated` 不会改变执行(已经在主机上)。参见[提权模式](/tools/elevated)。
|
|
38
|
+
|
|
39
|
+
## 模式
|
|
40
|
+
|
|
41
|
+
`agents.defaults.sandbox.mode` 控制**何时**使用沙箱隔离:
|
|
42
|
+
|
|
43
|
+
- `"off"`:不使用沙箱隔离。
|
|
44
|
+
- `"non-main"`:仅沙箱隔离**非主**会话(如果你想让普通聊天在主机上运行,这是默认值)。
|
|
45
|
+
- `"all"`:每个会话都在沙箱中运行。
|
|
46
|
+
注意:`"non-main"` 基于 `session.mainKey`(默认 `"main"`),而不是智能体 ID。
|
|
47
|
+
群组/频道会话使用它们自己的键,因此它们算作非主会话并将被沙箱隔离。
|
|
48
|
+
|
|
49
|
+
## 作用域
|
|
50
|
+
|
|
51
|
+
`agents.defaults.sandbox.scope` 控制**创建多少容器**:
|
|
52
|
+
|
|
53
|
+
- `"session"`(默认):每个会话一个容器。
|
|
54
|
+
- `"agent"`:每个智能体一个容器。
|
|
55
|
+
- `"shared"`:所有沙箱会话共享一个容器。
|
|
56
|
+
|
|
57
|
+
## 工作区访问
|
|
58
|
+
|
|
59
|
+
`agents.defaults.sandbox.workspaceAccess` 控制**沙箱可以看到什么**:
|
|
60
|
+
|
|
61
|
+
- `"none"`(默认):工具看到 `~/.quantumclaw/sandboxes` 下的沙箱工作区。
|
|
62
|
+
- `"ro"`:以只读方式在 `/agent` 挂载智能体工作区(禁用 `write`/`edit`/`apply_patch`)。
|
|
63
|
+
- `"rw"`:以读写方式在 `/workspace` 挂载智能体工作区。
|
|
64
|
+
|
|
65
|
+
入站媒体被复制到活动沙箱工作区(`media/inbound/*`)。
|
|
66
|
+
Skills 注意事项:`read` 工具以沙箱为根。使用 `workspaceAccess: "none"` 时,QuantumClaw 将符合条件的 Skills 镜像到沙箱工作区(`.../skills`)以便可以读取。使用 `"rw"` 时,工作区 Skills 可从 `/workspace/skills` 读取。
|
|
67
|
+
|
|
68
|
+
## 自定义绑定挂载
|
|
69
|
+
|
|
70
|
+
`agents.defaults.sandbox.docker.binds` 将额外的主机目录挂载到容器中。
|
|
71
|
+
格式:`host:container:mode`(例如 `"/home/user/source:/source:rw"`)。
|
|
72
|
+
|
|
73
|
+
全局和每智能体的绑定是**合并**的(不是替换)。在 `scope: "shared"` 下,每智能体的绑定被忽略。
|
|
74
|
+
|
|
75
|
+
示例(只读源码 + docker 套接字):
|
|
76
|
+
|
|
77
|
+
```json5
|
|
78
|
+
{
|
|
79
|
+
agents: {
|
|
80
|
+
defaults: {
|
|
81
|
+
sandbox: {
|
|
82
|
+
docker: {
|
|
83
|
+
binds: ["/home/user/source:/source:ro", "/var/run/docker.sock:/var/run/docker.sock"],
|
|
84
|
+
},
|
|
85
|
+
},
|
|
86
|
+
},
|
|
87
|
+
list: [
|
|
88
|
+
{
|
|
89
|
+
id: "build",
|
|
90
|
+
sandbox: {
|
|
91
|
+
docker: {
|
|
92
|
+
binds: ["/mnt/cache:/cache:rw"],
|
|
93
|
+
},
|
|
94
|
+
},
|
|
95
|
+
},
|
|
96
|
+
],
|
|
97
|
+
},
|
|
98
|
+
}
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
安全注意事项:
|
|
102
|
+
|
|
103
|
+
- 绑定绕过沙箱文件系统:它们以你设置的任何模式(`:ro` 或 `:rw`)暴露主机路径。
|
|
104
|
+
- 敏感挂载(例如 `docker.sock`、密钥、SSH 密钥)应该是 `:ro`,除非绝对必要。
|
|
105
|
+
- 如果你只需要对工作区的读取访问,请结合 `workspaceAccess: "ro"`;绑定模式保持独立。
|
|
106
|
+
- 参见[沙箱 vs 工具策略 vs 提权](/gateway/sandbox-vs-tool-policy-vs-elevated)了解绑定如何与工具策略和提权 exec 交互。
|
|
107
|
+
|
|
108
|
+
## 镜像 + 设置
|
|
109
|
+
|
|
110
|
+
默认镜像:`quantumclaw-sandbox:bookworm-slim`
|
|
111
|
+
|
|
112
|
+
构建一次:
|
|
113
|
+
|
|
114
|
+
```bash
|
|
115
|
+
scripts/sandbox-setup.sh
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
注意:默认镜像**不**包含 Node。如果 Skills 需要 Node(或其他运行时),要么构建自定义镜像,要么通过 `sandbox.docker.setupCommand` 安装(需要网络出口 + 可写根 + root 用户)。
|
|
119
|
+
|
|
120
|
+
沙箱浏览器镜像:
|
|
121
|
+
|
|
122
|
+
```bash
|
|
123
|
+
scripts/sandbox-browser-setup.sh
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
默认情况下,沙箱容器运行时**没有网络**。
|
|
127
|
+
通过 `agents.defaults.sandbox.docker.network` 覆盖。
|
|
128
|
+
|
|
129
|
+
Docker 安装和容器化 Gateway 网关在此:
|
|
130
|
+
[Docker](/install/docker)
|
|
131
|
+
|
|
132
|
+
## setupCommand(一次性容器设置)
|
|
133
|
+
|
|
134
|
+
`setupCommand` 在沙箱容器创建后**运行一次**(不是每次运行)。
|
|
135
|
+
它通过 `sh -lc` 在容器内执行。
|
|
136
|
+
|
|
137
|
+
路径:
|
|
138
|
+
|
|
139
|
+
- 全局:`agents.defaults.sandbox.docker.setupCommand`
|
|
140
|
+
- 每智能体:`agents.list[].sandbox.docker.setupCommand`
|
|
141
|
+
|
|
142
|
+
常见陷阱:
|
|
143
|
+
|
|
144
|
+
- 默认 `docker.network` 是 `"none"`(无出口),因此包安装会失败。
|
|
145
|
+
- `readOnlyRoot: true` 阻止写入;设置 `readOnlyRoot: false` 或构建自定义镜像。
|
|
146
|
+
- `user` 必须是 root 才能安装包(省略 `user` 或设置 `user: "0:0"`)。
|
|
147
|
+
- 沙箱 exec **不**继承主机 `process.env`。使用 `agents.defaults.sandbox.docker.env`(或自定义镜像)设置 Skills API 密钥。
|
|
148
|
+
|
|
149
|
+
## 工具策略 + 逃逸通道
|
|
150
|
+
|
|
151
|
+
工具允许/拒绝策略仍在沙箱规则之前应用。如果工具在全局或每智能体被拒绝,沙箱隔离不会恢复它。
|
|
152
|
+
|
|
153
|
+
`tools.elevated` 是一个显式的逃逸通道,在主机上运行 `exec`。
|
|
154
|
+
`/exec` 指令仅适用于授权发送者并按会话持久化;要硬禁用 `exec`,使用工具策略拒绝(参见[沙箱 vs 工具策略 vs 提权](/gateway/sandbox-vs-tool-policy-vs-elevated))。
|
|
155
|
+
|
|
156
|
+
调试:
|
|
157
|
+
|
|
158
|
+
- 使用 `quantumclaw sandbox explain` 检查生效的沙箱模式、工具策略和修复配置键。
|
|
159
|
+
- 参见[沙箱 vs 工具策略 vs 提权](/gateway/sandbox-vs-tool-policy-vs-elevated)了解"为什么被阻止?"的心智模型。
|
|
160
|
+
保持锁定。
|
|
161
|
+
|
|
162
|
+
## 多智能体覆盖
|
|
163
|
+
|
|
164
|
+
每个智能体可以覆盖沙箱 + 工具:
|
|
165
|
+
`agents.list[].sandbox` 和 `agents.list[].tools`(加上 `agents.list[].tools.sandbox.tools` 用于沙箱工具策略)。
|
|
166
|
+
参见[多智能体沙箱与工具](/tools/multi-agent-sandbox-tools)了解优先级。
|
|
167
|
+
|
|
168
|
+
## 最小启用示例
|
|
169
|
+
|
|
170
|
+
```json5
|
|
171
|
+
{
|
|
172
|
+
agents: {
|
|
173
|
+
defaults: {
|
|
174
|
+
sandbox: {
|
|
175
|
+
mode: "non-main",
|
|
176
|
+
scope: "session",
|
|
177
|
+
workspaceAccess: "none",
|
|
178
|
+
},
|
|
179
|
+
},
|
|
180
|
+
},
|
|
181
|
+
}
|
|
182
|
+
```
|
|
183
|
+
|
|
184
|
+
## 相关文档
|
|
185
|
+
|
|
186
|
+
- [沙箱配置](/gateway/configuration#agentsdefaults-sandbox)
|
|
187
|
+
- [多智能体沙箱与工具](/tools/multi-agent-sandbox-tools)
|
|
188
|
+
- [安全](/gateway/security)
|