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,383 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Runbook for the Gateway service, lifecycle, and operations"
|
|
3
|
+
read_when:
|
|
4
|
+
- Running or debugging the gateway process
|
|
5
|
+
title: "Gateway runbook"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
Use this page for day-1 startup and day-2 operations of the Gateway service.
|
|
9
|
+
|
|
10
|
+
<CardGroup cols={2}>
|
|
11
|
+
<Card title="Deep troubleshooting" icon="siren" href="/gateway/troubleshooting">
|
|
12
|
+
Symptom-first diagnostics with exact command ladders and log signatures.
|
|
13
|
+
</Card>
|
|
14
|
+
<Card title="Configuration" icon="sliders" href="/gateway/configuration">
|
|
15
|
+
Task-oriented setup guide + full configuration reference.
|
|
16
|
+
</Card>
|
|
17
|
+
<Card title="Secrets management" icon="key-round" href="/gateway/secrets">
|
|
18
|
+
SecretRef contract, runtime snapshot behavior, and migrate/reload operations.
|
|
19
|
+
</Card>
|
|
20
|
+
<Card title="Secrets plan contract" icon="shield-check" href="/gateway/secrets-plan-contract">
|
|
21
|
+
Exact `secrets apply` target/path rules and ref-only auth-profile behavior.
|
|
22
|
+
</Card>
|
|
23
|
+
</CardGroup>
|
|
24
|
+
|
|
25
|
+
## 5-minute local startup
|
|
26
|
+
|
|
27
|
+
<Steps>
|
|
28
|
+
<Step title="Start the Gateway">
|
|
29
|
+
|
|
30
|
+
```bash
|
|
31
|
+
nodmix gateway --port 18789
|
|
32
|
+
# debug/trace mirrored to stdio
|
|
33
|
+
nodmix gateway --port 18789 --verbose
|
|
34
|
+
# force-kill listener on selected port, then start
|
|
35
|
+
nodmix gateway --force
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
</Step>
|
|
39
|
+
|
|
40
|
+
<Step title="Verify service health">
|
|
41
|
+
|
|
42
|
+
```bash
|
|
43
|
+
nodmix gateway status
|
|
44
|
+
nodmix status
|
|
45
|
+
nodmix logs --follow
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
Healthy baseline: `Runtime: running`, `Connectivity probe: ok`, and `Capability: ...` that matches what you expect. Use `nodmix gateway status --require-rpc` when you need read-scope RPC proof, not just reachability.
|
|
49
|
+
|
|
50
|
+
</Step>
|
|
51
|
+
|
|
52
|
+
<Step title="Validate channel readiness">
|
|
53
|
+
|
|
54
|
+
```bash
|
|
55
|
+
nodmix channels status --probe
|
|
56
|
+
```
|
|
57
|
+
|
|
58
|
+
With a reachable gateway this runs live per-account channel probes and optional audits.
|
|
59
|
+
If the gateway is unreachable, the CLI falls back to config-only channel summaries instead
|
|
60
|
+
of live probe output.
|
|
61
|
+
|
|
62
|
+
</Step>
|
|
63
|
+
</Steps>
|
|
64
|
+
|
|
65
|
+
<Note>
|
|
66
|
+
Gateway config reload watches the active config file path (resolved from profile/state defaults, or `NODMIX_CONFIG_PATH` when set).
|
|
67
|
+
Default mode is `gateway.reload.mode="hybrid"`.
|
|
68
|
+
After the first successful load, the running process serves the active in-memory config snapshot; successful reload swaps that snapshot atomically.
|
|
69
|
+
</Note>
|
|
70
|
+
|
|
71
|
+
## Runtime model
|
|
72
|
+
|
|
73
|
+
- One always-on process for routing, control plane, and channel connections.
|
|
74
|
+
- Single multiplexed port for:
|
|
75
|
+
- WebSocket control/RPC
|
|
76
|
+
- HTTP APIs (`/v1/models`, `/v1/embeddings`, `/v1/chat/completions`, `/v1/responses`, `/tools/invoke`)
|
|
77
|
+
- Plugin HTTP routes, such as optional `/api/v1/admin/rpc`
|
|
78
|
+
- Control UI and hooks
|
|
79
|
+
- Default bind mode: `loopback`.
|
|
80
|
+
- Auth is required by default. Shared-secret setups use
|
|
81
|
+
`gateway.auth.token` / `gateway.auth.password` (or
|
|
82
|
+
`NODMIX_GATEWAY_TOKEN` / `NODMIX_GATEWAY_PASSWORD`), and non-loopback
|
|
83
|
+
reverse-proxy setups can use `gateway.auth.mode: "trusted-proxy"`.
|
|
84
|
+
|
|
85
|
+
## OpenAI-compatible endpoints
|
|
86
|
+
|
|
87
|
+
Nodmix's highest-leverage compatibility surface is now:
|
|
88
|
+
|
|
89
|
+
- `GET /v1/models`
|
|
90
|
+
- `GET /v1/models/{id}`
|
|
91
|
+
- `POST /v1/embeddings`
|
|
92
|
+
- `POST /v1/chat/completions`
|
|
93
|
+
- `POST /v1/responses`
|
|
94
|
+
|
|
95
|
+
Why this set matters:
|
|
96
|
+
|
|
97
|
+
- Most Open WebUI, LobeChat, and LibreChat integrations probe `/v1/models` first.
|
|
98
|
+
- Many RAG and memory pipelines expect `/v1/embeddings`.
|
|
99
|
+
- Agent-native clients increasingly prefer `/v1/responses`.
|
|
100
|
+
|
|
101
|
+
Planning note:
|
|
102
|
+
|
|
103
|
+
- `/v1/models` is agent-first: it returns `nodmix`, `nodmix/default`, and `nodmix/<agentId>`.
|
|
104
|
+
- `nodmix/default` is the stable alias that always maps to the configured default agent.
|
|
105
|
+
- Use `x-nodmix-model` when you want a backend provider/model override; otherwise the selected agent's normal model and embedding setup stays in control.
|
|
106
|
+
|
|
107
|
+
All of these run on the main Gateway port and use the same trusted operator auth boundary as the rest of the Gateway HTTP API.
|
|
108
|
+
|
|
109
|
+
Admin HTTP RPC (`POST /api/v1/admin/rpc`) is a separate, default-off plugin route for host tooling that cannot use WebSocket RPC. See [Admin HTTP RPC](/plugins/admin-http-rpc).
|
|
110
|
+
|
|
111
|
+
### Port and bind precedence
|
|
112
|
+
|
|
113
|
+
| Setting | Resolution order |
|
|
114
|
+
| ------------ | ------------------------------------------------------------- |
|
|
115
|
+
| Gateway port | `--port` → `NODMIX_GATEWAY_PORT` → `gateway.port` → `18789` |
|
|
116
|
+
| Bind mode | CLI/override → `gateway.bind` → `loopback` |
|
|
117
|
+
|
|
118
|
+
Installed gateway services record the resolved `--port` in supervisor metadata. After changing `gateway.port`, run `nodmix doctor --fix` or `nodmix gateway install --force` so launchd/systemd/schtasks starts the process on the new port.
|
|
119
|
+
|
|
120
|
+
Gateway startup uses the same effective port and bind when it seeds local
|
|
121
|
+
Control UI origins for non-loopback binds. For example, `--bind lan --port 3000`
|
|
122
|
+
seeds `http://localhost:3000` and `http://127.0.0.1:3000` before runtime
|
|
123
|
+
validation runs. Add any remote browser origins, such as HTTPS proxy URLs, to
|
|
124
|
+
`gateway.controlUi.allowedOrigins` explicitly.
|
|
125
|
+
|
|
126
|
+
### Hot reload modes
|
|
127
|
+
|
|
128
|
+
| `gateway.reload.mode` | Behavior |
|
|
129
|
+
| --------------------- | ------------------------------------------ |
|
|
130
|
+
| `off` | No config reload |
|
|
131
|
+
| `hot` | Apply only hot-safe changes |
|
|
132
|
+
| `restart` | Restart on reload-required changes |
|
|
133
|
+
| `hybrid` (default) | Hot-apply when safe, restart when required |
|
|
134
|
+
|
|
135
|
+
## Operator command set
|
|
136
|
+
|
|
137
|
+
```bash
|
|
138
|
+
nodmix gateway status
|
|
139
|
+
nodmix gateway status --deep # adds a system-level service scan
|
|
140
|
+
nodmix gateway status --json
|
|
141
|
+
nodmix gateway install
|
|
142
|
+
nodmix gateway restart
|
|
143
|
+
nodmix gateway stop
|
|
144
|
+
nodmix secrets reload
|
|
145
|
+
nodmix logs --follow
|
|
146
|
+
nodmix doctor
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
`gateway status --deep` is for extra service discovery (LaunchDaemons/systemd system
|
|
150
|
+
units/schtasks), not a deeper RPC health probe.
|
|
151
|
+
|
|
152
|
+
## Multiple gateways (same host)
|
|
153
|
+
|
|
154
|
+
Most installs should run one gateway per machine. A single gateway can host multiple
|
|
155
|
+
agents and channels.
|
|
156
|
+
|
|
157
|
+
You only need multiple gateways when you intentionally want isolation or a rescue bot.
|
|
158
|
+
|
|
159
|
+
Useful checks:
|
|
160
|
+
|
|
161
|
+
```bash
|
|
162
|
+
nodmix gateway status --deep
|
|
163
|
+
nodmix gateway probe
|
|
164
|
+
```
|
|
165
|
+
|
|
166
|
+
What to expect:
|
|
167
|
+
|
|
168
|
+
- `gateway status --deep` can report `Other gateway-like services detected (best effort)`
|
|
169
|
+
and print cleanup hints when stale launchd/systemd/schtasks installs are still around.
|
|
170
|
+
- `gateway probe` can warn about `multiple reachable gateways` when more than one target
|
|
171
|
+
answers.
|
|
172
|
+
- If that is intentional, isolate ports, config/state, and workspace roots per gateway.
|
|
173
|
+
|
|
174
|
+
Checklist per instance:
|
|
175
|
+
|
|
176
|
+
- Unique `gateway.port`
|
|
177
|
+
- Unique `NODMIX_CONFIG_PATH`
|
|
178
|
+
- Unique `NODMIX_STATE_DIR`
|
|
179
|
+
- Unique `agents.defaults.workspace`
|
|
180
|
+
|
|
181
|
+
Example:
|
|
182
|
+
|
|
183
|
+
```bash
|
|
184
|
+
NODMIX_CONFIG_PATH=~/.nodmix/a.json NODMIX_STATE_DIR=~/.nodmix-a nodmix gateway --port 19001
|
|
185
|
+
NODMIX_CONFIG_PATH=~/.nodmix/b.json NODMIX_STATE_DIR=~/.nodmix-b nodmix gateway --port 19002
|
|
186
|
+
```
|
|
187
|
+
|
|
188
|
+
Detailed setup: [/gateway/multiple-gateways](/gateway/multiple-gateways).
|
|
189
|
+
|
|
190
|
+
## Remote access
|
|
191
|
+
|
|
192
|
+
Preferred: Tailscale/VPN.
|
|
193
|
+
Fallback: SSH tunnel.
|
|
194
|
+
|
|
195
|
+
```bash
|
|
196
|
+
ssh -N -L 18789:127.0.0.1:18789 user@host
|
|
197
|
+
```
|
|
198
|
+
|
|
199
|
+
Then connect clients locally to `ws://127.0.0.1:18789`.
|
|
200
|
+
|
|
201
|
+
<Warning>
|
|
202
|
+
SSH tunnels do not bypass gateway auth. For shared-secret auth, clients still
|
|
203
|
+
must send `token`/`password` even over the tunnel. For identity-bearing modes,
|
|
204
|
+
the request still has to satisfy that auth path.
|
|
205
|
+
</Warning>
|
|
206
|
+
|
|
207
|
+
See: [Remote Gateway](/gateway/remote), [Authentication](/gateway/authentication), [Tailscale](/gateway/tailscale).
|
|
208
|
+
|
|
209
|
+
## Supervision and service lifecycle
|
|
210
|
+
|
|
211
|
+
Use supervised runs for production-like reliability.
|
|
212
|
+
|
|
213
|
+
<Tabs>
|
|
214
|
+
<Tab title="macOS (launchd)">
|
|
215
|
+
|
|
216
|
+
```bash
|
|
217
|
+
nodmix gateway install
|
|
218
|
+
nodmix gateway status
|
|
219
|
+
nodmix gateway restart
|
|
220
|
+
nodmix gateway stop
|
|
221
|
+
```
|
|
222
|
+
|
|
223
|
+
Use `nodmix gateway restart` for restarts. Do not chain `nodmix gateway stop` and `nodmix gateway start` as a restart substitute.
|
|
224
|
+
|
|
225
|
+
On macOS, `gateway stop` uses `launchctl bootout` by default — this removes the LaunchAgent from the current boot session without persisting a disable, so KeepAlive auto-recovery still works after unexpected crashes and `gateway start` re-enables cleanly. To persistently suppress auto-respawn across reboots, pass `--disable`: `nodmix gateway stop --disable`.
|
|
226
|
+
|
|
227
|
+
LaunchAgent labels are `ai.nodmix.gateway` (default) or `ai.nodmix.<profile>` (named profile). `nodmix doctor` audits and repairs service config drift.
|
|
228
|
+
|
|
229
|
+
</Tab>
|
|
230
|
+
|
|
231
|
+
<Tab title="Linux (systemd user)">
|
|
232
|
+
|
|
233
|
+
```bash
|
|
234
|
+
nodmix gateway install
|
|
235
|
+
systemctl --user enable --now nodmix-gateway[-<profile>].service
|
|
236
|
+
nodmix gateway status
|
|
237
|
+
```
|
|
238
|
+
|
|
239
|
+
For persistence after logout, enable lingering:
|
|
240
|
+
|
|
241
|
+
```bash
|
|
242
|
+
sudo loginctl enable-linger <user>
|
|
243
|
+
```
|
|
244
|
+
|
|
245
|
+
Manual user-unit example when you need a custom install path:
|
|
246
|
+
|
|
247
|
+
```ini
|
|
248
|
+
[Unit]
|
|
249
|
+
Description=Nodmix Gateway
|
|
250
|
+
After=network-online.target
|
|
251
|
+
Wants=network-online.target
|
|
252
|
+
|
|
253
|
+
[Service]
|
|
254
|
+
ExecStart=/usr/local/bin/nodmix gateway --port 18789
|
|
255
|
+
Restart=always
|
|
256
|
+
RestartSec=5
|
|
257
|
+
TimeoutStopSec=30
|
|
258
|
+
TimeoutStartSec=30
|
|
259
|
+
SuccessExitStatus=0 143
|
|
260
|
+
KillMode=control-group
|
|
261
|
+
|
|
262
|
+
[Install]
|
|
263
|
+
WantedBy=default.target
|
|
264
|
+
```
|
|
265
|
+
|
|
266
|
+
</Tab>
|
|
267
|
+
|
|
268
|
+
<Tab title="Windows (native)">
|
|
269
|
+
|
|
270
|
+
```powershell
|
|
271
|
+
nodmix gateway install
|
|
272
|
+
nodmix gateway status --json
|
|
273
|
+
nodmix gateway restart
|
|
274
|
+
nodmix gateway stop
|
|
275
|
+
```
|
|
276
|
+
|
|
277
|
+
Native Windows managed startup uses a Scheduled Task named `Nodmix Gateway`
|
|
278
|
+
(or `Nodmix Gateway (<profile>)` for named profiles). If Scheduled Task
|
|
279
|
+
creation is denied, Nodmix falls back to a per-user Startup-folder launcher
|
|
280
|
+
that points at `gateway.cmd` inside the state directory.
|
|
281
|
+
|
|
282
|
+
</Tab>
|
|
283
|
+
|
|
284
|
+
<Tab title="Linux (system service)">
|
|
285
|
+
|
|
286
|
+
Use a system unit for multi-user/always-on hosts.
|
|
287
|
+
|
|
288
|
+
```bash
|
|
289
|
+
sudo systemctl daemon-reload
|
|
290
|
+
sudo systemctl enable --now nodmix-gateway[-<profile>].service
|
|
291
|
+
```
|
|
292
|
+
|
|
293
|
+
Use the same service body as the user unit, but install it under
|
|
294
|
+
`/etc/systemd/system/nodmix-gateway[-<profile>].service` and adjust
|
|
295
|
+
`ExecStart=` if your `nodmix` binary lives elsewhere.
|
|
296
|
+
|
|
297
|
+
Do not also let `nodmix doctor --fix` install a user-level gateway service for the same profile/port. Doctor refuses that automatic install when it finds a system-level Nodmix gateway service; use `NODMIX_SERVICE_REPAIR_POLICY=external` when the system unit owns the lifecycle.
|
|
298
|
+
|
|
299
|
+
</Tab>
|
|
300
|
+
</Tabs>
|
|
301
|
+
|
|
302
|
+
## Dev profile quick path
|
|
303
|
+
|
|
304
|
+
```bash
|
|
305
|
+
nodmix --dev setup
|
|
306
|
+
nodmix --dev gateway --allow-unconfigured
|
|
307
|
+
nodmix --dev status
|
|
308
|
+
```
|
|
309
|
+
|
|
310
|
+
Defaults include isolated state/config and base gateway port `19001`.
|
|
311
|
+
|
|
312
|
+
## Protocol quick reference (operator view)
|
|
313
|
+
|
|
314
|
+
- First client frame must be `connect`.
|
|
315
|
+
- Gateway returns `hello-ok` snapshot (`presence`, `health`, `stateVersion`, `uptimeMs`, limits/policy).
|
|
316
|
+
- `hello-ok.features.methods` / `events` are a conservative discovery list, not
|
|
317
|
+
a generated dump of every callable helper route.
|
|
318
|
+
- Requests: `req(method, params)` → `res(ok/payload|error)`.
|
|
319
|
+
- Common events include `connect.challenge`, `agent`, `chat`,
|
|
320
|
+
`session.message`, `session.operation`, `session.tool`, `sessions.changed`,
|
|
321
|
+
`presence`, `tick`, `health`, `heartbeat`, pairing/approval lifecycle events,
|
|
322
|
+
and `shutdown`.
|
|
323
|
+
|
|
324
|
+
Agent runs are two-stage:
|
|
325
|
+
|
|
326
|
+
1. Immediate accepted ack (`status:"accepted"`)
|
|
327
|
+
2. Final completion response (`status:"ok"|"error"`), with streamed `agent` events in between.
|
|
328
|
+
|
|
329
|
+
See full protocol docs: [Gateway Protocol](/gateway/protocol).
|
|
330
|
+
|
|
331
|
+
## Operational checks
|
|
332
|
+
|
|
333
|
+
### Liveness
|
|
334
|
+
|
|
335
|
+
- Open WS and send `connect`.
|
|
336
|
+
- Expect `hello-ok` response with snapshot.
|
|
337
|
+
|
|
338
|
+
### Readiness
|
|
339
|
+
|
|
340
|
+
```bash
|
|
341
|
+
nodmix gateway status
|
|
342
|
+
nodmix channels status --probe
|
|
343
|
+
nodmix health
|
|
344
|
+
```
|
|
345
|
+
|
|
346
|
+
### Gap recovery
|
|
347
|
+
|
|
348
|
+
Events are not replayed. On sequence gaps, refresh state (`health`, `system-presence`) before continuing.
|
|
349
|
+
|
|
350
|
+
## Common failure signatures
|
|
351
|
+
|
|
352
|
+
| Signature | Likely issue |
|
|
353
|
+
| -------------------------------------------------------------- | ------------------------------------------------------------------------------- |
|
|
354
|
+
| `refusing to bind gateway ... without auth` | Non-loopback bind without a valid gateway auth path |
|
|
355
|
+
| `another gateway instance is already listening` / `EADDRINUSE` | Port conflict |
|
|
356
|
+
| `Gateway start blocked: set gateway.mode=local` | Config set to remote mode, or local-mode stamp is missing from a damaged config |
|
|
357
|
+
| `unauthorized` during connect | Auth mismatch between client and gateway |
|
|
358
|
+
|
|
359
|
+
For full diagnosis ladders, use [Gateway Troubleshooting](/gateway/troubleshooting).
|
|
360
|
+
|
|
361
|
+
## Safety guarantees
|
|
362
|
+
|
|
363
|
+
- Gateway protocol clients fail fast when Gateway is unavailable (no implicit direct-channel fallback).
|
|
364
|
+
- Invalid/non-connect first frames are rejected and closed.
|
|
365
|
+
- Graceful shutdown emits `shutdown` event before socket close.
|
|
366
|
+
|
|
367
|
+
---
|
|
368
|
+
|
|
369
|
+
Related:
|
|
370
|
+
|
|
371
|
+
- [Troubleshooting](/gateway/troubleshooting)
|
|
372
|
+
- [Background Process](/gateway/background-process)
|
|
373
|
+
- [Configuration](/gateway/configuration)
|
|
374
|
+
- [Health](/gateway/health)
|
|
375
|
+
- [Doctor](/gateway/doctor)
|
|
376
|
+
- [Authentication](/gateway/authentication)
|
|
377
|
+
|
|
378
|
+
## Related
|
|
379
|
+
|
|
380
|
+
- [Configuration](/gateway/configuration)
|
|
381
|
+
- [Gateway troubleshooting](/gateway/troubleshooting)
|
|
382
|
+
- [Remote access](/gateway/remote)
|
|
383
|
+
- [Secrets management](/gateway/secrets)
|
|
@@ -0,0 +1,205 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Start local model servers on demand before Nodmix model requests"
|
|
3
|
+
read_when:
|
|
4
|
+
- You want Nodmix to start a local model server only when its model is selected
|
|
5
|
+
- You run ds4, inferrs, vLLM, llama.cpp, MLX, or another OpenAI-compatible local server
|
|
6
|
+
- You need to control cold start, readiness, and idle shutdown for local providers
|
|
7
|
+
title: "Local model services"
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
`models.providers.<id>.localService` lets Nodmix start a provider-owned local
|
|
11
|
+
model server on demand. It is provider-level config: when the selected model
|
|
12
|
+
belongs to that provider, Nodmix probes the service, starts the process if the
|
|
13
|
+
endpoint is down, waits for readiness, then sends the model request.
|
|
14
|
+
|
|
15
|
+
Use it for local servers that are expensive to keep running all day, or for
|
|
16
|
+
manual setups where model selection should be enough to bring the backend up.
|
|
17
|
+
|
|
18
|
+
## How it works
|
|
19
|
+
|
|
20
|
+
1. A model request resolves to a configured provider.
|
|
21
|
+
2. If that provider has `localService`, Nodmix probes `healthUrl`.
|
|
22
|
+
3. If the probe succeeds, Nodmix uses the existing server.
|
|
23
|
+
4. If the probe fails, Nodmix starts `command` with `args`.
|
|
24
|
+
5. Nodmix polls readiness until `readyTimeoutMs` expires.
|
|
25
|
+
6. The model request is sent through the normal provider transport.
|
|
26
|
+
7. If Nodmix started the process and `idleStopMs` is positive, the process is
|
|
27
|
+
stopped after the last in-flight request has been idle for that long.
|
|
28
|
+
|
|
29
|
+
Nodmix does not install launchd, systemd, Docker, or a daemon for this. The
|
|
30
|
+
server is a child process of the Nodmix process that first needed it.
|
|
31
|
+
|
|
32
|
+
## Config shape
|
|
33
|
+
|
|
34
|
+
```json5
|
|
35
|
+
{
|
|
36
|
+
models: {
|
|
37
|
+
providers: {
|
|
38
|
+
local: {
|
|
39
|
+
baseUrl: "http://127.0.0.1:8000/v1",
|
|
40
|
+
apiKey: "local-model",
|
|
41
|
+
api: "openai-completions",
|
|
42
|
+
timeoutSeconds: 300,
|
|
43
|
+
localService: {
|
|
44
|
+
command: "/absolute/path/to/server",
|
|
45
|
+
args: ["--host", "127.0.0.1", "--port", "8000"],
|
|
46
|
+
cwd: "/absolute/path/to/working-dir",
|
|
47
|
+
env: { LOCAL_MODEL_CACHE: "/absolute/path/to/cache" },
|
|
48
|
+
healthUrl: "http://127.0.0.1:8000/v1/models",
|
|
49
|
+
readyTimeoutMs: 180000,
|
|
50
|
+
idleStopMs: 0,
|
|
51
|
+
},
|
|
52
|
+
models: [
|
|
53
|
+
{
|
|
54
|
+
id: "my-local-model",
|
|
55
|
+
name: "My Local Model",
|
|
56
|
+
reasoning: false,
|
|
57
|
+
input: ["text"],
|
|
58
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
59
|
+
contextWindow: 131072,
|
|
60
|
+
maxTokens: 8192,
|
|
61
|
+
},
|
|
62
|
+
],
|
|
63
|
+
},
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
}
|
|
67
|
+
```
|
|
68
|
+
|
|
69
|
+
## Fields
|
|
70
|
+
|
|
71
|
+
- `command`: absolute executable path. Shell lookup is not used.
|
|
72
|
+
- `args`: process arguments. No shell expansion, pipes, globbing, or quoting
|
|
73
|
+
rules are applied.
|
|
74
|
+
- `cwd`: optional working directory for the process.
|
|
75
|
+
- `env`: optional environment variables merged over the Nodmix process
|
|
76
|
+
environment.
|
|
77
|
+
- `healthUrl`: readiness URL. If omitted, Nodmix appends `/models` to
|
|
78
|
+
`baseUrl`, so `http://127.0.0.1:8000/v1` becomes
|
|
79
|
+
`http://127.0.0.1:8000/v1/models`.
|
|
80
|
+
- `readyTimeoutMs`: startup readiness deadline. Default: `120000`.
|
|
81
|
+
- `idleStopMs`: idle shutdown delay for Nodmix-started processes. `0` or
|
|
82
|
+
omitted keeps the process alive until Nodmix exits.
|
|
83
|
+
|
|
84
|
+
## Inferrs example
|
|
85
|
+
|
|
86
|
+
Inferrs is a custom OpenAI-compatible `/v1` backend, so the same local service
|
|
87
|
+
API works with the `inferrs` provider entry.
|
|
88
|
+
|
|
89
|
+
```json5
|
|
90
|
+
{
|
|
91
|
+
agents: {
|
|
92
|
+
defaults: {
|
|
93
|
+
model: { primary: "inferrs/google/gemma-4-E2B-it" },
|
|
94
|
+
},
|
|
95
|
+
},
|
|
96
|
+
models: {
|
|
97
|
+
mode: "merge",
|
|
98
|
+
providers: {
|
|
99
|
+
inferrs: {
|
|
100
|
+
baseUrl: "http://127.0.0.1:8080/v1",
|
|
101
|
+
apiKey: "inferrs-local",
|
|
102
|
+
api: "openai-completions",
|
|
103
|
+
timeoutSeconds: 300,
|
|
104
|
+
localService: {
|
|
105
|
+
command: "/opt/homebrew/bin/inferrs",
|
|
106
|
+
args: [
|
|
107
|
+
"serve",
|
|
108
|
+
"google/gemma-4-E2B-it",
|
|
109
|
+
"--host",
|
|
110
|
+
"127.0.0.1",
|
|
111
|
+
"--port",
|
|
112
|
+
"8080",
|
|
113
|
+
"--device",
|
|
114
|
+
"metal",
|
|
115
|
+
],
|
|
116
|
+
healthUrl: "http://127.0.0.1:8080/v1/models",
|
|
117
|
+
readyTimeoutMs: 180000,
|
|
118
|
+
idleStopMs: 0,
|
|
119
|
+
},
|
|
120
|
+
models: [
|
|
121
|
+
{
|
|
122
|
+
id: "google/gemma-4-E2B-it",
|
|
123
|
+
name: "Gemma 4 E2B (inferrs)",
|
|
124
|
+
reasoning: false,
|
|
125
|
+
input: ["text"],
|
|
126
|
+
cost: { input: 0, output: 0, cacheRead: 0, cacheWrite: 0 },
|
|
127
|
+
contextWindow: 131072,
|
|
128
|
+
maxTokens: 4096,
|
|
129
|
+
compat: {
|
|
130
|
+
requiresStringContent: true,
|
|
131
|
+
},
|
|
132
|
+
},
|
|
133
|
+
],
|
|
134
|
+
},
|
|
135
|
+
},
|
|
136
|
+
},
|
|
137
|
+
}
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
Replace `command` with the result of `which inferrs` on the machine running
|
|
141
|
+
Nodmix.
|
|
142
|
+
|
|
143
|
+
## ds4 example
|
|
144
|
+
|
|
145
|
+
For the full setup, context sizing guidance, and verification commands, see
|
|
146
|
+
[ds4](/providers/ds4).
|
|
147
|
+
|
|
148
|
+
```json5
|
|
149
|
+
{
|
|
150
|
+
models: {
|
|
151
|
+
providers: {
|
|
152
|
+
ds4: {
|
|
153
|
+
baseUrl: "http://127.0.0.1:18000/v1",
|
|
154
|
+
apiKey: "ds4-local",
|
|
155
|
+
api: "openai-completions",
|
|
156
|
+
timeoutSeconds: 300,
|
|
157
|
+
localService: {
|
|
158
|
+
command: "<DS4_DIR>/ds4-server",
|
|
159
|
+
args: [
|
|
160
|
+
"--model",
|
|
161
|
+
"<DS4_DIR>/ds4flash.gguf",
|
|
162
|
+
"--host",
|
|
163
|
+
"127.0.0.1",
|
|
164
|
+
"--port",
|
|
165
|
+
"18000",
|
|
166
|
+
"--ctx",
|
|
167
|
+
"32768",
|
|
168
|
+
"--tokens",
|
|
169
|
+
"128",
|
|
170
|
+
],
|
|
171
|
+
cwd: "<DS4_DIR>",
|
|
172
|
+
healthUrl: "http://127.0.0.1:18000/v1/models",
|
|
173
|
+
readyTimeoutMs: 300000,
|
|
174
|
+
idleStopMs: 0,
|
|
175
|
+
},
|
|
176
|
+
models: [],
|
|
177
|
+
},
|
|
178
|
+
},
|
|
179
|
+
},
|
|
180
|
+
}
|
|
181
|
+
```
|
|
182
|
+
|
|
183
|
+
## Operational notes
|
|
184
|
+
|
|
185
|
+
- One Nodmix process manages the child it started. Another Nodmix process
|
|
186
|
+
that sees the same health URL already live will reuse it without adopting it.
|
|
187
|
+
- Startup is serialized per provider command and argument set, so concurrent
|
|
188
|
+
requests do not spawn duplicate servers for the same config.
|
|
189
|
+
- Active streaming responses hold a lease; idle shutdown waits until response
|
|
190
|
+
body handling is complete.
|
|
191
|
+
- Use `timeoutSeconds` on slow local providers so cold starts and long generations
|
|
192
|
+
do not hit the default model request timeout.
|
|
193
|
+
- Use an explicit `healthUrl` if your server exposes readiness somewhere other
|
|
194
|
+
than `/v1/models`.
|
|
195
|
+
|
|
196
|
+
## Related
|
|
197
|
+
|
|
198
|
+
<CardGroup cols={2}>
|
|
199
|
+
<Card title="Local models" href="/gateway/local-models" icon="server">
|
|
200
|
+
Local model setup, provider choices, and safety guidance.
|
|
201
|
+
</Card>
|
|
202
|
+
<Card title="Inferrs" href="/providers/inferrs" icon="cpu">
|
|
203
|
+
Run Nodmix through the inferrs OpenAI-compatible local server.
|
|
204
|
+
</Card>
|
|
205
|
+
</CardGroup>
|