@poolzin/pool-bot 2026.1.26 → 2026.1.30
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 +76 -1116
- package/LICENSE +21 -0
- package/README.md +58 -37
- package/assets/chrome-extension/README.md +2 -2
- package/assets/chrome-extension/background.js +5 -5
- package/assets/chrome-extension/manifest.json +3 -3
- package/assets/chrome-extension/options.html +5 -6
- package/assets/chrome-extension/options.js +1 -1
- package/dist/acp/client.js +5 -5
- package/dist/acp/server.js +1 -1
- package/dist/acp/types.js +2 -2
- package/dist/agents/agent-paths.js +3 -3
- package/dist/agents/auth-health.js +2 -6
- package/dist/agents/auth-profiles/doctor.js +1 -1
- package/dist/agents/auth-profiles/external-cli-sync.js +5 -150
- package/dist/agents/auth-profiles/oauth.js +26 -7
- package/dist/agents/auth-profiles/paths.js +3 -3
- package/dist/agents/auth-profiles/store.js +5 -13
- package/dist/agents/bash-tools.shared.js +8 -1
- package/dist/agents/cli-backends.js +8 -0
- package/dist/agents/cli-runner/helpers.js +3 -3
- package/dist/agents/cli-runner.js +2 -2
- package/dist/agents/compaction.js +3 -0
- package/dist/agents/context.js +4 -4
- package/dist/agents/docs-path.js +3 -3
- package/dist/agents/identity.js +1 -1
- package/dist/agents/memory-search.js +7 -2
- package/dist/agents/minimax-vlm.js +1 -1
- package/dist/agents/model-auth.js +1 -1
- package/dist/agents/model-catalog.js +4 -4
- package/dist/agents/model-fallback.js +22 -0
- package/dist/agents/model-selection.js +1 -1
- package/dist/agents/models-config.js +3 -3
- package/dist/agents/models-config.providers.js +4 -4
- package/dist/agents/pi-embedded-helpers/openai.js +1 -1
- package/dist/agents/pi-embedded-runner/cache-ttl.js +1 -1
- package/dist/agents/pi-embedded-runner/compact.js +8 -8
- package/dist/agents/pi-embedded-runner/extensions.js +5 -0
- package/dist/agents/pi-embedded-runner/model.js +2 -2
- package/dist/agents/pi-embedded-runner/run/attempt.js +10 -6
- package/dist/agents/pi-embedded-runner/run.js +4 -4
- package/dist/agents/pi-embedded-runner/sandbox-info.js +1 -4
- package/dist/agents/pi-embedded-runner/utils.js +1 -1
- package/dist/agents/pi-embedded-utils.js +7 -1
- package/dist/agents/pi-extensions/compaction-safeguard-runtime.js +20 -0
- package/dist/agents/pi-extensions/compaction-safeguard.js +32 -3
- package/dist/agents/pi-tools.js +25 -15
- package/dist/agents/pi-tools.policy.js +34 -1
- package/dist/agents/pi-tools.read.js +2 -2
- package/dist/agents/{clawdbot-tools.js → poolbot-tools.js} +2 -5
- package/dist/agents/sandbox/browser.js +5 -7
- package/dist/agents/sandbox/config.js +0 -12
- package/dist/agents/sandbox/constants.js +8 -8
- package/dist/agents/sandbox/context.js +3 -3
- package/dist/agents/sandbox/docker.js +8 -8
- package/dist/agents/sandbox/runtime-status.js +1 -1
- package/dist/agents/session-transcript-repair.js +1 -1
- package/dist/agents/session-write-lock.js +68 -0
- package/dist/agents/skills/config.js +9 -8
- package/dist/agents/skills/env-overrides.js +1 -1
- package/dist/agents/skills/frontmatter.js +15 -14
- package/dist/agents/skills/workspace.js +7 -7
- package/dist/agents/skills-install.js +1 -1
- package/dist/agents/skills-status.js +12 -12
- package/dist/agents/subagent-registry.store.js +2 -2
- package/dist/agents/system-prompt.js +24 -35
- package/dist/agents/tool-images.js +1 -1
- package/dist/agents/tool-policy.js +8 -2
- package/dist/agents/tools/browser-tool.js +19 -79
- package/dist/agents/tools/browser-tool.schema.js +1 -2
- package/dist/agents/tools/cron-tool.js +44 -1
- package/dist/agents/tools/discord-actions-guild.js +5 -1
- package/dist/agents/tools/image-tool.js +2 -2
- package/dist/agents/tools/memory-tool.js +2 -1
- package/dist/agents/tools/message-tool.js +1 -0
- package/dist/agents/tools/sessions-send-helpers.js +17 -2
- package/dist/agents/tools/telegram-actions.js +93 -1
- package/dist/agents/tools/web-fetch.js +123 -103
- package/dist/agents/tools/web-search.js +7 -7
- package/dist/agents/workspace.js +36 -0
- package/dist/auto-reply/commands-registry.data.js +68 -3
- package/dist/auto-reply/commands-registry.js +14 -11
- package/dist/auto-reply/reply/agent-runner-execution.js +21 -3
- package/dist/auto-reply/reply/agent-runner-memory.js +5 -0
- package/dist/auto-reply/reply/bash-command.js +2 -2
- package/dist/auto-reply/reply/commands-context-report.js +2 -2
- package/dist/auto-reply/reply/commands-info.js +50 -5
- package/dist/auto-reply/reply/commands-session.js +4 -4
- package/dist/auto-reply/reply/commands-tts.js +61 -63
- package/dist/auto-reply/reply/directive-handling.shared.js +1 -1
- package/dist/auto-reply/reply/dispatch-from-config.js +65 -1
- package/dist/auto-reply/reply/followup-runner.js +5 -0
- package/dist/auto-reply/reply/get-reply-inline-actions.js +2 -2
- package/dist/auto-reply/reply/get-reply-run.js +4 -0
- package/dist/auto-reply/reply/groups.js +1 -1
- package/dist/auto-reply/reply/history.js +23 -0
- package/dist/auto-reply/reply/reply-elevated.js +1 -1
- package/dist/auto-reply/reply/session-updates.js +6 -1
- package/dist/auto-reply/reply/stage-sandbox-media.js +1 -1
- package/dist/auto-reply/status.js +142 -50
- package/dist/browser/bridge-server.js +1 -3
- package/dist/browser/client-actions-core.js +13 -7
- package/dist/browser/client-actions-observe.js +14 -8
- package/dist/browser/client-actions-state.js +21 -15
- package/dist/browser/client-fetch.js +74 -61
- package/dist/browser/client.js +19 -21
- package/dist/browser/config.js +13 -26
- package/dist/browser/constants.js +1 -1
- package/dist/browser/control-service.js +72 -0
- package/dist/browser/extension-relay.js +3 -3
- package/dist/browser/pw-session.js +41 -4
- package/dist/browser/pw-tools-core.downloads.js +1 -1
- package/dist/browser/pw-tools-core.interactions.js +5 -5
- package/dist/browser/pw-tools-core.responses.js +1 -1
- package/dist/browser/routes/agent.act.js +13 -0
- package/dist/browser/routes/agent.debug.js +1 -1
- package/dist/browser/routes/basic.js +0 -1
- package/dist/browser/routes/dispatcher.js +86 -0
- package/dist/browser/server-context.js +3 -3
- package/dist/browser/server.js +7 -9
- package/dist/build-info.json +3 -3
- package/dist/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/canvas-host/a2ui/a2ui.bundle.js +1620 -1618
- package/dist/canvas-host/a2ui/index.html +28 -28
- package/dist/canvas-host/a2ui.js +27 -21
- package/dist/canvas-host/server.js +66 -32
- package/dist/channels/plugins/actions/discord/handle-action.guild-admin.js +5 -1
- package/dist/channels/plugins/actions/telegram.js +60 -7
- package/dist/channels/plugins/catalog.js +6 -4
- package/dist/channels/plugins/group-mentions.js +48 -1
- package/dist/channels/plugins/helpers.js +2 -2
- package/dist/channels/plugins/message-action-names.js +1 -0
- package/dist/channels/plugins/onboarding/imessage.js +1 -1
- package/dist/channels/plugins/onboarding/signal.js +2 -2
- package/dist/channels/plugins/onboarding/slack.js +4 -4
- package/dist/channels/plugins/onboarding/telegram.js +17 -9
- package/dist/channels/plugins/onboarding/whatsapp.js +4 -4
- package/dist/channels/plugins/outbound/telegram.js +38 -0
- package/dist/channels/plugins/pairing-message.js +1 -1
- package/dist/channels/plugins/status-issues/bluebubbles.js +1 -1
- package/dist/channels/plugins/status-issues/whatsapp.js +2 -2
- package/dist/channels/registry.js +1 -1
- package/dist/cli/acp-cli.js +2 -2
- package/dist/cli/argv.js +14 -7
- package/dist/cli/banner.js +3 -1
- package/dist/cli/browser-cli-actions-input/register.element.js +72 -44
- package/dist/cli/browser-cli-actions-input/register.files-downloads.js +55 -35
- package/dist/cli/browser-cli-actions-input/register.form-wait-eval.js +41 -28
- package/dist/cli/browser-cli-actions-input/register.navigation.js +23 -14
- package/dist/cli/browser-cli-actions-input/shared.js +10 -3
- package/dist/cli/browser-cli-actions-observe.js +29 -21
- package/dist/cli/browser-cli-debug.js +49 -35
- package/dist/cli/browser-cli-examples.js +29 -29
- package/dist/cli/browser-cli-extension.js +8 -8
- package/dist/cli/browser-cli-inspect.js +23 -17
- package/dist/cli/browser-cli-manage.js +106 -56
- package/dist/cli/browser-cli-shared.js +34 -1
- package/dist/cli/browser-cli-state.cookies-storage.js +53 -39
- package/dist/cli/browser-cli-state.js +90 -64
- package/dist/cli/browser-cli.js +4 -5
- package/dist/cli/channels-cli.js +1 -1
- package/dist/cli/cli-name.js +26 -0
- package/dist/cli/command-format.js +11 -7
- package/dist/cli/config-cli.js +2 -2
- package/dist/cli/cron-cli/register.js +1 -1
- package/dist/cli/daemon-cli/install.js +1 -1
- package/dist/cli/daemon-cli/register.js +1 -1
- package/dist/cli/daemon-cli/shared.js +5 -3
- package/dist/cli/daemon-cli/status.print.js +6 -6
- package/dist/cli/directory-cli.js +1 -1
- package/dist/cli/dns-cli.js +7 -7
- package/dist/cli/docs-cli.js +2 -2
- package/dist/cli/exec-approvals-cli.js +2 -2
- package/dist/cli/gateway-cli/dev.js +4 -4
- package/dist/cli/gateway-cli/register.js +1 -1
- package/dist/cli/gateway-cli/run.js +11 -8
- package/dist/cli/gateway-cli/shared.js +4 -4
- package/dist/cli/hooks-cli.js +3 -3
- package/dist/cli/logs-cli.js +3 -3
- package/dist/cli/memory-cli.js +1 -1
- package/dist/cli/models-cli.js +2 -2
- package/dist/cli/node-cli/daemon.js +2 -2
- package/dist/cli/node-cli/register.js +1 -1
- package/dist/cli/nodes-camera.js +3 -1
- package/dist/cli/nodes-canvas.js +3 -1
- package/dist/cli/nodes-cli/register.canvas.js +1 -1
- package/dist/cli/nodes-cli/register.js +1 -1
- package/dist/cli/nodes-screen.js +1 -1
- package/dist/cli/pairing-cli.js +3 -3
- package/dist/cli/plugin-registry.js +2 -2
- package/dist/cli/plugins-cli.js +3 -3
- package/dist/cli/profile.js +2 -2
- package/dist/cli/program/command-registry.js +5 -0
- package/dist/cli/program/config-guard.js +1 -1
- package/dist/cli/program/help.js +15 -16
- package/dist/cli/program/message/register.send.js +2 -1
- package/dist/cli/program/preaction.js +4 -2
- package/dist/cli/program/register.agent.js +12 -12
- package/dist/cli/program/register.completion.js +355 -0
- package/dist/cli/program/register.configure.js +1 -1
- package/dist/cli/program/register.maintenance.js +4 -4
- package/dist/cli/program/register.message.js +5 -5
- package/dist/cli/program/register.onboard.js +5 -3
- package/dist/cli/program/register.setup.js +2 -2
- package/dist/cli/program/register.status-health-sessions.js +13 -13
- package/dist/cli/run-main.js +11 -4
- package/dist/cli/sandbox-cli.js +19 -19
- package/dist/cli/security-cli.js +18 -8
- package/dist/cli/skills-cli.js +3 -3
- package/dist/cli/system-cli.js +1 -1
- package/dist/cli/tagline.js +1 -1
- package/dist/cli/tui-cli.js +1 -1
- package/dist/cli/update-cli.js +58 -42
- package/dist/cli/webhooks-cli.js +6 -6
- package/dist/commands/agent-via-gateway.js +1 -1
- package/dist/commands/agent.js +2 -1
- package/dist/commands/agents.command-shared.js +1 -1
- package/dist/commands/agents.commands.add.js +2 -3
- package/dist/commands/agents.commands.list.js +1 -1
- package/dist/commands/auth-choice-options.js +4 -54
- package/dist/commands/auth-choice.apply.anthropic.js +6 -109
- package/dist/commands/auth-choice.apply.openai.js +1 -33
- package/dist/commands/auth-choice.apply.plugin-provider.js +2 -2
- package/dist/commands/channels/list.js +2 -2
- package/dist/commands/channels/shared.js +1 -1
- package/dist/commands/channels/status.js +1 -1
- package/dist/commands/chutes-oauth.js +1 -1
- package/dist/commands/configure.channels.js +4 -4
- package/dist/commands/configure.gateway-auth.js +1 -8
- package/dist/commands/configure.gateway.js +1 -10
- package/dist/commands/configure.wizard.js +11 -11
- package/dist/commands/daemon-install-helpers.js +1 -1
- package/dist/commands/dashboard.js +1 -1
- package/dist/commands/docs.js +5 -5
- package/dist/commands/doctor-auth.js +122 -3
- package/dist/commands/doctor-config-flow.js +7 -7
- package/dist/commands/doctor-format.js +2 -2
- package/dist/commands/doctor-gateway-daemon-flow.js +1 -1
- package/dist/commands/doctor-gateway-services.js +3 -3
- package/dist/commands/doctor-platform-notes.js +1 -1
- package/dist/commands/doctor-security.js +48 -1
- package/dist/commands/doctor-state-integrity.js +3 -3
- package/dist/commands/doctor-ui.js +2 -2
- package/dist/commands/doctor-update.js +4 -4
- package/dist/commands/doctor-workspace-status.js +2 -2
- package/dist/commands/doctor-workspace.js +4 -4
- package/dist/commands/doctor.js +13 -12
- package/dist/commands/gateway-status.js +2 -2
- package/dist/commands/models/auth.js +23 -22
- package/dist/commands/models/list.probe.js +2 -2
- package/dist/commands/models/list.registry.js +4 -4
- package/dist/commands/models/list.status-command.js +8 -9
- package/dist/commands/onboard-auth.credentials.js +2 -2
- package/dist/commands/onboard-channels.js +3 -3
- package/dist/commands/onboard-helpers.js +4 -4
- package/dist/commands/onboard-hooks.js +4 -4
- package/dist/commands/onboard-non-interactive/local/auth-choice.js +38 -34
- package/dist/commands/onboard-non-interactive/local/gateway-config.js +7 -4
- package/dist/commands/onboard-non-interactive/local.js +1 -1
- package/dist/commands/onboard-non-interactive/remote.js +1 -1
- package/dist/commands/onboard-non-interactive.js +1 -1
- package/dist/commands/onboard-remote.js +2 -2
- package/dist/commands/onboard-skills.js +2 -2
- package/dist/commands/onboard.js +25 -4
- package/dist/commands/onboarding/plugin-install.js +2 -2
- package/dist/commands/reset.js +3 -3
- package/dist/commands/sandbox-display.js +1 -1
- package/dist/commands/sandbox-explain.js +2 -2
- package/dist/commands/setup.js +2 -2
- package/dist/commands/signal-install.js +2 -2
- package/dist/commands/status-all/diagnosis.js +1 -1
- package/dist/commands/status-all/report-lines.js +1 -1
- package/dist/commands/status-all.js +3 -3
- package/dist/commands/status.command.js +9 -9
- package/dist/commands/status.update.js +3 -3
- package/dist/commands/uninstall.js +4 -4
- package/dist/compat/legacy-names.js +5 -0
- package/dist/config/config.js +1 -1
- package/dist/config/group-policy.js +69 -0
- package/dist/config/io.js +17 -5
- package/dist/config/legacy.migrations.part-3.js +3 -0
- package/dist/config/logging.js +3 -3
- package/dist/config/paths.js +44 -14
- package/dist/config/schema.js +23 -11
- package/dist/config/sessions/transcript.js +1 -1
- package/dist/config/types.js +1 -1
- package/dist/config/types.poolbot.js +1 -0
- package/dist/config/validation.js +2 -2
- package/dist/config/version.js +4 -4
- package/dist/config/zod-schema.agent-defaults.js +1 -0
- package/dist/config/zod-schema.agent-runtime.js +39 -7
- package/dist/config/zod-schema.hooks.js +2 -0
- package/dist/config/zod-schema.js +9 -3
- package/dist/config/zod-schema.providers-core.js +23 -0
- package/dist/config/zod-schema.providers-whatsapp.js +3 -0
- package/dist/control-ui/assets/index-CIRDm-Lu.css +1 -0
- package/dist/control-ui/assets/{index-Cl-Y9zqE.js → index-CmNMuoem.js} +620 -578
- package/dist/control-ui/assets/index-CmNMuoem.js.map +1 -0
- package/dist/control-ui/index.html +4 -4
- package/dist/cron/isolated-agent/run.js +38 -3
- package/dist/daemon/constants.js +16 -16
- package/dist/daemon/inspect.js +12 -12
- package/dist/daemon/paths.js +1 -1
- package/dist/daemon/program-args.js +1 -1
- package/dist/daemon/systemd-hints.js +1 -1
- package/dist/daemon/systemd-unit.js +1 -1
- package/dist/discord/monitor/listeners.js +25 -1
- package/dist/discord/monitor/native-command.js +7 -5
- package/dist/discord/monitor/presence-cache.js +38 -0
- package/dist/discord/monitor/provider.js +21 -7
- package/dist/entry.js +4 -4
- package/dist/gateway/auth.js +52 -19
- package/dist/gateway/hooks/index.js +53 -0
- package/dist/gateway/hooks/lifecycle-hooks-integration.js +256 -0
- package/dist/gateway/hooks/lifecycle-hooks.js +236 -0
- package/dist/gateway/hooks/progressive-disclosure-details.js +237 -0
- package/dist/gateway/hooks/progressive-disclosure-index.js +354 -0
- package/dist/gateway/hooks/progressive-disclosure-timeline.js +231 -0
- package/dist/gateway/hooks/progressive-disclosure-types.js +65 -0
- package/dist/gateway/hooks/progressive-disclosure.js +242 -0
- package/dist/gateway/hooks/tool-usage-capture.js +253 -0
- package/dist/gateway/hooks/tool-usage-storage.js +144 -0
- package/dist/gateway/hooks-mapping.js +18 -4
- package/dist/gateway/hooks.js +5 -7
- package/dist/gateway/http-utils.js +3 -5
- package/dist/gateway/net.js +1 -1
- package/dist/gateway/openai-http.js +3 -3
- package/dist/gateway/openresponses-http.js +4 -4
- package/dist/gateway/protocol/client-info.js +5 -5
- package/dist/gateway/protocol/schema/logs-chat.js +1 -1
- package/dist/gateway/server/health-state.js +3 -3
- package/dist/gateway/server/hooks.js +1 -0
- package/dist/gateway/server/ws-connection/message-handler.js +44 -35
- package/dist/gateway/server-browser.js +14 -3
- package/dist/gateway/server-chat.js +28 -2
- package/dist/gateway/server-discovery-runtime.js +25 -17
- package/dist/gateway/server-discovery.js +5 -5
- package/dist/gateway/server-http.js +9 -3
- package/dist/gateway/server-methods/agent.js +2 -0
- package/dist/gateway/server-methods/browser.js +204 -0
- package/dist/gateway/server-methods/chat.js +5 -0
- package/dist/gateway/server-methods/config.js +8 -8
- package/dist/gateway/server-methods/logs.js +1 -1
- package/dist/gateway/server-methods/nodes.js +2 -0
- package/dist/gateway/server-methods/skills.js +3 -3
- package/dist/gateway/server-methods/update.js +2 -2
- package/dist/gateway/server-methods-list.js +1 -0
- package/dist/gateway/server-methods.js +3 -0
- package/dist/gateway/server-plugins.js +2 -2
- package/dist/gateway/server-restart-sentinel.js +10 -5
- package/dist/gateway/server-runtime-config.js +5 -2
- package/dist/gateway/server.impl.js +11 -6
- package/dist/gateway/session-utils.fs.js +1 -1
- package/dist/gateway/session-utils.js +31 -11
- package/dist/gateway/test-helpers.mocks.js +5 -5
- package/dist/gateway/test-helpers.server.js +30 -11
- package/dist/gateway/tools-invoke-http.js +15 -8
- package/dist/hooks/bundled/boot-md/HOOK.md +3 -3
- package/dist/hooks/bundled/command-logger/HOOK.md +12 -12
- package/dist/hooks/bundled/command-logger/handler.js +1 -1
- package/dist/hooks/bundled/session-memory/HOOK.md +4 -4
- package/dist/hooks/bundled/session-memory/handler.js +2 -2
- package/dist/hooks/bundled/soul-evil/HOOK.md +5 -5
- package/dist/hooks/bundled-dir.js +1 -1
- package/dist/hooks/config.js +8 -7
- package/dist/hooks/frontmatter.js +16 -15
- package/dist/hooks/gmail-ops.js +4 -4
- package/dist/hooks/hooks-status.js +13 -13
- package/dist/hooks/install.js +8 -7
- package/dist/hooks/internal-hooks.js +1 -1
- package/dist/hooks/llm-slug-generator.js +1 -1
- package/dist/hooks/loader.js +3 -3
- package/dist/hooks/plugin-hooks.js +8 -8
- package/dist/hooks/workspace.js +10 -9
- package/dist/imessage/monitor/monitor-provider.js +16 -3
- package/dist/index.js +4 -4
- package/dist/infra/agent-events.js +3 -0
- package/dist/infra/bonjour-discovery.js +9 -9
- package/dist/infra/bonjour.js +19 -12
- package/dist/infra/device-identity.js +1 -1
- package/dist/infra/dotenv.js +1 -1
- package/dist/infra/exec-approvals.js +2 -2
- package/dist/infra/fs-safe.js +76 -0
- package/dist/infra/gateway-lock.js +1 -1
- package/dist/infra/heartbeat-visibility.js +14 -0
- package/dist/infra/heartbeat-wake.js +2 -2
- package/dist/infra/machine-name.js +1 -1
- package/dist/infra/net/ssrf.js +77 -1
- package/dist/infra/outbound/message-action-spec.js +1 -0
- package/dist/infra/outbound/targets.js +1 -1
- package/dist/infra/path-env.js +7 -7
- package/dist/infra/{clawdbot-root.js → poolbot-root.js} +3 -2
- package/dist/infra/ports-format.js +2 -2
- package/dist/infra/ports.js +2 -2
- package/dist/infra/provider-usage.auth.js +2 -4
- package/dist/infra/provider-usage.fetch.claude.js +1 -1
- package/dist/infra/provider-usage.fetch.minimax.js +1 -1
- package/dist/infra/restart-sentinel.js +1 -1
- package/dist/infra/restart.js +1 -1
- package/dist/infra/retry-policy.js +4 -1
- package/dist/infra/runtime-guard.js +2 -2
- package/dist/infra/shell-env.js +1 -1
- package/dist/infra/skills-remote.js +3 -3
- package/dist/infra/tailscale.js +63 -1
- package/dist/infra/tls/gateway.js +1 -1
- package/dist/infra/unhandled-rejections.js +89 -2
- package/dist/infra/update-check.js +2 -4
- package/dist/infra/update-global.js +5 -5
- package/dist/infra/update-runner.js +32 -8
- package/dist/infra/update-startup.js +3 -3
- package/dist/infra/warnings.js +1 -1
- package/dist/infra/widearea-dns.js +10 -10
- package/dist/line/monitor.js +1 -5
- package/dist/line/signature.js +11 -0
- package/dist/line/webhook.js +2 -6
- package/dist/logging/logger.js +4 -4
- package/dist/macos/gateway-daemon.js +2 -2
- package/dist/macos/relay.js +4 -4
- package/dist/media/host.js +1 -1
- package/dist/media/image-ops.js +1 -1
- package/dist/media/input-files.js +40 -32
- package/dist/media/server.js +39 -15
- package/dist/media/store.js +109 -53
- package/dist/media-understanding/attachments.js +1 -1
- package/dist/media-understanding/providers/image.js +2 -2
- package/dist/media-understanding/runner.js +33 -1
- package/dist/memory/batch-gemini.js +1 -1
- package/dist/memory/batch-openai.js +1 -1
- package/dist/memory/embeddings.js +1 -1
- package/dist/memory/index.js +5 -0
- package/dist/memory/manager.js +25 -2
- package/dist/node-host/runner.js +60 -56
- package/dist/pairing/pairing-messages.js +2 -2
- package/dist/plugin-sdk/index.js +1 -0
- package/dist/plugins/cli.js +2 -2
- package/dist/plugins/discovery.js +6 -5
- package/dist/plugins/install.js +8 -7
- package/dist/plugins/loader.js +10 -4
- package/dist/plugins/manifest-registry.js +2 -2
- package/dist/plugins/manifest.js +16 -1
- package/dist/plugins/providers.js +2 -2
- package/dist/plugins/registry.js +5 -5
- package/dist/plugins/runtime.js +1 -1
- package/dist/plugins/services.js +3 -3
- package/dist/plugins/status.js +2 -2
- package/dist/plugins/tools.js +2 -2
- package/dist/plugins/update.js +3 -3
- package/dist/providers/qwen-portal-oauth.js +1 -1
- package/dist/routing/session-key.js +17 -12
- package/dist/security/audit-extra.js +116 -69
- package/dist/security/audit-fs.js +78 -0
- package/dist/security/audit.js +121 -88
- package/dist/security/external-content.js +143 -0
- package/dist/security/fix.js +93 -8
- package/dist/security/windows-acl.js +162 -0
- package/dist/slack/monitor/media.js +32 -4
- package/dist/slack/monitor/message-handler/dispatch.js +2 -1
- package/dist/slack/monitor/slash.js +3 -3
- package/dist/slack/monitor.test-helpers.js +1 -1
- package/dist/telegram/api-logging.js +24 -0
- package/dist/telegram/bot/delivery.js +139 -22
- package/dist/telegram/bot-handlers.js +70 -8
- package/dist/telegram/bot-message-context.js +79 -21
- package/dist/telegram/bot-message-dispatch.js +64 -0
- package/dist/telegram/bot-native-commands.js +244 -94
- package/dist/telegram/bot.js +18 -2
- package/dist/telegram/fetch.js +25 -1
- package/dist/telegram/monitor.js +11 -3
- package/dist/telegram/network-config.js +23 -0
- package/dist/telegram/network-errors.js +103 -0
- package/dist/telegram/send.js +148 -4
- package/dist/telegram/sticker-cache.js +202 -0
- package/dist/telegram/webhook-set.js +13 -6
- package/dist/telegram/webhook.js +8 -3
- package/dist/terminal/links.js +1 -1
- package/dist/tts/tts.js +27 -22
- package/dist/tui/components/filterable-select-list.js +1 -1
- package/dist/tui/components/searchable-select-list.js +2 -1
- package/dist/tui/gateway-chat.js +1 -1
- package/dist/tui/tui.js +1 -1
- package/dist/utils.js +1 -1
- package/dist/version.js +1 -1
- package/dist/web/active-listener.js +1 -1
- package/dist/web/auth-store.js +1 -1
- package/dist/web/auto-reply/monitor/process-message.js +1 -1
- package/dist/web/auto-reply/monitor.js +1 -1
- package/dist/web/login.js +1 -1
- package/dist/web/session.js +2 -2
- package/dist/wizard/onboarding.finalize.js +24 -21
- package/dist/wizard/onboarding.gateway-config.js +1 -11
- package/dist/wizard/onboarding.js +22 -11
- package/docs/CNAME +1 -1
- package/docs/RELEASE_WORKFLOW.md +133 -0
- package/docs/RELEASE_WORKFOTS_COMPARISON.md +151 -0
- package/docs/WHATSAPP-HEARTBEAT-TROUBLESHOOTING.md +319 -0
- package/docs/WORKFOTS_OPTIMIZATION.md +138 -0
- package/docs/_config.yml +2 -2
- package/docs/_layouts/default.html +9 -9
- package/docs/adr/002-model-fallback-router.md +104 -0
- package/docs/assets/terminal.css +3 -0
- package/docs/assets/theme.js +1 -1
- package/docs/automation/auth-monitoring.md +7 -7
- package/docs/automation/cron-jobs.md +17 -17
- package/docs/automation/cron-vs-heartbeat.md +8 -8
- package/docs/automation/gmail-pubsub.md +23 -21
- package/docs/automation/poll.md +7 -7
- package/docs/automation/webhook.md +13 -8
- package/docs/bedrock.md +10 -10
- package/docs/brave-search.md +1 -1
- package/docs/broadcast-groups.md +4 -4
- package/docs/channels/bluebubbles.md +13 -12
- package/docs/channels/discord.md +21 -16
- package/docs/channels/googlechat.md +16 -16
- package/docs/channels/imessage.md +12 -12
- package/docs/channels/index.md +6 -4
- package/docs/channels/line.md +183 -0
- package/docs/channels/location.md +1 -1
- package/docs/channels/matrix.md +15 -15
- package/docs/channels/mattermost.md +8 -8
- package/docs/channels/msteams.md +30 -26
- package/docs/channels/nextcloud-talk.md +7 -7
- package/docs/channels/nostr.md +9 -9
- package/docs/channels/signal.md +9 -9
- package/docs/channels/slack.md +15 -13
- package/docs/channels/telegram.md +149 -20
- package/docs/channels/tlon.md +5 -5
- package/docs/channels/troubleshooting.md +2 -2
- package/docs/channels/twitch.md +366 -0
- package/docs/channels/whatsapp.md +25 -25
- package/docs/channels/zalo.md +8 -8
- package/docs/channels/zalouser.md +12 -12
- package/docs/cli/acp.md +24 -24
- package/docs/cli/agent.md +6 -6
- package/docs/cli/agents.md +9 -9
- package/docs/cli/approvals.md +14 -14
- package/docs/cli/browser.md +33 -35
- package/docs/cli/channels.md +21 -21
- package/docs/cli/config.md +15 -15
- package/docs/cli/configure.md +6 -6
- package/docs/cli/cron.md +5 -5
- package/docs/cli/dashboard.md +4 -4
- package/docs/cli/devices.md +13 -13
- package/docs/cli/directory.md +12 -12
- package/docs/cli/dns.md +5 -5
- package/docs/cli/docs.md +5 -5
- package/docs/cli/doctor.md +6 -6
- package/docs/cli/gateway.md +24 -24
- package/docs/cli/health.md +5 -5
- package/docs/cli/hooks.md +34 -34
- package/docs/cli/index.md +46 -52
- package/docs/cli/logs.md +6 -6
- package/docs/cli/memory.md +11 -11
- package/docs/cli/message.md +11 -11
- package/docs/cli/models.md +17 -17
- package/docs/cli/node.md +14 -14
- package/docs/cli/nodes.md +14 -14
- package/docs/cli/onboard.md +7 -6
- package/docs/cli/pairing.md +4 -4
- package/docs/cli/plugins.md +16 -16
- package/docs/cli/reset.md +5 -5
- package/docs/cli/sandbox.md +28 -28
- package/docs/cli/security.md +5 -5
- package/docs/cli/sessions.md +5 -5
- package/docs/cli/setup.md +6 -6
- package/docs/cli/skills.md +6 -6
- package/docs/cli/status.md +7 -7
- package/docs/cli/system.md +6 -6
- package/docs/cli/tui.md +5 -5
- package/docs/cli/uninstall.md +5 -5
- package/docs/cli/update.md +20 -20
- package/docs/cli/voicecall.md +9 -9
- package/docs/cli/webhooks.md +5 -5
- package/docs/concepts/agent-loop.md +5 -5
- package/docs/concepts/agent-workspace.md +20 -20
- package/docs/concepts/agent.md +12 -12
- package/docs/concepts/architecture.md +1 -1
- package/docs/concepts/channel-routing.md +4 -4
- package/docs/concepts/compaction.md +5 -5
- package/docs/concepts/context.md +6 -6
- package/docs/concepts/group-messages.md +6 -6
- package/docs/concepts/groups.md +41 -5
- package/docs/concepts/markdown-formatting.md +3 -3
- package/docs/concepts/memory.md +14 -14
- package/docs/concepts/messages.md +4 -4
- package/docs/concepts/model-failover.md +14 -14
- package/docs/concepts/model-providers.md +22 -22
- package/docs/concepts/models.md +27 -27
- package/docs/concepts/multi-agent.md +18 -18
- package/docs/concepts/oauth.md +31 -58
- package/docs/concepts/presence.md +2 -2
- package/docs/concepts/retry.md +1 -1
- package/docs/concepts/session-pruning.md +1 -1
- package/docs/concepts/session-tool.md +4 -4
- package/docs/concepts/session.md +14 -14
- package/docs/concepts/streaming.md +3 -3
- package/docs/concepts/system-prompt.md +11 -11
- package/docs/concepts/timezone.md +2 -2
- package/docs/concepts/typebox.md +2 -2
- package/docs/concepts/typing-indicators.md +2 -2
- package/docs/concepts/usage-tracking.md +3 -3
- package/docs/date-time.md +2 -2
- package/docs/debug/node-issue.md +4 -4
- package/docs/debugging.md +14 -14
- package/docs/diagnostics/flags.md +5 -5
- package/docs/docs.json +37 -7
- package/docs/environment.md +4 -4
- package/docs/experiments/plans/cron-add-hardening.md +1 -1
- package/docs/experiments/plans/openresponses-gateway.md +2 -2
- package/docs/experiments/research/memory.md +6 -6
- package/docs/gateway/authentication.md +33 -57
- package/docs/gateway/background-process.md +1 -1
- package/docs/gateway/bonjour.md +21 -21
- package/docs/gateway/bridge-protocol.md +2 -2
- package/docs/gateway/cli-backends.md +13 -12
- package/docs/gateway/configuration-examples.md +14 -14
- package/docs/gateway/configuration.md +145 -132
- package/docs/gateway/discovery.md +6 -6
- package/docs/gateway/doctor.md +26 -26
- package/docs/gateway/gateway-lock.md +1 -1
- package/docs/gateway/health.md +11 -11
- package/docs/gateway/heartbeat.md +5 -5
- package/docs/gateway/index.md +56 -56
- package/docs/gateway/local-models.md +2 -2
- package/docs/gateway/logging.md +8 -8
- package/docs/gateway/multiple-gateways.md +23 -23
- package/docs/gateway/openai-http-api.md +10 -10
- package/docs/gateway/openresponses-http-api.md +10 -10
- package/docs/gateway/pairing.md +8 -8
- package/docs/gateway/protocol.md +5 -4
- package/docs/gateway/remote-gateway-readme.md +13 -13
- package/docs/gateway/remote.md +4 -4
- package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +10 -7
- package/docs/gateway/sandboxing.md +8 -6
- package/docs/gateway/security/formal-verification.md +107 -0
- package/docs/gateway/{security.md → security/index.md} +151 -71
- package/docs/gateway/tailscale.md +16 -35
- package/docs/gateway/tools-invoke-http-api.md +3 -3
- package/docs/gateway/troubleshooting.md +108 -113
- package/docs/help/faq.md +326 -335
- package/docs/help/troubleshooting.md +15 -15
- package/docs/hooks/soul-evil.md +2 -2
- package/docs/hooks.md +60 -60
- package/docs/index.md +35 -35
- package/docs/install/ansible.md +35 -35
- package/docs/install/development-channels.md +10 -10
- package/docs/install/docker.md +31 -31
- package/docs/install/index.md +28 -27
- package/docs/install/installer.md +21 -21
- package/docs/install/migrating.md +190 -0
- package/docs/install/nix.md +17 -17
- package/docs/install/node.md +7 -6
- package/docs/install/uninstall.md +29 -29
- package/docs/install/updating.md +50 -49
- package/docs/logging.md +58 -58
- package/docs/multi-agent-sandbox-tools.md +7 -7
- package/docs/network.md +1 -1
- package/docs/nodes/audio.md +2 -2
- package/docs/nodes/camera.md +18 -18
- package/docs/nodes/images.md +4 -4
- package/docs/nodes/index.md +55 -55
- package/docs/nodes/location-command.md +2 -2
- package/docs/nodes/media-understanding.md +5 -5
- package/docs/nodes/talk.md +1 -1
- package/docs/nodes/voicewake.md +2 -2
- package/docs/northflank.mdx +53 -0
- package/docs/perplexity.md +2 -2
- package/docs/platforms/android.md +13 -13
- package/docs/platforms/digitalocean.md +243 -0
- package/docs/platforms/exe-dev.md +23 -23
- package/docs/platforms/fly.md +129 -18
- package/docs/platforms/gcp.md +498 -0
- package/docs/platforms/hetzner.md +30 -30
- package/docs/platforms/index.md +9 -9
- package/docs/platforms/ios.md +13 -13
- package/docs/platforms/linux.md +11 -11
- package/docs/platforms/mac/bundled-gateway.md +14 -14
- package/docs/platforms/mac/canvas.md +14 -14
- package/docs/platforms/mac/child-process.md +9 -9
- package/docs/platforms/mac/dev-setup.md +11 -11
- package/docs/platforms/mac/health.md +2 -2
- package/docs/platforms/mac/icon.md +1 -1
- package/docs/platforms/mac/logging.md +7 -7
- package/docs/platforms/mac/menu-bar.md +1 -1
- package/docs/platforms/mac/peekaboo.md +9 -9
- package/docs/platforms/mac/permissions.md +3 -3
- package/docs/platforms/mac/release.md +20 -20
- package/docs/platforms/mac/remote.md +14 -14
- package/docs/platforms/mac/signing.md +7 -7
- package/docs/platforms/mac/skills.md +4 -4
- package/docs/platforms/mac/voice-overlay.md +2 -2
- package/docs/platforms/mac/webchat.md +2 -2
- package/docs/platforms/mac/xpc.md +4 -4
- package/docs/platforms/macos-vm.md +27 -27
- package/docs/platforms/macos.md +20 -20
- package/docs/platforms/oracle.md +291 -0
- package/docs/platforms/raspberry-pi.md +354 -0
- package/docs/platforms/windows.md +11 -11
- package/docs/plugin.md +64 -64
- package/docs/plugins/agent-tools.md +1 -1
- package/docs/plugins/manifest.md +4 -4
- package/docs/plugins/voice-call.md +15 -12
- package/docs/plugins/zalouser.md +9 -9
- package/docs/prose.md +9 -9
- package/docs/providers/anthropic.md +23 -27
- package/docs/providers/claude-max-api-proxy.md +145 -0
- package/docs/providers/deepgram.md +2 -2
- package/docs/providers/github-copilot.md +11 -11
- package/docs/providers/glm.md +4 -4
- package/docs/providers/index.md +7 -3
- package/docs/providers/minimax.md +9 -9
- package/docs/providers/models.md +3 -3
- package/docs/providers/moonshot.md +2 -2
- package/docs/providers/ollama.md +11 -11
- package/docs/providers/openai.md +9 -13
- package/docs/providers/opencode.md +3 -3
- package/docs/providers/openrouter.md +3 -3
- package/docs/providers/qwen.md +6 -6
- package/docs/providers/synthetic.md +4 -4
- package/docs/providers/venice.md +21 -21
- package/docs/providers/vercel-ai-gateway.md +5 -4
- package/docs/providers/zai.md +5 -5
- package/docs/railway.mdx +5 -5
- package/docs/refactor/exec-host.md +5 -5
- package/docs/refactor/plugin-sdk.md +12 -12
- package/docs/refactor/strict-config.md +11 -11
- package/docs/reference/AGENTS.default.md +10 -10
- package/docs/reference/RELEASING.md +27 -27
- package/docs/reference/api-usage-costs.md +6 -6
- package/docs/reference/device-models.md +7 -7
- package/docs/reference/rpc.md +3 -3
- package/docs/reference/session-management-compaction.md +19 -19
- package/docs/reference/templates/AGENTS.dev.md +1 -1
- package/docs/reference/templates/BOOT.md +1 -1
- package/docs/reference/templates/TOOLS.dev.md +1 -1
- package/docs/reference/templates/USER.dev.md +2 -2
- package/docs/reference/test.md +2 -2
- package/docs/reference/transcript-hygiene.md +1 -1
- package/docs/render.mdx +158 -0
- package/docs/scripts.md +1 -1
- package/docs/security/formal-verification.md +107 -0
- package/docs/start/getting-started.md +31 -25
- package/docs/start/hubs.md +2 -2
- package/docs/start/lore.md +74 -38
- package/docs/start/onboarding.md +7 -7
- package/docs/start/pairing.md +10 -10
- package/docs/start/{clawd.md → poolbot.md} +29 -29
- package/docs/start/setup.md +30 -17
- package/docs/start/showcase.md +32 -32
- package/docs/start/wizard.md +29 -26
- package/docs/testing.md +12 -12
- package/docs/token-use.md +7 -7
- package/docs/tools/agent-send.md +10 -10
- package/docs/tools/browser-linux-troubleshooting.md +10 -10
- package/docs/tools/browser-login.md +4 -4
- package/docs/tools/browser.md +135 -241
- package/docs/tools/chrome-extension.md +31 -48
- package/docs/tools/creating-skills.md +4 -4
- package/docs/tools/elevated.md +1 -0
- package/docs/tools/exec-approvals.md +8 -5
- package/docs/tools/exec.md +15 -4
- package/docs/tools/firecrawl.md +2 -2
- package/docs/tools/index.md +18 -15
- package/docs/tools/llm-task.md +1 -1
- package/docs/tools/lobster.md +23 -11
- package/docs/tools/{clawdhub.md → poolhub.md} +7 -7
- package/docs/tools/skills-config.md +2 -2
- package/docs/tools/skills.md +39 -31
- package/docs/tools/slash-commands.md +10 -8
- package/docs/tools/web.md +8 -8
- package/docs/tts.md +11 -11
- package/docs/tui.md +7 -7
- package/docs/vps.md +6 -1
- package/docs/web/control-ui.md +13 -12
- package/docs/web/dashboard.md +8 -4
- package/docs/web/index.md +6 -5
- package/docs/web/webchat.md +1 -1
- package/extensions/bluebubbles/index.ts +3 -3
- package/extensions/bluebubbles/package.json +5 -5
- package/extensions/bluebubbles/src/accounts.ts +9 -9
- package/extensions/bluebubbles/src/actions.test.ts +22 -22
- package/extensions/bluebubbles/src/actions.ts +6 -6
- package/extensions/bluebubbles/src/attachments.ts +2 -2
- package/extensions/bluebubbles/src/channel.ts +17 -17
- package/extensions/bluebubbles/src/chat.ts +2 -2
- package/extensions/bluebubbles/src/config-schema.ts +1 -1
- package/extensions/bluebubbles/src/media-send.ts +2 -2
- package/extensions/bluebubbles/src/monitor.test.ts +56 -50
- package/extensions/bluebubbles/src/monitor.ts +181 -6
- package/extensions/bluebubbles/src/onboarding.ts +9 -9
- package/extensions/bluebubbles/src/reactions.ts +2 -2
- package/extensions/bluebubbles/src/runtime.ts +1 -1
- package/extensions/bluebubbles/src/send.ts +2 -2
- package/extensions/copilot-proxy/README.md +2 -2
- package/extensions/copilot-proxy/index.ts +1 -1
- package/extensions/copilot-proxy/package.json +4 -4
- package/extensions/diagnostics-otel/index.ts +3 -3
- package/extensions/diagnostics-otel/package.json +4 -4
- package/extensions/diagnostics-otel/src/service.test.ts +15 -15
- package/extensions/diagnostics-otel/src/service.ts +85 -85
- package/extensions/discord/index.ts +3 -3
- package/extensions/discord/package.json +4 -4
- package/extensions/discord/src/channel.ts +1 -1
- package/extensions/discord/src/runtime.ts +1 -1
- package/extensions/google-antigravity-auth/README.md +2 -2
- package/extensions/google-antigravity-auth/index.ts +9 -2
- package/extensions/google-antigravity-auth/package.json +4 -4
- package/extensions/google-gemini-cli-auth/README.md +2 -2
- package/extensions/google-gemini-cli-auth/index.ts +1 -1
- package/extensions/google-gemini-cli-auth/oauth.ts +2 -2
- package/extensions/google-gemini-cli-auth/package.json +4 -4
- package/extensions/googlechat/index.ts +4 -4
- package/extensions/googlechat/node_modules/.bin/poolbot +21 -0
- package/extensions/googlechat/package.json +7 -7
- package/extensions/googlechat/src/accounts.ts +9 -9
- package/extensions/googlechat/src/actions.ts +8 -8
- package/extensions/googlechat/src/api.ts +1 -1
- package/extensions/googlechat/src/channel.ts +23 -23
- package/extensions/googlechat/src/monitor.ts +9 -9
- package/extensions/googlechat/src/onboarding.ts +11 -11
- package/extensions/googlechat/src/runtime.ts +1 -1
- package/extensions/googlechat/src/types.config.ts +1 -1
- package/extensions/imessage/index.ts +3 -3
- package/extensions/imessage/package.json +4 -4
- package/extensions/imessage/src/channel.ts +1 -1
- package/extensions/imessage/src/runtime.ts +1 -1
- package/extensions/line/index.ts +3 -3
- package/extensions/line/node_modules/.bin/poolbot +21 -0
- package/extensions/line/package.json +6 -6
- package/extensions/line/src/card-command.ts +3 -3
- package/extensions/line/src/channel.logout.test.ts +4 -4
- package/extensions/line/src/channel.sendPayload.test.ts +8 -8
- package/extensions/line/src/channel.ts +5 -5
- package/extensions/line/src/runtime.ts +1 -1
- package/extensions/llm-task/README.md +1 -1
- package/extensions/llm-task/index.ts +2 -2
- package/extensions/llm-task/package.json +4 -4
- package/extensions/llm-task/src/llm-task-tool.ts +5 -5
- package/extensions/lobster/index.ts +2 -2
- package/extensions/lobster/package.json +3 -3
- package/extensions/lobster/src/lobster-tool.test.ts +26 -6
- package/extensions/lobster/src/lobster-tool.ts +24 -6
- package/extensions/matrix/CHANGELOG.md +9 -9
- package/extensions/matrix/index.ts +3 -3
- package/extensions/matrix/node_modules/.bin/markdown-it +0 -0
- package/extensions/matrix/node_modules/.bin/poolbot +21 -0
- package/extensions/matrix/package.json +7 -7
- package/extensions/matrix/src/actions.ts +1 -1
- package/extensions/matrix/src/channel.directory.test.ts +1 -1
- package/extensions/matrix/src/channel.ts +1 -1
- package/extensions/matrix/src/config-schema.ts +1 -1
- package/extensions/matrix/src/directory-live.ts +1 -1
- package/extensions/matrix/src/group-mentions.ts +1 -1
- package/extensions/matrix/src/matrix/accounts.ts +1 -1
- package/extensions/matrix/src/matrix/actions/messages.ts +1 -1
- package/extensions/matrix/src/matrix/actions/reactions.ts +1 -1
- package/extensions/matrix/src/matrix/actions/room.ts +3 -3
- package/extensions/matrix/src/matrix/actions/summary.ts +1 -1
- package/extensions/matrix/src/matrix/actions/types.ts +1 -1
- package/extensions/matrix/src/matrix/active-client.ts +1 -1
- package/extensions/matrix/src/matrix/client/config.ts +2 -2
- package/extensions/matrix/src/matrix/client/create-client.ts +2 -2
- package/extensions/matrix/src/matrix/client/logging.ts +1 -1
- package/extensions/matrix/src/matrix/client/shared.ts +3 -3
- package/extensions/matrix/src/matrix/deps.ts +5 -5
- package/extensions/matrix/src/matrix/monitor/allowlist.ts +1 -1
- package/extensions/matrix/src/matrix/monitor/auto-join.ts +3 -3
- package/extensions/matrix/src/matrix/monitor/direct.ts +1 -1
- package/extensions/matrix/src/matrix/monitor/events.ts +2 -2
- package/extensions/matrix/src/matrix/monitor/handler.ts +8 -8
- package/extensions/matrix/src/matrix/monitor/index.ts +2 -2
- package/extensions/matrix/src/matrix/monitor/location.ts +2 -2
- package/extensions/matrix/src/matrix/monitor/media.test.ts +3 -3
- package/extensions/matrix/src/matrix/monitor/media.ts +3 -3
- package/extensions/matrix/src/matrix/monitor/replies.ts +2 -2
- package/extensions/matrix/src/matrix/monitor/room-info.ts +1 -1
- package/extensions/matrix/src/matrix/monitor/rooms.ts +1 -1
- package/extensions/matrix/src/matrix/monitor/threads.ts +1 -1
- package/extensions/matrix/src/matrix/monitor/types.ts +1 -1
- package/extensions/matrix/src/matrix/poll-types.ts +1 -1
- package/extensions/matrix/src/matrix/probe.ts +1 -1
- package/extensions/matrix/src/matrix/send/client.ts +2 -2
- package/extensions/matrix/src/matrix/send/media.ts +1 -1
- package/extensions/matrix/src/matrix/send/targets.test.ts +1 -1
- package/extensions/matrix/src/matrix/send/targets.ts +1 -1
- package/extensions/matrix/src/matrix/send/types.ts +2 -2
- package/extensions/matrix/src/matrix/send.test.ts +3 -3
- package/extensions/matrix/src/matrix/send.ts +4 -4
- package/extensions/matrix/src/onboarding.ts +3 -3
- package/extensions/matrix/src/outbound.ts +1 -1
- package/extensions/matrix/src/resolve-targets.ts +1 -1
- package/extensions/matrix/src/runtime.ts +1 -1
- package/extensions/matrix/src/tool-actions.ts +1 -1
- package/extensions/matrix/src/types.ts +1 -1
- package/extensions/mattermost/index.ts +3 -3
- package/extensions/mattermost/package.json +5 -5
- package/extensions/mattermost/src/channel.ts +1 -1
- package/extensions/mattermost/src/config-schema.ts +1 -1
- package/extensions/mattermost/src/group-mentions.ts +1 -1
- package/extensions/mattermost/src/mattermost/accounts.ts +9 -9
- package/extensions/mattermost/src/mattermost/monitor-helpers.ts +5 -5
- package/extensions/mattermost/src/mattermost/monitor.ts +4 -4
- package/extensions/mattermost/src/onboarding-helpers.ts +4 -4
- package/extensions/mattermost/src/onboarding.ts +4 -4
- package/extensions/mattermost/src/runtime.ts +1 -1
- package/extensions/mattermost/src/types.ts +1 -1
- package/extensions/memory-core/index.ts +3 -3
- package/extensions/memory-core/node_modules/.bin/poolbot +21 -0
- package/extensions/memory-core/package.json +5 -5
- package/extensions/memory-lancedb/config.ts +2 -2
- package/extensions/memory-lancedb/index.test.ts +2 -2
- package/extensions/memory-lancedb/index.ts +4 -4
- package/extensions/memory-lancedb/node_modules/.bin/openai +0 -0
- package/extensions/memory-lancedb/package.json +4 -4
- package/extensions/memory-lancedb/{clawdbot.plugin.json → poolbot.plugin.json} +1 -1
- package/extensions/msteams/CHANGELOG.md +7 -7
- package/extensions/msteams/index.ts +3 -3
- package/extensions/msteams/node_modules/.bin/poolbot +21 -0
- package/extensions/msteams/package.json +6 -6
- package/extensions/msteams/src/attachments.test.ts +1 -1
- package/extensions/msteams/src/channel.directory.test.ts +2 -2
- package/extensions/msteams/src/channel.ts +3 -3
- package/extensions/msteams/src/conversation-store-fs.test.ts +3 -3
- package/extensions/msteams/src/directory-live.ts +1 -1
- package/extensions/msteams/src/graph-upload.ts +4 -4
- package/extensions/msteams/src/media-helpers.ts +1 -1
- package/extensions/msteams/src/messenger.test.ts +1 -1
- package/extensions/msteams/src/messenger.ts +1 -1
- package/extensions/msteams/src/monitor-handler/message-handler.ts +1 -1
- package/extensions/msteams/src/monitor-handler.ts +2 -2
- package/extensions/msteams/src/monitor.ts +3 -3
- package/extensions/msteams/src/onboarding.ts +11 -11
- package/extensions/msteams/src/outbound.ts +1 -1
- package/extensions/msteams/src/policy.test.ts +1 -1
- package/extensions/msteams/src/policy.ts +50 -5
- package/extensions/msteams/src/polls-store.test.ts +1 -1
- package/extensions/msteams/src/polls.test.ts +4 -4
- package/extensions/msteams/src/polls.ts +8 -8
- package/extensions/msteams/src/probe.test.ts +1 -1
- package/extensions/msteams/src/probe.ts +1 -1
- package/extensions/msteams/src/reply-dispatcher.ts +36 -36
- package/extensions/msteams/src/runtime.ts +1 -1
- package/extensions/msteams/src/send-context.ts +2 -2
- package/extensions/msteams/src/send.ts +5 -5
- package/extensions/msteams/src/token.ts +1 -1
- package/extensions/nextcloud-talk/index.ts +3 -3
- package/extensions/nextcloud-talk/package.json +5 -5
- package/extensions/nextcloud-talk/src/accounts.ts +1 -1
- package/extensions/nextcloud-talk/src/channel.ts +8 -8
- package/extensions/nextcloud-talk/src/config-schema.ts +1 -1
- package/extensions/nextcloud-talk/src/inbound.ts +8 -8
- package/extensions/nextcloud-talk/src/monitor.ts +1 -1
- package/extensions/nextcloud-talk/src/onboarding.ts +2 -2
- package/extensions/nextcloud-talk/src/policy.ts +2 -2
- package/extensions/nextcloud-talk/src/room-info.ts +1 -1
- package/extensions/nextcloud-talk/src/runtime.ts +1 -1
- package/extensions/nextcloud-talk/src/types.ts +1 -1
- package/extensions/nostr/CHANGELOG.md +4 -4
- package/extensions/nostr/README.md +3 -3
- package/extensions/nostr/index.ts +6 -6
- package/extensions/nostr/node_modules/.bin/poolbot +21 -0
- package/extensions/nostr/package.json +6 -6
- package/extensions/nostr/src/channel.ts +2 -2
- package/extensions/nostr/src/config-schema.ts +1 -1
- package/extensions/nostr/src/nostr-state-store.test.ts +3 -3
- package/extensions/nostr/src/runtime.ts +1 -1
- package/extensions/nostr/src/types.ts +4 -4
- package/extensions/open-prose/index.ts +2 -2
- package/extensions/open-prose/package.json +3 -3
- package/extensions/open-prose/skills/prose/SKILL.md +5 -5
- package/extensions/open-prose/skills/prose/prose.md +4 -4
- package/extensions/qwen-portal-auth/README.md +2 -2
- package/extensions/qwen-portal-auth/index.ts +1 -1
- package/extensions/signal/index.ts +3 -3
- package/extensions/signal/package.json +4 -4
- package/extensions/signal/src/channel.ts +1 -1
- package/extensions/signal/src/runtime.ts +1 -1
- package/extensions/slack/index.ts +3 -3
- package/extensions/slack/package.json +4 -4
- package/extensions/slack/src/channel.ts +1 -1
- package/extensions/slack/src/runtime.ts +1 -1
- package/extensions/telegram/index.ts +3 -3
- package/extensions/telegram/package.json +4 -4
- package/extensions/telegram/src/channel.ts +3 -3
- package/extensions/telegram/src/runtime.ts +1 -1
- package/extensions/tlon/README.md +1 -1
- package/extensions/tlon/index.ts +3 -3
- package/extensions/tlon/package.json +5 -5
- package/extensions/tlon/src/channel.ts +15 -15
- package/extensions/tlon/src/config-schema.ts +1 -1
- package/extensions/tlon/src/monitor/discovery.ts +1 -1
- package/extensions/tlon/src/monitor/history.ts +1 -1
- package/extensions/tlon/src/monitor/index.ts +3 -3
- package/extensions/tlon/src/onboarding.ts +4 -4
- package/extensions/tlon/src/runtime.ts +1 -1
- package/extensions/tlon/src/types.ts +3 -3
- package/extensions/tlon/src/urbit/send.ts +19 -6
- package/extensions/twitch/CHANGELOG.md +21 -0
- package/extensions/twitch/README.md +89 -0
- package/extensions/twitch/index.ts +20 -0
- package/extensions/twitch/node_modules/.bin/poolbot +21 -0
- package/extensions/twitch/package.json +20 -0
- package/extensions/twitch/poolbot.plugin.json +9 -0
- package/extensions/twitch/src/access-control.test.ts +489 -0
- package/extensions/twitch/src/access-control.ts +154 -0
- package/extensions/twitch/src/actions.ts +173 -0
- package/extensions/twitch/src/client-manager-registry.ts +115 -0
- package/extensions/twitch/src/config-schema.ts +82 -0
- package/extensions/twitch/src/config.test.ts +88 -0
- package/extensions/twitch/src/config.ts +116 -0
- package/extensions/twitch/src/monitor.ts +257 -0
- package/extensions/twitch/src/onboarding.test.ts +311 -0
- package/extensions/twitch/src/onboarding.ts +411 -0
- package/extensions/twitch/src/outbound.test.ts +373 -0
- package/extensions/twitch/src/outbound.ts +186 -0
- package/extensions/twitch/src/plugin.test.ts +39 -0
- package/extensions/twitch/src/plugin.ts +274 -0
- package/extensions/twitch/src/probe.test.ts +198 -0
- package/extensions/twitch/src/probe.ts +118 -0
- package/extensions/twitch/src/resolver.ts +137 -0
- package/extensions/twitch/src/runtime.ts +14 -0
- package/extensions/twitch/src/send.test.ts +289 -0
- package/extensions/twitch/src/send.ts +136 -0
- package/extensions/twitch/src/status.test.ts +270 -0
- package/extensions/twitch/src/status.ts +176 -0
- package/extensions/twitch/src/token.test.ts +171 -0
- package/extensions/twitch/src/token.ts +87 -0
- package/extensions/twitch/src/twitch-client.test.ts +574 -0
- package/extensions/twitch/src/twitch-client.ts +277 -0
- package/extensions/twitch/src/types.ts +141 -0
- package/extensions/twitch/src/utils/markdown.ts +92 -0
- package/extensions/twitch/src/utils/twitch.ts +78 -0
- package/extensions/twitch/test/setup.ts +7 -0
- package/extensions/voice-call/CHANGELOG.md +13 -12
- package/extensions/voice-call/README.md +15 -14
- package/extensions/voice-call/index.ts +11 -9
- package/extensions/voice-call/package.json +4 -4
- package/extensions/voice-call/{clawdbot.plugin.json → poolbot.plugin.json} +3 -3
- package/extensions/voice-call/src/cli.ts +1 -1
- package/extensions/voice-call/src/config.test.ts +204 -0
- package/extensions/voice-call/src/config.ts +61 -4
- package/extensions/voice-call/src/core-bridge.ts +10 -8
- package/extensions/voice-call/src/manager.test.ts +2 -2
- package/extensions/voice-call/src/providers/twilio/webhook.ts +2 -1
- package/extensions/voice-call/src/providers/twilio.ts +2 -2
- package/extensions/voice-call/src/response-generator.ts +1 -1
- package/extensions/voice-call/src/runtime.ts +26 -15
- package/extensions/voice-call/src/types.ts +1 -0
- package/extensions/voice-call/src/webhook-security.test.ts +52 -0
- package/extensions/voice-call/src/webhook-security.ts +16 -5
- package/extensions/voice-call/src/webhook.ts +1 -0
- package/extensions/whatsapp/index.ts +3 -3
- package/extensions/whatsapp/package.json +4 -4
- package/extensions/whatsapp/src/channel.ts +1 -1
- package/extensions/whatsapp/src/runtime.ts +1 -1
- package/extensions/zalo/CHANGELOG.md +9 -9
- package/extensions/zalo/README.md +3 -3
- package/extensions/zalo/index.ts +3 -3
- package/extensions/zalo/node_modules/.bin/poolbot +21 -0
- package/extensions/zalo/package.json +6 -6
- package/extensions/zalo/src/accounts.ts +9 -9
- package/extensions/zalo/src/actions.ts +6 -6
- package/extensions/zalo/src/channel.directory.test.ts +2 -2
- package/extensions/zalo/src/channel.ts +20 -20
- package/extensions/zalo/src/config-schema.ts +1 -1
- package/extensions/zalo/src/monitor.ts +9 -9
- package/extensions/zalo/src/monitor.webhook.test.ts +2 -2
- package/extensions/zalo/src/onboarding.ts +27 -27
- package/extensions/zalo/src/runtime.ts +1 -1
- package/extensions/zalo/src/send.ts +2 -2
- package/extensions/zalo/src/status-issues.ts +1 -1
- package/extensions/zalo/src/token.ts +1 -1
- package/extensions/zalouser/CHANGELOG.md +4 -4
- package/extensions/zalouser/README.md +17 -17
- package/extensions/zalouser/index.ts +3 -3
- package/extensions/zalouser/node_modules/.bin/poolbot +21 -0
- package/extensions/zalouser/package.json +6 -6
- package/extensions/zalouser/src/accounts.ts +10 -10
- package/extensions/zalouser/src/channel.ts +27 -27
- package/extensions/zalouser/src/config-schema.ts +1 -1
- package/extensions/zalouser/src/monitor.ts +5 -5
- package/extensions/zalouser/src/onboarding.ts +32 -32
- package/extensions/zalouser/src/runtime.ts +1 -1
- package/extensions/zalouser/src/status-issues.ts +2 -2
- package/git-hooks/pre-commit +0 -0
- package/package.json +78 -89
- package/skills/1password/SKILL.md +3 -3
- package/skills/apple-notes/SKILL.md +2 -2
- package/skills/apple-reminders/SKILL.md +1 -1
- package/skills/bear-notes/SKILL.md +1 -1
- package/skills/bird/SKILL.md +1 -1
- package/skills/blogwatcher/SKILL.md +1 -1
- package/skills/blucli/SKILL.md +1 -1
- package/skills/bluebubbles/SKILL.md +2 -2
- package/skills/camsnap/SKILL.md +1 -1
- package/skills/canvas/SKILL.md +15 -15
- package/skills/coding-agent/SKILL.md +6 -6
- package/skills/discord/SKILL.md +6 -5
- package/skills/eightctl/SKILL.md +1 -1
- package/skills/food-order/SKILL.md +1 -1
- package/skills/gemini/SKILL.md +1 -1
- package/skills/gifgrep/SKILL.md +1 -1
- package/skills/github/SKILL.md +1 -0
- package/skills/gog/SKILL.md +1 -1
- package/skills/goplaces/SKILL.md +1 -1
- package/skills/himalaya/SKILL.md +1 -1
- package/skills/imsg/SKILL.md +1 -1
- package/skills/local-places/SKILL.md +1 -1
- package/skills/mcporter/SKILL.md +1 -1
- package/skills/model-usage/SKILL.md +1 -1
- package/skills/nano-banana-pro/SKILL.md +10 -5
- package/skills/nano-banana-pro/scripts/generate_image.py +42 -27
- package/skills/nano-pdf/SKILL.md +1 -1
- package/skills/notion/SKILL.md +1 -1
- package/skills/obsidian/SKILL.md +1 -1
- package/skills/openai-image-gen/SKILL.md +1 -1
- package/skills/openai-whisper/SKILL.md +1 -1
- package/skills/openai-whisper-api/SKILL.md +2 -2
- package/skills/openhue/SKILL.md +1 -1
- package/skills/oracle/SKILL.md +1 -1
- package/skills/ordercli/SKILL.md +1 -1
- package/skills/peekaboo/SKILL.md +1 -1
- package/skills/{clawdhub → poolhub}/SKILL.md +2 -2
- package/skills/sag/SKILL.md +1 -1
- package/skills/session-logs/SKILL.md +7 -7
- package/skills/sherpa-onnx-tts/SKILL.md +6 -6
- package/skills/sherpa-onnx-tts/bin/sherpa-onnx-tts +0 -0
- package/skills/slack/SKILL.md +4 -3
- package/skills/songsee/SKILL.md +1 -1
- package/skills/sonoscli/SKILL.md +1 -1
- package/skills/spotify-player/SKILL.md +1 -1
- package/skills/summarize/SKILL.md +1 -1
- package/skills/things-mac/SKILL.md +3 -3
- package/skills/tmux/SKILL.md +7 -7
- package/skills/tmux/scripts/find-sessions.sh +1 -1
- package/skills/tmux/scripts/wait-for-text.sh +0 -0
- package/skills/trello/SKILL.md +2 -2
- package/skills/video-frames/SKILL.md +1 -1
- package/skills/voice-call/SKILL.md +4 -4
- package/skills/wacli/SKILL.md +2 -2
- package/skills/weather/SKILL.md +1 -1
- package/skills/webgpu-threejs-tsl/REFERENCE.md +283 -0
- package/skills/webgpu-threejs-tsl/SKILL.md +91 -0
- package/skills/webgpu-threejs-tsl/docs/compute-shaders.md +404 -0
- package/skills/webgpu-threejs-tsl/docs/core-concepts.md +453 -0
- package/skills/webgpu-threejs-tsl/docs/materials.md +353 -0
- package/skills/webgpu-threejs-tsl/docs/post-processing.md +434 -0
- package/skills/webgpu-threejs-tsl/docs/wgsl-integration.md +324 -0
- package/skills/webgpu-threejs-tsl/examples/basic-setup.js +87 -0
- package/skills/webgpu-threejs-tsl/examples/custom-material.js +170 -0
- package/skills/webgpu-threejs-tsl/examples/earth-shader.js +292 -0
- package/skills/webgpu-threejs-tsl/examples/particle-system.js +259 -0
- package/skills/webgpu-threejs-tsl/examples/post-processing.js +199 -0
- package/skills/webgpu-threejs-tsl/templates/compute-shader.js +305 -0
- package/skills/webgpu-threejs-tsl/templates/webgpu-project.js +276 -0
- package/dist/cli/browser-cli-serve.js +0 -91
- package/dist/control-ui/assets/index-Cl-Y9zqE.js.map +0 -1
- package/dist/control-ui/assets/index-DEPfFcOb.css +0 -1
- package/docs/POOL-BOT.md +0 -119
- /package/dist/{config/types.clawdbot.js → browser/routes/types.js} +0 -0
- /package/docs/{whatsapp-clawd.jpg → whatsapp-poolbot.jpg} +0 -0
- /package/extensions/bluebubbles/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/copilot-proxy/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/diagnostics-otel/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/discord/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/google-antigravity-auth/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/google-gemini-cli-auth/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/googlechat/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/imessage/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/line/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/llm-task/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/lobster/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/matrix/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/mattermost/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/memory-core/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/msteams/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/nextcloud-talk/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/nostr/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/open-prose/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/qwen-portal-auth/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/signal/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/slack/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/telegram/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/tlon/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/whatsapp/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/zalo/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
- /package/extensions/zalouser/{clawdbot.plugin.json → poolbot.plugin.json} +0 -0
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { discoverAuthStorage, discoverModels } from "@mariozechner/pi-coding-agent";
|
|
2
|
-
import {
|
|
2
|
+
import { resolveMoltbotAgentDir } from "../../agents/agent-paths.js";
|
|
3
3
|
import { listProfilesForProvider } from "../../agents/auth-profiles.js";
|
|
4
4
|
import { getCustomProviderApiKey, resolveAwsSdkEnvVarName, resolveEnvApiKey, } from "../../agents/model-auth.js";
|
|
5
|
-
import {
|
|
5
|
+
import { ensureMoltbotModelsJson } from "../../agents/models-config.js";
|
|
6
6
|
import { modelKey } from "./shared.js";
|
|
7
7
|
const isLocalBaseUrl = (baseUrl) => {
|
|
8
8
|
try {
|
|
@@ -30,8 +30,8 @@ const hasAuthForProvider = (provider, cfg, authStore) => {
|
|
|
30
30
|
return false;
|
|
31
31
|
};
|
|
32
32
|
export async function loadModelRegistry(cfg) {
|
|
33
|
-
await
|
|
34
|
-
const agentDir =
|
|
33
|
+
await ensureMoltbotModelsJson(cfg);
|
|
34
|
+
const agentDir = resolveMoltbotAgentDir();
|
|
35
35
|
const authStorage = discoverAuthStorage(agentDir);
|
|
36
36
|
const registry = discoverModels(authStorage, agentDir);
|
|
37
37
|
const models = registry.getAll();
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import path from "node:path";
|
|
2
|
-
import {
|
|
2
|
+
import { resolveMoltbotAgentDir } from "../../agents/agent-paths.js";
|
|
3
3
|
import { buildAuthHealthSummary, DEFAULT_OAUTH_WARN_MS, formatRemainingShort, } from "../../agents/auth-health.js";
|
|
4
4
|
import { ensureAuthProfileStore, resolveAuthStorePathForDisplay, resolveProfileUnusableUntilForDisplay, } from "../../agents/auth-profiles.js";
|
|
5
5
|
import { resolveEnvApiKey } from "../../agents/model-auth.js";
|
|
6
6
|
import { buildModelAliasIndex, parseModelRef, resolveConfiguredModelRef, resolveModelRefFromString, } from "../../agents/model-selection.js";
|
|
7
|
-
import {
|
|
7
|
+
import { CONFIG_PATH, loadConfig } from "../../config/config.js";
|
|
8
8
|
import { getShellEnvAppliedKeys, shouldEnableShellEnvFallback } from "../../infra/shell-env.js";
|
|
9
9
|
import { withProgressTotals } from "../../cli/progress.js";
|
|
10
10
|
import { formatUsageWindowSummary, loadProviderUsageSummary, resolveUsageProviderId, } from "../../infra/provider-usage.js";
|
|
@@ -42,7 +42,7 @@ export async function modelsStatusCommand(opts, runtime) {
|
|
|
42
42
|
return acc;
|
|
43
43
|
}, {});
|
|
44
44
|
const allowed = Object.keys(cfg.agents?.defaults?.models ?? {});
|
|
45
|
-
const agentDir =
|
|
45
|
+
const agentDir = resolveMoltbotAgentDir();
|
|
46
46
|
const store = ensureAuthProfileStore();
|
|
47
47
|
const modelsPath = path.join(agentDir, "models.json");
|
|
48
48
|
const providersFromStore = new Set(Object.values(store.profiles)
|
|
@@ -207,7 +207,7 @@ export async function modelsStatusCommand(opts, runtime) {
|
|
|
207
207
|
})();
|
|
208
208
|
if (opts.json) {
|
|
209
209
|
runtime.log(JSON.stringify({
|
|
210
|
-
configPath:
|
|
210
|
+
configPath: CONFIG_PATH,
|
|
211
211
|
agentDir,
|
|
212
212
|
defaultModel: defaultLabel,
|
|
213
213
|
resolvedDefault: resolvedLabel,
|
|
@@ -247,7 +247,7 @@ export async function modelsStatusCommand(opts, runtime) {
|
|
|
247
247
|
const rich = isRich(opts);
|
|
248
248
|
const label = (value) => colorize(rich, theme.accent, value.padEnd(14));
|
|
249
249
|
const displayDefault = rawModel && rawModel !== resolvedLabel ? `${resolvedLabel} (from ${rawModel})` : resolvedLabel;
|
|
250
|
-
runtime.log(`${label("Config")}${colorize(rich, theme.muted, ":")} ${colorize(rich, theme.info, shortenHomePath(
|
|
250
|
+
runtime.log(`${label("Config")}${colorize(rich, theme.muted, ":")} ${colorize(rich, theme.info, shortenHomePath(CONFIG_PATH))}`);
|
|
251
251
|
runtime.log(`${label("Agent dir")}${colorize(rich, theme.muted, ":")} ${colorize(rich, theme.info, shortenHomePath(agentDir))}`);
|
|
252
252
|
runtime.log(`${label("Default")}${colorize(rich, theme.muted, ":")} ${colorize(rich, theme.success, displayDefault)}`);
|
|
253
253
|
runtime.log(`${label(`Fallbacks (${fallbacks.length || 0})`)}${colorize(rich, theme.muted, ":")} ${colorize(rich, fallbacks.length ? theme.warn : theme.muted, fallbacks.length ? fallbacks.join(", ") : "-")}`);
|
|
@@ -292,8 +292,8 @@ export async function modelsStatusCommand(opts, runtime) {
|
|
|
292
292
|
runtime.log(colorize(rich, theme.heading, "Missing auth"));
|
|
293
293
|
for (const provider of missingProvidersInUse) {
|
|
294
294
|
const hint = provider === "anthropic"
|
|
295
|
-
? `Run \`claude setup-token\` or \`${formatCliCommand("
|
|
296
|
-
: `Run \`${formatCliCommand("
|
|
295
|
+
? `Run \`claude setup-token\`, then \`${formatCliCommand("poolbot models auth setup-token")}\` or \`${formatCliCommand("poolbot configure")}\`.`
|
|
296
|
+
: `Run \`${formatCliCommand("poolbot configure")}\` or set an API key env var.`;
|
|
297
297
|
runtime.log(`- ${theme.heading(provider)} ${hint}`);
|
|
298
298
|
}
|
|
299
299
|
}
|
|
@@ -362,8 +362,7 @@ export async function modelsStatusCommand(opts, runtime) {
|
|
|
362
362
|
: profile.expiresAt
|
|
363
363
|
? ` expires in ${formatRemainingShort(profile.remainingMs)}`
|
|
364
364
|
: " expires unknown";
|
|
365
|
-
|
|
366
|
-
runtime.log(` - ${label} ${status}${expiry}${source}`);
|
|
365
|
+
runtime.log(` - ${label} ${status}${expiry}`);
|
|
367
366
|
}
|
|
368
367
|
}
|
|
369
368
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { resolveMoltbotAgentDir } from "../agents/agent-paths.js";
|
|
2
2
|
import { upsertAuthProfile } from "../agents/auth-profiles.js";
|
|
3
|
-
const resolveAuthAgentDir = (agentDir) => agentDir ??
|
|
3
|
+
const resolveAuthAgentDir = (agentDir) => agentDir ?? resolveMoltbotAgentDir();
|
|
4
4
|
export async function writeOAuthCredentials(provider, creds, agentDir) {
|
|
5
5
|
// Write to resolved agent dir so gateway finds credentials on startup.
|
|
6
6
|
upsertAuthProfile({
|
|
@@ -123,7 +123,7 @@ async function noteChannelPrimer(prompter, channels) {
|
|
|
123
123
|
}));
|
|
124
124
|
await prompter.note([
|
|
125
125
|
"DM security: default is pairing; unknown DMs get a pairing code.",
|
|
126
|
-
`Approve with: ${formatCliCommand("
|
|
126
|
+
`Approve with: ${formatCliCommand("poolbot pairing approve <channel> <code>")}`,
|
|
127
127
|
'Public DMs require dmPolicy="open" + allowFrom=["*"].',
|
|
128
128
|
'Multi-user DMs: set session.dmScope="per-channel-peer" to isolate sessions.',
|
|
129
129
|
`Docs: ${formatDocsLink("/start/pairing", "start/pairing")}`,
|
|
@@ -159,7 +159,7 @@ async function maybeConfigureDmPolicies(params) {
|
|
|
159
159
|
const selectPolicy = async (policy) => {
|
|
160
160
|
await prompter.note([
|
|
161
161
|
"Default: pairing (unknown DMs get a pairing code).",
|
|
162
|
-
`Approve: ${formatCliCommand(`
|
|
162
|
+
`Approve: ${formatCliCommand(`poolbot pairing approve ${policy.channel} <code>`)}`,
|
|
163
163
|
`Allowlist DMs: ${policy.policyKey}="allowlist" + ${policy.allowFromKey} entries.`,
|
|
164
164
|
`Public DMs: ${policy.policyKey}="open" + ${policy.allowFromKey} includes "*".`,
|
|
165
165
|
'Multi-user DMs: set session.dmScope="per-channel-peer" to isolate sessions.',
|
|
@@ -472,7 +472,7 @@ export async function setupChannels(cfg, runtime, prompter, options) {
|
|
|
472
472
|
{
|
|
473
473
|
value: "__skip__",
|
|
474
474
|
label: "Skip for now",
|
|
475
|
-
hint: `You can add channels later via \`${formatCliCommand("
|
|
475
|
+
hint: `You can add channels later via \`${formatCliCommand("poolbot channels add")}\``,
|
|
476
476
|
},
|
|
477
477
|
],
|
|
478
478
|
initialValue: quickstartDefault,
|
|
@@ -4,7 +4,7 @@ import path from "node:path";
|
|
|
4
4
|
import { inspect } from "node:util";
|
|
5
5
|
import { cancel, isCancel } from "@clack/prompts";
|
|
6
6
|
import { DEFAULT_AGENT_WORKSPACE_DIR, ensureAgentWorkspace } from "../agents/workspace.js";
|
|
7
|
-
import {
|
|
7
|
+
import { CONFIG_PATH } from "../config/config.js";
|
|
8
8
|
import { resolveSessionTranscriptsDirForAgent } from "../config/sessions.js";
|
|
9
9
|
import { callGateway } from "../gateway/call.js";
|
|
10
10
|
import { normalizeControlUiBasePath } from "../gateway/control-ui-shared.js";
|
|
@@ -135,8 +135,8 @@ export function formatControlUiSshHint(params) {
|
|
|
135
135
|
localUrl,
|
|
136
136
|
authedUrl,
|
|
137
137
|
"Docs:",
|
|
138
|
-
"https://docs.
|
|
139
|
-
"https://docs.
|
|
138
|
+
"https://docs.molt.bot/gateway/remote",
|
|
139
|
+
"https://docs.molt.bot/web/control-ui",
|
|
140
140
|
]
|
|
141
141
|
.filter(Boolean)
|
|
142
142
|
.join("\n");
|
|
@@ -229,7 +229,7 @@ export async function moveToTrash(pathname, runtime) {
|
|
|
229
229
|
}
|
|
230
230
|
}
|
|
231
231
|
export async function handleReset(scope, workspaceDir, runtime) {
|
|
232
|
-
await moveToTrash(
|
|
232
|
+
await moveToTrash(CONFIG_PATH, runtime);
|
|
233
233
|
if (scope === "config")
|
|
234
234
|
return;
|
|
235
235
|
await moveToTrash(path.join(CONFIG_DIR, "credentials"), runtime);
|
|
@@ -6,7 +6,7 @@ export async function setupInternalHooks(cfg, runtime, prompter) {
|
|
|
6
6
|
"Hooks let you automate actions when agent commands are issued.",
|
|
7
7
|
"Example: Save session context to memory when you issue /new.",
|
|
8
8
|
"",
|
|
9
|
-
"Learn more: https://docs.
|
|
9
|
+
"Learn more: https://docs.molt.bot/hooks",
|
|
10
10
|
].join("\n"), "Hooks");
|
|
11
11
|
// Discover available hooks using the hook discovery system
|
|
12
12
|
const workspaceDir = resolveAgentWorkspaceDir(cfg, resolveDefaultAgentId(cfg));
|
|
@@ -51,9 +51,9 @@ export async function setupInternalHooks(cfg, runtime, prompter) {
|
|
|
51
51
|
`Enabled ${selected.length} hook${selected.length > 1 ? "s" : ""}: ${selected.join(", ")}`,
|
|
52
52
|
"",
|
|
53
53
|
"You can manage hooks later with:",
|
|
54
|
-
` ${formatCliCommand("
|
|
55
|
-
` ${formatCliCommand("
|
|
56
|
-
` ${formatCliCommand("
|
|
54
|
+
` ${formatCliCommand("poolbot hooks list")}`,
|
|
55
|
+
` ${formatCliCommand("poolbot hooks enable <name>")}`,
|
|
56
|
+
` ${formatCliCommand("poolbot hooks disable <name>")}`,
|
|
57
57
|
].join("\n"), "Hooks Configured");
|
|
58
58
|
return next;
|
|
59
59
|
}
|
|
@@ -1,16 +1,31 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { upsertAuthProfile } from "../../../agents/auth-profiles.js";
|
|
2
2
|
import { normalizeProviderId } from "../../../agents/model-selection.js";
|
|
3
3
|
import { parseDurationMs } from "../../../cli/parse-duration.js";
|
|
4
4
|
import { upsertSharedEnvVar } from "../../../infra/env-file.js";
|
|
5
5
|
import { buildTokenProfileId, validateAnthropicSetupToken } from "../../auth-token.js";
|
|
6
6
|
import { applyGoogleGeminiModelDefault } from "../../google-gemini-model-default.js";
|
|
7
|
-
import { applyAuthProfileConfig, applyKimiCodeConfig, applyMinimaxApiConfig, applyMinimaxConfig, applyMoonshotConfig, applyOpencodeZenConfig, applyOpenrouterConfig, applySyntheticConfig, applyVercelAiGatewayConfig, applyZaiConfig, setAnthropicApiKey, setGeminiApiKey, setKimiCodeApiKey, setMinimaxApiKey, setMoonshotApiKey, setOpencodeZenApiKey, setOpenrouterApiKey, setSyntheticApiKey, setVercelAiGatewayApiKey, setZaiApiKey, } from "../../onboard-auth.js";
|
|
8
|
-
import { applyOpenAICodexModelDefault } from "../../openai-codex-model-default.js";
|
|
7
|
+
import { applyAuthProfileConfig, applyKimiCodeConfig, applyMinimaxApiConfig, applyMinimaxConfig, applyMoonshotConfig, applyOpencodeZenConfig, applyOpenrouterConfig, applySyntheticConfig, applyVeniceConfig, applyVercelAiGatewayConfig, applyZaiConfig, setAnthropicApiKey, setGeminiApiKey, setKimiCodeApiKey, setMinimaxApiKey, setMoonshotApiKey, setOpencodeZenApiKey, setOpenrouterApiKey, setSyntheticApiKey, setVeniceApiKey, setVercelAiGatewayApiKey, setZaiApiKey, } from "../../onboard-auth.js";
|
|
9
8
|
import { resolveNonInteractiveApiKey } from "../api-keys.js";
|
|
10
9
|
import { shortenHomePath } from "../../../utils.js";
|
|
11
10
|
export async function applyNonInteractiveAuthChoice(params) {
|
|
12
11
|
const { authChoice, opts, runtime, baseConfig } = params;
|
|
13
12
|
let nextConfig = params.nextConfig;
|
|
13
|
+
if (authChoice === "claude-cli" || authChoice === "codex-cli") {
|
|
14
|
+
runtime.error([
|
|
15
|
+
`Auth choice "${authChoice}" is deprecated.`,
|
|
16
|
+
'Use "--auth-choice token" (Anthropic setup-token) or "--auth-choice openai-codex".',
|
|
17
|
+
].join("\n"));
|
|
18
|
+
runtime.exit(1);
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
21
|
+
if (authChoice === "setup-token") {
|
|
22
|
+
runtime.error([
|
|
23
|
+
'Auth choice "setup-token" requires interactive mode.',
|
|
24
|
+
'Use "--auth-choice token" with --token and --token-provider anthropic.',
|
|
25
|
+
].join("\n"));
|
|
26
|
+
runtime.exit(1);
|
|
27
|
+
return null;
|
|
28
|
+
}
|
|
14
29
|
if (authChoice === "apiKey") {
|
|
15
30
|
const resolved = await resolveNonInteractiveApiKey({
|
|
16
31
|
provider: "anthropic",
|
|
@@ -241,6 +256,26 @@ export async function applyNonInteractiveAuthChoice(params) {
|
|
|
241
256
|
});
|
|
242
257
|
return applySyntheticConfig(nextConfig);
|
|
243
258
|
}
|
|
259
|
+
if (authChoice === "venice-api-key") {
|
|
260
|
+
const resolved = await resolveNonInteractiveApiKey({
|
|
261
|
+
provider: "venice",
|
|
262
|
+
cfg: baseConfig,
|
|
263
|
+
flagValue: opts.veniceApiKey,
|
|
264
|
+
flagName: "--venice-api-key",
|
|
265
|
+
envVar: "VENICE_API_KEY",
|
|
266
|
+
runtime,
|
|
267
|
+
});
|
|
268
|
+
if (!resolved)
|
|
269
|
+
return null;
|
|
270
|
+
if (resolved.source !== "profile")
|
|
271
|
+
await setVeniceApiKey(resolved.key);
|
|
272
|
+
nextConfig = applyAuthProfileConfig(nextConfig, {
|
|
273
|
+
profileId: "venice:default",
|
|
274
|
+
provider: "venice",
|
|
275
|
+
mode: "api_key",
|
|
276
|
+
});
|
|
277
|
+
return applyVeniceConfig(nextConfig);
|
|
278
|
+
}
|
|
244
279
|
if (authChoice === "minimax-cloud" ||
|
|
245
280
|
authChoice === "minimax-api" ||
|
|
246
281
|
authChoice === "minimax-api-lightning") {
|
|
@@ -264,37 +299,6 @@ export async function applyNonInteractiveAuthChoice(params) {
|
|
|
264
299
|
const modelId = authChoice === "minimax-api-lightning" ? "MiniMax-M2.1-lightning" : "MiniMax-M2.1";
|
|
265
300
|
return applyMinimaxApiConfig(nextConfig, modelId);
|
|
266
301
|
}
|
|
267
|
-
if (authChoice === "claude-cli") {
|
|
268
|
-
const store = ensureAuthProfileStore(undefined, {
|
|
269
|
-
allowKeychainPrompt: false,
|
|
270
|
-
});
|
|
271
|
-
if (!store.profiles[CLAUDE_CLI_PROFILE_ID]) {
|
|
272
|
-
runtime.error(process.platform === "darwin"
|
|
273
|
-
? 'No Claude Code CLI credentials found. Run interactive onboarding to approve Keychain access for "Claude Code-credentials".'
|
|
274
|
-
: "No Claude Code CLI credentials found at ~/.claude/.credentials.json");
|
|
275
|
-
runtime.exit(1);
|
|
276
|
-
return null;
|
|
277
|
-
}
|
|
278
|
-
return applyAuthProfileConfig(nextConfig, {
|
|
279
|
-
profileId: CLAUDE_CLI_PROFILE_ID,
|
|
280
|
-
provider: "anthropic",
|
|
281
|
-
mode: "oauth",
|
|
282
|
-
});
|
|
283
|
-
}
|
|
284
|
-
if (authChoice === "codex-cli") {
|
|
285
|
-
const store = ensureAuthProfileStore();
|
|
286
|
-
if (!store.profiles[CODEX_CLI_PROFILE_ID]) {
|
|
287
|
-
runtime.error("No Codex CLI credentials found at ~/.codex/auth.json");
|
|
288
|
-
runtime.exit(1);
|
|
289
|
-
return null;
|
|
290
|
-
}
|
|
291
|
-
nextConfig = applyAuthProfileConfig(nextConfig, {
|
|
292
|
-
profileId: CODEX_CLI_PROFILE_ID,
|
|
293
|
-
provider: "openai-codex",
|
|
294
|
-
mode: "oauth",
|
|
295
|
-
});
|
|
296
|
-
return applyOpenAICodexModelDefault(nextConfig).next;
|
|
297
|
-
}
|
|
298
302
|
if (authChoice === "minimax")
|
|
299
303
|
return applyMinimaxConfig(nextConfig);
|
|
300
304
|
if (authChoice === "opencode-zen") {
|
|
@@ -9,17 +9,20 @@ export function applyNonInteractiveGatewayConfig(params) {
|
|
|
9
9
|
}
|
|
10
10
|
const port = hasGatewayPort ? opts.gatewayPort : params.defaultPort;
|
|
11
11
|
let bind = opts.gatewayBind ?? "loopback";
|
|
12
|
-
|
|
12
|
+
const authModeRaw = opts.gatewayAuth ?? "token";
|
|
13
|
+
if (authModeRaw !== "token" && authModeRaw !== "password") {
|
|
14
|
+
runtime.error("Invalid --gateway-auth (use token|password).");
|
|
15
|
+
runtime.exit(1);
|
|
16
|
+
return null;
|
|
17
|
+
}
|
|
18
|
+
let authMode = authModeRaw;
|
|
13
19
|
const tailscaleMode = opts.tailscale ?? "off";
|
|
14
20
|
const tailscaleResetOnExit = Boolean(opts.tailscaleResetOnExit);
|
|
15
21
|
// Tighten config to safe combos:
|
|
16
22
|
// - If Tailscale is on, force loopback bind (the tunnel handles external access).
|
|
17
|
-
// - If binding beyond loopback, disallow auth=off.
|
|
18
23
|
// - If using Tailscale Funnel, require password auth.
|
|
19
24
|
if (tailscaleMode !== "off" && bind !== "loopback")
|
|
20
25
|
bind = "loopback";
|
|
21
|
-
if (authMode === "off" && bind !== "loopback")
|
|
22
|
-
authMode = "token";
|
|
23
26
|
if (tailscaleMode === "funnel" && authMode !== "password")
|
|
24
27
|
authMode = "password";
|
|
25
28
|
let nextConfig = params.nextConfig;
|
|
@@ -100,6 +100,6 @@ export async function runNonInteractiveOnboardingLocal(params) {
|
|
|
100
100
|
skipHealth: Boolean(opts.skipHealth),
|
|
101
101
|
});
|
|
102
102
|
if (!opts.json) {
|
|
103
|
-
runtime.log(`Tip: run \`${formatCliCommand("
|
|
103
|
+
runtime.log(`Tip: run \`${formatCliCommand("poolbot configure --section web")}\` to store your Brave API key for web_search. Docs: https://docs.molt.bot/tools/web`);
|
|
104
104
|
}
|
|
105
105
|
}
|
|
@@ -36,6 +36,6 @@ export async function runNonInteractiveOnboardingRemote(params) {
|
|
|
36
36
|
else {
|
|
37
37
|
runtime.log(`Remote gateway: ${remoteUrl}`);
|
|
38
38
|
runtime.log(`Auth: ${payload.auth}`);
|
|
39
|
-
runtime.log(`Tip: run \`${formatCliCommand("
|
|
39
|
+
runtime.log(`Tip: run \`${formatCliCommand("poolbot configure --section web")}\` to store your Brave API key for web_search. Docs: https://docs.molt.bot/tools/web`);
|
|
40
40
|
}
|
|
41
41
|
}
|
|
@@ -6,7 +6,7 @@ import { runNonInteractiveOnboardingRemote } from "./onboard-non-interactive/rem
|
|
|
6
6
|
export async function runNonInteractiveOnboarding(opts, runtime = defaultRuntime) {
|
|
7
7
|
const snapshot = await readConfigFileSnapshot();
|
|
8
8
|
if (snapshot.exists && !snapshot.valid) {
|
|
9
|
-
runtime.error(`Config invalid. Run \`${formatCliCommand("
|
|
9
|
+
runtime.error(`Config invalid. Run \`${formatCliCommand("poolbot doctor")}\` to repair it, then re-run onboarding.`);
|
|
10
10
|
runtime.exit(1);
|
|
11
11
|
return;
|
|
12
12
|
}
|
|
@@ -30,7 +30,7 @@ export async function promptRemoteGatewayConfig(cfg, prompter) {
|
|
|
30
30
|
if (!hasBonjourTool) {
|
|
31
31
|
await prompter.note([
|
|
32
32
|
"Bonjour discovery requires dns-sd (macOS) or avahi-browse (Linux).",
|
|
33
|
-
"Docs: https://docs.
|
|
33
|
+
"Docs: https://docs.molt.bot/gateway/discovery",
|
|
34
34
|
].join("\n"), "Discovery");
|
|
35
35
|
}
|
|
36
36
|
if (wantsDiscover) {
|
|
@@ -76,7 +76,7 @@ export async function promptRemoteGatewayConfig(cfg, prompter) {
|
|
|
76
76
|
await prompter.note([
|
|
77
77
|
"Start a tunnel before using the CLI:",
|
|
78
78
|
`ssh -N -L 18789:127.0.0.1:18789 <user>@${host}${selectedBeacon.sshPort ? ` -p ${selectedBeacon.sshPort}` : ""}`,
|
|
79
|
-
"Docs: https://docs.
|
|
79
|
+
"Docs: https://docs.molt.bot/gateway/remote",
|
|
80
80
|
].join("\n"), "SSH tunnel");
|
|
81
81
|
}
|
|
82
82
|
}
|
|
@@ -122,8 +122,8 @@ export async function setupSkills(cfg, workspaceDir, runtime, prompter) {
|
|
|
122
122
|
runtime.log(result.stderr.trim());
|
|
123
123
|
else if (result.stdout)
|
|
124
124
|
runtime.log(result.stdout.trim());
|
|
125
|
-
runtime.log(`Tip: run \`${formatCliCommand("
|
|
126
|
-
runtime.log("Docs: https://docs.
|
|
125
|
+
runtime.log(`Tip: run \`${formatCliCommand("poolbot doctor")}\` to review skills + requirements.`);
|
|
126
|
+
runtime.log("Docs: https://docs.molt.bot/skills");
|
|
127
127
|
}
|
|
128
128
|
}
|
|
129
129
|
}
|
package/dist/commands/onboard.js
CHANGED
|
@@ -9,13 +9,34 @@ import { formatCliCommand } from "../cli/command-format.js";
|
|
|
9
9
|
export async function onboardCommand(opts, runtime = defaultRuntime) {
|
|
10
10
|
assertSupportedRuntime(runtime);
|
|
11
11
|
const authChoice = opts.authChoice === "oauth" ? "setup-token" : opts.authChoice;
|
|
12
|
+
const normalizedAuthChoice = authChoice === "claude-cli"
|
|
13
|
+
? "setup-token"
|
|
14
|
+
: authChoice === "codex-cli"
|
|
15
|
+
? "openai-codex"
|
|
16
|
+
: authChoice;
|
|
17
|
+
if (opts.nonInteractive && (authChoice === "claude-cli" || authChoice === "codex-cli")) {
|
|
18
|
+
runtime.error([
|
|
19
|
+
`Auth choice "${authChoice}" is deprecated.`,
|
|
20
|
+
'Use "--auth-choice token" (Anthropic setup-token) or "--auth-choice openai-codex".',
|
|
21
|
+
].join("\n"));
|
|
22
|
+
runtime.exit(1);
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
if (authChoice === "claude-cli") {
|
|
26
|
+
runtime.log('Auth choice "claude-cli" is deprecated; using setup-token flow instead.');
|
|
27
|
+
}
|
|
28
|
+
if (authChoice === "codex-cli") {
|
|
29
|
+
runtime.log('Auth choice "codex-cli" is deprecated; using OpenAI Codex OAuth instead.');
|
|
30
|
+
}
|
|
12
31
|
const flow = opts.flow === "manual" ? "advanced" : opts.flow;
|
|
13
|
-
const normalizedOpts =
|
|
32
|
+
const normalizedOpts = normalizedAuthChoice === opts.authChoice && flow === opts.flow
|
|
33
|
+
? opts
|
|
34
|
+
: { ...opts, authChoice: normalizedAuthChoice, flow };
|
|
14
35
|
if (normalizedOpts.nonInteractive && normalizedOpts.acceptRisk !== true) {
|
|
15
36
|
runtime.error([
|
|
16
37
|
"Non-interactive onboarding requires explicit risk acknowledgement.",
|
|
17
|
-
"Read: https://docs.
|
|
18
|
-
`Re-run with: ${formatCliCommand("
|
|
38
|
+
"Read: https://docs.molt.bot/security",
|
|
39
|
+
`Re-run with: ${formatCliCommand("poolbot onboard --non-interactive --accept-risk ...")}`,
|
|
19
40
|
].join("\n"));
|
|
20
41
|
runtime.exit(1);
|
|
21
42
|
return;
|
|
@@ -30,7 +51,7 @@ export async function onboardCommand(opts, runtime = defaultRuntime) {
|
|
|
30
51
|
runtime.log([
|
|
31
52
|
"Windows detected.",
|
|
32
53
|
"WSL2 is strongly recommended; native Windows is untested and more problematic.",
|
|
33
|
-
"Guide: https://docs.
|
|
54
|
+
"Guide: https://docs.molt.bot/windows",
|
|
34
55
|
].join("\n"));
|
|
35
56
|
}
|
|
36
57
|
if (normalizedOpts.nonInteractive) {
|
|
@@ -4,7 +4,7 @@ import { resolveAgentWorkspaceDir, resolveDefaultAgentId } from "../../agents/ag
|
|
|
4
4
|
import { createSubsystemLogger } from "../../logging/subsystem.js";
|
|
5
5
|
import { recordPluginInstall } from "../../plugins/installs.js";
|
|
6
6
|
import { enablePluginInConfig } from "../../plugins/enable.js";
|
|
7
|
-
import {
|
|
7
|
+
import { loadPoolBotPlugins } from "../../plugins/loader.js";
|
|
8
8
|
import { installPluginFromNpmSpec } from "../../plugins/install.js";
|
|
9
9
|
function hasGitWorkspace(workspaceDir) {
|
|
10
10
|
const candidates = new Set();
|
|
@@ -148,7 +148,7 @@ export async function ensureOnboardingPluginInstalled(params) {
|
|
|
148
148
|
export function reloadOnboardingPluginRegistry(params) {
|
|
149
149
|
const workspaceDir = params.workspaceDir ?? resolveAgentWorkspaceDir(params.cfg, resolveDefaultAgentId(params.cfg));
|
|
150
150
|
const log = createSubsystemLogger("plugins");
|
|
151
|
-
|
|
151
|
+
loadPoolBotPlugins({
|
|
152
152
|
config: params.cfg,
|
|
153
153
|
workspaceDir,
|
|
154
154
|
cache: false,
|
package/dist/commands/reset.js
CHANGED
|
@@ -50,7 +50,7 @@ export async function resetCommand(runtime, opts) {
|
|
|
50
50
|
{
|
|
51
51
|
value: "config",
|
|
52
52
|
label: "Config only",
|
|
53
|
-
hint: "
|
|
53
|
+
hint: "poolbot.json",
|
|
54
54
|
},
|
|
55
55
|
{
|
|
56
56
|
value: "config+creds+sessions",
|
|
@@ -114,7 +114,7 @@ export async function resetCommand(runtime, opts) {
|
|
|
114
114
|
for (const dir of sessionDirs) {
|
|
115
115
|
await removePath(dir, runtime, { dryRun, label: dir });
|
|
116
116
|
}
|
|
117
|
-
runtime.log(`Next: ${formatCliCommand("
|
|
117
|
+
runtime.log(`Next: ${formatCliCommand("poolbot onboard --install-daemon")}`);
|
|
118
118
|
return;
|
|
119
119
|
}
|
|
120
120
|
if (scope === "full") {
|
|
@@ -128,7 +128,7 @@ export async function resetCommand(runtime, opts) {
|
|
|
128
128
|
for (const workspace of workspaceDirs) {
|
|
129
129
|
await removePath(workspace, runtime, { dryRun, label: workspace });
|
|
130
130
|
}
|
|
131
|
-
runtime.log(`Next: ${formatCliCommand("
|
|
131
|
+
runtime.log(`Next: ${formatCliCommand("poolbot onboard --install-daemon")}`);
|
|
132
132
|
return;
|
|
133
133
|
}
|
|
134
134
|
}
|
|
@@ -54,7 +54,7 @@ export function displaySummary(containers, browsers, runtime) {
|
|
|
54
54
|
runtime.log(`Total: ${totalCount} (${runningCount} running)`);
|
|
55
55
|
if (mismatchCount > 0) {
|
|
56
56
|
runtime.log(`\n⚠️ ${mismatchCount} container(s) with image mismatch detected.`);
|
|
57
|
-
runtime.log(` Run '${formatCliCommand("
|
|
57
|
+
runtime.log(` Run '${formatCliCommand("poolbot sandbox recreate --all")}' to update all containers.`);
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
60
|
export function displayRecreatePreview(containers, browsers, runtime) {
|
|
@@ -7,7 +7,7 @@ import { buildAgentMainSessionKey, normalizeAgentId, normalizeMainKey, parseAgen
|
|
|
7
7
|
import { formatDocsLink } from "../terminal/links.js";
|
|
8
8
|
import { colorize, isRich, theme } from "../terminal/theme.js";
|
|
9
9
|
import { INTERNAL_MESSAGE_CHANNEL } from "../utils/message-channel.js";
|
|
10
|
-
const SANDBOX_DOCS_URL = "https://docs.
|
|
10
|
+
const SANDBOX_DOCS_URL = "https://docs.molt.bot/sandbox";
|
|
11
11
|
function normalizeExplainSessionKey(params) {
|
|
12
12
|
const raw = (params.session ?? "").trim();
|
|
13
13
|
if (!raw) {
|
|
@@ -221,6 +221,6 @@ export async function sandboxExplainCommand(opts, runtime) {
|
|
|
221
221
|
for (const key of payload.fixIt)
|
|
222
222
|
lines.push(` - ${key}`);
|
|
223
223
|
lines.push("");
|
|
224
|
-
lines.push(`${key("Docs:")} ${formatDocsLink("/sandbox", "docs.
|
|
224
|
+
lines.push(`${key("Docs:")} ${formatDocsLink("/sandbox", "docs.molt.bot/sandbox")}`);
|
|
225
225
|
runtime.log(`${lines.join("\n")}\n`);
|
|
226
226
|
}
|
package/dist/commands/setup.js
CHANGED
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import fs from "node:fs/promises";
|
|
2
2
|
import JSON5 from "json5";
|
|
3
3
|
import { DEFAULT_AGENT_WORKSPACE_DIR, ensureAgentWorkspace } from "../agents/workspace.js";
|
|
4
|
-
import {
|
|
4
|
+
import { CONFIG_PATH, writeConfigFile } from "../config/config.js";
|
|
5
5
|
import { formatConfigPath, logConfigUpdated } from "../config/logging.js";
|
|
6
6
|
import { resolveSessionTranscriptsDir } from "../config/sessions.js";
|
|
7
7
|
import { defaultRuntime } from "../runtime.js";
|
|
8
8
|
import { shortenHomePath } from "../utils.js";
|
|
9
9
|
async function readConfigFileRaw() {
|
|
10
10
|
try {
|
|
11
|
-
const raw = await fs.readFile(
|
|
11
|
+
const raw = await fs.readFile(CONFIG_PATH, "utf-8");
|
|
12
12
|
const parsed = JSON5.parse(raw);
|
|
13
13
|
if (parsed && typeof parsed === "object") {
|
|
14
14
|
return { exists: true, parsed: parsed };
|
|
@@ -79,7 +79,7 @@ export async function installSignalCli(runtime) {
|
|
|
79
79
|
const apiUrl = "https://api.github.com/repos/AsamK/signal-cli/releases/latest";
|
|
80
80
|
const response = await fetch(apiUrl, {
|
|
81
81
|
headers: {
|
|
82
|
-
"User-Agent": "
|
|
82
|
+
"User-Agent": "poolbot",
|
|
83
83
|
Accept: "application/vnd.github+json",
|
|
84
84
|
},
|
|
85
85
|
});
|
|
@@ -101,7 +101,7 @@ export async function installSignalCli(runtime) {
|
|
|
101
101
|
error: "No compatible release asset found for this platform.",
|
|
102
102
|
};
|
|
103
103
|
}
|
|
104
|
-
const tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), "
|
|
104
|
+
const tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), "poolbot-signal-"));
|
|
105
105
|
const archivePath = path.join(tmpDir, assetName);
|
|
106
106
|
runtime.log(`Downloading signal-cli ${version} (${assetName})…`);
|
|
107
107
|
await downloadToFile(assetUrl, archivePath);
|
|
@@ -151,6 +151,6 @@ export async function appendStatusAllDiagnosis(params) {
|
|
|
151
151
|
}
|
|
152
152
|
lines.push("");
|
|
153
153
|
lines.push(muted("Pasteable debug report. Auth tokens redacted."));
|
|
154
|
-
lines.push("Troubleshooting: https://docs.
|
|
154
|
+
lines.push("Troubleshooting: https://docs.molt.bot/troubleshooting");
|
|
155
155
|
lines.push("");
|
|
156
156
|
}
|
|
@@ -88,7 +88,7 @@ export async function buildStatusAllReportLines(params) {
|
|
|
88
88
|
rows: agentRows,
|
|
89
89
|
});
|
|
90
90
|
const lines = [];
|
|
91
|
-
lines.push(heading("
|
|
91
|
+
lines.push(heading("Moltbot status --all"));
|
|
92
92
|
lines.push("");
|
|
93
93
|
lines.push(heading("Overview"));
|
|
94
94
|
lines.push(overview.trimEnd());
|
|
@@ -9,7 +9,7 @@ import { buildGatewayConnectionDetails, callGateway } from "../gateway/call.js";
|
|
|
9
9
|
import { normalizeControlUiBasePath } from "../gateway/control-ui-shared.js";
|
|
10
10
|
import { probeGateway } from "../gateway/probe.js";
|
|
11
11
|
import { collectChannelStatusIssues } from "../infra/channels-status-issues.js";
|
|
12
|
-
import {
|
|
12
|
+
import { resolvePoolBotPackageRoot } from "../infra/poolbot-root.js";
|
|
13
13
|
import { resolveOsSummary } from "../infra/os-summary.js";
|
|
14
14
|
import { inspectPortUsage } from "../infra/ports.js";
|
|
15
15
|
import { readRestartSentinel } from "../infra/restart-sentinel.js";
|
|
@@ -67,7 +67,7 @@ export async function statusAllCommand(runtime, opts) {
|
|
|
67
67
|
: null;
|
|
68
68
|
progress.tick();
|
|
69
69
|
progress.setLabel("Checking for updates…");
|
|
70
|
-
const root = await
|
|
70
|
+
const root = await resolvePoolBotPackageRoot({
|
|
71
71
|
moduleUrl: import.meta.url,
|
|
72
72
|
argv1: process.argv[1],
|
|
73
73
|
cwd: process.cwd(),
|
|
@@ -350,7 +350,7 @@ export async function statusAllCommand(runtime, opts) {
|
|
|
350
350
|
Item: "Gateway",
|
|
351
351
|
Value: `${gatewayMode}${remoteUrlMissing ? " (remote.url missing)" : ""} · ${gatewayTarget} (${connection.urlSource}) · ${gatewayStatus}${gatewayAuth}`,
|
|
352
352
|
},
|
|
353
|
-
{ Item: "Security", Value: `Run: ${formatCliCommand("
|
|
353
|
+
{ Item: "Security", Value: `Run: ${formatCliCommand("poolbot security audit --deep")}` },
|
|
354
354
|
gatewaySelfLine
|
|
355
355
|
? { Item: "Gateway self", Value: gatewaySelfLine }
|
|
356
356
|
: { Item: "Gateway self", Value: "unknown" },
|
|
@@ -271,7 +271,7 @@ export async function statusCommand(opts, runtime) {
|
|
|
271
271
|
Value: `${summary.sessions.count} active · default ${defaults.model ?? "unknown"}${defaultCtx} · ${storeLabel}`,
|
|
272
272
|
},
|
|
273
273
|
];
|
|
274
|
-
runtime.log(theme.heading("
|
|
274
|
+
runtime.log(theme.heading("Moltbot status"));
|
|
275
275
|
runtime.log("");
|
|
276
276
|
runtime.log(theme.heading("Overview"));
|
|
277
277
|
runtime.log(renderTable({
|
|
@@ -318,8 +318,8 @@ export async function statusCommand(opts, runtime) {
|
|
|
318
318
|
runtime.log(theme.muted(`… +${sorted.length - shown.length} more`));
|
|
319
319
|
}
|
|
320
320
|
}
|
|
321
|
-
runtime.log(theme.muted(`Full report: ${formatCliCommand("
|
|
322
|
-
runtime.log(theme.muted(`Deep probe: ${formatCliCommand("
|
|
321
|
+
runtime.log(theme.muted(`Full report: ${formatCliCommand("poolbot security audit")}`));
|
|
322
|
+
runtime.log(theme.muted(`Deep probe: ${formatCliCommand("poolbot security audit --deep")}`));
|
|
323
323
|
runtime.log("");
|
|
324
324
|
runtime.log(theme.heading("Channels"));
|
|
325
325
|
const channelIssuesByChannel = (() => {
|
|
@@ -456,8 +456,8 @@ export async function statusCommand(opts, runtime) {
|
|
|
456
456
|
}
|
|
457
457
|
}
|
|
458
458
|
runtime.log("");
|
|
459
|
-
runtime.log("FAQ: https://docs.
|
|
460
|
-
runtime.log("Troubleshooting: https://docs.
|
|
459
|
+
runtime.log("FAQ: https://docs.molt.bot/faq");
|
|
460
|
+
runtime.log("Troubleshooting: https://docs.molt.bot/troubleshooting");
|
|
461
461
|
runtime.log("");
|
|
462
462
|
const updateHint = formatUpdateAvailableHint(update);
|
|
463
463
|
if (updateHint) {
|
|
@@ -465,12 +465,12 @@ export async function statusCommand(opts, runtime) {
|
|
|
465
465
|
runtime.log("");
|
|
466
466
|
}
|
|
467
467
|
runtime.log("Next steps:");
|
|
468
|
-
runtime.log(` Need to share? ${formatCliCommand("
|
|
469
|
-
runtime.log(` Need to debug live? ${formatCliCommand("
|
|
468
|
+
runtime.log(` Need to share? ${formatCliCommand("poolbot status --all")}`);
|
|
469
|
+
runtime.log(` Need to debug live? ${formatCliCommand("poolbot logs --follow")}`);
|
|
470
470
|
if (gatewayReachable) {
|
|
471
|
-
runtime.log(` Need to test channels? ${formatCliCommand("
|
|
471
|
+
runtime.log(` Need to test channels? ${formatCliCommand("poolbot status --deep")}`);
|
|
472
472
|
}
|
|
473
473
|
else {
|
|
474
|
-
runtime.log(` Fix reachability first: ${formatCliCommand("
|
|
474
|
+
runtime.log(` Fix reachability first: ${formatCliCommand("poolbot gateway probe")}`);
|
|
475
475
|
}
|
|
476
476
|
}
|