@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,295 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Expose an OpenResponses-compatible /v1/responses HTTP endpoint from the Gateway"
|
|
3
|
+
read_when:
|
|
4
|
+
- Integrating clients that speak the OpenResponses API
|
|
5
|
+
- You want item-based inputs, client tool calls, or SSE events
|
|
6
|
+
title: "OpenResponses API"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# OpenResponses API (HTTP)
|
|
10
|
+
|
|
11
|
+
QuantumClaw’s Gateway can serve an OpenResponses-compatible `POST /v1/responses` endpoint.
|
|
12
|
+
|
|
13
|
+
This endpoint is **disabled by default**. Enable it in config first.
|
|
14
|
+
|
|
15
|
+
- `POST /v1/responses`
|
|
16
|
+
- Same port as the Gateway (WS + HTTP multiplex): `http://<gateway-host>:<port>/v1/responses`
|
|
17
|
+
|
|
18
|
+
Under the hood, requests are executed as a normal Gateway agent run (same codepath as
|
|
19
|
+
`quantumclaw agent`), so routing/permissions/config match your Gateway.
|
|
20
|
+
|
|
21
|
+
## Authentication, security, and routing
|
|
22
|
+
|
|
23
|
+
Operational behavior matches [OpenAI Chat Completions](/gateway/openai-http-api):
|
|
24
|
+
|
|
25
|
+
- use `Authorization: Bearer <token>` with the normal Gateway auth config
|
|
26
|
+
- treat the endpoint as full operator access for the gateway instance
|
|
27
|
+
- select agents with `model: "quantumclaw:<agentId>"`, `model: "agent:<agentId>"`, or `x-quantumclaw-agent-id`
|
|
28
|
+
- use `x-quantumclaw-session-key` for explicit session routing
|
|
29
|
+
|
|
30
|
+
Enable or disable this endpoint with `gateway.http.endpoints.responses.enabled`.
|
|
31
|
+
|
|
32
|
+
## Session behavior
|
|
33
|
+
|
|
34
|
+
By default the endpoint is **stateless per request** (a new session key is generated each call).
|
|
35
|
+
|
|
36
|
+
If the request includes an OpenResponses `user` string, the Gateway derives a stable session key
|
|
37
|
+
from it, so repeated calls can share an agent session.
|
|
38
|
+
|
|
39
|
+
## Request shape (supported)
|
|
40
|
+
|
|
41
|
+
The request follows the OpenResponses API with item-based input. Current support:
|
|
42
|
+
|
|
43
|
+
- `input`: string or array of item objects.
|
|
44
|
+
- `instructions`: merged into the system prompt.
|
|
45
|
+
- `tools`: client tool definitions (function tools).
|
|
46
|
+
- `tool_choice`: filter or require client tools.
|
|
47
|
+
- `stream`: enables SSE streaming.
|
|
48
|
+
- `max_output_tokens`: best-effort output limit (provider dependent).
|
|
49
|
+
- `user`: stable session routing.
|
|
50
|
+
|
|
51
|
+
Accepted but **currently ignored**:
|
|
52
|
+
|
|
53
|
+
- `max_tool_calls`
|
|
54
|
+
- `reasoning`
|
|
55
|
+
- `metadata`
|
|
56
|
+
- `store`
|
|
57
|
+
- `previous_response_id`
|
|
58
|
+
- `truncation`
|
|
59
|
+
|
|
60
|
+
## Items (input)
|
|
61
|
+
|
|
62
|
+
### `message`
|
|
63
|
+
|
|
64
|
+
Roles: `system`, `developer`, `user`, `assistant`.
|
|
65
|
+
|
|
66
|
+
- `system` and `developer` are appended to the system prompt.
|
|
67
|
+
- The most recent `user` or `function_call_output` item becomes the “current message.”
|
|
68
|
+
- Earlier user/assistant messages are included as history for context.
|
|
69
|
+
|
|
70
|
+
### `function_call_output` (turn-based tools)
|
|
71
|
+
|
|
72
|
+
Send tool results back to the model:
|
|
73
|
+
|
|
74
|
+
```json
|
|
75
|
+
{
|
|
76
|
+
"type": "function_call_output",
|
|
77
|
+
"call_id": "call_123",
|
|
78
|
+
"output": "{\"temperature\": \"72F\"}"
|
|
79
|
+
}
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
### `reasoning` and `item_reference`
|
|
83
|
+
|
|
84
|
+
Accepted for schema compatibility but ignored when building the prompt.
|
|
85
|
+
|
|
86
|
+
## Tools (client-side function tools)
|
|
87
|
+
|
|
88
|
+
Provide tools with `tools: [{ type: "function", function: { name, description?, parameters? } }]`.
|
|
89
|
+
|
|
90
|
+
If the agent decides to call a tool, the response returns a `function_call` output item.
|
|
91
|
+
You then send a follow-up request with `function_call_output` to continue the turn.
|
|
92
|
+
|
|
93
|
+
## Images (`input_image`)
|
|
94
|
+
|
|
95
|
+
Supports base64 or URL sources:
|
|
96
|
+
|
|
97
|
+
```json
|
|
98
|
+
{
|
|
99
|
+
"type": "input_image",
|
|
100
|
+
"source": { "type": "url", "url": "https://example.com/image.png" }
|
|
101
|
+
}
|
|
102
|
+
```
|
|
103
|
+
|
|
104
|
+
Allowed MIME types (current): `image/jpeg`, `image/png`, `image/gif`, `image/webp`, `image/heic`, `image/heif`.
|
|
105
|
+
Max size (current): 10MB.
|
|
106
|
+
|
|
107
|
+
## Files (`input_file`)
|
|
108
|
+
|
|
109
|
+
Supports base64 or URL sources:
|
|
110
|
+
|
|
111
|
+
```json
|
|
112
|
+
{
|
|
113
|
+
"type": "input_file",
|
|
114
|
+
"source": {
|
|
115
|
+
"type": "base64",
|
|
116
|
+
"media_type": "text/plain",
|
|
117
|
+
"data": "SGVsbG8gV29ybGQh",
|
|
118
|
+
"filename": "hello.txt"
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
```
|
|
122
|
+
|
|
123
|
+
Allowed MIME types (current): `text/plain`, `text/markdown`, `text/html`, `text/csv`,
|
|
124
|
+
`application/json`, `application/pdf`.
|
|
125
|
+
|
|
126
|
+
Max size (current): 5MB.
|
|
127
|
+
|
|
128
|
+
Current behavior:
|
|
129
|
+
|
|
130
|
+
- File content is decoded and added to the **system prompt**, not the user message,
|
|
131
|
+
so it stays ephemeral (not persisted in session history).
|
|
132
|
+
- PDFs are parsed for text. If little text is found, the first pages are rasterized
|
|
133
|
+
into images and passed to the model.
|
|
134
|
+
|
|
135
|
+
PDF parsing uses the Node-friendly `pdfjs-dist` legacy build (no worker). The modern
|
|
136
|
+
PDF.js build expects browser workers/DOM globals, so it is not used in the Gateway.
|
|
137
|
+
|
|
138
|
+
URL fetch defaults:
|
|
139
|
+
|
|
140
|
+
- `files.allowUrl`: `true`
|
|
141
|
+
- `images.allowUrl`: `true`
|
|
142
|
+
- `maxUrlParts`: `8` (total URL-based `input_file` + `input_image` parts per request)
|
|
143
|
+
- Requests are guarded (DNS resolution, private IP blocking, redirect caps, timeouts).
|
|
144
|
+
- Optional hostname allowlists are supported per input type (`files.urlAllowlist`, `images.urlAllowlist`).
|
|
145
|
+
- Exact host: `"cdn.example.com"`
|
|
146
|
+
- Wildcard subdomains: `"*.assets.example.com"` (does not match apex)
|
|
147
|
+
- Empty or omitted allowlists mean no hostname allowlist restriction.
|
|
148
|
+
- To disable URL-based fetches entirely, set `files.allowUrl: false` and/or `images.allowUrl: false`.
|
|
149
|
+
|
|
150
|
+
## File + image limits (config)
|
|
151
|
+
|
|
152
|
+
Defaults can be tuned under `gateway.http.endpoints.responses`:
|
|
153
|
+
|
|
154
|
+
```json5
|
|
155
|
+
{
|
|
156
|
+
gateway: {
|
|
157
|
+
http: {
|
|
158
|
+
endpoints: {
|
|
159
|
+
responses: {
|
|
160
|
+
enabled: true,
|
|
161
|
+
maxBodyBytes: 20000000,
|
|
162
|
+
maxUrlParts: 8,
|
|
163
|
+
files: {
|
|
164
|
+
allowUrl: true,
|
|
165
|
+
urlAllowlist: ["cdn.example.com", "*.assets.example.com"],
|
|
166
|
+
allowedMimes: [
|
|
167
|
+
"text/plain",
|
|
168
|
+
"text/markdown",
|
|
169
|
+
"text/html",
|
|
170
|
+
"text/csv",
|
|
171
|
+
"application/json",
|
|
172
|
+
"application/pdf",
|
|
173
|
+
],
|
|
174
|
+
maxBytes: 5242880,
|
|
175
|
+
maxChars: 200000,
|
|
176
|
+
maxRedirects: 3,
|
|
177
|
+
timeoutMs: 10000,
|
|
178
|
+
pdf: {
|
|
179
|
+
maxPages: 4,
|
|
180
|
+
maxPixels: 4000000,
|
|
181
|
+
minTextChars: 200,
|
|
182
|
+
},
|
|
183
|
+
},
|
|
184
|
+
images: {
|
|
185
|
+
allowUrl: true,
|
|
186
|
+
urlAllowlist: ["images.example.com"],
|
|
187
|
+
allowedMimes: [
|
|
188
|
+
"image/jpeg",
|
|
189
|
+
"image/png",
|
|
190
|
+
"image/gif",
|
|
191
|
+
"image/webp",
|
|
192
|
+
"image/heic",
|
|
193
|
+
"image/heif",
|
|
194
|
+
],
|
|
195
|
+
maxBytes: 10485760,
|
|
196
|
+
maxRedirects: 3,
|
|
197
|
+
timeoutMs: 10000,
|
|
198
|
+
},
|
|
199
|
+
},
|
|
200
|
+
},
|
|
201
|
+
},
|
|
202
|
+
},
|
|
203
|
+
}
|
|
204
|
+
```
|
|
205
|
+
|
|
206
|
+
Defaults when omitted:
|
|
207
|
+
|
|
208
|
+
- `maxBodyBytes`: 20MB
|
|
209
|
+
- `maxUrlParts`: 8
|
|
210
|
+
- `files.maxBytes`: 5MB
|
|
211
|
+
- `files.maxChars`: 200k
|
|
212
|
+
- `files.maxRedirects`: 3
|
|
213
|
+
- `files.timeoutMs`: 10s
|
|
214
|
+
- `files.pdf.maxPages`: 4
|
|
215
|
+
- `files.pdf.maxPixels`: 4,000,000
|
|
216
|
+
- `files.pdf.minTextChars`: 200
|
|
217
|
+
- `images.maxBytes`: 10MB
|
|
218
|
+
- `images.maxRedirects`: 3
|
|
219
|
+
- `images.timeoutMs`: 10s
|
|
220
|
+
- HEIC/HEIF `input_image` sources are accepted and normalized to JPEG before provider delivery.
|
|
221
|
+
|
|
222
|
+
Security note:
|
|
223
|
+
|
|
224
|
+
- URL allowlists are enforced before fetch and on redirect hops.
|
|
225
|
+
- Allowlisting a hostname does not bypass private/internal IP blocking.
|
|
226
|
+
- For internet-exposed gateways, apply network egress controls in addition to app-level guards.
|
|
227
|
+
See [Security](/gateway/security).
|
|
228
|
+
|
|
229
|
+
## Streaming (SSE)
|
|
230
|
+
|
|
231
|
+
Set `stream: true` to receive Server-Sent Events (SSE):
|
|
232
|
+
|
|
233
|
+
- `Content-Type: text/event-stream`
|
|
234
|
+
- Each event line is `event: <type>` and `data: <json>`
|
|
235
|
+
- Stream ends with `data: [DONE]`
|
|
236
|
+
|
|
237
|
+
Event types currently emitted:
|
|
238
|
+
|
|
239
|
+
- `response.created`
|
|
240
|
+
- `response.in_progress`
|
|
241
|
+
- `response.output_item.added`
|
|
242
|
+
- `response.content_part.added`
|
|
243
|
+
- `response.output_text.delta`
|
|
244
|
+
- `response.output_text.done`
|
|
245
|
+
- `response.content_part.done`
|
|
246
|
+
- `response.output_item.done`
|
|
247
|
+
- `response.completed`
|
|
248
|
+
- `response.failed` (on error)
|
|
249
|
+
|
|
250
|
+
## Usage
|
|
251
|
+
|
|
252
|
+
`usage` is populated when the underlying provider reports token counts.
|
|
253
|
+
|
|
254
|
+
## Errors
|
|
255
|
+
|
|
256
|
+
Errors use a JSON object like:
|
|
257
|
+
|
|
258
|
+
```json
|
|
259
|
+
{ "error": { "message": "...", "type": "invalid_request_error" } }
|
|
260
|
+
```
|
|
261
|
+
|
|
262
|
+
Common cases:
|
|
263
|
+
|
|
264
|
+
- `401` missing/invalid auth
|
|
265
|
+
- `400` invalid request body
|
|
266
|
+
- `405` wrong method
|
|
267
|
+
|
|
268
|
+
## Examples
|
|
269
|
+
|
|
270
|
+
Non-streaming:
|
|
271
|
+
|
|
272
|
+
```bash
|
|
273
|
+
curl -sS http://127.0.0.1:18789/v1/responses \
|
|
274
|
+
-H 'Authorization: Bearer YOUR_TOKEN' \
|
|
275
|
+
-H 'Content-Type: application/json' \
|
|
276
|
+
-H 'x-quantumclaw-agent-id: main' \
|
|
277
|
+
-d '{
|
|
278
|
+
"model": "quantumclaw",
|
|
279
|
+
"input": "hi"
|
|
280
|
+
}'
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
Streaming:
|
|
284
|
+
|
|
285
|
+
```bash
|
|
286
|
+
curl -N http://127.0.0.1:18789/v1/responses \
|
|
287
|
+
-H 'Authorization: Bearer YOUR_TOKEN' \
|
|
288
|
+
-H 'Content-Type: application/json' \
|
|
289
|
+
-H 'x-quantumclaw-agent-id: main' \
|
|
290
|
+
-d '{
|
|
291
|
+
"model": "quantumclaw",
|
|
292
|
+
"stream": true,
|
|
293
|
+
"input": "hi"
|
|
294
|
+
}'
|
|
295
|
+
```
|
|
@@ -0,0 +1,307 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: OpenShell
|
|
3
|
+
summary: "Use OpenShell as a managed sandbox backend for QuantumClaw agents"
|
|
4
|
+
read_when:
|
|
5
|
+
- You want cloud-managed sandboxes instead of local Docker
|
|
6
|
+
- You are setting up the OpenShell plugin
|
|
7
|
+
- You need to choose between mirror and remote workspace modes
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# OpenShell
|
|
11
|
+
|
|
12
|
+
OpenShell is a managed sandbox backend for QuantumClaw. Instead of running Docker
|
|
13
|
+
containers locally, QuantumClaw delegates sandbox lifecycle to the `openshell` CLI,
|
|
14
|
+
which provisions remote environments with SSH-based command execution.
|
|
15
|
+
|
|
16
|
+
The OpenShell plugin reuses the same core SSH transport and remote filesystem
|
|
17
|
+
bridge as the generic [SSH backend](/gateway/sandboxing#ssh-backend). It adds
|
|
18
|
+
OpenShell-specific lifecycle (`sandbox create/get/delete`, `sandbox ssh-config`)
|
|
19
|
+
and an optional `mirror` workspace mode.
|
|
20
|
+
|
|
21
|
+
## Prerequisites
|
|
22
|
+
|
|
23
|
+
- The `openshell` CLI installed and on `PATH` (or set a custom path via
|
|
24
|
+
`plugins.entries.openshell.config.command`)
|
|
25
|
+
- An OpenShell account with sandbox access
|
|
26
|
+
- QuantumClaw Gateway running on the host
|
|
27
|
+
|
|
28
|
+
## Quick start
|
|
29
|
+
|
|
30
|
+
1. Enable the plugin and set the sandbox backend:
|
|
31
|
+
|
|
32
|
+
```json5
|
|
33
|
+
{
|
|
34
|
+
agents: {
|
|
35
|
+
defaults: {
|
|
36
|
+
sandbox: {
|
|
37
|
+
mode: "all",
|
|
38
|
+
backend: "openshell",
|
|
39
|
+
scope: "session",
|
|
40
|
+
workspaceAccess: "rw",
|
|
41
|
+
},
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
plugins: {
|
|
45
|
+
entries: {
|
|
46
|
+
openshell: {
|
|
47
|
+
enabled: true,
|
|
48
|
+
config: {
|
|
49
|
+
from: "quantumclaw",
|
|
50
|
+
mode: "remote",
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
},
|
|
55
|
+
}
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
2. Restart the Gateway. On the next agent turn, QuantumClaw creates an OpenShell
|
|
59
|
+
sandbox and routes tool execution through it.
|
|
60
|
+
|
|
61
|
+
3. Verify:
|
|
62
|
+
|
|
63
|
+
```bash
|
|
64
|
+
quantumclaw sandbox list
|
|
65
|
+
quantumclaw sandbox explain
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
## Workspace modes
|
|
69
|
+
|
|
70
|
+
This is the most important decision when using OpenShell.
|
|
71
|
+
|
|
72
|
+
### `mirror`
|
|
73
|
+
|
|
74
|
+
Use `plugins.entries.openshell.config.mode: "mirror"` when you want the **local
|
|
75
|
+
workspace to stay canonical**.
|
|
76
|
+
|
|
77
|
+
Behavior:
|
|
78
|
+
|
|
79
|
+
- Before `exec`, QuantumClaw syncs the local workspace into the OpenShell sandbox.
|
|
80
|
+
- After `exec`, QuantumClaw syncs the remote workspace back to the local workspace.
|
|
81
|
+
- File tools still operate through the sandbox bridge, but the local workspace
|
|
82
|
+
remains the source of truth between turns.
|
|
83
|
+
|
|
84
|
+
Best for:
|
|
85
|
+
|
|
86
|
+
- You edit files locally outside QuantumClaw and want those changes visible in the
|
|
87
|
+
sandbox automatically.
|
|
88
|
+
- You want the OpenShell sandbox to behave as much like the Docker backend as
|
|
89
|
+
possible.
|
|
90
|
+
- You want the host workspace to reflect sandbox writes after each exec turn.
|
|
91
|
+
|
|
92
|
+
Tradeoff: extra sync cost before and after each exec.
|
|
93
|
+
|
|
94
|
+
### `remote`
|
|
95
|
+
|
|
96
|
+
Use `plugins.entries.openshell.config.mode: "remote"` when you want the
|
|
97
|
+
**OpenShell workspace to become canonical**.
|
|
98
|
+
|
|
99
|
+
Behavior:
|
|
100
|
+
|
|
101
|
+
- When the sandbox is first created, QuantumClaw seeds the remote workspace from
|
|
102
|
+
the local workspace once.
|
|
103
|
+
- After that, `exec`, `read`, `write`, `edit`, and `apply_patch` operate
|
|
104
|
+
directly against the remote OpenShell workspace.
|
|
105
|
+
- QuantumClaw does **not** sync remote changes back into the local workspace.
|
|
106
|
+
- Prompt-time media reads still work because file and media tools read through
|
|
107
|
+
the sandbox bridge.
|
|
108
|
+
|
|
109
|
+
Best for:
|
|
110
|
+
|
|
111
|
+
- The sandbox should live primarily on the remote side.
|
|
112
|
+
- You want lower per-turn sync overhead.
|
|
113
|
+
- You do not want host-local edits to silently overwrite remote sandbox state.
|
|
114
|
+
|
|
115
|
+
Important: if you edit files on the host outside QuantumClaw after the initial seed,
|
|
116
|
+
the remote sandbox does **not** see those changes. Use
|
|
117
|
+
`quantumclaw sandbox recreate` to re-seed.
|
|
118
|
+
|
|
119
|
+
### Choosing a mode
|
|
120
|
+
|
|
121
|
+
| | `mirror` | `remote` |
|
|
122
|
+
| ------------------------ | -------------------------- | ------------------------- |
|
|
123
|
+
| **Canonical workspace** | Local host | Remote OpenShell |
|
|
124
|
+
| **Sync direction** | Bidirectional (each exec) | One-time seed |
|
|
125
|
+
| **Per-turn overhead** | Higher (upload + download) | Lower (direct remote ops) |
|
|
126
|
+
| **Local edits visible?** | Yes, on next exec | No, until recreate |
|
|
127
|
+
| **Best for** | Development workflows | Long-running agents, CI |
|
|
128
|
+
|
|
129
|
+
## Configuration reference
|
|
130
|
+
|
|
131
|
+
All OpenShell config lives under `plugins.entries.openshell.config`:
|
|
132
|
+
|
|
133
|
+
| Key | Type | Default | Description |
|
|
134
|
+
| ------------------------- | ------------------------ | ------------- | ----------------------------------------------------- |
|
|
135
|
+
| `mode` | `"mirror"` or `"remote"` | `"mirror"` | Workspace sync mode |
|
|
136
|
+
| `command` | `string` | `"openshell"` | Path or name of the `openshell` CLI |
|
|
137
|
+
| `from` | `string` | `"quantumclaw"` | Sandbox source for first-time create |
|
|
138
|
+
| `gateway` | `string` | — | OpenShell gateway name (`--gateway`) |
|
|
139
|
+
| `gatewayEndpoint` | `string` | — | OpenShell gateway endpoint URL (`--gateway-endpoint`) |
|
|
140
|
+
| `policy` | `string` | — | OpenShell policy ID for sandbox creation |
|
|
141
|
+
| `providers` | `string[]` | `[]` | Provider names to attach when sandbox is created |
|
|
142
|
+
| `gpu` | `boolean` | `false` | Request GPU resources |
|
|
143
|
+
| `autoProviders` | `boolean` | `true` | Pass `--auto-providers` during sandbox create |
|
|
144
|
+
| `remoteWorkspaceDir` | `string` | `"/sandbox"` | Primary writable workspace inside the sandbox |
|
|
145
|
+
| `remoteAgentWorkspaceDir` | `string` | `"/agent"` | Agent workspace mount path (for read-only access) |
|
|
146
|
+
| `timeoutSeconds` | `number` | `120` | Timeout for `openshell` CLI operations |
|
|
147
|
+
|
|
148
|
+
Sandbox-level settings (`mode`, `scope`, `workspaceAccess`) are configured under
|
|
149
|
+
`agents.defaults.sandbox` as with any backend. See
|
|
150
|
+
[Sandboxing](/gateway/sandboxing) for the full matrix.
|
|
151
|
+
|
|
152
|
+
## Examples
|
|
153
|
+
|
|
154
|
+
### Minimal remote setup
|
|
155
|
+
|
|
156
|
+
```json5
|
|
157
|
+
{
|
|
158
|
+
agents: {
|
|
159
|
+
defaults: {
|
|
160
|
+
sandbox: {
|
|
161
|
+
mode: "all",
|
|
162
|
+
backend: "openshell",
|
|
163
|
+
},
|
|
164
|
+
},
|
|
165
|
+
},
|
|
166
|
+
plugins: {
|
|
167
|
+
entries: {
|
|
168
|
+
openshell: {
|
|
169
|
+
enabled: true,
|
|
170
|
+
config: {
|
|
171
|
+
from: "quantumclaw",
|
|
172
|
+
mode: "remote",
|
|
173
|
+
},
|
|
174
|
+
},
|
|
175
|
+
},
|
|
176
|
+
},
|
|
177
|
+
}
|
|
178
|
+
```
|
|
179
|
+
|
|
180
|
+
### Mirror mode with GPU
|
|
181
|
+
|
|
182
|
+
```json5
|
|
183
|
+
{
|
|
184
|
+
agents: {
|
|
185
|
+
defaults: {
|
|
186
|
+
sandbox: {
|
|
187
|
+
mode: "all",
|
|
188
|
+
backend: "openshell",
|
|
189
|
+
scope: "agent",
|
|
190
|
+
workspaceAccess: "rw",
|
|
191
|
+
},
|
|
192
|
+
},
|
|
193
|
+
},
|
|
194
|
+
plugins: {
|
|
195
|
+
entries: {
|
|
196
|
+
openshell: {
|
|
197
|
+
enabled: true,
|
|
198
|
+
config: {
|
|
199
|
+
from: "quantumclaw",
|
|
200
|
+
mode: "mirror",
|
|
201
|
+
gpu: true,
|
|
202
|
+
providers: ["openai"],
|
|
203
|
+
timeoutSeconds: 180,
|
|
204
|
+
},
|
|
205
|
+
},
|
|
206
|
+
},
|
|
207
|
+
},
|
|
208
|
+
}
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
### Per-agent OpenShell with custom gateway
|
|
212
|
+
|
|
213
|
+
```json5
|
|
214
|
+
{
|
|
215
|
+
agents: {
|
|
216
|
+
defaults: {
|
|
217
|
+
sandbox: { mode: "off" },
|
|
218
|
+
},
|
|
219
|
+
list: [
|
|
220
|
+
{
|
|
221
|
+
id: "researcher",
|
|
222
|
+
sandbox: {
|
|
223
|
+
mode: "all",
|
|
224
|
+
backend: "openshell",
|
|
225
|
+
scope: "agent",
|
|
226
|
+
workspaceAccess: "rw",
|
|
227
|
+
},
|
|
228
|
+
},
|
|
229
|
+
],
|
|
230
|
+
},
|
|
231
|
+
plugins: {
|
|
232
|
+
entries: {
|
|
233
|
+
openshell: {
|
|
234
|
+
enabled: true,
|
|
235
|
+
config: {
|
|
236
|
+
from: "quantumclaw",
|
|
237
|
+
mode: "remote",
|
|
238
|
+
gateway: "lab",
|
|
239
|
+
gatewayEndpoint: "https://lab.example",
|
|
240
|
+
policy: "strict",
|
|
241
|
+
},
|
|
242
|
+
},
|
|
243
|
+
},
|
|
244
|
+
},
|
|
245
|
+
}
|
|
246
|
+
```
|
|
247
|
+
|
|
248
|
+
## Lifecycle management
|
|
249
|
+
|
|
250
|
+
OpenShell sandboxes are managed through the normal sandbox CLI:
|
|
251
|
+
|
|
252
|
+
```bash
|
|
253
|
+
# List all sandbox runtimes (Docker + OpenShell)
|
|
254
|
+
quantumclaw sandbox list
|
|
255
|
+
|
|
256
|
+
# Inspect effective policy
|
|
257
|
+
quantumclaw sandbox explain
|
|
258
|
+
|
|
259
|
+
# Recreate (deletes remote workspace, re-seeds on next use)
|
|
260
|
+
quantumclaw sandbox recreate --all
|
|
261
|
+
```
|
|
262
|
+
|
|
263
|
+
For `remote` mode, **recreate is especially important**: it deletes the canonical
|
|
264
|
+
remote workspace for that scope. The next use seeds a fresh remote workspace from
|
|
265
|
+
the local workspace.
|
|
266
|
+
|
|
267
|
+
For `mirror` mode, recreate mainly resets the remote execution environment because
|
|
268
|
+
the local workspace remains canonical.
|
|
269
|
+
|
|
270
|
+
### When to recreate
|
|
271
|
+
|
|
272
|
+
Recreate after changing any of these:
|
|
273
|
+
|
|
274
|
+
- `agents.defaults.sandbox.backend`
|
|
275
|
+
- `plugins.entries.openshell.config.from`
|
|
276
|
+
- `plugins.entries.openshell.config.mode`
|
|
277
|
+
- `plugins.entries.openshell.config.policy`
|
|
278
|
+
|
|
279
|
+
```bash
|
|
280
|
+
quantumclaw sandbox recreate --all
|
|
281
|
+
```
|
|
282
|
+
|
|
283
|
+
## Current limitations
|
|
284
|
+
|
|
285
|
+
- Sandbox browser is not supported on the OpenShell backend.
|
|
286
|
+
- `sandbox.docker.binds` does not apply to OpenShell.
|
|
287
|
+
- Docker-specific runtime knobs under `sandbox.docker.*` apply only to the Docker
|
|
288
|
+
backend.
|
|
289
|
+
|
|
290
|
+
## How it works
|
|
291
|
+
|
|
292
|
+
1. QuantumClaw calls `openshell sandbox create` (with `--from`, `--gateway`,
|
|
293
|
+
`--policy`, `--providers`, `--gpu` flags as configured).
|
|
294
|
+
2. QuantumClaw calls `openshell sandbox ssh-config <name>` to get SSH connection
|
|
295
|
+
details for the sandbox.
|
|
296
|
+
3. Core writes the SSH config to a temp file and opens an SSH session using the
|
|
297
|
+
same remote filesystem bridge as the generic SSH backend.
|
|
298
|
+
4. In `mirror` mode: sync local to remote before exec, run, sync back after exec.
|
|
299
|
+
5. In `remote` mode: seed once on create, then operate directly on the remote
|
|
300
|
+
workspace.
|
|
301
|
+
|
|
302
|
+
## See also
|
|
303
|
+
|
|
304
|
+
- [Sandboxing](/gateway/sandboxing) -- modes, scopes, and backend comparison
|
|
305
|
+
- [Sandbox vs Tool Policy vs Elevated](/gateway/sandbox-vs-tool-policy-vs-elevated) -- debugging blocked tools
|
|
306
|
+
- [Multi-Agent Sandbox and Tools](/tools/multi-agent-sandbox-tools) -- per-agent overrides
|
|
307
|
+
- [Sandbox CLI](/cli/sandbox) -- `quantumclaw sandbox` commands
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Gateway-owned node pairing (Option B) for iOS and other remote nodes"
|
|
3
|
+
read_when:
|
|
4
|
+
- Implementing node pairing approvals without macOS UI
|
|
5
|
+
- Adding CLI flows for approving remote nodes
|
|
6
|
+
- Extending gateway protocol with node management
|
|
7
|
+
title: "Gateway-Owned Pairing"
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# Gateway-owned pairing (Option B)
|
|
11
|
+
|
|
12
|
+
In Gateway-owned pairing, the **Gateway** is the source of truth for which nodes
|
|
13
|
+
are allowed to join. UIs (macOS app, future clients) are just frontends that
|
|
14
|
+
approve or reject pending requests.
|
|
15
|
+
|
|
16
|
+
**Important:** WS nodes use **device pairing** (role `node`) during `connect`.
|
|
17
|
+
`node.pair.*` is a separate pairing store and does **not** gate the WS handshake.
|
|
18
|
+
Only clients that explicitly call `node.pair.*` use this flow.
|
|
19
|
+
|
|
20
|
+
## Concepts
|
|
21
|
+
|
|
22
|
+
- **Pending request**: a node asked to join; requires approval.
|
|
23
|
+
- **Paired node**: approved node with an issued auth token.
|
|
24
|
+
- **Transport**: the Gateway WS endpoint forwards requests but does not decide
|
|
25
|
+
membership. (Legacy TCP bridge support is deprecated/removed.)
|
|
26
|
+
|
|
27
|
+
## How pairing works
|
|
28
|
+
|
|
29
|
+
1. A node connects to the Gateway WS and requests pairing.
|
|
30
|
+
2. The Gateway stores a **pending request** and emits `node.pair.requested`.
|
|
31
|
+
3. You approve or reject the request (CLI or UI).
|
|
32
|
+
4. On approval, the Gateway issues a **new token** (tokens are rotated on re‑pair).
|
|
33
|
+
5. The node reconnects using the token and is now “paired”.
|
|
34
|
+
|
|
35
|
+
Pending requests expire automatically after **5 minutes**.
|
|
36
|
+
|
|
37
|
+
## CLI workflow (headless friendly)
|
|
38
|
+
|
|
39
|
+
```bash
|
|
40
|
+
quantumclaw nodes pending
|
|
41
|
+
quantumclaw nodes approve <requestId>
|
|
42
|
+
quantumclaw nodes reject <requestId>
|
|
43
|
+
quantumclaw nodes status
|
|
44
|
+
quantumclaw nodes rename --node <id|name|ip> --name "Living Room iPad"
|
|
45
|
+
```
|
|
46
|
+
|
|
47
|
+
`nodes status` shows paired/connected nodes and their capabilities.
|
|
48
|
+
|
|
49
|
+
## API surface (gateway protocol)
|
|
50
|
+
|
|
51
|
+
Events:
|
|
52
|
+
|
|
53
|
+
- `node.pair.requested` — emitted when a new pending request is created.
|
|
54
|
+
- `node.pair.resolved` — emitted when a request is approved/rejected/expired.
|
|
55
|
+
|
|
56
|
+
Methods:
|
|
57
|
+
|
|
58
|
+
- `node.pair.request` — create or reuse a pending request.
|
|
59
|
+
- `node.pair.list` — list pending + paired nodes.
|
|
60
|
+
- `node.pair.approve` — approve a pending request (issues token).
|
|
61
|
+
- `node.pair.reject` — reject a pending request.
|
|
62
|
+
- `node.pair.verify` — verify `{ nodeId, token }`.
|
|
63
|
+
|
|
64
|
+
Notes:
|
|
65
|
+
|
|
66
|
+
- `node.pair.request` is idempotent per node: repeated calls return the same
|
|
67
|
+
pending request.
|
|
68
|
+
- Approval **always** generates a fresh token; no token is ever returned from
|
|
69
|
+
`node.pair.request`.
|
|
70
|
+
- Requests may include `silent: true` as a hint for auto-approval flows.
|
|
71
|
+
|
|
72
|
+
## Auto-approval (macOS app)
|
|
73
|
+
|
|
74
|
+
The macOS app can optionally attempt a **silent approval** when:
|
|
75
|
+
|
|
76
|
+
- the request is marked `silent`, and
|
|
77
|
+
- the app can verify an SSH connection to the gateway host using the same user.
|
|
78
|
+
|
|
79
|
+
If silent approval fails, it falls back to the normal “Approve/Reject” prompt.
|
|
80
|
+
|
|
81
|
+
## Storage (local, private)
|
|
82
|
+
|
|
83
|
+
Pairing state is stored under the Gateway state directory (default `~/.quantumclaw`):
|
|
84
|
+
|
|
85
|
+
- `~/.quantumclaw/nodes/paired.json`
|
|
86
|
+
- `~/.quantumclaw/nodes/pending.json`
|
|
87
|
+
|
|
88
|
+
If you override `QUANTUMCLAW_STATE_DIR`, the `nodes/` folder moves with it.
|
|
89
|
+
|
|
90
|
+
Security notes:
|
|
91
|
+
|
|
92
|
+
- Tokens are secrets; treat `paired.json` as sensitive.
|
|
93
|
+
- Rotating a token requires re-approval (or deleting the node entry).
|
|
94
|
+
|
|
95
|
+
## Transport behavior
|
|
96
|
+
|
|
97
|
+
- The transport is **stateless**; it does not store membership.
|
|
98
|
+
- If the Gateway is offline or pairing is disabled, nodes cannot pair.
|
|
99
|
+
- If the Gateway is in remote mode, pairing still happens against the remote Gateway’s store.
|