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,208 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Manage sandbox runtimes and inspect effective sandbox policy"
|
|
3
|
+
title: Sandbox CLI
|
|
4
|
+
read_when: "You are managing sandbox runtimes or debugging sandbox/tool-policy behavior."
|
|
5
|
+
status: active
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
Manage sandbox runtimes for isolated agent execution.
|
|
9
|
+
|
|
10
|
+
## Overview
|
|
11
|
+
|
|
12
|
+
Nodmix can run agents in isolated sandbox runtimes for security. The `sandbox` commands help you inspect and recreate those runtimes after updates or configuration changes.
|
|
13
|
+
|
|
14
|
+
Today that usually means:
|
|
15
|
+
|
|
16
|
+
- Docker sandbox containers
|
|
17
|
+
- SSH sandbox runtimes when `agents.defaults.sandbox.backend = "ssh"`
|
|
18
|
+
- OpenShell sandbox runtimes when `agents.defaults.sandbox.backend = "openshell"`
|
|
19
|
+
|
|
20
|
+
For `ssh` and OpenShell `remote`, recreate matters more than with Docker:
|
|
21
|
+
|
|
22
|
+
- the remote workspace is canonical after the initial seed
|
|
23
|
+
- `nodmix sandbox recreate` deletes that canonical remote workspace for the selected scope
|
|
24
|
+
- next use seeds it again from the current local workspace
|
|
25
|
+
|
|
26
|
+
## Commands
|
|
27
|
+
|
|
28
|
+
### `nodmix sandbox explain`
|
|
29
|
+
|
|
30
|
+
Inspect the **effective** sandbox mode/scope/workspace access, sandbox tool policy, and elevated gates (with fix-it config key paths).
|
|
31
|
+
|
|
32
|
+
```bash
|
|
33
|
+
nodmix sandbox explain
|
|
34
|
+
nodmix sandbox explain --session agent:main:main
|
|
35
|
+
nodmix sandbox explain --agent work
|
|
36
|
+
nodmix sandbox explain --json
|
|
37
|
+
```
|
|
38
|
+
|
|
39
|
+
### `nodmix sandbox list`
|
|
40
|
+
|
|
41
|
+
List all sandbox runtimes with their status and configuration.
|
|
42
|
+
|
|
43
|
+
```bash
|
|
44
|
+
nodmix sandbox list
|
|
45
|
+
nodmix sandbox list --browser # List only browser containers
|
|
46
|
+
nodmix sandbox list --json # JSON output
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
**Output includes:**
|
|
50
|
+
|
|
51
|
+
- Runtime name and status
|
|
52
|
+
- Backend (`docker`, `openshell`, etc.)
|
|
53
|
+
- Config label and whether it matches current config
|
|
54
|
+
- Age (time since creation)
|
|
55
|
+
- Idle time (time since last use)
|
|
56
|
+
- Associated session/agent
|
|
57
|
+
|
|
58
|
+
### `nodmix sandbox recreate`
|
|
59
|
+
|
|
60
|
+
Remove sandbox runtimes to force recreation with updated config.
|
|
61
|
+
|
|
62
|
+
```bash
|
|
63
|
+
nodmix sandbox recreate --all # Recreate all containers
|
|
64
|
+
nodmix sandbox recreate --session main # Specific session
|
|
65
|
+
nodmix sandbox recreate --agent mybot # Specific agent
|
|
66
|
+
nodmix sandbox recreate --browser # Only browser containers
|
|
67
|
+
nodmix sandbox recreate --all --force # Skip confirmation
|
|
68
|
+
```
|
|
69
|
+
|
|
70
|
+
**Options:**
|
|
71
|
+
|
|
72
|
+
- `--all`: Recreate all sandbox containers
|
|
73
|
+
- `--session <key>`: Recreate container for specific session
|
|
74
|
+
- `--agent <id>`: Recreate containers for specific agent
|
|
75
|
+
- `--browser`: Only recreate browser containers
|
|
76
|
+
- `--force`: Skip confirmation prompt
|
|
77
|
+
|
|
78
|
+
<Note>
|
|
79
|
+
Runtimes are automatically recreated when the agent is next used.
|
|
80
|
+
</Note>
|
|
81
|
+
|
|
82
|
+
## Use cases
|
|
83
|
+
|
|
84
|
+
### After updating a Docker image
|
|
85
|
+
|
|
86
|
+
```bash
|
|
87
|
+
# Pull new image
|
|
88
|
+
docker pull nodmix-sandbox:latest
|
|
89
|
+
docker tag nodmix-sandbox:latest nodmix-sandbox:bookworm-slim
|
|
90
|
+
|
|
91
|
+
# Update config to use new image
|
|
92
|
+
# Edit config: agents.defaults.sandbox.docker.image (or agents.list[].sandbox.docker.image)
|
|
93
|
+
|
|
94
|
+
# Recreate containers
|
|
95
|
+
nodmix sandbox recreate --all
|
|
96
|
+
```
|
|
97
|
+
|
|
98
|
+
### After changing sandbox configuration
|
|
99
|
+
|
|
100
|
+
```bash
|
|
101
|
+
# Edit config: agents.defaults.sandbox.* (or agents.list[].sandbox.*)
|
|
102
|
+
|
|
103
|
+
# Recreate to apply new config
|
|
104
|
+
nodmix sandbox recreate --all
|
|
105
|
+
```
|
|
106
|
+
|
|
107
|
+
### After changing SSH target or SSH auth material
|
|
108
|
+
|
|
109
|
+
```bash
|
|
110
|
+
# Edit config:
|
|
111
|
+
# - agents.defaults.sandbox.backend
|
|
112
|
+
# - agents.defaults.sandbox.ssh.target
|
|
113
|
+
# - agents.defaults.sandbox.ssh.workspaceRoot
|
|
114
|
+
# - agents.defaults.sandbox.ssh.identityFile / certificateFile / knownHostsFile
|
|
115
|
+
# - agents.defaults.sandbox.ssh.identityData / certificateData / knownHostsData
|
|
116
|
+
|
|
117
|
+
nodmix sandbox recreate --all
|
|
118
|
+
```
|
|
119
|
+
|
|
120
|
+
For the core `ssh` backend, recreate deletes the per-scope remote workspace root
|
|
121
|
+
on the SSH target. The next run seeds it again from the local workspace.
|
|
122
|
+
|
|
123
|
+
### After changing OpenShell source, policy, or mode
|
|
124
|
+
|
|
125
|
+
```bash
|
|
126
|
+
# Edit config:
|
|
127
|
+
# - agents.defaults.sandbox.backend
|
|
128
|
+
# - plugins.entries.openshell.config.from
|
|
129
|
+
# - plugins.entries.openshell.config.mode
|
|
130
|
+
# - plugins.entries.openshell.config.policy
|
|
131
|
+
|
|
132
|
+
nodmix sandbox recreate --all
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
For OpenShell `remote` mode, recreate deletes the canonical remote workspace
|
|
136
|
+
for that scope. The next run seeds it again from the local workspace.
|
|
137
|
+
|
|
138
|
+
### After changing setupCommand
|
|
139
|
+
|
|
140
|
+
```bash
|
|
141
|
+
nodmix sandbox recreate --all
|
|
142
|
+
# or just one agent:
|
|
143
|
+
nodmix sandbox recreate --agent family
|
|
144
|
+
```
|
|
145
|
+
|
|
146
|
+
### For a specific agent only
|
|
147
|
+
|
|
148
|
+
```bash
|
|
149
|
+
# Update only one agent's containers
|
|
150
|
+
nodmix sandbox recreate --agent alfred
|
|
151
|
+
```
|
|
152
|
+
|
|
153
|
+
## Why this is needed
|
|
154
|
+
|
|
155
|
+
When you update sandbox configuration:
|
|
156
|
+
|
|
157
|
+
- Existing runtimes continue running with old settings.
|
|
158
|
+
- Runtimes are only pruned after 24h of inactivity.
|
|
159
|
+
- Regularly-used agents keep old runtimes alive indefinitely.
|
|
160
|
+
|
|
161
|
+
Use `nodmix sandbox recreate` to force removal of old runtimes. They are recreated automatically with current settings when next needed.
|
|
162
|
+
|
|
163
|
+
<Tip>
|
|
164
|
+
Prefer `nodmix sandbox recreate` over manual backend-specific cleanup. It uses the Gateway's runtime registry and avoids mismatches when scope or session keys change.
|
|
165
|
+
</Tip>
|
|
166
|
+
|
|
167
|
+
## Registry migration
|
|
168
|
+
|
|
169
|
+
Nodmix stores sandbox runtime metadata as one JSON shard per container/browser entry under the sandbox state directory. Older installs may still have monolithic legacy files:
|
|
170
|
+
|
|
171
|
+
- `~/.nodmix/sandbox/containers.json`
|
|
172
|
+
- `~/.nodmix/sandbox/browsers.json`
|
|
173
|
+
|
|
174
|
+
Regular sandbox runtime reads do not rewrite those files. Run `nodmix doctor --fix` to migrate valid legacy entries into the sharded registry directories. Invalid legacy files are quarantined so one bad old registry cannot hide current runtime entries.
|
|
175
|
+
|
|
176
|
+
## Configuration
|
|
177
|
+
|
|
178
|
+
Sandbox settings live in `~/.nodmix/nodmix.json` under `agents.defaults.sandbox` (per-agent overrides go in `agents.list[].sandbox`):
|
|
179
|
+
|
|
180
|
+
```jsonc
|
|
181
|
+
{
|
|
182
|
+
"agents": {
|
|
183
|
+
"defaults": {
|
|
184
|
+
"sandbox": {
|
|
185
|
+
"mode": "all", // off, non-main, all
|
|
186
|
+
"backend": "docker", // docker, ssh, openshell
|
|
187
|
+
"scope": "agent", // session, agent, shared
|
|
188
|
+
"docker": {
|
|
189
|
+
"image": "nodmix-sandbox:bookworm-slim",
|
|
190
|
+
"containerPrefix": "nodmix-sbx-",
|
|
191
|
+
// ... more Docker options
|
|
192
|
+
},
|
|
193
|
+
"prune": {
|
|
194
|
+
"idleHours": 24, // Auto-prune after 24h idle
|
|
195
|
+
"maxAgeDays": 7, // Auto-prune after 7 days
|
|
196
|
+
},
|
|
197
|
+
},
|
|
198
|
+
},
|
|
199
|
+
},
|
|
200
|
+
}
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
## Related
|
|
204
|
+
|
|
205
|
+
- [CLI reference](/cli)
|
|
206
|
+
- [Sandboxing](/gateway/sandboxing)
|
|
207
|
+
- [Agent workspace](/concepts/agent-workspace)
|
|
208
|
+
- [Doctor](/gateway/doctor): checks sandbox setup.
|
|
@@ -0,0 +1,202 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "CLI reference for `nodmix secrets` (reload, audit, configure, apply)"
|
|
3
|
+
read_when:
|
|
4
|
+
- Re-resolving secret refs at runtime
|
|
5
|
+
- Auditing plaintext residues and unresolved refs
|
|
6
|
+
- Configuring SecretRefs and applying one-way scrub changes
|
|
7
|
+
title: "Secrets"
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# `nodmix secrets`
|
|
11
|
+
|
|
12
|
+
Use `nodmix secrets` to manage SecretRefs and keep the active runtime snapshot healthy.
|
|
13
|
+
|
|
14
|
+
Command roles:
|
|
15
|
+
|
|
16
|
+
- `reload`: gateway RPC (`secrets.reload`) that re-resolves refs and swaps runtime snapshot only on full success (no config writes).
|
|
17
|
+
- `audit`: read-only scan of configuration/auth/generated-model stores and legacy residues for plaintext, unresolved refs, and precedence drift (exec refs are skipped unless `--allow-exec` is set).
|
|
18
|
+
- `configure`: interactive planner for provider setup, target mapping, and preflight (TTY required).
|
|
19
|
+
- `apply`: execute a saved plan (`--dry-run` for validation only; dry-run skips exec checks by default, and write mode rejects exec-containing plans unless `--allow-exec` is set), then scrub targeted plaintext residues.
|
|
20
|
+
|
|
21
|
+
Recommended operator loop:
|
|
22
|
+
|
|
23
|
+
```bash
|
|
24
|
+
nodmix secrets audit --check
|
|
25
|
+
nodmix secrets configure
|
|
26
|
+
nodmix secrets apply --from /tmp/nodmix-secrets-plan.json --dry-run
|
|
27
|
+
nodmix secrets apply --from /tmp/nodmix-secrets-plan.json
|
|
28
|
+
nodmix secrets audit --check
|
|
29
|
+
nodmix secrets reload
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
If your plan includes `exec` SecretRefs/providers, pass `--allow-exec` on both dry-run and write apply commands.
|
|
33
|
+
|
|
34
|
+
Exit code note for CI/gates:
|
|
35
|
+
|
|
36
|
+
- `audit --check` returns `1` on findings.
|
|
37
|
+
- unresolved refs return `2`.
|
|
38
|
+
|
|
39
|
+
Related:
|
|
40
|
+
|
|
41
|
+
- Secrets guide: [Secrets Management](/gateway/secrets)
|
|
42
|
+
- Credential surface: [SecretRef Credential Surface](/reference/secretref-credential-surface)
|
|
43
|
+
- Security guide: [Security](/gateway/security)
|
|
44
|
+
|
|
45
|
+
## Reload runtime snapshot
|
|
46
|
+
|
|
47
|
+
Re-resolve secret refs and atomically swap runtime snapshot.
|
|
48
|
+
|
|
49
|
+
```bash
|
|
50
|
+
nodmix secrets reload
|
|
51
|
+
nodmix secrets reload --json
|
|
52
|
+
nodmix secrets reload --url ws://127.0.0.1:18789 --token <token>
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
Notes:
|
|
56
|
+
|
|
57
|
+
- Uses gateway RPC method `secrets.reload`.
|
|
58
|
+
- If resolution fails, gateway keeps last-known-good snapshot and returns an error (no partial activation).
|
|
59
|
+
- JSON response includes `warningCount`.
|
|
60
|
+
|
|
61
|
+
Options:
|
|
62
|
+
|
|
63
|
+
- `--url <url>`
|
|
64
|
+
- `--token <token>`
|
|
65
|
+
- `--timeout <ms>`
|
|
66
|
+
- `--json`
|
|
67
|
+
|
|
68
|
+
## Audit
|
|
69
|
+
|
|
70
|
+
Scan Nodmix state for:
|
|
71
|
+
|
|
72
|
+
- plaintext secret storage
|
|
73
|
+
- unresolved refs
|
|
74
|
+
- precedence drift (`auth-profiles.json` credentials shadowing `nodmix.json` refs)
|
|
75
|
+
- generated `agents/*/agent/models.json` residues (provider `apiKey` values and sensitive provider headers)
|
|
76
|
+
- legacy residues (legacy auth store entries, OAuth reminders)
|
|
77
|
+
|
|
78
|
+
Header residue note:
|
|
79
|
+
|
|
80
|
+
- Sensitive provider header detection is name-heuristic based (common auth/credential header names and fragments such as `authorization`, `x-api-key`, `token`, `secret`, `password`, and `credential`).
|
|
81
|
+
|
|
82
|
+
```bash
|
|
83
|
+
nodmix secrets audit
|
|
84
|
+
nodmix secrets audit --check
|
|
85
|
+
nodmix secrets audit --json
|
|
86
|
+
nodmix secrets audit --allow-exec
|
|
87
|
+
```
|
|
88
|
+
|
|
89
|
+
Exit behavior:
|
|
90
|
+
|
|
91
|
+
- `--check` exits non-zero on findings.
|
|
92
|
+
- unresolved refs exit with higher-priority non-zero code.
|
|
93
|
+
|
|
94
|
+
Report shape highlights:
|
|
95
|
+
|
|
96
|
+
- `status`: `clean | findings | unresolved`
|
|
97
|
+
- `resolution`: `refsChecked`, `skippedExecRefs`, `resolvabilityComplete`
|
|
98
|
+
- `summary`: `plaintextCount`, `unresolvedRefCount`, `shadowedRefCount`, `legacyResidueCount`
|
|
99
|
+
- finding codes:
|
|
100
|
+
- `PLAINTEXT_FOUND`
|
|
101
|
+
- `REF_UNRESOLVED`
|
|
102
|
+
- `REF_SHADOWED`
|
|
103
|
+
- `LEGACY_RESIDUE`
|
|
104
|
+
|
|
105
|
+
## Configure (interactive helper)
|
|
106
|
+
|
|
107
|
+
Build provider and SecretRef changes interactively, run preflight, and optionally apply:
|
|
108
|
+
|
|
109
|
+
```bash
|
|
110
|
+
nodmix secrets configure
|
|
111
|
+
nodmix secrets configure --plan-out /tmp/nodmix-secrets-plan.json
|
|
112
|
+
nodmix secrets configure --apply --yes
|
|
113
|
+
nodmix secrets configure --providers-only
|
|
114
|
+
nodmix secrets configure --skip-provider-setup
|
|
115
|
+
nodmix secrets configure --agent ops
|
|
116
|
+
nodmix secrets configure --json
|
|
117
|
+
```
|
|
118
|
+
|
|
119
|
+
Flow:
|
|
120
|
+
|
|
121
|
+
- Provider setup first (`add/edit/remove` for `secrets.providers` aliases).
|
|
122
|
+
- Credential mapping second (select fields and assign `{source, provider, id}` refs).
|
|
123
|
+
- Preflight and optional apply last.
|
|
124
|
+
|
|
125
|
+
Flags:
|
|
126
|
+
|
|
127
|
+
- `--providers-only`: configure `secrets.providers` only, skip credential mapping.
|
|
128
|
+
- `--skip-provider-setup`: skip provider setup and map credentials to existing providers.
|
|
129
|
+
- `--agent <id>`: scope `auth-profiles.json` target discovery and writes to one agent store.
|
|
130
|
+
- `--allow-exec`: allow exec SecretRef checks during preflight/apply (may execute provider commands).
|
|
131
|
+
|
|
132
|
+
Notes:
|
|
133
|
+
|
|
134
|
+
- Requires an interactive TTY.
|
|
135
|
+
- You cannot combine `--providers-only` with `--skip-provider-setup`.
|
|
136
|
+
- `configure` targets secret-bearing fields in `nodmix.json` plus `auth-profiles.json` for the selected agent scope.
|
|
137
|
+
- `configure` supports creating new `auth-profiles.json` mappings directly in the picker flow.
|
|
138
|
+
- Canonical supported surface: [SecretRef Credential Surface](/reference/secretref-credential-surface).
|
|
139
|
+
- It performs preflight resolution before apply.
|
|
140
|
+
- If preflight/apply includes exec refs, keep `--allow-exec` set for both steps.
|
|
141
|
+
- Generated plans default to scrub options (`scrubEnv`, `scrubAuthProfilesForProviderTargets`, `scrubLegacyAuthJson` all enabled).
|
|
142
|
+
- Apply path is one-way for scrubbed plaintext values.
|
|
143
|
+
- Without `--apply`, CLI still prompts `Apply this plan now?` after preflight.
|
|
144
|
+
- With `--apply` (and no `--yes`), CLI prompts an extra irreversible confirmation.
|
|
145
|
+
- `--json` prints the plan + preflight report, but the command still requires an interactive TTY.
|
|
146
|
+
|
|
147
|
+
Exec provider safety note:
|
|
148
|
+
|
|
149
|
+
- Homebrew installs often expose symlinked binaries under `/opt/homebrew/bin/*`.
|
|
150
|
+
- Set `allowSymlinkCommand: true` only when needed for trusted package-manager paths, and pair it with `trustedDirs` (for example `["/opt/homebrew"]`).
|
|
151
|
+
- On Windows, if ACL verification is unavailable for a provider path, Nodmix fails closed. For trusted paths only, set `allowInsecurePath: true` on that provider to bypass path security checks.
|
|
152
|
+
|
|
153
|
+
## Apply a saved plan
|
|
154
|
+
|
|
155
|
+
Apply or preflight a plan generated previously:
|
|
156
|
+
|
|
157
|
+
```bash
|
|
158
|
+
nodmix secrets apply --from /tmp/nodmix-secrets-plan.json
|
|
159
|
+
nodmix secrets apply --from /tmp/nodmix-secrets-plan.json --allow-exec
|
|
160
|
+
nodmix secrets apply --from /tmp/nodmix-secrets-plan.json --dry-run
|
|
161
|
+
nodmix secrets apply --from /tmp/nodmix-secrets-plan.json --dry-run --allow-exec
|
|
162
|
+
nodmix secrets apply --from /tmp/nodmix-secrets-plan.json --json
|
|
163
|
+
```
|
|
164
|
+
|
|
165
|
+
Exec behavior:
|
|
166
|
+
|
|
167
|
+
- `--dry-run` validates preflight without writing files.
|
|
168
|
+
- exec SecretRef checks are skipped by default in dry-run.
|
|
169
|
+
- write mode rejects plans that contain exec SecretRefs/providers unless `--allow-exec` is set.
|
|
170
|
+
- Use `--allow-exec` to opt in to exec provider checks/execution in either mode.
|
|
171
|
+
|
|
172
|
+
Plan contract details (allowed target paths, validation rules, and failure semantics):
|
|
173
|
+
|
|
174
|
+
- [Secrets Apply Plan Contract](/gateway/secrets-plan-contract)
|
|
175
|
+
|
|
176
|
+
What `apply` may update:
|
|
177
|
+
|
|
178
|
+
- `nodmix.json` (SecretRef targets + provider upserts/deletes)
|
|
179
|
+
- `auth-profiles.json` (provider-target scrubbing)
|
|
180
|
+
- legacy `auth.json` residues
|
|
181
|
+
- `~/.nodmix/.env` known secret keys whose values were migrated
|
|
182
|
+
|
|
183
|
+
## Why no rollback backups
|
|
184
|
+
|
|
185
|
+
`secrets apply` intentionally does not write rollback backups containing old plaintext values.
|
|
186
|
+
|
|
187
|
+
Safety comes from strict preflight + atomic-ish apply with best-effort in-memory restore on failure.
|
|
188
|
+
|
|
189
|
+
## Example
|
|
190
|
+
|
|
191
|
+
```bash
|
|
192
|
+
nodmix secrets audit --check
|
|
193
|
+
nodmix secrets configure
|
|
194
|
+
nodmix secrets audit --check
|
|
195
|
+
```
|
|
196
|
+
|
|
197
|
+
If `audit --check` still reports plaintext findings, update the remaining reported target paths and rerun audit.
|
|
198
|
+
|
|
199
|
+
## Related
|
|
200
|
+
|
|
201
|
+
- [CLI reference](/cli)
|
|
202
|
+
- [Secrets management](/gateway/secrets)
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "CLI reference for `nodmix security` (audit and fix common security footguns)"
|
|
3
|
+
read_when:
|
|
4
|
+
- You want to run a quick security audit on config/state
|
|
5
|
+
- You want to apply safe "fix" suggestions (permissions, tighten defaults)
|
|
6
|
+
title: "Security"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
# `nodmix security`
|
|
10
|
+
|
|
11
|
+
Security tools (audit + optional fixes).
|
|
12
|
+
|
|
13
|
+
Related:
|
|
14
|
+
|
|
15
|
+
- Security guide: [Security](/gateway/security)
|
|
16
|
+
|
|
17
|
+
## Audit
|
|
18
|
+
|
|
19
|
+
```bash
|
|
20
|
+
nodmix security audit
|
|
21
|
+
nodmix security audit --deep
|
|
22
|
+
nodmix security audit --deep --password <password>
|
|
23
|
+
nodmix security audit --deep --token <token>
|
|
24
|
+
nodmix security audit --fix
|
|
25
|
+
nodmix security audit --json
|
|
26
|
+
```
|
|
27
|
+
|
|
28
|
+
Plain `security audit` stays on the cold config/filesystem/read-only path. It does not discover plugin runtime security collectors by default, so routine audits do not load every installed plugin runtime. Use `--deep` to include best-effort live Gateway probes and plugin-owned security audit collectors; explicit internal callers may also opt into those plugin-owned collectors when they already have an appropriate runtime scope.
|
|
29
|
+
|
|
30
|
+
The audit warns when multiple DM senders share the main session and recommends **secure DM mode**: `session.dmScope="per-channel-peer"` (or `per-account-channel-peer` for multi-account channels) for shared inboxes.
|
|
31
|
+
This is for cooperative/shared inbox hardening. A single Gateway shared by mutually untrusted/adversarial operators is not a recommended setup; split trust boundaries with separate gateways (or separate OS users/hosts).
|
|
32
|
+
It also emits `security.trust_model.multi_user_heuristic` when config suggests likely shared-user ingress (for example open DM/group policy, configured group targets, or wildcard sender rules), and reminds you that Nodmix is a personal-assistant trust model by default.
|
|
33
|
+
For intentional shared-user setups, the audit guidance is to sandbox all sessions, keep filesystem access workspace-scoped, and keep personal/private identities or credentials off that runtime.
|
|
34
|
+
It also warns when small models (`<=300B`) are used without sandboxing and with web/browser tools enabled.
|
|
35
|
+
For webhook ingress, it warns when `hooks.token` reuses the Gateway token, when `hooks.token` is short, when `hooks.path="/"`, when `hooks.defaultSessionKey` is unset, when `hooks.allowedAgentIds` is unrestricted, when request `sessionKey` overrides are enabled, and when overrides are enabled without `hooks.allowedSessionKeyPrefixes`.
|
|
36
|
+
It also warns when sandbox Docker settings are configured while sandbox mode is off, when `gateway.nodes.denyCommands` uses ineffective pattern-like/unknown entries (exact node command-name matching only, not shell-text filtering), when `gateway.nodes.allowCommands` explicitly enables dangerous node commands, when global `tools.profile="minimal"` is overridden by agent tool profiles, when write/edit tools are disabled but `exec` is still available without a constraining sandbox filesystem boundary, when open groups expose runtime/filesystem tools without sandbox/workspace guards, and when installed plugin tools may be reachable under permissive tool policy.
|
|
37
|
+
It also flags `gateway.allowRealIpFallback=true` (header-spoofing risk if proxies are misconfigured) and `discovery.mdns.mode="full"` (metadata leakage via mDNS TXT records).
|
|
38
|
+
It also warns when sandbox browser uses Docker `bridge` network without `sandbox.browser.cdpSourceRange`.
|
|
39
|
+
It also flags dangerous sandbox Docker network modes (including `host` and `container:*` namespace joins).
|
|
40
|
+
It also warns when existing sandbox browser Docker containers have missing/stale hash labels (for example pre-migration containers missing `nodmix.browserConfigEpoch`) and recommends `nodmix sandbox recreate --browser --all`.
|
|
41
|
+
It also warns when npm-based plugin/hook install records are unpinned, missing integrity metadata, or drift from currently installed package versions.
|
|
42
|
+
It warns when channel allowlists rely on mutable names/emails/tags instead of stable IDs (Discord, Slack, Google Chat, Microsoft Teams, Mattermost, IRC scopes where applicable).
|
|
43
|
+
It warns when `gateway.auth.mode="none"` leaves Gateway HTTP APIs reachable without a shared secret (`/tools/invoke` plus any enabled `/v1/*` endpoint).
|
|
44
|
+
Settings prefixed with `dangerous`/`dangerously` are explicit break-glass operator overrides; enabling one is not, by itself, a security vulnerability report.
|
|
45
|
+
For the complete dangerous-parameter inventory, see the "Insecure or dangerous flags summary" section in [Security](/gateway/security).
|
|
46
|
+
|
|
47
|
+
Intentional standing findings can be accepted with `security.audit.suppressions`.
|
|
48
|
+
Each suppression matches an exact `checkId` and can be narrowed with
|
|
49
|
+
`titleIncludes` and/or `detailIncludes` case-insensitive substrings:
|
|
50
|
+
|
|
51
|
+
```json
|
|
52
|
+
{
|
|
53
|
+
"security": {
|
|
54
|
+
"audit": {
|
|
55
|
+
"suppressions": [
|
|
56
|
+
{
|
|
57
|
+
"checkId": "plugins.tools_reachable_permissive_policy",
|
|
58
|
+
"detailIncludes": "Enabled extension plugins: gbrain",
|
|
59
|
+
"reason": "trusted local operator plugin"
|
|
60
|
+
}
|
|
61
|
+
]
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
```
|
|
66
|
+
|
|
67
|
+
Suppressed findings are removed from the active `summary` and `findings` list.
|
|
68
|
+
JSON output keeps them under `suppressedFindings` for auditability.
|
|
69
|
+
When suppressions are configured, active output also keeps an unsuppressible
|
|
70
|
+
`security.audit.suppressions.active` info finding so readers can tell the audit
|
|
71
|
+
was filtered. Dangerous config flags are emitted one flag per finding, so
|
|
72
|
+
accepting one dangerous flag does not hide other enabled flags that share the
|
|
73
|
+
same `config.insecure_or_dangerous_flags` checkId.
|
|
74
|
+
Because suppressions can hide standing risk, adding or removing them through
|
|
75
|
+
agent-run shell commands requires exec approval unless exec is already running
|
|
76
|
+
with `security="full"` and `ask="off"` for trusted local automation.
|
|
77
|
+
|
|
78
|
+
SecretRef behavior:
|
|
79
|
+
|
|
80
|
+
- `security audit` resolves supported SecretRefs in read-only mode for its targeted paths.
|
|
81
|
+
- If a SecretRef is unavailable in the current command path, audit continues and reports `secretDiagnostics` (instead of crashing).
|
|
82
|
+
- `--token` and `--password` only override deep-probe auth for that command invocation; they do not rewrite config or SecretRef mappings.
|
|
83
|
+
|
|
84
|
+
## JSON output
|
|
85
|
+
|
|
86
|
+
Use `--json` for CI/policy checks:
|
|
87
|
+
|
|
88
|
+
```bash
|
|
89
|
+
nodmix security audit --json | jq '.summary'
|
|
90
|
+
nodmix security audit --deep --json | jq '.findings[] | select(.severity=="critical") | .checkId'
|
|
91
|
+
```
|
|
92
|
+
|
|
93
|
+
If `--fix` and `--json` are combined, output includes both fix actions and final report:
|
|
94
|
+
|
|
95
|
+
```bash
|
|
96
|
+
nodmix security audit --fix --json | jq '{fix: .fix.ok, summary: .report.summary}'
|
|
97
|
+
```
|
|
98
|
+
|
|
99
|
+
## What `--fix` changes
|
|
100
|
+
|
|
101
|
+
`--fix` applies safe, deterministic remediations:
|
|
102
|
+
|
|
103
|
+
- flips common `groupPolicy="open"` to `groupPolicy="allowlist"` (including account variants in supported channels)
|
|
104
|
+
- when WhatsApp group policy flips to `allowlist`, seeds `groupAllowFrom` from
|
|
105
|
+
the stored `allowFrom` file when that list exists and config does not already
|
|
106
|
+
define `allowFrom`
|
|
107
|
+
- sets `logging.redactSensitive` from `"off"` to `"tools"`
|
|
108
|
+
- tightens permissions for state/config and common sensitive files
|
|
109
|
+
(`credentials/*.json`, `auth-profiles.json`, `sessions.json`, session
|
|
110
|
+
`*.jsonl`)
|
|
111
|
+
- also tightens config include files referenced from `nodmix.json`
|
|
112
|
+
- uses `chmod` on POSIX hosts and `icacls` resets on Windows
|
|
113
|
+
|
|
114
|
+
`--fix` does **not**:
|
|
115
|
+
|
|
116
|
+
- rotate tokens/passwords/API keys
|
|
117
|
+
- disable tools (`gateway`, `cron`, `exec`, etc.)
|
|
118
|
+
- change gateway bind/auth/network exposure choices
|
|
119
|
+
- remove or rewrite plugins/skills
|
|
120
|
+
|
|
121
|
+
## Related
|
|
122
|
+
|
|
123
|
+
- [CLI reference](/cli)
|
|
124
|
+
- [Security audit](/gateway/security)
|