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,185 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Agent loop lifecycle, streams, and wait semantics"
|
|
3
|
+
read_when:
|
|
4
|
+
- You need an exact walkthrough of the agent loop or lifecycle events
|
|
5
|
+
- You are changing session queueing, transcript writes, or session write lock behavior
|
|
6
|
+
title: "Agent loop"
|
|
7
|
+
---
|
|
8
|
+
|
|
9
|
+
An agentic loop is the full "real" run of an agent: intake → context assembly → model inference →
|
|
10
|
+
tool execution → streaming replies → persistence. It's the authoritative path that turns a message
|
|
11
|
+
into actions and a final reply, while keeping session state consistent.
|
|
12
|
+
|
|
13
|
+
In Nodmix, a loop is a single, serialized run per session that emits lifecycle and stream events
|
|
14
|
+
as the model thinks, calls tools, and streams output. This doc explains how that authentic loop is
|
|
15
|
+
wired end-to-end.
|
|
16
|
+
|
|
17
|
+
## Entry points
|
|
18
|
+
|
|
19
|
+
- Gateway RPC: `agent` and `agent.wait`.
|
|
20
|
+
- CLI: `agent` command.
|
|
21
|
+
|
|
22
|
+
## How it works (high-level)
|
|
23
|
+
|
|
24
|
+
1. `agent` RPC validates params, resolves session (sessionKey/sessionId), persists session metadata, returns `{ runId, acceptedAt }` immediately.
|
|
25
|
+
2. `agentCommand` runs the agent:
|
|
26
|
+
- resolves model + thinking/verbose/trace defaults
|
|
27
|
+
- loads skills snapshot
|
|
28
|
+
- calls `runEmbeddedPiAgent` (pi-agent-core runtime)
|
|
29
|
+
- emits **lifecycle end/error** if the embedded loop does not emit one
|
|
30
|
+
3. `runEmbeddedPiAgent`:
|
|
31
|
+
- serializes runs via per-session + global queues
|
|
32
|
+
- resolves model + auth profile and builds the pi session
|
|
33
|
+
- subscribes to pi events and streams assistant/tool deltas
|
|
34
|
+
- enforces timeout -> aborts run if exceeded
|
|
35
|
+
- for Codex app-server turns, aborts an accepted turn that stops producing app-server progress before a terminal event
|
|
36
|
+
- returns payloads + usage metadata
|
|
37
|
+
4. `subscribeEmbeddedPiSession` bridges pi-agent-core events to Nodmix `agent` stream:
|
|
38
|
+
- tool events => `stream: "tool"`
|
|
39
|
+
- assistant deltas => `stream: "assistant"`
|
|
40
|
+
- lifecycle events => `stream: "lifecycle"` (`phase: "start" | "end" | "error"`)
|
|
41
|
+
5. `agent.wait` uses `waitForAgentRun`:
|
|
42
|
+
- waits for **lifecycle end/error** for `runId`
|
|
43
|
+
- returns `{ status: ok|error|timeout, startedAt, endedAt, error? }`
|
|
44
|
+
|
|
45
|
+
## Queueing + concurrency
|
|
46
|
+
|
|
47
|
+
- Runs are serialized per session key (session lane) and optionally through a global lane.
|
|
48
|
+
- This prevents tool/session races and keeps session history consistent.
|
|
49
|
+
- Messaging channels can choose queue modes (steer/followup/collect/interrupt) that feed this lane system.
|
|
50
|
+
See [Command Queue](/concepts/queue).
|
|
51
|
+
- Transcript writes are also protected by a session write lock on the session file. The lock is
|
|
52
|
+
process-aware and file-based, so it catches writers that bypass the in-process queue or come from
|
|
53
|
+
another process. Session transcript writers wait up to `session.writeLock.acquireTimeoutMs`
|
|
54
|
+
before reporting the session as busy; the default is `60000` ms.
|
|
55
|
+
- Session write locks are non-reentrant by default. If a helper intentionally nests acquisition of
|
|
56
|
+
the same lock while preserving one logical writer, it must opt in explicitly with
|
|
57
|
+
`allowReentrant: true`.
|
|
58
|
+
|
|
59
|
+
## Session + workspace preparation
|
|
60
|
+
|
|
61
|
+
- Workspace is resolved and created; sandboxed runs may redirect to a sandbox workspace root.
|
|
62
|
+
- Skills are loaded (or reused from a snapshot) and injected into env and prompt.
|
|
63
|
+
- Bootstrap/context files are resolved and injected into the system prompt report.
|
|
64
|
+
- A session write lock is acquired; `SessionManager` is opened and prepared before streaming. Any
|
|
65
|
+
later transcript rewrite, compaction, or truncation path must take the same lock before opening or
|
|
66
|
+
mutating the transcript file.
|
|
67
|
+
|
|
68
|
+
## Prompt assembly + system prompt
|
|
69
|
+
|
|
70
|
+
- System prompt is built from Nodmix's base prompt, skills prompt, bootstrap context, and per-run overrides.
|
|
71
|
+
- Model-specific limits and compaction reserve tokens are enforced.
|
|
72
|
+
- See [System prompt](/concepts/system-prompt) for what the model sees.
|
|
73
|
+
|
|
74
|
+
## Hook points (where you can intercept)
|
|
75
|
+
|
|
76
|
+
Nodmix has two hook systems:
|
|
77
|
+
|
|
78
|
+
- **Internal hooks** (Gateway hooks): event-driven scripts for commands and lifecycle events.
|
|
79
|
+
- **Plugin hooks**: extension points inside the agent/tool lifecycle and gateway pipeline.
|
|
80
|
+
|
|
81
|
+
### Internal hooks (Gateway hooks)
|
|
82
|
+
|
|
83
|
+
- **`agent:bootstrap`**: runs while building bootstrap files before the system prompt is finalized.
|
|
84
|
+
Use this to add/remove bootstrap context files.
|
|
85
|
+
- **Command hooks**: `/new`, `/reset`, `/stop`, and other command events (see Hooks doc).
|
|
86
|
+
|
|
87
|
+
See [Hooks](/automation/hooks) for setup and examples.
|
|
88
|
+
|
|
89
|
+
### Plugin hooks (agent + gateway lifecycle)
|
|
90
|
+
|
|
91
|
+
These run inside the agent loop or gateway pipeline:
|
|
92
|
+
|
|
93
|
+
- **`before_model_resolve`**: runs pre-session (no `messages`) to deterministically override provider/model before model resolution.
|
|
94
|
+
- **`before_prompt_build`**: runs after session load (with `messages`) to inject `prependContext`, `systemPrompt`, `prependSystemContext`, or `appendSystemContext` before prompt submission. Use `prependContext` for per-turn dynamic text and system-context fields for stable guidance that should sit in system prompt space.
|
|
95
|
+
- **`before_agent_start`**: legacy compatibility hook that may run in either phase; prefer the explicit hooks above.
|
|
96
|
+
- **`before_agent_reply`**: runs after inline actions and before the LLM call, letting a plugin claim the turn and return a synthetic reply or silence the turn entirely.
|
|
97
|
+
- **`agent_end`**: inspect the final message list and run metadata after completion.
|
|
98
|
+
- **`before_compaction` / `after_compaction`**: observe or annotate compaction cycles.
|
|
99
|
+
- **`before_tool_call` / `after_tool_call`**: intercept tool params/results.
|
|
100
|
+
- **`before_install`**: inspect built-in scan findings and optionally block skill or plugin installs.
|
|
101
|
+
- **`tool_result_persist`**: synchronously transform tool results before they are written to an Nodmix-owned session transcript.
|
|
102
|
+
- **`message_received` / `message_sending` / `message_sent`**: inbound + outbound message hooks.
|
|
103
|
+
- **`session_start` / `session_end`**: session lifecycle boundaries.
|
|
104
|
+
- **`gateway_start` / `gateway_stop`**: gateway lifecycle events.
|
|
105
|
+
|
|
106
|
+
Hook decision rules for outbound/tool guards:
|
|
107
|
+
|
|
108
|
+
- `before_tool_call`: `{ block: true }` is terminal and stops lower-priority handlers.
|
|
109
|
+
- `before_tool_call`: `{ block: false }` is a no-op and does not clear a prior block.
|
|
110
|
+
- `before_install`: `{ block: true }` is terminal and stops lower-priority handlers.
|
|
111
|
+
- `before_install`: `{ block: false }` is a no-op and does not clear a prior block.
|
|
112
|
+
- `message_sending`: `{ cancel: true }` is terminal and stops lower-priority handlers.
|
|
113
|
+
- `message_sending`: `{ cancel: false }` is a no-op and does not clear a prior cancel.
|
|
114
|
+
|
|
115
|
+
See [Plugin hooks](/plugins/hooks) for the hook API and registration details.
|
|
116
|
+
|
|
117
|
+
Harnesses may adapt these hooks differently. The Codex app-server harness keeps
|
|
118
|
+
Nodmix plugin hooks as the compatibility contract for documented mirrored
|
|
119
|
+
surfaces, while Codex native hooks remain a separate lower-level Codex mechanism.
|
|
120
|
+
|
|
121
|
+
## Streaming + partial replies
|
|
122
|
+
|
|
123
|
+
- Assistant deltas are streamed from pi-agent-core and emitted as `assistant` events.
|
|
124
|
+
- Block streaming can emit partial replies either on `text_end` or `message_end`.
|
|
125
|
+
- Reasoning streaming can be emitted as a separate stream or as block replies.
|
|
126
|
+
- See [Streaming](/concepts/streaming) for chunking and block reply behavior.
|
|
127
|
+
|
|
128
|
+
## Tool execution + messaging tools
|
|
129
|
+
|
|
130
|
+
- Tool start/update/end events are emitted on the `tool` stream.
|
|
131
|
+
- Tool results are sanitized for size and image payloads before logging/emitting.
|
|
132
|
+
- Messaging tool sends are tracked to suppress duplicate assistant confirmations.
|
|
133
|
+
|
|
134
|
+
## Reply shaping + suppression
|
|
135
|
+
|
|
136
|
+
- Final payloads are assembled from:
|
|
137
|
+
- assistant text (and optional reasoning)
|
|
138
|
+
- inline tool summaries (when verbose + allowed)
|
|
139
|
+
- assistant error text when the model errors
|
|
140
|
+
- The exact silent token `NO_REPLY` / `no_reply` is filtered from outgoing
|
|
141
|
+
payloads.
|
|
142
|
+
- Messaging tool duplicates are removed from the final payload list.
|
|
143
|
+
- If no renderable payloads remain and a tool errored, a fallback tool error reply is emitted
|
|
144
|
+
(unless a messaging tool already sent a user-visible reply).
|
|
145
|
+
|
|
146
|
+
## Compaction + retries
|
|
147
|
+
|
|
148
|
+
- Auto-compaction emits `compaction` stream events and can trigger a retry.
|
|
149
|
+
- On retry, in-memory buffers and tool summaries are reset to avoid duplicate output.
|
|
150
|
+
- See [Compaction](/concepts/compaction) for the compaction pipeline.
|
|
151
|
+
|
|
152
|
+
## Event streams (today)
|
|
153
|
+
|
|
154
|
+
- `lifecycle`: emitted by `subscribeEmbeddedPiSession` (and as a fallback by `agentCommand`)
|
|
155
|
+
- `assistant`: streamed deltas from pi-agent-core
|
|
156
|
+
- `tool`: streamed tool events from pi-agent-core
|
|
157
|
+
|
|
158
|
+
## Chat channel handling
|
|
159
|
+
|
|
160
|
+
- Assistant deltas are buffered into chat `delta` messages.
|
|
161
|
+
- A chat `final` is emitted on **lifecycle end/error**.
|
|
162
|
+
|
|
163
|
+
## Timeouts
|
|
164
|
+
|
|
165
|
+
- `agent.wait` default: 30s (just the wait). `timeoutMs` param overrides.
|
|
166
|
+
- Agent runtime: `agents.defaults.timeoutSeconds` default 172800s (48 hours); enforced in `runEmbeddedPiAgent` abort timer.
|
|
167
|
+
- Cron runtime: isolated agent-turn `timeoutSeconds` is owned by cron. The scheduler starts that timer when execution begins, aborts the underlying run at the configured deadline, then runs bounded cleanup before recording the timeout so a stale child session cannot keep the lane stuck.
|
|
168
|
+
- Session liveness diagnostics: with diagnostics enabled, `diagnostics.stuckSessionWarnMs` classifies long `processing` sessions that have no observed reply, tool, status, block, or ACP progress. Active embedded runs, model calls, and tool calls report as `session.long_running`; active work with no recent progress reports as `session.stalled`; `session.stuck` is reserved for stale session bookkeeping with no active work. Stale session bookkeeping releases the affected session lane immediately; stalled embedded runs are abort-drained only after `diagnostics.stuckSessionAbortMs` (default: at least 5 minutes and 3x the warning threshold) so queued work can resume without cutting off merely slow runs. Recovery emits structured requested/completed outcomes, and diagnostic state is marked idle only if the same processing generation is still current. Repeated `session.stuck` diagnostics back off while the session remains unchanged.
|
|
169
|
+
- Model idle timeout: Nodmix aborts a model request when no response chunks arrive before the idle window. `models.providers.<id>.timeoutSeconds` extends this idle watchdog for slow local/self-hosted providers, but it is still bounded by any lower `agents.defaults.timeoutSeconds` or run-specific timeout because those control the whole agent run. Otherwise Nodmix uses `agents.defaults.timeoutSeconds` when configured, capped at 120s by default. Cron-triggered runs with no explicit model or agent timeout disable the idle watchdog and rely on the cron outer timeout.
|
|
170
|
+
- Provider HTTP request timeout: `models.providers.<id>.timeoutSeconds` applies to that provider's model HTTP fetches, including connect, headers, body, SDK request timeout, total guarded-fetch abort handling, and model stream idle watchdog. Use this for slow local/self-hosted providers such as Ollama before raising the whole agent runtime timeout, and keep the agent/runtime timeout at least as high when the model request needs to run longer.
|
|
171
|
+
|
|
172
|
+
## Where things can end early
|
|
173
|
+
|
|
174
|
+
- Agent timeout (abort)
|
|
175
|
+
- AbortSignal (cancel)
|
|
176
|
+
- Gateway disconnect or RPC timeout
|
|
177
|
+
- `agent.wait` timeout (wait-only, does not stop agent)
|
|
178
|
+
|
|
179
|
+
## Related
|
|
180
|
+
|
|
181
|
+
- [Tools](/tools) — available agent tools
|
|
182
|
+
- [Hooks](/automation/hooks) — event-driven scripts triggered by agent lifecycle events
|
|
183
|
+
- [Compaction](/concepts/compaction) — how long conversations are summarized
|
|
184
|
+
- [Exec Approvals](/tools/exec-approvals) — approval gates for shell commands
|
|
185
|
+
- [Thinking](/tools/thinking) — thinking/reasoning level configuration
|
|
@@ -0,0 +1,243 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "How Nodmix separates model providers, models, channels, and agent runtimes"
|
|
3
|
+
title: "Agent runtimes"
|
|
4
|
+
read_when:
|
|
5
|
+
- You are choosing between PI, Codex, ACP, or another native agent runtime
|
|
6
|
+
- You are confused by provider/model/runtime labels in status or config
|
|
7
|
+
- You are documenting support parity for a native harness
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
An **agent runtime** is the component that owns one prepared model loop: it
|
|
11
|
+
receives the prompt, drives model output, handles native tool calls, and returns
|
|
12
|
+
the finished turn to Nodmix.
|
|
13
|
+
|
|
14
|
+
Runtimes are easy to confuse with providers because both show up near model
|
|
15
|
+
configuration. They are different layers:
|
|
16
|
+
|
|
17
|
+
| Layer | Examples | What it means |
|
|
18
|
+
| ------------- | ------------------------------------- | ------------------------------------------------------------------- |
|
|
19
|
+
| Provider | `openai`, `anthropic`, `openai-codex` | How Nodmix authenticates, discovers models, and names model refs. |
|
|
20
|
+
| Model | `gpt-5.5`, `claude-opus-4-6` | The model selected for the agent turn. |
|
|
21
|
+
| Agent runtime | `pi`, `codex`, `claude-cli` | The low level loop or backend that executes the prepared turn. |
|
|
22
|
+
| Channel | Telegram, Discord, Slack, WhatsApp | Where messages enter and leave Nodmix. |
|
|
23
|
+
|
|
24
|
+
You will also see the word **harness** in code. A harness is the implementation
|
|
25
|
+
that provides an agent runtime. For example, the bundled Codex harness
|
|
26
|
+
implements the `codex` runtime. Public config uses `agentRuntime.id` on
|
|
27
|
+
provider or model entries; whole-agent runtime keys are legacy and ignored.
|
|
28
|
+
`nodmix doctor --fix` removes old whole-agent runtime pins and rewrites
|
|
29
|
+
legacy runtime model refs to canonical provider/model refs plus model-scoped
|
|
30
|
+
runtime policy where needed.
|
|
31
|
+
|
|
32
|
+
There are two runtime families:
|
|
33
|
+
|
|
34
|
+
- **Embedded harnesses** run inside Nodmix's prepared agent loop. Today this
|
|
35
|
+
is the built-in `pi` runtime plus registered plugin harnesses such as
|
|
36
|
+
`codex`.
|
|
37
|
+
- **CLI backends** run a local CLI process while keeping the model ref
|
|
38
|
+
canonical. For example, `anthropic/claude-opus-4-7` with
|
|
39
|
+
a model-scoped `agentRuntime.id: "claude-cli"` means "select the Anthropic
|
|
40
|
+
model, execute through Claude CLI." `claude-cli` is not an embedded harness id
|
|
41
|
+
and must not be passed to AgentHarness selection.
|
|
42
|
+
|
|
43
|
+
## Codex surfaces
|
|
44
|
+
|
|
45
|
+
Most confusion comes from several different surfaces sharing the Codex name:
|
|
46
|
+
|
|
47
|
+
| Surface | Nodmix name/config | What it does |
|
|
48
|
+
| ------------------------------------------------ | ------------------------------------ | -------------------------------------------------------------------------------------------------------------- |
|
|
49
|
+
| Native Codex app-server runtime | `openai/*` model refs | Runs OpenAI embedded agent turns through Codex app-server. This is the usual ChatGPT/Codex subscription setup. |
|
|
50
|
+
| Codex OAuth auth profiles | `openai-codex` auth provider | Stores ChatGPT/Codex subscription auth that the Codex app-server harness consumes. |
|
|
51
|
+
| Codex ACP adapter | `runtime: "acp"`, `agentId: "codex"` | Runs Codex through the external ACP/acpx control plane. Use only when ACP/acpx is explicitly asked. |
|
|
52
|
+
| Native Codex chat-control command set | `/codex ...` | Binds, resumes, steers, stops, and inspects Codex app-server threads from chat. |
|
|
53
|
+
| OpenAI Platform API route for non-agent surfaces | `openai/*` plus API-key auth | Used for direct OpenAI APIs such as images, embeddings, speech, and realtime. |
|
|
54
|
+
|
|
55
|
+
Those surfaces are intentionally independent. Enabling the `codex` plugin makes
|
|
56
|
+
the native app-server features available; `nodmix doctor --fix` owns legacy
|
|
57
|
+
`openai-codex/*` route repair and stale session pin cleanup. Selecting
|
|
58
|
+
`openai/*` for an agent model now means "run this through Codex" unless a
|
|
59
|
+
non-agent OpenAI API surface is being used.
|
|
60
|
+
|
|
61
|
+
The common ChatGPT/Codex subscription setup uses Codex OAuth for auth, but keeps
|
|
62
|
+
the model ref as `openai/*` and selects the `codex` runtime:
|
|
63
|
+
|
|
64
|
+
```json5
|
|
65
|
+
{
|
|
66
|
+
agents: {
|
|
67
|
+
defaults: {
|
|
68
|
+
model: "openai/gpt-5.5",
|
|
69
|
+
},
|
|
70
|
+
},
|
|
71
|
+
}
|
|
72
|
+
```
|
|
73
|
+
|
|
74
|
+
That means Nodmix selects an OpenAI model ref, then asks the Codex app-server
|
|
75
|
+
runtime to run the embedded agent turn. It does not mean "use API billing," and
|
|
76
|
+
it does not mean the channel, model provider catalog, or Nodmix session store
|
|
77
|
+
becomes Codex.
|
|
78
|
+
|
|
79
|
+
When the bundled `codex` plugin is enabled, natural-language Codex control
|
|
80
|
+
should use the native `/codex` command surface (`/codex bind`, `/codex threads`,
|
|
81
|
+
`/codex resume`, `/codex steer`, `/codex stop`) instead of ACP. Use ACP for
|
|
82
|
+
Codex only when the user explicitly asks for ACP/acpx or is testing the ACP
|
|
83
|
+
adapter path. Claude Code, Gemini CLI, OpenCode, Cursor, and similar external
|
|
84
|
+
harnesses still use ACP.
|
|
85
|
+
|
|
86
|
+
This is the agent-facing decision tree:
|
|
87
|
+
|
|
88
|
+
1. If the user asks for **Codex bind/control/thread/resume/steer/stop**, use the
|
|
89
|
+
native `/codex` command surface when the bundled `codex` plugin is enabled.
|
|
90
|
+
2. If the user asks for **Codex as the embedded runtime** or wants the normal
|
|
91
|
+
subscription-backed Codex agent experience, use `openai/<model>`.
|
|
92
|
+
3. If the user explicitly chooses **PI for an OpenAI model**, keep the model ref
|
|
93
|
+
as `openai/<model>` and set provider/model runtime policy to
|
|
94
|
+
`agentRuntime.id: "pi"`. A selected `openai-codex` auth profile is routed
|
|
95
|
+
internally through PI's legacy Codex-auth transport.
|
|
96
|
+
4. If legacy config still contains **`openai-codex/*` model refs**, repair it to
|
|
97
|
+
`openai/<model>` with `nodmix doctor --fix`; doctor keeps the Codex auth
|
|
98
|
+
route by adding provider/model-scoped `agentRuntime.id: "codex"` where the
|
|
99
|
+
old model ref implied it.
|
|
100
|
+
Legacy **`codex-cli/*` model refs** repair to the same `openai/<model>` Codex
|
|
101
|
+
app-server route; Nodmix no longer keeps a bundled Codex CLI backend.
|
|
102
|
+
5. If the user explicitly says **ACP**, **acpx**, or **Codex ACP adapter**, use
|
|
103
|
+
ACP with `runtime: "acp"` and `agentId: "codex"`.
|
|
104
|
+
6. If the request is for **Claude Code, Gemini CLI, OpenCode, Cursor, Droid, or
|
|
105
|
+
another external harness**, use ACP/acpx, not the native sub-agent runtime.
|
|
106
|
+
|
|
107
|
+
| You mean... | Use... |
|
|
108
|
+
| --------------------------------------- | -------------------------------------------- |
|
|
109
|
+
| Codex app-server chat/thread control | `/codex ...` from the bundled `codex` plugin |
|
|
110
|
+
| Codex app-server embedded agent runtime | `openai/*` agent model refs |
|
|
111
|
+
| OpenAI Codex OAuth | `openai-codex` auth profiles |
|
|
112
|
+
| Claude Code or other external harness | ACP/acpx |
|
|
113
|
+
|
|
114
|
+
For the OpenAI-family prefix split, see [OpenAI](/providers/openai) and
|
|
115
|
+
[Model providers](/concepts/model-providers). For the Codex runtime support
|
|
116
|
+
contract, see [Codex harness runtime](/plugins/codex-harness-runtime#v1-support-contract).
|
|
117
|
+
|
|
118
|
+
## Runtime ownership
|
|
119
|
+
|
|
120
|
+
Different runtimes own different amounts of the loop.
|
|
121
|
+
|
|
122
|
+
| Surface | Nodmix PI embedded | Codex app-server |
|
|
123
|
+
| --------------------------- | --------------------------------------- | --------------------------------------------------------------------------- |
|
|
124
|
+
| Model loop owner | Nodmix through the PI embedded runner | Codex app-server |
|
|
125
|
+
| Canonical thread state | Nodmix transcript | Codex thread, plus Nodmix transcript mirror |
|
|
126
|
+
| Nodmix dynamic tools | Native Nodmix tool loop | Bridged through the Codex adapter |
|
|
127
|
+
| Native shell and file tools | PI/Nodmix path | Codex-native tools, bridged through native hooks where supported |
|
|
128
|
+
| Context engine | Native Nodmix context assembly | Nodmix projects assembled context into the Codex turn |
|
|
129
|
+
| Compaction | Nodmix or selected context engine | Codex-native compaction, with Nodmix notifications and mirror maintenance |
|
|
130
|
+
| Channel delivery | Nodmix | Nodmix |
|
|
131
|
+
|
|
132
|
+
This ownership split is the main design rule:
|
|
133
|
+
|
|
134
|
+
- If Nodmix owns the surface, Nodmix can provide normal plugin hook behavior.
|
|
135
|
+
- If the native runtime owns the surface, Nodmix needs runtime events or native hooks.
|
|
136
|
+
- If the native runtime owns canonical thread state, Nodmix should mirror and project context, not rewrite unsupported internals.
|
|
137
|
+
|
|
138
|
+
## Runtime selection
|
|
139
|
+
|
|
140
|
+
Nodmix chooses an embedded runtime after provider and model resolution:
|
|
141
|
+
|
|
142
|
+
1. Model-scoped runtime policy wins. This can live in a configured provider
|
|
143
|
+
model entry or in `agents.defaults.models["provider/model"].agentRuntime` /
|
|
144
|
+
`agents.list[].models["provider/model"].agentRuntime`. A provider wildcard
|
|
145
|
+
such as `agents.defaults.models["vllm/*"].agentRuntime` applies after exact
|
|
146
|
+
model policy, so dynamically discovered provider models can share one
|
|
147
|
+
runtime without overriding exact per-model exceptions.
|
|
148
|
+
2. Provider-scoped runtime policy comes next at
|
|
149
|
+
`models.providers.<provider>.agentRuntime`.
|
|
150
|
+
3. In `auto` mode, registered plugin runtimes can claim supported provider/model
|
|
151
|
+
pairs.
|
|
152
|
+
4. If no runtime claims a turn in `auto` mode, Nodmix uses PI as the
|
|
153
|
+
compatibility runtime. Use an explicit runtime id when the run must be
|
|
154
|
+
strict.
|
|
155
|
+
|
|
156
|
+
Whole-session and whole-agent runtime pins are ignored. That includes
|
|
157
|
+
`NODMIX_AGENT_RUNTIME`, session `agentHarnessId`/`agentRuntimeOverride` state,
|
|
158
|
+
`agents.defaults.agentRuntime`, and `agents.list[].agentRuntime`. Run
|
|
159
|
+
`nodmix doctor --fix` to remove stale whole-agent runtime config and convert
|
|
160
|
+
legacy runtime model refs where Nodmix can preserve the intent.
|
|
161
|
+
|
|
162
|
+
Explicit provider/model plugin runtimes fail closed. For example,
|
|
163
|
+
`agentRuntime.id: "codex"` on a provider or model means Codex or a clear
|
|
164
|
+
selection/runtime error; it is never silently routed back to PI.
|
|
165
|
+
|
|
166
|
+
CLI backend aliases are different from embedded harness ids. The preferred
|
|
167
|
+
Claude CLI form is:
|
|
168
|
+
|
|
169
|
+
```json5
|
|
170
|
+
{
|
|
171
|
+
agents: {
|
|
172
|
+
defaults: {
|
|
173
|
+
model: "anthropic/claude-opus-4-7",
|
|
174
|
+
models: {
|
|
175
|
+
"anthropic/claude-opus-4-7": {
|
|
176
|
+
agentRuntime: { id: "claude-cli" },
|
|
177
|
+
},
|
|
178
|
+
},
|
|
179
|
+
},
|
|
180
|
+
},
|
|
181
|
+
}
|
|
182
|
+
```
|
|
183
|
+
|
|
184
|
+
Legacy refs such as `claude-cli/claude-opus-4-7` remain supported for
|
|
185
|
+
compatibility, but new config should keep the provider/model canonical and put
|
|
186
|
+
the execution backend in provider/model runtime policy.
|
|
187
|
+
|
|
188
|
+
Legacy `codex-cli/*` refs are different: doctor migrates them to `openai/*` so
|
|
189
|
+
they run through the Codex app-server harness instead of preserving a Codex CLI
|
|
190
|
+
backend.
|
|
191
|
+
|
|
192
|
+
`auto` mode is intentionally conservative for most providers. OpenAI agent
|
|
193
|
+
models are the exception: unset runtime and `auto` both resolve to the Codex
|
|
194
|
+
harness. Explicit PI runtime config remains an opt-in compatibility route for
|
|
195
|
+
`openai/*` agent turns; when paired with a selected `openai-codex` auth profile,
|
|
196
|
+
Nodmix routes PI internally through the legacy Codex-auth transport while
|
|
197
|
+
keeping the public model ref as `openai/*`. Stale OpenAI PI session pins are
|
|
198
|
+
ignored by runtime selection and can be cleaned with `nodmix doctor --fix`.
|
|
199
|
+
|
|
200
|
+
If `nodmix doctor` warns that the `codex` plugin is enabled while
|
|
201
|
+
`openai-codex/*` remains in config, treat that as legacy route state. Run
|
|
202
|
+
`nodmix doctor --fix` to rewrite it to `openai/*` with the Codex runtime.
|
|
203
|
+
|
|
204
|
+
## Compatibility contract
|
|
205
|
+
|
|
206
|
+
When a runtime is not PI, it should document what Nodmix surfaces it supports.
|
|
207
|
+
Use this shape for runtime docs:
|
|
208
|
+
|
|
209
|
+
| Question | Why it matters |
|
|
210
|
+
| -------------------------------------- | ------------------------------------------------------------------------------------------------- |
|
|
211
|
+
| Who owns the model loop? | Determines where retries, tool continuation, and final answer decisions happen. |
|
|
212
|
+
| Who owns canonical thread history? | Determines whether Nodmix can edit history or only mirror it. |
|
|
213
|
+
| Do Nodmix dynamic tools work? | Messaging, sessions, cron, and Nodmix-owned tools rely on this. |
|
|
214
|
+
| Do dynamic tool hooks work? | Plugins expect `before_tool_call`, `after_tool_call`, and middleware around Nodmix-owned tools. |
|
|
215
|
+
| Do native tool hooks work? | Shell, patch, and runtime-owned tools need native hook support for policy and observation. |
|
|
216
|
+
| Does the context engine lifecycle run? | Memory and context plugins depend on assemble, ingest, after-turn, and compaction lifecycle. |
|
|
217
|
+
| What compaction data is exposed? | Some plugins only need notifications, while others need kept/dropped metadata. |
|
|
218
|
+
| What is intentionally unsupported? | Users should not assume PI equivalence where the native runtime owns more state. |
|
|
219
|
+
|
|
220
|
+
The Codex runtime support contract is documented in
|
|
221
|
+
[Codex harness runtime](/plugins/codex-harness-runtime#v1-support-contract).
|
|
222
|
+
|
|
223
|
+
## Status labels
|
|
224
|
+
|
|
225
|
+
Status output may show both `Execution` and `Runtime` labels. Read them as
|
|
226
|
+
diagnostics, not as provider names.
|
|
227
|
+
|
|
228
|
+
- A model ref such as `openai/gpt-5.5` tells you the selected provider/model.
|
|
229
|
+
- A runtime id such as `codex` tells you which loop is executing the turn.
|
|
230
|
+
- A channel label such as Telegram or Discord tells you where the conversation is happening.
|
|
231
|
+
|
|
232
|
+
If a run still shows an unexpected runtime, inspect the selected provider/model
|
|
233
|
+
runtime policy first. Legacy session runtime pins no longer decide routing.
|
|
234
|
+
|
|
235
|
+
## Related
|
|
236
|
+
|
|
237
|
+
- [Codex harness](/plugins/codex-harness)
|
|
238
|
+
- [Codex harness runtime](/plugins/codex-harness-runtime)
|
|
239
|
+
- [OpenAI](/providers/openai)
|
|
240
|
+
- [Agent harness plugins](/plugins/sdk-agent-harness)
|
|
241
|
+
- [Agent loop](/concepts/agent-loop)
|
|
242
|
+
- [Models](/concepts/models)
|
|
243
|
+
- [Status](/cli/status)
|
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
---
|
|
2
|
+
summary: "Agent workspace: location, layout, and backup strategy"
|
|
3
|
+
read_when:
|
|
4
|
+
- You need to explain the agent workspace or its file layout
|
|
5
|
+
- You want to back up or migrate an agent workspace
|
|
6
|
+
title: "Agent workspace"
|
|
7
|
+
sidebarTitle: "Agent workspace"
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
The workspace is the agent's home. It is the only working directory used for file tools and for workspace context. Keep it private and treat it as memory.
|
|
11
|
+
|
|
12
|
+
This is separate from `~/.nodmix/`, which stores config, credentials, and sessions.
|
|
13
|
+
|
|
14
|
+
<Warning>
|
|
15
|
+
The workspace is the **default cwd**, not a hard sandbox. Tools resolve relative paths against the workspace, but absolute paths can still reach elsewhere on the host unless sandboxing is enabled. If you need isolation, use [`agents.defaults.sandbox`](/gateway/sandboxing) (and/or per-agent sandbox config).
|
|
16
|
+
|
|
17
|
+
When sandboxing is enabled and `workspaceAccess` is not `"rw"`, tools operate inside a sandbox workspace under `~/.nodmix/sandboxes`, not your host workspace.
|
|
18
|
+
</Warning>
|
|
19
|
+
|
|
20
|
+
## Default location
|
|
21
|
+
|
|
22
|
+
- Default: `~/.nodmix/workspace`
|
|
23
|
+
- If `NODMIX_PROFILE` is set and not `"default"`, the default becomes `~/.nodmix/workspace-<profile>`.
|
|
24
|
+
- Override in `~/.nodmix/nodmix.json`:
|
|
25
|
+
|
|
26
|
+
```json5
|
|
27
|
+
{
|
|
28
|
+
agents: {
|
|
29
|
+
defaults: {
|
|
30
|
+
workspace: "~/.nodmix/workspace",
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
}
|
|
34
|
+
```
|
|
35
|
+
|
|
36
|
+
`nodmix onboard`, `nodmix configure`, or `nodmix setup` will create the workspace and seed the bootstrap files if they are missing.
|
|
37
|
+
|
|
38
|
+
<Note>
|
|
39
|
+
Sandbox seed copies only accept regular in-workspace files; symlink/hardlink aliases that resolve outside the source workspace are ignored.
|
|
40
|
+
</Note>
|
|
41
|
+
|
|
42
|
+
If you already manage the workspace files yourself, you can disable bootstrap file creation:
|
|
43
|
+
|
|
44
|
+
```json5
|
|
45
|
+
{ agents: { defaults: { skipBootstrap: true } } }
|
|
46
|
+
```
|
|
47
|
+
|
|
48
|
+
## Extra workspace folders
|
|
49
|
+
|
|
50
|
+
Older installs may have created `~/nodmix`. Keeping multiple workspace directories around can cause confusing auth or state drift, because only one workspace is active at a time.
|
|
51
|
+
|
|
52
|
+
<Note>
|
|
53
|
+
**Recommendation:** keep a single active workspace. If you no longer use the extra folders, archive or move them to Trash (for example `trash ~/nodmix`). If you intentionally keep multiple workspaces, make sure `agents.defaults.workspace` points to the active one.
|
|
54
|
+
|
|
55
|
+
`nodmix doctor` warns when it detects extra workspace directories.
|
|
56
|
+
</Note>
|
|
57
|
+
|
|
58
|
+
## Workspace file map
|
|
59
|
+
|
|
60
|
+
These are the standard files Nodmix expects inside the workspace:
|
|
61
|
+
|
|
62
|
+
<AccordionGroup>
|
|
63
|
+
<Accordion title="AGENTS.md - operating instructions">
|
|
64
|
+
Operating instructions for the agent and how it should use memory. Loaded at the start of every session. Good place for rules, priorities, and "how to behave" details.
|
|
65
|
+
</Accordion>
|
|
66
|
+
<Accordion title="SOUL.md - persona and tone">
|
|
67
|
+
Persona, tone, and boundaries. Loaded every session. Guide: [SOUL.md personality guide](/concepts/soul).
|
|
68
|
+
</Accordion>
|
|
69
|
+
<Accordion title="USER.md - who the user is">
|
|
70
|
+
Who the user is and how to address them. Loaded every session.
|
|
71
|
+
</Accordion>
|
|
72
|
+
<Accordion title="IDENTITY.md - name, vibe, emoji">
|
|
73
|
+
The agent's name, vibe, and emoji. Created/updated during the bootstrap ritual.
|
|
74
|
+
</Accordion>
|
|
75
|
+
<Accordion title="TOOLS.md - local tool conventions">
|
|
76
|
+
Notes about your local tools and conventions. Does not control tool availability; it is only guidance.
|
|
77
|
+
</Accordion>
|
|
78
|
+
<Accordion title="HEARTBEAT.md - heartbeat checklist">
|
|
79
|
+
Optional tiny checklist for heartbeat runs. Keep it short to avoid token burn.
|
|
80
|
+
</Accordion>
|
|
81
|
+
<Accordion title="BOOT.md - startup checklist">
|
|
82
|
+
Optional startup checklist run automatically on gateway restart (when [internal hooks](/automation/hooks) are enabled). Keep it short; use the message tool for outbound sends.
|
|
83
|
+
</Accordion>
|
|
84
|
+
<Accordion title="BOOTSTRAP.md - first-run ritual">
|
|
85
|
+
One-time first-run ritual. Only created for a brand-new workspace. Delete it after the ritual is complete.
|
|
86
|
+
</Accordion>
|
|
87
|
+
<Accordion title="memory/YYYY-MM-DD.md - daily memory log">
|
|
88
|
+
Daily memory log (one file per day). Recommended to read today + yesterday on session start.
|
|
89
|
+
</Accordion>
|
|
90
|
+
<Accordion title="MEMORY.md - curated long-term memory (optional)">
|
|
91
|
+
Curated long-term memory: durable facts, preferences, decisions, and short summaries. Keep detailed logs in `memory/YYYY-MM-DD.md` so memory tools can retrieve them on demand without injecting them into every prompt. Only load `MEMORY.md` in the main, private session (not shared/group contexts). See [Memory](/concepts/memory) for the workflow and automatic memory flush.
|
|
92
|
+
</Accordion>
|
|
93
|
+
<Accordion title="skills/ - workspace skills (optional)">
|
|
94
|
+
Workspace-specific skills. Highest-precedence skill location for that workspace. Overrides project agent skills, personal agent skills, managed skills, bundled skills, and `skills.load.extraDirs` when names collide.
|
|
95
|
+
</Accordion>
|
|
96
|
+
<Accordion title="canvas/ - Canvas UI files (optional)">
|
|
97
|
+
Canvas UI files for node displays (for example `canvas/index.html`).
|
|
98
|
+
</Accordion>
|
|
99
|
+
</AccordionGroup>
|
|
100
|
+
|
|
101
|
+
<Note>
|
|
102
|
+
If any bootstrap file is missing, Nodmix injects a "missing file" marker into the session and continues. Large bootstrap files are truncated when injected; adjust limits with `agents.defaults.bootstrapMaxChars` (default: 12000) and `agents.defaults.bootstrapTotalMaxChars` (default: 60000). `nodmix setup` can recreate missing defaults without overwriting existing files.
|
|
103
|
+
</Note>
|
|
104
|
+
|
|
105
|
+
## What is NOT in the workspace
|
|
106
|
+
|
|
107
|
+
These live under `~/.nodmix/` and should NOT be committed to the workspace repo:
|
|
108
|
+
|
|
109
|
+
- `~/.nodmix/nodmix.json` (config)
|
|
110
|
+
- `~/.nodmix/agents/<agentId>/agent/auth-profiles.json` (model auth profiles: OAuth + API keys)
|
|
111
|
+
- `~/.nodmix/agents/<agentId>/agent/codex-home/` (per-agent Codex runtime account, config, skills, plugins, and native thread state)
|
|
112
|
+
- `~/.nodmix/credentials/` (channel/provider state plus legacy OAuth import data)
|
|
113
|
+
- `~/.nodmix/agents/<agentId>/sessions/` (session transcripts + metadata)
|
|
114
|
+
- `~/.nodmix/skills/` (managed skills)
|
|
115
|
+
|
|
116
|
+
If you need to migrate sessions or config, copy them separately and keep them out of version control.
|
|
117
|
+
|
|
118
|
+
## Git backup (recommended, private)
|
|
119
|
+
|
|
120
|
+
Treat the workspace as private memory. Put it in a **private** git repo so it is backed up and recoverable.
|
|
121
|
+
|
|
122
|
+
Run these steps on the machine where the Gateway runs (that is where the workspace lives).
|
|
123
|
+
|
|
124
|
+
<Steps>
|
|
125
|
+
<Step title="Initialize the repo">
|
|
126
|
+
If git is installed, brand-new workspaces are initialized automatically. If this workspace is not already a repo, run:
|
|
127
|
+
|
|
128
|
+
```bash
|
|
129
|
+
cd ~/.nodmix/workspace
|
|
130
|
+
git init
|
|
131
|
+
git add AGENTS.md SOUL.md TOOLS.md IDENTITY.md USER.md HEARTBEAT.md memory/
|
|
132
|
+
git commit -m "Add agent workspace"
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
</Step>
|
|
136
|
+
<Step title="Add a private remote">
|
|
137
|
+
<Tabs>
|
|
138
|
+
<Tab title="GitHub web UI">
|
|
139
|
+
1. Create a new **private** repository on GitHub.
|
|
140
|
+
2. Do not initialize with a README (avoids merge conflicts).
|
|
141
|
+
3. Copy the HTTPS remote URL.
|
|
142
|
+
4. Add the remote and push:
|
|
143
|
+
|
|
144
|
+
```bash
|
|
145
|
+
git branch -M main
|
|
146
|
+
git remote add origin <https-url>
|
|
147
|
+
git push -u origin main
|
|
148
|
+
```
|
|
149
|
+
</Tab>
|
|
150
|
+
<Tab title="GitHub CLI (gh)">
|
|
151
|
+
```bash
|
|
152
|
+
gh auth login
|
|
153
|
+
gh repo create nodmix-workspace --private --source . --remote origin --push
|
|
154
|
+
```
|
|
155
|
+
</Tab>
|
|
156
|
+
<Tab title="GitLab web UI">
|
|
157
|
+
1. Create a new **private** repository on GitLab.
|
|
158
|
+
2. Do not initialize with a README (avoids merge conflicts).
|
|
159
|
+
3. Copy the HTTPS remote URL.
|
|
160
|
+
4. Add the remote and push:
|
|
161
|
+
|
|
162
|
+
```bash
|
|
163
|
+
git branch -M main
|
|
164
|
+
git remote add origin <https-url>
|
|
165
|
+
git push -u origin main
|
|
166
|
+
```
|
|
167
|
+
</Tab>
|
|
168
|
+
</Tabs>
|
|
169
|
+
|
|
170
|
+
</Step>
|
|
171
|
+
<Step title="Ongoing updates">
|
|
172
|
+
```bash
|
|
173
|
+
git status
|
|
174
|
+
git add .
|
|
175
|
+
git commit -m "Update memory"
|
|
176
|
+
git push
|
|
177
|
+
```
|
|
178
|
+
</Step>
|
|
179
|
+
</Steps>
|
|
180
|
+
|
|
181
|
+
## Do not commit secrets
|
|
182
|
+
|
|
183
|
+
<Warning>
|
|
184
|
+
Even in a private repo, avoid storing secrets in the workspace:
|
|
185
|
+
|
|
186
|
+
- API keys, OAuth tokens, passwords, or private credentials.
|
|
187
|
+
- Anything under `~/.nodmix/`.
|
|
188
|
+
- Raw dumps of chats or sensitive attachments.
|
|
189
|
+
|
|
190
|
+
If you must store sensitive references, use placeholders and keep the real secret elsewhere (password manager, environment variables, or `~/.nodmix/`).
|
|
191
|
+
</Warning>
|
|
192
|
+
|
|
193
|
+
Suggested `.gitignore` starter:
|
|
194
|
+
|
|
195
|
+
```gitignore
|
|
196
|
+
.DS_Store
|
|
197
|
+
.env
|
|
198
|
+
**/*.key
|
|
199
|
+
**/*.pem
|
|
200
|
+
**/secrets*
|
|
201
|
+
```
|
|
202
|
+
|
|
203
|
+
## Moving the workspace to a new machine
|
|
204
|
+
|
|
205
|
+
<Steps>
|
|
206
|
+
<Step title="Clone the repo">
|
|
207
|
+
Clone the repo to the desired path (default `~/.nodmix/workspace`).
|
|
208
|
+
</Step>
|
|
209
|
+
<Step title="Update config">
|
|
210
|
+
Set `agents.defaults.workspace` to that path in `~/.nodmix/nodmix.json`.
|
|
211
|
+
</Step>
|
|
212
|
+
<Step title="Seed missing files">
|
|
213
|
+
Run `nodmix setup --workspace <path>` to seed any missing files.
|
|
214
|
+
</Step>
|
|
215
|
+
<Step title="Copy sessions (optional)">
|
|
216
|
+
If you need sessions, copy `~/.nodmix/agents/<agentId>/sessions/` from the old machine separately.
|
|
217
|
+
</Step>
|
|
218
|
+
</Steps>
|
|
219
|
+
|
|
220
|
+
## Advanced notes
|
|
221
|
+
|
|
222
|
+
- Multi-agent routing can use different workspaces per agent. See [Channel routing](/channels/channel-routing) for routing configuration.
|
|
223
|
+
- If `agents.defaults.sandbox` is enabled, non-main sessions can use per-session sandbox workspaces under `agents.defaults.sandbox.workspaceRoot`.
|
|
224
|
+
|
|
225
|
+
## Related
|
|
226
|
+
|
|
227
|
+
- [Heartbeat](/gateway/heartbeat) - HEARTBEAT.md workspace file
|
|
228
|
+
- [Sandboxing](/gateway/sandboxing) - workspace access in sandboxed environments
|
|
229
|
+
- [Session](/concepts/session) - session storage paths
|
|
230
|
+
- [Standing orders](/automation/standing-orders) - persistent instructions in workspace files
|