@poolzin/pool-bot 2026.2.20 → 2026.2.22
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 +25 -0
- package/dist/agents/api-key-rotation.js +47 -0
- package/dist/agents/apply-patch-update.js +19 -9
- package/dist/agents/apply-patch.js +72 -47
- package/dist/agents/bash-tools.exec.js +141 -559
- package/dist/agents/cli-backends.js +49 -6
- package/dist/agents/cli-runner/helpers.js +69 -152
- package/dist/agents/cli-runner.js +70 -19
- package/dist/agents/identity.js +20 -1
- package/dist/agents/image-sanitization.js +9 -0
- package/dist/agents/live-auth-keys.js +123 -26
- package/dist/agents/live-model-filter.js +13 -4
- package/dist/agents/model-auth.js +12 -0
- package/dist/agents/model-catalog.js +40 -9
- package/dist/agents/model-fallback.js +24 -0
- package/dist/agents/model-forward-compat.js +60 -23
- package/dist/agents/model-selection.js +134 -41
- package/dist/agents/pi-auth-json.js +2 -2
- package/dist/agents/pi-embedded-helpers/bootstrap.js +65 -15
- package/dist/agents/pi-embedded-helpers/errors.js +140 -15
- package/dist/agents/pi-embedded-helpers/images.js +22 -12
- package/dist/agents/pi-embedded-helpers.js +2 -2
- package/dist/agents/pi-embedded-runner/abort.js +10 -3
- package/dist/agents/pi-embedded-runner/compact.js +230 -32
- package/dist/agents/pi-embedded-runner/extra-params.js +203 -12
- package/dist/agents/pi-embedded-runner/google.js +109 -19
- package/dist/agents/pi-embedded-runner/history.js +35 -17
- package/dist/agents/pi-embedded-runner/run/attempt.js +386 -80
- package/dist/agents/pi-embedded-runner/run/images.js +81 -55
- package/dist/agents/pi-embedded-runner/run/payloads.js +89 -39
- package/dist/agents/pi-embedded-runner/run.js +193 -25
- package/dist/agents/pi-embedded-runner/run.overflow-compaction.mocks.shared.js +2 -2
- package/dist/agents/pi-embedded-runner/runs.js +17 -8
- package/dist/agents/pi-embedded-runner/tool-result-context-guard.js +262 -0
- package/dist/agents/pi-embedded-runner.js +1 -1
- package/dist/agents/pi-embedded-subscribe.handlers.tools.js +180 -10
- package/dist/agents/pi-embedded-subscribe.js +37 -0
- package/dist/agents/pi-embedded-subscribe.tools.js +127 -30
- package/dist/agents/pi-model-discovery.js +9 -2
- package/dist/agents/pi-tool-definition-adapter.js +60 -8
- package/dist/agents/pi-tools.before-tool-call.js +1 -1
- package/dist/agents/pi-tools.js +113 -94
- package/dist/agents/pi-tools.read.js +337 -38
- package/dist/agents/poolbot-tools.js +14 -5
- package/dist/agents/provider/config-loader.js +76 -0
- package/dist/agents/provider/index.js +15 -0
- package/dist/agents/provider/integration.js +136 -0
- package/dist/agents/provider/models-dev.js +129 -0
- package/dist/agents/provider/rate-limits.js +458 -0
- package/dist/agents/provider/request-monitor.js +449 -0
- package/dist/agents/provider/session-binding.js +376 -0
- package/dist/agents/provider/token-pool.js +541 -0
- package/dist/agents/sandbox/docker.js +10 -5
- package/dist/agents/sandbox/registry.js +96 -46
- package/dist/agents/sandbox/sanitize-env-vars.js +82 -0
- package/dist/agents/sandbox-paths.js +43 -10
- package/dist/agents/session-tool-result-guard-wrapper.js +23 -11
- package/dist/agents/session-tool-result-guard.js +39 -39
- package/dist/agents/session-transcript-repair.js +36 -33
- package/dist/agents/session-write-lock.js +62 -44
- package/dist/agents/skills/frontmatter.js +49 -88
- package/dist/agents/skills/workspace.js +335 -28
- package/dist/agents/subagent-announce.js +508 -174
- package/dist/agents/subagent-registry.js +45 -4
- package/dist/agents/subagent-spawn.js +16 -33
- package/dist/agents/system-prompt-report.js +27 -10
- package/dist/agents/system-prompt.js +26 -32
- package/dist/agents/tool-call-id.js +69 -17
- package/dist/agents/tool-display-common.js +1 -1
- package/dist/agents/tool-images.js +64 -31
- package/dist/agents/tools/canvas-tool.js +17 -11
- package/dist/agents/tools/common.js +37 -19
- package/dist/agents/tools/cron-tool.js +40 -38
- package/dist/agents/tools/gateway.js +70 -2
- package/dist/agents/tools/message-tool.js +181 -40
- package/dist/agents/tools/nodes-tool.js +128 -36
- package/dist/agents/tools/nodes-utils.js +12 -38
- package/dist/agents/tools/session-status-tool.js +24 -71
- package/dist/agents/tools/sessions-helpers.js +38 -210
- package/dist/agents/tools/sessions-spawn-tool.js +28 -198
- package/dist/agents/tools/telegram-actions.js +58 -7
- package/dist/agents/tools/web-fetch-utils.js +112 -7
- package/dist/agents/tools/web-fetch.js +279 -175
- package/dist/agents/tools/web-shared.js +71 -8
- package/dist/agents/usage.js +25 -16
- package/dist/auto-reply/commands-registry.data.js +85 -11
- package/dist/auto-reply/dispatch.js +40 -21
- package/dist/auto-reply/reply/abort.js +102 -33
- package/dist/auto-reply/reply/commands-core.js +82 -33
- package/dist/auto-reply/reply/commands-export-session.js +1 -1
- package/dist/auto-reply/reply/commands-info.js +41 -12
- package/dist/auto-reply/reply/commands-subagents.js +352 -100
- package/dist/auto-reply/reply/commands-system-prompt.js +2 -2
- package/dist/auto-reply/reply/dispatch-from-config.js +100 -29
- package/dist/auto-reply/reply/elevated-unavailable.js +1 -1
- package/dist/auto-reply/reply/inbound-meta.js +12 -1
- package/dist/auto-reply/reply/mentions.js +18 -11
- package/dist/auto-reply/reply/normalize-reply.js +17 -8
- package/dist/auto-reply/reply/reply-dispatcher.js +62 -10
- package/dist/auto-reply/reply/session.js +102 -21
- package/dist/auto-reply/reply/streaming-directives.js +16 -5
- package/dist/auto-reply/status.js +73 -50
- package/dist/browser/extension-relay.js +3 -3
- package/dist/browser/http-auth.js +1 -1
- package/dist/browser/paths.js +2 -2
- package/dist/build-info.json +3 -3
- package/dist/channels/allowlist-match.js +20 -0
- package/dist/channels/allowlists/resolve-utils.js +65 -2
- package/dist/channels/chat-type.js +8 -4
- package/dist/channels/dock.js +127 -35
- package/dist/channels/draft-stream-loop.js +6 -2
- package/dist/channels/plugins/actions/telegram.js +42 -18
- package/dist/channels/plugins/allowlist-match.js +1 -1
- package/dist/channels/plugins/group-mentions.js +51 -41
- package/dist/channels/plugins/message-action-names.js +2 -0
- package/dist/channels/plugins/message-actions.js +24 -5
- package/dist/channels/plugins/normalize/discord.js +26 -4
- package/dist/channels/plugins/normalize/signal.js +35 -22
- package/dist/channels/plugins/onboarding/helpers.js +8 -26
- package/dist/channels/plugins/outbound/imessage.js +15 -14
- package/dist/channels/registry.js +20 -7
- package/dist/cli/acp-cli.js +7 -5
- package/dist/cli/browser-cli-extension.js +25 -12
- package/dist/cli/browser-cli-state.cookies-storage.js +25 -6
- package/dist/cli/browser-cli-state.js +101 -145
- package/dist/cli/command-options.js +28 -0
- package/dist/cli/completion-cli.js +6 -6
- package/dist/cli/cron-cli/register.cron-add.js +25 -1
- package/dist/cli/cron-cli/register.cron-edit.js +44 -0
- package/dist/cli/cron-cli/shared.js +7 -1
- package/dist/cli/daemon-cli/lifecycle-core.js +23 -21
- package/dist/cli/daemon-cli/lifecycle.js +23 -247
- package/dist/cli/daemon-cli/register-service-commands.js +25 -4
- package/dist/cli/daemon-cli.js +1 -0
- package/dist/cli/devices-cli.js +33 -20
- package/dist/cli/gateway-cli/register.js +37 -105
- package/dist/cli/gateway-cli/run.js +49 -11
- package/dist/cli/nodes-camera.js +59 -4
- package/dist/cli/nodes-cli/register.camera.js +27 -24
- package/dist/cli/nodes-cli/rpc.js +21 -38
- package/dist/cli/qr-cli.js +2 -2
- package/dist/cli/skills-cli.format.js +2 -2
- package/dist/cli/update-cli/progress.js +2 -2
- package/dist/cli/update-cli/restart-helper.js +28 -7
- package/dist/cli/update-cli/shared.js +7 -7
- package/dist/cli/update-cli/status.js +1 -1
- package/dist/cli/update-cli/update-command.js +14 -8
- package/dist/cli/update-cli/wizard.js +2 -2
- package/dist/cli/update-cli.js +21 -1027
- package/dist/commands/auth-choice.apply.anthropic.js +10 -2
- package/dist/commands/channels/add-mutators.js +3 -35
- package/dist/commands/channels/add.js +39 -51
- package/dist/commands/config-validation.js +1 -1
- package/dist/commands/configure.gateway-auth.js +52 -15
- package/dist/commands/configure.gateway.js +84 -40
- package/dist/commands/doctor-completion.js +3 -3
- package/dist/commands/doctor-config-flow.js +536 -16
- package/dist/commands/doctor-gateway-services.js +103 -79
- package/dist/commands/doctor-memory-search.js +9 -9
- package/dist/commands/doctor-platform-notes.js +57 -30
- package/dist/commands/doctor-prompter.js +26 -15
- package/dist/commands/doctor-session-locks.js +1 -1
- package/dist/commands/doctor.js +21 -9
- package/dist/commands/model-picker.js +120 -95
- package/dist/commands/models/set.js +2 -21
- package/dist/commands/models/shared.js +65 -37
- package/dist/commands/onboard-helpers.js +81 -39
- package/dist/commands/openai-codex-oauth.js +1 -1
- package/dist/commands/sessions.js +52 -53
- package/dist/commands/status.summary.js +52 -34
- package/dist/commands/test-wizard-helpers.js +2 -2
- package/dist/config/defaults.js +79 -42
- package/dist/config/group-policy.js +50 -18
- package/dist/config/includes.js +37 -10
- package/dist/config/schema.help.js +5 -4
- package/dist/config/schema.hints.js +2 -2
- package/dist/config/schema.labels.js +1 -0
- package/dist/config/sessions/group.js +12 -11
- package/dist/config/sessions/paths.js +137 -11
- package/dist/config/sessions/store.js +185 -65
- package/dist/config/sessions/types.js +15 -1
- package/dist/config/sessions.js +1 -0
- package/dist/config/telegram-custom-commands.js +3 -2
- package/dist/config/types.js +2 -0
- package/dist/config/zod-schema.agent-defaults.js +6 -27
- package/dist/config/zod-schema.agent-runtime.js +171 -79
- package/dist/config/zod-schema.providers-core.js +138 -65
- package/dist/config/zod-schema.session.js +49 -22
- package/dist/control-ui/assets/index-HRr1grwl.js.map +1 -1
- package/dist/cron/isolated-agent/run.js +224 -57
- package/dist/cron/normalize.js +48 -45
- package/dist/cron/run-log.js +14 -0
- package/dist/cron/service/jobs.js +190 -28
- package/dist/cron/service/normalize.js +29 -11
- package/dist/cron/service/store.js +30 -44
- package/dist/cron/service/timer.js +182 -96
- package/dist/cron/service.js +3 -0
- package/dist/cron/stagger.js +37 -0
- package/dist/daemon/inspect.js +132 -92
- package/dist/daemon/runtime-paths.js +25 -4
- package/dist/daemon/service-audit.js +47 -16
- package/dist/discord/accounts.js +23 -20
- package/dist/discord/monitor/agent-components.js +1115 -219
- package/dist/discord/monitor/allow-list.js +114 -34
- package/dist/discord/monitor/listeners.js +204 -97
- package/dist/discord/monitor/message-handler.js +21 -10
- package/dist/discord/monitor/message-handler.preflight.js +195 -101
- package/dist/discord/monitor/message-handler.process.js +384 -123
- package/dist/discord/monitor/message-utils.js +86 -23
- package/dist/discord/monitor/native-command.js +77 -57
- package/dist/discord/monitor/provider.js +122 -117
- package/dist/discord/monitor/reply-context.js +20 -16
- package/dist/discord/monitor/reply-delivery.js +40 -8
- package/dist/discord/monitor/rest-fetch.js +22 -0
- package/dist/discord/monitor/threading.js +117 -24
- package/dist/discord/send.js +2 -1
- package/dist/discord/send.outbound.js +124 -11
- package/dist/discord/send.shared.js +112 -72
- package/dist/discord/voice-message.js +3 -3
- package/dist/gateway/auth.js +119 -44
- package/dist/gateway/call.js +76 -34
- package/dist/gateway/channel-health-monitor.js +57 -50
- package/dist/gateway/client.js +63 -29
- package/dist/gateway/control-ui-contract.js +1 -1
- package/dist/gateway/gateway-config-prompts.shared.js +2 -2
- package/dist/gateway/net.js +109 -1
- package/dist/gateway/protocol/index.js +5 -8
- package/dist/gateway/protocol/schema/agent.js +19 -1
- package/dist/gateway/protocol/schema/channels.js +21 -0
- package/dist/gateway/protocol/schema/cron.js +43 -30
- package/dist/gateway/protocol/schema/protocol-schemas.js +6 -11
- package/dist/gateway/protocol/schema/sessions.js +5 -1
- package/dist/gateway/protocol/schema.js +0 -1
- package/dist/gateway/server/presence-events.js +12 -0
- package/dist/gateway/server/ws-connection/message-handler.js +203 -212
- package/dist/gateway/server/ws-connection.js +58 -21
- package/dist/gateway/server-broadcast.js +18 -13
- package/dist/gateway/server-cron.js +177 -10
- package/dist/gateway/server-methods/agent-job.js +131 -38
- package/dist/gateway/server-methods/send.js +60 -14
- package/dist/gateway/server-methods/sessions.js +160 -96
- package/dist/gateway/server-methods/system.js +5 -7
- package/dist/gateway/server-methods-list.js +8 -0
- package/dist/gateway/server-methods.js +24 -8
- package/dist/gateway/server-node-events.js +278 -68
- package/dist/gateway/session-utils.fs.js +316 -75
- package/dist/gateway/session-utils.js +224 -70
- package/dist/gateway/sessions-patch.js +63 -20
- package/dist/gateway/test-temp-config.js +1 -1
- package/dist/gateway/tools-invoke-http.js +118 -70
- package/dist/gateway/ws-log.js +135 -107
- package/dist/hooks/frontmatter.js +36 -82
- package/dist/hooks/install.js +149 -139
- package/dist/hooks/internal-hooks.js +29 -4
- package/dist/hooks/plugin-hooks.js +2 -1
- package/dist/imessage/monitor/deliver.js +10 -4
- package/dist/imessage/monitor/monitor-provider.js +138 -375
- package/dist/imessage/monitor/runtime.js +4 -8
- package/dist/imessage/send.js +65 -19
- package/dist/infra/exec-approvals-allowlist.js +7 -0
- package/dist/infra/exec-approvals.js +35 -920
- package/dist/infra/exec-safe-bin-trust.js +64 -0
- package/dist/infra/heartbeat-runner.js +207 -134
- package/dist/infra/heartbeat-wake.js +183 -22
- package/dist/infra/install-source-utils.js +47 -0
- package/dist/infra/net/ssrf.js +170 -36
- package/dist/infra/outbound/deliver.js +224 -58
- package/dist/infra/outbound/message-action-spec.js +12 -5
- package/dist/infra/outbound/outbound-session.js +27 -25
- package/dist/infra/poolbot-root.js +32 -22
- package/dist/infra/ports.js +14 -11
- package/dist/infra/skills-remote.js +48 -37
- package/dist/infra/system-events.js +25 -11
- package/dist/infra/system-presence.js +26 -33
- package/dist/infra/tmp-poolbot-dir.js +81 -2
- package/dist/infra/wsl.js +37 -1
- package/dist/line/bot-message-context.js +163 -191
- package/dist/logging/subsystem.js +59 -22
- package/dist/markdown/ir.js +124 -50
- package/dist/media/store.js +1 -1
- package/dist/media-understanding/runner.entries.js +42 -25
- package/dist/media-understanding/runner.js +53 -488
- package/dist/memory/embeddings-gemini.js +53 -38
- package/dist/memory/manager-embedding-ops.js +48 -69
- package/dist/pairing/pairing-store.js +178 -119
- package/dist/plugin-sdk/index.js +34 -6
- package/dist/plugins/hooks.js +135 -14
- package/dist/plugins/install.js +190 -152
- package/dist/polls.js +11 -0
- package/dist/routing/resolve-route.js +190 -56
- package/dist/routing/session-key.js +38 -22
- package/dist/runtime.js +35 -9
- package/dist/security/audit-channel.js +1 -1
- package/dist/sessions/session-key-utils.js +29 -11
- package/dist/shared/frontmatter.js +5 -5
- package/dist/shared/node-list-types.js +1 -0
- package/dist/shared/string-normalization.js +15 -0
- package/dist/signal/monitor/event-handler.js +68 -36
- package/dist/signal/send.js +29 -37
- package/dist/slack/monitor/allow-list.js +10 -11
- package/dist/slack/monitor/commands.js +14 -3
- package/dist/slack/monitor/events/interactions.js +4 -4
- package/dist/slack/monitor/media.js +224 -16
- package/dist/slack/monitor/message-handler/dispatch.js +247 -13
- package/dist/slack/monitor/message-handler/prepare.js +128 -45
- package/dist/slack/monitor/slash.js +357 -144
- package/dist/slack/streaming.js +77 -0
- package/dist/telegram/accounts.js +40 -13
- package/dist/telegram/allowed-updates.js +3 -0
- package/dist/telegram/bot/delivery.js +129 -66
- package/dist/telegram/bot/helpers.js +136 -122
- package/dist/telegram/bot-handlers.js +600 -339
- package/dist/telegram/bot-message-context.js +115 -73
- package/dist/telegram/bot-message-dispatch.js +235 -104
- package/dist/telegram/bot-native-command-menu.js +3 -1
- package/dist/telegram/bot-native-commands.js +213 -193
- package/dist/telegram/bot.js +24 -132
- package/dist/telegram/draft-stream.js +84 -75
- package/dist/telegram/format.js +150 -6
- package/dist/telegram/send.js +415 -255
- package/dist/telegram/targets.js +21 -2
- package/dist/telegram/update-offset-store.js +19 -3
- package/dist/terminal/restore.js +5 -2
- package/dist/test-utils/fetch-mock.js +5 -0
- package/dist/version.js +18 -5
- package/dist/web/auto-reply/monitor/broadcast.js +7 -3
- package/dist/web/auto-reply/monitor/on-message.js +6 -3
- package/dist/web/inbound/media.js +34 -8
- package/dist/web/inbound/monitor.js +34 -17
- package/dist/web/inbound/send-api.js +18 -17
- package/dist/web/outbound.js +12 -5
- package/dist/wizard/clack-prompter.js +40 -7
- package/extensions/bluebubbles/package.json +1 -1
- package/extensions/copilot-proxy/package.json +1 -1
- package/extensions/diagnostics-otel/package.json +1 -1
- package/extensions/discord/package.json +1 -1
- package/extensions/feishu/package.json +1 -1
- package/extensions/google-antigravity-auth/package.json +1 -1
- package/extensions/google-gemini-cli-auth/package.json +1 -1
- package/extensions/googlechat/package.json +1 -1
- package/extensions/imessage/package.json +1 -1
- package/extensions/irc/package.json +1 -1
- package/extensions/line/package.json +1 -1
- package/extensions/llm-task/package.json +1 -1
- package/extensions/lobster/package.json +1 -1
- package/extensions/matrix/CHANGELOG.md +5 -0
- package/extensions/matrix/package.json +1 -1
- package/extensions/mattermost/package.json +1 -1
- package/extensions/memory-core/package.json +1 -1
- package/extensions/memory-lancedb/package.json +1 -1
- package/extensions/minimax-portal-auth/package.json +1 -1
- package/extensions/msteams/CHANGELOG.md +5 -0
- package/extensions/msteams/package.json +1 -1
- package/extensions/nextcloud-talk/package.json +1 -1
- package/extensions/nostr/CHANGELOG.md +5 -0
- package/extensions/nostr/package.json +1 -1
- package/extensions/open-prose/package.json +1 -1
- package/extensions/openai-codex-auth/package.json +1 -1
- package/extensions/signal/package.json +1 -1
- package/extensions/slack/package.json +1 -1
- package/extensions/telegram/package.json +1 -1
- package/extensions/tlon/package.json +1 -1
- package/extensions/twitch/CHANGELOG.md +5 -0
- package/extensions/twitch/package.json +1 -1
- package/extensions/voice-call/CHANGELOG.md +5 -0
- package/extensions/voice-call/package.json +1 -1
- package/extensions/whatsapp/package.json +1 -1
- package/extensions/zalo/CHANGELOG.md +5 -0
- package/extensions/zalo/package.json +1 -1
- package/extensions/zalouser/CHANGELOG.md +5 -0
- package/extensions/zalouser/package.json +1 -1
- package/package.json +1 -1
- package/skills/apple-reminders/SKILL.md +100 -49
- package/skills/coding-agent/SKILL.md +34 -28
- package/skills/github/SKILL.md +131 -16
- package/skills/imsg/SKILL.md +112 -15
- package/skills/openhue/SKILL.md +101 -19
- package/skills/plcode-controller/SKILL.md +156 -0
- package/skills/plcode-controller/assets/operator-prompts.md +65 -0
- package/skills/plcode-controller/references/command-cheatsheet.md +53 -0
- package/skills/plcode-controller/references/failure-handling.md +60 -0
- package/skills/plcode-controller/references/model-selection.md +57 -0
- package/skills/plcode-controller/references/plan-vs-build.md +52 -0
- package/skills/plcode-controller/references/question-handling.md +40 -0
- package/skills/plcode-controller/references/session-management.md +63 -0
- package/skills/plcode-controller/references/workflow.md +35 -0
- package/skills/tmux/SKILL.md +111 -79
- package/skills/weather/SKILL.md +88 -25
|
@@ -0,0 +1,136 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Provider Infrastructure — Integration Facade
|
|
3
|
+
*
|
|
4
|
+
* Thin integration layer that bridges the provider infrastructure modules
|
|
5
|
+
* (TokenPool, RateLimits, RequestMonitor) into the existing LLM pipeline
|
|
6
|
+
* (model-auth.ts, model-fallback.ts, attempt.ts).
|
|
7
|
+
*
|
|
8
|
+
* Design principles:
|
|
9
|
+
* - **Opt-in**: Only activates when TokenPool has tokens for a provider
|
|
10
|
+
* - **Fallthrough**: Returns null/undefined when not configured, letting existing paths run
|
|
11
|
+
* - **Error-isolated**: Never throws — all failures are caught and logged
|
|
12
|
+
* - **Zero behavior change by default**: Without pool configuration, the system is identical
|
|
13
|
+
*
|
|
14
|
+
* @module provider/integration
|
|
15
|
+
*/
|
|
16
|
+
import { RateLimits } from "./rate-limits.js";
|
|
17
|
+
import { RequestMonitor } from "./request-monitor.js";
|
|
18
|
+
import { TokenPool } from "./token-pool.js";
|
|
19
|
+
/**
|
|
20
|
+
* Try to resolve an API key from the token pool for a provider.
|
|
21
|
+
* Returns `null` if no pool is configured or no tokens are available,
|
|
22
|
+
* allowing the caller to fall back to the existing auth resolution path.
|
|
23
|
+
*/
|
|
24
|
+
export async function resolveTokenFromPool(provider) {
|
|
25
|
+
try {
|
|
26
|
+
if (!TokenPool.hasPool(provider))
|
|
27
|
+
return null;
|
|
28
|
+
const result = await TokenPool.getToken(provider);
|
|
29
|
+
if (!result)
|
|
30
|
+
return null;
|
|
31
|
+
return {
|
|
32
|
+
apiKey: result.token.key,
|
|
33
|
+
tokenID: result.token.id,
|
|
34
|
+
source: `pool:${provider}/${result.token.id}`,
|
|
35
|
+
waited: result.waited,
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
catch {
|
|
39
|
+
// Never break the auth chain — fall back to existing resolution
|
|
40
|
+
return null;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Check whether a provider is rate-limited across all its pool keys.
|
|
45
|
+
* Returns `{ isLimited: false }` if no pool is configured (safe default).
|
|
46
|
+
*
|
|
47
|
+
* When `keyID` is provided, checks that specific key only.
|
|
48
|
+
*/
|
|
49
|
+
export function isProviderRateLimited(provider, keyID) {
|
|
50
|
+
try {
|
|
51
|
+
const check = RateLimits.isLimited(provider, keyID);
|
|
52
|
+
return {
|
|
53
|
+
isLimited: check.isLimited,
|
|
54
|
+
waitTimeMs: check.waitTimeMs,
|
|
55
|
+
};
|
|
56
|
+
}
|
|
57
|
+
catch {
|
|
58
|
+
return { isLimited: false, waitTimeMs: 0 };
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Record the outcome of a provider request into both RateLimits and RequestMonitor.
|
|
63
|
+
*
|
|
64
|
+
* - For 429 responses: marks the provider/key as rate-limited (with header parsing)
|
|
65
|
+
* - For successes: records success in TokenPool (for scheduling) and clears rate limits
|
|
66
|
+
* - All outcomes: logged in RequestMonitor for observability
|
|
67
|
+
*
|
|
68
|
+
* Safe to call unconditionally — does nothing harmful if provider modules aren't configured.
|
|
69
|
+
*/
|
|
70
|
+
export function recordRequestOutcome(outcome) {
|
|
71
|
+
try {
|
|
72
|
+
// Feed into RequestMonitor for observability
|
|
73
|
+
RequestMonitor.logRequest({
|
|
74
|
+
providerID: outcome.provider,
|
|
75
|
+
modelID: outcome.model,
|
|
76
|
+
method: "chat",
|
|
77
|
+
status: outcome.status,
|
|
78
|
+
latencyMs: outcome.latencyMs,
|
|
79
|
+
streaming: outcome.streaming,
|
|
80
|
+
keyID: outcome.keyID,
|
|
81
|
+
inputTokens: outcome.inputTokens,
|
|
82
|
+
outputTokens: outcome.outputTokens,
|
|
83
|
+
cacheReadTokens: outcome.cacheReadTokens,
|
|
84
|
+
cacheWriteTokens: outcome.cacheWriteTokens,
|
|
85
|
+
error: outcome.error,
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
catch {
|
|
89
|
+
// Observability should never break the pipeline
|
|
90
|
+
}
|
|
91
|
+
try {
|
|
92
|
+
// Feed into RateLimits for 429s
|
|
93
|
+
if (outcome.status === 429) {
|
|
94
|
+
RateLimits.markLimitedFromResponse(outcome.provider, outcome.status, outcome.headers ?? {}, outcome.keyID);
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
catch {
|
|
98
|
+
// Rate limit tracking should never break the pipeline
|
|
99
|
+
}
|
|
100
|
+
try {
|
|
101
|
+
// Feed success/failure into TokenPool for scheduling decisions
|
|
102
|
+
if (outcome.keyID && TokenPool.hasPool(outcome.provider)) {
|
|
103
|
+
if (outcome.status >= 200 && outcome.status < 400) {
|
|
104
|
+
TokenPool.recordSuccess(outcome.provider, outcome.keyID, {
|
|
105
|
+
inputTokens: outcome.inputTokens ?? 0,
|
|
106
|
+
outputTokens: outcome.outputTokens ?? 0,
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
else if (outcome.status >= 400) {
|
|
110
|
+
TokenPool.recordFailure(outcome.provider, outcome.keyID, outcome.status, outcome.headers);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
catch {
|
|
115
|
+
// Token pool feedback should never break the pipeline
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
// ---------------------------------------------------------------------------
|
|
119
|
+
// Convenience: record a fallback error
|
|
120
|
+
// ---------------------------------------------------------------------------
|
|
121
|
+
/**
|
|
122
|
+
* Record a fallback error (e.g., from model-fallback catch block).
|
|
123
|
+
* Extracts provider, model, status from the error and feeds into the monitoring pipeline.
|
|
124
|
+
*/
|
|
125
|
+
export function recordFallbackError(params) {
|
|
126
|
+
recordRequestOutcome({
|
|
127
|
+
provider: params.provider,
|
|
128
|
+
model: params.model,
|
|
129
|
+
status: params.status ?? 500,
|
|
130
|
+
latencyMs: params.latencyMs ?? 0,
|
|
131
|
+
streaming: false,
|
|
132
|
+
keyID: params.keyID,
|
|
133
|
+
error: params.error ?? params.reason,
|
|
134
|
+
headers: params.headers,
|
|
135
|
+
});
|
|
136
|
+
}
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Models.dev Catalog
|
|
3
|
+
*
|
|
4
|
+
* Fetches and caches the model catalog from https://models.dev/api.json.
|
|
5
|
+
* Provides typed schemas for providers and models via Zod.
|
|
6
|
+
*
|
|
7
|
+
* @module provider/models-dev
|
|
8
|
+
*/
|
|
9
|
+
import { readFile, writeFile, mkdir } from "node:fs/promises";
|
|
10
|
+
import path from "node:path";
|
|
11
|
+
import z from "zod";
|
|
12
|
+
import { createSubsystemLogger } from "../../logging/subsystem.js";
|
|
13
|
+
import { resolveStateDir } from "../../config/paths.js";
|
|
14
|
+
export var ModelsDev;
|
|
15
|
+
(function (ModelsDev) {
|
|
16
|
+
const log = createSubsystemLogger("provider/models-dev");
|
|
17
|
+
/** Cache directory: ~/.poolbot/cache/ */
|
|
18
|
+
const cacheDir = path.join(resolveStateDir(), "cache");
|
|
19
|
+
const filepath = path.join(cacheDir, "models.json");
|
|
20
|
+
/** User-Agent for fetching */
|
|
21
|
+
const USER_AGENT = "pool-bot";
|
|
22
|
+
ModelsDev.Model = z.object({
|
|
23
|
+
id: z.string(),
|
|
24
|
+
name: z.string(),
|
|
25
|
+
family: z.string().optional(),
|
|
26
|
+
release_date: z.string(),
|
|
27
|
+
attachment: z.boolean(),
|
|
28
|
+
reasoning: z.boolean(),
|
|
29
|
+
temperature: z.boolean(),
|
|
30
|
+
tool_call: z.boolean(),
|
|
31
|
+
interleaved: z
|
|
32
|
+
.union([
|
|
33
|
+
z.literal(true),
|
|
34
|
+
z
|
|
35
|
+
.object({
|
|
36
|
+
field: z.enum(["reasoning_content", "reasoning_details"]),
|
|
37
|
+
})
|
|
38
|
+
.strict(),
|
|
39
|
+
])
|
|
40
|
+
.optional(),
|
|
41
|
+
cost: z
|
|
42
|
+
.object({
|
|
43
|
+
input: z.number(),
|
|
44
|
+
output: z.number(),
|
|
45
|
+
cache_read: z.number().optional(),
|
|
46
|
+
cache_write: z.number().optional(),
|
|
47
|
+
context_over_200k: z
|
|
48
|
+
.object({
|
|
49
|
+
input: z.number(),
|
|
50
|
+
output: z.number(),
|
|
51
|
+
cache_read: z.number().optional(),
|
|
52
|
+
cache_write: z.number().optional(),
|
|
53
|
+
})
|
|
54
|
+
.optional(),
|
|
55
|
+
})
|
|
56
|
+
.optional(),
|
|
57
|
+
limit: z.object({
|
|
58
|
+
context: z.number(),
|
|
59
|
+
output: z.number(),
|
|
60
|
+
}),
|
|
61
|
+
modalities: z
|
|
62
|
+
.object({
|
|
63
|
+
input: z.array(z.enum(["text", "audio", "image", "video", "pdf"])),
|
|
64
|
+
output: z.array(z.enum(["text", "audio", "image", "video", "pdf"])),
|
|
65
|
+
})
|
|
66
|
+
.optional(),
|
|
67
|
+
experimental: z.boolean().optional(),
|
|
68
|
+
status: z.enum(["alpha", "beta", "deprecated"]).optional(),
|
|
69
|
+
options: z.record(z.string(), z.any()),
|
|
70
|
+
headers: z.record(z.string(), z.string()).optional(),
|
|
71
|
+
provider: z.object({ npm: z.string() }).optional(),
|
|
72
|
+
});
|
|
73
|
+
ModelsDev.Provider = z.object({
|
|
74
|
+
api: z.string().optional(),
|
|
75
|
+
name: z.string(),
|
|
76
|
+
env: z.array(z.string()),
|
|
77
|
+
id: z.string(),
|
|
78
|
+
npm: z.string().optional(),
|
|
79
|
+
models: z.record(z.string(), ModelsDev.Model),
|
|
80
|
+
});
|
|
81
|
+
/**
|
|
82
|
+
* Gets the cached model catalog, triggering a background refresh.
|
|
83
|
+
* Returns empty object if no cached data is available.
|
|
84
|
+
*/
|
|
85
|
+
async function get() {
|
|
86
|
+
// Fire-and-forget background refresh
|
|
87
|
+
refresh().catch((e) => log.error("background refresh failed", { error: String(e) }));
|
|
88
|
+
// Try reading from cache
|
|
89
|
+
try {
|
|
90
|
+
const content = await readFile(filepath, "utf-8");
|
|
91
|
+
const result = JSON.parse(content);
|
|
92
|
+
return result;
|
|
93
|
+
}
|
|
94
|
+
catch {
|
|
95
|
+
// No cached file yet — return empty catalog
|
|
96
|
+
return {};
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
ModelsDev.get = get;
|
|
100
|
+
/**
|
|
101
|
+
* Fetches the latest model catalog from models.dev and caches it.
|
|
102
|
+
*/
|
|
103
|
+
async function refresh() {
|
|
104
|
+
if (process.env.POOLBOT_DISABLE_MODELS_FETCH)
|
|
105
|
+
return;
|
|
106
|
+
log.info("refreshing", { filepath });
|
|
107
|
+
const result = await fetch("https://models.dev/api.json", {
|
|
108
|
+
headers: {
|
|
109
|
+
"User-Agent": USER_AGENT,
|
|
110
|
+
},
|
|
111
|
+
signal: AbortSignal.timeout(10 * 1000),
|
|
112
|
+
}).catch((e) => {
|
|
113
|
+
log.error("failed to fetch models.dev", { error: String(e) });
|
|
114
|
+
});
|
|
115
|
+
if (!result || !result.ok)
|
|
116
|
+
return;
|
|
117
|
+
try {
|
|
118
|
+
const text = await result.text();
|
|
119
|
+
await mkdir(cacheDir, { recursive: true });
|
|
120
|
+
await writeFile(filepath, text, "utf-8");
|
|
121
|
+
}
|
|
122
|
+
catch (e) {
|
|
123
|
+
log.error("failed to write models.json", { error: String(e) });
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
ModelsDev.refresh = refresh;
|
|
127
|
+
})(ModelsDev || (ModelsDev = {}));
|
|
128
|
+
// Background refresh every hour
|
|
129
|
+
setInterval(() => ModelsDev.refresh().catch(() => { }), 60 * 60 * 1000).unref();
|