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,107 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Gateway dashboard (Control UI) access and auth"
|
|
3
|
+
read_when:
|
|
4
|
+
- Changing dashboard authentication or exposure modes
|
|
5
|
+
title: "Dashboard"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
The Gateway dashboard is the browser Control UI served at `/` by default
|
|
9
|
+
(override with `gateway.controlUi.basePath`).
|
|
10
|
+
|
|
11
|
+
Quick open (local Gateway):
|
|
12
|
+
|
|
13
|
+
- [http://127.0.0.1:18789/](http://127.0.0.1:18789/) (or [http://localhost:18789/](http://localhost:18789/))
|
|
14
|
+
- With `gateway.tls.enabled: true`, use `https://127.0.0.1:18789/` and
|
|
15
|
+
`wss://127.0.0.1:18789` for the WebSocket endpoint.
|
|
16
|
+
|
|
17
|
+
Key references:
|
|
18
|
+
|
|
19
|
+
- [Control UI](/web/control-ui) for usage and UI capabilities.
|
|
20
|
+
- [Tailscale](/gateway/tailscale) for Serve/Funnel automation.
|
|
21
|
+
- [Web surfaces](/web) for bind modes and security notes.
|
|
22
|
+
|
|
23
|
+
Authentication is enforced at the WebSocket handshake via the configured gateway
|
|
24
|
+
auth path:
|
|
25
|
+
|
|
26
|
+
- `connect.params.auth.token`
|
|
27
|
+
- `connect.params.auth.password`
|
|
28
|
+
- Tailscale Serve identity headers when `gateway.auth.allowTailscale: true`
|
|
29
|
+
- trusted-proxy identity headers when `gateway.auth.mode: "trusted-proxy"`
|
|
30
|
+
|
|
31
|
+
See `gateway.auth` in [Gateway configuration](/gateway/configuration).
|
|
32
|
+
|
|
33
|
+
Security note: the Control UI is an **admin surface** (chat, config, exec approvals).
|
|
34
|
+
Do not expose it publicly. The UI keeps dashboard URL tokens in sessionStorage
|
|
35
|
+
for the current browser tab session and selected gateway URL, and strips them from the URL after load.
|
|
36
|
+
Prefer localhost, Tailscale Serve, or an SSH tunnel.
|
|
37
|
+
|
|
38
|
+
## Fast path (recommended)
|
|
39
|
+
|
|
40
|
+
- After onboarding, the CLI auto-opens the dashboard and prints a clean (non-tokenized) link.
|
|
41
|
+
- Re-open anytime: `nodmix dashboard` (copies link, opens browser if possible, shows SSH hint if headless).
|
|
42
|
+
- If clipboard and browser delivery fail, `nodmix dashboard` still prints the
|
|
43
|
+
clean URL and tells you to use the token from `NODMIX_GATEWAY_TOKEN` or
|
|
44
|
+
`gateway.auth.token` as the URL fragment key `token`; it does not print token
|
|
45
|
+
values in logs.
|
|
46
|
+
- If the UI prompts for shared-secret auth, paste the configured token or
|
|
47
|
+
password into Control UI settings.
|
|
48
|
+
|
|
49
|
+
## Auth basics (local vs remote)
|
|
50
|
+
|
|
51
|
+
- **Localhost**: open `http://127.0.0.1:18789/`.
|
|
52
|
+
- **Gateway TLS**: when `gateway.tls.enabled: true`, dashboard/status links use
|
|
53
|
+
`https://` and Control UI WebSocket links use `wss://`.
|
|
54
|
+
- **Shared-secret token source**: `gateway.auth.token` (or
|
|
55
|
+
`NODMIX_GATEWAY_TOKEN`); `nodmix dashboard` can pass it via URL fragment
|
|
56
|
+
for one-time bootstrap, and the Control UI keeps it in sessionStorage for the
|
|
57
|
+
current browser tab session and selected gateway URL instead of localStorage.
|
|
58
|
+
- If `gateway.auth.token` is SecretRef-managed, `nodmix dashboard`
|
|
59
|
+
prints/copies/opens a non-tokenized URL by design. This avoids exposing
|
|
60
|
+
externally managed tokens in shell logs, clipboard history, or browser-launch
|
|
61
|
+
arguments.
|
|
62
|
+
- If `gateway.auth.token` is configured as a SecretRef and is unresolved in your
|
|
63
|
+
current shell, `nodmix dashboard` still prints a non-tokenized URL plus
|
|
64
|
+
actionable auth setup guidance.
|
|
65
|
+
- **Shared-secret password**: use the configured `gateway.auth.password` (or
|
|
66
|
+
`NODMIX_GATEWAY_PASSWORD`). The dashboard does not persist passwords across
|
|
67
|
+
reloads.
|
|
68
|
+
- **Identity-bearing modes**: Tailscale Serve can satisfy Control UI/WebSocket
|
|
69
|
+
auth via identity headers when `gateway.auth.allowTailscale: true`, and a
|
|
70
|
+
non-loopback identity-aware reverse proxy can satisfy
|
|
71
|
+
`gateway.auth.mode: "trusted-proxy"`. In those modes the dashboard does not
|
|
72
|
+
need a pasted shared secret for the WebSocket.
|
|
73
|
+
- **Not localhost**: use Tailscale Serve, a non-loopback shared-secret bind, a
|
|
74
|
+
non-loopback identity-aware reverse proxy with
|
|
75
|
+
`gateway.auth.mode: "trusted-proxy"`, or an SSH tunnel. HTTP APIs still use
|
|
76
|
+
shared-secret auth unless you intentionally run private-ingress
|
|
77
|
+
`gateway.auth.mode: "none"` or trusted-proxy HTTP auth. See
|
|
78
|
+
[Web surfaces](/web).
|
|
79
|
+
|
|
80
|
+
<a id="if-you-see-unauthorized-1008"></a>
|
|
81
|
+
|
|
82
|
+
## If you see "unauthorized" / 1008
|
|
83
|
+
|
|
84
|
+
- Ensure the gateway is reachable (local: `nodmix status`; remote: SSH tunnel `ssh -N -L 18789:127.0.0.1:18789 user@host` then open `http://127.0.0.1:18789/`).
|
|
85
|
+
- For `AUTH_TOKEN_MISMATCH`, clients may do one trusted retry with a cached device token when the gateway returns retry hints. That cached-token retry reuses the token's cached approved scopes; explicit `deviceToken` / explicit `scopes` callers keep their requested scope set. If auth still fails after that retry, resolve token drift manually.
|
|
86
|
+
- For `AUTH_SCOPE_MISMATCH`, the device token was recognized but does not carry the dashboard's requested scopes; re-pair or approve the requested scope contract instead of rotating the shared gateway token.
|
|
87
|
+
- Outside that retry path, connect auth precedence is explicit shared token/password first, then explicit `deviceToken`, then stored device token, then bootstrap token.
|
|
88
|
+
- On the async Tailscale Serve Control UI path, failed attempts for the same
|
|
89
|
+
`{scope, ip}` are serialized before the failed-auth limiter records them, so
|
|
90
|
+
the second concurrent bad retry can already show `retry later`.
|
|
91
|
+
- For token drift repair steps, follow [Token drift recovery checklist](/cli/devices#token-drift-recovery-checklist).
|
|
92
|
+
- Retrieve or supply the shared secret from the gateway host:
|
|
93
|
+
- Token: `nodmix config get gateway.auth.token`
|
|
94
|
+
- Password: resolve the configured `gateway.auth.password` or
|
|
95
|
+
`NODMIX_GATEWAY_PASSWORD`
|
|
96
|
+
- SecretRef-managed token: resolve the external secret provider or export
|
|
97
|
+
`NODMIX_GATEWAY_TOKEN` in this shell, then rerun `nodmix dashboard`
|
|
98
|
+
- No shared secret configured: `nodmix doctor --generate-gateway-token`
|
|
99
|
+
- In the dashboard settings, paste the token or password into the auth field,
|
|
100
|
+
then connect.
|
|
101
|
+
- The UI language picker is in **Overview -> Gateway Access -> Language**.
|
|
102
|
+
It is part of the access card, not the Appearance section.
|
|
103
|
+
|
|
104
|
+
## Related
|
|
105
|
+
|
|
106
|
+
- [Control UI](/web/control-ui)
|
|
107
|
+
- [WebChat](/web/webchat)
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Gateway web surfaces: Control UI, bind modes, and security"
|
|
3
|
+
read_when:
|
|
4
|
+
- You want to access the Gateway over Tailscale
|
|
5
|
+
- You want the browser Control UI and config editing
|
|
6
|
+
title: "Web"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
The Gateway serves a small **browser Control UI** (Vite + Lit) from the same port as the Gateway WebSocket:
|
|
10
|
+
|
|
11
|
+
- default: `http://<host>:18789/`
|
|
12
|
+
- with `gateway.tls.enabled: true`: `https://<host>:18789/`
|
|
13
|
+
- optional prefix: set `gateway.controlUi.basePath` (e.g. `/nodmix`)
|
|
14
|
+
|
|
15
|
+
Capabilities live in [Control UI](/web/control-ui). The rest of this page focuses on bind modes, security, and web-facing surfaces.
|
|
16
|
+
|
|
17
|
+
## Webhooks
|
|
18
|
+
|
|
19
|
+
When `hooks.enabled=true`, the Gateway also exposes a small webhook endpoint on the same HTTP server.
|
|
20
|
+
See [Gateway configuration](/gateway/configuration) → `hooks` for auth + payloads.
|
|
21
|
+
|
|
22
|
+
## Admin HTTP RPC
|
|
23
|
+
|
|
24
|
+
Admin HTTP RPC exposes selected Gateway control-plane methods at `POST /api/v1/admin/rpc`.
|
|
25
|
+
It is off by default and is registered only when the `admin-http-rpc` plugin is enabled.
|
|
26
|
+
See [Admin HTTP RPC](/plugins/admin-http-rpc) for the auth model, allowed methods, and WebSocket comparison.
|
|
27
|
+
|
|
28
|
+
## Config (default-on)
|
|
29
|
+
|
|
30
|
+
The Control UI is **enabled by default** when assets are present (`dist/control-ui`).
|
|
31
|
+
You can control it via config:
|
|
32
|
+
|
|
33
|
+
```json5
|
|
34
|
+
{
|
|
35
|
+
gateway: {
|
|
36
|
+
controlUi: { enabled: true, basePath: "/nodmix" }, // basePath optional
|
|
37
|
+
},
|
|
38
|
+
}
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
## Tailscale access
|
|
42
|
+
|
|
43
|
+
### Integrated Serve (recommended)
|
|
44
|
+
|
|
45
|
+
Keep the Gateway on loopback and let Tailscale Serve proxy it:
|
|
46
|
+
|
|
47
|
+
```json5
|
|
48
|
+
{
|
|
49
|
+
gateway: {
|
|
50
|
+
bind: "loopback",
|
|
51
|
+
tailscale: { mode: "serve" },
|
|
52
|
+
},
|
|
53
|
+
}
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
Then start the gateway:
|
|
57
|
+
|
|
58
|
+
```bash
|
|
59
|
+
nodmix gateway
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
Open:
|
|
63
|
+
|
|
64
|
+
- `https://<magicdns>/` (or your configured `gateway.controlUi.basePath`)
|
|
65
|
+
|
|
66
|
+
### Tailnet bind + token
|
|
67
|
+
|
|
68
|
+
```json5
|
|
69
|
+
{
|
|
70
|
+
gateway: {
|
|
71
|
+
bind: "tailnet",
|
|
72
|
+
controlUi: { enabled: true },
|
|
73
|
+
auth: { mode: "token", token: "your-token" },
|
|
74
|
+
},
|
|
75
|
+
}
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
Then start the gateway (this non-loopback example uses shared-secret token
|
|
79
|
+
auth):
|
|
80
|
+
|
|
81
|
+
```bash
|
|
82
|
+
nodmix gateway
|
|
83
|
+
```
|
|
84
|
+
|
|
85
|
+
Open:
|
|
86
|
+
|
|
87
|
+
- `http://<tailscale-ip>:18789/` (or your configured `gateway.controlUi.basePath`)
|
|
88
|
+
|
|
89
|
+
### Public internet (Funnel)
|
|
90
|
+
|
|
91
|
+
```json5
|
|
92
|
+
{
|
|
93
|
+
gateway: {
|
|
94
|
+
bind: "loopback",
|
|
95
|
+
tailscale: { mode: "funnel" },
|
|
96
|
+
auth: { mode: "password" }, // or NODMIX_GATEWAY_PASSWORD
|
|
97
|
+
},
|
|
98
|
+
}
|
|
99
|
+
```
|
|
100
|
+
|
|
101
|
+
## Security notes
|
|
102
|
+
|
|
103
|
+
- Gateway auth is required by default (token, password, trusted-proxy, or Tailscale Serve identity headers when enabled).
|
|
104
|
+
- Non-loopback binds still **require** gateway auth. In practice that means token/password auth or an identity-aware reverse proxy with `gateway.auth.mode: "trusted-proxy"`.
|
|
105
|
+
- The wizard creates shared-secret auth by default and usually generates a
|
|
106
|
+
gateway token (even on loopback).
|
|
107
|
+
- In shared-secret mode, the UI sends `connect.params.auth.token` or
|
|
108
|
+
`connect.params.auth.password`.
|
|
109
|
+
- When `gateway.tls.enabled: true`, local dashboard and status helpers render
|
|
110
|
+
`https://` dashboard URLs and `wss://` WebSocket URLs.
|
|
111
|
+
- In identity-bearing modes such as Tailscale Serve or `trusted-proxy`, the
|
|
112
|
+
WebSocket auth check is satisfied from request headers instead.
|
|
113
|
+
- For public non-loopback Control UI deployments, set `gateway.controlUi.allowedOrigins`
|
|
114
|
+
explicitly (full origins). Private same-origin LAN/Tailnet loads are accepted for loopback,
|
|
115
|
+
RFC1918/link-local, `.local`, `.ts.net`, and Tailscale CGNAT hosts.
|
|
116
|
+
- `gateway.controlUi.dangerouslyAllowHostHeaderOriginFallback=true` enables
|
|
117
|
+
Host-header origin fallback mode, but is a dangerous security downgrade.
|
|
118
|
+
- With Serve, Tailscale identity headers can satisfy Control UI/WebSocket auth
|
|
119
|
+
when `gateway.auth.allowTailscale` is `true` (no token/password required).
|
|
120
|
+
HTTP API endpoints do not use those Tailscale identity headers; they follow
|
|
121
|
+
the gateway's normal HTTP auth mode instead. Set
|
|
122
|
+
`gateway.auth.allowTailscale: false` to require explicit credentials. See
|
|
123
|
+
[Tailscale](/gateway/tailscale) and [Security](/gateway/security). This
|
|
124
|
+
tokenless flow assumes the gateway host is trusted.
|
|
125
|
+
- `gateway.tailscale.mode: "funnel"` requires `gateway.auth.mode: "password"` (shared password).
|
|
126
|
+
|
|
127
|
+
## Building the UI
|
|
128
|
+
|
|
129
|
+
The Gateway serves static files from `dist/control-ui`. Build them with:
|
|
130
|
+
|
|
131
|
+
```bash
|
|
132
|
+
pnpm ui:build
|
|
133
|
+
```
|
package/docs/web/tui.md
ADDED
|
@@ -0,0 +1,246 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Terminal UI (TUI): connect to the Gateway or run locally in embedded mode"
|
|
3
|
+
read_when:
|
|
4
|
+
- You want a beginner-friendly walkthrough of the TUI
|
|
5
|
+
- You need the complete list of TUI features, commands, and shortcuts
|
|
6
|
+
title: "TUI"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
## Quick start
|
|
10
|
+
|
|
11
|
+
### Gateway mode
|
|
12
|
+
|
|
13
|
+
1. Start the Gateway.
|
|
14
|
+
|
|
15
|
+
```bash
|
|
16
|
+
nodmix gateway
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
2. Open the TUI.
|
|
20
|
+
|
|
21
|
+
```bash
|
|
22
|
+
nodmix tui
|
|
23
|
+
```
|
|
24
|
+
|
|
25
|
+
3. Type a message and press Enter.
|
|
26
|
+
|
|
27
|
+
Remote Gateway:
|
|
28
|
+
|
|
29
|
+
```bash
|
|
30
|
+
nodmix tui --url ws://<host>:<port> --token <gateway-token>
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
Use `--password` if your Gateway uses password auth.
|
|
34
|
+
|
|
35
|
+
### Local mode
|
|
36
|
+
|
|
37
|
+
Run the TUI without a Gateway:
|
|
38
|
+
|
|
39
|
+
```bash
|
|
40
|
+
nodmix chat
|
|
41
|
+
# or
|
|
42
|
+
nodmix tui --local
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
Notes:
|
|
46
|
+
|
|
47
|
+
- `nodmix chat` and `nodmix terminal` are aliases for `nodmix tui --local`.
|
|
48
|
+
- `--local` cannot be combined with `--url`, `--token`, or `--password`.
|
|
49
|
+
- Local mode uses the embedded agent runtime directly. Most local tools work, but Gateway-only features are unavailable.
|
|
50
|
+
- `nodmix` and `nodmix crestodian` also use this TUI shell, with Crestodian as the local setup and repair chat backend.
|
|
51
|
+
|
|
52
|
+
## What you see
|
|
53
|
+
|
|
54
|
+
- Header: connection URL, current agent, current session.
|
|
55
|
+
- Chat log: user messages, assistant replies, system notices, tool cards.
|
|
56
|
+
- Status line: connection/run state (connecting, running, streaming, idle, error).
|
|
57
|
+
- Footer: connection state + agent + session + model + think/fast/verbose/trace/reasoning + token counts + deliver.
|
|
58
|
+
- Input: text editor with autocomplete.
|
|
59
|
+
|
|
60
|
+
## Mental model: agents + sessions
|
|
61
|
+
|
|
62
|
+
- Agents are unique slugs (e.g. `main`, `research`). The Gateway exposes the list.
|
|
63
|
+
- Sessions belong to the current agent.
|
|
64
|
+
- Session keys are stored as `agent:<agentId>:<sessionKey>`.
|
|
65
|
+
- If you type `/session main`, the TUI expands it to `agent:<currentAgent>:main`.
|
|
66
|
+
- If you type `/session agent:other:main`, you switch to that agent session explicitly.
|
|
67
|
+
- Session scope:
|
|
68
|
+
- `per-sender` (default): each agent has many sessions.
|
|
69
|
+
- `global`: the TUI always uses the `global` session (the picker may be empty).
|
|
70
|
+
- The current agent + session are always visible in the footer.
|
|
71
|
+
- When started without `--session`, gateway-mode TUI resumes the last selected session for the same gateway, agent, and session scope if that session still exists. Passing `--session`, `/session`, `/new`, or `/reset` remains explicit.
|
|
72
|
+
|
|
73
|
+
## Sending + delivery
|
|
74
|
+
|
|
75
|
+
- Messages are sent to the Gateway; delivery to providers is off by default.
|
|
76
|
+
- The TUI is an internal source surface like WebChat, not a generic outbound channel. Harnesses that require `tools.message` for visible replies can satisfy the active TUI turn with a targetless `message.send`; explicit provider delivery still uses normal configured channels and never falls back to `lastChannel`.
|
|
77
|
+
- Turn delivery on:
|
|
78
|
+
- `/deliver on`
|
|
79
|
+
- or the Settings panel
|
|
80
|
+
- or start with `nodmix tui --deliver`
|
|
81
|
+
|
|
82
|
+
## Pickers + overlays
|
|
83
|
+
|
|
84
|
+
- Model picker: list available models and set the session override.
|
|
85
|
+
- Agent picker: choose a different agent.
|
|
86
|
+
- Session picker: shows up to 50 sessions for the current agent updated in the last 7 days. Use `/session <key>` to jump to an older known session.
|
|
87
|
+
- Settings: toggle deliver, tool output expansion, and thinking visibility.
|
|
88
|
+
|
|
89
|
+
## Keyboard shortcuts
|
|
90
|
+
|
|
91
|
+
- Enter: send message
|
|
92
|
+
- Esc: abort active run
|
|
93
|
+
- Ctrl+C: clear input (press twice to exit)
|
|
94
|
+
- Ctrl+D: exit
|
|
95
|
+
- Ctrl+L: model picker
|
|
96
|
+
- Ctrl+G: agent picker
|
|
97
|
+
- Ctrl+P: session picker
|
|
98
|
+
- Ctrl+O: toggle tool output expansion
|
|
99
|
+
- Ctrl+T: toggle thinking visibility (reloads history)
|
|
100
|
+
|
|
101
|
+
## Slash commands
|
|
102
|
+
|
|
103
|
+
Core:
|
|
104
|
+
|
|
105
|
+
- `/help`
|
|
106
|
+
- `/status`
|
|
107
|
+
- `/agent <id>` (or `/agents`)
|
|
108
|
+
- `/session <key>` (or `/sessions`)
|
|
109
|
+
- `/model <provider/model>` (or `/models`)
|
|
110
|
+
|
|
111
|
+
Session controls:
|
|
112
|
+
|
|
113
|
+
- `/think <off|minimal|low|medium|high>`
|
|
114
|
+
- `/fast <status|on|off>`
|
|
115
|
+
- `/verbose <on|full|off>`
|
|
116
|
+
- `/trace <on|off>`
|
|
117
|
+
- `/reasoning <on|off|stream>`
|
|
118
|
+
- `/usage <off|tokens|full>`
|
|
119
|
+
- `/elevated <on|off|ask|full>` (alias: `/elev`)
|
|
120
|
+
- `/activation <mention|always>`
|
|
121
|
+
- `/deliver <on|off>`
|
|
122
|
+
|
|
123
|
+
Session lifecycle:
|
|
124
|
+
|
|
125
|
+
- `/new` or `/reset` (reset the session)
|
|
126
|
+
- `/abort` (abort the active run)
|
|
127
|
+
- `/settings`
|
|
128
|
+
- `/exit`
|
|
129
|
+
|
|
130
|
+
Local mode only:
|
|
131
|
+
|
|
132
|
+
- `/auth [provider]` opens the provider auth/login flow inside the TUI.
|
|
133
|
+
|
|
134
|
+
Other Gateway slash commands (for example, `/context`) are forwarded to the Gateway and shown as system output. See [Slash commands](/tools/slash-commands).
|
|
135
|
+
|
|
136
|
+
## Local shell commands
|
|
137
|
+
|
|
138
|
+
- Prefix a line with `!` to run a local shell command on the TUI host.
|
|
139
|
+
- The TUI prompts once per session to allow local execution; declining keeps `!` disabled for the session.
|
|
140
|
+
- Commands run in a fresh, non-interactive shell in the TUI working directory (no persistent `cd`/env).
|
|
141
|
+
- Local shell commands receive `NODMIX_SHELL=tui-local` in their environment.
|
|
142
|
+
- A lone `!` is sent as a normal message; leading spaces do not trigger local exec.
|
|
143
|
+
|
|
144
|
+
## Repair configs from the local TUI
|
|
145
|
+
|
|
146
|
+
Use local mode when the current config already validates and you want the
|
|
147
|
+
embedded agent to inspect it on the same machine, compare it against the docs,
|
|
148
|
+
and help repair drift without depending on a running Gateway.
|
|
149
|
+
|
|
150
|
+
If `nodmix config validate` is already failing, start with `nodmix configure`
|
|
151
|
+
or `nodmix doctor --fix` first. `nodmix chat` does not bypass the invalid-
|
|
152
|
+
config guard.
|
|
153
|
+
|
|
154
|
+
Typical loop:
|
|
155
|
+
|
|
156
|
+
1. Start local mode:
|
|
157
|
+
|
|
158
|
+
```bash
|
|
159
|
+
nodmix chat
|
|
160
|
+
```
|
|
161
|
+
|
|
162
|
+
2. Ask the agent what you want checked, for example:
|
|
163
|
+
|
|
164
|
+
```text
|
|
165
|
+
Compare my gateway auth config with the docs and suggest the smallest fix.
|
|
166
|
+
```
|
|
167
|
+
|
|
168
|
+
3. Use local shell commands for exact evidence and validation:
|
|
169
|
+
|
|
170
|
+
```text
|
|
171
|
+
!nodmix config file
|
|
172
|
+
!nodmix docs gateway auth token secretref
|
|
173
|
+
!nodmix config validate
|
|
174
|
+
!nodmix doctor
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
4. Apply narrow changes with `nodmix config set` or `nodmix configure`, then rerun `!nodmix config validate`.
|
|
178
|
+
5. If Doctor recommends an automatic migration or repair, review it and run `!nodmix doctor --fix`.
|
|
179
|
+
|
|
180
|
+
Tips:
|
|
181
|
+
|
|
182
|
+
- Prefer `nodmix config set` or `nodmix configure` over hand-editing `nodmix.json`.
|
|
183
|
+
- `nodmix docs "<query>"` searches the live docs index from the same machine.
|
|
184
|
+
- `nodmix config validate --json` is useful when you want structured schema and SecretRef/resolvability errors.
|
|
185
|
+
|
|
186
|
+
## Tool output
|
|
187
|
+
|
|
188
|
+
- Tool calls show as cards with args + results.
|
|
189
|
+
- Ctrl+O toggles between collapsed/expanded views.
|
|
190
|
+
- While tools run, partial updates stream into the same card.
|
|
191
|
+
|
|
192
|
+
## Terminal colors
|
|
193
|
+
|
|
194
|
+
- The TUI keeps assistant body text in your terminal's default foreground so dark and light terminals both stay readable.
|
|
195
|
+
- If your terminal uses a light background and auto-detection is wrong, set `NODMIX_THEME=light` before launching `nodmix tui`.
|
|
196
|
+
- To force the original dark palette instead, set `NODMIX_THEME=dark`.
|
|
197
|
+
|
|
198
|
+
## History + streaming
|
|
199
|
+
|
|
200
|
+
- On connect, the TUI loads the latest history (default 200 messages).
|
|
201
|
+
- Streaming responses update in place until finalized.
|
|
202
|
+
- The TUI also listens to agent tool events for richer tool cards.
|
|
203
|
+
|
|
204
|
+
## Connection details
|
|
205
|
+
|
|
206
|
+
- The TUI registers with the Gateway as `mode: "tui"`.
|
|
207
|
+
- Reconnects show a system message; event gaps are surfaced in the log.
|
|
208
|
+
|
|
209
|
+
## Options
|
|
210
|
+
|
|
211
|
+
- `--local`: Run against the local embedded agent runtime
|
|
212
|
+
- `--url <url>`: Gateway WebSocket URL (defaults to config or `ws://127.0.0.1:<port>`)
|
|
213
|
+
- `--token <token>`: Gateway token (if required)
|
|
214
|
+
- `--password <password>`: Gateway password (if required)
|
|
215
|
+
- `--session <key>`: Session key (default: `main`, or `global` when scope is global)
|
|
216
|
+
- `--deliver`: Deliver assistant replies to the provider (default off)
|
|
217
|
+
- `--thinking <level>`: Override thinking level for sends
|
|
218
|
+
- `--message <text>`: Send an initial message after connecting
|
|
219
|
+
- `--timeout-ms <ms>`: Agent timeout in ms (defaults to `agents.defaults.timeoutSeconds`)
|
|
220
|
+
- `--history-limit <n>`: History entries to load (default `200`)
|
|
221
|
+
|
|
222
|
+
<Warning>
|
|
223
|
+
When you set `--url`, the TUI does not fall back to config or environment credentials. Pass `--token` or `--password` explicitly. Missing explicit credentials is an error. In local mode, do not pass `--url`, `--token`, or `--password`.
|
|
224
|
+
</Warning>
|
|
225
|
+
|
|
226
|
+
## Troubleshooting
|
|
227
|
+
|
|
228
|
+
No output after sending a message:
|
|
229
|
+
|
|
230
|
+
- Run `/status` in the TUI to confirm the Gateway is connected and idle/busy.
|
|
231
|
+
- Check the Gateway logs: `nodmix logs --follow`.
|
|
232
|
+
- Confirm the agent can run: `nodmix status` and `nodmix models status`.
|
|
233
|
+
- If you expect messages in a chat channel, enable delivery (`/deliver on` or `--deliver`).
|
|
234
|
+
|
|
235
|
+
## Connection troubleshooting
|
|
236
|
+
|
|
237
|
+
- `disconnected`: ensure the Gateway is running and your `--url/--token/--password` are correct.
|
|
238
|
+
- No agents in picker: check `nodmix agents list` and your routing config.
|
|
239
|
+
- Empty session picker: you might be in global scope or have no sessions yet.
|
|
240
|
+
|
|
241
|
+
## Related
|
|
242
|
+
|
|
243
|
+
- [Control UI](/web/control-ui) — web-based control interface
|
|
244
|
+
- [Config](/cli/config) — inspect, validate, and edit `nodmix.json`
|
|
245
|
+
- [Doctor](/cli/doctor) — guided repair and migration checks
|
|
246
|
+
- [CLI Reference](/cli) — full CLI command reference
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Loopback WebChat static host and Gateway WS usage for chat UI"
|
|
3
|
+
read_when:
|
|
4
|
+
- Debugging or configuring WebChat access
|
|
5
|
+
title: "WebChat"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
Status: the macOS/iOS SwiftUI chat UI talks directly to the Gateway WebSocket.
|
|
9
|
+
|
|
10
|
+
## What it is
|
|
11
|
+
|
|
12
|
+
- A native chat UI for the gateway (no embedded browser and no local static server).
|
|
13
|
+
- Uses the same sessions and routing rules as other channels.
|
|
14
|
+
- Deterministic routing: replies always go back to WebChat.
|
|
15
|
+
|
|
16
|
+
## Quick start
|
|
17
|
+
|
|
18
|
+
1. Start the gateway.
|
|
19
|
+
2. Open the WebChat UI (macOS/iOS app) or the Control UI chat tab.
|
|
20
|
+
3. Ensure a valid gateway auth path is configured (shared-secret by default,
|
|
21
|
+
even on loopback).
|
|
22
|
+
|
|
23
|
+
## How it works (behavior)
|
|
24
|
+
|
|
25
|
+
- The UI connects to the Gateway WebSocket and uses `chat.history`, `chat.send`, and `chat.inject`.
|
|
26
|
+
- `chat.history` is bounded for stability: Gateway may truncate long text fields, omit heavy metadata, and replace oversized entries with `[chat.history omitted: message too large]`.
|
|
27
|
+
- `chat.history` follows the active transcript branch for modern append-only session files, so abandoned rewrite branches and superseded prompt copies are not rendered in WebChat.
|
|
28
|
+
- Compaction entries render as an explicit compacted-history divider. The divider explains that earlier turns are preserved in a checkpoint and links to the Sessions checkpoint controls, where operators can branch or restore the pre-compaction view when their permissions allow it.
|
|
29
|
+
- Control UI remembers the backing Gateway `sessionId` returned by `chat.history` and includes it on follow-up `chat.send` calls, so reconnects and page refreshes continue the same stored conversation unless the user starts or resets a session.
|
|
30
|
+
- Control UI coalesces duplicate in-flight submits for the same session, message, and attachments before generating a new `chat.send` run id; the Gateway still dedupes repeated requests that reuse the same idempotency key.
|
|
31
|
+
- Workspace startup files and pending `BOOTSTRAP.md` instructions are supplied through the agent system prompt's Project Context, not copied into the WebChat user message. Bootstrap truncation only adds a concise system-prompt recovery notice; detailed counts and config knobs stay on diagnostic surfaces.
|
|
32
|
+
- `chat.history` is also display-normalized: runtime-only Nodmix context,
|
|
33
|
+
inbound envelope wrappers, inline delivery directive tags
|
|
34
|
+
such as `[[reply_to_*]]` and `[[audio_as_voice]]`, plain-text tool-call XML
|
|
35
|
+
payloads (including `<tool_call>...</tool_call>`,
|
|
36
|
+
`<function_call>...</function_call>`, `<tool_calls>...</tool_calls>`,
|
|
37
|
+
`<function_calls>...</function_calls>`, and truncated tool-call blocks), and
|
|
38
|
+
leaked ASCII/full-width model control tokens are stripped from visible text,
|
|
39
|
+
and assistant entries whose whole visible text is only the exact silent
|
|
40
|
+
token `NO_REPLY` / `no_reply` are omitted.
|
|
41
|
+
- Reasoning-flagged reply payloads (`isReasoning: true`) are excluded from WebChat assistant content, transcript replay text, and audio content blocks, so thinking-only payloads do not surface as visible assistant messages or playable audio.
|
|
42
|
+
- `chat.inject` appends an assistant note directly to the transcript and broadcasts it to the UI (no agent run).
|
|
43
|
+
- Aborted runs can keep partial assistant output visible in the UI.
|
|
44
|
+
- Gateway persists aborted partial assistant text into transcript history when buffered output exists, and marks those entries with abort metadata.
|
|
45
|
+
- History is always fetched from the gateway (no local file watching).
|
|
46
|
+
- If the gateway is unreachable, WebChat is read-only.
|
|
47
|
+
|
|
48
|
+
### Transcript and delivery model
|
|
49
|
+
|
|
50
|
+
WebChat has two separate data paths:
|
|
51
|
+
|
|
52
|
+
- The session JSONL file is the durable model/runtime transcript. For normal agent runs, Pi persists model-visible `user`, `assistant`, and `toolResult` messages through its session manager. WebChat does not write arbitrary delivery, status, or helper text into that transcript.
|
|
53
|
+
- Gateway `ReplyPayload` events are the live delivery projection. They can be normalized for WebChat/channel display, block streaming, directive tags, media embedding, TTS/audio flags, and UI fallback behavior. They are not themselves the canonical session log.
|
|
54
|
+
- Harnesses that require visible replies through `tools.message` still use WebChat as a current-run internal source reply sink. A targetless `message.send` from that active WebChat run is projected into the same chat and mirrored to the session transcript; WebChat does not become a reusable outbound channel and never inherits `lastChannel`.
|
|
55
|
+
- WebChat injects assistant transcript entries only when the Gateway owns a displayed message outside a normal Pi assistant turn: `chat.inject`, non-agent command replies, aborted partial output, and WebChat-managed media transcript supplements.
|
|
56
|
+
- `chat.history` reads the stored session transcript and applies WebChat display projection. If live assistant text appears during a run but disappears after history reload, first check whether the raw JSONL contains the assistant text, then whether `chat.history` projection stripped it, then whether the Control UI optimistic-tail merge replaced local delivery state with the persisted snapshot.
|
|
57
|
+
|
|
58
|
+
Normal agent-run final answers should be durable because Pi writes the assistant `message_end`. Any fallback that mirrors a delivered final payload into the transcript must first avoid duplicating an assistant turn that Pi already wrote.
|
|
59
|
+
|
|
60
|
+
## Control UI agents tools panel
|
|
61
|
+
|
|
62
|
+
- The Control UI `/agents` Tools panel has two separate views:
|
|
63
|
+
- **Available Right Now** uses `tools.effective(sessionKey=...)` and shows what the current
|
|
64
|
+
session can actually use at runtime, including core, plugin, and channel-owned tools.
|
|
65
|
+
- **Tool Configuration** uses `tools.catalog` and stays focused on profiles, overrides, and
|
|
66
|
+
catalog semantics.
|
|
67
|
+
- Runtime availability is session-scoped. Switching sessions on the same agent can change the
|
|
68
|
+
**Available Right Now** list.
|
|
69
|
+
- The config editor does not imply runtime availability; effective access still follows policy
|
|
70
|
+
precedence (`allow`/`deny`, per-agent and provider/channel overrides).
|
|
71
|
+
|
|
72
|
+
## Remote use
|
|
73
|
+
|
|
74
|
+
- Remote mode tunnels the gateway WebSocket over SSH/Tailscale.
|
|
75
|
+
- You do not need to run a separate WebChat server.
|
|
76
|
+
|
|
77
|
+
## Configuration reference (WebChat)
|
|
78
|
+
|
|
79
|
+
Full configuration: [Configuration](/gateway/configuration)
|
|
80
|
+
|
|
81
|
+
WebChat options:
|
|
82
|
+
|
|
83
|
+
- `gateway.webchat.chatHistoryMaxChars`: maximum character count for text fields in `chat.history` responses. When a transcript entry exceeds this limit, Gateway truncates long text fields and may replace oversized messages with a placeholder. Per-request `maxChars` can also be sent by the client to override this default for a single `chat.history` call.
|
|
84
|
+
|
|
85
|
+
Related global options:
|
|
86
|
+
|
|
87
|
+
- `gateway.port`, `gateway.bind`: WebSocket host/port.
|
|
88
|
+
- `gateway.auth.mode`, `gateway.auth.token`, `gateway.auth.password`:
|
|
89
|
+
shared-secret WebSocket auth.
|
|
90
|
+
- `gateway.auth.allowTailscale`: browser Control UI chat tab can use Tailscale
|
|
91
|
+
Serve identity headers when enabled.
|
|
92
|
+
- `gateway.auth.mode: "trusted-proxy"`: reverse-proxy auth for browser clients behind an identity-aware **non-loopback** proxy source (see [Trusted Proxy Auth](/gateway/trusted-proxy-auth)).
|
|
93
|
+
- `gateway.remote.url`, `gateway.remote.token`, `gateway.remote.password`: remote gateway target.
|
|
94
|
+
- `session.*`: session storage and main key defaults.
|
|
95
|
+
|
|
96
|
+
## Related
|
|
97
|
+
|
|
98
|
+
- [Control UI](/web/control-ui)
|
|
99
|
+
- [Dashboard](/web/dashboard)
|
|
Binary file
|
|
Binary file
|