@elizaos/agent 0.25.8 → 2.0.0-alpha.83
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/LICENSE +1 -1
- package/package.json +994 -34
- package/packages/agent/src/actions/emote.d.ts +14 -0
- package/packages/agent/src/actions/emote.d.ts.map +1 -0
- package/packages/agent/src/actions/emote.js +91 -0
- package/packages/agent/src/actions/restart.d.ts +19 -0
- package/packages/agent/src/actions/restart.d.ts.map +1 -0
- package/packages/agent/src/actions/restart.js +86 -0
- package/packages/agent/src/actions/send-message.d.ts +3 -0
- package/packages/agent/src/actions/send-message.d.ts.map +1 -0
- package/packages/agent/src/actions/send-message.js +144 -0
- package/packages/agent/src/actions/stream-control.d.ts +15 -0
- package/packages/agent/src/actions/stream-control.d.ts.map +1 -0
- package/packages/agent/src/actions/stream-control.js +357 -0
- package/packages/agent/src/actions/switch-stream-source.d.ts +16 -0
- package/packages/agent/src/actions/switch-stream-source.d.ts.map +1 -0
- package/packages/agent/src/actions/switch-stream-source.js +94 -0
- package/packages/agent/src/actions/terminal.d.ts +14 -0
- package/packages/agent/src/actions/terminal.d.ts.map +1 -0
- package/packages/agent/src/actions/terminal.js +154 -0
- package/packages/agent/src/api/agent-admin-routes.d.ts +38 -0
- package/packages/agent/src/api/agent-admin-routes.d.ts.map +1 -0
- package/packages/agent/src/api/agent-admin-routes.js +93 -0
- package/packages/agent/src/api/agent-lifecycle-routes.d.ts +16 -0
- package/packages/agent/src/api/agent-lifecycle-routes.d.ts.map +1 -0
- package/packages/agent/src/api/agent-lifecycle-routes.js +80 -0
- package/packages/agent/src/api/agent-model.d.ts +12 -0
- package/packages/agent/src/api/agent-model.d.ts.map +1 -0
- package/packages/agent/src/api/agent-model.js +123 -0
- package/packages/agent/src/api/agent-transfer-routes.d.ts +16 -0
- package/packages/agent/src/api/agent-transfer-routes.d.ts.map +1 -0
- package/packages/agent/src/api/agent-transfer-routes.js +124 -0
- package/packages/agent/src/api/apps-routes.d.ts +19 -0
- package/packages/agent/src/api/apps-routes.d.ts.map +1 -0
- package/packages/agent/src/api/apps-routes.js +128 -0
- package/packages/agent/src/api/auth-routes.d.ts +11 -0
- package/packages/agent/src/api/auth-routes.d.ts.map +1 -0
- package/packages/agent/src/api/auth-routes.js +54 -0
- package/packages/agent/src/api/bsc-trade.d.ts +34 -0
- package/packages/agent/src/api/bsc-trade.d.ts.map +1 -0
- package/packages/agent/src/api/bsc-trade.js +567 -0
- package/packages/agent/src/api/bug-report-routes.d.ts +7 -0
- package/packages/agent/src/api/bug-report-routes.d.ts.map +1 -0
- package/packages/agent/src/api/bug-report-routes.js +124 -0
- package/packages/agent/src/api/character-routes.d.ts +50 -0
- package/packages/agent/src/api/character-routes.d.ts.map +1 -0
- package/packages/agent/src/api/character-routes.js +302 -0
- package/packages/agent/src/api/cloud-billing-routes.d.ts +14 -0
- package/packages/agent/src/api/cloud-billing-routes.d.ts.map +1 -0
- package/packages/agent/src/api/cloud-billing-routes.js +400 -0
- package/packages/agent/src/api/cloud-compat-routes.d.ts +15 -0
- package/packages/agent/src/api/cloud-compat-routes.d.ts.map +1 -0
- package/packages/agent/src/api/cloud-compat-routes.js +131 -0
- package/packages/agent/src/api/cloud-routes.d.ts +62 -0
- package/packages/agent/src/api/cloud-routes.d.ts.map +1 -0
- package/packages/agent/src/api/cloud-routes.js +339 -0
- package/packages/agent/src/api/cloud-status-routes.d.ts +15 -0
- package/packages/agent/src/api/cloud-status-routes.d.ts.map +1 -0
- package/packages/agent/src/api/cloud-status-routes.js +165 -0
- package/packages/agent/src/api/compat-utils.d.ts +49 -0
- package/packages/agent/src/api/compat-utils.d.ts.map +1 -0
- package/packages/agent/src/api/compat-utils.js +126 -0
- package/packages/agent/src/api/connector-health.d.ts +34 -0
- package/packages/agent/src/api/connector-health.d.ts.map +1 -0
- package/packages/agent/src/api/connector-health.js +109 -0
- package/packages/agent/src/api/coordinator-wiring.d.ts +46 -0
- package/packages/agent/src/api/coordinator-wiring.d.ts.map +1 -0
- package/packages/agent/src/api/coordinator-wiring.js +101 -0
- package/packages/agent/src/api/credit-detection.d.ts +9 -0
- package/packages/agent/src/api/credit-detection.d.ts.map +1 -0
- package/packages/agent/src/api/credit-detection.js +41 -0
- package/packages/agent/src/api/database.d.ts +33 -0
- package/packages/agent/src/api/database.d.ts.map +1 -0
- package/packages/agent/src/api/database.js +1019 -0
- package/packages/agent/src/api/diagnostics-routes.d.ts +46 -0
- package/packages/agent/src/api/diagnostics-routes.d.ts.map +1 -0
- package/packages/agent/src/api/diagnostics-routes.js +241 -0
- package/packages/agent/src/api/drop-service.d.ts +26 -0
- package/packages/agent/src/api/drop-service.d.ts.map +1 -0
- package/packages/agent/src/api/drop-service.js +134 -0
- package/packages/agent/src/api/early-logs.d.ts +29 -0
- package/packages/agent/src/api/early-logs.d.ts.map +1 -0
- package/packages/agent/src/api/early-logs.js +96 -0
- package/packages/agent/src/api/http-helpers.d.ts +50 -0
- package/packages/agent/src/api/http-helpers.d.ts.map +1 -0
- package/packages/agent/src/api/http-helpers.js +145 -0
- package/packages/agent/src/api/index.d.ts +61 -0
- package/packages/agent/src/api/index.d.ts.map +1 -0
- package/packages/agent/src/api/index.js +59 -0
- package/packages/agent/src/api/knowledge-routes.d.ts +23 -0
- package/packages/agent/src/api/knowledge-routes.d.ts.map +1 -0
- package/packages/agent/src/api/knowledge-routes.js +931 -0
- package/packages/agent/src/api/knowledge-service-loader.d.ts +51 -0
- package/packages/agent/src/api/knowledge-service-loader.d.ts.map +1 -0
- package/packages/agent/src/api/knowledge-service-loader.js +34 -0
- package/packages/agent/src/api/memory-bounds.d.ts +51 -0
- package/packages/agent/src/api/memory-bounds.d.ts.map +1 -0
- package/packages/agent/src/api/memory-bounds.js +81 -0
- package/packages/agent/src/api/memory-routes.d.ts +9 -0
- package/packages/agent/src/api/memory-routes.d.ts.map +1 -0
- package/packages/agent/src/api/memory-routes.js +241 -0
- package/packages/agent/src/api/merkle-tree.d.ts +90 -0
- package/packages/agent/src/api/merkle-tree.d.ts.map +1 -0
- package/packages/agent/src/api/merkle-tree.js +174 -0
- package/packages/agent/src/api/models-routes.d.ts +14 -0
- package/packages/agent/src/api/models-routes.d.ts.map +1 -0
- package/packages/agent/src/api/models-routes.js +37 -0
- package/packages/agent/src/api/nfa-routes.d.ts +5 -0
- package/packages/agent/src/api/nfa-routes.d.ts.map +1 -0
- package/packages/agent/src/api/nfa-routes.js +125 -0
- package/packages/agent/src/api/og-tracker.d.ts +28 -0
- package/packages/agent/src/api/og-tracker.d.ts.map +1 -0
- package/packages/agent/src/api/og-tracker.js +60 -0
- package/packages/agent/src/api/parse-action-block.d.ts +36 -0
- package/packages/agent/src/api/parse-action-block.d.ts.map +1 -0
- package/packages/agent/src/api/parse-action-block.js +110 -0
- package/packages/agent/src/api/permissions-routes.d.ts +32 -0
- package/packages/agent/src/api/permissions-routes.d.ts.map +1 -0
- package/packages/agent/src/api/permissions-routes.js +149 -0
- package/packages/agent/src/api/plugin-validation.d.ts +86 -0
- package/packages/agent/src/api/plugin-validation.d.ts.map +1 -0
- package/packages/agent/src/api/plugin-validation.js +259 -0
- package/packages/agent/src/api/provider-switch-config.d.ts +37 -0
- package/packages/agent/src/api/provider-switch-config.d.ts.map +1 -0
- package/packages/agent/src/api/provider-switch-config.js +317 -0
- package/packages/agent/src/api/registry-routes.d.ts +26 -0
- package/packages/agent/src/api/registry-routes.d.ts.map +1 -0
- package/packages/agent/src/api/registry-routes.js +90 -0
- package/packages/agent/src/api/registry-service.d.ts +77 -0
- package/packages/agent/src/api/registry-service.d.ts.map +1 -0
- package/packages/agent/src/api/registry-service.js +190 -0
- package/packages/agent/src/api/route-helpers.d.ts +16 -0
- package/packages/agent/src/api/route-helpers.d.ts.map +1 -0
- package/packages/agent/src/api/route-helpers.js +1 -0
- package/packages/agent/src/api/sandbox-routes.d.ts +12 -0
- package/packages/agent/src/api/sandbox-routes.d.ts.map +1 -0
- package/packages/agent/src/api/sandbox-routes.js +1334 -0
- package/packages/agent/src/api/server.d.ts +418 -0
- package/packages/agent/src/api/server.d.ts.map +1 -0
- package/packages/agent/src/api/server.js +13614 -0
- package/packages/agent/src/api/signal-routes.d.ts +39 -0
- package/packages/agent/src/api/signal-routes.d.ts.map +1 -0
- package/packages/agent/src/api/signal-routes.js +168 -0
- package/packages/agent/src/api/stream-persistence.d.ts +64 -0
- package/packages/agent/src/api/stream-persistence.d.ts.map +1 -0
- package/packages/agent/src/api/stream-persistence.js +231 -0
- package/packages/agent/src/api/stream-route-state.d.ts +50 -0
- package/packages/agent/src/api/stream-route-state.d.ts.map +1 -0
- package/packages/agent/src/api/stream-route-state.js +1 -0
- package/packages/agent/src/api/stream-routes.d.ts +45 -0
- package/packages/agent/src/api/stream-routes.d.ts.map +1 -0
- package/packages/agent/src/api/stream-routes.js +809 -0
- package/packages/agent/src/api/stream-voice-routes.d.ts +36 -0
- package/packages/agent/src/api/stream-voice-routes.d.ts.map +1 -0
- package/packages/agent/src/api/stream-voice-routes.js +133 -0
- package/packages/agent/src/api/streaming-text.d.ts +9 -0
- package/packages/agent/src/api/streaming-text.d.ts.map +1 -0
- package/packages/agent/src/api/streaming-text.js +85 -0
- package/packages/agent/src/api/streaming-types.d.ts +30 -0
- package/packages/agent/src/api/streaming-types.d.ts.map +1 -0
- package/packages/agent/src/api/streaming-types.js +1 -0
- package/packages/agent/src/api/subscription-routes.d.ts +20 -0
- package/packages/agent/src/api/subscription-routes.d.ts.map +1 -0
- package/packages/agent/src/api/subscription-routes.js +191 -0
- package/packages/agent/src/api/terminal-run-limits.d.ts +5 -0
- package/packages/agent/src/api/terminal-run-limits.d.ts.map +1 -0
- package/packages/agent/src/api/terminal-run-limits.js +22 -0
- package/packages/agent/src/api/training-backend-check.d.ts +8 -0
- package/packages/agent/src/api/training-backend-check.d.ts.map +1 -0
- package/packages/agent/src/api/training-backend-check.js +28 -0
- package/packages/agent/src/api/training-routes.d.ts +44 -0
- package/packages/agent/src/api/training-routes.d.ts.map +1 -0
- package/packages/agent/src/api/training-routes.js +195 -0
- package/packages/agent/src/api/training-service-like.d.ts +38 -0
- package/packages/agent/src/api/training-service-like.d.ts.map +1 -0
- package/packages/agent/src/api/training-service-like.js +1 -0
- package/packages/agent/src/api/trajectory-routes.d.ts +17 -0
- package/packages/agent/src/api/trajectory-routes.d.ts.map +1 -0
- package/packages/agent/src/api/trajectory-routes.js +405 -0
- package/packages/agent/src/api/trigger-routes.d.ts +72 -0
- package/packages/agent/src/api/trigger-routes.d.ts.map +1 -0
- package/packages/agent/src/api/trigger-routes.js +268 -0
- package/packages/agent/src/api/twitter-verify.d.ts +25 -0
- package/packages/agent/src/api/twitter-verify.d.ts.map +1 -0
- package/packages/agent/src/api/twitter-verify.js +168 -0
- package/packages/agent/src/api/tx-service.d.ts +47 -0
- package/packages/agent/src/api/tx-service.d.ts.map +1 -0
- package/packages/agent/src/api/tx-service.js +156 -0
- package/packages/agent/src/api/wallet-dex-prices.d.ts +43 -0
- package/packages/agent/src/api/wallet-dex-prices.d.ts.map +1 -0
- package/packages/agent/src/api/wallet-dex-prices.js +149 -0
- package/packages/agent/src/api/wallet-evm-balance.d.ts +65 -0
- package/packages/agent/src/api/wallet-evm-balance.d.ts.map +1 -0
- package/packages/agent/src/api/wallet-evm-balance.js +663 -0
- package/packages/agent/src/api/wallet-routes.d.ts +33 -0
- package/packages/agent/src/api/wallet-routes.d.ts.map +1 -0
- package/packages/agent/src/api/wallet-routes.js +292 -0
- package/packages/agent/src/api/wallet-rpc.d.ts +61 -0
- package/packages/agent/src/api/wallet-rpc.d.ts.map +1 -0
- package/packages/agent/src/api/wallet-rpc.js +367 -0
- package/packages/agent/src/api/wallet-trading-profile.d.ts +51 -0
- package/packages/agent/src/api/wallet-trading-profile.d.ts.map +1 -0
- package/packages/agent/src/api/wallet-trading-profile.js +547 -0
- package/packages/agent/src/api/wallet.d.ts +31 -0
- package/packages/agent/src/api/wallet.d.ts.map +1 -0
- package/packages/agent/src/api/wallet.js +513 -0
- package/packages/agent/src/api/whatsapp-routes.d.ts +39 -0
- package/packages/agent/src/api/whatsapp-routes.d.ts.map +1 -0
- package/packages/agent/src/api/whatsapp-routes.js +182 -0
- package/packages/agent/src/api/zip-utils.d.ts +8 -0
- package/packages/agent/src/api/zip-utils.d.ts.map +1 -0
- package/packages/agent/src/api/zip-utils.js +115 -0
- package/packages/agent/src/auth/anthropic.d.ts +25 -0
- package/packages/agent/src/auth/anthropic.d.ts.map +1 -0
- package/packages/agent/src/auth/anthropic.js +40 -0
- package/packages/agent/src/auth/apply-stealth.d.ts +8 -0
- package/packages/agent/src/auth/apply-stealth.d.ts.map +1 -0
- package/packages/agent/src/auth/apply-stealth.js +35 -0
- package/packages/agent/src/auth/claude-code-stealth.d.ts +2 -0
- package/packages/agent/src/auth/claude-code-stealth.d.ts.map +1 -0
- package/packages/agent/src/auth/claude-code-stealth.js +104 -0
- package/packages/agent/src/auth/credentials.d.ts +55 -0
- package/packages/agent/src/auth/credentials.d.ts.map +1 -0
- package/packages/agent/src/auth/credentials.js +182 -0
- package/packages/agent/src/auth/index.d.ts +7 -0
- package/packages/agent/src/auth/index.d.ts.map +1 -0
- package/packages/agent/src/auth/index.js +3 -0
- package/packages/agent/src/auth/openai-codex.d.ts +27 -0
- package/packages/agent/src/auth/openai-codex.d.ts.map +1 -0
- package/packages/agent/src/auth/openai-codex.js +72 -0
- package/packages/agent/src/auth/types.d.ts +18 -0
- package/packages/agent/src/auth/types.d.ts.map +1 -0
- package/packages/agent/src/auth/types.js +8 -0
- package/packages/agent/src/awareness/registry.d.ts +27 -0
- package/packages/agent/src/awareness/registry.d.ts.map +1 -0
- package/packages/agent/src/awareness/registry.js +161 -0
- package/packages/agent/src/benchmark-server.d.ts +2 -0
- package/packages/agent/src/benchmark-server.d.ts.map +1 -0
- package/packages/agent/src/benchmark-server.js +773 -0
- package/packages/agent/src/bin.d.ts +3 -0
- package/packages/agent/src/bin.d.ts.map +1 -0
- package/packages/agent/src/bin.js +6 -0
- package/packages/agent/src/cli/index.d.ts +2 -0
- package/packages/agent/src/cli/index.d.ts.map +1 -0
- package/packages/agent/src/cli/index.js +40 -0
- package/packages/agent/src/cli/parse-duration.d.ts +5 -0
- package/packages/agent/src/cli/parse-duration.d.ts.map +1 -0
- package/packages/agent/src/cli/parse-duration.js +27 -0
- package/packages/agent/src/cloud/auth.d.ts +19 -0
- package/packages/agent/src/cloud/auth.d.ts.map +1 -0
- package/packages/agent/src/cloud/auth.js +107 -0
- package/packages/agent/src/cloud/backup.d.ts +18 -0
- package/packages/agent/src/cloud/backup.d.ts.map +1 -0
- package/packages/agent/src/cloud/backup.js +42 -0
- package/packages/agent/src/cloud/base-url.d.ts +3 -0
- package/packages/agent/src/cloud/base-url.d.ts.map +1 -0
- package/packages/agent/src/cloud/base-url.js +40 -0
- package/packages/agent/src/cloud/bridge-client.d.ts +56 -0
- package/packages/agent/src/cloud/bridge-client.d.ts.map +1 -0
- package/packages/agent/src/cloud/bridge-client.js +190 -0
- package/packages/agent/src/cloud/cloud-manager.d.ts +32 -0
- package/packages/agent/src/cloud/cloud-manager.d.ts.map +1 -0
- package/packages/agent/src/cloud/cloud-manager.js +119 -0
- package/packages/agent/src/cloud/cloud-proxy.d.ts +20 -0
- package/packages/agent/src/cloud/cloud-proxy.d.ts.map +1 -0
- package/packages/agent/src/cloud/cloud-proxy.js +34 -0
- package/packages/agent/src/cloud/index.d.ts +7 -0
- package/packages/agent/src/cloud/index.d.ts.map +1 -0
- package/packages/agent/src/cloud/index.js +6 -0
- package/packages/agent/src/cloud/reconnect.d.ts +26 -0
- package/packages/agent/src/cloud/reconnect.d.ts.map +1 -0
- package/packages/agent/src/cloud/reconnect.js +86 -0
- package/packages/agent/src/cloud/validate-url.d.ts +2 -0
- package/packages/agent/src/cloud/validate-url.d.ts.map +1 -0
- package/packages/agent/src/cloud/validate-url.js +162 -0
- package/packages/agent/src/config/character-schema.d.ts +25 -0
- package/packages/agent/src/config/character-schema.d.ts.map +1 -0
- package/packages/agent/src/config/character-schema.js +39 -0
- package/packages/agent/src/config/config.d.ts +6 -0
- package/packages/agent/src/config/config.d.ts.map +1 -0
- package/packages/agent/src/config/config.js +118 -0
- package/packages/agent/src/config/env-vars.d.ts +3 -0
- package/packages/agent/src/config/env-vars.d.ts.map +1 -0
- package/packages/agent/src/config/env-vars.js +76 -0
- package/packages/agent/src/config/includes.d.ts +26 -0
- package/packages/agent/src/config/includes.d.ts.map +1 -0
- package/packages/agent/src/config/includes.js +148 -0
- package/packages/agent/src/config/index.d.ts +16 -0
- package/packages/agent/src/config/index.d.ts.map +1 -0
- package/packages/agent/src/config/index.js +15 -0
- package/packages/agent/src/config/object-utils.d.ts +2 -0
- package/packages/agent/src/config/object-utils.d.ts.map +1 -0
- package/packages/agent/src/config/object-utils.js +6 -0
- package/packages/agent/src/config/paths.d.ts +13 -0
- package/packages/agent/src/config/paths.d.ts.map +1 -0
- package/packages/agent/src/config/paths.js +67 -0
- package/packages/agent/src/config/plugin-auto-enable.d.ts +16 -0
- package/packages/agent/src/config/plugin-auto-enable.d.ts.map +1 -0
- package/packages/agent/src/config/plugin-auto-enable.js +384 -0
- package/packages/agent/src/config/schema.d.ts +87 -0
- package/packages/agent/src/config/schema.d.ts.map +1 -0
- package/packages/agent/src/config/schema.js +928 -0
- package/packages/agent/src/config/telegram-custom-commands.d.ts +25 -0
- package/packages/agent/src/config/telegram-custom-commands.d.ts.map +1 -0
- package/packages/agent/src/config/telegram-custom-commands.js +71 -0
- package/packages/agent/src/config/types.agent-defaults.d.ts +331 -0
- package/packages/agent/src/config/types.agent-defaults.d.ts.map +1 -0
- package/packages/agent/src/config/types.agent-defaults.js +1 -0
- package/packages/agent/src/config/types.agents.d.ts +110 -0
- package/packages/agent/src/config/types.agents.d.ts.map +1 -0
- package/packages/agent/src/config/types.agents.js +1 -0
- package/packages/agent/src/config/types.d.ts +8 -0
- package/packages/agent/src/config/types.d.ts.map +1 -0
- package/packages/agent/src/config/types.eliza.d.ts +636 -0
- package/packages/agent/src/config/types.eliza.d.ts.map +1 -0
- package/packages/agent/src/config/types.eliza.js +1 -0
- package/packages/agent/src/config/types.gateway.d.ts +216 -0
- package/packages/agent/src/config/types.gateway.d.ts.map +1 -0
- package/packages/agent/src/config/types.gateway.js +1 -0
- package/packages/agent/src/config/types.hooks.d.ts +107 -0
- package/packages/agent/src/config/types.hooks.d.ts.map +1 -0
- package/packages/agent/src/config/types.hooks.js +1 -0
- package/packages/agent/src/config/types.js +7 -0
- package/packages/agent/src/config/types.messages.d.ts +176 -0
- package/packages/agent/src/config/types.messages.d.ts.map +1 -0
- package/packages/agent/src/config/types.messages.js +1 -0
- package/packages/agent/src/config/types.tools.d.ts +400 -0
- package/packages/agent/src/config/types.tools.d.ts.map +1 -0
- package/packages/agent/src/config/types.tools.js +1 -0
- package/packages/agent/src/config/zod-schema.agent-runtime.d.ts +1062 -0
- package/packages/agent/src/config/zod-schema.agent-runtime.d.ts.map +1 -0
- package/packages/agent/src/config/zod-schema.agent-runtime.js +721 -0
- package/packages/agent/src/config/zod-schema.core.d.ts +1021 -0
- package/packages/agent/src/config/zod-schema.core.d.ts.map +1 -0
- package/packages/agent/src/config/zod-schema.core.js +694 -0
- package/packages/agent/src/config/zod-schema.d.ts +4817 -0
- package/packages/agent/src/config/zod-schema.d.ts.map +1 -0
- package/packages/agent/src/config/zod-schema.hooks.d.ts +88 -0
- package/packages/agent/src/config/zod-schema.hooks.d.ts.map +1 -0
- package/packages/agent/src/config/zod-schema.hooks.js +133 -0
- package/packages/agent/src/config/zod-schema.js +778 -0
- package/packages/agent/src/config/zod-schema.providers-core.d.ts +2976 -0
- package/packages/agent/src/config/zod-schema.providers-core.d.ts.map +1 -0
- package/packages/agent/src/config/zod-schema.providers-core.js +1006 -0
- package/packages/agent/src/config/zod-schema.session.d.ts +183 -0
- package/packages/agent/src/config/zod-schema.session.d.ts.map +1 -0
- package/packages/agent/src/config/zod-schema.session.js +86 -0
- package/packages/agent/src/contracts/apps.d.ts +42 -0
- package/packages/agent/src/contracts/apps.d.ts.map +1 -0
- package/packages/agent/src/contracts/apps.js +4 -0
- package/packages/agent/src/contracts/awareness.d.ts +38 -0
- package/packages/agent/src/contracts/awareness.d.ts.map +1 -0
- package/packages/agent/src/contracts/awareness.js +7 -0
- package/packages/agent/src/contracts/config.d.ts +146 -0
- package/packages/agent/src/contracts/config.d.ts.map +1 -0
- package/packages/agent/src/contracts/config.js +4 -0
- package/packages/agent/src/contracts/drop.d.ts +20 -0
- package/packages/agent/src/contracts/drop.d.ts.map +1 -0
- package/packages/agent/src/contracts/drop.js +4 -0
- package/packages/agent/src/contracts/index.d.ts +9 -0
- package/packages/agent/src/contracts/index.d.ts.map +1 -0
- package/packages/agent/src/contracts/index.js +8 -0
- package/packages/agent/src/contracts/onboarding.d.ts +379 -0
- package/packages/agent/src/contracts/onboarding.d.ts.map +1 -0
- package/packages/agent/src/contracts/onboarding.js +290 -0
- package/packages/agent/src/contracts/permissions.d.ts +35 -0
- package/packages/agent/src/contracts/permissions.d.ts.map +1 -0
- package/packages/agent/src/contracts/permissions.js +4 -0
- package/packages/agent/src/contracts/verification.d.ts +9 -0
- package/packages/agent/src/contracts/verification.d.ts.map +1 -0
- package/packages/agent/src/contracts/verification.js +4 -0
- package/packages/agent/src/contracts/wallet.d.ts +409 -0
- package/packages/agent/src/contracts/wallet.d.ts.map +1 -0
- package/packages/agent/src/contracts/wallet.js +60 -0
- package/packages/agent/src/diagnostics/integration-observability.d.ts +40 -0
- package/packages/agent/src/diagnostics/integration-observability.d.ts.map +1 -0
- package/packages/agent/src/diagnostics/integration-observability.js +68 -0
- package/packages/agent/src/emotes/catalog.d.ts +31 -0
- package/packages/agent/src/emotes/catalog.d.ts.map +1 -0
- package/packages/agent/src/emotes/catalog.js +618 -0
- package/packages/agent/src/hooks/discovery.d.ts +13 -0
- package/packages/agent/src/hooks/discovery.d.ts.map +1 -0
- package/packages/agent/src/hooks/discovery.js +184 -0
- package/packages/agent/src/hooks/eligibility.d.ts +12 -0
- package/packages/agent/src/hooks/eligibility.d.ts.map +1 -0
- package/packages/agent/src/hooks/eligibility.js +100 -0
- package/packages/agent/src/hooks/index.d.ts +3 -0
- package/packages/agent/src/hooks/index.d.ts.map +1 -0
- package/packages/agent/src/hooks/index.js +2 -0
- package/packages/agent/src/hooks/loader.d.ts +34 -0
- package/packages/agent/src/hooks/loader.d.ts.map +1 -0
- package/packages/agent/src/hooks/loader.js +176 -0
- package/packages/agent/src/hooks/registry.d.ts +11 -0
- package/packages/agent/src/hooks/registry.d.ts.map +1 -0
- package/packages/agent/src/hooks/registry.js +58 -0
- package/packages/agent/src/hooks/types.d.ts +104 -0
- package/packages/agent/src/hooks/types.d.ts.map +1 -0
- package/packages/agent/src/hooks/types.js +8 -0
- package/packages/agent/src/index.d.ts +20 -0
- package/packages/agent/src/index.d.ts.map +1 -0
- package/packages/agent/src/index.js +19 -0
- package/packages/agent/src/onboarding-presets.d.ts +78 -0
- package/packages/agent/src/onboarding-presets.d.ts.map +1 -0
- package/packages/agent/src/onboarding-presets.js +1352 -0
- package/packages/agent/src/plugins/custom-rtmp/index.d.ts +12 -0
- package/packages/agent/src/plugins/custom-rtmp/index.d.ts.map +1 -0
- package/packages/agent/src/plugins/custom-rtmp/index.js +26 -0
- package/packages/agent/src/providers/admin-trust.d.ts +4 -0
- package/packages/agent/src/providers/admin-trust.d.ts.map +1 -0
- package/packages/agent/src/providers/admin-trust.js +53 -0
- package/packages/agent/src/providers/session-bridge.d.ts +24 -0
- package/packages/agent/src/providers/session-bridge.d.ts.map +1 -0
- package/packages/agent/src/providers/session-bridge.js +85 -0
- package/packages/agent/src/providers/session-utils.d.ts +20 -0
- package/packages/agent/src/providers/session-utils.d.ts.map +1 -0
- package/packages/agent/src/providers/session-utils.js +33 -0
- package/packages/agent/src/providers/simple-mode.d.ts +4 -0
- package/packages/agent/src/providers/simple-mode.d.ts.map +1 -0
- package/packages/agent/src/providers/simple-mode.js +85 -0
- package/packages/agent/src/providers/ui-catalog.d.ts +3 -0
- package/packages/agent/src/providers/ui-catalog.d.ts.map +1 -0
- package/packages/agent/src/providers/ui-catalog.js +123 -0
- package/packages/agent/src/providers/workspace-provider.d.ts +22 -0
- package/packages/agent/src/providers/workspace-provider.d.ts.map +1 -0
- package/packages/agent/src/providers/workspace-provider.js +167 -0
- package/packages/agent/src/providers/workspace.d.ts +54 -0
- package/packages/agent/src/providers/workspace.d.ts.map +1 -0
- package/packages/agent/src/providers/workspace.js +405 -0
- package/packages/agent/src/runtime/agent-event-service.d.ts +35 -0
- package/packages/agent/src/runtime/agent-event-service.d.ts.map +1 -0
- package/packages/agent/src/runtime/agent-event-service.js +16 -0
- package/packages/agent/src/runtime/cloud-onboarding.d.ts +55 -0
- package/packages/agent/src/runtime/cloud-onboarding.d.ts.map +1 -0
- package/packages/agent/src/runtime/cloud-onboarding.js +279 -0
- package/packages/agent/src/runtime/core-plugins.d.ts +14 -0
- package/packages/agent/src/runtime/core-plugins.d.ts.map +1 -0
- package/packages/agent/src/runtime/core-plugins.js +51 -0
- package/packages/agent/src/runtime/custom-actions.d.ts +40 -0
- package/packages/agent/src/runtime/custom-actions.d.ts.map +1 -0
- package/packages/agent/src/runtime/custom-actions.js +454 -0
- package/packages/agent/src/runtime/eliza-plugin.d.ts +16 -0
- package/packages/agent/src/runtime/eliza-plugin.d.ts.map +1 -0
- package/packages/agent/src/runtime/eliza-plugin.js +108 -0
- package/packages/agent/src/runtime/eliza.d.ts +205 -0
- package/packages/agent/src/runtime/eliza.d.ts.map +1 -0
- package/packages/agent/src/runtime/eliza.js +3935 -0
- package/packages/agent/src/runtime/embedding-presets.d.ts +19 -0
- package/packages/agent/src/runtime/embedding-presets.d.ts.map +1 -0
- package/packages/agent/src/runtime/embedding-presets.js +53 -0
- package/packages/agent/src/runtime/index.d.ts +9 -0
- package/packages/agent/src/runtime/index.d.ts.map +1 -0
- package/packages/agent/src/runtime/index.js +8 -0
- package/packages/agent/src/runtime/onboarding-names.d.ts +11 -0
- package/packages/agent/src/runtime/onboarding-names.d.ts.map +1 -0
- package/packages/agent/src/runtime/onboarding-names.js +74 -0
- package/packages/agent/src/runtime/release-plugin-policy.d.ts +20 -0
- package/packages/agent/src/runtime/release-plugin-policy.d.ts.map +1 -0
- package/packages/agent/src/runtime/release-plugin-policy.js +87 -0
- package/packages/agent/src/runtime/restart.d.ts +45 -0
- package/packages/agent/src/runtime/restart.d.ts.map +1 -0
- package/packages/agent/src/runtime/restart.js +45 -0
- package/packages/agent/src/runtime/trajectory-persistence.d.ts +214 -0
- package/packages/agent/src/runtime/trajectory-persistence.d.ts.map +1 -0
- package/packages/agent/src/runtime/trajectory-persistence.js +1957 -0
- package/packages/agent/src/runtime/version.d.ts +2 -0
- package/packages/agent/src/runtime/version.d.ts.map +1 -0
- package/packages/agent/src/runtime/version.js +5 -0
- package/packages/agent/src/security/audit-log.d.ts +49 -0
- package/packages/agent/src/security/audit-log.d.ts.map +1 -0
- package/packages/agent/src/security/audit-log.js +161 -0
- package/packages/agent/src/security/network-policy.d.ts +6 -0
- package/packages/agent/src/security/network-policy.d.ts.map +1 -0
- package/packages/agent/src/security/network-policy.js +85 -0
- package/packages/agent/src/server/index.d.ts +3 -0
- package/packages/agent/src/server/index.d.ts.map +1 -0
- package/packages/agent/src/server/index.js +1 -0
- package/packages/agent/src/services/agent-export.d.ts +100 -0
- package/packages/agent/src/services/agent-export.d.ts.map +1 -0
- package/packages/agent/src/services/agent-export.js +729 -0
- package/packages/agent/src/services/app-manager.d.ts +34 -0
- package/packages/agent/src/services/app-manager.d.ts.map +1 -0
- package/packages/agent/src/services/app-manager.js +425 -0
- package/packages/agent/src/services/browser-capture.d.ts +39 -0
- package/packages/agent/src/services/browser-capture.d.ts.map +1 -0
- package/packages/agent/src/services/browser-capture.js +162 -0
- package/packages/agent/src/services/coding-agent-context.d.ts +310 -0
- package/packages/agent/src/services/coding-agent-context.d.ts.map +1 -0
- package/packages/agent/src/services/coding-agent-context.js +281 -0
- package/packages/agent/src/services/fallback-training-service.d.ts +78 -0
- package/packages/agent/src/services/fallback-training-service.d.ts.map +1 -0
- package/packages/agent/src/services/fallback-training-service.js +126 -0
- package/packages/agent/src/services/index.d.ts +18 -0
- package/packages/agent/src/services/index.d.ts.map +1 -0
- package/packages/agent/src/services/index.js +17 -0
- package/packages/agent/src/services/mcp-marketplace.d.ts +89 -0
- package/packages/agent/src/services/mcp-marketplace.d.ts.map +1 -0
- package/packages/agent/src/services/mcp-marketplace.js +200 -0
- package/packages/agent/src/services/plugin-manager-types.d.ts +139 -0
- package/packages/agent/src/services/plugin-manager-types.d.ts.map +1 -0
- package/packages/agent/src/services/plugin-manager-types.js +18 -0
- package/packages/agent/src/services/privy-wallets.d.ts +18 -0
- package/packages/agent/src/services/privy-wallets.d.ts.map +1 -0
- package/packages/agent/src/services/privy-wallets.js +225 -0
- package/packages/agent/src/services/registry-client-app-meta.d.ts +6 -0
- package/packages/agent/src/services/registry-client-app-meta.d.ts.map +1 -0
- package/packages/agent/src/services/registry-client-app-meta.js +147 -0
- package/packages/agent/src/services/registry-client-endpoints.d.ts +7 -0
- package/packages/agent/src/services/registry-client-endpoints.d.ts.map +1 -0
- package/packages/agent/src/services/registry-client-endpoints.js +183 -0
- package/packages/agent/src/services/registry-client-local.d.ts +4 -0
- package/packages/agent/src/services/registry-client-local.d.ts.map +1 -0
- package/packages/agent/src/services/registry-client-local.js +377 -0
- package/packages/agent/src/services/registry-client-network.d.ts +9 -0
- package/packages/agent/src/services/registry-client-network.d.ts.map +1 -0
- package/packages/agent/src/services/registry-client-network.js +109 -0
- package/packages/agent/src/services/registry-client-queries.d.ts +15 -0
- package/packages/agent/src/services/registry-client-queries.d.ts.map +1 -0
- package/packages/agent/src/services/registry-client-queries.js +150 -0
- package/packages/agent/src/services/registry-client-types.d.ts +115 -0
- package/packages/agent/src/services/registry-client-types.d.ts.map +1 -0
- package/packages/agent/src/services/registry-client-types.js +1 -0
- package/packages/agent/src/services/registry-client.d.ts +39 -0
- package/packages/agent/src/services/registry-client.d.ts.map +1 -0
- package/packages/agent/src/services/registry-client.js +249 -0
- package/packages/agent/src/services/remote-signing-service.d.ts +58 -0
- package/packages/agent/src/services/remote-signing-service.d.ts.map +1 -0
- package/packages/agent/src/services/remote-signing-service.js +185 -0
- package/packages/agent/src/services/sandbox-engine.d.ts +96 -0
- package/packages/agent/src/services/sandbox-engine.d.ts.map +1 -0
- package/packages/agent/src/services/sandbox-engine.js +604 -0
- package/packages/agent/src/services/sandbox-manager.d.ts +104 -0
- package/packages/agent/src/services/sandbox-manager.d.ts.map +1 -0
- package/packages/agent/src/services/sandbox-manager.js +353 -0
- package/packages/agent/src/services/self-updater.d.ts +21 -0
- package/packages/agent/src/services/self-updater.d.ts.map +1 -0
- package/packages/agent/src/services/self-updater.js +162 -0
- package/packages/agent/src/services/signal-pairing.d.ts +37 -0
- package/packages/agent/src/services/signal-pairing.d.ts.map +1 -0
- package/packages/agent/src/services/signal-pairing.js +124 -0
- package/packages/agent/src/services/signing-policy.d.ts +44 -0
- package/packages/agent/src/services/signing-policy.d.ts.map +1 -0
- package/packages/agent/src/services/signing-policy.js +165 -0
- package/packages/agent/src/services/skill-catalog-client.d.ts +47 -0
- package/packages/agent/src/services/skill-catalog-client.d.ts.map +1 -0
- package/packages/agent/src/services/skill-catalog-client.js +130 -0
- package/packages/agent/src/services/skill-marketplace.d.ts +42 -0
- package/packages/agent/src/services/skill-marketplace.d.ts.map +1 -0
- package/packages/agent/src/services/skill-marketplace.js +680 -0
- package/packages/agent/src/services/stream-manager.d.ts +121 -0
- package/packages/agent/src/services/stream-manager.d.ts.map +1 -0
- package/packages/agent/src/services/stream-manager.js +604 -0
- package/packages/agent/src/services/tts-stream-bridge.d.ts +83 -0
- package/packages/agent/src/services/tts-stream-bridge.d.ts.map +1 -0
- package/packages/agent/src/services/tts-stream-bridge.js +349 -0
- package/packages/agent/src/services/update-checker.d.ts +29 -0
- package/packages/agent/src/services/update-checker.d.ts.map +1 -0
- package/packages/agent/src/services/update-checker.js +134 -0
- package/packages/agent/src/services/version-compat.d.ts +99 -0
- package/packages/agent/src/services/version-compat.d.ts.map +1 -0
- package/packages/agent/src/services/version-compat.js +195 -0
- package/packages/agent/src/services/whatsapp-pairing.d.ts +41 -0
- package/packages/agent/src/services/whatsapp-pairing.d.ts.map +1 -0
- package/packages/agent/src/services/whatsapp-pairing.js +209 -0
- package/packages/agent/src/shared/ui-catalog-prompt.d.ts +52 -0
- package/packages/agent/src/shared/ui-catalog-prompt.d.ts.map +1 -0
- package/packages/agent/src/shared/ui-catalog-prompt.js +1028 -0
- package/packages/agent/src/test-support/process-helpers.d.ts +13 -0
- package/packages/agent/src/test-support/process-helpers.d.ts.map +1 -0
- package/packages/agent/src/test-support/process-helpers.js +23 -0
- package/packages/agent/src/test-support/route-test-helpers.d.ts +37 -0
- package/packages/agent/src/test-support/route-test-helpers.d.ts.map +1 -0
- package/packages/agent/src/test-support/route-test-helpers.js +54 -0
- package/packages/agent/src/test-support/test-helpers.d.ts +77 -0
- package/packages/agent/src/test-support/test-helpers.d.ts.map +1 -0
- package/packages/agent/src/test-support/test-helpers.js +210 -0
- package/packages/agent/src/testing/index.d.ts +4 -0
- package/packages/agent/src/testing/index.d.ts.map +1 -0
- package/packages/agent/src/testing/index.js +3 -0
- package/packages/agent/src/triggers/action.d.ts +3 -0
- package/packages/agent/src/triggers/action.d.ts.map +1 -0
- package/packages/agent/src/triggers/action.js +267 -0
- package/packages/agent/src/triggers/runtime.d.ts +24 -0
- package/packages/agent/src/triggers/runtime.d.ts.map +1 -0
- package/packages/agent/src/triggers/runtime.js +322 -0
- package/packages/agent/src/triggers/scheduling.d.ts +70 -0
- package/packages/agent/src/triggers/scheduling.d.ts.map +1 -0
- package/packages/agent/src/triggers/scheduling.js +355 -0
- package/packages/agent/src/triggers/types.d.ts +115 -0
- package/packages/agent/src/triggers/types.d.ts.map +1 -0
- package/packages/agent/src/triggers/types.js +1 -0
- package/packages/agent/src/utils/exec-safety.d.ts +2 -0
- package/packages/agent/src/utils/exec-safety.d.ts.map +1 -0
- package/packages/agent/src/utils/exec-safety.js +21 -0
- package/packages/agent/src/utils/number-parsing.d.ts +26 -0
- package/packages/agent/src/utils/number-parsing.d.ts.map +1 -0
- package/packages/agent/src/utils/number-parsing.js +52 -0
- package/packages/agent/src/utils/spoken-text.d.ts +2 -0
- package/packages/agent/src/utils/spoken-text.d.ts.map +1 -0
- package/packages/agent/src/utils/spoken-text.js +56 -0
- package/packages/agent/src/version-resolver.d.ts +3 -0
- package/packages/agent/src/version-resolver.d.ts.map +1 -0
- package/packages/agent/src/version-resolver.js +51 -0
- package/jest.config.js +0 -17
- package/src/__tests__/client-type-identification.test.ts +0 -59
- package/src/defaultCharacter.ts +0 -530
- package/src/index.ts +0 -865
- package/tsconfig.json +0 -16
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import type { IncomingMessage, ServerResponse } from "node:http";
|
|
2
|
+
import type { StreamRouteState } from "./stream-route-state";
|
|
3
|
+
interface StreamVoiceSettings {
|
|
4
|
+
enabled?: boolean;
|
|
5
|
+
autoSpeak?: boolean;
|
|
6
|
+
provider?: string;
|
|
7
|
+
}
|
|
8
|
+
interface StreamSettingsLike {
|
|
9
|
+
voice?: StreamVoiceSettings;
|
|
10
|
+
}
|
|
11
|
+
interface TtsBridgeLike {
|
|
12
|
+
isSpeaking(): boolean;
|
|
13
|
+
isAttached(): boolean;
|
|
14
|
+
speak(text: string, config: Record<string, unknown>): Promise<boolean>;
|
|
15
|
+
}
|
|
16
|
+
export interface StreamVoiceRouteContext {
|
|
17
|
+
req: IncomingMessage;
|
|
18
|
+
res: ServerResponse;
|
|
19
|
+
pathname: string;
|
|
20
|
+
method: string;
|
|
21
|
+
state: StreamRouteState;
|
|
22
|
+
getTtsProviderStatus: (config: unknown) => {
|
|
23
|
+
resolvedProvider: string | null;
|
|
24
|
+
configuredProvider: string | null;
|
|
25
|
+
hasApiKey: boolean;
|
|
26
|
+
};
|
|
27
|
+
resolveTtsConfig: (config: unknown) => Record<string, unknown> | null;
|
|
28
|
+
ttsStreamBridge: TtsBridgeLike;
|
|
29
|
+
sanitizeSpeechText: (text: string) => string;
|
|
30
|
+
readStreamSettings: () => StreamSettingsLike;
|
|
31
|
+
writeStreamSettings: (settings: StreamSettingsLike) => void;
|
|
32
|
+
}
|
|
33
|
+
export declare function handleStreamVoiceRoute(ctx: StreamVoiceRouteContext): Promise<boolean>;
|
|
34
|
+
export declare function onAgentMessage(text: string, state: StreamRouteState, deps: Pick<StreamVoiceRouteContext, "sanitizeSpeechText" | "readStreamSettings" | "resolveTtsConfig" | "ttsStreamBridge">): Promise<void>;
|
|
35
|
+
export {};
|
|
36
|
+
//# sourceMappingURL=stream-voice-routes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"stream-voice-routes.d.ts","sourceRoot":"","sources":["../../../../../src/api/stream-voice-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,WAAW,CAAC;AAGjE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAE7D,UAAU,mBAAmB;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,UAAU,kBAAkB;IAC1B,KAAK,CAAC,EAAE,mBAAmB,CAAC;CAC7B;AAED,UAAU,aAAa;IACrB,UAAU,IAAI,OAAO,CAAC;IACtB,UAAU,IAAI,OAAO,CAAC;IACtB,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;CACxE;AAED,MAAM,WAAW,uBAAuB;IACtC,GAAG,EAAE,eAAe,CAAC;IACrB,GAAG,EAAE,cAAc,CAAC;IACpB,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,EAAE,gBAAgB,CAAC;IACxB,oBAAoB,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK;QACzC,gBAAgB,EAAE,MAAM,GAAG,IAAI,CAAC;QAChC,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;QAClC,SAAS,EAAE,OAAO,CAAC;KACpB,CAAC;IACF,gBAAgB,EAAE,CAAC,MAAM,EAAE,OAAO,KAAK,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IACtE,eAAe,EAAE,aAAa,CAAC;IAC/B,kBAAkB,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,MAAM,CAAC;IAC7C,kBAAkB,EAAE,MAAM,kBAAkB,CAAC;IAC7C,mBAAmB,EAAE,CAAC,QAAQ,EAAE,kBAAkB,KAAK,IAAI,CAAC;CAC7D;AAYD,wBAAsB,sBAAsB,CAC1C,GAAG,EAAE,uBAAuB,GAC3B,OAAO,CAAC,OAAO,CAAC,CAyIlB;AAED,wBAAsB,cAAc,CAClC,IAAI,EAAE,MAAM,EACZ,KAAK,EAAE,gBAAgB,EACvB,IAAI,EAAE,IAAI,CACR,uBAAuB,EACrB,oBAAoB,GACpB,oBAAoB,GACpB,kBAAkB,GAClB,iBAAiB,CACpB,GACA,OAAO,CAAC,IAAI,CAAC,CAqBf"}
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
import { logger } from "@elizaos/core";
|
|
2
|
+
import { readRequestBody, sendJson, sendJsonError } from "./http-helpers";
|
|
3
|
+
const SPEAK_TEXT_MAX_CHARS = 2000;
|
|
4
|
+
function json(res, data, status = 200) {
|
|
5
|
+
sendJson(res, data, status);
|
|
6
|
+
}
|
|
7
|
+
function error(res, message, status) {
|
|
8
|
+
sendJsonError(res, message, status);
|
|
9
|
+
}
|
|
10
|
+
export async function handleStreamVoiceRoute(ctx) {
|
|
11
|
+
const { req, res, pathname, method, state, getTtsProviderStatus, resolveTtsConfig, ttsStreamBridge, sanitizeSpeechText, readStreamSettings, writeStreamSettings, } = ctx;
|
|
12
|
+
if (method === "GET" && pathname === "/api/stream/voice") {
|
|
13
|
+
try {
|
|
14
|
+
const settings = readStreamSettings();
|
|
15
|
+
const ttsConf = state.config?.messages?.tts;
|
|
16
|
+
const providerStatus = getTtsProviderStatus(ttsConf);
|
|
17
|
+
json(res, {
|
|
18
|
+
ok: true,
|
|
19
|
+
enabled: settings.voice?.enabled === true,
|
|
20
|
+
autoSpeak: settings.voice?.autoSpeak === true,
|
|
21
|
+
provider: providerStatus.resolvedProvider,
|
|
22
|
+
configuredProvider: providerStatus.configuredProvider,
|
|
23
|
+
hasApiKey: providerStatus.hasApiKey,
|
|
24
|
+
isSpeaking: ttsStreamBridge.isSpeaking(),
|
|
25
|
+
isAttached: ttsStreamBridge.isAttached(),
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
catch (err) {
|
|
29
|
+
error(res, err instanceof Error ? err.message : "Failed to read voice config", 500);
|
|
30
|
+
}
|
|
31
|
+
return true;
|
|
32
|
+
}
|
|
33
|
+
if (method === "POST" && pathname === "/api/stream/voice") {
|
|
34
|
+
try {
|
|
35
|
+
const body = await readRequestBody(req, {
|
|
36
|
+
maxBytes: 2048,
|
|
37
|
+
returnNullOnTooLarge: true,
|
|
38
|
+
});
|
|
39
|
+
if (body === null) {
|
|
40
|
+
error(res, "Request body too large", 413);
|
|
41
|
+
return true;
|
|
42
|
+
}
|
|
43
|
+
const parsed = typeof body === "string" ? JSON.parse(body) : body;
|
|
44
|
+
const current = readStreamSettings();
|
|
45
|
+
const voice = {
|
|
46
|
+
enabled: current.voice?.enabled ?? false,
|
|
47
|
+
autoSpeak: current.voice?.autoSpeak ?? false,
|
|
48
|
+
};
|
|
49
|
+
if (typeof parsed?.enabled === "boolean")
|
|
50
|
+
voice.enabled = parsed.enabled;
|
|
51
|
+
if (typeof parsed?.autoSpeak === "boolean") {
|
|
52
|
+
voice.autoSpeak = parsed.autoSpeak;
|
|
53
|
+
}
|
|
54
|
+
if (typeof parsed?.provider === "string") {
|
|
55
|
+
voice.provider = parsed.provider;
|
|
56
|
+
}
|
|
57
|
+
current.voice = voice;
|
|
58
|
+
writeStreamSettings(current);
|
|
59
|
+
json(res, { ok: true, voice });
|
|
60
|
+
}
|
|
61
|
+
catch (err) {
|
|
62
|
+
error(res, err instanceof Error ? err.message : "Failed to save voice settings", 500);
|
|
63
|
+
}
|
|
64
|
+
return true;
|
|
65
|
+
}
|
|
66
|
+
if (method === "POST" && pathname === "/api/stream/voice/speak") {
|
|
67
|
+
try {
|
|
68
|
+
const body = await readRequestBody(req, {
|
|
69
|
+
maxBytes: 8192,
|
|
70
|
+
returnNullOnTooLarge: true,
|
|
71
|
+
});
|
|
72
|
+
if (body === null) {
|
|
73
|
+
error(res, "Request body too large", 413);
|
|
74
|
+
return true;
|
|
75
|
+
}
|
|
76
|
+
const parsed = typeof body === "string" ? JSON.parse(body) : body;
|
|
77
|
+
const text = typeof parsed?.text === "string" ? sanitizeSpeechText(parsed.text) : "";
|
|
78
|
+
if (!text) {
|
|
79
|
+
error(res, "text must include speakable content", 400);
|
|
80
|
+
return true;
|
|
81
|
+
}
|
|
82
|
+
if (text.length > SPEAK_TEXT_MAX_CHARS) {
|
|
83
|
+
error(res, `text exceeds maximum length of ${SPEAK_TEXT_MAX_CHARS} characters`, 400);
|
|
84
|
+
return true;
|
|
85
|
+
}
|
|
86
|
+
const ttsConf = state.config?.messages?.tts;
|
|
87
|
+
const resolved = resolveTtsConfig(ttsConf);
|
|
88
|
+
if (!resolved) {
|
|
89
|
+
error(res, "No TTS provider available. Configure API keys in Secrets.", 400);
|
|
90
|
+
return true;
|
|
91
|
+
}
|
|
92
|
+
if (!ttsStreamBridge.isAttached()) {
|
|
93
|
+
error(res, "TTS bridge not attached — start stream with voice enabled first", 400);
|
|
94
|
+
return true;
|
|
95
|
+
}
|
|
96
|
+
if (ttsStreamBridge.isSpeaking()) {
|
|
97
|
+
error(res, "Already speaking — wait for current speech to finish", 429);
|
|
98
|
+
return true;
|
|
99
|
+
}
|
|
100
|
+
const speaking = await ttsStreamBridge.speak(text, resolved);
|
|
101
|
+
json(res, { ok: true, speaking });
|
|
102
|
+
}
|
|
103
|
+
catch (err) {
|
|
104
|
+
error(res, err instanceof Error ? err.message : "TTS speak failed", 500);
|
|
105
|
+
}
|
|
106
|
+
return true;
|
|
107
|
+
}
|
|
108
|
+
return false;
|
|
109
|
+
}
|
|
110
|
+
export async function onAgentMessage(text, state, deps) {
|
|
111
|
+
const speakableText = deps.sanitizeSpeechText(text);
|
|
112
|
+
if (!speakableText)
|
|
113
|
+
return;
|
|
114
|
+
if (!state.streamManager.isRunning())
|
|
115
|
+
return;
|
|
116
|
+
if (!deps.ttsStreamBridge.isAttached())
|
|
117
|
+
return;
|
|
118
|
+
const settings = deps.readStreamSettings();
|
|
119
|
+
if (!settings.voice?.enabled)
|
|
120
|
+
return;
|
|
121
|
+
if (settings.voice.autoSpeak === false)
|
|
122
|
+
return;
|
|
123
|
+
const ttsConf = state.config?.messages?.tts;
|
|
124
|
+
const resolved = deps.resolveTtsConfig(ttsConf);
|
|
125
|
+
if (!resolved)
|
|
126
|
+
return;
|
|
127
|
+
try {
|
|
128
|
+
await deps.ttsStreamBridge.speak(speakableText, resolved);
|
|
129
|
+
}
|
|
130
|
+
catch (err) {
|
|
131
|
+
logger.warn(`[stream-voice] Auto-TTS failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export type StreamingUpdateKind = "noop" | "append" | "replace";
|
|
2
|
+
export interface StreamingUpdate {
|
|
3
|
+
kind: StreamingUpdateKind;
|
|
4
|
+
nextText: string;
|
|
5
|
+
emittedText: string;
|
|
6
|
+
}
|
|
7
|
+
export declare function mergeStreamingText(existing: string, incoming: string): string;
|
|
8
|
+
export declare function resolveStreamingUpdate(existing: string, incoming: string): StreamingUpdate;
|
|
9
|
+
//# sourceMappingURL=streaming-text.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"streaming-text.d.ts","sourceRoot":"","sources":["../../../../../src/api/streaming-text.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,mBAAmB,GAAG,MAAM,GAAG,QAAQ,GAAG,SAAS,CAAC;AAEhE,MAAM,WAAW,eAAe;IAC9B,IAAI,EAAE,mBAAmB,CAAC;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,WAAW,EAAE,MAAM,CAAC;CACrB;AAqDD,wBAAgB,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,MAAM,CA6C7E;AAED,wBAAgB,sBAAsB,CACpC,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,GACf,eAAe,CAmBjB"}
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
function commonPrefixLength(left, right) {
|
|
2
|
+
const maxLength = Math.min(left.length, right.length);
|
|
3
|
+
let index = 0;
|
|
4
|
+
while (index < maxLength &&
|
|
5
|
+
left.charCodeAt(index) === right.charCodeAt(index)) {
|
|
6
|
+
index += 1;
|
|
7
|
+
}
|
|
8
|
+
return index;
|
|
9
|
+
}
|
|
10
|
+
function commonSuffixLength(left, right, sharedPrefixLength) {
|
|
11
|
+
const maxLength = Math.min(left.length - sharedPrefixLength, right.length - sharedPrefixLength);
|
|
12
|
+
let length = 0;
|
|
13
|
+
while (length < maxLength &&
|
|
14
|
+
left.charCodeAt(left.length - 1 - length) ===
|
|
15
|
+
right.charCodeAt(right.length - 1 - length)) {
|
|
16
|
+
length += 1;
|
|
17
|
+
}
|
|
18
|
+
return length;
|
|
19
|
+
}
|
|
20
|
+
function isLikelySnapshotReplacement(existing, incoming) {
|
|
21
|
+
const sharedPrefixLength = commonPrefixLength(existing, incoming);
|
|
22
|
+
const sharedSuffixLength = commonSuffixLength(existing, incoming, sharedPrefixLength);
|
|
23
|
+
const sharedLength = sharedPrefixLength + sharedSuffixLength;
|
|
24
|
+
const minLength = Math.min(existing.length, incoming.length);
|
|
25
|
+
return (sharedPrefixLength >= 8 ||
|
|
26
|
+
sharedLength >= Math.max(4, Math.ceil(minLength * 0.7)));
|
|
27
|
+
}
|
|
28
|
+
export function mergeStreamingText(existing, incoming) {
|
|
29
|
+
if (!incoming)
|
|
30
|
+
return existing;
|
|
31
|
+
if (!existing)
|
|
32
|
+
return incoming;
|
|
33
|
+
if (incoming === existing)
|
|
34
|
+
return existing;
|
|
35
|
+
if (incoming.startsWith(existing)) {
|
|
36
|
+
return incoming;
|
|
37
|
+
}
|
|
38
|
+
if (incoming.includes(existing)) {
|
|
39
|
+
return incoming;
|
|
40
|
+
}
|
|
41
|
+
if (existing.startsWith(incoming)) {
|
|
42
|
+
return existing;
|
|
43
|
+
}
|
|
44
|
+
const maxOverlap = Math.min(existing.length, incoming.length);
|
|
45
|
+
const existingLength = existing.length;
|
|
46
|
+
for (let overlap = maxOverlap; overlap > 0; overlap -= 1) {
|
|
47
|
+
const existingStart = existingLength - overlap;
|
|
48
|
+
let match = true;
|
|
49
|
+
for (let index = 0; index < overlap; index += 1) {
|
|
50
|
+
if (existing.charCodeAt(existingStart + index) !==
|
|
51
|
+
incoming.charCodeAt(index)) {
|
|
52
|
+
match = false;
|
|
53
|
+
break;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
if (!match)
|
|
57
|
+
continue;
|
|
58
|
+
if (overlap === incoming.length) {
|
|
59
|
+
return incoming.length === 1 ? `${existing}${incoming}` : existing;
|
|
60
|
+
}
|
|
61
|
+
return `${existing}${incoming.slice(overlap)}`;
|
|
62
|
+
}
|
|
63
|
+
if (isLikelySnapshotReplacement(existing, incoming)) {
|
|
64
|
+
return incoming;
|
|
65
|
+
}
|
|
66
|
+
return `${existing}${incoming}`;
|
|
67
|
+
}
|
|
68
|
+
export function resolveStreamingUpdate(existing, incoming) {
|
|
69
|
+
const nextText = mergeStreamingText(existing, incoming);
|
|
70
|
+
if (nextText === existing) {
|
|
71
|
+
return { kind: "noop", nextText: existing, emittedText: "" };
|
|
72
|
+
}
|
|
73
|
+
if (nextText.startsWith(existing)) {
|
|
74
|
+
return {
|
|
75
|
+
kind: "append",
|
|
76
|
+
nextText,
|
|
77
|
+
emittedText: nextText.slice(existing.length),
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
return {
|
|
81
|
+
kind: "replace",
|
|
82
|
+
nextText,
|
|
83
|
+
emittedText: nextText,
|
|
84
|
+
};
|
|
85
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
export interface OverlayWidgetInstance {
|
|
2
|
+
id: string;
|
|
3
|
+
type: string;
|
|
4
|
+
enabled: boolean;
|
|
5
|
+
position: {
|
|
6
|
+
x: number;
|
|
7
|
+
y: number;
|
|
8
|
+
width: number;
|
|
9
|
+
height: number;
|
|
10
|
+
};
|
|
11
|
+
zIndex: number;
|
|
12
|
+
config: Record<string, unknown>;
|
|
13
|
+
}
|
|
14
|
+
export interface OverlayLayoutData {
|
|
15
|
+
version: 1;
|
|
16
|
+
name: string;
|
|
17
|
+
widgets: OverlayWidgetInstance[];
|
|
18
|
+
}
|
|
19
|
+
export interface StreamingDestination {
|
|
20
|
+
id: string;
|
|
21
|
+
name: string;
|
|
22
|
+
getCredentials(): Promise<{
|
|
23
|
+
rtmpUrl: string;
|
|
24
|
+
rtmpKey: string;
|
|
25
|
+
}>;
|
|
26
|
+
onStreamStart?(): Promise<void>;
|
|
27
|
+
onStreamStop?(): Promise<void>;
|
|
28
|
+
defaultOverlayLayout?: OverlayLayoutData;
|
|
29
|
+
}
|
|
30
|
+
//# sourceMappingURL=streaming-types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"streaming-types.d.ts","sourceRoot":"","sources":["../../../../../src/api/streaming-types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,qBAAqB;IACpC,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,EAAE;QAAE,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC;IAClE,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC;AAED,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,CAAC,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,qBAAqB,EAAE,CAAC;CAClC;AAED,MAAM,WAAW,oBAAoB;IACnC,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE,MAAM,CAAC;IACb,cAAc,IAAI,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IAChE,aAAa,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAChC,YAAY,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC/B,oBAAoB,CAAC,EAAE,iBAAiB,CAAC;CAC1C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import type { AnthropicFlow } from "../auth/anthropic";
|
|
2
|
+
import type { CodexFlow } from "../auth/openai-codex";
|
|
3
|
+
import type { ElizaConfig } from "../config/types.eliza";
|
|
4
|
+
import type { RouteRequestContext } from "./route-helpers";
|
|
5
|
+
type AuthModule = typeof import("../auth/index");
|
|
6
|
+
export type SubscriptionAuthApi = Pick<AuthModule, "getSubscriptionStatus" | "startAnthropicLogin" | "startCodexLogin" | "saveCredentials" | "applySubscriptionCredentials" | "deleteCredentials">;
|
|
7
|
+
export interface SubscriptionRouteState {
|
|
8
|
+
config: ElizaConfig;
|
|
9
|
+
_anthropicFlow?: AnthropicFlow;
|
|
10
|
+
_codexFlow?: CodexFlow;
|
|
11
|
+
_codexFlowTimer?: ReturnType<typeof setTimeout>;
|
|
12
|
+
}
|
|
13
|
+
export interface SubscriptionRouteContext extends RouteRequestContext {
|
|
14
|
+
state: SubscriptionRouteState;
|
|
15
|
+
saveConfig: (config: ElizaConfig) => void;
|
|
16
|
+
loadSubscriptionAuth: () => Promise<SubscriptionAuthApi>;
|
|
17
|
+
}
|
|
18
|
+
export declare function handleSubscriptionRoutes(ctx: SubscriptionRouteContext): Promise<boolean>;
|
|
19
|
+
export {};
|
|
20
|
+
//# sourceMappingURL=subscription-routes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"subscription-routes.d.ts","sourceRoot":"","sources":["../../../../../src/api/subscription-routes.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,mBAAmB,CAAC;AACvD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAEtD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AACzD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAE3D,KAAK,UAAU,GAAG,cAAc,eAAe,CAAC,CAAC;AAEjD,MAAM,MAAM,mBAAmB,GAAG,IAAI,CACpC,UAAU,EACR,uBAAuB,GACvB,qBAAqB,GACrB,iBAAiB,GACjB,iBAAiB,GACjB,8BAA8B,GAC9B,mBAAmB,CACtB,CAAC;AAEF,MAAM,WAAW,sBAAsB;IACrC,MAAM,EAAE,WAAW,CAAC;IACpB,cAAc,CAAC,EAAE,aAAa,CAAC;IAC/B,UAAU,CAAC,EAAE,SAAS,CAAC;IACvB,eAAe,CAAC,EAAE,UAAU,CAAC,OAAO,UAAU,CAAC,CAAC;CACjD;AAED,MAAM,WAAW,wBAAyB,SAAQ,mBAAmB;IACnE,KAAK,EAAE,sBAAsB,CAAC;IAC9B,UAAU,EAAE,CAAC,MAAM,EAAE,WAAW,KAAK,IAAI,CAAC;IAC1C,oBAAoB,EAAE,MAAM,OAAO,CAAC,mBAAmB,CAAC,CAAC;CAC1D;AAED,wBAAsB,wBAAwB,CAC5C,GAAG,EAAE,wBAAwB,GAC5B,OAAO,CAAC,OAAO,CAAC,CAoOlB"}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { logger } from "@elizaos/core";
|
|
2
|
+
export async function handleSubscriptionRoutes(ctx) {
|
|
3
|
+
const { req, res, method, pathname, state, readJsonBody, json, error, loadSubscriptionAuth, } = ctx;
|
|
4
|
+
if (!pathname.startsWith("/api/subscription/"))
|
|
5
|
+
return false;
|
|
6
|
+
if (method === "GET" && pathname === "/api/subscription/status") {
|
|
7
|
+
try {
|
|
8
|
+
const { getSubscriptionStatus } = await loadSubscriptionAuth();
|
|
9
|
+
json(res, { providers: getSubscriptionStatus() });
|
|
10
|
+
}
|
|
11
|
+
catch (err) {
|
|
12
|
+
logger.error(`[api] Failed to get subscription status: ${err instanceof Error ? err.stack : err}`);
|
|
13
|
+
error(res, "Failed to get subscription status", 500);
|
|
14
|
+
}
|
|
15
|
+
return true;
|
|
16
|
+
}
|
|
17
|
+
if (method === "POST" && pathname === "/api/subscription/anthropic/start") {
|
|
18
|
+
try {
|
|
19
|
+
const { startAnthropicLogin } = await loadSubscriptionAuth();
|
|
20
|
+
const flow = await startAnthropicLogin();
|
|
21
|
+
state._anthropicFlow = flow;
|
|
22
|
+
json(res, { authUrl: flow.authUrl });
|
|
23
|
+
}
|
|
24
|
+
catch (err) {
|
|
25
|
+
logger.error(`[api] Failed to start Anthropic login: ${err instanceof Error ? err.stack : err}`);
|
|
26
|
+
error(res, "Failed to start Anthropic login", 500);
|
|
27
|
+
}
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
if (method === "POST" &&
|
|
31
|
+
pathname === "/api/subscription/anthropic/exchange") {
|
|
32
|
+
const body = await readJsonBody(req, res);
|
|
33
|
+
if (!body)
|
|
34
|
+
return true;
|
|
35
|
+
if (!body.code) {
|
|
36
|
+
error(res, "Missing code", 400);
|
|
37
|
+
return true;
|
|
38
|
+
}
|
|
39
|
+
try {
|
|
40
|
+
const { saveCredentials, applySubscriptionCredentials } = await loadSubscriptionAuth();
|
|
41
|
+
const flow = state._anthropicFlow;
|
|
42
|
+
if (!flow) {
|
|
43
|
+
error(res, "No active flow — call /start first", 400);
|
|
44
|
+
return true;
|
|
45
|
+
}
|
|
46
|
+
flow.submitCode(body.code);
|
|
47
|
+
const credentials = await flow.credentials;
|
|
48
|
+
saveCredentials("anthropic-subscription", credentials);
|
|
49
|
+
await applySubscriptionCredentials(state.config);
|
|
50
|
+
delete state._anthropicFlow;
|
|
51
|
+
json(res, { success: true, expiresAt: credentials.expires });
|
|
52
|
+
}
|
|
53
|
+
catch (err) {
|
|
54
|
+
delete state._anthropicFlow;
|
|
55
|
+
logger.error(`[api] Anthropic exchange failed: ${err instanceof Error ? err.stack : err}`);
|
|
56
|
+
error(res, "Anthropic exchange failed", 500);
|
|
57
|
+
}
|
|
58
|
+
return true;
|
|
59
|
+
}
|
|
60
|
+
if (method === "POST" &&
|
|
61
|
+
pathname === "/api/subscription/anthropic/setup-token") {
|
|
62
|
+
const body = await readJsonBody(req, res);
|
|
63
|
+
if (!body)
|
|
64
|
+
return true;
|
|
65
|
+
if (!body.token || !body.token.startsWith("sk-ant-")) {
|
|
66
|
+
error(res, "Invalid token format — expected sk-ant-oat01-...", 400);
|
|
67
|
+
return true;
|
|
68
|
+
}
|
|
69
|
+
try {
|
|
70
|
+
process.env.ANTHROPIC_API_KEY = body.token.trim();
|
|
71
|
+
if (!state.config.env)
|
|
72
|
+
state.config.env = {};
|
|
73
|
+
state.config.env.ANTHROPIC_API_KEY = body.token.trim();
|
|
74
|
+
ctx.saveConfig(state.config);
|
|
75
|
+
json(res, { success: true });
|
|
76
|
+
}
|
|
77
|
+
catch (err) {
|
|
78
|
+
logger.error(`[api] Failed to save setup token: ${err instanceof Error ? err.stack : err}`);
|
|
79
|
+
error(res, "Failed to save setup token", 500);
|
|
80
|
+
}
|
|
81
|
+
return true;
|
|
82
|
+
}
|
|
83
|
+
if (method === "POST" && pathname === "/api/subscription/openai/start") {
|
|
84
|
+
try {
|
|
85
|
+
const { startCodexLogin } = await loadSubscriptionAuth();
|
|
86
|
+
if (state._codexFlow) {
|
|
87
|
+
try {
|
|
88
|
+
state._codexFlow.close();
|
|
89
|
+
}
|
|
90
|
+
catch (err) {
|
|
91
|
+
logger.debug(`[api] OAuth flow cleanup failed: ${err instanceof Error ? err.message : err}`);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
clearTimeout(state._codexFlowTimer);
|
|
95
|
+
const flow = await startCodexLogin();
|
|
96
|
+
state._codexFlow = flow;
|
|
97
|
+
state._codexFlowTimer = setTimeout(() => {
|
|
98
|
+
try {
|
|
99
|
+
flow.close();
|
|
100
|
+
}
|
|
101
|
+
catch (err) {
|
|
102
|
+
logger.debug(`[api] OAuth flow cleanup failed: ${err instanceof Error ? err.message : err}`);
|
|
103
|
+
}
|
|
104
|
+
delete state._codexFlow;
|
|
105
|
+
delete state._codexFlowTimer;
|
|
106
|
+
}, 10 * 60 * 1000);
|
|
107
|
+
json(res, {
|
|
108
|
+
authUrl: flow.authUrl,
|
|
109
|
+
state: flow.state,
|
|
110
|
+
instructions: "Open the URL in your browser. After login, if auto-redirect doesn't work, paste the full redirect URL.",
|
|
111
|
+
});
|
|
112
|
+
}
|
|
113
|
+
catch (err) {
|
|
114
|
+
logger.error(`[api] Failed to start OpenAI login: ${err instanceof Error ? err.stack : err}`);
|
|
115
|
+
error(res, "Failed to start OpenAI login", 500);
|
|
116
|
+
}
|
|
117
|
+
return true;
|
|
118
|
+
}
|
|
119
|
+
if (method === "POST" && pathname === "/api/subscription/openai/exchange") {
|
|
120
|
+
const body = await readJsonBody(req, res);
|
|
121
|
+
if (!body)
|
|
122
|
+
return true;
|
|
123
|
+
try {
|
|
124
|
+
const { saveCredentials, applySubscriptionCredentials } = await loadSubscriptionAuth();
|
|
125
|
+
const flow = state._codexFlow;
|
|
126
|
+
if (!flow) {
|
|
127
|
+
error(res, "No active flow — call /start first", 400);
|
|
128
|
+
return true;
|
|
129
|
+
}
|
|
130
|
+
if (body.code) {
|
|
131
|
+
flow.submitCode(body.code);
|
|
132
|
+
}
|
|
133
|
+
else if (!body.waitForCallback) {
|
|
134
|
+
error(res, "Provide either code or set waitForCallback: true", 400);
|
|
135
|
+
return true;
|
|
136
|
+
}
|
|
137
|
+
let credentials;
|
|
138
|
+
try {
|
|
139
|
+
credentials = await flow.credentials;
|
|
140
|
+
}
|
|
141
|
+
catch (err) {
|
|
142
|
+
try {
|
|
143
|
+
flow.close();
|
|
144
|
+
}
|
|
145
|
+
catch (closeErr) {
|
|
146
|
+
logger.debug(`[api] OAuth flow cleanup failed: ${closeErr instanceof Error ? closeErr.message : closeErr}`);
|
|
147
|
+
}
|
|
148
|
+
delete state._codexFlow;
|
|
149
|
+
clearTimeout(state._codexFlowTimer);
|
|
150
|
+
delete state._codexFlowTimer;
|
|
151
|
+
logger.error(`[api] OpenAI exchange failed: ${err instanceof Error ? err.stack : err}`);
|
|
152
|
+
error(res, "OpenAI exchange failed", 500);
|
|
153
|
+
return true;
|
|
154
|
+
}
|
|
155
|
+
saveCredentials("openai-codex", credentials);
|
|
156
|
+
await applySubscriptionCredentials(state.config);
|
|
157
|
+
flow.close();
|
|
158
|
+
delete state._codexFlow;
|
|
159
|
+
clearTimeout(state._codexFlowTimer);
|
|
160
|
+
delete state._codexFlowTimer;
|
|
161
|
+
json(res, {
|
|
162
|
+
success: true,
|
|
163
|
+
expiresAt: credentials.expires,
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
catch (err) {
|
|
167
|
+
logger.error(`[api] OpenAI exchange failed: ${err instanceof Error ? err.stack : err}`);
|
|
168
|
+
error(res, "OpenAI exchange failed", 500);
|
|
169
|
+
}
|
|
170
|
+
return true;
|
|
171
|
+
}
|
|
172
|
+
if (method === "DELETE" && pathname.startsWith("/api/subscription/")) {
|
|
173
|
+
const provider = pathname.split("/").pop();
|
|
174
|
+
if (provider === "anthropic-subscription" || provider === "openai-codex") {
|
|
175
|
+
try {
|
|
176
|
+
const { deleteCredentials } = await loadSubscriptionAuth();
|
|
177
|
+
deleteCredentials(provider);
|
|
178
|
+
json(res, { success: true });
|
|
179
|
+
}
|
|
180
|
+
catch (err) {
|
|
181
|
+
logger.error(`[api] Failed to delete credentials: ${err instanceof Error ? err.stack : err}`);
|
|
182
|
+
error(res, "Failed to delete credentials", 500);
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
else {
|
|
186
|
+
error(res, `Unknown provider: ${provider}`, 400);
|
|
187
|
+
}
|
|
188
|
+
return true;
|
|
189
|
+
}
|
|
190
|
+
return false;
|
|
191
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"terminal-run-limits.d.ts","sourceRoot":"","sources":["../../../../../src/api/terminal-run-limits.ts"],"names":[],"mappings":"AAOA,wBAAgB,wBAAwB,IAAI;IAC1C,aAAa,EAAE,MAAM,CAAC;IACtB,aAAa,EAAE,MAAM,CAAC;CACvB,CAoBA"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { parseClampedInteger } from "../utils/number-parsing";
|
|
2
|
+
const TERMINAL_RUN_MAX_CONCURRENT_DEFAULT = 2;
|
|
3
|
+
const TERMINAL_RUN_MAX_CONCURRENT_CAP = 16;
|
|
4
|
+
const TERMINAL_RUN_MAX_DURATION_MS_DEFAULT = 5 * 60 * 1000;
|
|
5
|
+
const TERMINAL_RUN_MAX_DURATION_MS_CAP = 60 * 60 * 1000;
|
|
6
|
+
export function resolveTerminalRunLimits() {
|
|
7
|
+
const maxConcurrentRaw = process.env.ELIZA_TERMINAL_MAX_CONCURRENT ??
|
|
8
|
+
process.env.ELIZA_TERMINAL_MAX_CONCURRENT;
|
|
9
|
+
const maxConcurrent = parseClampedInteger(maxConcurrentRaw, {
|
|
10
|
+
fallback: TERMINAL_RUN_MAX_CONCURRENT_DEFAULT,
|
|
11
|
+
min: 1,
|
|
12
|
+
max: TERMINAL_RUN_MAX_CONCURRENT_CAP,
|
|
13
|
+
});
|
|
14
|
+
const maxDurationMsRaw = process.env.ELIZA_TERMINAL_MAX_DURATION_MS ??
|
|
15
|
+
process.env.ELIZA_TERMINAL_MAX_DURATION_MS;
|
|
16
|
+
const maxDurationMs = parseClampedInteger(maxDurationMsRaw, {
|
|
17
|
+
fallback: TERMINAL_RUN_MAX_DURATION_MS_DEFAULT,
|
|
18
|
+
min: 1_000,
|
|
19
|
+
max: TERMINAL_RUN_MAX_DURATION_MS_CAP,
|
|
20
|
+
});
|
|
21
|
+
return { maxConcurrent, maxDurationMs };
|
|
22
|
+
}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export interface BackendAvailability {
|
|
2
|
+
mlx: boolean;
|
|
3
|
+
cuda: boolean;
|
|
4
|
+
cpu: boolean;
|
|
5
|
+
}
|
|
6
|
+
export declare function detectAvailableBackends(): Promise<BackendAvailability>;
|
|
7
|
+
export declare function clearBackendCache(): void;
|
|
8
|
+
//# sourceMappingURL=training-backend-check.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"training-backend-check.d.ts","sourceRoot":"","sources":["../../../../../src/api/training-backend-check.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,mBAAmB;IAClC,GAAG,EAAE,OAAO,CAAC;IACb,IAAI,EAAE,OAAO,CAAC;IACd,GAAG,EAAE,OAAO,CAAC;CACd;AAcD,wBAAsB,uBAAuB,IAAI,OAAO,CAAC,mBAAmB,CAAC,CAe5E;AAED,wBAAgB,iBAAiB,IAAI,IAAI,CAExC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { execFile } from "node:child_process";
|
|
2
|
+
let cached = null;
|
|
3
|
+
const CACHE_TTL_MS = 60_000;
|
|
4
|
+
function probe(command, args) {
|
|
5
|
+
return new Promise((resolve) => {
|
|
6
|
+
const child = execFile(command, args, { timeout: 3_000 }, (err) => {
|
|
7
|
+
resolve(!err);
|
|
8
|
+
});
|
|
9
|
+
child.stdin?.end();
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
export async function detectAvailableBackends() {
|
|
13
|
+
if (cached && Date.now() < cached.expiresAt) {
|
|
14
|
+
return cached.result;
|
|
15
|
+
}
|
|
16
|
+
const [mlx, cuda] = await Promise.all([
|
|
17
|
+
process.platform === "darwin"
|
|
18
|
+
? probe("python3", ["-c", "import mlx"])
|
|
19
|
+
: Promise.resolve(false),
|
|
20
|
+
probe("nvidia-smi", []),
|
|
21
|
+
]);
|
|
22
|
+
const result = { mlx, cuda, cpu: true };
|
|
23
|
+
cached = { result, expiresAt: Date.now() + CACHE_TTL_MS };
|
|
24
|
+
return result;
|
|
25
|
+
}
|
|
26
|
+
export function clearBackendCache() {
|
|
27
|
+
cached = null;
|
|
28
|
+
}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import type { AgentRuntime } from "@elizaos/core";
|
|
2
|
+
import type { RouteHelpers, RouteRequestContext } from "./route-helpers";
|
|
3
|
+
export type TrainingRouteHelpers = RouteHelpers;
|
|
4
|
+
interface TrainingServiceLike {
|
|
5
|
+
getStatus(): Record<string, unknown>;
|
|
6
|
+
listTrajectories(options: {
|
|
7
|
+
limit?: number;
|
|
8
|
+
offset?: number;
|
|
9
|
+
}): Promise<Record<string, unknown>>;
|
|
10
|
+
getTrajectoryById(trajectoryId: string): Promise<Record<string, unknown> | null>;
|
|
11
|
+
listDatasets(): Record<string, unknown>[];
|
|
12
|
+
buildDataset(options: {
|
|
13
|
+
limit?: number;
|
|
14
|
+
minLlmCallsPerTrajectory?: number;
|
|
15
|
+
}): Promise<Record<string, unknown>>;
|
|
16
|
+
listJobs(): Record<string, unknown>[];
|
|
17
|
+
startTrainingJob(options: {
|
|
18
|
+
datasetId?: string;
|
|
19
|
+
maxTrajectories?: number;
|
|
20
|
+
backend?: "mlx" | "cuda" | "cpu";
|
|
21
|
+
model?: string;
|
|
22
|
+
iterations?: number;
|
|
23
|
+
batchSize?: number;
|
|
24
|
+
learningRate?: number;
|
|
25
|
+
}): Promise<Record<string, unknown>>;
|
|
26
|
+
getJob(jobId: string): Record<string, unknown> | null;
|
|
27
|
+
cancelJob(jobId: string): Promise<Record<string, unknown>>;
|
|
28
|
+
listModels(): Record<string, unknown>[];
|
|
29
|
+
importModelToOllama(modelId: string, body: {
|
|
30
|
+
modelName?: string;
|
|
31
|
+
baseModel?: string;
|
|
32
|
+
ollamaUrl?: string;
|
|
33
|
+
}): Promise<Record<string, unknown>>;
|
|
34
|
+
activateModel(modelId: string, providerModel?: string): Promise<Record<string, unknown>>;
|
|
35
|
+
benchmarkModel(modelId: string): Promise<Record<string, unknown>>;
|
|
36
|
+
}
|
|
37
|
+
export interface TrainingRouteContext extends RouteRequestContext {
|
|
38
|
+
runtime: AgentRuntime | null;
|
|
39
|
+
trainingService: TrainingServiceLike;
|
|
40
|
+
isLoopbackHost: (host: string) => boolean;
|
|
41
|
+
}
|
|
42
|
+
export declare function handleTrainingRoutes(ctx: TrainingRouteContext): Promise<boolean>;
|
|
43
|
+
export {};
|
|
44
|
+
//# sourceMappingURL=training-routes.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"training-routes.d.ts","sourceRoot":"","sources":["../../../../../src/api/training-routes.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAElD,OAAO,KAAK,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAC;AAGzE,MAAM,MAAM,oBAAoB,GAAG,YAAY,CAAC;AAEhD,UAAU,mBAAmB;IAC3B,SAAS,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IACrC,gBAAgB,CAAC,OAAO,EAAE;QACxB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;IACrC,iBAAiB,CACf,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC;IAC3C,YAAY,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IAC1C,YAAY,CAAC,OAAO,EAAE;QACpB,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,wBAAwB,CAAC,EAAE,MAAM,CAAC;KACnC,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;IACrC,QAAQ,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IACtC,gBAAgB,CAAC,OAAO,EAAE;QACxB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,eAAe,CAAC,EAAE,MAAM,CAAC;QACzB,OAAO,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,KAAK,CAAC;QACjC,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,UAAU,CAAC,EAAE,MAAM,CAAC;QACpB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,YAAY,CAAC,EAAE,MAAM,CAAC;KACvB,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;IACrC,MAAM,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IACtD,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;IAC3D,UAAU,IAAI,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IACxC,mBAAmB,CACjB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE;QACJ,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,GACA,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;IACpC,aAAa,CACX,OAAO,EAAE,MAAM,EACf,aAAa,CAAC,EAAE,MAAM,GACrB,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;IACpC,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC,CAAC;CACnE;AAED,MAAM,WAAW,oBAAqB,SAAQ,mBAAmB;IAC/D,OAAO,EAAE,YAAY,GAAG,IAAI,CAAC;IAC7B,eAAe,EAAE,mBAAmB,CAAC;IACrC,cAAc,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;CAC3C;AA2BD,wBAAsB,oBAAoB,CACxC,GAAG,EAAE,oBAAoB,GACxB,OAAO,CAAC,OAAO,CAAC,CAuOlB"}
|