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,136 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Agent runtime, workspace contract, and session bootstrap"
|
|
3
|
+
read_when:
|
|
4
|
+
- Changing agent runtime, workspace bootstrap, or session behavior
|
|
5
|
+
title: "Agent runtime"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
Nodmix runs a **single embedded agent runtime** - one agent process per
|
|
9
|
+
Gateway, with its own workspace, bootstrap files, and session store. This page
|
|
10
|
+
covers that runtime contract: what the workspace must contain, which files get
|
|
11
|
+
injected, and how sessions bootstrap against it.
|
|
12
|
+
|
|
13
|
+
## Workspace (required)
|
|
14
|
+
|
|
15
|
+
Nodmix uses a single agent workspace directory (`agents.defaults.workspace`) as the agent's **only** working directory (`cwd`) for tools and context.
|
|
16
|
+
|
|
17
|
+
Recommended: use `nodmix setup` to create `~/.nodmix/nodmix.json` if missing and initialize the workspace files.
|
|
18
|
+
|
|
19
|
+
Full workspace layout + backup guide: [Agent workspace](/concepts/agent-workspace)
|
|
20
|
+
|
|
21
|
+
If `agents.defaults.sandbox` is enabled, non-main sessions can override this with
|
|
22
|
+
per-session workspaces under `agents.defaults.sandbox.workspaceRoot` (see
|
|
23
|
+
[Gateway configuration](/gateway/configuration)).
|
|
24
|
+
|
|
25
|
+
## Bootstrap files (injected)
|
|
26
|
+
|
|
27
|
+
Inside `agents.defaults.workspace`, Nodmix expects these user-editable files:
|
|
28
|
+
|
|
29
|
+
- `AGENTS.md` - operating instructions + "memory"
|
|
30
|
+
- `SOUL.md` - persona, boundaries, tone
|
|
31
|
+
- `TOOLS.md` - user-maintained tool notes (e.g. `imsg`, `sag`, conventions)
|
|
32
|
+
- `BOOTSTRAP.md` - one-time first-run ritual (deleted after completion)
|
|
33
|
+
- `IDENTITY.md` - agent name/vibe/emoji
|
|
34
|
+
- `USER.md` - user profile + preferred address
|
|
35
|
+
|
|
36
|
+
On the first turn of a new session, Nodmix injects the contents of these files into the system prompt's Project Context.
|
|
37
|
+
|
|
38
|
+
Blank files are skipped. Large files are trimmed and truncated with a marker so prompts stay lean (read the file for full content).
|
|
39
|
+
|
|
40
|
+
If a file is missing, Nodmix injects a single "missing file" marker line (and `nodmix setup` will create a safe default template).
|
|
41
|
+
|
|
42
|
+
`BOOTSTRAP.md` is only created for a **brand new workspace** (no other bootstrap files present). While it is pending, Nodmix keeps it in Project Context and adds system-prompt bootstrap guidance for the initial ritual instead of copying it into the user message. If you delete it after completing the ritual, it should not be recreated on later restarts.
|
|
43
|
+
|
|
44
|
+
To disable bootstrap file creation entirely (for pre-seeded workspaces), set:
|
|
45
|
+
|
|
46
|
+
```json5
|
|
47
|
+
{ agents: { defaults: { skipBootstrap: true } } }
|
|
48
|
+
```
|
|
49
|
+
|
|
50
|
+
## Built-in tools
|
|
51
|
+
|
|
52
|
+
Core tools (read/exec/edit/write and related system tools) are always available,
|
|
53
|
+
subject to tool policy. `apply_patch` is optional and gated by
|
|
54
|
+
`tools.exec.applyPatch`. `TOOLS.md` does **not** control which tools exist; it's
|
|
55
|
+
guidance for how _you_ want them used.
|
|
56
|
+
|
|
57
|
+
## Skills
|
|
58
|
+
|
|
59
|
+
Nodmix loads skills from these locations (highest precedence first):
|
|
60
|
+
|
|
61
|
+
- Workspace: `<workspace>/skills`
|
|
62
|
+
- Project agent skills: `<workspace>/.agents/skills`
|
|
63
|
+
- Personal agent skills: `~/.agents/skills`
|
|
64
|
+
- Managed/local: `~/.nodmix/skills`
|
|
65
|
+
- Bundled (shipped with the install)
|
|
66
|
+
- Extra skill folders: `skills.load.extraDirs`
|
|
67
|
+
|
|
68
|
+
Skills can be gated by config/env (see `skills` in [Gateway configuration](/gateway/configuration)).
|
|
69
|
+
|
|
70
|
+
## Runtime boundaries
|
|
71
|
+
|
|
72
|
+
The embedded agent runtime is built on the Pi agent core (models, tools, and
|
|
73
|
+
prompt pipeline). Session management, discovery, tool wiring, and channel
|
|
74
|
+
delivery are Nodmix-owned layers on top of that core.
|
|
75
|
+
|
|
76
|
+
## Sessions
|
|
77
|
+
|
|
78
|
+
Session transcripts are stored as JSONL at:
|
|
79
|
+
|
|
80
|
+
- `~/.nodmix/agents/<agentId>/sessions/<SessionId>.jsonl`
|
|
81
|
+
|
|
82
|
+
The session ID is stable and chosen by Nodmix.
|
|
83
|
+
Legacy session folders from other tools are not read.
|
|
84
|
+
|
|
85
|
+
## Steering while streaming
|
|
86
|
+
|
|
87
|
+
Inbound prompts that arrive mid-run are steered into the current run by default.
|
|
88
|
+
Steering is delivered **after the current assistant turn finishes executing its
|
|
89
|
+
tool calls**, before the next LLM call, and no longer skips remaining tool calls
|
|
90
|
+
from the current assistant message.
|
|
91
|
+
|
|
92
|
+
`/queue steer` is the default active-run behavior. `/queue followup` and
|
|
93
|
+
`/queue collect` make messages wait for a later turn instead of steering.
|
|
94
|
+
`/queue interrupt` aborts the active run instead. See [Queue](/concepts/queue)
|
|
95
|
+
and [Steering queue](/concepts/queue-steering) for queue and boundary behavior.
|
|
96
|
+
|
|
97
|
+
Block streaming sends completed assistant blocks as soon as they finish; it is
|
|
98
|
+
**off by default** (`agents.defaults.blockStreamingDefault: "off"`).
|
|
99
|
+
Tune the boundary via `agents.defaults.blockStreamingBreak` (`text_end` vs `message_end`; defaults to text_end).
|
|
100
|
+
Control soft block chunking with `agents.defaults.blockStreamingChunk` (defaults to
|
|
101
|
+
800-1200 chars; prefers paragraph breaks, then newlines; sentences last).
|
|
102
|
+
Coalesce streamed chunks with `agents.defaults.blockStreamingCoalesce` to reduce
|
|
103
|
+
single-line spam (idle-based merging before send). Non-Telegram channels require
|
|
104
|
+
explicit `*.blockStreaming: true` to enable block replies.
|
|
105
|
+
Verbose tool summaries are emitted at tool start (no debounce); Control UI
|
|
106
|
+
streams tool output via agent events when available.
|
|
107
|
+
More details: [Streaming + chunking](/concepts/streaming).
|
|
108
|
+
|
|
109
|
+
## Model refs
|
|
110
|
+
|
|
111
|
+
Model refs in config (for example `agents.defaults.model` and `agents.defaults.models`) are parsed by splitting on the **first** `/`.
|
|
112
|
+
|
|
113
|
+
- Use `provider/model` when configuring models.
|
|
114
|
+
- If the model ID itself contains `/` (OpenRouter-style), include the provider prefix (example: `openrouter/moonshotai/kimi-k2`).
|
|
115
|
+
- If you omit the provider, Nodmix tries an alias first, then a unique
|
|
116
|
+
configured-provider match for that exact model id, and only then falls back
|
|
117
|
+
to the configured default provider. If that provider no longer exposes the
|
|
118
|
+
configured default model, Nodmix falls back to the first configured
|
|
119
|
+
provider/model instead of surfacing a stale removed-provider default.
|
|
120
|
+
|
|
121
|
+
## Configuration (minimal)
|
|
122
|
+
|
|
123
|
+
At minimum, set:
|
|
124
|
+
|
|
125
|
+
- `agents.defaults.workspace`
|
|
126
|
+
- `channels.whatsapp.allowFrom` (strongly recommended)
|
|
127
|
+
|
|
128
|
+
---
|
|
129
|
+
|
|
130
|
+
_Next: [Group Chats](/channels/group-messages)_ 🦞
|
|
131
|
+
|
|
132
|
+
## Related
|
|
133
|
+
|
|
134
|
+
- [Agent workspace](/concepts/agent-workspace)
|
|
135
|
+
- [Multi-agent routing](/concepts/multi-agent)
|
|
136
|
+
- [Session management](/concepts/session)
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "WebSocket gateway architecture, components, and client flows"
|
|
3
|
+
read_when:
|
|
4
|
+
- Working on gateway protocol, clients, or transports
|
|
5
|
+
title: "Gateway architecture"
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
## Overview
|
|
9
|
+
|
|
10
|
+
- A single long-lived **Gateway** owns all messaging surfaces (WhatsApp via
|
|
11
|
+
Baileys, Telegram via grammY, Slack, Discord, Signal, iMessage, WebChat).
|
|
12
|
+
- Control-plane clients (macOS app, CLI, web UI, automations) connect to the
|
|
13
|
+
Gateway over **WebSocket** on the configured bind host (default
|
|
14
|
+
`127.0.0.1:18789`).
|
|
15
|
+
- **Nodes** (macOS/iOS/Android/headless) also connect over **WebSocket**, but
|
|
16
|
+
declare `role: node` with explicit caps/commands.
|
|
17
|
+
- One Gateway per host; it is the only place that opens a WhatsApp session.
|
|
18
|
+
- The **canvas host** is served by the Gateway HTTP server under:
|
|
19
|
+
- `/__nodmix__/canvas/` (agent-editable HTML/CSS/JS)
|
|
20
|
+
- `/__nodmix__/a2ui/` (A2UI host)
|
|
21
|
+
It uses the same port as the Gateway (default `18789`).
|
|
22
|
+
|
|
23
|
+
## Components and flows
|
|
24
|
+
|
|
25
|
+
### Gateway (daemon)
|
|
26
|
+
|
|
27
|
+
- Maintains provider connections.
|
|
28
|
+
- Exposes a typed WS API (requests, responses, server-push events).
|
|
29
|
+
- Validates inbound frames against JSON Schema.
|
|
30
|
+
- Emits events like `agent`, `chat`, `presence`, `health`, `heartbeat`, `cron`.
|
|
31
|
+
|
|
32
|
+
### Clients (mac app / CLI / web admin)
|
|
33
|
+
|
|
34
|
+
- One WS connection per client.
|
|
35
|
+
- Send requests (`health`, `status`, `send`, `agent`, `system-presence`).
|
|
36
|
+
- Subscribe to events (`tick`, `agent`, `presence`, `shutdown`).
|
|
37
|
+
|
|
38
|
+
### Nodes (macOS / iOS / Android / headless)
|
|
39
|
+
|
|
40
|
+
- Connect to the **same WS server** with `role: node`.
|
|
41
|
+
- Provide a device identity in `connect`; pairing is **device-based** (role `node`) and
|
|
42
|
+
approval lives in the device pairing store.
|
|
43
|
+
- Expose commands like `canvas.*`, `camera.*`, `screen.record`, `location.get`.
|
|
44
|
+
|
|
45
|
+
Protocol details:
|
|
46
|
+
|
|
47
|
+
- [Gateway protocol](/gateway/protocol)
|
|
48
|
+
|
|
49
|
+
### WebChat
|
|
50
|
+
|
|
51
|
+
- Static UI that uses the Gateway WS API for chat history and sends.
|
|
52
|
+
- In remote setups, connects through the same SSH/Tailscale tunnel as other
|
|
53
|
+
clients.
|
|
54
|
+
|
|
55
|
+
## Connection lifecycle (single client)
|
|
56
|
+
|
|
57
|
+
```mermaid
|
|
58
|
+
sequenceDiagram
|
|
59
|
+
participant Client
|
|
60
|
+
participant Gateway
|
|
61
|
+
|
|
62
|
+
Client->>Gateway: req:connect
|
|
63
|
+
Gateway-->>Client: res (ok)
|
|
64
|
+
Note right of Gateway: or res error + close
|
|
65
|
+
Note left of Client: payload=hello-ok<br>snapshot: presence + health
|
|
66
|
+
|
|
67
|
+
Gateway-->>Client: event:presence
|
|
68
|
+
Gateway-->>Client: event:tick
|
|
69
|
+
|
|
70
|
+
Client->>Gateway: req:agent
|
|
71
|
+
Gateway-->>Client: res:agent<br>ack {runId, status:"accepted"}
|
|
72
|
+
Gateway-->>Client: event:agent<br>(streaming)
|
|
73
|
+
Gateway-->>Client: res:agent<br>final {runId, status, summary}
|
|
74
|
+
```
|
|
75
|
+
|
|
76
|
+
## Wire protocol (summary)
|
|
77
|
+
|
|
78
|
+
- Transport: WebSocket, text frames with JSON payloads.
|
|
79
|
+
- First frame **must** be `connect`.
|
|
80
|
+
- After handshake:
|
|
81
|
+
- Requests: `{type:"req", id, method, params}` → `{type:"res", id, ok, payload|error}`
|
|
82
|
+
- Events: `{type:"event", event, payload, seq?, stateVersion?}`
|
|
83
|
+
- `hello-ok.features.methods` / `events` are discovery metadata, not a
|
|
84
|
+
generated dump of every callable helper route.
|
|
85
|
+
- Shared-secret auth uses `connect.params.auth.token` or
|
|
86
|
+
`connect.params.auth.password`, depending on the configured gateway auth mode.
|
|
87
|
+
- Identity-bearing modes such as Tailscale Serve
|
|
88
|
+
(`gateway.auth.allowTailscale: true`) or non-loopback
|
|
89
|
+
`gateway.auth.mode: "trusted-proxy"` satisfy auth from request headers
|
|
90
|
+
instead of `connect.params.auth.*`.
|
|
91
|
+
- Private-ingress `gateway.auth.mode: "none"` disables shared-secret auth
|
|
92
|
+
entirely; keep that mode off public/untrusted ingress.
|
|
93
|
+
- Idempotency keys are required for side-effecting methods (`send`, `agent`) to
|
|
94
|
+
safely retry; the server keeps a short-lived dedupe cache.
|
|
95
|
+
- Nodes must include `role: "node"` plus caps/commands/permissions in `connect`.
|
|
96
|
+
|
|
97
|
+
## Pairing + local trust
|
|
98
|
+
|
|
99
|
+
- All WS clients (operators + nodes) include a **device identity** on `connect`.
|
|
100
|
+
- New device IDs require pairing approval; the Gateway issues a **device token**
|
|
101
|
+
for subsequent connects.
|
|
102
|
+
- Direct local loopback connects can be auto-approved to keep same-host UX
|
|
103
|
+
smooth.
|
|
104
|
+
- Nodmix also has a narrow backend/container-local self-connect path for
|
|
105
|
+
trusted shared-secret helper flows.
|
|
106
|
+
- Tailnet and LAN connects, including same-host tailnet binds, still require
|
|
107
|
+
explicit pairing approval.
|
|
108
|
+
- All connects must sign the `connect.challenge` nonce.
|
|
109
|
+
- Signature payload `v3` also binds `platform` + `deviceFamily`; the gateway
|
|
110
|
+
pins paired metadata on reconnect and requires repair pairing for metadata
|
|
111
|
+
changes.
|
|
112
|
+
- **Non-local** connects still require explicit approval.
|
|
113
|
+
- Gateway auth (`gateway.auth.*`) still applies to **all** connections, local or
|
|
114
|
+
remote.
|
|
115
|
+
|
|
116
|
+
Details: [Gateway protocol](/gateway/protocol), [Pairing](/channels/pairing),
|
|
117
|
+
[Security](/gateway/security).
|
|
118
|
+
|
|
119
|
+
## Protocol typing and codegen
|
|
120
|
+
|
|
121
|
+
- TypeBox schemas define the protocol.
|
|
122
|
+
- JSON Schema is generated from those schemas.
|
|
123
|
+
- Swift models are generated from the JSON Schema.
|
|
124
|
+
|
|
125
|
+
## Remote access
|
|
126
|
+
|
|
127
|
+
- Preferred: Tailscale or VPN.
|
|
128
|
+
- Alternative: SSH tunnel
|
|
129
|
+
|
|
130
|
+
```bash
|
|
131
|
+
ssh -N -L 18789:127.0.0.1:18789 user@host
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
- The same handshake + auth token apply over the tunnel.
|
|
135
|
+
- TLS + optional pinning can be enabled for WS in remote setups.
|
|
136
|
+
|
|
137
|
+
## Operations snapshot
|
|
138
|
+
|
|
139
|
+
- Start: `nodmix gateway` (foreground, logs to stdout).
|
|
140
|
+
- Health: `health` over WS (also included in `hello-ok`).
|
|
141
|
+
- Supervision: launchd/systemd for auto-restart.
|
|
142
|
+
|
|
143
|
+
## Invariants
|
|
144
|
+
|
|
145
|
+
- Exactly one Gateway controls a single Baileys session per host.
|
|
146
|
+
- Handshake is mandatory; any non-JSON or non-connect first frame is a hard close.
|
|
147
|
+
- Events are not replayed; clients must refresh on gaps.
|
|
148
|
+
|
|
149
|
+
## Related
|
|
150
|
+
|
|
151
|
+
- [Agent Loop](/concepts/agent-loop) — detailed agent execution cycle
|
|
152
|
+
- [Gateway Protocol](/gateway/protocol) — WebSocket protocol contract
|
|
153
|
+
- [Queue](/concepts/queue) — command queue and concurrency
|
|
154
|
+
- [Security](/gateway/security) — trust model and hardening
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Move one Nodmix session's reply route between linked chat channels"
|
|
3
|
+
title: "Channel docking"
|
|
4
|
+
read_when:
|
|
5
|
+
- You want replies for one active session to move from Telegram to Discord, Slack, Mattermost, or another linked channel
|
|
6
|
+
- You are configuring session.identityLinks for cross-channel direct messages
|
|
7
|
+
- A /dock command says the sender is not linked or no active session exists
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
Channel docking is call forwarding for one Nodmix session.
|
|
11
|
+
|
|
12
|
+
It keeps the same conversation context, but changes where future replies for
|
|
13
|
+
that session are delivered.
|
|
14
|
+
|
|
15
|
+
## Example
|
|
16
|
+
|
|
17
|
+
Alice can message Nodmix on Telegram and Discord:
|
|
18
|
+
|
|
19
|
+
```json5
|
|
20
|
+
{
|
|
21
|
+
session: {
|
|
22
|
+
identityLinks: {
|
|
23
|
+
alice: ["telegram:123", "discord:456"],
|
|
24
|
+
},
|
|
25
|
+
},
|
|
26
|
+
}
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
If Alice sends this from Telegram:
|
|
30
|
+
|
|
31
|
+
```text
|
|
32
|
+
/dock_discord
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
Nodmix keeps the current session context and changes the reply route:
|
|
36
|
+
|
|
37
|
+
| Before docking | After `/dock_discord` |
|
|
38
|
+
| ---------------------------- | --------------------------- |
|
|
39
|
+
| Replies go to Telegram `123` | Replies go to Discord `456` |
|
|
40
|
+
|
|
41
|
+
The session is not recreated. The transcript history stays attached to the
|
|
42
|
+
same session.
|
|
43
|
+
|
|
44
|
+
## Why use it
|
|
45
|
+
|
|
46
|
+
Use docking when a task starts in one chat app but the next replies should land
|
|
47
|
+
somewhere else.
|
|
48
|
+
|
|
49
|
+
Common flow:
|
|
50
|
+
|
|
51
|
+
1. Start an agent task from Telegram.
|
|
52
|
+
2. Move to Discord where you are coordinating work.
|
|
53
|
+
3. Send `/dock_discord` from the Telegram session.
|
|
54
|
+
4. Keep the same Nodmix session, but receive future replies in Discord.
|
|
55
|
+
|
|
56
|
+
## Required config
|
|
57
|
+
|
|
58
|
+
Docking requires `session.identityLinks`. The source sender and target peer
|
|
59
|
+
must be in the same identity group:
|
|
60
|
+
|
|
61
|
+
```json5
|
|
62
|
+
{
|
|
63
|
+
session: {
|
|
64
|
+
identityLinks: {
|
|
65
|
+
alice: ["telegram:123", "discord:456", "slack:U123"],
|
|
66
|
+
},
|
|
67
|
+
},
|
|
68
|
+
}
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
The values are channel-prefixed peer ids:
|
|
72
|
+
|
|
73
|
+
| Value | Meaning |
|
|
74
|
+
| -------------- | ---------------------------- |
|
|
75
|
+
| `telegram:123` | Telegram sender id `123` |
|
|
76
|
+
| `discord:456` | Discord direct peer id `456` |
|
|
77
|
+
| `slack:U123` | Slack user id `U123` |
|
|
78
|
+
|
|
79
|
+
The canonical key (`alice` above) is only the shared identity group name. Dock
|
|
80
|
+
commands use the channel-prefixed values to prove that the source sender and
|
|
81
|
+
target peer are the same person.
|
|
82
|
+
|
|
83
|
+
## Commands
|
|
84
|
+
|
|
85
|
+
Dock commands are generated from loaded channel plugins that support native
|
|
86
|
+
commands. Current bundled commands:
|
|
87
|
+
|
|
88
|
+
| Target channel | Command | Alias |
|
|
89
|
+
| -------------- | ------------------ | ------------------ |
|
|
90
|
+
| Discord | `/dock-discord` | `/dock_discord` |
|
|
91
|
+
| Mattermost | `/dock-mattermost` | `/dock_mattermost` |
|
|
92
|
+
| Slack | `/dock-slack` | `/dock_slack` |
|
|
93
|
+
| Telegram | `/dock-telegram` | `/dock_telegram` |
|
|
94
|
+
|
|
95
|
+
The underscore aliases are useful on native command surfaces such as Telegram.
|
|
96
|
+
|
|
97
|
+
## What changes
|
|
98
|
+
|
|
99
|
+
Docking updates the active session delivery fields:
|
|
100
|
+
|
|
101
|
+
| Session field | Example after `/dock_discord` |
|
|
102
|
+
| --------------- | ---------------------------------------- |
|
|
103
|
+
| `lastChannel` | `discord` |
|
|
104
|
+
| `lastTo` | `456` |
|
|
105
|
+
| `lastAccountId` | the target channel account, or `default` |
|
|
106
|
+
|
|
107
|
+
Those fields are persisted in the session store and used by later reply
|
|
108
|
+
delivery for that session.
|
|
109
|
+
|
|
110
|
+
## What does not change
|
|
111
|
+
|
|
112
|
+
Docking does not:
|
|
113
|
+
|
|
114
|
+
- create channel accounts
|
|
115
|
+
- connect a new Discord, Telegram, Slack, or Mattermost bot
|
|
116
|
+
- grant access to a user
|
|
117
|
+
- bypass channel allowlists or DM policies
|
|
118
|
+
- move transcript history to another session
|
|
119
|
+
- make unrelated users share a session
|
|
120
|
+
|
|
121
|
+
It only changes the delivery route for the current session.
|
|
122
|
+
|
|
123
|
+
## Troubleshooting
|
|
124
|
+
|
|
125
|
+
**The command says the sender is not linked.**
|
|
126
|
+
|
|
127
|
+
Add both the current sender and the target peer to the same
|
|
128
|
+
`session.identityLinks` group. For example, if Telegram sender `123` should dock
|
|
129
|
+
to Discord peer `456`, include both `telegram:123` and `discord:456`.
|
|
130
|
+
|
|
131
|
+
**The command says no active session exists.**
|
|
132
|
+
|
|
133
|
+
Dock from an existing direct-chat session. The command needs an active session
|
|
134
|
+
entry so it can persist the new route.
|
|
135
|
+
|
|
136
|
+
**Replies still go to the old channel.**
|
|
137
|
+
|
|
138
|
+
Check that the command replied with a success message, and confirm the target
|
|
139
|
+
peer id matches the id used by that channel. Docking only changes the active
|
|
140
|
+
session route; another session may still route elsewhere.
|
|
141
|
+
|
|
142
|
+
**I need to switch back.**
|
|
143
|
+
|
|
144
|
+
Send the matching command for the original channel, such as `/dock_telegram` or
|
|
145
|
+
`/dock-telegram`, from a linked sender.
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Inferred follow-up memory for check-ins that are not exact reminders"
|
|
3
|
+
title: "Inferred commitments"
|
|
4
|
+
sidebarTitle: "Commitments"
|
|
5
|
+
read_when:
|
|
6
|
+
- You want Nodmix to remember natural follow-ups
|
|
7
|
+
- You want to understand how inferred check-ins differ from reminders
|
|
8
|
+
- You want to review or dismiss follow-up commitments
|
|
9
|
+
---
|
|
10
|
+
|
|
11
|
+
Commitments are short-lived follow-up memories. When enabled, Nodmix can
|
|
12
|
+
notice that a conversation created a future check-in opportunity and remember
|
|
13
|
+
to bring it back later.
|
|
14
|
+
|
|
15
|
+
Examples:
|
|
16
|
+
|
|
17
|
+
- You mention an interview tomorrow. Nodmix may check in afterward.
|
|
18
|
+
- You say you are exhausted. Nodmix may ask later whether you slept.
|
|
19
|
+
- The agent says it will follow up after something changes. Nodmix may track
|
|
20
|
+
that open loop.
|
|
21
|
+
|
|
22
|
+
Commitments are not durable facts like `MEMORY.md`, and they are not exact
|
|
23
|
+
reminders. They sit between memory and automation: Nodmix remembers a
|
|
24
|
+
conversation-bound obligation, then heartbeat delivers it when it is due.
|
|
25
|
+
|
|
26
|
+
## Enable commitments
|
|
27
|
+
|
|
28
|
+
Commitments are off by default. Enable them in config:
|
|
29
|
+
|
|
30
|
+
```bash
|
|
31
|
+
nodmix config set commitments.enabled true
|
|
32
|
+
nodmix config set commitments.maxPerDay 3
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
Equivalent `nodmix.json`:
|
|
36
|
+
|
|
37
|
+
```json
|
|
38
|
+
{
|
|
39
|
+
"commitments": {
|
|
40
|
+
"enabled": true,
|
|
41
|
+
"maxPerDay": 3
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
`commitments.maxPerDay` limits how many inferred follow-ups can be delivered
|
|
47
|
+
per agent session in a rolling day. The default is `3`.
|
|
48
|
+
|
|
49
|
+
## How it works
|
|
50
|
+
|
|
51
|
+
After an agent reply, Nodmix may run a hidden background extraction pass in a
|
|
52
|
+
separate context. That pass looks only for inferred follow-up commitments. It
|
|
53
|
+
does not write into the visible conversation and it does not ask the main agent
|
|
54
|
+
to reason about the extraction.
|
|
55
|
+
|
|
56
|
+
When it finds a high-confidence candidate, Nodmix stores a commitment with:
|
|
57
|
+
|
|
58
|
+
- the agent id
|
|
59
|
+
- the session key
|
|
60
|
+
- the original channel and delivery target
|
|
61
|
+
- a due window
|
|
62
|
+
- a short suggested check-in
|
|
63
|
+
- non-instructional metadata for heartbeat to decide whether to send it
|
|
64
|
+
|
|
65
|
+
Delivery happens through heartbeat. When a commitment becomes due, heartbeat
|
|
66
|
+
adds the commitment to the heartbeat turn for the same agent and channel scope.
|
|
67
|
+
The model can send one natural check-in or reply `HEARTBEAT_OK` to dismiss it.
|
|
68
|
+
If heartbeat is configured with `target: "none"`, due commitments remain
|
|
69
|
+
internal and do not send external check-ins. Commitment delivery prompts do not
|
|
70
|
+
replay the original conversation text, and due commitment heartbeat turns run
|
|
71
|
+
without Nodmix tools.
|
|
72
|
+
|
|
73
|
+
Nodmix never delivers an inferred commitment immediately after writing it.
|
|
74
|
+
The due time is clamped to at least one heartbeat interval after the commitment
|
|
75
|
+
is created, so the follow-up cannot echo back in the same moment it was
|
|
76
|
+
inferred.
|
|
77
|
+
|
|
78
|
+
## Scope
|
|
79
|
+
|
|
80
|
+
Commitments are scoped to the exact agent and channel context where they were
|
|
81
|
+
created. A follow-up inferred while talking to one agent in Discord is not
|
|
82
|
+
delivered by another agent, another channel, or an unrelated session.
|
|
83
|
+
|
|
84
|
+
This scope is part of the feature. Natural check-ins should feel like the same
|
|
85
|
+
conversation continuing, not like a global reminder system.
|
|
86
|
+
|
|
87
|
+
## Commitments vs reminders
|
|
88
|
+
|
|
89
|
+
| Need | Use |
|
|
90
|
+
| ----------------------------------------------- | ---------------------------------------- |
|
|
91
|
+
| "Remind me at 3 PM" | [Scheduled tasks](/automation/cron-jobs) |
|
|
92
|
+
| "Ping me in 20 minutes" | [Scheduled tasks](/automation/cron-jobs) |
|
|
93
|
+
| "Run this report every weekday" | [Scheduled tasks](/automation/cron-jobs) |
|
|
94
|
+
| "I have an interview tomorrow" | Commitments |
|
|
95
|
+
| "I was up all night" | Commitments |
|
|
96
|
+
| "Follow up if I do not answer this open thread" | Commitments |
|
|
97
|
+
|
|
98
|
+
Exact user requests already belong to the scheduler path. Commitments are only
|
|
99
|
+
for inferred follow-ups: the moments where the user did not ask for a reminder,
|
|
100
|
+
but the conversation clearly created a useful future check-in.
|
|
101
|
+
|
|
102
|
+
## Manage commitments
|
|
103
|
+
|
|
104
|
+
Use the CLI to inspect and clear stored commitments:
|
|
105
|
+
|
|
106
|
+
```bash
|
|
107
|
+
nodmix commitments
|
|
108
|
+
nodmix commitments --all
|
|
109
|
+
nodmix commitments --agent main
|
|
110
|
+
nodmix commitments --status snoozed
|
|
111
|
+
nodmix commitments dismiss cm_abc123
|
|
112
|
+
```
|
|
113
|
+
|
|
114
|
+
See [`nodmix commitments`](/cli/commitments) for the command reference.
|
|
115
|
+
|
|
116
|
+
## Privacy and cost
|
|
117
|
+
|
|
118
|
+
Commitment extraction uses an LLM pass, so enabling it adds background model
|
|
119
|
+
usage after eligible turns. The pass is hidden from the user-visible
|
|
120
|
+
conversation, but it can read the recent exchange needed to decide whether a
|
|
121
|
+
follow-up exists.
|
|
122
|
+
|
|
123
|
+
Stored commitments are local Nodmix state. They are operational memory, not
|
|
124
|
+
long-term memory. Disable the feature with:
|
|
125
|
+
|
|
126
|
+
```bash
|
|
127
|
+
nodmix config set commitments.enabled false
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
## Troubleshooting
|
|
131
|
+
|
|
132
|
+
If expected follow-ups are not appearing:
|
|
133
|
+
|
|
134
|
+
- Confirm `commitments.enabled` is `true`.
|
|
135
|
+
- Check `nodmix commitments --all` for pending, dismissed, snoozed, or expired
|
|
136
|
+
records.
|
|
137
|
+
- Make sure heartbeat is running for the agent.
|
|
138
|
+
- Check whether `commitments.maxPerDay` has already been reached for that
|
|
139
|
+
agent session.
|
|
140
|
+
- Remember that exact reminders are skipped by commitment extraction and should
|
|
141
|
+
appear under [scheduled tasks](/automation/cron-jobs) instead.
|
|
142
|
+
|
|
143
|
+
## Related
|
|
144
|
+
|
|
145
|
+
- [Memory overview](/concepts/memory)
|
|
146
|
+
- [Active memory](/concepts/active-memory)
|
|
147
|
+
- [Heartbeat](/gateway/heartbeat)
|
|
148
|
+
- [Scheduled tasks](/automation/cron-jobs)
|
|
149
|
+
- [`nodmix commitments`](/cli/commitments)
|
|
150
|
+
- [Configuration reference](/gateway/configuration-reference#commitments)
|