nodmix 2026.5.25
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 +11573 -0
- package/LICENSE +21 -0
- package/README.md +486 -0
- package/docs/.i18n/README.md +81 -0
- package/docs/.i18n/ar-navigation.json +18 -0
- package/docs/.i18n/de-navigation.json +18 -0
- package/docs/.i18n/es-navigation.json +18 -0
- package/docs/.i18n/fr-navigation.json +18 -0
- package/docs/.i18n/glossary.ar.json +78 -0
- package/docs/.i18n/glossary.de.json +78 -0
- package/docs/.i18n/glossary.es.json +78 -0
- package/docs/.i18n/glossary.fa.json +78 -0
- package/docs/.i18n/glossary.fr.json +78 -0
- package/docs/.i18n/glossary.id.json +78 -0
- package/docs/.i18n/glossary.it.json +78 -0
- package/docs/.i18n/glossary.ja-JP.json +98 -0
- package/docs/.i18n/glossary.ko.json +78 -0
- package/docs/.i18n/glossary.nl.json +78 -0
- package/docs/.i18n/glossary.pl.json +78 -0
- package/docs/.i18n/glossary.pt-BR.json +78 -0
- package/docs/.i18n/glossary.th.json +78 -0
- package/docs/.i18n/glossary.tr.json +78 -0
- package/docs/.i18n/glossary.uk.json +78 -0
- package/docs/.i18n/glossary.vi.json +78 -0
- package/docs/.i18n/glossary.zh-CN.json +1002 -0
- package/docs/.i18n/glossary.zh-TW.json +78 -0
- package/docs/.i18n/id-navigation.json +18 -0
- package/docs/.i18n/it-navigation.json +18 -0
- package/docs/.i18n/ja-navigation.json +18 -0
- package/docs/.i18n/ko-navigation.json +18 -0
- package/docs/.i18n/pl-navigation.json +18 -0
- package/docs/.i18n/pt-BR-navigation.json +18 -0
- package/docs/.i18n/tr-navigation.json +18 -0
- package/docs/.i18n/translation-workflow.md +111 -0
- package/docs/.i18n/zh-Hans-navigation.json +542 -0
- package/docs/AGENTS.md +36 -0
- package/docs/announcements/bluebubbles-imessage.md +79 -0
- package/docs/assets/install-script.svg +1 -0
- package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
- package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
- package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
- package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
- package/docs/assets/macos-onboarding/05-permissions.png +0 -0
- package/docs/assets/openclaw-logo-text-dark.png +0 -0
- package/docs/assets/openclaw-logo-text-dark.svg +418 -0
- package/docs/assets/openclaw-logo-text.png +0 -0
- package/docs/assets/openclaw-logo-text.svg +418 -0
- package/docs/assets/pixel-lobster.svg +60 -0
- package/docs/assets/pr/quick-settings-browser-tools.png +0 -0
- package/docs/assets/showcase/agents-ui.jpg +0 -0
- package/docs/assets/showcase/bambu-cli.png +0 -0
- package/docs/assets/showcase/codexmonitor.png +0 -0
- package/docs/assets/showcase/gohome-grafana.png +0 -0
- package/docs/assets/showcase/ios-testflight.jpg +0 -0
- package/docs/assets/showcase/oura-health.png +0 -0
- package/docs/assets/showcase/padel-cli.svg +11 -0
- package/docs/assets/showcase/padel-screenshot.jpg +0 -0
- package/docs/assets/showcase/papla-tts.jpg +0 -0
- package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
- package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
- package/docs/assets/showcase/roborock-status.svg +13 -0
- package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
- package/docs/assets/showcase/snag.png +0 -0
- package/docs/assets/showcase/tesco-shop.jpg +0 -0
- package/docs/assets/showcase/wienerlinien.png +0 -0
- package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
- package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
- package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
- package/docs/assets/sponsors/blacksmith-light.svg +14 -0
- package/docs/assets/sponsors/blacksmith.svg +14 -0
- package/docs/assets/sponsors/convex-light.svg +16 -0
- package/docs/assets/sponsors/convex.svg +16 -0
- package/docs/assets/sponsors/github-light.svg +3 -0
- package/docs/assets/sponsors/github.svg +3 -0
- package/docs/assets/sponsors/nvidia-dark.svg +9 -0
- package/docs/assets/sponsors/nvidia.svg +9 -0
- package/docs/assets/sponsors/openai-light.svg +3 -0
- package/docs/assets/sponsors/openai.svg +3 -0
- package/docs/assets/sponsors/vercel-light.svg +5 -0
- package/docs/assets/sponsors/vercel.svg +5 -0
- package/docs/auth-credential-semantics.md +124 -0
- package/docs/automation/auth-monitoring.md +11 -0
- package/docs/automation/clawflow.md +12 -0
- package/docs/automation/cron-jobs.md +500 -0
- package/docs/automation/cron-vs-heartbeat.md +11 -0
- package/docs/automation/gmail-pubsub.md +11 -0
- package/docs/automation/hooks.md +365 -0
- package/docs/automation/index.md +135 -0
- package/docs/automation/poll.md +12 -0
- package/docs/automation/standing-orders.md +250 -0
- package/docs/automation/taskflow.md +155 -0
- package/docs/automation/tasks.md +374 -0
- package/docs/automation/troubleshooting.md +12 -0
- package/docs/automation/webhook.md +12 -0
- package/docs/brave-search.md +11 -0
- package/docs/channels/access-groups.md +201 -0
- package/docs/channels/ambient-room-events.md +214 -0
- package/docs/channels/bot-loop-protection.md +131 -0
- package/docs/channels/broadcast-groups.md +472 -0
- package/docs/channels/channel-routing.md +162 -0
- package/docs/channels/clickclack.md +138 -0
- package/docs/channels/discord.md +1762 -0
- package/docs/channels/feishu.md +502 -0
- package/docs/channels/googlechat.md +284 -0
- package/docs/channels/group-messages.md +95 -0
- package/docs/channels/groups.md +519 -0
- package/docs/channels/imessage-from-bluebubbles.md +259 -0
- package/docs/channels/imessage.md +813 -0
- package/docs/channels/index.md +64 -0
- package/docs/channels/irc.md +253 -0
- package/docs/channels/line.md +243 -0
- package/docs/channels/location.md +71 -0
- package/docs/channels/matrix-migration.md +370 -0
- package/docs/channels/matrix-presentation.md +77 -0
- package/docs/channels/matrix-push-rules.md +150 -0
- package/docs/channels/matrix.md +921 -0
- package/docs/channels/mattermost.md +542 -0
- package/docs/channels/msteams.md +1042 -0
- package/docs/channels/nextcloud-talk.md +176 -0
- package/docs/channels/nostr.md +253 -0
- package/docs/channels/pairing.md +214 -0
- package/docs/channels/qqbot.md +309 -0
- package/docs/channels/signal.md +400 -0
- package/docs/channels/slack.md +1564 -0
- package/docs/channels/synology-chat.md +187 -0
- package/docs/channels/telegram.md +1107 -0
- package/docs/channels/tlon.md +296 -0
- package/docs/channels/troubleshooting.md +161 -0
- package/docs/channels/twitch.md +431 -0
- package/docs/channels/wechat.md +171 -0
- package/docs/channels/whatsapp.md +739 -0
- package/docs/channels/yuanbao.md +416 -0
- package/docs/channels/zalo.md +253 -0
- package/docs/channels/zalouser.md +199 -0
- package/docs/ci.md +612 -0
- package/docs/clawhub/publishing.md +96 -0
- package/docs/cli/acp.md +370 -0
- package/docs/cli/agent.md +103 -0
- package/docs/cli/agents.md +232 -0
- package/docs/cli/approvals.md +190 -0
- package/docs/cli/backup.md +97 -0
- package/docs/cli/browser.md +307 -0
- package/docs/cli/channels.md +154 -0
- package/docs/cli/clawbot.md +25 -0
- package/docs/cli/commitments.md +90 -0
- package/docs/cli/completion.md +39 -0
- package/docs/cli/config.md +504 -0
- package/docs/cli/configure.md +77 -0
- package/docs/cli/crestodian.md +332 -0
- package/docs/cli/cron.md +281 -0
- package/docs/cli/daemon.md +67 -0
- package/docs/cli/dashboard.md +33 -0
- package/docs/cli/devices.md +204 -0
- package/docs/cli/directory.md +68 -0
- package/docs/cli/dns.md +53 -0
- package/docs/cli/docs.md +73 -0
- package/docs/cli/doctor.md +237 -0
- package/docs/cli/flows.md +52 -0
- package/docs/cli/gateway.md +567 -0
- package/docs/cli/health.md +43 -0
- package/docs/cli/hooks.md +345 -0
- package/docs/cli/index.md +396 -0
- package/docs/cli/infer.md +364 -0
- package/docs/cli/logs.md +65 -0
- package/docs/cli/mcp.md +529 -0
- package/docs/cli/memory.md +183 -0
- package/docs/cli/message.md +317 -0
- package/docs/cli/migrate.md +290 -0
- package/docs/cli/models.md +224 -0
- package/docs/cli/node.md +177 -0
- package/docs/cli/nodes.md +76 -0
- package/docs/cli/onboard.md +245 -0
- package/docs/cli/pairing.md +77 -0
- package/docs/cli/path.md +502 -0
- package/docs/cli/plugins.md +454 -0
- package/docs/cli/policy.md +418 -0
- package/docs/cli/proxy.md +89 -0
- package/docs/cli/qr.md +56 -0
- package/docs/cli/reset.md +39 -0
- package/docs/cli/sandbox.md +208 -0
- package/docs/cli/secrets.md +202 -0
- package/docs/cli/security.md +124 -0
- package/docs/cli/sessions.md +164 -0
- package/docs/cli/setup.md +59 -0
- package/docs/cli/skills.md +102 -0
- package/docs/cli/status.md +45 -0
- package/docs/cli/system.md +89 -0
- package/docs/cli/tasks.md +111 -0
- package/docs/cli/tui.md +89 -0
- package/docs/cli/uninstall.md +44 -0
- package/docs/cli/update.md +242 -0
- package/docs/cli/voicecall.md +204 -0
- package/docs/cli/webhooks.md +117 -0
- package/docs/cli/wiki.md +256 -0
- package/docs/concepts/active-memory.md +856 -0
- package/docs/concepts/agent-loop.md +185 -0
- package/docs/concepts/agent-runtimes.md +243 -0
- package/docs/concepts/agent-workspace.md +230 -0
- package/docs/concepts/agent.md +136 -0
- package/docs/concepts/architecture.md +154 -0
- package/docs/concepts/channel-docking.md +145 -0
- package/docs/concepts/commitments.md +150 -0
- package/docs/concepts/compaction.md +203 -0
- package/docs/concepts/context-engine.md +306 -0
- package/docs/concepts/context.md +199 -0
- package/docs/concepts/delegate-architecture.md +319 -0
- package/docs/concepts/dreaming.md +261 -0
- package/docs/concepts/experimental-features.md +108 -0
- package/docs/concepts/features.md +91 -0
- package/docs/concepts/mantis-slack-desktop-runbook.md +202 -0
- package/docs/concepts/mantis.md +740 -0
- package/docs/concepts/markdown-formatting.md +139 -0
- package/docs/concepts/memory-builtin.md +146 -0
- package/docs/concepts/memory-honcho.md +144 -0
- package/docs/concepts/memory-qmd.md +271 -0
- package/docs/concepts/memory-search.md +166 -0
- package/docs/concepts/memory.md +258 -0
- package/docs/concepts/message-lifecycle-refactor.md +1128 -0
- package/docs/concepts/messages.md +214 -0
- package/docs/concepts/model-failover.md +385 -0
- package/docs/concepts/model-providers.md +715 -0
- package/docs/concepts/models.md +370 -0
- package/docs/concepts/multi-agent.md +619 -0
- package/docs/concepts/oauth.md +198 -0
- package/docs/concepts/openclaw-sdk.md +323 -0
- package/docs/concepts/parallel-specialist-lanes.md +127 -0
- package/docs/concepts/personal-agent-benchmark-pack.md +74 -0
- package/docs/concepts/presence.md +117 -0
- package/docs/concepts/progress-drafts.md +362 -0
- package/docs/concepts/qa-e2e-automation.md +820 -0
- package/docs/concepts/qa-matrix.md +139 -0
- package/docs/concepts/queue-steering.md +90 -0
- package/docs/concepts/queue.md +122 -0
- package/docs/concepts/retry.md +86 -0
- package/docs/concepts/session-pruning.md +104 -0
- package/docs/concepts/session-tool.md +190 -0
- package/docs/concepts/session.md +164 -0
- package/docs/concepts/soul.md +116 -0
- package/docs/concepts/streaming.md +251 -0
- package/docs/concepts/system-prompt.md +310 -0
- package/docs/concepts/timezone.md +47 -0
- package/docs/concepts/typebox.md +309 -0
- package/docs/concepts/typing-indicators.md +88 -0
- package/docs/concepts/usage-tracking.md +66 -0
- package/docs/date-time.md +126 -0
- package/docs/debug/node-issue.md +90 -0
- package/docs/diagnostics/flags.md +138 -0
- package/docs/docs.json +1832 -0
- package/docs/gateway/authentication.md +239 -0
- package/docs/gateway/background-process.md +147 -0
- package/docs/gateway/bonjour.md +303 -0
- package/docs/gateway/bridge-protocol.md +94 -0
- package/docs/gateway/cli-backends.md +420 -0
- package/docs/gateway/config-agents.md +1514 -0
- package/docs/gateway/config-channels.md +945 -0
- package/docs/gateway/config-tools.md +769 -0
- package/docs/gateway/configuration-examples.md +705 -0
- package/docs/gateway/configuration-reference.md +1393 -0
- package/docs/gateway/configuration.md +737 -0
- package/docs/gateway/diagnostics.md +213 -0
- package/docs/gateway/discovery.md +154 -0
- package/docs/gateway/doctor.md +574 -0
- package/docs/gateway/gateway-lock.md +37 -0
- package/docs/gateway/health.md +73 -0
- package/docs/gateway/heartbeat.md +493 -0
- package/docs/gateway/index.md +383 -0
- package/docs/gateway/local-model-services.md +205 -0
- package/docs/gateway/local-models.md +355 -0
- package/docs/gateway/logging.md +149 -0
- package/docs/gateway/multiple-gateways.md +178 -0
- package/docs/gateway/network-model.md +15 -0
- package/docs/gateway/openai-http-api.md +350 -0
- package/docs/gateway/openresponses-http-api.md +347 -0
- package/docs/gateway/openshell.md +316 -0
- package/docs/gateway/opentelemetry.md +404 -0
- package/docs/gateway/operator-scopes.md +111 -0
- package/docs/gateway/pairing.md +207 -0
- package/docs/gateway/prometheus.md +230 -0
- package/docs/gateway/protocol.md +803 -0
- package/docs/gateway/remote-gateway-readme.md +169 -0
- package/docs/gateway/remote.md +280 -0
- package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +146 -0
- package/docs/gateway/sandboxing.md +545 -0
- package/docs/gateway/secrets-plan-contract.md +114 -0
- package/docs/gateway/secrets.md +609 -0
- package/docs/gateway/security/audit-checks.md +127 -0
- package/docs/gateway/security/index.md +1326 -0
- package/docs/gateway/security/secure-file-operations.md +76 -0
- package/docs/gateway/tailscale.md +156 -0
- package/docs/gateway/tools-invoke-http-api.md +169 -0
- package/docs/gateway/troubleshooting.md +772 -0
- package/docs/gateway/trusted-proxy-auth.md +451 -0
- package/docs/help/debugging.md +344 -0
- package/docs/help/environment.md +214 -0
- package/docs/help/faq-first-run.md +867 -0
- package/docs/help/faq-models.md +553 -0
- package/docs/help/faq.md +1975 -0
- package/docs/help/gpt55-codex-agentic-parity-maintainers.md +196 -0
- package/docs/help/gpt55-codex-agentic-parity.md +230 -0
- package/docs/help/index.md +39 -0
- package/docs/help/scripts.md +56 -0
- package/docs/help/testing-live.md +580 -0
- package/docs/help/testing-updates-plugins.md +291 -0
- package/docs/help/testing.md +928 -0
- package/docs/help/troubleshooting.md +424 -0
- package/docs/images/configure-model-picker-unsearchable.png +0 -0
- package/docs/images/feishu-get-group-id.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 +233 -0
- package/docs/install/azure.md +315 -0
- package/docs/install/bun.md +59 -0
- package/docs/install/clawdock.md +112 -0
- package/docs/install/development-channels.md +135 -0
- package/docs/install/digitalocean.md +174 -0
- package/docs/install/docker-vm-runtime.md +154 -0
- package/docs/install/docker.md +562 -0
- package/docs/install/exe-dev.md +201 -0
- package/docs/install/fly.md +524 -0
- package/docs/install/gcp.md +418 -0
- package/docs/install/hetzner.md +285 -0
- package/docs/install/hostinger.md +98 -0
- package/docs/install/index.md +221 -0
- package/docs/install/installer.md +455 -0
- package/docs/install/kubernetes.md +196 -0
- package/docs/install/macos-vm.md +281 -0
- package/docs/install/migrating-claude.md +165 -0
- package/docs/install/migrating-hermes.md +177 -0
- package/docs/install/migrating.md +137 -0
- package/docs/install/nix.md +112 -0
- package/docs/install/node.md +142 -0
- package/docs/install/northflank.mdx +44 -0
- package/docs/install/oracle.md +218 -0
- package/docs/install/podman.md +210 -0
- package/docs/install/railway.mdx +92 -0
- package/docs/install/raspberry-pi.md +234 -0
- package/docs/install/render.mdx +167 -0
- package/docs/install/uninstall.md +131 -0
- package/docs/install/updating.md +280 -0
- package/docs/logging.md +318 -0
- package/docs/nav-tabs-underline.js +100 -0
- package/docs/network.md +72 -0
- package/docs/nodes/audio.md +215 -0
- package/docs/nodes/camera.md +166 -0
- package/docs/nodes/images.md +77 -0
- package/docs/nodes/index.md +439 -0
- package/docs/nodes/location-command.md +102 -0
- package/docs/nodes/media-understanding.md +469 -0
- package/docs/nodes/talk.md +154 -0
- package/docs/nodes/troubleshooting.md +123 -0
- package/docs/nodes/voicewake.md +93 -0
- package/docs/perplexity.md +11 -0
- package/docs/pi-dev.md +82 -0
- package/docs/pi.md +573 -0
- package/docs/plan/codex-context-engine-harness.md +624 -0
- package/docs/plan/ui-channels.md +284 -0
- package/docs/platforms/android.md +285 -0
- package/docs/platforms/digitalocean.md +12 -0
- package/docs/platforms/index.md +60 -0
- package/docs/platforms/ios.md +283 -0
- package/docs/platforms/linux.md +141 -0
- package/docs/platforms/mac/bundled-gateway.md +79 -0
- package/docs/platforms/mac/canvas.md +128 -0
- package/docs/platforms/mac/child-process.md +72 -0
- package/docs/platforms/mac/dev-setup.md +112 -0
- package/docs/platforms/mac/health.md +39 -0
- package/docs/platforms/mac/icon.md +36 -0
- package/docs/platforms/mac/logging.md +62 -0
- package/docs/platforms/mac/menu-bar.md +93 -0
- package/docs/platforms/mac/peekaboo.md +92 -0
- package/docs/platforms/mac/permissions.md +53 -0
- package/docs/platforms/mac/remote.md +123 -0
- package/docs/platforms/mac/signing.md +52 -0
- package/docs/platforms/mac/skills.md +43 -0
- package/docs/platforms/mac/voice-overlay.md +66 -0
- package/docs/platforms/mac/voicewake.md +73 -0
- package/docs/platforms/mac/webchat.md +54 -0
- package/docs/platforms/mac/xpc.md +66 -0
- package/docs/platforms/macos.md +226 -0
- package/docs/platforms/oracle.md +12 -0
- package/docs/platforms/raspberry-pi.md +13 -0
- package/docs/platforms/windows.md +286 -0
- package/docs/plugins/adding-capabilities.md +133 -0
- package/docs/plugins/admin-http-rpc.md +216 -0
- package/docs/plugins/agent-tools.md +13 -0
- package/docs/plugins/architecture-internals.md +1195 -0
- package/docs/plugins/architecture.md +481 -0
- package/docs/plugins/building-extensions.md +13 -0
- package/docs/plugins/building-plugins.md +330 -0
- package/docs/plugins/bundles.md +310 -0
- package/docs/plugins/cli-backend-plugins.md +310 -0
- package/docs/plugins/codex-computer-use.md +293 -0
- package/docs/plugins/codex-harness-reference.md +409 -0
- package/docs/plugins/codex-harness-runtime.md +247 -0
- package/docs/plugins/codex-harness.md +746 -0
- package/docs/plugins/codex-native-plugins.md +276 -0
- package/docs/plugins/community.md +77 -0
- package/docs/plugins/compatibility.md +164 -0
- package/docs/plugins/dependency-resolution.md +143 -0
- package/docs/plugins/google-meet.md +1737 -0
- package/docs/plugins/hooks.md +459 -0
- package/docs/plugins/install-overrides.md +80 -0
- package/docs/plugins/manage-plugins.md +210 -0
- package/docs/plugins/manifest.md +1359 -0
- package/docs/plugins/memory-lancedb.md +385 -0
- package/docs/plugins/memory-wiki.md +529 -0
- package/docs/plugins/message-presentation.md +473 -0
- package/docs/plugins/oc-path.md +166 -0
- package/docs/plugins/plugin-inventory.md +182 -0
- package/docs/plugins/reference/acpx.md +23 -0
- package/docs/plugins/reference/admin-http-rpc.md +23 -0
- package/docs/plugins/reference/alibaba.md +23 -0
- package/docs/plugins/reference/amazon-bedrock-mantle.md +23 -0
- package/docs/plugins/reference/amazon-bedrock.md +23 -0
- package/docs/plugins/reference/anthropic-vertex.md +19 -0
- package/docs/plugins/reference/anthropic.md +23 -0
- package/docs/plugins/reference/arcee.md +23 -0
- package/docs/plugins/reference/azure-speech.md +23 -0
- package/docs/plugins/reference/bonjour.md +19 -0
- package/docs/plugins/reference/brave.md +23 -0
- package/docs/plugins/reference/browser.md +23 -0
- package/docs/plugins/reference/byteplus.md +19 -0
- package/docs/plugins/reference/canvas.md +19 -0
- package/docs/plugins/reference/cerebras.md +23 -0
- package/docs/plugins/reference/chutes.md +23 -0
- package/docs/plugins/reference/clickclack.md +23 -0
- package/docs/plugins/reference/cloudflare-ai-gateway.md +23 -0
- package/docs/plugins/reference/codex.md +23 -0
- package/docs/plugins/reference/comfy.md +23 -0
- package/docs/plugins/reference/copilot-proxy.md +19 -0
- package/docs/plugins/reference/deepgram.md +23 -0
- package/docs/plugins/reference/deepinfra.md +23 -0
- package/docs/plugins/reference/deepseek.md +23 -0
- package/docs/plugins/reference/diagnostics-otel.md +19 -0
- package/docs/plugins/reference/diagnostics-prometheus.md +19 -0
- package/docs/plugins/reference/diffs.md +19 -0
- package/docs/plugins/reference/discord.md +23 -0
- package/docs/plugins/reference/document-extract.md +23 -0
- package/docs/plugins/reference/duckduckgo.md +23 -0
- package/docs/plugins/reference/elevenlabs.md +23 -0
- package/docs/plugins/reference/exa.md +23 -0
- package/docs/plugins/reference/fal.md +23 -0
- package/docs/plugins/reference/feishu.md +23 -0
- package/docs/plugins/reference/file-transfer.md +19 -0
- package/docs/plugins/reference/firecrawl.md +23 -0
- package/docs/plugins/reference/fireworks.md +23 -0
- package/docs/plugins/reference/github-copilot.md +23 -0
- package/docs/plugins/reference/google-meet.md +23 -0
- package/docs/plugins/reference/google.md +23 -0
- package/docs/plugins/reference/googlechat.md +23 -0
- package/docs/plugins/reference/gradium.md +23 -0
- package/docs/plugins/reference/groq.md +23 -0
- package/docs/plugins/reference/huggingface.md +23 -0
- package/docs/plugins/reference/imessage.md +23 -0
- package/docs/plugins/reference/inworld.md +23 -0
- package/docs/plugins/reference/irc.md +23 -0
- package/docs/plugins/reference/kilocode.md +23 -0
- package/docs/plugins/reference/kimi.md +23 -0
- package/docs/plugins/reference/line.md +23 -0
- package/docs/plugins/reference/litellm.md +23 -0
- package/docs/plugins/reference/llm-task.md +19 -0
- package/docs/plugins/reference/lmstudio.md +23 -0
- package/docs/plugins/reference/lobster.md +19 -0
- package/docs/plugins/reference/matrix.md +23 -0
- package/docs/plugins/reference/mattermost.md +23 -0
- package/docs/plugins/reference/memory-core.md +19 -0
- package/docs/plugins/reference/memory-lancedb.md +23 -0
- package/docs/plugins/reference/memory-wiki.md +23 -0
- package/docs/plugins/reference/microsoft-foundry.md +19 -0
- package/docs/plugins/reference/microsoft.md +19 -0
- package/docs/plugins/reference/migrate-claude.md +19 -0
- package/docs/plugins/reference/migrate-hermes.md +19 -0
- package/docs/plugins/reference/minimax.md +23 -0
- package/docs/plugins/reference/mistral.md +23 -0
- package/docs/plugins/reference/moonshot.md +23 -0
- package/docs/plugins/reference/msteams.md +23 -0
- package/docs/plugins/reference/nextcloud-talk.md +23 -0
- package/docs/plugins/reference/nostr.md +23 -0
- package/docs/plugins/reference/nvidia.md +23 -0
- package/docs/plugins/reference/oc-path.md +23 -0
- package/docs/plugins/reference/ollama.md +23 -0
- package/docs/plugins/reference/open-prose.md +19 -0
- package/docs/plugins/reference/openai.md +23 -0
- package/docs/plugins/reference/opencode-go.md +23 -0
- package/docs/plugins/reference/opencode.md +23 -0
- package/docs/plugins/reference/openrouter.md +23 -0
- package/docs/plugins/reference/openshell.md +19 -0
- package/docs/plugins/reference/perplexity.md +23 -0
- package/docs/plugins/reference/policy.md +23 -0
- package/docs/plugins/reference/qa-channel.md +23 -0
- package/docs/plugins/reference/qa-lab.md +19 -0
- package/docs/plugins/reference/qa-matrix.md +19 -0
- package/docs/plugins/reference/qianfan.md +23 -0
- package/docs/plugins/reference/qqbot.md +23 -0
- package/docs/plugins/reference/qwen.md +23 -0
- package/docs/plugins/reference/runway.md +23 -0
- package/docs/plugins/reference/searxng.md +19 -0
- package/docs/plugins/reference/senseaudio.md +23 -0
- package/docs/plugins/reference/sglang.md +23 -0
- package/docs/plugins/reference/signal.md +23 -0
- package/docs/plugins/reference/skill-workshop.md +23 -0
- package/docs/plugins/reference/slack.md +23 -0
- package/docs/plugins/reference/stepfun.md +23 -0
- package/docs/plugins/reference/synology-chat.md +23 -0
- package/docs/plugins/reference/synthetic.md +23 -0
- package/docs/plugins/reference/tavily.md +23 -0
- package/docs/plugins/reference/telegram.md +23 -0
- package/docs/plugins/reference/tencent.md +23 -0
- package/docs/plugins/reference/tlon.md +23 -0
- package/docs/plugins/reference/together.md +23 -0
- package/docs/plugins/reference/tokenjuice.md +23 -0
- package/docs/plugins/reference/tts-local-cli.md +19 -0
- package/docs/plugins/reference/twitch.md +23 -0
- package/docs/plugins/reference/venice.md +23 -0
- package/docs/plugins/reference/vercel-ai-gateway.md +23 -0
- package/docs/plugins/reference/vllm.md +23 -0
- package/docs/plugins/reference/voice-call.md +23 -0
- package/docs/plugins/reference/volcengine.md +23 -0
- package/docs/plugins/reference/voyage.md +19 -0
- package/docs/plugins/reference/vydra.md +23 -0
- package/docs/plugins/reference/web-readability.md +19 -0
- package/docs/plugins/reference/webhooks.md +23 -0
- package/docs/plugins/reference/whatsapp.md +23 -0
- package/docs/plugins/reference/xai.md +23 -0
- package/docs/plugins/reference/xiaomi.md +23 -0
- package/docs/plugins/reference/zai.md +23 -0
- package/docs/plugins/reference/zalo.md +23 -0
- package/docs/plugins/reference/zalouser.md +24 -0
- package/docs/plugins/reference.md +138 -0
- package/docs/plugins/sdk-agent-harness.md +339 -0
- package/docs/plugins/sdk-channel-ingress.md +137 -0
- package/docs/plugins/sdk-channel-message.md +458 -0
- package/docs/plugins/sdk-channel-plugins.md +762 -0
- package/docs/plugins/sdk-channel-turn.md +580 -0
- package/docs/plugins/sdk-entrypoints.md +333 -0
- package/docs/plugins/sdk-migration.md +949 -0
- package/docs/plugins/sdk-overview.md +501 -0
- package/docs/plugins/sdk-provider-plugins.md +807 -0
- package/docs/plugins/sdk-runtime.md +676 -0
- package/docs/plugins/sdk-setup.md +550 -0
- package/docs/plugins/sdk-subpaths.md +396 -0
- package/docs/plugins/sdk-testing.md +401 -0
- package/docs/plugins/skill-workshop.md +713 -0
- package/docs/plugins/tool-plugins.md +411 -0
- package/docs/plugins/voice-call.md +943 -0
- package/docs/plugins/webhooks.md +192 -0
- package/docs/plugins/zalouser.md +86 -0
- package/docs/prose.md +137 -0
- package/docs/providers/alibaba.md +158 -0
- package/docs/providers/anthropic.md +344 -0
- package/docs/providers/arcee.md +144 -0
- package/docs/providers/azure-speech.md +119 -0
- package/docs/providers/bedrock-mantle.md +211 -0
- package/docs/providers/bedrock.md +414 -0
- package/docs/providers/cerebras.md +130 -0
- package/docs/providers/chutes.md +153 -0
- package/docs/providers/claude-max-api-proxy.md +188 -0
- package/docs/providers/cloudflare-ai-gateway.md +119 -0
- package/docs/providers/comfy.md +362 -0
- package/docs/providers/deepgram.md +184 -0
- package/docs/providers/deepinfra.md +87 -0
- package/docs/providers/deepseek.md +146 -0
- package/docs/providers/ds4.md +309 -0
- package/docs/providers/elevenlabs.md +130 -0
- package/docs/providers/fal.md +204 -0
- package/docs/providers/fireworks.md +144 -0
- package/docs/providers/github-copilot.md +225 -0
- package/docs/providers/glm.md +137 -0
- package/docs/providers/google.md +472 -0
- package/docs/providers/gradium.md +123 -0
- package/docs/providers/groq.md +180 -0
- package/docs/providers/huggingface.md +235 -0
- package/docs/providers/index.md +102 -0
- package/docs/providers/inferrs.md +272 -0
- package/docs/providers/inworld.md +120 -0
- package/docs/providers/kilocode.md +135 -0
- package/docs/providers/litellm.md +234 -0
- package/docs/providers/lmstudio.md +224 -0
- package/docs/providers/minimax.md +505 -0
- package/docs/providers/mistral.md +235 -0
- package/docs/providers/models.md +65 -0
- package/docs/providers/moonshot.md +413 -0
- package/docs/providers/nvidia.md +140 -0
- package/docs/providers/ollama.md +1180 -0
- package/docs/providers/openai.md +1057 -0
- package/docs/providers/opencode-go.md +123 -0
- package/docs/providers/opencode.md +149 -0
- package/docs/providers/openrouter.md +349 -0
- package/docs/providers/perplexity-provider.md +123 -0
- package/docs/providers/qianfan.md +132 -0
- package/docs/providers/qwen.md +332 -0
- package/docs/providers/runway.md +103 -0
- package/docs/providers/senseaudio.md +68 -0
- package/docs/providers/sglang.md +161 -0
- package/docs/providers/stepfun.md +229 -0
- package/docs/providers/synthetic.md +154 -0
- package/docs/providers/tencent.md +130 -0
- package/docs/providers/together.md +141 -0
- package/docs/providers/venice.md +315 -0
- package/docs/providers/vercel-ai-gateway.md +128 -0
- package/docs/providers/vllm.md +383 -0
- package/docs/providers/volcengine.md +199 -0
- package/docs/providers/vydra.md +180 -0
- package/docs/providers/xai.md +560 -0
- package/docs/providers/xiaomi.md +188 -0
- package/docs/providers/zai.md +203 -0
- package/docs/refactor/access.md +9 -0
- package/docs/refactor/acp.md +298 -0
- package/docs/refactor/canvas.md +131 -0
- package/docs/refactor/ingress-core.md +341 -0
- package/docs/reference/AGENTS.default.md +129 -0
- package/docs/reference/RELEASING.md +767 -0
- package/docs/reference/api-usage-costs.md +202 -0
- package/docs/reference/application-modernization-plan.md +208 -0
- package/docs/reference/code-mode.md +757 -0
- package/docs/reference/credits.md +33 -0
- package/docs/reference/device-models.md +50 -0
- package/docs/reference/full-release-validation.md +202 -0
- package/docs/reference/memory-config.md +630 -0
- package/docs/reference/openclaw-sdk-api-design.md +390 -0
- package/docs/reference/prompt-caching.md +358 -0
- package/docs/reference/rich-output-protocol.md +79 -0
- package/docs/reference/rpc.md +43 -0
- package/docs/reference/secretref-credential-surface.md +159 -0
- package/docs/reference/secretref-user-supplied-credentials-matrix.json +663 -0
- package/docs/reference/session-management-compaction.md +461 -0
- package/docs/reference/templates/AGENTS.dev.md +89 -0
- package/docs/reference/templates/AGENTS.md +225 -0
- package/docs/reference/templates/BOOT.md +16 -0
- package/docs/reference/templates/BOOTSTRAP.md +66 -0
- package/docs/reference/templates/HEARTBEAT.md +16 -0
- package/docs/reference/templates/IDENTITY.dev.md +52 -0
- package/docs/reference/templates/IDENTITY.md +34 -0
- package/docs/reference/templates/SOUL.dev.md +82 -0
- package/docs/reference/templates/SOUL.md +49 -0
- package/docs/reference/templates/TOOLS.dev.md +29 -0
- package/docs/reference/templates/TOOLS.md +51 -0
- package/docs/reference/templates/USER.dev.md +23 -0
- package/docs/reference/templates/USER.md +28 -0
- package/docs/reference/test.md +239 -0
- package/docs/reference/token-use.md +233 -0
- package/docs/reference/transcript-hygiene.md +214 -0
- package/docs/reference/wizard.md +252 -0
- package/docs/security/CONTRIBUTING-THREAT-MODEL.md +101 -0
- package/docs/security/THREAT-MODEL-ATLAS.md +611 -0
- package/docs/security/formal-verification.md +170 -0
- package/docs/security/incident-response.md +59 -0
- package/docs/security/network-proxy.md +268 -0
- package/docs/snippets/plugin-publish/minimal-openclaw.plugin.json +12 -0
- package/docs/snippets/plugin-publish/minimal-package.json +16 -0
- package/docs/start/bootstrapping.md +49 -0
- package/docs/start/docs-directory.md +69 -0
- package/docs/start/getting-started.md +152 -0
- package/docs/start/hubs.md +201 -0
- package/docs/start/lore.md +223 -0
- package/docs/start/onboarding-overview.md +72 -0
- package/docs/start/onboarding.md +95 -0
- package/docs/start/openclaw.md +244 -0
- package/docs/start/quickstart.md +25 -0
- package/docs/start/setup.md +178 -0
- package/docs/start/showcase.md +383 -0
- package/docs/start/wizard-cli-automation.md +232 -0
- package/docs/start/wizard-cli-reference.md +331 -0
- package/docs/start/wizard.md +141 -0
- package/docs/style.css +184 -0
- package/docs/superpowers/specs/2026-04-22-tweakcn-custom-theme-import-design.md +316 -0
- package/docs/tools/acp-agents-setup.md +352 -0
- package/docs/tools/acp-agents.md +847 -0
- package/docs/tools/agent-send.md +112 -0
- package/docs/tools/apply-patch.md +64 -0
- package/docs/tools/brave-search.md +139 -0
- package/docs/tools/browser-control.md +391 -0
- package/docs/tools/browser-linux-troubleshooting.md +173 -0
- package/docs/tools/browser-login.md +77 -0
- package/docs/tools/browser-wsl2-windows-remote-cdp-troubleshooting.md +219 -0
- package/docs/tools/browser.md +769 -0
- package/docs/tools/btw.md +159 -0
- package/docs/tools/capability-cookbook.md +12 -0
- package/docs/tools/clawhub.md +5 -0
- package/docs/tools/code-execution.md +173 -0
- package/docs/tools/creating-skills.md +120 -0
- package/docs/tools/diffs.md +506 -0
- package/docs/tools/duckduckgo-search.md +109 -0
- package/docs/tools/elevated.md +128 -0
- package/docs/tools/exa-search.md +152 -0
- package/docs/tools/exec-approvals-advanced.md +360 -0
- package/docs/tools/exec-approvals.md +474 -0
- package/docs/tools/exec.md +282 -0
- package/docs/tools/firecrawl.md +155 -0
- package/docs/tools/gemini-search.md +114 -0
- package/docs/tools/grok-search.md +113 -0
- package/docs/tools/image-generation.md +433 -0
- package/docs/tools/index.md +178 -0
- package/docs/tools/kimi-search.md +105 -0
- package/docs/tools/llm-task.md +137 -0
- package/docs/tools/lobster.md +365 -0
- package/docs/tools/loop-detection.md +154 -0
- package/docs/tools/media-overview.md +157 -0
- package/docs/tools/minimax-search.md +102 -0
- package/docs/tools/multi-agent-sandbox-tools.md +409 -0
- package/docs/tools/music-generation.md +371 -0
- package/docs/tools/ollama-search.md +153 -0
- package/docs/tools/pdf.md +195 -0
- package/docs/tools/perplexity-search.md +220 -0
- package/docs/tools/plugin.md +327 -0
- package/docs/tools/reactions.md +100 -0
- package/docs/tools/searxng-search.md +141 -0
- package/docs/tools/skills-config.md +195 -0
- package/docs/tools/skills.md +535 -0
- package/docs/tools/slash-commands.md +488 -0
- package/docs/tools/steer.md +84 -0
- package/docs/tools/subagents.md +650 -0
- package/docs/tools/tavily.md +162 -0
- package/docs/tools/thinking.md +140 -0
- package/docs/tools/tokenjuice.md +81 -0
- package/docs/tools/tool-search.md +269 -0
- package/docs/tools/trajectory.md +229 -0
- package/docs/tools/tts.md +1004 -0
- package/docs/tools/video-generation.md +552 -0
- package/docs/tools/web-fetch.md +195 -0
- package/docs/tools/web.md +459 -0
- package/docs/tts.md +11 -0
- package/docs/vps.md +139 -0
- package/docs/web/control-ui.md +503 -0
- package/docs/web/dashboard.md +107 -0
- package/docs/web/index.md +133 -0
- package/docs/web/tui.md +246 -0
- package/docs/web/webchat.md +99 -0
- package/docs/whatsapp-openclaw-ai-zh.jpg +0 -0
- package/docs/whatsapp-openclaw.jpg +0 -0
- package/nodmix.mjs +487 -0
- package/package.json +1852 -0
- package/patches/.gitkeep +0 -0
- package/patches/@agentclientprotocol__claude-agent-acp@0.36.1.patch +41 -0
- package/pnpm-workspace.yaml +63 -0
- package/scripts/crabbox-wrapper.mjs +353 -0
- package/scripts/lib/official-external-channel-catalog.json +559 -0
- package/scripts/lib/official-external-plugin-catalog.json +192 -0
- package/scripts/lib/official-external-provider-catalog.json +117 -0
- package/scripts/lib/package-dist-imports.mjs +171 -0
- package/scripts/npm-runner.mjs +91 -0
- package/scripts/postinstall-bundled-plugins.mjs +978 -0
- package/scripts/preinstall-package-manager-warning.mjs +64 -0
- package/scripts/windows-cmd-helpers.mjs +20 -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/camsnap/SKILL.md +45 -0
- package/skills/canvas/SKILL.md +78 -0
- package/skills/clawhub/SKILL.md +77 -0
- package/skills/coding-agent/SKILL.md +149 -0
- package/skills/diagram-maker/SKILL.md +53 -0
- package/skills/diagram-maker/references/excalidraw-patterns.md +85 -0
- package/skills/diagram-maker/references/svg-template.md +112 -0
- package/skills/discord/SKILL.md +136 -0
- package/skills/eightctl/SKILL.md +50 -0
- package/skills/gemini/SKILL.md +47 -0
- package/skills/gh-issues/SKILL.md +213 -0
- package/skills/gifgrep/SKILL.md +85 -0
- package/skills/github/SKILL.md +84 -0
- package/skills/gog/SKILL.md +116 -0
- package/skills/goplaces/SKILL.md +52 -0
- package/skills/healthcheck/SKILL.md +105 -0
- package/skills/himalaya/SKILL.md +80 -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/meme-maker/SKILL.md +42 -0
- package/skills/meme-maker/references/templates.json +358 -0
- package/skills/meme-maker/scripts/meme.mjs +398 -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 +319 -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/node-inspect-debugger/SKILL.md +85 -0
- package/skills/notion/SKILL.md +150 -0
- package/skills/obsidian/SKILL.md +119 -0
- package/skills/openai-whisper/SKILL.md +38 -0
- package/skills/openai-whisper-api/SKILL.md +71 -0
- package/skills/openai-whisper-api/scripts/transcribe.sh +154 -0
- package/skills/openhue/SKILL.md +112 -0
- package/skills/oracle/SKILL.md +126 -0
- package/skills/ordercli/SKILL.md +78 -0
- package/skills/peekaboo/SKILL.md +190 -0
- package/skills/pyproject.toml +10 -0
- package/skills/python-debugpy/SKILL.md +73 -0
- package/skills/sag/SKILL.md +87 -0
- package/skills/session-logs/SKILL.md +151 -0
- package/skills/sherpa-onnx-tts/SKILL.md +109 -0
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +178 -0
- package/skills/skill-creator/SKILL.md +78 -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 +169 -0
- package/skills/skill-creator/scripts/test_package_skill.py +161 -0
- package/skills/skill-creator/scripts/test_quick_validate.py +116 -0
- package/skills/slack/SKILL.md +78 -0
- package/skills/songsee/SKILL.md +49 -0
- package/skills/sonoscli/SKILL.md +65 -0
- package/skills/spike/SKILL.md +51 -0
- package/skills/spotify-player/SKILL.md +64 -0
- package/skills/summarize/SKILL.md +87 -0
- package/skills/taskflow/SKILL.md +149 -0
- package/skills/taskflow/examples/inbox-triage.lobster +33 -0
- package/skills/taskflow/examples/pr-intake.lobster +32 -0
- package/skills/taskflow-inbox-triage/SKILL.md +119 -0
- package/skills/things-mac/SKILL.md +86 -0
- package/skills/tmux/SKILL.md +91 -0
- package/skills/tmux/scripts/find-sessions.sh +112 -0
- package/skills/tmux/scripts/wait-for-text.sh +83 -0
- package/skills/trello/SKILL.md +108 -0
- package/skills/video-frames/SKILL.md +46 -0
- package/skills/video-frames/scripts/frame.sh +81 -0
- package/skills/voice-call/SKILL.md +45 -0
- package/skills/wacli/SKILL.md +72 -0
- package/skills/weather/SKILL.md +64 -0
- package/skills/xurl/SKILL.md +120 -0
|
@@ -0,0 +1,347 @@
|
|
|
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
|
+
Nodmix's Gateway can serve an OpenResponses-compatible `POST /v1/responses` endpoint.
|
|
10
|
+
|
|
11
|
+
This endpoint is **disabled by default**. Enable it in config first.
|
|
12
|
+
|
|
13
|
+
- `POST /v1/responses`
|
|
14
|
+
- Same port as the Gateway (WS + HTTP multiplex): `http://<gateway-host>:<port>/v1/responses`
|
|
15
|
+
|
|
16
|
+
Under the hood, requests are executed as a normal Gateway agent run (same codepath as
|
|
17
|
+
`nodmix agent`), so routing/permissions/config match your Gateway.
|
|
18
|
+
|
|
19
|
+
## Authentication, security, and routing
|
|
20
|
+
|
|
21
|
+
Operational behavior matches [OpenAI Chat Completions](/gateway/openai-http-api):
|
|
22
|
+
|
|
23
|
+
- use the matching Gateway HTTP auth path:
|
|
24
|
+
- shared-secret auth (`gateway.auth.mode="token"` or `"password"`): `Authorization: Bearer <token-or-password>`
|
|
25
|
+
- trusted-proxy auth (`gateway.auth.mode="trusted-proxy"`): identity-aware proxy headers from a configured trusted proxy source; same-host loopback proxies require explicit `gateway.auth.trustedProxy.allowLoopback = true`
|
|
26
|
+
- trusted-proxy local direct fallback: same-host callers with no `Forwarded`, `X-Forwarded-*`, or `X-Real-IP` headers can use `gateway.auth.password` / `NODMIX_GATEWAY_PASSWORD`
|
|
27
|
+
- private-ingress open auth (`gateway.auth.mode="none"`): no auth header
|
|
28
|
+
- treat the endpoint as full operator access for the gateway instance
|
|
29
|
+
- for shared-secret auth modes (`token` and `password`), ignore narrower bearer-declared `x-nodmix-scopes` values and restore the normal full operator defaults
|
|
30
|
+
- for trusted identity-bearing HTTP modes (for example trusted proxy auth or `gateway.auth.mode="none"`), honor `x-nodmix-scopes` when present and otherwise fall back to the normal operator default scope set
|
|
31
|
+
- select agents with `model: "nodmix"`, `model: "nodmix/default"`, `model: "nodmix/<agentId>"`, or `x-nodmix-agent-id`
|
|
32
|
+
- use `x-nodmix-model` when you want to override the selected agent's backend model
|
|
33
|
+
- use `x-nodmix-session-key` for explicit session routing
|
|
34
|
+
- use `x-nodmix-message-channel` when you want a non-default synthetic ingress channel context
|
|
35
|
+
|
|
36
|
+
Auth matrix:
|
|
37
|
+
|
|
38
|
+
- `gateway.auth.mode="token"` or `"password"` + `Authorization: Bearer ...`
|
|
39
|
+
- proves possession of the shared gateway operator secret
|
|
40
|
+
- ignores narrower `x-nodmix-scopes`
|
|
41
|
+
- restores the full default operator scope set:
|
|
42
|
+
`operator.admin`, `operator.approvals`, `operator.pairing`,
|
|
43
|
+
`operator.read`, `operator.talk.secrets`, `operator.write`
|
|
44
|
+
- treats chat turns on this endpoint as owner-sender turns
|
|
45
|
+
- trusted identity-bearing HTTP modes (for example trusted proxy auth, or `gateway.auth.mode="none"` on private ingress)
|
|
46
|
+
- honor `x-nodmix-scopes` when the header is present
|
|
47
|
+
- fall back to the normal operator default scope set when the header is absent
|
|
48
|
+
- only lose owner semantics when the caller explicitly narrows scopes and omits `operator.admin`
|
|
49
|
+
|
|
50
|
+
Enable or disable this endpoint with `gateway.http.endpoints.responses.enabled`.
|
|
51
|
+
|
|
52
|
+
The same compatibility surface also includes:
|
|
53
|
+
|
|
54
|
+
- `GET /v1/models`
|
|
55
|
+
- `GET /v1/models/{id}`
|
|
56
|
+
- `POST /v1/embeddings`
|
|
57
|
+
- `POST /v1/chat/completions`
|
|
58
|
+
|
|
59
|
+
For the canonical explanation of how agent-target models, `nodmix/default`, embeddings pass-through, and backend model overrides fit together, see [OpenAI Chat Completions](/gateway/openai-http-api#agent-first-model-contract) and [Model list and agent routing](/gateway/openai-http-api#model-list-and-agent-routing).
|
|
60
|
+
|
|
61
|
+
## Session behavior
|
|
62
|
+
|
|
63
|
+
By default the endpoint is **stateless per request** (a new session key is generated each call).
|
|
64
|
+
|
|
65
|
+
If the request includes an OpenResponses `user` string, the Gateway derives a stable session key
|
|
66
|
+
from it, so repeated calls can share an agent session.
|
|
67
|
+
|
|
68
|
+
## Request shape (supported)
|
|
69
|
+
|
|
70
|
+
The request follows the OpenResponses API with item-based input. Current support:
|
|
71
|
+
|
|
72
|
+
- `input`: string or array of item objects.
|
|
73
|
+
- `instructions`: merged into the system prompt.
|
|
74
|
+
- `tools`: client tool definitions (function tools).
|
|
75
|
+
- `tool_choice`: filter or require client tools.
|
|
76
|
+
- `stream`: enables SSE streaming.
|
|
77
|
+
- `max_output_tokens`: best-effort output limit (provider dependent).
|
|
78
|
+
- `temperature`: best-effort sampling temperature forwarded to the provider. Ignored by the ChatGPT-based Codex Responses backend, which uses fixed server-side sampling.
|
|
79
|
+
- `top_p`: best-effort nucleus sampling forwarded to the provider. Same Codex Responses caveat as `temperature`.
|
|
80
|
+
- `user`: stable session routing.
|
|
81
|
+
|
|
82
|
+
Accepted but **currently ignored**:
|
|
83
|
+
|
|
84
|
+
- `max_tool_calls`
|
|
85
|
+
- `reasoning`
|
|
86
|
+
- `metadata`
|
|
87
|
+
- `store`
|
|
88
|
+
- `truncation`
|
|
89
|
+
|
|
90
|
+
Supported:
|
|
91
|
+
|
|
92
|
+
- `previous_response_id`: Nodmix reuses the earlier response session when the request stays within the same agent/user/requested-session scope.
|
|
93
|
+
|
|
94
|
+
## Items (input)
|
|
95
|
+
|
|
96
|
+
### `message`
|
|
97
|
+
|
|
98
|
+
Roles: `system`, `developer`, `user`, `assistant`.
|
|
99
|
+
|
|
100
|
+
- `system` and `developer` are appended to the system prompt.
|
|
101
|
+
- The most recent `user` or `function_call_output` item becomes the "current message."
|
|
102
|
+
- Earlier user/assistant messages are included as history for context.
|
|
103
|
+
|
|
104
|
+
### `function_call_output` (turn-based tools)
|
|
105
|
+
|
|
106
|
+
Send tool results back to the model:
|
|
107
|
+
|
|
108
|
+
```json
|
|
109
|
+
{
|
|
110
|
+
"type": "function_call_output",
|
|
111
|
+
"call_id": "call_123",
|
|
112
|
+
"output": "{\"temperature\": \"72F\"}"
|
|
113
|
+
}
|
|
114
|
+
```
|
|
115
|
+
|
|
116
|
+
### `reasoning` and `item_reference`
|
|
117
|
+
|
|
118
|
+
Accepted for schema compatibility but ignored when building the prompt.
|
|
119
|
+
|
|
120
|
+
## Tools (client-side function tools)
|
|
121
|
+
|
|
122
|
+
Provide tools with `tools: [{ type: "function", function: { name, description?, parameters? } }]`.
|
|
123
|
+
|
|
124
|
+
If the agent decides to call a tool, the response returns a `function_call` output item.
|
|
125
|
+
You then send a follow-up request with `function_call_output` to continue the turn.
|
|
126
|
+
|
|
127
|
+
## Images (`input_image`)
|
|
128
|
+
|
|
129
|
+
Supports base64 or URL sources:
|
|
130
|
+
|
|
131
|
+
```json
|
|
132
|
+
{
|
|
133
|
+
"type": "input_image",
|
|
134
|
+
"source": { "type": "url", "url": "https://example.com/image.png" }
|
|
135
|
+
}
|
|
136
|
+
```
|
|
137
|
+
|
|
138
|
+
Allowed MIME types (current): `image/jpeg`, `image/png`, `image/gif`, `image/webp`, `image/heic`, `image/heif`.
|
|
139
|
+
Max size (current): 10MB.
|
|
140
|
+
|
|
141
|
+
## Files (`input_file`)
|
|
142
|
+
|
|
143
|
+
Supports base64 or URL sources:
|
|
144
|
+
|
|
145
|
+
```json
|
|
146
|
+
{
|
|
147
|
+
"type": "input_file",
|
|
148
|
+
"source": {
|
|
149
|
+
"type": "base64",
|
|
150
|
+
"media_type": "text/plain",
|
|
151
|
+
"data": "SGVsbG8gV29ybGQh",
|
|
152
|
+
"filename": "hello.txt"
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
```
|
|
156
|
+
|
|
157
|
+
Allowed MIME types (current): `text/plain`, `text/markdown`, `text/html`, `text/csv`,
|
|
158
|
+
`application/json`, `application/pdf`.
|
|
159
|
+
|
|
160
|
+
Max size (current): 5MB.
|
|
161
|
+
|
|
162
|
+
Current behavior:
|
|
163
|
+
|
|
164
|
+
- File content is decoded and added to the **system prompt**, not the user message,
|
|
165
|
+
so it stays ephemeral (not persisted in session history).
|
|
166
|
+
- Decoded file text is wrapped as **untrusted external content** before it is added,
|
|
167
|
+
so file bytes are treated as data, not trusted instructions.
|
|
168
|
+
- The injected block uses explicit boundary markers like
|
|
169
|
+
`<<<EXTERNAL_UNTRUSTED_CONTENT id="...">>>` /
|
|
170
|
+
`<<<END_EXTERNAL_UNTRUSTED_CONTENT id="...">>>` and includes a
|
|
171
|
+
`Source: External` metadata line.
|
|
172
|
+
- This file-input path intentionally omits the long `SECURITY NOTICE:` banner to
|
|
173
|
+
preserve prompt budget; the boundary markers and metadata still stay in place.
|
|
174
|
+
- PDFs are parsed for text first. If little text is found, the first pages are
|
|
175
|
+
rasterized into images and passed to the model, and the injected file block uses
|
|
176
|
+
the placeholder `[PDF content rendered to images]`.
|
|
177
|
+
|
|
178
|
+
PDF parsing is provided by the bundled `document-extract` plugin, which uses the
|
|
179
|
+
Node-friendly `pdfjs-dist` legacy build (no worker). The modern PDF.js build
|
|
180
|
+
expects browser workers/DOM globals, so it is not used in the Gateway.
|
|
181
|
+
|
|
182
|
+
URL fetch defaults:
|
|
183
|
+
|
|
184
|
+
- `files.allowUrl`: `true`
|
|
185
|
+
- `images.allowUrl`: `true`
|
|
186
|
+
- `maxUrlParts`: `8` (total URL-based `input_file` + `input_image` parts per request)
|
|
187
|
+
- Requests are guarded (DNS resolution, private IP blocking, redirect caps, timeouts).
|
|
188
|
+
- Optional hostname allowlists are supported per input type (`files.urlAllowlist`, `images.urlAllowlist`).
|
|
189
|
+
- Exact host: `"cdn.example.com"`
|
|
190
|
+
- Wildcard subdomains: `"*.assets.example.com"` (does not match apex)
|
|
191
|
+
- Empty or omitted allowlists mean no hostname allowlist restriction.
|
|
192
|
+
- To disable URL-based fetches entirely, set `files.allowUrl: false` and/or `images.allowUrl: false`.
|
|
193
|
+
|
|
194
|
+
## File + image limits (config)
|
|
195
|
+
|
|
196
|
+
Defaults can be tuned under `gateway.http.endpoints.responses`:
|
|
197
|
+
|
|
198
|
+
```json5
|
|
199
|
+
{
|
|
200
|
+
gateway: {
|
|
201
|
+
http: {
|
|
202
|
+
endpoints: {
|
|
203
|
+
responses: {
|
|
204
|
+
enabled: true,
|
|
205
|
+
maxBodyBytes: 20000000,
|
|
206
|
+
maxUrlParts: 8,
|
|
207
|
+
files: {
|
|
208
|
+
allowUrl: true,
|
|
209
|
+
urlAllowlist: ["cdn.example.com", "*.assets.example.com"],
|
|
210
|
+
allowedMimes: [
|
|
211
|
+
"text/plain",
|
|
212
|
+
"text/markdown",
|
|
213
|
+
"text/html",
|
|
214
|
+
"text/csv",
|
|
215
|
+
"application/json",
|
|
216
|
+
"application/pdf",
|
|
217
|
+
],
|
|
218
|
+
maxBytes: 5242880,
|
|
219
|
+
maxChars: 200000,
|
|
220
|
+
maxRedirects: 3,
|
|
221
|
+
timeoutMs: 10000,
|
|
222
|
+
pdf: {
|
|
223
|
+
maxPages: 4,
|
|
224
|
+
maxPixels: 4000000,
|
|
225
|
+
minTextChars: 200,
|
|
226
|
+
},
|
|
227
|
+
},
|
|
228
|
+
images: {
|
|
229
|
+
allowUrl: true,
|
|
230
|
+
urlAllowlist: ["images.example.com"],
|
|
231
|
+
allowedMimes: [
|
|
232
|
+
"image/jpeg",
|
|
233
|
+
"image/png",
|
|
234
|
+
"image/gif",
|
|
235
|
+
"image/webp",
|
|
236
|
+
"image/heic",
|
|
237
|
+
"image/heif",
|
|
238
|
+
],
|
|
239
|
+
maxBytes: 10485760,
|
|
240
|
+
maxRedirects: 3,
|
|
241
|
+
timeoutMs: 10000,
|
|
242
|
+
},
|
|
243
|
+
},
|
|
244
|
+
},
|
|
245
|
+
},
|
|
246
|
+
},
|
|
247
|
+
}
|
|
248
|
+
```
|
|
249
|
+
|
|
250
|
+
Defaults when omitted:
|
|
251
|
+
|
|
252
|
+
- `maxBodyBytes`: 20MB
|
|
253
|
+
- `maxUrlParts`: 8
|
|
254
|
+
- `files.maxBytes`: 5MB
|
|
255
|
+
- `files.maxChars`: 200k
|
|
256
|
+
- `files.maxRedirects`: 3
|
|
257
|
+
- `files.timeoutMs`: 10s
|
|
258
|
+
- `files.pdf.maxPages`: 4
|
|
259
|
+
- `files.pdf.maxPixels`: 4,000,000
|
|
260
|
+
- `files.pdf.minTextChars`: 200
|
|
261
|
+
- `images.maxBytes`: 10MB
|
|
262
|
+
- `images.maxRedirects`: 3
|
|
263
|
+
- `images.timeoutMs`: 10s
|
|
264
|
+
- HEIC/HEIF `input_image` sources are accepted and normalized to JPEG before provider delivery.
|
|
265
|
+
|
|
266
|
+
Security note:
|
|
267
|
+
|
|
268
|
+
- URL allowlists are enforced before fetch and on redirect hops.
|
|
269
|
+
- Allowlisting a hostname does not bypass private/internal IP blocking.
|
|
270
|
+
- For internet-exposed gateways, apply network egress controls in addition to app-level guards.
|
|
271
|
+
See [Security](/gateway/security).
|
|
272
|
+
|
|
273
|
+
## Streaming (SSE)
|
|
274
|
+
|
|
275
|
+
Set `stream: true` to receive Server-Sent Events (SSE):
|
|
276
|
+
|
|
277
|
+
- `Content-Type: text/event-stream`
|
|
278
|
+
- Each event line is `event: <type>` and `data: <json>`
|
|
279
|
+
- Stream ends with `data: [DONE]`
|
|
280
|
+
|
|
281
|
+
Event types currently emitted:
|
|
282
|
+
|
|
283
|
+
- `response.created`
|
|
284
|
+
- `response.in_progress`
|
|
285
|
+
- `response.output_item.added`
|
|
286
|
+
- `response.content_part.added`
|
|
287
|
+
- `response.output_text.delta`
|
|
288
|
+
- `response.output_text.done`
|
|
289
|
+
- `response.content_part.done`
|
|
290
|
+
- `response.output_item.done`
|
|
291
|
+
- `response.completed`
|
|
292
|
+
- `response.failed` (on error)
|
|
293
|
+
|
|
294
|
+
## Usage
|
|
295
|
+
|
|
296
|
+
`usage` is populated when the underlying provider reports token counts.
|
|
297
|
+
Nodmix normalizes common OpenAI-style aliases before those counters reach
|
|
298
|
+
downstream status/session surfaces, including `input_tokens` / `output_tokens`
|
|
299
|
+
and `prompt_tokens` / `completion_tokens`.
|
|
300
|
+
|
|
301
|
+
## Errors
|
|
302
|
+
|
|
303
|
+
Errors use a JSON object like:
|
|
304
|
+
|
|
305
|
+
```json
|
|
306
|
+
{ "error": { "message": "...", "type": "invalid_request_error" } }
|
|
307
|
+
```
|
|
308
|
+
|
|
309
|
+
Common cases:
|
|
310
|
+
|
|
311
|
+
- `401` missing/invalid auth
|
|
312
|
+
- `400` invalid request body
|
|
313
|
+
- `405` wrong method
|
|
314
|
+
|
|
315
|
+
## Examples
|
|
316
|
+
|
|
317
|
+
Non-streaming:
|
|
318
|
+
|
|
319
|
+
```bash
|
|
320
|
+
curl -sS http://127.0.0.1:18789/v1/responses \
|
|
321
|
+
-H 'Authorization: Bearer YOUR_TOKEN' \
|
|
322
|
+
-H 'Content-Type: application/json' \
|
|
323
|
+
-H 'x-nodmix-agent-id: main' \
|
|
324
|
+
-d '{
|
|
325
|
+
"model": "nodmix",
|
|
326
|
+
"input": "hi"
|
|
327
|
+
}'
|
|
328
|
+
```
|
|
329
|
+
|
|
330
|
+
Streaming:
|
|
331
|
+
|
|
332
|
+
```bash
|
|
333
|
+
curl -N http://127.0.0.1:18789/v1/responses \
|
|
334
|
+
-H 'Authorization: Bearer YOUR_TOKEN' \
|
|
335
|
+
-H 'Content-Type: application/json' \
|
|
336
|
+
-H 'x-nodmix-agent-id: main' \
|
|
337
|
+
-d '{
|
|
338
|
+
"model": "nodmix",
|
|
339
|
+
"stream": true,
|
|
340
|
+
"input": "hi"
|
|
341
|
+
}'
|
|
342
|
+
```
|
|
343
|
+
|
|
344
|
+
## Related
|
|
345
|
+
|
|
346
|
+
- [OpenAI chat completions](/gateway/openai-http-api)
|
|
347
|
+
- [OpenAI](/providers/openai)
|
|
@@ -0,0 +1,316 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Use OpenShell as a managed sandbox backend for Nodmix agents"
|
|
3
|
+
title: OpenShell
|
|
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 is a managed sandbox backend for Nodmix. Instead of running Docker
|
|
11
|
+
containers locally, Nodmix delegates sandbox lifecycle to the `openshell` CLI,
|
|
12
|
+
which provisions remote environments with SSH-based command execution.
|
|
13
|
+
|
|
14
|
+
The OpenShell plugin reuses the same core SSH transport and remote filesystem
|
|
15
|
+
bridge as the generic [SSH backend](/gateway/sandboxing#ssh-backend). It adds
|
|
16
|
+
OpenShell-specific lifecycle (`sandbox create/get/delete`, `sandbox ssh-config`)
|
|
17
|
+
and an optional `mirror` workspace mode.
|
|
18
|
+
|
|
19
|
+
## Prerequisites
|
|
20
|
+
|
|
21
|
+
- OpenShell plugin installed (`nodmix plugins install @nodmix/openshell-sandbox`)
|
|
22
|
+
- The `openshell` CLI installed and on `PATH` (or set a custom path via
|
|
23
|
+
`plugins.entries.openshell.config.command`)
|
|
24
|
+
- An OpenShell account with sandbox access
|
|
25
|
+
- Nodmix Gateway running on the host
|
|
26
|
+
|
|
27
|
+
## Quick start
|
|
28
|
+
|
|
29
|
+
1. Install and enable the plugin, then set the sandbox backend:
|
|
30
|
+
|
|
31
|
+
```bash
|
|
32
|
+
nodmix plugins install @nodmix/openshell-sandbox
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
```json5
|
|
36
|
+
{
|
|
37
|
+
agents: {
|
|
38
|
+
defaults: {
|
|
39
|
+
sandbox: {
|
|
40
|
+
mode: "all",
|
|
41
|
+
backend: "openshell",
|
|
42
|
+
scope: "session",
|
|
43
|
+
workspaceAccess: "rw",
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
plugins: {
|
|
48
|
+
entries: {
|
|
49
|
+
openshell: {
|
|
50
|
+
enabled: true,
|
|
51
|
+
config: {
|
|
52
|
+
from: "nodmix",
|
|
53
|
+
mode: "remote",
|
|
54
|
+
},
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
},
|
|
58
|
+
}
|
|
59
|
+
```
|
|
60
|
+
|
|
61
|
+
2. Restart the Gateway. On the next agent turn, Nodmix creates an OpenShell
|
|
62
|
+
sandbox and routes tool execution through it.
|
|
63
|
+
|
|
64
|
+
3. Verify:
|
|
65
|
+
|
|
66
|
+
```bash
|
|
67
|
+
nodmix sandbox list
|
|
68
|
+
nodmix sandbox explain
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
## Workspace modes
|
|
72
|
+
|
|
73
|
+
This is the most important decision when using OpenShell.
|
|
74
|
+
|
|
75
|
+
### `mirror`
|
|
76
|
+
|
|
77
|
+
Use `plugins.entries.openshell.config.mode: "mirror"` when you want the **local
|
|
78
|
+
workspace to stay canonical**.
|
|
79
|
+
|
|
80
|
+
Behavior:
|
|
81
|
+
|
|
82
|
+
- Before `exec`, Nodmix syncs the local workspace into the OpenShell sandbox.
|
|
83
|
+
- After `exec`, Nodmix syncs the remote workspace back to the local workspace.
|
|
84
|
+
- File tools still operate through the sandbox bridge, but the local workspace
|
|
85
|
+
remains the source of truth between turns.
|
|
86
|
+
|
|
87
|
+
Best for:
|
|
88
|
+
|
|
89
|
+
- You edit files locally outside Nodmix and want those changes visible in the
|
|
90
|
+
sandbox automatically.
|
|
91
|
+
- You want the OpenShell sandbox to behave as much like the Docker backend as
|
|
92
|
+
possible.
|
|
93
|
+
- You want the host workspace to reflect sandbox writes after each exec turn.
|
|
94
|
+
|
|
95
|
+
Tradeoff: extra sync cost before and after each exec.
|
|
96
|
+
|
|
97
|
+
### `remote`
|
|
98
|
+
|
|
99
|
+
Use `plugins.entries.openshell.config.mode: "remote"` when you want the
|
|
100
|
+
**OpenShell workspace to become canonical**.
|
|
101
|
+
|
|
102
|
+
Behavior:
|
|
103
|
+
|
|
104
|
+
- When the sandbox is first created, Nodmix seeds the remote workspace from
|
|
105
|
+
the local workspace once.
|
|
106
|
+
- After that, `exec`, `read`, `write`, `edit`, and `apply_patch` operate
|
|
107
|
+
directly against the remote OpenShell workspace.
|
|
108
|
+
- Nodmix does **not** sync remote changes back into the local workspace.
|
|
109
|
+
- Prompt-time media reads still work because file and media tools read through
|
|
110
|
+
the sandbox bridge.
|
|
111
|
+
|
|
112
|
+
Best for:
|
|
113
|
+
|
|
114
|
+
- The sandbox should live primarily on the remote side.
|
|
115
|
+
- You want lower per-turn sync overhead.
|
|
116
|
+
- You do not want host-local edits to silently overwrite remote sandbox state.
|
|
117
|
+
|
|
118
|
+
<Warning>
|
|
119
|
+
If you edit files on the host outside Nodmix after the initial seed, the remote sandbox does **not** see those changes. Use `nodmix sandbox recreate` to re-seed.
|
|
120
|
+
</Warning>
|
|
121
|
+
|
|
122
|
+
### Choosing a mode
|
|
123
|
+
|
|
124
|
+
| | `mirror` | `remote` |
|
|
125
|
+
| ------------------------ | -------------------------- | ------------------------- |
|
|
126
|
+
| **Canonical workspace** | Local host | Remote OpenShell |
|
|
127
|
+
| **Sync direction** | Bidirectional (each exec) | One-time seed |
|
|
128
|
+
| **Per-turn overhead** | Higher (upload + download) | Lower (direct remote ops) |
|
|
129
|
+
| **Local edits visible?** | Yes, on next exec | No, until recreate |
|
|
130
|
+
| **Best for** | Development workflows | Long-running agents, CI |
|
|
131
|
+
|
|
132
|
+
## Configuration reference
|
|
133
|
+
|
|
134
|
+
All OpenShell config lives under `plugins.entries.openshell.config`:
|
|
135
|
+
|
|
136
|
+
| Key | Type | Default | Description |
|
|
137
|
+
| ------------------------- | ------------------------ | ------------- | ----------------------------------------------------- |
|
|
138
|
+
| `mode` | `"mirror"` or `"remote"` | `"mirror"` | Workspace sync mode |
|
|
139
|
+
| `command` | `string` | `"openshell"` | Path or name of the `openshell` CLI |
|
|
140
|
+
| `from` | `string` | `"nodmix"` | Sandbox source for first-time create |
|
|
141
|
+
| `gateway` | `string` | — | OpenShell gateway name (`--gateway`) |
|
|
142
|
+
| `gatewayEndpoint` | `string` | — | OpenShell gateway endpoint URL (`--gateway-endpoint`) |
|
|
143
|
+
| `policy` | `string` | — | OpenShell policy ID for sandbox creation |
|
|
144
|
+
| `providers` | `string[]` | `[]` | Provider names to attach when sandbox is created |
|
|
145
|
+
| `gpu` | `boolean` | `false` | Request GPU resources |
|
|
146
|
+
| `autoProviders` | `boolean` | `true` | Pass `--auto-providers` during sandbox create |
|
|
147
|
+
| `remoteWorkspaceDir` | `string` | `"/sandbox"` | Primary writable workspace inside the sandbox |
|
|
148
|
+
| `remoteAgentWorkspaceDir` | `string` | `"/agent"` | Agent workspace mount path (for read-only access) |
|
|
149
|
+
| `timeoutSeconds` | `number` | `120` | Timeout for `openshell` CLI operations |
|
|
150
|
+
|
|
151
|
+
Sandbox-level settings (`mode`, `scope`, `workspaceAccess`) are configured under
|
|
152
|
+
`agents.defaults.sandbox` as with any backend. See
|
|
153
|
+
[Sandboxing](/gateway/sandboxing) for the full matrix.
|
|
154
|
+
|
|
155
|
+
## Examples
|
|
156
|
+
|
|
157
|
+
### Minimal remote setup
|
|
158
|
+
|
|
159
|
+
```json5
|
|
160
|
+
{
|
|
161
|
+
agents: {
|
|
162
|
+
defaults: {
|
|
163
|
+
sandbox: {
|
|
164
|
+
mode: "all",
|
|
165
|
+
backend: "openshell",
|
|
166
|
+
},
|
|
167
|
+
},
|
|
168
|
+
},
|
|
169
|
+
plugins: {
|
|
170
|
+
entries: {
|
|
171
|
+
openshell: {
|
|
172
|
+
enabled: true,
|
|
173
|
+
config: {
|
|
174
|
+
from: "nodmix",
|
|
175
|
+
mode: "remote",
|
|
176
|
+
},
|
|
177
|
+
},
|
|
178
|
+
},
|
|
179
|
+
},
|
|
180
|
+
}
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
### Mirror mode with GPU
|
|
184
|
+
|
|
185
|
+
```json5
|
|
186
|
+
{
|
|
187
|
+
agents: {
|
|
188
|
+
defaults: {
|
|
189
|
+
sandbox: {
|
|
190
|
+
mode: "all",
|
|
191
|
+
backend: "openshell",
|
|
192
|
+
scope: "agent",
|
|
193
|
+
workspaceAccess: "rw",
|
|
194
|
+
},
|
|
195
|
+
},
|
|
196
|
+
},
|
|
197
|
+
plugins: {
|
|
198
|
+
entries: {
|
|
199
|
+
openshell: {
|
|
200
|
+
enabled: true,
|
|
201
|
+
config: {
|
|
202
|
+
from: "nodmix",
|
|
203
|
+
mode: "mirror",
|
|
204
|
+
gpu: true,
|
|
205
|
+
providers: ["openai"],
|
|
206
|
+
timeoutSeconds: 180,
|
|
207
|
+
},
|
|
208
|
+
},
|
|
209
|
+
},
|
|
210
|
+
},
|
|
211
|
+
}
|
|
212
|
+
```
|
|
213
|
+
|
|
214
|
+
### Per-agent OpenShell with custom gateway
|
|
215
|
+
|
|
216
|
+
```json5
|
|
217
|
+
{
|
|
218
|
+
agents: {
|
|
219
|
+
defaults: {
|
|
220
|
+
sandbox: { mode: "off" },
|
|
221
|
+
},
|
|
222
|
+
list: [
|
|
223
|
+
{
|
|
224
|
+
id: "researcher",
|
|
225
|
+
sandbox: {
|
|
226
|
+
mode: "all",
|
|
227
|
+
backend: "openshell",
|
|
228
|
+
scope: "agent",
|
|
229
|
+
workspaceAccess: "rw",
|
|
230
|
+
},
|
|
231
|
+
},
|
|
232
|
+
],
|
|
233
|
+
},
|
|
234
|
+
plugins: {
|
|
235
|
+
entries: {
|
|
236
|
+
openshell: {
|
|
237
|
+
enabled: true,
|
|
238
|
+
config: {
|
|
239
|
+
from: "nodmix",
|
|
240
|
+
mode: "remote",
|
|
241
|
+
gateway: "lab",
|
|
242
|
+
gatewayEndpoint: "https://lab.example",
|
|
243
|
+
policy: "strict",
|
|
244
|
+
},
|
|
245
|
+
},
|
|
246
|
+
},
|
|
247
|
+
},
|
|
248
|
+
}
|
|
249
|
+
```
|
|
250
|
+
|
|
251
|
+
## Lifecycle management
|
|
252
|
+
|
|
253
|
+
OpenShell sandboxes are managed through the normal sandbox CLI:
|
|
254
|
+
|
|
255
|
+
```bash
|
|
256
|
+
# List all sandbox runtimes (Docker + OpenShell)
|
|
257
|
+
nodmix sandbox list
|
|
258
|
+
|
|
259
|
+
# Inspect effective policy
|
|
260
|
+
nodmix sandbox explain
|
|
261
|
+
|
|
262
|
+
# Recreate (deletes remote workspace, re-seeds on next use)
|
|
263
|
+
nodmix sandbox recreate --all
|
|
264
|
+
```
|
|
265
|
+
|
|
266
|
+
For `remote` mode, **recreate is especially important**: it deletes the canonical
|
|
267
|
+
remote workspace for that scope. The next use seeds a fresh remote workspace from
|
|
268
|
+
the local workspace.
|
|
269
|
+
|
|
270
|
+
For `mirror` mode, recreate mainly resets the remote execution environment because
|
|
271
|
+
the local workspace remains canonical.
|
|
272
|
+
|
|
273
|
+
### When to recreate
|
|
274
|
+
|
|
275
|
+
Recreate after changing any of these:
|
|
276
|
+
|
|
277
|
+
- `agents.defaults.sandbox.backend`
|
|
278
|
+
- `plugins.entries.openshell.config.from`
|
|
279
|
+
- `plugins.entries.openshell.config.mode`
|
|
280
|
+
- `plugins.entries.openshell.config.policy`
|
|
281
|
+
|
|
282
|
+
```bash
|
|
283
|
+
nodmix sandbox recreate --all
|
|
284
|
+
```
|
|
285
|
+
|
|
286
|
+
## Security hardening
|
|
287
|
+
|
|
288
|
+
OpenShell pins the workspace root fd and rechecks sandbox identity before each
|
|
289
|
+
read, so symlink swaps or a remounted workspace cannot redirect reads out of
|
|
290
|
+
the intended remote workspace.
|
|
291
|
+
|
|
292
|
+
## Current limitations
|
|
293
|
+
|
|
294
|
+
- Sandbox browser is not supported on the OpenShell backend.
|
|
295
|
+
- `sandbox.docker.binds` does not apply to OpenShell.
|
|
296
|
+
- Docker-specific runtime knobs under `sandbox.docker.*` apply only to the Docker
|
|
297
|
+
backend.
|
|
298
|
+
|
|
299
|
+
## How it works
|
|
300
|
+
|
|
301
|
+
1. Nodmix calls `openshell sandbox create` (with `--from`, `--gateway`,
|
|
302
|
+
`--policy`, `--providers`, `--gpu` flags as configured).
|
|
303
|
+
2. Nodmix calls `openshell sandbox ssh-config <name>` to get SSH connection
|
|
304
|
+
details for the sandbox.
|
|
305
|
+
3. Core writes the SSH config to a temp file and opens an SSH session using the
|
|
306
|
+
same remote filesystem bridge as the generic SSH backend.
|
|
307
|
+
4. In `mirror` mode: sync local to remote before exec, run, sync back after exec.
|
|
308
|
+
5. In `remote` mode: seed once on create, then operate directly on the remote
|
|
309
|
+
workspace.
|
|
310
|
+
|
|
311
|
+
## Related
|
|
312
|
+
|
|
313
|
+
- [Sandboxing](/gateway/sandboxing) -- modes, scopes, and backend comparison
|
|
314
|
+
- [Sandbox vs Tool Policy vs Elevated](/gateway/sandbox-vs-tool-policy-vs-elevated) -- debugging blocked tools
|
|
315
|
+
- [Multi-Agent Sandbox and Tools](/tools/multi-agent-sandbox-tools) -- per-agent overrides
|
|
316
|
+
- [Sandbox CLI](/cli/sandbox) -- `nodmix sandbox` commands
|