qlogicagent 2.10.22 → 2.10.23
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/README.md +29 -4
- package/dist/agent.js +11 -11
- package/dist/cli.js +701 -604
- package/dist/index.js +700 -603
- package/dist/permissions.js +1 -0
- package/dist/protocol.js +1 -1
- package/dist/types/agent/tool-access.d.ts +1 -30
- package/dist/types/agent/tunable-defaults.d.ts +1 -249
- package/dist/types/agent/types.d.ts +7 -0
- package/dist/types/cli/acp-extended-handlers.d.ts +41 -0
- package/dist/types/cli/acp-extended-host-adapter.d.ts +28 -0
- package/dist/types/cli/acp-extended-host-adapter.test.d.ts +1 -0
- package/dist/types/cli/acp-session-handlers.d.ts +39 -0
- package/dist/types/cli/acp-session-handlers.test.d.ts +1 -0
- package/dist/types/cli/agent-config-coordinator.d.ts +13 -0
- package/dist/types/cli/agent-config-runtime.d.ts +11 -0
- package/dist/types/cli/agent-runner-factory.d.ts +2 -0
- package/dist/types/cli/agent-runtime-bootstrap.d.ts +64 -0
- package/dist/types/cli/agent-status-notifier.d.ts +11 -0
- package/dist/types/cli/agent-status-notifier.test.d.ts +1 -0
- package/dist/types/cli/base-tool-bootstrap.d.ts +7 -0
- package/dist/types/cli/cli-acp-request-handler.d.ts +9 -0
- package/dist/types/cli/cli-acp-request-handler.test.d.ts +1 -0
- package/dist/types/cli/cli-agent-builder.d.ts +35 -0
- package/dist/types/cli/community-skill-installer.d.ts +12 -0
- package/dist/types/cli/community-skill-installer.test.d.ts +1 -0
- package/dist/types/cli/core-tool-coordinator.d.ts +30 -0
- package/dist/types/cli/core-tools/agent-tool-bootstrap.d.ts +10 -0
- package/dist/types/cli/core-tools/agent-tool-service.d.ts +18 -0
- package/dist/types/cli/core-tools/checkpoint-tool-bootstrap.d.ts +7 -0
- package/dist/types/cli/core-tools/checkpoint-tool-service.d.ts +7 -0
- package/dist/types/cli/core-tools/config-tool-bootstrap.d.ts +7 -0
- package/dist/types/cli/core-tools/config-tool-service.d.ts +7 -0
- package/dist/types/cli/core-tools/cron-tool-bootstrap.d.ts +7 -0
- package/dist/types/cli/core-tools/cron-tool-service.d.ts +22 -0
- package/dist/types/cli/core-tools/cron-tool-service.test.d.ts +1 -0
- package/dist/types/cli/core-tools/monitor-tool-bootstrap.d.ts +5 -0
- package/dist/types/cli/core-tools/monitor-tool-service.d.ts +6 -0
- package/dist/types/cli/core-tools/registry.d.ts +9 -0
- package/dist/types/cli/core-tools/team-tool-bootstrap.d.ts +7 -0
- package/dist/types/cli/core-tools/team-tool-service.d.ts +21 -0
- package/dist/types/cli/core-tools/utility-tool-bootstrap.d.ts +8 -0
- package/dist/types/cli/default-project-bootstrap.d.ts +8 -0
- package/dist/types/cli/dev-tool-bootstrap.d.ts +4 -0
- package/dist/types/cli/dev-tools/lsp-tool-service.d.ts +5 -0
- package/dist/types/cli/dev-tools/repl-lsp-tool-services.test.d.ts +1 -0
- package/dist/types/cli/dev-tools/repl-tool-service.d.ts +5 -0
- package/dist/types/cli/dream-host-adapter.d.ts +19 -0
- package/dist/types/cli/handlers/agents-handler.d.ts +28 -14
- package/dist/types/cli/handlers/community-handler.d.ts +25 -0
- package/dist/types/cli/handlers/community-handler.test.d.ts +1 -0
- package/dist/types/cli/handlers/config-handler.d.ts +15 -9
- package/dist/types/cli/handlers/config-handler.test.d.ts +1 -0
- package/dist/types/cli/handlers/control-handler.d.ts +23 -0
- package/dist/types/cli/handlers/dream-handler.d.ts +21 -1
- package/dist/types/cli/handlers/files-handler.d.ts +15 -9
- package/dist/types/cli/handlers/files-handler.instructions.test.d.ts +1 -0
- package/dist/types/cli/handlers/media-handler.d.ts +10 -4
- package/dist/types/cli/handlers/media-handler.test.d.ts +1 -0
- package/dist/types/cli/handlers/memory-handler.d.ts +39 -12
- package/dist/types/cli/handlers/pet-confirm-handler.d.ts +7 -0
- package/dist/types/cli/handlers/pet-handler.d.ts +29 -4
- package/dist/types/cli/handlers/pet-handler.test.d.ts +1 -0
- package/dist/types/cli/handlers/product-handler.d.ts +40 -14
- package/dist/types/cli/handlers/project-handler.d.ts +23 -14
- package/dist/types/cli/handlers/session-handler.d.ts +36 -17
- package/dist/types/cli/handlers/session-handler.resume.test.d.ts +1 -0
- package/dist/types/cli/handlers/settings-handler.d.ts +16 -12
- package/dist/types/cli/handlers/skills-handler.d.ts +19 -10
- package/dist/types/cli/handlers/skills-handler.profile.test.d.ts +1 -0
- package/dist/types/cli/handlers/solo-handler.d.ts +31 -9
- package/dist/types/cli/handlers/turn-handler.approval.test.d.ts +1 -0
- package/dist/types/cli/handlers/turn-handler.d.ts +17 -11
- package/dist/types/cli/idle-dream-coordinator.d.ts +46 -0
- package/dist/types/cli/idle-dream-coordinator.test.d.ts +1 -0
- package/dist/types/cli/mcp-plugin-bootstrap.d.ts +27 -0
- package/dist/types/cli/mcp-plugin-bootstrap.test.d.ts +1 -0
- package/dist/types/cli/mcp-tool-proxy.d.ts +7 -0
- package/dist/types/cli/media-file-api-service.d.ts +73 -0
- package/dist/types/cli/media-file-api-service.test.d.ts +1 -0
- package/dist/types/cli/media-file-tool-service.d.ts +13 -0
- package/dist/types/cli/memory-coordinator.d.ts +36 -0
- package/dist/types/cli/model-client-resolver.d.ts +22 -0
- package/dist/types/cli/multi-agent-handler-host.d.ts +27 -0
- package/dist/types/cli/multi-agent-handler-host.test.d.ts +1 -0
- package/dist/types/cli/multi-agent-state-coordinator.d.ts +11 -0
- package/dist/types/cli/permission-bootstrap.d.ts +33 -0
- package/dist/types/cli/permission-bootstrap.test.d.ts +1 -0
- package/dist/types/cli/permission-settings-store.d.ts +2 -0
- package/dist/types/cli/permission-settings-store.test.d.ts +1 -0
- package/dist/types/cli/pet-confirm-coordinator.d.ts +20 -0
- package/dist/types/cli/pet-confirm-coordinator.test.d.ts +1 -0
- package/dist/types/cli/pet-runtime.d.ts +34 -0
- package/dist/types/cli/pet-runtime.test.d.ts +1 -0
- package/dist/types/cli/project-context.d.ts +1 -0
- package/dist/types/cli/project-memory-store-factory.d.ts +2 -0
- package/dist/types/cli/project-template-seeder.d.ts +5 -0
- package/dist/types/cli/provider-core-facade.d.ts +27 -0
- package/dist/types/cli/rpc-registry.community.test.d.ts +1 -0
- package/dist/types/cli/rpc-registry.d.ts +8 -0
- package/dist/types/cli/runtime-hook-bootstrap.d.ts +34 -0
- package/dist/types/cli/runtime-watcher-bootstrap.d.ts +15 -0
- package/dist/types/cli/session-coordinator.d.ts +10 -0
- package/dist/types/cli/session-coordinator.test.d.ts +1 -0
- package/dist/types/cli/session-history-coordinator.d.ts +11 -0
- package/dist/types/cli/session-history-coordinator.test.d.ts +1 -0
- package/dist/types/cli/skill-meta-tool-bootstrap.d.ts +25 -0
- package/dist/types/cli/skill-meta-tool-bootstrap.test.d.ts +1 -0
- package/dist/types/cli/stdio-server.d.ts +17 -134
- package/dist/types/cli/tool-bootstrap.d.ts +1 -4
- package/dist/types/cli/tool-bootstrap.instructions.test.d.ts +1 -0
- package/dist/types/cli/tool-bootstrap.media-provider-alias.test.d.ts +1 -0
- package/dist/types/cli/tool-catalog.d.ts +2 -0
- package/dist/types/cli/tool-invoker-factory.d.ts +10 -0
- package/dist/types/cli/tool-result-processor.d.ts +14 -0
- package/dist/types/cli/transport.d.ts +2 -12
- package/dist/types/cli/turn-ask-user-setup.d.ts +9 -0
- package/dist/types/cli/turn-event-forwarder.d.ts +10 -0
- package/dist/types/cli/turn-lifecycle.d.ts +19 -0
- package/dist/types/cli/turn-lifecycle.test.d.ts +1 -0
- package/dist/types/cli/turn-media-setup.d.ts +16 -0
- package/dist/types/cli/turn-permission-sync.d.ts +7 -0
- package/dist/types/cli/turn-permission-sync.test.d.ts +1 -0
- package/dist/types/cli/turn-project-router.d.ts +22 -0
- package/dist/types/cli/turn-project-router.test.d.ts +1 -0
- package/dist/types/cli/turn-skill-autopersist.d.ts +47 -0
- package/dist/types/cli/turn-skill-autopersist.test.d.ts +1 -0
- package/dist/types/cli/turn-suggestion-generator.d.ts +15 -0
- package/dist/types/orchestration/agent-instance.d.ts +1 -1
- package/dist/types/orchestration/dag-scheduler.d.ts +135 -86
- package/dist/types/orchestration/index.d.ts +2 -2
- package/dist/types/orchestration/product-budget.d.ts +1 -1
- package/dist/types/orchestration/product-persistence.d.ts +3 -12
- package/dist/types/orchestration/product-planner.d.ts +1 -1
- package/dist/types/orchestration/skill-improvement.d.ts +1 -1
- package/dist/types/orchestration/solo-evaluator.d.ts +1 -1
- package/dist/types/orchestration/solo-persistence.d.ts +1 -1
- package/dist/types/orchestration/subagent/fork-subagent.d.ts +1 -1
- package/dist/types/orchestration/subagent/task-types.d.ts +1 -146
- package/dist/types/orchestration/tool-cascade.d.ts +2 -2
- package/dist/types/orchestration/workflow/budget-permission-gate.d.ts +85 -0
- package/dist/types/orchestration/workflow/builtin-executors.d.ts +12 -0
- package/dist/types/orchestration/workflow/cron-schedule.d.ts +37 -0
- package/dist/types/orchestration/workflow/data-item.d.ts +39 -0
- package/dist/types/orchestration/workflow/expression.d.ts +52 -0
- package/dist/types/orchestration/workflow/host-executors.d.ts +15 -0
- package/dist/types/orchestration/workflow/n8n-import.d.ts +35 -0
- package/dist/types/orchestration/workflow/node-registry.d.ts +19 -0
- package/dist/types/orchestration/workflow/node-schema.d.ts +119 -0
- package/dist/types/orchestration/workflow/run-checkpoint-store.d.ts +53 -0
- package/dist/types/orchestration/workflow/trigger-validation.d.ts +22 -0
- package/dist/types/orchestration/workflow/workflow-controller.d.ts +143 -0
- package/dist/types/orchestration/workflow/workflow-patch.d.ts +101 -0
- package/dist/types/orchestration/workflow/workflow-render.d.ts +41 -0
- package/dist/types/orchestration/workflow/workflow-runtime.d.ts +127 -0
- package/dist/types/orchestration/workflow/workflow-scheduler.d.ts +83 -0
- package/dist/types/orchestration/workflow/workflow-store.d.ts +40 -0
- package/dist/types/orchestration/workflow/workflow-trigger.d.ts +14 -0
- package/dist/types/permissions.d.ts +2 -0
- package/dist/types/permissions.public-api.test.d.ts +1 -0
- package/dist/types/protocol/methods.d.ts +262 -11
- package/dist/types/{runtime/infra/acp-types.d.ts → protocol/wire/acp-agent-management.d.ts} +3 -3
- package/dist/types/protocol/wire/agent-methods.d.ts +15 -11
- package/dist/types/protocol/wire/agent-rpc.d.ts +11 -0
- package/dist/types/protocol/wire/chat-types.d.ts +9 -0
- package/dist/types/protocol/wire/gateway-rpc.d.ts +13 -0
- package/dist/types/protocol/wire/index.d.ts +2 -1
- package/dist/types/protocol/wire/notification-payloads.d.ts +18 -3
- package/dist/types/runtime/community/community-consent-client.d.ts +117 -0
- package/dist/types/runtime/community/community-consent-client.test.d.ts +1 -0
- package/dist/types/runtime/community/community-desensitization-red-team-cli.d.ts +7 -0
- package/dist/types/runtime/community/community-desensitization-red-team-cli.test.d.ts +1 -0
- package/dist/types/runtime/community/community-desensitization.d.ts +29 -0
- package/dist/types/runtime/community/community-desensitization.test.d.ts +1 -0
- package/dist/types/runtime/community/community-telemetry-recorder.d.ts +6 -0
- package/dist/types/runtime/config/tunable-defaults.d.ts +249 -0
- package/dist/types/runtime/execution/dream-agent.d.ts +4 -2
- package/dist/types/runtime/execution/dream-category-context.d.ts +1 -1
- package/dist/types/runtime/execution/forked-agent.d.ts +3 -1
- package/dist/types/runtime/execution/streaming-tool-executor.d.ts +4 -2
- package/dist/types/runtime/execution/tool-eligibility.d.ts +1 -1
- package/dist/types/runtime/hooks/context-compression.d.ts +2 -2
- package/dist/types/runtime/hooks/memory-hooks.d.ts +6 -6
- package/dist/types/runtime/infra/acp-detector.d.ts +2 -2
- package/dist/types/runtime/infra/acp-protocol-adapter.d.ts +1 -1
- package/dist/types/runtime/infra/acp-usage-tracker.d.ts +1 -1
- package/dist/types/runtime/infra/agent-config-store.d.ts +2 -2
- package/dist/types/runtime/infra/agent-paths.d.ts +14 -10
- package/dist/types/runtime/infra/agent-paths.test.d.ts +1 -0
- package/dist/types/runtime/infra/agent-process.d.ts +2 -2
- package/dist/types/runtime/infra/checkpoint-backend.d.ts +2 -2
- package/dist/types/runtime/infra/index.d.ts +1 -1
- package/dist/types/runtime/infra/llmrouter-catalog.d.ts +10 -0
- package/dist/types/runtime/infra/mcp-bridge.d.ts +1 -1
- package/dist/types/runtime/infra/model-registry.d.ts +2 -1
- package/dist/types/runtime/infra/profile-storage.test.d.ts +1 -0
- package/dist/types/runtime/infra/skill-injector.d.ts +3 -2
- package/dist/types/runtime/infra/skill-injector.test.d.ts +1 -0
- package/dist/types/runtime/infra/task-runtime.d.ts +1 -1
- package/dist/types/runtime/infra/worktree-backend.d.ts +2 -2
- package/dist/types/runtime/memory/categories.d.ts +5 -0
- package/dist/types/runtime/memory/find-relevant-memories.d.ts +70 -0
- package/dist/types/runtime/memory/implicit-extraction.d.ts +58 -0
- package/dist/types/runtime/memory/recall-category-filter.d.ts +54 -0
- package/dist/types/runtime/pet/index.d.ts +1 -1
- package/dist/types/runtime/pet/pet-growth-engine.d.ts +10 -9
- package/dist/types/runtime/pet/pet-growth-engine.test.d.ts +1 -0
- package/dist/types/runtime/pet/pet-soul-service.d.ts +1 -2
- package/dist/types/runtime/pet/pet-soul-service.test.d.ts +1 -0
- package/dist/types/runtime/ports/agent-execution-contracts.d.ts +182 -0
- package/dist/types/runtime/ports/checkpoint-contracts.d.ts +19 -0
- package/dist/types/runtime/ports/index.d.ts +13 -0
- package/dist/types/runtime/ports/memory-provider.d.ts +146 -0
- package/dist/types/runtime/ports/memory-recall-source.d.ts +3 -0
- package/dist/types/runtime/ports/memory-writer.d.ts +21 -0
- package/dist/types/runtime/ports/path-service.d.ts +5 -0
- package/dist/types/runtime/ports/permission-contracts.d.ts +107 -0
- package/dist/types/runtime/ports/project-memory-store.d.ts +44 -0
- package/dist/types/runtime/ports/tool-call-contracts.d.ts +16 -0
- package/dist/types/runtime/ports/tool-contracts.d.ts +23 -0
- package/dist/types/runtime/ports/web-search-contracts.d.ts +17 -0
- package/dist/types/runtime/ports/worktree-contracts.d.ts +22 -0
- package/dist/types/runtime/prompt/environment-context.test.d.ts +1 -0
- package/dist/types/runtime/prompt/fresh-workspace-evidence.d.ts +19 -0
- package/dist/types/runtime/prompt/fresh-workspace-evidence.test.d.ts +1 -0
- package/dist/types/runtime/prompt/instruction-loader.d.ts +9 -3
- package/dist/types/runtime/prompt/instruction-loader.test.d.ts +1 -0
- package/dist/types/runtime/session/session-persistence.test.d.ts +1 -0
- package/dist/types/runtime/tasks/task-types.d.ts +146 -0
- package/dist/types/skills/index.d.ts +2 -2
- package/dist/types/skills/mcp/mcp-http-client.d.ts +2 -0
- package/dist/types/skills/mcp/mcp-manager.d.ts +7 -4
- package/dist/types/skills/mcp/mcp-stdio-client.d.ts +2 -0
- package/dist/types/skills/mcp/mcp-tool-metadata.d.ts +18 -0
- package/dist/types/skills/memory/categories.d.ts +1 -5
- package/dist/types/skills/memory/find-relevant-memories.d.ts +1 -70
- package/dist/types/skills/memory/implicit-extraction.d.ts +1 -58
- package/dist/types/skills/memory/local-memory-provider.d.ts +4 -10
- package/dist/types/skills/memory/local-store.d.ts +4 -4
- package/dist/types/skills/memory/memory-consolidation.d.ts +9 -1
- package/dist/types/skills/memory/memory-provider-factory.d.ts +2 -0
- package/dist/types/skills/memory/memory-tool.d.ts +4 -6
- package/dist/types/skills/memory/recall-category-filter.d.ts +1 -54
- package/dist/types/skills/permissions/community-sandbox-policy.d.ts +3 -0
- package/dist/types/skills/permissions/community-sandbox-red-team-cli.d.ts +7 -0
- package/dist/types/skills/permissions/community-sandbox-red-team.d.ts +30 -0
- package/dist/types/skills/permissions/hook-runner.d.ts +15 -2
- package/dist/types/skills/permissions/settings-watcher.d.ts +2 -0
- package/dist/types/skills/permissions/types.d.ts +2 -113
- package/dist/types/skills/portable-tool.d.ts +22 -0
- package/dist/types/skills/skill-system/skill-lifecycle.d.ts +5 -0
- package/dist/types/skills/skill-system/skill-source.d.ts +2 -148
- package/dist/types/skills/tool-access.d.ts +30 -0
- package/dist/types/skills/tools/skill-tool.d.ts +2 -10
- package/dist/types/skills/tools/web-search-tool.d.ts +3 -20
- package/dist/types/skills/tools.d.ts +1 -1
- package/dist/types/transport/acp-server.d.ts +1 -1
- package/dist/types/transport/index.d.ts +1 -0
- package/dist/types/transport/io-transport.d.ts +19 -0
- package/package.json +93 -80
- package/dist/types/llm/index.d.ts +0 -1
- /package/dist/types/{orchestration/context/context-compression.d.ts → runtime/context/context-compression-strategies.d.ts} +0 -0
package/README.md
CHANGED
|
@@ -1,6 +1,31 @@
|
|
|
1
|
-
# qlogicagent
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
# qlogicagent
|
|
2
|
+
|
|
3
|
+
## Community Red-Team Reports
|
|
4
|
+
|
|
5
|
+
Generate the v0.15 community red-team reports from the same detectors and permission checker used by local community flows:
|
|
6
|
+
|
|
7
|
+
```bash
|
|
8
|
+
pnpm redteam:community-desensitization -- --out=../qlogicagent-hub/reports/community-go-live/red-team/desensitization.json
|
|
9
|
+
pnpm redteam:community-sandbox -- --out=../qlogicagent-hub/reports/community-go-live/red-team/sandbox.json
|
|
10
|
+
```
|
|
11
|
+
|
|
12
|
+
The reports contain case ids, rule/finding ids, counts, and failures only; they do not store raw emails, secrets, paths, phone numbers, memories, skill text, tool commands, or file paths.
|
|
13
|
+
|
|
14
|
+
Installed community skills are marked from their lifecycle registry provenance. Non-official installed skills execute as `community-skill:*` subturns, and `PermissionChecker` applies the L1 sandbox overlay only while that subturn is active.
|
|
15
|
+
|
|
16
|
+
The generic `skill` meta-tool no longer exposes raw URL installation. New community skills must enter through the v0.15 registry install flow so manifest kind, source tier, risk tier, dependencies, checksum, and local `SKILL.md` rescan all run on the same path.
|
|
17
|
+
|
|
18
|
+
Community skill installation also rescans the downloaded `SKILL.md` entry after checksum verification and before moving it into the owner profile. Prompt-injection hits fail closed, leave no installed skill or lifecycle record, and return only a generic scan failure.
|
|
19
|
+
|
|
20
|
+
At runtime, the community sandbox overlay also blocks host side-effect tools such as `notify`, `send_message`, `agent`, `team`, `cron`, and `monitor` from community skill subturns, so injected instructions cannot escape through notifications, delegation, or scheduled work.
|
|
21
|
+
|
|
22
|
+
Community skill subturns also treat local file upload as tainted data egress. A `file_upload` call from `community-skill:*` requires explicit per-call approval before any provider Files API upload can proceed; auto-mode classifiers cannot replace that approval, and denied approvals leave no raw file path in the sandbox red-team report.
|
|
23
|
+
|
|
24
|
+
Community skill subturns also treat provider prompt/media tools as tainted external egress. Calls such as `image_generate`, `video_generate`, `music_generate`, `tts`, `three_d_generate`, `video_edit`, `video_merge`, `video_upscale`, `voice_clone`, and `stt` require explicit per-call approval from `community-skill:*`; worker/coordinator roles fail closed, and auto-mode classifiers cannot replace that approval.
|
|
25
|
+
|
|
26
|
+
Pet/Soul data is display-only. Runtime load/save sanitization strips fields and Chinese/English text that claim the pet is a desktop agent, execution actor, decision layer, permission subject, or can alter agent tools, permissions, memory, retrieval, planning, security policy, or system prompts.
|
|
27
|
+
|
|
28
|
+
小智 Claw 的本地 AI Agent 运行时。作为独立进程运行,通过 **ACP (Agent Client Protocol) + Native JSON-RPC over stdio** 对外提供 Agent 能力。openclaw 智能网关作为 ACP Client 连接本进程。
|
|
4
29
|
|
|
5
30
|
## 功能概览
|
|
6
31
|
|
|
@@ -198,7 +223,7 @@ src/
|
|
|
198
223
|
│ ├── dream-agent.ts # 记忆整合 (Dream)
|
|
199
224
|
│ ├── secure-storage.ts # 凭据安全存储
|
|
200
225
|
│ ├── token-budget.ts # Token 预算管理
|
|
201
|
-
│ ├── instruction-loader.ts # .
|
|
226
|
+
│ ├── instruction-loader.ts # INSTRUCTIONS.md 与 .qlogicagent/rules 加载
|
|
202
227
|
│ └── ... # 21 个运行时文件
|
|
203
228
|
│
|
|
204
229
|
├── skills/ # 工具与技能层
|
package/dist/agent.js
CHANGED
|
@@ -1,23 +1,23 @@
|
|
|
1
|
-
var Bn=Object.defineProperty;var $n=(t,e)=>()=>(t&&(e=t(t=0)),e);var jn=(t,e)=>{for(var o in e)Bn(t,o,{get:e[o],enumerable:!0})};var _n={};jn(_n,{resolveToolEligibility:()=>Lr});function wr(t,e){if(Er.some(o=>o.test(t)))return!0;if(e)for(let o of e)try{if(new RegExp(o,"i").test(t))return!0}catch{}return!1}function Ir(t,e){let o=t.function.name,n=t.meta,r=[];return e.blockedToolNames?.includes(o)?(r.push("policy_blocked"),{level:5,reasons:r}):n?.isReadOnly?(r.push("always_allowed"),{level:1,reasons:r}):n?.requiresApproval?(r.push("approval_required"),{level:4,reasons:r}):n?.isDangerous||wr(o,e.dangerousPatterns)?(r.push("dangerous_tool"),{level:3,reasons:r}):{level:2,reasons:r}}function Pr(t){switch(t){case 1:return"eligible";case 2:return"eligible";case 3:return"dangerous-notify";case 4:return"approval-required";case 5:return"blocked-by-policy"}}function Lr(t,e={}){let o=new Map,n=[],r=[],s=[];for(let l of t){let i=l.function.name,{level:p,reasons:y}=Ir(l,e),g=Pr(p),f={toolName:i,status:g,permissionLevel:p,approvalRequired:p===4,reasonCodes:y};o.set(i,f),p===5?r.push(f):(n.push(l),p===4&&s.push(f))}return{eligibleTools:n,blockedTools:r,approvalRequiredTools:s,eligibilityByName:o}}var Er,Sn=$n(()=>{"use strict";Er=[/^(?:bash|shell|exec|terminal|run_command)$/i,/^(?:write_file|delete_file|move_file|create_directory)$/i,/^(?:git_push|git_reset|git_force)$/i]});import{cleanSchemaForGemini as ls}from"@xiaozhiclaw/provider-core/gemini-schema-utils";function Pe(t,e,o,n){return{role:"assistant",content:e||null,tool_calls:t,...o&&o.length>0?{thinkingBlocks:o}:{},...n?{reasoning_content:n}:{}}}function G(t,e){let o=e.ok?typeof e.payload=="string"?e.payload:JSON.stringify(e.payload??""):`Error: ${e.error??"Tool execution failed"}`;return{role:"tool",tool_call_id:t,content:o,...!e.ok&&{is_error:!0},...e.toolReferences?.length?{toolReferences:e.toolReferences}:{},...e.imageUrls?.length?{imageUrls:e.imageUrls}:{}}}var Kn=/\b(?:daily|weekly|monthly)(?:\/(?:daily|weekly|monthly))* (?:usage )?limit(?:s)?(?: (?:exhausted|reached|exceeded))?\b/i,q={rateLimit:[/rate[_ ]limit|too many requests|429/,"model_cooldown","exceeded your current quota","resource has been exhausted","quota exceeded","resource_exhausted","usage limit",/\btpm\b/i,"tokens per minute","tokens per day"],overloaded:[/overloaded_error|"type"\s*:\s*"overloaded_error"/i,"overloaded",/service[_ ]unavailable.*(?:overload|capacity|high[_ ]demand)|(?:overload|capacity|high[_ ]demand).*service[_ ]unavailable/i,"high demand"],timeout:["timeout","timed out","service unavailable","deadline exceeded","context deadline exceeded","connection error","network error","network request failed","fetch failed","socket hang up",/\beconn(?:refused|reset|aborted)\b/i,/\benotfound\b/i,/\beai_again\b/i,/without sending (?:any )?chunks?/i,/\bstop reason:\s*(?:abort|error|network_error)\b/i,/\breason:\s*(?:abort|error|network_error)\b/i,/\bunhandled stop reason:\s*(?:abort|error|network_error)\b/i],billing:[/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment/i,"payment required","insufficient credits",/insufficient[_ ]quota/i,"credit balance","plans & billing","insufficient balance"],authPermanent:[/api[_ ]?key[_ ]?(?:revoked|invalid|deactivated|deleted)/i,"invalid_api_key","key has been disabled","key has been revoked","account has been deactivated",/could not (?:authenticate|validate).*(?:api[_ ]?key|credentials)/i,"permission_error","not allowed for this organization"],auth:[/invalid[_ ]?api[_ ]?key/,"incorrect api key","invalid token","authentication","re-authenticate","oauth token refresh failed","unauthorized","forbidden","access denied","insufficient permissions","insufficient permission",/missing scopes?:/i,"expired","token has expired",/\b401\b/,/\b403\b/,"no credentials found","no api key found"],format:["string should match pattern","tool_use.id","tool_use_id","messages.1.content.1.tool_use.id","invalid request format",/tool call id was.*must be/i]},Gn=/^(?:error[:\s-]+)?billing(?:\s+error)?(?:[:\s-]+|$)|^(?:error[:\s-]+)?(?:credit balance|insufficient credits?|payment required|http\s*402\b)/i,Hn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|^\s*402\s+payment/i,zn=512,qn=/^(?:http\s*)?(\d{3})(?:\s+([\s\S]+))?$/i;var Wn=new Set([500,502,503,504,521,522,523,524,529]),Xn=["insufficient credits","insufficient quota","credit balance","insufficient balance","plans & billing","add more credits","top up"],Vn=["upgrade your plan","upgrade plan","current plan","subscription"],Yn=["daily","weekly","monthly"],Jn=["try again","retry","temporary","cooldown"],Qn=["usage limit","rate limit","organization usage"],Zn=["organization","workspace"],eo=["billing period","exceeded","reached","exhausted"],to=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment required\b/i,no=/^(?:error[:\s-]+)?(?:(?:http\s*)?402(?:\s+payment required)?|payment required)(?:[:\s-]+|$)/i;function W(t,e){if(!t)return!1;let o=t.toLowerCase();return e.some(n=>n instanceof RegExp?n.test(o):o.includes(n))}function oo(t){return W(t,q.format)}function Rt(t){return W(t,q.rateLimit)}function ro(t){return W(t,q.timeout)}function so(t){return Kn.test(t)}function Le(t){let e=t.toLowerCase();return e?t.length>zn?Hn.test(e):W(e,q.billing)?!0:Gn.test(t)?e.includes("upgrade")||e.includes("credits")||e.includes("payment")||e.includes("plan"):!1:!1}function _t(t){return W(t,q.authPermanent)}function io(t){return W(t,q.auth)}function St(t){return W(t,q.overloaded)}function z(t,e){return e.some(o=>t.includes(o))}function ao(t){return z(t,Xn)||z(t,Vn)&&t.includes("limit")||t.includes("billing hard limit")||t.includes("hard limit reached")||t.includes("maximum allowed")&&t.includes("limit")}function lo(t){let e=z(t,Yn),o=t.includes("spend limit")||t.includes("spending limit"),n=z(t,Zn);return z(t,Jn)&&z(t,Qn)||e&&(t.includes("usage limit")||o)||e&&t.includes("limit")&&t.includes("reset")||n&&t.includes("limit")&&(o||z(t,eo))}function co(t){return t.trim().toLowerCase().replace(no,"").trim()}function vt(t){let e=co(t);return!e||ao(e)?"billing":Rt(e)||lo(e)?"rate_limit":"billing"}function uo(t){return to.test(t)?vt(t):null}function xt(t){let e=t.match(qn);if(!e)return null;let o=Number(e[1]);return Number.isFinite(o)?{code:o,rest:(e[2]??"").trim()}:null}function po(t){if(!t)return!1;let e=t.toLowerCase();return e.includes('"type":"api_error"')&&e.includes("internal server error")}function go(t){let e=t.trim();if(!e)return!1;let o=xt(e);return o?Wn.has(o.code):!1}function Mt(t,e){return typeof t!="number"||!Number.isFinite(t)?null:t===402?e?vt(e):"billing":t===429?"rate_limit":t===401||t===403?e&&_t(e)?"auth_permanent":"auth":t===408?"timeout":t===503?e&&St(e)?"overloaded":"timeout":t===502||t===504?"timeout":t===529?"overloaded":t===400?e&&Le(e)?"billing":"format":null}function mo(t){if(!t)return!1;let e=t.toLowerCase();return!!(e.includes("unknown model")||e.includes("model not found")||e.includes("model_not_found")||e.includes("not_found_error")||e.includes("does not exist")&&e.includes("model")||e.includes("invalid model")&&!e.includes("invalid model reference")||/models\/[^\s]+ is not found/i.test(t)||/\b404\b/.test(t)&&/not[-_ ]?found/i.test(t))}function fo(t){if(!t)return!1;let e=t.toLowerCase();return e.includes("session not found")||e.includes("session does not exist")||e.includes("session expired")||e.includes("session invalid")||e.includes("conversation not found")||e.includes("conversation does not exist")||e.includes("conversation expired")||e.includes("conversation invalid")||e.includes("no such session")||e.includes("invalid session")||e.includes("session id not found")||e.includes("conversation id not found")}function At(t){if(fo(t))return"session_expired";if(mo(t))return"model_not_found";let e=uo(t);return e||(so(t)?Le(t)?"billing":"rate_limit":Rt(t)?"rate_limit":St(t)?"overloaded":go(t)?xt(t.trim())?.code===529?"overloaded":"timeout":po(t)?"timeout":oo(t)?"format":Le(t)?"billing":ro(t)?"timeout":_t(t)?"auth_permanent":io(t)?"auth":null)}var ho={timeout:"RETRYABLE_TRANSIENT",overloaded:"RETRYABLE_TRANSIENT",rate_limit:"RETRYABLE_DEGRADED",auth:"NON_RETRYABLE_AUTH",auth_permanent:"NON_RETRYABLE_AUTH",billing:"NON_RETRYABLE_QUOTA",format:"NON_RETRYABLE_CONTENT",model_not_found:"NON_RETRYABLE_CONTENT",session_expired:"NON_RETRYABLE_CONTENT",unknown:"RETRYABLE_TRANSIENT"},yo=new Set(["RETRYABLE_TRANSIENT","RETRYABLE_DEGRADED","TOOL_EXECUTION_FAILED"]);function V(t,e){let o=Mt(t,e)??(e?At(e):null);return o?ho[o]:typeof t=="number"&&t>=400&&t<500?"NON_RETRYABLE_CONTENT":"RETRYABLE_TRANSIENT"}function Oe(t){return yo.has(t)}var Et=4,ne=class{constructor(e){this.estimateTokens=e}estimateTokens;compress(e,o){let n=[],r=[];for(let g of e)g.role==="system"?n.push(g):r.push(g);let s=o;for(let g of n)s-=this.estimateTokens(g);let l;for(let g of r)if(g.role==="user"){l=g;break}if(l&&(s-=this.estimateTokens(l)),s<=0)return{messages:l?[...n,l]:n,droppedCount:r.length-(l?1:0),strategy:"sliding-window"};let i=[],p=0;for(let g=r.length-1;g>=0;g--){let f=r[g];if(f===l)continue;let A=this.estimateTokens(f);if(s-A<0&&p>=Et)break;if(s-A<0&&p<Et){i.unshift(f),p++;continue}s-=A,i.unshift(f),p++}let y=[...n];return l&&!i.includes(l)&&y.push(l),y.push(...i),{messages:y,droppedCount:r.length-(i.length+(l&&!i.includes(l)?1:0)),strategy:"sliding-window"}}};var oe=class{constructor(e=8e3){this.maxToolResultChars=e}maxToolResultChars;compress(e,o){let n=0;return{messages:e.map(s=>s.role!=="tool"||typeof s.content!="string"||s.content.length<=this.maxToolResultChars?s:(n++,{...s,content:To(s.content,this.maxToolResultChars)})),droppedCount:n,strategy:"tool-result-trim"}}};function To(t,e){if(t.length<=e)return t;let o=t.slice(0,e);if(t.trimStart().startsWith("{")||t.trimStart().startsWith("[")){let s=Math.max(o.lastIndexOf("},"),o.lastIndexOf("],"),o.lastIndexOf(`}
|
|
1
|
+
var zn=Object.defineProperty;var Wn=(t,e)=>()=>(t&&(e=t(t=0)),e);var Xn=(t,e)=>{for(var o in e)zn(t,o,{get:e[o],enumerable:!0})};var An={};Xn(An,{resolveToolEligibility:()=>Gr});function $r(t,e){if(Br.some(o=>o.test(t)))return!0;if(e)for(let o of e)try{if(new RegExp(o,"i").test(t))return!0}catch{}return!1}function jr(t,e){let o=t.function.name,n=t.meta,r=[];return e.blockedToolNames?.includes(o)?(r.push("policy_blocked"),{level:5,reasons:r}):n?.isReadOnly?(r.push("always_allowed"),{level:1,reasons:r}):n?.requiresApproval?(r.push("approval_required"),{level:4,reasons:r}):n?.isDangerous||$r(o,e.dangerousPatterns)?(r.push("dangerous_tool"),{level:3,reasons:r}):{level:2,reasons:r}}function Kr(t){switch(t){case 1:return"eligible";case 2:return"eligible";case 3:return"dangerous-notify";case 4:return"approval-required";case 5:return"blocked-by-policy"}}function Gr(t,e={}){let o=new Map,n=[],r=[],s=[];for(let l of t){let i=l.function.name,{level:p,reasons:h}=jr(l,e),g=Kr(p),f={toolName:i,status:g,permissionLevel:p,approvalRequired:p===4,reasonCodes:h};o.set(i,f),p===5?r.push(f):(n.push(l),p===4&&s.push(f))}return{eligibleTools:n,blockedTools:r,approvalRequiredTools:s,eligibilityByName:o}}var Br,En=Wn(()=>{"use strict";Br=[/^(?:bash|shell|exec|terminal|run_command)$/i,/^(?:write_file|delete_file|move_file|create_directory)$/i,/^(?:git_push|git_reset|git_force)$/i]});import{cleanSchemaForGemini as bs}from"@xiaozhiclaw/provider-core/gemini-schema-utils";function De(t,e,o,n){return{role:"assistant",content:e||null,tool_calls:t,...o&&o.length>0?{thinkingBlocks:o}:{},...n?{reasoning_content:n}:{}}}function ke(t,e){let o=e.ok?typeof e.payload=="string"?e.payload:JSON.stringify(e.payload??""):`Error: ${e.error??"Tool execution failed"}`;return{role:"tool",tool_call_id:t,content:o,...!e.ok&&{is_error:!0},...e.toolReferences?.length?{toolReferences:e.toolReferences}:{},...e.imageUrls?.length?{imageUrls:e.imageUrls}:{}}}var Vn=/\b(?:daily|weekly|monthly)(?:\/(?:daily|weekly|monthly))* (?:usage )?limit(?:s)?(?: (?:exhausted|reached|exceeded))?\b/i,X={rateLimit:[/rate[_ ]limit|too many requests|429/,"model_cooldown","exceeded your current quota","resource has been exhausted","quota exceeded","resource_exhausted","usage limit",/\btpm\b/i,"tokens per minute","tokens per day"],overloaded:[/overloaded_error|"type"\s*:\s*"overloaded_error"/i,"overloaded",/service[_ ]unavailable.*(?:overload|capacity|high[_ ]demand)|(?:overload|capacity|high[_ ]demand).*service[_ ]unavailable/i,"high demand"],timeout:["timeout","timed out","service unavailable","deadline exceeded","context deadline exceeded","connection error","network error","network request failed","fetch failed","socket hang up",/\beconn(?:refused|reset|aborted)\b/i,/\benotfound\b/i,/\beai_again\b/i,/without sending (?:any )?chunks?/i,/\bstop reason:\s*(?:abort|error|network_error)\b/i,/\breason:\s*(?:abort|error|network_error)\b/i,/\bunhandled stop reason:\s*(?:abort|error|network_error)\b/i],billing:[/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment/i,"payment required","insufficient credits",/insufficient[_ ]quota/i,"credit balance","plans & billing","insufficient balance"],authPermanent:[/api[_ ]?key[_ ]?(?:revoked|invalid|deactivated|deleted)/i,"invalid_api_key","key has been disabled","key has been revoked","account has been deactivated",/could not (?:authenticate|validate).*(?:api[_ ]?key|credentials)/i,"permission_error","not allowed for this organization"],auth:[/invalid[_ ]?api[_ ]?key/,"incorrect api key","invalid token","authentication","re-authenticate","oauth token refresh failed","unauthorized","forbidden","access denied","insufficient permissions","insufficient permission",/missing scopes?:/i,"expired","token has expired",/\b401\b/,/\b403\b/,"no credentials found","no api key found"],format:["string should match pattern","tool_use.id","tool_use_id","messages.1.content.1.tool_use.id","invalid request format",/tool call id was.*must be/i]},Yn=/^(?:error[:\s-]+)?billing(?:\s+error)?(?:[:\s-]+|$)|^(?:error[:\s-]+)?(?:credit balance|insufficient credits?|payment required|http\s*402\b)/i,Jn=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|^\s*402\s+payment/i,Qn=512,Zn=/^(?:http\s*)?(\d{3})(?:\s+([\s\S]+))?$/i;var eo=new Set([500,502,503,504,521,522,523,524,529]),to=["insufficient credits","insufficient quota","credit balance","insufficient balance","plans & billing","add more credits","top up"],no=["upgrade your plan","upgrade plan","current plan","subscription"],oo=["daily","weekly","monthly"],ro=["try again","retry","temporary","cooldown"],so=["usage limit","rate limit","organization usage"],io=["organization","workspace"],ao=["billing period","exceeded","reached","exhausted"],lo=/["']?(?:status|code)["']?\s*[:=]\s*402\b|\bhttp\s*402\b|\berror(?:\s+code)?\s*[:=]?\s*402\b|\b(?:got|returned|received)\s+(?:a\s+)?402\b|^\s*402\s+payment required\b/i,co=/^(?:error[:\s-]+)?(?:(?:http\s*)?402(?:\s+payment required)?|payment required)(?:[:\s-]+|$)/i;function V(t,e){if(!t)return!1;let o=t.toLowerCase();return e.some(n=>n instanceof RegExp?n.test(o):o.includes(n))}function uo(t){return V(t,X.format)}function At(t){return V(t,X.rateLimit)}function po(t){return V(t,X.timeout)}function go(t){return Vn.test(t)}function Ue(t){let e=t.toLowerCase();return e?t.length>Qn?Jn.test(e):V(e,X.billing)?!0:Yn.test(t)?e.includes("upgrade")||e.includes("credits")||e.includes("payment")||e.includes("plan"):!1:!1}function Et(t){return V(t,X.authPermanent)}function mo(t){return V(t,X.auth)}function wt(t){return V(t,X.overloaded)}function W(t,e){return e.some(o=>t.includes(o))}function fo(t){return W(t,to)||W(t,no)&&t.includes("limit")||t.includes("billing hard limit")||t.includes("hard limit reached")||t.includes("maximum allowed")&&t.includes("limit")}function ho(t){let e=W(t,oo),o=t.includes("spend limit")||t.includes("spending limit"),n=W(t,io);return W(t,ro)&&W(t,so)||e&&(t.includes("usage limit")||o)||e&&t.includes("limit")&&t.includes("reset")||n&&t.includes("limit")&&(o||W(t,ao))}function yo(t){return t.trim().toLowerCase().replace(co,"").trim()}function It(t){let e=yo(t);return!e||fo(e)?"billing":At(e)||ho(e)?"rate_limit":"billing"}function To(t){return lo.test(t)?It(t):null}function Pt(t){let e=t.match(Zn);if(!e)return null;let o=Number(e[1]);return Number.isFinite(o)?{code:o,rest:(e[2]??"").trim()}:null}function bo(t){if(!t)return!1;let e=t.toLowerCase();return e.includes('"type":"api_error"')&&e.includes("internal server error")}function Co(t){let e=t.trim();if(!e)return!1;let o=Pt(e);return o?eo.has(o.code):!1}function Lt(t,e){return typeof t!="number"||!Number.isFinite(t)?null:t===402?e?It(e):"billing":t===429?"rate_limit":t===401||t===403?e&&Et(e)?"auth_permanent":"auth":t===408?"timeout":t===503?e&&wt(e)?"overloaded":"timeout":t===502||t===504?"timeout":t===529?"overloaded":t===400?e&&Ue(e)?"billing":"format":null}function ko(t){if(!t)return!1;let e=t.toLowerCase();return!!(e.includes("unknown model")||e.includes("model not found")||e.includes("model_not_found")||e.includes("not_found_error")||e.includes("does not exist")&&e.includes("model")||e.includes("invalid model")&&!e.includes("invalid model reference")||/models\/[^\s]+ is not found/i.test(t)||/\b404\b/.test(t)&&/not[-_ ]?found/i.test(t))}function Ro(t){if(!t)return!1;let e=t.toLowerCase();return e.includes("session not found")||e.includes("session does not exist")||e.includes("session expired")||e.includes("session invalid")||e.includes("conversation not found")||e.includes("conversation does not exist")||e.includes("conversation expired")||e.includes("conversation invalid")||e.includes("no such session")||e.includes("invalid session")||e.includes("session id not found")||e.includes("conversation id not found")}function Ot(t){if(Ro(t))return"session_expired";if(ko(t))return"model_not_found";let e=To(t);return e||(go(t)?Ue(t)?"billing":"rate_limit":At(t)?"rate_limit":wt(t)?"overloaded":Co(t)?Pt(t.trim())?.code===529?"overloaded":"timeout":bo(t)?"timeout":uo(t)?"format":Ue(t)?"billing":po(t)?"timeout":Et(t)?"auth_permanent":mo(t)?"auth":null)}var _o={timeout:"RETRYABLE_TRANSIENT",overloaded:"RETRYABLE_TRANSIENT",rate_limit:"RETRYABLE_DEGRADED",auth:"NON_RETRYABLE_AUTH",auth_permanent:"NON_RETRYABLE_AUTH",billing:"NON_RETRYABLE_QUOTA",format:"NON_RETRYABLE_CONTENT",model_not_found:"NON_RETRYABLE_CONTENT",session_expired:"NON_RETRYABLE_CONTENT",unknown:"RETRYABLE_TRANSIENT"},So=new Set(["RETRYABLE_TRANSIENT","RETRYABLE_DEGRADED","TOOL_EXECUTION_FAILED"]);function Q(t,e){let o=Lt(t,e)??(e?Ot(e):null);return o?_o[o]:typeof t=="number"&&t>=400&&t<500?"NON_RETRYABLE_CONTENT":"RETRYABLE_TRANSIENT"}function Fe(t){return So.has(t)}var Nt=4,se=class{constructor(e){this.estimateTokens=e}estimateTokens;compress(e,o){let n=[],r=[];for(let g of e)g.role==="system"?n.push(g):r.push(g);let s=o;for(let g of n)s-=this.estimateTokens(g);let l;for(let g of r)if(g.role==="user"){l=g;break}if(l&&(s-=this.estimateTokens(l)),s<=0)return{messages:l?[...n,l]:n,droppedCount:r.length-(l?1:0),strategy:"sliding-window"};let i=[],p=0;for(let g=r.length-1;g>=0;g--){let f=r[g];if(f===l)continue;let M=this.estimateTokens(f);if(s-M<0&&p>=Nt)break;if(s-M<0&&p<Nt){i.unshift(f),p++;continue}s-=M,i.unshift(f),p++}let h=[...n];return l&&!i.includes(l)&&h.push(l),h.push(...i),{messages:h,droppedCount:r.length-(i.length+(l&&!i.includes(l)?1:0)),strategy:"sliding-window"}}};var ie=class{constructor(e=8e3){this.maxToolResultChars=e}maxToolResultChars;compress(e,o){let n=0;return{messages:e.map(s=>s.role!=="tool"||typeof s.content!="string"||s.content.length<=this.maxToolResultChars?s:(n++,{...s,content:xo(s.content,this.maxToolResultChars)})),droppedCount:n,strategy:"tool-result-trim"}}};function xo(t,e){if(t.length<=e)return t;let o=t.slice(0,e);if(t.trimStart().startsWith("{")||t.trimStart().startsWith("[")){let s=Math.max(o.lastIndexOf("},"),o.lastIndexOf("],"),o.lastIndexOf(`}
|
|
2
2
|
`),o.lastIndexOf(`]
|
|
3
3
|
`));if(s>e*.5)return o.slice(0,s+1)+`
|
|
4
4
|
[...truncated: ${t.length-s-1} chars omitted]`}let r=o.lastIndexOf(`
|
|
5
5
|
`);return r>e*.7?o.slice(0,r)+`
|
|
6
6
|
[...truncated: ${t.length-r} chars omitted]`:o+`
|
|
7
|
-
[...truncated: ${t.length-e} chars omitted]`}function
|
|
8
|
-
`).map(y=>y.replace(/^\s*-\s*/,"").trim()).filter(Boolean);if(be(p)===o)return r.name}}catch{}}}catch{}return null}function Ao(t){if(!He(t))return 0;try{return nn(t,{withFileTypes:!0}).filter(e=>e.isDirectory()&&He(ze(t,e.name,"SKILL.md"))).length}catch{return 0}}function Eo(t,e){return!(!t.ok||t.existingSkillName||!t.multiStep||t.toolCallCount<Vt||t.distinctToolCount<Yt||Date.now()-on<Jt||e?.projectSkillsDir&&(Ao(e.projectSkillsDir)>=Xt||e.tools.length>0&&Mo(e.tools,e.projectSkillsDir))||e?.projectRoot&&e.tools.length>0&&!sn(e.projectRoot,e.tools))}function wo(t){return t.existingSkillName?t.feedback==="negative":!1}function Ce(t,e){return wo(t)?{type:"skill.improve",skillName:t.existingSkillName,reason:"negative user feedback on existing skill execution"}:Eo(t,e)?(on=Date.now(),{type:"skill.create",suggestedName:e.suggestedName??`auto-skill-${e.tools.slice(0,3).join("-")}`,description:`Multi-step orchestration using ${e.tools.join(", ")}`,tools:e.tools,stepCount:t.toolCallCount}):null}function an(t){return t.function&&typeof t.function=="object"&&typeof t.function.name=="string"?t.function.name.trim():typeof t.name=="string"?t.name.trim():""}function Io(t){return t==="enabled-eligible"||t==="installed-awaiting-approval"}function Po(t){return new Map((t??[]).map(e=>[e.toolName,e]))}function Lo(t){if(!t.eligibility?.length)return[...t.tools];let e=Po(t.eligibility);return t.tools.filter(o=>{let n=an(o);if(!n)return!1;let r=e.get(n);return!r||Io(r.status)})}function Oo(t){let e=[],o=t.compatibility??{},n=t.toolChoice;if(t.thinkingEnabled&&o.requireAutoWhenThinking){let r=typeof n=="object"&&n&&!Array.isArray(n)?String(n.type??""):n;r&&r!=="auto"&&r!=="none"&&(e.push("tool_choice downgraded to auto because thinking mode requires auto/none compatibility."),n="auto")}if(n==="required"&&o.allowRequiredToolChoice===!1){let r=o.requiredFallback??"auto";e.push(`tool_choice=required is not supported by this provider; downgraded to ${r}.`),n=r}if(n&&typeof n=="object"&&!Array.isArray(n)&&n.type==="function"&&o.allowNamedToolChoice===!1){let r=o.namedFallback??"required";e.push(`named tool_choice is not supported by this provider; downgraded to ${r}.`),n=r}return{normalizedToolChoice:n,warnings:e}}function qe(t){let e=Oo({toolChoice:t.toolChoice,thinkingEnabled:t.thinkingEnabled,compatibility:t.compatibility}),o=e.normalizedToolChoice,n=[...e.warnings],r=Lo({tools:t.tools,eligibility:t.eligibility});if(!o||o==="auto")return{tools:r,normalizedToolChoice:o,warnings:n};if(o==="none")return{tools:[],normalizedToolChoice:"none",warnings:n};if(o==="required"){if(r.length===0)throw new Error("tool_choice=required but no tools were provided");return{tools:r,normalizedToolChoice:"required",extraSystemPrompt:"You must call one of the available tools before responding.",warnings:n}}if(typeof o=="object"&&!Array.isArray(o)&&o.type==="function"){let s=o.function??void 0,l=typeof s?.name=="string"?s.name.trim():"";if(!l)throw new Error("tool_choice.function.name is required");let i=r.filter(p=>an(p)===l);if(i.length===0)throw new Error(`tool_choice requested unknown tool: ${l}`);return{tools:i,normalizedToolChoice:{type:"function",function:{name:l}},extraSystemPrompt:`You must call the ${l} tool before responding.`,warnings:n}}return{tools:r,normalizedToolChoice:o,warnings:n}}var No=["stop","aborted","timeout","cancelled","interrupted","error"],Do=["tool_calls","toolCalls","function_call","functionCall","raw_tool_calls","rawToolCalls"];function ln(t){return t==null?[]:typeof t=="string"?t.length>0?[{type:"text",text:t}]:[]:Array.isArray(t)?t:[{type:"text",text:String(t)}]}function Fo(t,e){return{...t,content:[...ln(t.content),...ln(e.content)]}}function Uo(t){if(!t||typeof t!="object")return!1;if(t.function&&typeof t.function=="object"){let e=t.function.name;if(typeof e=="string"&&e.length>0)return!0}return typeof t.name=="string"&&t.name.length>0}function Bo(t){return new Set((t??No).map(e=>e.trim().toLowerCase()))}function $o(t,e){return t?Bo(e).has(t.trim().toLowerCase()):!1}function We(t){if(!Array.isArray(t)||t.length===0)return[...t];let e=t.map(i=>{if(i.role==="assistant"&&Array.isArray(i.tool_calls)){let p=i.tool_calls.filter(y=>Uo(y));return{...i,...p.length>0?{tool_calls:p}:{tool_calls:void 0}}}return{...i}}),o=new Set;for(let i of e)if(!(i.role!=="assistant"||!Array.isArray(i.tool_calls)))for(let p of i.tool_calls)typeof p.id=="string"&&p.id&&o.add(p.id);let n=e.filter(i=>i.role!=="tool"?!0:!!(i.tool_call_id&&o.has(i.tool_call_id))),r=new Set;for(let i of n)i.role==="tool"&&typeof i.tool_call_id=="string"&&i.tool_call_id&&r.add(i.tool_call_id);let s=[];for(let i of n){if(i.role==="assistant"&&Array.isArray(i.tool_calls)&&i.tool_calls.length>0){let p=i.tool_calls.filter(y=>typeof y.id=="string"&&r.has(y.id));if(p.length===0){let{tool_calls:y,...g}=i;g.content!=null&&g.content!==""&&s.push(g);continue}if(p.length<i.tool_calls.length){s.push({...i,tool_calls:p});continue}}s.push(i)}let l=[];for(let i of s){let p=l.length>0?l[l.length-1]:void 0;if(i.role==="user"&&p?.role==="user"){l[l.length-1]=Fo(p,i);continue}l.push(i)}return l}function Xe(t,e){return $o(e?.stopReason,e?.forcedStopReasons)?t.map(o=>{if(o.role!=="assistant")return{...o};let n={...o};for(let r of Do)delete n[r];return n}):[...t]}function Ve(t,e){let o=e?.placeholderToolResult??"Error: Tool loop interrupted before the tool result was replayed.",n=new Set;for(let s of t)s.role==="tool"&&typeof s.tool_call_id=="string"&&s.tool_call_id&&n.add(s.tool_call_id);let r=[];for(let s of t)if(r.push({...s}),!(s.role!=="assistant"||!Array.isArray(s.tool_calls)||s.tool_calls.length===0))for(let l of s.tool_calls)typeof l.id!="string"||!l.id||n.has(l.id)||(n.add(l.id),r.push({role:"tool",tool_call_id:l.id,content:o}));return r}function Ye(t,e){let o=We(t),n=Xe(o,e);return Ve(n,e)}function jo(t){let e=new Set,o=new Set;for(let n of t){if(n.role==="assistant"&&Array.isArray(n.tool_calls))for(let r of n.tool_calls)typeof r.id=="string"&&r.id&&e.add(r.id);n.role==="tool"&&typeof n.tool_call_id=="string"&&n.tool_call_id&&o.add(n.tool_call_id)}return[...e].filter(n=>!o.has(n))}function Ko(t){let e=new Set;for(let o of t)o.role==="tool"&&typeof o.tool_call_id=="string"&&o.tool_call_id&&e.add(o.tool_call_id);return[...e]}function Go(t){return{round:t.round??0,maxRounds:t.maxRounds,pendingToolCallIds:[...t.pendingToolCallIds??[]],completedToolCallIds:[...t.completedToolCallIds??[]],lastStopReason:t.lastStopReason,replayMessages:[...t.replayMessages??[]]}}function Je(t,e){return{round:t.round+1,maxRounds:t.maxRounds,pendingToolCallIds:[...e.pendingToolCallIds??t.pendingToolCallIds],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function ke(t,e){return{round:t.round,maxRounds:t.maxRounds,pendingToolCallIds:[],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function Re(t){let e=[],o=We(t.replayMessages);o.length!==t.replayMessages.length&&e.push({kind:"drop-orphan-tool-result",detail:"Removed orphan tool results or invalid assistant tool calls."});let n=Xe(o,t.options);n.some((s,l)=>s!==o[l])&&e.push({kind:"strip-forced-stop-tool-metadata",detail:"Removed assistant tool-call metadata after forced stop."});let r=Ve(n,t.options);return r.length>n.length&&e.push({kind:"inject-placeholder-tool-result",detail:"Injected placeholder tool result for pending tool calls."}),{state:Go({maxRounds:t.maxRounds,round:t.round,lastStopReason:t.lastStopReason,replayMessages:r,pendingToolCallIds:jo(r),completedToolCallIds:Ko(r)}),recoveryActions:e}}var Ho=new Set(["main","sdk","agent","compact","hook","verification","side_question"]);function Qe(t){return t?Ho.has(t):!0}function Ze(t){return t===429||t===529}function _e(t,e=500,o=32e3){let n=Math.min(e*Math.pow(2,t-1),o);return n+Math.floor(Math.random()*n*.25)}var Ls={maxBackoffMs:300*1e3,resetCapMs:360*60*1e3,heartbeatIntervalMs:3e4};function Se(){let t=process.env.QLOGICAGENT_PERSISTENT_RETRY;return t==="1"||t==="true"}var ae=class extends Error{constructor(o,n){super(`Model fallback triggered: ${o} -> ${n}`);this.originalModel=o;this.fallbackModel=n;this.name="FallbackTriggeredError"}originalModel;fallbackModel};function et(t){return{promptTokens:0,hasAttemptedReactiveCompact:!1,currentMaxOutputTokens:t.maxOutputTokens,consecutiveTruncations:0,aborted:t.abortSignal?.aborted??!1}}function tt(t,e){if(t.aborted)return{level:"blocking",usagePercent:100,reason:"budget_exhausted"};let o=e.contextWindowTokens-e.responseBufferTokens-t.currentMaxOutputTokens,n=o>0?t.promptTokens/o*100:100;return t.promptTokens>=o?t.hasAttemptedReactiveCompact||!e.reactiveCompactEnabled?{level:"blocking",usagePercent:n,reason:"prompt_too_long"}:{level:"blocking",usagePercent:n,reason:"prompt_too_long"}:n>=85?{level:"warning",usagePercent:n,remainingTokens:o-t.promptTokens}:{level:"ok"}}function nt(t,e,o){let n=t.message?.toLowerCase()??"",r=t.status??0;return r===413||n.includes("prompt_too_long")||n.includes("context_length_exceeded")?!e.hasAttemptedReactiveCompact&&o.reactiveCompactEnabled?{action:"reactive_compact"}:{action:"abort",reason:"prompt_too_long_unrecoverable"}:r>=500&&r<600?{action:"retry",reason:`server_error_${r}`}:r===429?{action:"retry",reason:"rate_limited"}:r===401||r===403?{action:"abort",reason:"auth_error"}:r===404?{action:"abort",reason:"model_not_found"}:{action:"abort",reason:n||"unknown_error"}}function ot(t,e,o){if(!e.outputEscalationEnabled)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};if(t.consecutiveTruncations>=3)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};let n=Math.min(t.currentMaxOutputTokens*2,o);return n<=t.currentMaxOutputTokens?{shouldEscalate:!1,newMax:t.currentMaxOutputTokens}:{shouldEscalate:!0,newMax:n}}function rt(t,e){return t.aborted?!0:e.abortSignal?.aborted?(t.aborted=!0,!0):!1}var qo={maxConsecutiveFailures:3,minMessagesAfterCompact:4,targetUsagePercent:50};function st(){return{consecutiveFailures:0,attemptedThisTurn:!1,lastCompactAt:null,toolsAtLastCompact:[]}}function Y(t,e=qo){return!(t.attemptedThisTurn||t.consecutiveFailures>=e.maxConsecutiveFailures)}import{accumulateToolCalls as Dr}from"@xiaozhiclaw/provider-core";import{mkdir as Zo,writeFile as er}from"fs/promises";import{join as cn}from"path";import{tmpdir as tr}from"os";var nr="tool-results",un="<persisted-output>",or="</persisted-output>";function dn(){return{seenIds:new Set,replacements:new Map}}function pn(t){return cn(tr(),"qlogicagent-sessions",t,nr)}async function rr(t){try{await Zo(pn(t),{recursive:!0})}catch{}}function sr(t,e){let o=e.replace(/[^a-zA-Z0-9_-]/g,"_");return cn(pn(t),`${o}.txt`)}function ir(t,e){if(t.length<=e)return{preview:t,hasMore:!1};let n=t.slice(0,e).lastIndexOf(`
|
|
9
|
-
`),r=n>e*.5?n:e;return{preview:t.slice(0,r),hasMore:!0}}function
|
|
7
|
+
[...truncated: ${t.length-e} chars omitted]`}function Be(...t){return{compress(e,o){let n=e,r=0,s=[];for(let l of t){let i=l.compress(n,o);n=i.messages,r+=i.droppedCount,i.droppedCount>0&&s.push(i.strategy)}return{messages:n,droppedCount:r,strategy:s.length>0?s.join("+"):"none"}}}}var Dt={modelContextWindow:128e3,targetUsageRatio:.75,minBudget:16e3,maxBudget:12e4};function $e(t={}){let e={...Dt,...t},o=Math.floor(e.modelContextWindow*e.targetUsageRatio);return Math.max(e.minBudget,Math.min(o,e.maxBudget))}function je(t,e){let o=t/e;return o<=.8?"none":o<=1?"trim-only":o<=1.5?"sliding-window":"llm-summarize"}var ae=class{events=[];maxEvents;constructor(e=100){this.maxEvents=e}record(e){this.events.push(e),this.events.length>this.maxEvents&&this.events.shift()}snapshot(){let e=this.events.length;if(e===0)return{totalCompressions:0,totalLlmCalls:0,totalCacheInvalidations:0,averageCompressionRatio:1,averageLatencyMs:0,totalTokensSaved:0,recentEvents:[]};let o=0,n=0,r=0,s=0,l=0;for(let i of this.events)o+=i.tokensBefore>0?i.tokensAfter/i.tokensBefore:1,n+=i.latencyMs,r+=Math.max(0,i.tokensBefore-i.tokensAfter),i.usedLlm&&s++,i.cacheInvalidated&&l++;return{totalCompressions:e,totalLlmCalls:s,totalCacheInvalidations:l,averageCompressionRatio:o/e,averageLatencyMs:n/e,totalTokensSaved:r,recentEvents:this.events.slice(-10)}}reset(){this.events.length=0}},le=class{engines=new Map;activeId;register(e){this.engines.set(e.id,e)}activate(e){return this.engines.has(e)?(this.activeId=e,!0):!1}getActive(){return this.activeId?this.engines.get(this.activeId):void 0}listEngines(){return Array.from(this.engines.values()).map(e=>({id:e.id,label:e.label,active:e.id===this.activeId}))}};function Ut(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}var vo=new Set(["file_read","read","Read","bash","shell","Bash","grep","search","Grep","grep_search","glob","Glob","file_search","web_search","WebSearch","web_fetch","WebFetch","file_edit","edit","Edit","file_write","write","Write"]),Y=class{constructor(e=20,o=Ut){this.preserveRecentCount=e;this.estimateTokens=o}preserveRecentCount;estimateTokens;compress(e,o){if(e.length<=this.preserveRecentCount)return{messages:e,droppedCount:0,strategy:"micro-compact"};let n=e.length-this.preserveRecentCount,r=0,s=0;return{messages:e.map((i,p)=>{if(p>=n||i.role!=="tool"||typeof i.content!="string"||!i.name||!vo.has(i.name)||i.content.length<=200)return i;let h=this.estimateTokens(i);return s+=h,r++,{...i,content:`[result cleared \u2014 ${i.content.length} chars]`}}),droppedCount:r,strategy:"micro-compact",metrics:r>0?{tokensBefore:0,tokensAfter:0,compressionRatio:0,latencyMs:0,usedLlm:!1,cacheInvalidated:!1}:void 0}}};function Ke(t,e,o=Ut){if(e.size===0)return{messages:t,tokensFreed:0,removedCount:0};let n=0,r=0,s=[];for(let i of t){let p=i.tool_call_id??"";if(p&&e.has(p)){n+=o(i),r++,e.delete(p);continue}s.push(i)}let l=r>0?{role:"system",content:`[${r} messages removed by snip]`}:void 0;return{messages:s,tokensFreed:n,removedCount:r,boundaryMessage:l}}function Ge(){return{stages:[]}}function He(t,e,o){let n=o?.thresholdMessages??40;if(t.filter(i=>i.role!=="system").length<=n)return{messages:t,stagedCount:0};let s=Ft(t,e),l=Mo(s,e,n);if(l.length===0)return{messages:s,stagedCount:0};for(let i of l)e.stages.push(i);return s=Ft(t,e),{messages:s,stagedCount:l.length}}function qe(t,e){let o=0;for(let n of e.stages)n.committed||(n.committed=!0,o++);return o===0?{messages:t,committed:0}:{messages:Bt(t,e),committed:o}}function Ft(t,e){return e.stages.filter(n=>n.committed).length===0?t:Bt(t,e)}function Bt(t,e){let o=e.stages.filter(r=>r.committed).sort((r,s)=>s.range[0]-r.range[0]),n=[...t];for(let r of o){let[s,l]=r.range;if(s>=n.length)continue;let i=Math.min(l,n.length),p={role:"system",content:r.summary};n.splice(s,i-s,p)}return n}function Mo(t,e,o){let n=Math.max(0,t.length-Math.floor(o/2)),r=[],s=new Set(e.stages.map(p=>`${p.range[0]}-${p.range[1]}`)),l=-1,i=0;for(let p=0;p<n;p++){let h=t[p];if(h.role==="tool"||h.role==="assistant"&&typeof h.content=="string"&&h.content==="")l<0&&(l=p),i++;else{if(i>=3){let f=`${l}-${l+i}`;s.has(f)||r.push({id:`collapse_${l}_${l+i}`,range:[l,l+i],summary:`[${i} tool results collapsed]`,committed:!1})}l=-1,i=0}}if(i>=3){let p=`${l}-${l+i}`;s.has(p)||r.push({id:`collapse_${l}_${l+i}`,range:[l,l+i],summary:`[${i} tool results collapsed]`,committed:!1})}return r}import{existsSync as Xe,readFileSync as ln,writeFileSync as Ao,readdirSync as cn,mkdirSync as Eo}from"node:fs";import{join as Ve,dirname as wo}from"node:path";var $t=Math.min(Math.max(1,Number(process.env.TOOL_LOOP_DEFAULT_BUDGET)||25),100),jt=3,Kt=2,Re=2,Gt=128e3,Ht=13e3,qt=16384,zt=65536,Wt=3,Xt=65536,ze=500,Vt=3,Yt=5e4,Jt=2e5,We=2e3,Qt=3e4,Zt=3,ce=2;var en=20;var tn=3,nn=2,on=300*1e3,rn=3,sn=720*60*60*1e3;var vs=300*1e3;var Ms=3600*1e3;var As=50*1024,Es=500*1024,ws=500*1024*1024,Is=50*1024*1024;var Ps=60*1024;var un=0;var Io="skill-patterns.json";function dn(t){return Ve(t,".qlogicagent",Io)}function Po(t){let e=dn(t);try{return JSON.parse(ln(e,"utf8"))}catch{return{version:1,patterns:{}}}}function an(t,e){let o=dn(t);Eo(wo(o),{recursive:!0}),Ao(o,JSON.stringify(e,null,2),"utf8")}function Lo(t){let e=Date.now()-sn;for(let[o,n]of Object.entries(t.patterns))new Date(n.lastSeen).getTime()<e&&delete t.patterns[o]}function pn(t,e){if(e.length===0)return!1;let o=_e(e),n=Po(t);Lo(n);let r=new Date().toISOString(),s=n.patterns[o];if(s||(s={signature:o,count:0,firstSeen:r,lastSeen:r,promoted:!1},n.patterns[o]=s),s.promoted)return an(t,n),!1;s.count++,s.lastSeen=r;let l=s.count>=rn;return l&&(s.promoted=!0),an(t,n),l}function _e(t){return[...t].sort().join("+")}function Oo(t,e){if(!Xe(e))return null;let o=_e(t);try{let n=cn(e,{withFileTypes:!0});for(let r of n){if(!r.isDirectory())continue;let s=Ve(e,r.name,"SKILL.md");try{let i=ln(s,"utf8").match(/^tools:\s*\n((?:\s+-\s+\S+\n?)+)/m);if(i){let p=i[1].split(`
|
|
8
|
+
`).map(h=>h.replace(/^\s*-\s*/,"").trim()).filter(Boolean);if(_e(p)===o)return r.name}}catch{}}}catch{}return null}function No(t){if(!Xe(t))return 0;try{return cn(t,{withFileTypes:!0}).filter(e=>e.isDirectory()&&Xe(Ve(t,e.name,"SKILL.md"))).length}catch{return 0}}function Do(t,e){return!(!t.ok||t.existingSkillName||!t.multiStep||t.toolCallCount<tn||t.distinctToolCount<nn||Date.now()-un<on||e?.projectSkillsDir&&(No(e.projectSkillsDir)>=en||e.tools.length>0&&Oo(e.tools,e.projectSkillsDir))||e?.projectRoot&&e.tools.length>0&&!pn(e.projectRoot,e.tools))}function Uo(t){return t.existingSkillName?t.feedback==="negative":!1}function Se(t,e){return Uo(t)?{type:"skill.improve",skillName:t.existingSkillName,reason:"negative user feedback on existing skill execution"}:Do(t,e)?(un=Date.now(),{type:"skill.create",suggestedName:e.suggestedName??`auto-skill-${e.tools.slice(0,3).join("-")}`,description:`Multi-step orchestration using ${e.tools.join(", ")}`,tools:e.tools,stepCount:t.toolCallCount}):null}function gn(t){return t.function&&typeof t.function=="object"&&typeof t.function.name=="string"?t.function.name.trim():typeof t.name=="string"?t.name.trim():""}function Fo(t){return t==="enabled-eligible"||t==="installed-awaiting-approval"}function Bo(t){return new Map((t??[]).map(e=>[e.toolName,e]))}function $o(t){if(!t.eligibility?.length)return[...t.tools];let e=Bo(t.eligibility);return t.tools.filter(o=>{let n=gn(o);if(!n)return!1;let r=e.get(n);return!r||Fo(r.status)})}function jo(t){let e=[],o=t.compatibility??{},n=t.toolChoice;if(t.thinkingEnabled&&o.requireAutoWhenThinking){let r=typeof n=="object"&&n&&!Array.isArray(n)?String(n.type??""):n;r&&r!=="auto"&&r!=="none"&&(e.push("tool_choice downgraded to auto because thinking mode requires auto/none compatibility."),n="auto")}if(n==="required"&&o.allowRequiredToolChoice===!1){let r=o.requiredFallback??"auto";e.push(`tool_choice=required is not supported by this provider; downgraded to ${r}.`),n=r}if(n&&typeof n=="object"&&!Array.isArray(n)&&n.type==="function"&&o.allowNamedToolChoice===!1){let r=o.namedFallback??"required";e.push(`named tool_choice is not supported by this provider; downgraded to ${r}.`),n=r}return{normalizedToolChoice:n,warnings:e}}function Ye(t){let e=jo({toolChoice:t.toolChoice,thinkingEnabled:t.thinkingEnabled,compatibility:t.compatibility}),o=e.normalizedToolChoice,n=[...e.warnings],r=$o({tools:t.tools,eligibility:t.eligibility});if(!o||o==="auto")return{tools:r,normalizedToolChoice:o,warnings:n};if(o==="none")return{tools:[],normalizedToolChoice:"none",warnings:n};if(o==="required"){if(r.length===0)throw new Error("tool_choice=required but no tools were provided");return{tools:r,normalizedToolChoice:"required",extraSystemPrompt:"You must call one of the available tools before responding.",warnings:n}}if(typeof o=="object"&&!Array.isArray(o)&&o.type==="function"){let s=o.function??void 0,l=typeof s?.name=="string"?s.name.trim():"";if(!l)throw new Error("tool_choice.function.name is required");let i=r.filter(p=>gn(p)===l);if(i.length===0)throw new Error(`tool_choice requested unknown tool: ${l}`);return{tools:i,normalizedToolChoice:{type:"function",function:{name:l}},extraSystemPrompt:`You must call the ${l} tool before responding.`,warnings:n}}return{tools:r,normalizedToolChoice:o,warnings:n}}var Ko=["stop","aborted","timeout","cancelled","interrupted","error"],Go=["tool_calls","toolCalls","function_call","functionCall","raw_tool_calls","rawToolCalls"];function mn(t){return t==null?[]:typeof t=="string"?t.length>0?[{type:"text",text:t}]:[]:Array.isArray(t)?t:[{type:"text",text:String(t)}]}function Ho(t,e){return{...t,content:[...mn(t.content),...mn(e.content)]}}function qo(t){if(!t||typeof t!="object")return!1;if(t.function&&typeof t.function=="object"){let e=t.function.name;if(typeof e=="string"&&e.length>0)return!0}return typeof t.name=="string"&&t.name.length>0}function zo(t){return new Set((t??Ko).map(e=>e.trim().toLowerCase()))}function Wo(t,e){return t?zo(e).has(t.trim().toLowerCase()):!1}function Je(t){if(!Array.isArray(t)||t.length===0)return[...t];let e=t.map(i=>{if(i.role==="assistant"&&Array.isArray(i.tool_calls)){let p=i.tool_calls.filter(h=>qo(h));return{...i,...p.length>0?{tool_calls:p}:{tool_calls:void 0}}}return{...i}}),o=new Set;for(let i of e)if(!(i.role!=="assistant"||!Array.isArray(i.tool_calls)))for(let p of i.tool_calls)typeof p.id=="string"&&p.id&&o.add(p.id);let n=e.filter(i=>i.role!=="tool"?!0:!!(i.tool_call_id&&o.has(i.tool_call_id))),r=new Set;for(let i of n)i.role==="tool"&&typeof i.tool_call_id=="string"&&i.tool_call_id&&r.add(i.tool_call_id);let s=[];for(let i of n){if(i.role==="assistant"&&Array.isArray(i.tool_calls)&&i.tool_calls.length>0){let p=i.tool_calls.filter(h=>typeof h.id=="string"&&r.has(h.id));if(p.length===0){let{tool_calls:h,...g}=i;g.content!=null&&g.content!==""&&s.push(g);continue}if(p.length<i.tool_calls.length){s.push({...i,tool_calls:p});continue}}s.push(i)}let l=[];for(let i of s){let p=l.length>0?l[l.length-1]:void 0;if(i.role==="user"&&p?.role==="user"){l[l.length-1]=Ho(p,i);continue}l.push(i)}return l}function Qe(t,e){return Wo(e?.stopReason,e?.forcedStopReasons)?t.map(o=>{if(o.role!=="assistant")return{...o};let n={...o};for(let r of Go)delete n[r];return n}):[...t]}function Ze(t,e){let o=e?.placeholderToolResult??"Error: Tool loop interrupted before the tool result was replayed.",n=new Set;for(let s of t)s.role==="tool"&&typeof s.tool_call_id=="string"&&s.tool_call_id&&n.add(s.tool_call_id);let r=[];for(let s of t)if(r.push({...s}),!(s.role!=="assistant"||!Array.isArray(s.tool_calls)||s.tool_calls.length===0))for(let l of s.tool_calls)typeof l.id!="string"||!l.id||n.has(l.id)||(n.add(l.id),r.push({role:"tool",tool_call_id:l.id,content:o}));return r}function et(t,e){let o=Je(t),n=Qe(o,e);return Ze(n,e)}function Xo(t){let e=new Set,o=new Set;for(let n of t){if(n.role==="assistant"&&Array.isArray(n.tool_calls))for(let r of n.tool_calls)typeof r.id=="string"&&r.id&&e.add(r.id);n.role==="tool"&&typeof n.tool_call_id=="string"&&n.tool_call_id&&o.add(n.tool_call_id)}return[...e].filter(n=>!o.has(n))}function Vo(t){let e=new Set;for(let o of t)o.role==="tool"&&typeof o.tool_call_id=="string"&&o.tool_call_id&&e.add(o.tool_call_id);return[...e]}function Yo(t){return{round:t.round??0,maxRounds:t.maxRounds,pendingToolCallIds:[...t.pendingToolCallIds??[]],completedToolCallIds:[...t.completedToolCallIds??[]],lastStopReason:t.lastStopReason,replayMessages:[...t.replayMessages??[]]}}function tt(t,e){return{round:t.round+1,maxRounds:t.maxRounds,pendingToolCallIds:[...e.pendingToolCallIds??t.pendingToolCallIds],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function xe(t,e){return{round:t.round,maxRounds:t.maxRounds,pendingToolCallIds:[],completedToolCallIds:[...e.completedToolCallIds??t.completedToolCallIds],lastStopReason:e.lastStopReason??t.lastStopReason,replayMessages:[...e.replayMessages??t.replayMessages]}}function ve(t){let e=[],o=Je(t.replayMessages);o.length!==t.replayMessages.length&&e.push({kind:"drop-orphan-tool-result",detail:"Removed orphan tool results or invalid assistant tool calls."});let n=Qe(o,t.options);n.some((s,l)=>s!==o[l])&&e.push({kind:"strip-forced-stop-tool-metadata",detail:"Removed assistant tool-call metadata after forced stop."});let r=Ze(n,t.options);return r.length>n.length&&e.push({kind:"inject-placeholder-tool-result",detail:"Injected placeholder tool result for pending tool calls."}),{state:Yo({maxRounds:t.maxRounds,round:t.round,lastStopReason:t.lastStopReason,replayMessages:r,pendingToolCallIds:Xo(r),completedToolCallIds:Vo(r)}),recoveryActions:e}}var Jo=new Set(["main","sdk","agent","compact","hook","verification","side_question"]);function nt(t){return t?Jo.has(t):!0}function ot(t){return t===429||t===529}function Me(t,e=500,o=32e3){let n=Math.min(e*Math.pow(2,t-1),o);return n+Math.floor(Math.random()*n*.25)}var Hs={maxBackoffMs:300*1e3,resetCapMs:360*60*1e3,heartbeatIntervalMs:3e4};function Ae(){let t=process.env.QLOGICAGENT_PERSISTENT_RETRY;return t==="1"||t==="true"}var ue=class extends Error{constructor(o,n){super(`Model fallback triggered: ${o} -> ${n}`);this.originalModel=o;this.fallbackModel=n;this.name="FallbackTriggeredError"}originalModel;fallbackModel};function rt(t){return{promptTokens:0,hasAttemptedReactiveCompact:!1,currentMaxOutputTokens:t.maxOutputTokens,consecutiveTruncations:0,aborted:t.abortSignal?.aborted??!1}}function st(t,e){if(t.aborted)return{level:"blocking",usagePercent:100,reason:"budget_exhausted"};let o=e.contextWindowTokens-e.responseBufferTokens-t.currentMaxOutputTokens,n=o>0?t.promptTokens/o*100:100;return t.promptTokens>=o?t.hasAttemptedReactiveCompact||!e.reactiveCompactEnabled?{level:"blocking",usagePercent:n,reason:"prompt_too_long"}:{level:"blocking",usagePercent:n,reason:"prompt_too_long"}:n>=85?{level:"warning",usagePercent:n,remainingTokens:o-t.promptTokens}:{level:"ok"}}function it(t,e,o){let n=t.message?.toLowerCase()??"",r=t.status??0;return r===413||n.includes("prompt_too_long")||n.includes("context_length_exceeded")?!e.hasAttemptedReactiveCompact&&o.reactiveCompactEnabled?{action:"reactive_compact"}:{action:"abort",reason:"prompt_too_long_unrecoverable"}:r>=500&&r<600?{action:"retry",reason:`server_error_${r}`}:r===429?{action:"retry",reason:"rate_limited"}:r===401||r===403?{action:"abort",reason:"auth_error"}:r===404?{action:"abort",reason:"model_not_found"}:{action:"abort",reason:n||"unknown_error"}}function at(t,e,o){if(!e.outputEscalationEnabled)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};if(t.consecutiveTruncations>=3)return{shouldEscalate:!1,newMax:t.currentMaxOutputTokens};let n=Math.min(t.currentMaxOutputTokens*2,o);return n<=t.currentMaxOutputTokens?{shouldEscalate:!1,newMax:t.currentMaxOutputTokens}:{shouldEscalate:!0,newMax:n}}function lt(t,e){return t.aborted?!0:e.abortSignal?.aborted?(t.aborted=!0,!0):!1}var Zo={maxConsecutiveFailures:3,minMessagesAfterCompact:4,targetUsagePercent:50};function ct(){return{consecutiveFailures:0,attemptedThisTurn:!1,lastCompactAt:null,toolsAtLastCompact:[]}}function Z(t,e=Zo){return!(t.attemptedThisTurn||t.consecutiveFailures>=e.maxConsecutiveFailures)}import{accumulateToolCalls as zr}from"@xiaozhiclaw/provider-core";function Ee(t,e){let o=e.ok?typeof e.payload=="string"?e.payload:JSON.stringify(e.payload??""):`Error: ${e.error??"Tool execution failed"}`;return{role:"tool",tool_call_id:t,content:o,...!e.ok&&{is_error:!0},...e.toolReferences?.length?{toolReferences:e.toolReferences}:{},...e.imageUrls?.length?{imageUrls:e.imageUrls}:{}}}import{mkdir as ir,writeFile as ar}from"fs/promises";import{join as fn}from"path";import{tmpdir as lr}from"os";var cr="tool-results",hn="<persisted-output>",ur="</persisted-output>";function yn(){return{seenIds:new Set,replacements:new Map}}function Tn(t){return fn(lr(),"qlogicagent-sessions",t,cr)}async function dr(t){try{await ir(Tn(t),{recursive:!0})}catch{}}function pr(t,e){let o=e.replace(/[^a-zA-Z0-9_-]/g,"_");return fn(Tn(t),`${o}.txt`)}function gr(t,e){if(t.length<=e)return{preview:t,hasMore:!1};let n=t.slice(0,e).lastIndexOf(`
|
|
9
|
+
`),r=n>e*.5?n:e;return{preview:t.slice(0,r),hasMore:!0}}function bn(t){return t.includes(hn)}async function Cn(t,e,o){await dr(o);let n=pr(o,e);try{await ar(n,t,{encoding:"utf-8",flag:"wx"})}catch(l){if(l.code!=="EEXIST")return null}let{preview:r,hasMore:s}=gr(t,We);return{filepath:n,originalSize:t.length,preview:r,hasMore:s}}function kn(t){let e=`${hn}
|
|
10
10
|
`;return e+=`Output too large (${t.originalSize} chars). Full output saved to: ${t.filepath}
|
|
11
11
|
|
|
12
|
-
`,e+=`Preview (first ${
|
|
12
|
+
`,e+=`Preview (first ${We} bytes):
|
|
13
13
|
`,e+=t.preview,e+=t.hasMore?`
|
|
14
14
|
...
|
|
15
15
|
`:`
|
|
16
|
-
`,e+=
|
|
17
|
-
...[truncated ${t.length-n} chars]`}function ar(t){let e=[],o=[];for(let n of t)n.role==="tool"&&typeof n.content=="string"&&n.tool_call_id?gn(n.content)||o.push({toolCallId:n.tool_call_id,content:n.content,size:n.content.length}):n.role==="assistant"&&o.length>0&&(e.push(o),o=[]);return o.length>0&&e.push(o),e}function lr(t,e){let o=[],n=[],r=[];for(let s of t){let l=e.replacements.get(s.toolCallId);l!==void 0?o.push({...s,replacement:l}):e.seenIds.has(s.toolCallId)?n.push(s):r.push(s)}return{mustReapply:o,frozen:n,fresh:r}}function cr(t,e,o){let n=[...t].sort((l,i)=>i.size-l.size),r=[],s=e+t.reduce((l,i)=>l+i.size,0);for(let l of n){if(s<=o)break;r.push(l),s-=l.size}return r}async function yn(t,e,o,n=zt){let r=ar(t);if(r.length===0)return{messages:t,newlyReplacedCount:0};let s=new Map,l=[];for(let g of r){let{mustReapply:f,frozen:A,fresh:C}=lr(g,e);for(let _ of f)s.set(_.toolCallId,_.replacement);if(C.length===0){for(let _ of g)e.seenIds.add(_.toolCallId);continue}let x=A.reduce((_,w)=>_+w.size,0),R=C.reduce((_,w)=>_+w.size,0),S=x+R>n?cr(C,x,n):[],N=new Set(S.map(_=>_.toolCallId));for(let _ of g)N.has(_.toolCallId)||e.seenIds.add(_.toolCallId);S.length>0&&l.push(...S)}if(s.size===0&&l.length===0)return{messages:t,newlyReplacedCount:0};let i=await Promise.all(l.map(async g=>{let f=await mn(g.content,g.toolCallId,o);return{candidate:g,result:f}})),p=0;for(let{candidate:g,result:f}of i){if(e.seenIds.add(g.toolCallId),!f)continue;let A=fn(f);s.set(g.toolCallId,A),e.replacements.set(g.toolCallId,A),p++}return s.size===0?{messages:t,newlyReplacedCount:0}:{messages:t.map(g=>{if(g.role!=="tool"||!g.tool_call_id)return g;let f=s.get(g.tool_call_id);return f===void 0?g:{...g,content:f}}),newlyReplacedCount:p}}var ur=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),dr=new Set(["bash","execute_command","Bash","shell"]),ve=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??ur,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let o=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:o,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let o=this.tools.filter(r=>r.status==="executing"),n=this.config.maxConcurrentTools;return n&&n>0&&o.length>=n?!1:o.length===0||e&&o.every(r=>r.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let o;try{o=JSON.parse(e.toolCall.function.arguments)}catch{}let n=o?.command??o?.file_path??o?.pattern??"";if(typeof n=="string"&&n.length>0){let r=n.length>40?n.slice(0,40)+"\u2026":n;return`${e.toolCall.function.name}(${r})`}return e.toolCall.function.name}createSyntheticError(e,o){let n=this.erroredToolDescription,r=o==="user_interrupted"?"User rejected tool use":o==="discarded"?"Streaming fallback - tool execution discarded":n?`Cancelled: parallel tool call ${n} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:r,message:G(e.id,{ok:!1,error:r})}}async executeTool(e){e.status="executing";let n=(async()=>{let r=this.getAbortReason();if(r){e.results.push(this.createSyntheticError(e,r)),e.status="completed";return}let{toolInvoker:s,hooks:l,sessionId:i,turnId:p,log:y}=this.config,g=e.toolCall.function.name,f=!1,A=e.toolCall.function.arguments;if(l)try{let _=await l.invoke("tool.before_invoke",{sessionId:i,turnId:p,callId:e.id,toolName:g,arguments:pr(A)});if(_.action==="abort"){let w=_.reason??"blocked by policy";y.info(`tool ${g} blocked: ${w}`),e.results.push({callId:e.id,toolName:g,ok:!1,error:w,blocked:!0,blockReason:w,message:G(e.id,{ok:!1,error:w})}),e.status="completed";return}_.action==="continue"&&_.context?.arguments&&(A=JSON.stringify(_.context.arguments))}catch{}let C=await s.invoke(p,g,A,this.siblingAbortController.signal),x=this.getAbortReason();if(x&&!f){e.results.push(this.createSyntheticError(e,x)),e.status="completed";return}let R=!C.error,S=C.result;R&&S&&S.length>5e4&&(S=await hn(S,e.id,i));let N=G(e.id,{ok:R,payload:S,error:C.error,toolReferences:C.toolReferences,imageUrls:C.imageUrls});R||(f=!0,dr.has(g)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),l?.invoke(R?"tool.after_invoke":"tool.invoke_failed",{sessionId:i,turnId:p,callId:e.id,toolName:g,ok:R,...C.error?{error:C.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:g,ok:R,error:C.error,message:N}),e.status="completed"})();e.promise=n,n.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let o of e.results)yield o}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(n=>n.status==="executing"&&n.promise).map(n=>n.promise),o=new Promise(n=>{this.progressResolve=n});e.length>0&&await Promise.race([...e,o])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}};function pr(t){try{return JSON.parse(t)}catch{return}}import{readFile as Ki}from"node:fs/promises";import*as F from"node:fs";import{ProviderRegistry as hr,ProviderVariantResolver as yr}from"@xiaozhiclaw/provider-core";import{homedir as gr}from"node:os";import{join as Tn}from"node:path";import{existsSync as Li}from"node:fs";var mr=".qlogicagent";function fr(){return process.env.QLOGICAGENT_HOME||Tn(gr(),mr)}function bn(){return Tn(fr(),"settings.json")}var xe=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let o of e){this.pools.set(o.providerId,o);for(let n of o.keys)this.runtimeStates.set(n.id,this.createInitialState())}}acquireKey(e){let o=this.pools.get(e);if(!o||o.keys.length===0)return null;let n=Date.now(),r=this.getHealthyCandidates(o,n);if(r.length===0)return null;let s=this.selectByStrategy(r,o.strategy,n);if(!s)return null;let l=this.runtimeStates.get(s.id);return l.inFlight++,l.totalRequests++,l.lastUsedAt=n,l.requestTimestamps.push(n),{keyId:s.id,apiKey:s.key,providerId:e,release:i=>this.releaseKey(s.id,i)}}releaseKey(e,o){let n=this.runtimeStates.get(e);if(n)if(n.inFlight=Math.max(0,n.inFlight-1),o.success)n.consecutiveErrors=0,n.healthStatus="healthy",o.tokens&&(n.totalTokens+=o.tokens,n.tokenCounts.push(o.tokens));else if(n.consecutiveErrors++,n.lastErrorAt=Date.now(),o.errorCode===429){let r=o.retryAfter?o.retryAfter*1e3:3e4;n.cooldownUntil=Date.now()+r,n.healthStatus="cooldown"}else n.consecutiveErrors>=5?(n.cooldownUntil=Date.now()+6e4,n.healthStatus="cooldown"):n.consecutiveErrors>=3&&(n.healthStatus="degraded")}addProvider(e,o){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:o?.baseUrl,strategy:o?.strategy??"weighted-round-robin",keys:[],rateLimit:o?.rateLimit})}removeProvider(e){let o=this.pools.get(e);if(o){for(let n of o.keys)this.runtimeStates.delete(n.id);this.pools.delete(e)}}addKey(e,o,n){let r=this.pools.get(e);r||(r={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,r));let s=n?.id??crypto.randomUUID(),l={id:s,key:o,label:n?.label,weight:n?.weight??1,enabled:n?.enabled??!0};return r.keys.push(l),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let o of this.pools.values()){let n=o.keys.findIndex(r=>r.id===e);if(n!==-1){o.keys.splice(n,1),this.runtimeStates.delete(e);return}}}updateKey(e,o){for(let n of this.pools.values()){let r=n.keys.find(s=>s.id===e);if(r){if(o.label!==void 0&&(r.label=o.label),o.weight!==void 0&&(r.weight=o.weight),o.enabled!==void 0){r.enabled=o.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=o.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,o){let n=this.runtimeStates.get(e);n&&(n.healthStatus=o)}setStrategy(e,o){let n=this.pools.get(e);n&&(n.strategy=o)}setRateLimit(e,o){let n=this.pools.get(e);n&&(n.rateLimit=o)}getPoolStatus(e){let o=this.pools.get(e);return o?this.buildPoolStatus(o):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let o=this.pools.get(e);return o?this.getHealthyCandidates(o,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let o=new Set;for(let n of e){this.pools.set(n.providerId,n);for(let r of n.keys)o.add(r.id),this.runtimeStates.has(r.id)||this.runtimeStates.set(r.id,this.createInitialState())}for(let n of[...this.pools.keys()])e.some(r=>r.providerId===n)||this.pools.delete(n);for(let n of[...this.runtimeStates.keys()])o.has(n)||this.runtimeStates.delete(n)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,o){let n=[];for(let r of e.keys){if(!r.enabled)continue;let s=this.runtimeStates.get(r.id);if(s){if(s.healthStatus==="cooldown")if(o>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,o),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,o),s.tokenCounts.reduce((i,p)=>i+p,0)>=e.rateLimit.tpm*.9)||n.push(r))}}return n}selectByStrategy(e,o,n){if(e.length===0)return null;if(e.length===1)return e[0];switch(o){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let o=e.reduce((r,s)=>r+s.weight,0),n=Math.random()*o;for(let r of e)if(n-=r.weight,n<=0)return r;return e[e.length-1]}leastBusy(e){let o=1/0,n=e[0];for(let r of e){let l=this.runtimeStates.get(r.id)?.inFlight??0;(l<o||l===o&&r.weight>n.weight)&&(o=l,n=r)}return n}pruneWindow(e,o){let n=o-6e4;for(;e.length>0&&e[0]<n;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(o=>{let n=this.runtimeStates.get(o.id)??this.createInitialState();return{...o,inFlight:n.inFlight,totalRequests:n.totalRequests,totalTokens:n.totalTokens,lastUsedAt:n.lastUsedAt,lastErrorAt:n.lastErrorAt,consecutiveErrors:n.consecutiveErrors,cooldownUntil:n.cooldownUntil,healthStatus:o.enabled?n.healthStatus:"disabled"}})}}};var Tr=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],it=class{keyPool;coreProviderRegistry=new hr;providerVariantResolver=new yr(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=bn(),this.keyPool=new xe(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings}),this.hydrateCatalogModels()}getActiveModel(e){let o=this.bindings[e];if(!o)return null;let n=this.models.get(o);if(!n||!n.enabled)return null;let r=this.resolveTechnicalVariant(n,e),s=r?.provider??n.provider,l=r?.nativeModelId??n.nativeModelId??n.model,i=this.acquireKeyForProviderVariant(s);if(!i)return null;let{keyHandle:p,keyProviderId:y}=i,g=this.getProviderBaseUrl(s),f=this.getProviderBaseUrl(y);return{provider:s,model:l,apiKey:p.apiKey,baseUrl:g??(n.provider===s?n.baseUrl:void 0)??f,keyHandle:p}}peekActiveModel(e){let o=this.bindings[e];return o?this.models.get(o)??null:null}isAvailable(e){let o=this.peekActiveModel(e);return!!o?.enabled&&this.hasAvailableKeyForProviderVariant(o.provider)}resolveModelForPurpose(e){let o=this.peekActiveModel(e);return o?o.model:null}addProvider(e,o){this.keyPool.addProvider(e,o),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[o,n]of this.models)n.provider===e&&this.removeModel(o);this.emitChange()}addKey(e,o,n){let r=this.keyPool.addKey(e,o,n);return this.emitChange(),r}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,o){this.keyPool.updateKey(e,o),this.emitChange()}setKeyHealth(e,o){this.keyPool.setKeyHealth(e,o),this.emitChange()}setStrategy(e,o){this.keyPool.setStrategy(e,o),this.emitChange()}addModel(e){let o=e.id??`${e.provider}:${e.model}`;return this.models.set(o,{...e,id:o,enabled:this.modelEnabledOverrides.get(o)??e.enabled}),this.emitChange(),o}replaceCatalogModels(e){let o=new Map;for(let n of e)o.set(n.id,{...n,enabled:this.modelEnabledOverrides.get(n.id)??n.enabled});for(let n of this.modelEnabledOverrides.keys())o.has(n)||this.modelEnabledOverrides.delete(n);this.models=o;for(let[n,r]of Object.entries(this.bindings))r&&!this.models.has(r)&&delete this.bindings[n];this.emitChange()}migrateModelIds(e){for(let[o,n]of e){let r=this.modelEnabledOverrides.get(o);r!==void 0&&!this.modelEnabledOverrides.has(n)&&this.modelEnabledOverrides.set(n,r),this.modelEnabledOverrides.delete(o);for(let[s,l]of Object.entries(this.bindings))l===o&&(this.bindings[s]=n)}this.emitChange()}removeModel(e){this.models.delete(e),this.modelEnabledOverrides.delete(e);for(let[o,n]of Object.entries(this.bindings))n===e&&delete this.bindings[o];this.emitChange()}enableModel(e){let o=this.models.get(e);o&&(o.enabled=!0),this.modelEnabledOverrides.set(e,!0),this.emitChange()}disableModel(e){let o=this.models.get(e);o&&(o.enabled=!1),this.modelEnabledOverrides.set(e,!1),this.emitChange()}listModels(e){let o=[...this.models.values()];return e?.purpose&&(o=o.filter(n=>n.purposes.includes(e.purpose))),e?.provider&&(o=o.filter(n=>n.provider===e.provider)),e?.enabledOnly&&(o=o.filter(n=>n.enabled)),o}getModel(e){return this.models.get(e)??null}setBinding(e,o){let n=this.models.get(o);if(!n)throw new Error(`Model "${o}" not found in pool.`);if(!n.purposes.includes(e))throw new Error(`Model "${o}" does not support purpose "${e}".`);this.bindings[e]=o,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let o=this.bindings[e];return o?this.models.get(o)??null:null}getAllBindings(){let e={};for(let o of Tr){let n=this.bindings[o];e[o]=n?this.models.get(n)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{F.existsSync(this.settingsPath)&&(e=JSON.parse(F.readFileSync(this.settingsPath,"utf-8")))}catch{e={}}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let o={...e,providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}},n=this.settingsPath.replace(/[/\\][^/\\]+$/,"");F.existsSync(n)||F.mkdirSync(n,{recursive:!0}),F.writeFileSync(this.settingsPath,JSON.stringify(o,null,2),"utf-8")}load(){try{if(!F.existsSync(this.settingsPath))return!1;let e=F.readFileSync(this.settingsPath,"utf-8"),o=JSON.parse(e);return o.providers&&this.keyPool.reloadConfig(o.providers),this.models.clear(),this.modelEnabledOverrides.clear(),o.models&&this.loadModelState(o.models),this.hydrateCatalogModels(),this.bindings=o.bindings??{},this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}}}getTunable(e){try{if(!F.existsSync(this.settingsPath))return;let o=F.readFileSync(this.settingsPath,"utf-8");return JSON.parse(o).tunables?.[e]}catch{return}}getModelInfo(e,o){let n=this.listModels({provider:e}).find(r=>r.model===o);if(n)return{id:n.model,name:n.displayName,contextWindow:n.contextWindow,maxOutput:n.maxOutput,streamRequired:n.streamRequired}}getProviderDefaultModel(e){return this.listModels({provider:e,enabledOnly:!0})[0]?.model??this.listModels({provider:e})[0]?.model}hasConfiguredKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(o=>!!this.keyPool.getPoolStatus(o)?.keys.some(r=>r.enabled))}hasAvailableKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(o=>this.keyPool.hasAvailableKey(o))}listProviderDefs(){return this.keyPool.getAllStatus().map(e=>({id:e.providerId,name:e.providerId,transport:"",baseUrl:e.baseUrl??"",defaultModel:this.getProviderDefaultModel(e.providerId),models:this.listModels({provider:e.providerId}).map(o=>({id:o.model,name:o.displayName,contextWindow:o.contextWindow,maxOutput:o.maxOutput,streamRequired:o.streamRequired}))}))}resolveProviderApiKey(e){return this.getKeyForProvider(e)??void 0}onChange(e){return this.changeListeners.push(e),()=>{let o=this.changeListeners.indexOf(e);o>=0&&this.changeListeners.splice(o,1)}}getKeyForProvider(e){let n=this.acquireKeyForProviderVariant(e)?.keyHandle;if(!n)return null;let r=n.apiKey;return n.release({success:!0}),r}snapshotProviderKeys(){let e={};for(let o of this.keyPool.getAllStatus()){let n=this.getKeyForProvider(o.providerId);n&&(e[o.providerId]=n)}return e}getProviderBaseUrl(e){return this.coreProviderRegistry.getProvider(e)?.baseUrl??this.keyPool.getPoolStatus(e)?.baseUrl}acquireKeyForProviderVariant(e){for(let o of this.providerVariantKeyCandidates(e)){let n=this.keyPool.acquireKey(o);if(n)return{keyHandle:n,keyProviderId:o}}return null}resolveTechnicalVariant(e,o){let n=this.providerVariantKeyCandidates(e.provider).filter(s=>this.hasConfiguredKeyForProviderVariant(s));if(n.length===0)return;let r=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:kr(o,e.transport),capabilities:Rr(o),purpose:o,userPreference:{providerIds:n}});if(r)return{provider:r.provider,nativeModelId:r.nativeModelId}}providerVariantKeyCandidates(e){let o=[e],n=this.coreProviderRegistry.getProvider(e),r=n?.group??n?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===r&&o.push(s.id);return r!==e&&o.push(r),[...new Set(o)]}loadModelState(e){for(let o of e)typeof o.id!="string"||!o.id||typeof o.enabled=="boolean"&&this.modelEnabledOverrides.set(o.id,o.enabled)}hydrateCatalogModels(){let e=[];for(let n of this.coreProviderRegistry.listProviders())for(let r of this.coreProviderRegistry.listModels(n.id)){let s=r.aliases?.[0]??r.id,l=`${n.id}:${s}`;e.push({id:l,provider:n.id,model:s,displayName:r.name,purposes:br(r),baseUrl:n.baseUrl,enabled:this.modelEnabledOverrides.get(l)??!1,nativeModelId:r.id,transport:n.transport,contextWindow:r.contextWindow,maxOutput:r.maxOutput,streamRequired:r.streamRequired,capabilities:[...r.toolCall?["toolCall"]:[],...r.reasoning?["reasoning"]:[],...r.vision?["vision"]:[],...r.mediaType?[r.mediaType]:[]],pricing:{inputPer1M:r.costInput,outputPer1M:r.costOutput,cacheReadPer1M:r.costCacheRead,cacheWritePer1M:r.costCacheWrite}})}let o=new Map;for(let n of e)o.set(n.id,n);this.models=o}pruneInvalidBindings(){for(let[e,o]of Object.entries(this.bindings))o&&!this.models.has(o)&&delete this.bindings[e]}exportModelState(){let e=new Map;for(let[o,n]of this.modelEnabledOverrides)e.set(o,n);for(let o of this.models.values())e.set(o.id,o.enabled);return[...e.entries()].map(([o,n])=>({id:o,enabled:n}))}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}},Me=null;function at(){return Me||(Me=new it,Me.load()),Me}function br(t){let e=[];switch((!t.mediaType||t.mediaType==="image_understanding"||t.mediaType==="video_understanding")&&e.push("textGeneration"),(t.vision||t.mediaType==="image_understanding")&&e.push("imageUnderstanding"),t.mediaType==="video_understanding"&&e.push("videoUnderstanding"),t.mediaType){case"image":e.push("imageGeneration");break;case"video":e.push("videoGeneration");break;case"tts":e.push("tts");break;case"stt":e.push("stt");break;case"music":case"music_realtime":e.push("musicGeneration");break;case"voice_clone":e.push("voiceClone");break;case"embedding":e.push("embedding");break;case"3d":e.push("threeDGeneration");break;case"realtime_audio":e.push("realtimeAudio");break}return e.includes("textGeneration")&&e.push("smallModel"),[...new Set(e.length>0?e:["textGeneration"])]}function Cr(t){switch(t){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return t;default:return}}function kr(t,e){switch(t){case"imageUnderstanding":case"videoUnderstanding":case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return;default:return Cr(e)}}function Rr(t){switch(t){case"imageUnderstanding":case"videoUnderstanding":return["vision"];case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return["media"];default:return[]}}function ut(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}function lt(t){let e=0;for(let o of t)e+=ut(o);return e}var ct={"deepseek-v4-flash":1e6,"deepseek-v4-pro":1e6,"deepseek-chat":1e6,"deepseek-reasoner":1e6,"gpt-4o":128e3,"gpt-4o-mini":128e3,"claude-sonnet-4-20250514":2e5,"claude-3-5-haiku-20241022":2e5,"gemini-3.1-pro-preview":1e6,"gemini-3-flash-preview":1e6,"gemini-3.1-flash-lite":1e6};function _r(t){if(!t)return 128e3;if(t in ct)return ct[t];let e=t.toLowerCase();for(let[o,n]of Object.entries(ct))if(e.startsWith(o.toLowerCase()))return n;return 128e3}var Sr=8e3;var vr=new re(200);var xr=new se;function Cn(){return xr}function Mr(){return Ne(new oe(Sr),new X(20,ut),new ne(ut))}var Ar=null;function kn(t,e){let o=e?.budget??De({modelContextWindow:_r(e?.model)}),r=(e?.pipeline??Mr()).compress(t,o);if(r.droppedCount>0){let s=lt(t),l=lt(r.messages);vr.record({timestamp:Date.now(),strategy:r.strategy,tokensBefore:s,tokensAfter:l,droppedCount:r.droppedCount,latencyMs:r.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:r.metrics?.cacheInvalidated??!1,tier:Fe(s,o)})}return r.droppedCount>0&&Ar?.(r.droppedCount,lt(r.messages)),r}function Rn(t,e,o){let n=o-e;return`[Budget] ${Math.round(t)}% used (${e.toLocaleString()} / ${o.toLocaleString()} tokens). ${n.toLocaleString()} tokens remaining. `+(t>=90?"Wrap up your current taskyou are near the token limit.":"Continue workingdo not summarize prematurely.")}var Fr=new Set(["write","edit","patch","apply_patch"]);function Ur(t){let e=t.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(e)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(e)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(e)?"diagram":["csv","tsv","xlsx","xls"].includes(e)?"table":["ts","tsx","js","jsx","py","rs","go","java","c","cpp","h","cs","rb","sh","sql","json","yaml","yml","toml","xml","css","scss","vue","svelte"].includes(e)?"code":"file"}function Br(t){let e=t.split(".").pop()?.toLowerCase()??"";return{ts:"typescript",tsx:"typescriptreact",js:"javascript",jsx:"javascriptreact",py:"python",rs:"rust",go:"go",java:"java",c:"c",cpp:"cpp",h:"c",cs:"csharp",rb:"ruby",sh:"shellscript",sql:"sql",json:"json",yaml:"yaml",yml:"yaml",toml:"toml",xml:"xml",html:"html",css:"css",scss:"scss",vue:"vue",svelte:"svelte",md:"markdown"}[e]}var $r=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,jr=new Set(["search","grep","glob","find","list","read","exec"]);function Kr(t){if(!jr.has(t.toolName))return!1;let e=typeof t.message?.content=="string"?t.message.content.trim():"";return e.length>0&&e.length<200&&$r.test(e)}function vn(t,e){for(let o=t.length-1;o>=0;o--){let n=t[o];if(!n||n.role!=="tool")continue;let r=typeof n.content=="string"?n.content:"";if(r.startsWith("Error: "))return r.slice(7).trim()}}function Gr(t){return typeof t=="number"&&Number.isFinite(t)&&t>=1?Math.min(Math.round(t),100):Ot}function xn(t){let e=t.message.toLowerCase();return t.status===413||e.includes("prompt_too_long")||e.includes("context_length_exceeded")||e.includes("maximum context length")}function Hr(t){return t==="length"||t==="max_tokens"}function Mn(t){let e=t.message.toLowerCase();return(e.includes("image")||e.includes("media")||e.includes("file too large")||e.includes("payload too large"))&&(t.status===413||e.includes("too large")||e.includes("size"))}function zr(t){let e=t.headers;if(!e)return null;let o=e["retry-after"]??e["Retry-After"];if(!o)return null;let n=parseInt(o,10);return!isNaN(n)&&n>0?n*1e3:null}function qr(t){if(t.status!==400)return null;let e=t.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!e?.[1]||!e?.[3])return null;let o=parseInt(e[1],10),n=parseInt(e[3],10);if(isNaN(o)||isNaN(n))return null;let r=n-o-1e3;return r>=3e3?r:null}function Wr(t){return t.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*An(t,e,o,n){let{turnId:r,sessionId:s,messages:l,tools:i,model:p,apiKey:y,temperature:g=0,hooks:f,signal:A}=t,C={sessionId:s,turnId:r},x=t.maxTurns??0,R=t.querySource,{resolveToolEligibility:S}=await Promise.resolve().then(()=>(Sn(),_n)),N=S(i,t.toolEligibilityContext),_=N.eligibleTools;for(let b of N.blockedTools)yield{type:"tool_blocked",turnId:r,callId:"",name:b.toolName,reason:"blocked-by-policy"};if(!_.length){yield*Xr(r,p,l,y,g,A,e,n);return}let w=Gr(t.maxRounds),D={contextWindowTokens:t.contextWindowTokens??Ft,responseBufferTokens:Ut,maxOutputTokens:t.maxOutputTokens??Bt,abortSignal:A,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},M=new Set,L=0,ce=_,ue,a={messages:[...l],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:et(D),reactiveCompactState:st(),toolLoopState:Re({maxRounds:w,replayMessages:[...l]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:Be(),currentModel:p,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:dn(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},dt=Math.max(x*5,200),pt=0;for(;;){if(pt++,pt>dt){n.info(`hard iteration cap reached (${dt}), forcing completion`);let c=a.finalText||le(a.messages,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}let{messages:b,maxOutputTokensRecoveryCount:J,hasAttemptedReactiveCompact:ss,maxOutputTokensOverride:gt,turnCount:Q,guardState:I,reactiveCompactState:j,collapseStore:Ae}=a,{toolLoopState:U}=a;if(ue){try{let c=await ue;c&&(yield{type:"tool_use_summary",turnId:r,summary:c})}catch{}ue=void 0}if(t.refreshTools&&Q>1){let c=t.refreshTools();c!==ce&&(ce=c,n.debug(`tools refreshed: ${c.length} tools`))}if(rt(I,D)){n.info(`turn aborted by guard at turn ${Q}`),yield{type:"error",turnId:r,error:"Turn aborted",code:"ABORTED",usage:a.totalUsage};return}let H=tt(I,D);if(H.level==="blocking"){H.reason==="prompt_too_long"&&Y(j)&&(j.attemptedThisTurn=!0,I.hasAttemptedReactiveCompact=!0,n.info(`token budget blocking (${H.reason}), reactive compact needed`),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"token budget pre-check"}),n.info(`token budget blocking (${H.reason}), ending tool loop`);break}H.level==="warning"&&n.info(`token budget warning: ${H.usagePercent}% used, ${H.remainingTokens} remaining`);let P;{let c=await yn(b,a.contentReplacementState,s);P=c.messages,c.newlyReplacedCount>0&&(n.info(`tool-result-budget: persisted ${c.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:r,action:"tool_result_budget",detail:`${c.newlyReplacedCount} persisted`})}{let c=Ue(P,a.snipRemovedIds);P=c.messages,c.removedCount>0&&(n.info(`snip: removed ${c.removedCount} messages, freed ~${c.tokensFreed} tokens`),yield{type:"recovery",turnId:r,action:"snip",detail:`${c.removedCount} messages`})}{let u=new X().compress(P,0);u.droppedCount>0&&(P=u.messages,n.info(`microcompact: cleared ${u.droppedCount} old tool results`))}if(P=$e(P,Ae).messages,I.promptTokens>0){let c=D.contextWindowTokens*.75,u=Cn().getActive(),d;u?d=await u.compressAsync(P,c,{model:a.currentModel,sessionId:s}):d=kn(P,{budget:c,model:a.currentModel}),d.droppedCount>0&&(P=d.messages,n.info(`autocompact: ${d.strategy}, dropped ${d.droppedCount}`),yield{type:"recovery",turnId:r,action:"autocompact",detail:`${d.strategy}: ${d.droppedCount} dropped`},a.hasAttemptedReactiveCompact=!1,f?.invoke("context.after_compact",{...C,removedCount:d.droppedCount}).catch(()=>{}))}P=Wr(P);let de=qe({tools:ce,toolChoice:t.toolChoice??"auto"}),Z=Re({maxRounds:w,replayMessages:P,lastStopReason:U.lastStopReason,options:{stopReason:U.lastStopReason}}),mt=de.extraSystemPrompt?[{role:"system",content:de.extraSystemPrompt},...Z.state.replayMessages]:Z.state.replayMessages;U=Z.state,Z.recoveryActions.length>0&&n.debug(`tool loop recovery: ${Z.recoveryActions.map(c=>c.detail??c.kind).join("; ")}`),n.debug(`turn ${Q}, messages: ${mt.length}`),f?.invoke("turn.before_inference",{...C,model:a.currentModel}).catch(()=>{});let pe=!1,ft=[],ht=new Map,yt="stop",B,k=null,ge=!1,ee=[],O=[];try{for await(let c of e.stream({model:a.currentModel,messages:mt,tools:de.tools,toolChoice:de.normalizedToolChoice??"auto",temperature:g,maxTokens:(gt??I.currentMaxOutputTokens)||void 0,streamRequired:t.streamRequired,previousResponseId:a.lastResponseId,reasoning:t.reasoning,promptCacheKey:t.promptCacheKey,promptCacheRetention:t.promptCacheRetention,serviceTier:t.serviceTier,openaiBuiltinTools:t.openaiBuiltinTools,maxToolCalls:t.maxToolCalls,parallelToolCalls:t.parallelToolCalls,textVerbosity:t.textVerbosity},y,A))switch(c.type){case"delta":ft.push(c.text),pe||(yield{type:"delta",turnId:r,text:c.text});break;case"tool_call_delta":pe=!0,Dr(ht,c);break;case"reasoning_delta":ee.push(c.text);break;case"reasoning_block_complete":c.signature&&O.push({thinking:ee.join(""),signature:c.signature}),ee.length=0;break;case"usage":B={inputTokens:c.promptTokens,outputTokens:c.completionTokens,reasoningTokens:c.reasoningTokens,cacheRead:c.cacheReadTokens,cacheWrite:c.cacheCreationTokens};break;case"response_id":a.lastResponseId=c.id;break;case"annotations":yield{type:"annotations",turnId:r,annotations:c.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:r,message:`${c.toolType}: ${c.event}`};break;case"done":yt=c.finishReason;break}if(pe||f?.invoke("turn.after_inference",{...C,model:a.currentModel}).catch(()=>{}),t.postSamplingHooks&&t.postSamplingHooks.length>0){let c=a.currentModel;for(let u of t.postSamplingHooks)try{u({messages:[...P],model:c,sessionId:s})}catch{}}}catch(c){if(c instanceof ae&&t.fallbackModel){n.info(`model fallback triggered: ${c.originalModel} \u2192 ${c.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`${c.originalModel} \u2192 ${c.fallbackModel}`},a={...a,currentModel:c.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let u=c instanceof Error?c.message:String(c),d=typeof c?.status=="number"?c.status:void 0;if(!d&&u&&(u.includes("ECONNRESET")||u.includes("EPIPE"))){let T=(a.consecutiveApiRetries??0)+1;if(T>ie){n.info(`stale connection retry limit reached (${ie}), aborting`),yield{type:"error",turnId:r,error:u,code:"RETRIES_EXHAUSTED",usage:a.totalUsage};return}n.info(`stale connection (${u.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:r,action:"stale_connection_retry",detail:u.slice(0,80)},a={...a,consecutiveApiRetries:T,transition:void 0};continue}let m=qr({status:d,message:u});if(m!==null){n.info(`max_tokens overflow: adjusting to ${m}`),I.currentMaxOutputTokens=m,a={...a,maxOutputTokensOverride:m,transition:void 0};continue}if(Ze(d)){a.consecutive529Errors++;let T=2,E=t.fallbackModel&&a.currentModel!==t.fallbackModel;if(a.consecutive529Errors>T&&!E&&!Se()){n.info(`transient ${d} \xD7 ${a.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:r,error:`API unavailable after ${a.consecutive529Errors} consecutive ${d} errors`,code:"API_ERROR",usage:a.totalUsage};return}if(a.consecutive529Errors>=Wt&&t.fallbackModel&&a.currentModel!==t.fallbackModel){n.info(`529 \xD7 ${a.consecutive529Errors}: triggering fallback to ${t.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`529 \xD7 ${a.consecutive529Errors}`},a={...a,currentModel:t.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Se()){let h=_e(a.consecutive529Errors);n.info(`persistent retry: waiting ${h}ms (attempt ${a.consecutive529Errors})`);let v=h;for(;v>0;){if(A?.aborted){yield{type:"error",turnId:r,error:"Aborted during retry wait",code:"ABORTED",usage:a.totalUsage};return}yield{type:"heartbeat",turnId:r,message:`Retrying in ${Math.ceil(v/1e3)}s (${d})`};let $=Math.min(v,qt);await new Promise(Ie=>setTimeout(Ie,$)),v-=$}a={...a,transition:void 0};continue}if(Qe(R)){let v=zr({status:d,message:u})??_e(a.consecutive529Errors);n.info(`transient ${d}: retry in ${v}ms`),yield{type:"recovery",turnId:r,action:"retry",detail:`${d} retry in ${v}ms`},await new Promise($=>setTimeout($,v)),a={...a,transition:void 0};continue}n.info(`background source ${R}: not retrying ${d}`)}k={status:d,message:u}}if(k&&f?.invoke("turn.after_inference",{...C,model:a.currentModel,response:{error:k.message}}).catch(()=>{}),k)if(xn(k))ge=!0,n.info(`withheld prompt_too_long error (status=${k.status})`);else if(Mn(k))ge=!0,n.info(`withheld media_size error (status=${k.status})`);else{let c=nt({status:k.status??500,message:k.message},I,D);if(c.action==="reactive_compact"&&Y(j)&&(j.attemptedThisTurn=!0,I.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:r,action:"reactive_compact",detail:`API ${k.status??500}: ${k.message}`}),c.action==="retry"){let d=(a.consecutiveApiRetries??0)+1;if(d>ie){n.info(`API retry limit reached (${ie}), aborting`);let m=V(k.status,k.message);yield{type:"error",turnId:r,error:k.message,code:m,usage:a.totalUsage};return}yield{type:"recovery",turnId:r,action:"retry",detail:c.reason},a={...a,consecutiveApiRetries:d,transition:void 0};continue}let u=V(k.status,k.message);f?.invoke("stop.failure",{sessionId:s,reason:u,error:k.message}).catch(()=>{}),yield{type:"error",turnId:r,error:k.message,code:u,usage:a.totalUsage};return}B&&(a.totalUsage.inputTokens+=B.inputTokens,a.totalUsage.outputTokens+=B.outputTokens,B.reasoningTokens&&(a.totalUsage.reasoningTokens=(a.totalUsage.reasoningTokens??0)+B.reasoningTokens),B.cacheRead&&(a.totalUsage.cacheRead=(a.totalUsage.cacheRead??0)+B.cacheRead),B.cacheWrite&&(a.totalUsage.cacheWrite=(a.totalUsage.cacheWrite??0)+B.cacheWrite)),B?.inputTokens&&(I.promptTokens=B.inputTokens);let Tt=ft.join("");Tt&&(a.finalText=Tt);let K=[...ht.values()].map(c=>({id:c.id||`tc_${r}_${Q}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:c.name,arguments:c.arguments}}));if(K.length===0&&!pe){if(ge&&k&&xn(k)){if(a.transition?.reason!=="collapse_drain_retry"){let d=je(P,Ae);if(d.committed>0){n.info(`collapse drain: committed ${d.committed} stages`),yield{type:"recovery",turnId:r,action:"collapse_drain",detail:`${d.committed} stages committed`},a={...a,messages:d.messages,transition:{reason:"collapse_drain_retry",committed:d.committed}};continue}}if(Y(j)){j.attemptedThisTurn=!0,I.hasAttemptedReactiveCompact=!0,n.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"withheld prompt_too_long"},a={...a,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}n.info("withheld 413: recovery exhausted, surfacing error"),f?.invoke("stop.failure",{sessionId:s,reason:"prompt_too_long",error:k.message}).catch(()=>{}),yield{type:"error",turnId:r,error:k.message,code:"PROMPT_TOO_LONG",usage:a.totalUsage};return}if(ge&&k&&Mn(k)){if(Y(j)){j.attemptedThisTurn=!0,I.hasAttemptedReactiveCompact=!0,n.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"media error strip-retry"},a={...a,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}n.info("withheld media error: recovery exhausted"),f?.invoke("stop.failure",{sessionId:s,reason:"media_error",error:k.message}).catch(()=>{}),yield{type:"error",turnId:r,error:k.message,code:"IMAGE_ERROR",usage:a.totalUsage};return}if(Hr(yt)){I.consecutiveTruncations+=1;let d=t.modelMaxOutputTokens??$t,m=ot(I,D,d);if(m.shouldEscalate&>===void 0){I.currentMaxOutputTokens=m.newMax,n.info(`max_output_tokens escalate: ${m.newMax} tokens`),yield{type:"recovery",turnId:r,action:"output_escalation",detail:`${m.newMax} tokens`},a={...a,maxOutputTokensOverride:Kt,transition:{reason:"max_output_tokens_escalate"}};continue}if(J<jt){let T={role:"user",content:"Output token limit hit. Resume directly \u2014 no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};n.info(`max_output_tokens recovery #${J+1}`),yield{type:"recovery",turnId:r,action:"max_output_tokens_recovery",detail:`attempt ${J+1}`},a={...a,messages:[...P,T],maxOutputTokensRecoveryCount:J+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:J+1}};continue}n.info("max_output_tokens recovery exhausted, completing with partial content")}else I.consecutiveTruncations=0;if(U=ke(U,{replayMessages:b,lastStopReason:"completed"}),f){let d=await f.invoke("stop",{sessionId:s,reason:"completed"});if(d.action==="prevent"){n.info(`stop hook prevented continuation: ${d.reason??"no reason"}`),yield{type:"end",turnId:r,content:a.finalText,usage:a.totalUsage,model:a.currentModel};return}if(d.action==="abort"){let m=d.reason??"Stop hook requested continuation";n.info(`stop hook blocking: ${m}`);let T={role:"user",content:m},E={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,E,T],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(t.tokenBudget&&t.tokenBudget>0&&a.budgetContinuationCount<5){let d=a.totalUsage.inputTokens+a.totalUsage.outputTokens+(a.totalUsage.reasoningTokens??0),m=d/t.tokenBudget*100,T=d-a.lastBudgetGlobalTokens,E=a.budgetContinuationCount>=Gt&&T<Ke&&a.lastBudgetDeltaTokens<Ke;if(E&&n.info(`token budget early stop: diminishing returns at ${Math.round(m)}% (delta=${T})`),!E&&m<90){let h=a.budgetContinuationCount+1,v={role:"user",content:Rn(m,d,t.tokenBudget)};n.info(`token budget continuation #${h}: ${Math.round(m)}% used`),yield{type:"recovery",turnId:r,action:"budget_continuation",detail:`${Math.round(m)}% used (#${h})`};let $={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,$,v],budgetContinuationCount:h,lastBudgetDeltaTokens:T,lastBudgetGlobalTokens:d,transition:{reason:"token_budget_continuation"}};continue}}if(!a.stopHookActive){let d=l.find(h=>h.role==="user"),m=typeof d?.content=="string"?d.content:"",T=/创建文件|生成文件|写入|写一个|建一个|新建|重写|改写|create\s+(a\s+)?file|write\s+(a\s+)?file|make\s+(a\s+)?file|修改|改成|把.*改|文件名叫/i.test(m),E=M.has("write")||M.has("edit");if(T&&!E){if(n.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),L>0){let $=[...b].reverse().find(Ie=>Ie.role==="tool");$&&typeof $.content=="string"&&($.content+=`
|
|
16
|
+
`,e+=ur,e}async function Rn(t,e,o,n=Yt){if(t.length<=n||bn(t))return t;let r=await Cn(t,e,o);return r?kn(r):t.slice(0,n)+`
|
|
17
|
+
...[truncated ${t.length-n} chars]`}function mr(t){let e=[],o=[];for(let n of t)n.role==="tool"&&typeof n.content=="string"&&n.tool_call_id?bn(n.content)||o.push({toolCallId:n.tool_call_id,content:n.content,size:n.content.length}):n.role==="assistant"&&o.length>0&&(e.push(o),o=[]);return o.length>0&&e.push(o),e}function fr(t,e){let o=[],n=[],r=[];for(let s of t){let l=e.replacements.get(s.toolCallId);l!==void 0?o.push({...s,replacement:l}):e.seenIds.has(s.toolCallId)?n.push(s):r.push(s)}return{mustReapply:o,frozen:n,fresh:r}}function hr(t,e,o){let n=[...t].sort((l,i)=>i.size-l.size),r=[],s=e+t.reduce((l,i)=>l+i.size,0);for(let l of n){if(s<=o)break;r.push(l),s-=l.size}return r}async function _n(t,e,o,n=Jt){let r=mr(t);if(r.length===0)return{messages:t,newlyReplacedCount:0};let s=new Map,l=[];for(let g of r){let{mustReapply:f,frozen:M,fresh:_}=fr(g,e);for(let R of f)s.set(R.toolCallId,R.replacement);if(_.length===0){for(let R of g)e.seenIds.add(R.toolCallId);continue}let b=M.reduce((R,L)=>R+L.size,0),S=_.reduce((R,L)=>R+L.size,0),x=b+S>n?hr(_,b,n):[],w=new Set(x.map(R=>R.toolCallId));for(let R of g)w.has(R.toolCallId)||e.seenIds.add(R.toolCallId);x.length>0&&l.push(...x)}if(s.size===0&&l.length===0)return{messages:t,newlyReplacedCount:0};let i=await Promise.all(l.map(async g=>{let f=await Cn(g.content,g.toolCallId,o);return{candidate:g,result:f}})),p=0;for(let{candidate:g,result:f}of i){if(e.seenIds.add(g.toolCallId),!f)continue;let M=kn(f);s.set(g.toolCallId,M),e.replacements.set(g.toolCallId,M),p++}return s.size===0?{messages:t,newlyReplacedCount:0}:{messages:t.map(g=>{if(g.role!=="tool"||!g.tool_call_id)return g;let f=s.get(g.tool_call_id);return f===void 0?g:{...g,content:f}}),newlyReplacedCount:p}}var yr=new Set(["read_file","file_read","FileRead","grep","Grep","glob","Glob","search","list_dir","find_files","web_fetch","web_search","WebFetch","WebSearch"]),Tr=new Set(["bash","execute_command","Bash","shell"]),we=class{tools=[];hasErrored=!1;erroredToolDescription="";discarded=!1;siblingAbortController;progressResolve;config;concurrencySafe;constructor(e){this.config=e,this.concurrencySafe=e.concurrencySafeTools??yr,this.siblingAbortController=new AbortController,e.signal&&e.signal.addEventListener("abort",()=>{this.siblingAbortController.abort("parent_abort")},{once:!0})}discard(){this.discarded=!0}addTool(e){let o=this.concurrencySafe.has(e.function.name);this.tools.push({id:e.id,toolCall:e,status:"queued",isConcurrencySafe:o,results:[],pendingProgress:[]}),this.processQueue()}canExecuteTool(e){let o=this.tools.filter(r=>r.status==="executing"),n=this.config.maxConcurrentTools;return n&&n>0&&o.length>=n?!1:o.length===0||e&&o.every(r=>r.isConcurrencySafe)}async processQueue(){for(let e of this.tools)if(e.status==="queued"){if(this.canExecuteTool(e.isConcurrencySafe))await this.executeTool(e);else if(!e.isConcurrencySafe)break}}getAbortReason(){return this.discarded?"discarded":this.hasErrored?"sibling_error":this.config.signal?.aborted?"user_interrupted":null}getToolDescription(e){let o;try{o=JSON.parse(e.toolCall.function.arguments)}catch{}let n=o?.command??o?.file_path??o?.pattern??"";if(typeof n=="string"&&n.length>0){let r=n.length>40?n.slice(0,40)+"\u2026":n;return`${e.toolCall.function.name}(${r})`}return e.toolCall.function.name}createSyntheticError(e,o){let n=this.erroredToolDescription,r=o==="user_interrupted"?"User rejected tool use":o==="discarded"?"Streaming fallback - tool execution discarded":n?`Cancelled: parallel tool call ${n} errored`:"Cancelled: parallel tool call errored";return{callId:e.id,toolName:e.toolCall.function.name,ok:!1,error:r,message:Ee(e.id,{ok:!1,error:r})}}async executeTool(e){e.status="executing";let n=(async()=>{let r=this.getAbortReason();if(r){e.results.push(this.createSyntheticError(e,r)),e.status="completed";return}let{toolInvoker:s,hooks:l,sessionId:i,turnId:p,log:h}=this.config,g=e.toolCall.function.name,f=!1,M=e.toolCall.function.arguments;if(l)try{let A=await l.invoke("tool.before_invoke",{sessionId:i,turnId:p,callId:e.id,toolName:g,arguments:br(M)});if(A.action==="abort"){let k=A.reason??"blocked by policy";h.info(`tool ${g} blocked: ${k}`),e.results.push({callId:e.id,toolName:g,ok:!1,error:k,blocked:!0,blockReason:k,message:Ee(e.id,{ok:!1,error:k})}),e.status="completed";return}A.action==="continue"&&A.context?.arguments&&(M=JSON.stringify(A.context.arguments))}catch{}let _=Date.now(),b=await s.invoke(p,g,M,this.siblingAbortController.signal),S=Math.max(0,Date.now()-_),x=this.getAbortReason();if(x&&!f){e.results.push(this.createSyntheticError(e,x)),e.status="completed";return}let w=!b.error,R=b.result;w&&R&&R.length>5e4&&(R=await Rn(R,e.id,i));let L=Ee(e.id,{ok:w,payload:R,error:b.error,toolReferences:b.toolReferences,imageUrls:b.imageUrls});w||(f=!0,Tr.has(g)&&(this.hasErrored=!0,this.erroredToolDescription=this.getToolDescription(e),this.siblingAbortController.abort("sibling_error"))),l?.invoke(w?"tool.after_invoke":"tool.invoke_failed",{sessionId:i,turnId:p,callId:e.id,toolName:g,ok:w,...b.error?{error:b.error}:{}}).catch(()=>{}),e.results.push({callId:e.id,toolName:g,ok:w,error:b.error,durationMs:S,details:b.details,message:L}),e.status="completed"})();e.promise=n,n.finally(()=>{this.processQueue()})}*getCompletedResults(){if(!this.discarded){for(let e of this.tools)if(e.status!=="yielded"){if(e.status==="completed"&&e.results.length>0){e.status="yielded";for(let o of e.results)yield o}else if(e.status==="executing"&&!e.isConcurrencySafe)break}}}async*getRemainingResults(){if(!this.discarded){for(;this.hasUnfinishedTools();){await this.processQueue();for(let e of this.getCompletedResults())yield e;if(this.hasExecutingTools()&&!this.hasCompletedResults()){let e=this.tools.filter(n=>n.status==="executing"&&n.promise).map(n=>n.promise),o=new Promise(n=>{this.progressResolve=n});e.length>0&&await Promise.race([...e,o])}}for(let e of this.getCompletedResults())yield e}}hasCompletedResults(){return this.tools.some(e=>e.status==="completed")}hasExecutingTools(){return this.tools.some(e=>e.status==="executing")}hasUnfinishedTools(){return this.tools.some(e=>e.status!=="yielded")}};function br(t){try{return JSON.parse(t)}catch{return}}import{readFile as na}from"node:fs/promises";import*as F from"node:fs";import{ProviderRegistry as vr,ProviderVariantResolver as Mr}from"@xiaozhiclaw/provider-core";import{homedir as Cr}from"node:os";import{join as ut}from"node:path";import{existsSync as Wi}from"node:fs";var kr=".qlogicagent";function Rr(){return process.env.QLOGICAGENT_HOME||ut(Cr(),kr)}function _r(){let t=process.env.QLOGIC_LLMROUTER_USER_ID?.trim();if(t)return t;let e=process.env.QLOGIC_IMPLICIT_OWNER_ID?.trim();if(e)return e;let o=process.env.QLOGIC_DEVICE_ID?.trim();return o?`oc_${o}`:"oc_local"}function Sr(t){let e=t.trim();if(!e)throw new Error("ownerUserId is required for profile-scoped storage");return encodeURIComponent(e).replace(/\./g,"%2E")}function xr(t=_r()){return ut(Rr(),"profiles",Sr(t))}function Sn(){return ut(xr(),"settings.json")}var Ie=class{pools=new Map;runtimeStates=new Map;constructor(e){if(e)for(let o of e){this.pools.set(o.providerId,o);for(let n of o.keys)this.runtimeStates.set(n.id,this.createInitialState())}}acquireKey(e){let o=this.pools.get(e);if(!o||o.keys.length===0)return null;let n=Date.now(),r=this.getHealthyCandidates(o,n);if(r.length===0)return null;let s=this.selectByStrategy(r,o.strategy,n);if(!s)return null;let l=this.runtimeStates.get(s.id);return l.inFlight++,l.totalRequests++,l.lastUsedAt=n,l.requestTimestamps.push(n),{keyId:s.id,apiKey:s.key,providerId:e,release:i=>this.releaseKey(s.id,i)}}releaseKey(e,o){let n=this.runtimeStates.get(e);if(n)if(n.inFlight=Math.max(0,n.inFlight-1),o.success)n.consecutiveErrors=0,n.healthStatus="healthy",o.tokens&&(n.totalTokens+=o.tokens,n.tokenCounts.push(o.tokens));else if(n.consecutiveErrors++,n.lastErrorAt=Date.now(),o.errorCode===429){let r=o.retryAfter?o.retryAfter*1e3:3e4;n.cooldownUntil=Date.now()+r,n.healthStatus="cooldown"}else n.consecutiveErrors>=5?(n.cooldownUntil=Date.now()+6e4,n.healthStatus="cooldown"):n.consecutiveErrors>=3&&(n.healthStatus="degraded")}addProvider(e,o){this.pools.has(e)||this.pools.set(e,{providerId:e,baseUrl:o?.baseUrl,strategy:o?.strategy??"weighted-round-robin",keys:[],rateLimit:o?.rateLimit})}removeProvider(e){let o=this.pools.get(e);if(o){for(let n of o.keys)this.runtimeStates.delete(n.id);this.pools.delete(e)}}addKey(e,o,n){let r=this.pools.get(e);r||(r={providerId:e,strategy:"weighted-round-robin",keys:[]},this.pools.set(e,r));let s=n?.id??crypto.randomUUID(),l={id:s,key:o,label:n?.label,weight:n?.weight??1,enabled:n?.enabled??!0};return r.keys.push(l),this.runtimeStates.set(s,this.createInitialState()),s}removeKey(e){for(let o of this.pools.values()){let n=o.keys.findIndex(r=>r.id===e);if(n!==-1){o.keys.splice(n,1),this.runtimeStates.delete(e);return}}}updateKey(e,o){for(let n of this.pools.values()){let r=n.keys.find(s=>s.id===e);if(r){if(o.label!==void 0&&(r.label=o.label),o.weight!==void 0&&(r.weight=o.weight),o.enabled!==void 0){r.enabled=o.enabled;let s=this.runtimeStates.get(e);s&&(s.healthStatus=o.enabled?"healthy":"disabled")}return}}}setKeyHealth(e,o){let n=this.runtimeStates.get(e);n&&(n.healthStatus=o)}setStrategy(e,o){let n=this.pools.get(e);n&&(n.strategy=o)}setRateLimit(e,o){let n=this.pools.get(e);n&&(n.rateLimit=o)}getPoolStatus(e){let o=this.pools.get(e);return o?this.buildPoolStatus(o):null}getAllStatus(){return[...this.pools.values()].map(e=>this.buildPoolStatus(e))}getProviderIds(){return[...this.pools.keys()]}hasProvider(e){return this.pools.has(e)}hasAvailableKey(e){let o=this.pools.get(e);return o?this.getHealthyCandidates(o,Date.now()).length>0:!1}exportConfig(){return[...this.pools.values()]}reloadConfig(e){let o=new Set;for(let n of e){this.pools.set(n.providerId,n);for(let r of n.keys)o.add(r.id),this.runtimeStates.has(r.id)||this.runtimeStates.set(r.id,this.createInitialState())}for(let n of[...this.pools.keys()])e.some(r=>r.providerId===n)||this.pools.delete(n);for(let n of[...this.runtimeStates.keys()])o.has(n)||this.runtimeStates.delete(n)}createInitialState(){return{inFlight:0,totalRequests:0,totalTokens:0,lastUsedAt:0,lastErrorAt:0,consecutiveErrors:0,cooldownUntil:0,healthStatus:"healthy",requestTimestamps:[],tokenCounts:[]}}getHealthyCandidates(e,o){let n=[];for(let r of e.keys){if(!r.enabled)continue;let s=this.runtimeStates.get(r.id);if(s){if(s.healthStatus==="cooldown")if(o>=s.cooldownUntil)s.healthStatus="healthy",s.consecutiveErrors=0;else continue;s.healthStatus!=="disabled"&&(e.rateLimit?.rpm&&(this.pruneWindow(s.requestTimestamps,o),s.requestTimestamps.length>=e.rateLimit.rpm*.9)||e.rateLimit?.tpm&&(this.pruneWindow(s.tokenCounts,o),s.tokenCounts.reduce((i,p)=>i+p,0)>=e.rateLimit.tpm*.9)||n.push(r))}}return n}selectByStrategy(e,o,n){if(e.length===0)return null;if(e.length===1)return e[0];switch(o){case"weighted-round-robin":return this.weightedRandom(e);case"least-busy":return this.leastBusy(e);case"random":return e[Math.floor(Math.random()*e.length)];default:return this.weightedRandom(e)}}weightedRandom(e){let o=e.reduce((r,s)=>r+s.weight,0),n=Math.random()*o;for(let r of e)if(n-=r.weight,n<=0)return r;return e[e.length-1]}leastBusy(e){let o=1/0,n=e[0];for(let r of e){let l=this.runtimeStates.get(r.id)?.inFlight??0;(l<o||l===o&&r.weight>n.weight)&&(o=l,n=r)}return n}pruneWindow(e,o){let n=o-6e4;for(;e.length>0&&e[0]<n;)e.shift()}buildPoolStatus(e){return{providerId:e.providerId,baseUrl:e.baseUrl,strategy:e.strategy,rateLimit:e.rateLimit,keys:e.keys.map(o=>{let n=this.runtimeStates.get(o.id)??this.createInitialState();return{...o,inFlight:n.inFlight,totalRequests:n.totalRequests,totalTokens:n.totalTokens,lastUsedAt:n.lastUsedAt,lastErrorAt:n.lastErrorAt,consecutiveErrors:n.consecutiveErrors,cooldownUntil:n.cooldownUntil,healthStatus:o.enabled?n.healthStatus:"disabled"}})}}};var Ar=["textGeneration","smallModel","stt","tts","imageGeneration","imageUnderstanding","videoGeneration","videoUnderstanding","threeDGeneration","embedding","voiceClone","musicGeneration","realtimeAudio","realtimeVideo"],dt=class{keyPool;coreProviderRegistry=new vr;providerVariantResolver=new Mr(this.coreProviderRegistry);models=new Map;modelEnabledOverrides=new Map;bindings={};settingsPath;changeListeners=[];constructor(e){this.settingsPath=Sn(),this.keyPool=new Ie(e?.providers),e?.models&&this.loadModelState(e.models),e?.bindings&&(this.bindings={...e.bindings}),this.hydrateCatalogModels()}getActiveModel(e){let o=this.bindings[e];if(!o)return null;let n=this.models.get(o);if(!n||!n.enabled)return null;let r=this.resolveTechnicalVariant(n,e),s=r?.provider??n.provider,l=r?.nativeModelId??n.nativeModelId??n.model,i=this.acquireKeyForProviderVariant(s);if(!i)return null;let{keyHandle:p,keyProviderId:h}=i,g=this.getProviderBaseUrl(s),f=this.getProviderBaseUrl(h);return{provider:s,model:l,apiKey:p.apiKey,baseUrl:g??(n.provider===s?n.baseUrl:void 0)??f,keyHandle:p}}peekActiveModel(e){let o=this.bindings[e];return o?this.models.get(o)??null:null}isAvailable(e){let o=this.peekActiveModel(e);return!!o?.enabled&&this.hasAvailableKeyForProviderVariant(o.provider)}resolveModelForPurpose(e){let o=this.peekActiveModel(e);return o?o.model:null}addProvider(e,o){this.keyPool.addProvider(e,o),this.emitChange()}removeProvider(e){this.keyPool.removeProvider(e);for(let[o,n]of this.models)n.provider===e&&this.removeModel(o);this.emitChange()}addKey(e,o,n){let r=this.keyPool.addKey(e,o,n);return this.emitChange(),r}removeKey(e){this.keyPool.removeKey(e),this.emitChange()}updateKey(e,o){this.keyPool.updateKey(e,o),this.emitChange()}setKeyHealth(e,o){this.keyPool.setKeyHealth(e,o),this.emitChange()}setStrategy(e,o){this.keyPool.setStrategy(e,o),this.emitChange()}addModel(e){let o=e.id??`${e.provider}:${e.model}`;return this.models.set(o,{...e,id:o,enabled:this.modelEnabledOverrides.get(o)??e.enabled}),this.emitChange(),o}replaceCatalogModels(e){let o=new Map;for(let n of e)o.set(n.id,{...n,enabled:this.modelEnabledOverrides.get(n.id)??n.enabled});for(let n of this.modelEnabledOverrides.keys())o.has(n)||this.modelEnabledOverrides.delete(n);this.models=o;for(let[n,r]of Object.entries(this.bindings))r&&!this.models.has(r)&&delete this.bindings[n];this.emitChange()}replaceProviderModels(e,o){let n=new Map;for(let[s,l]of this.models)l.provider!==e&&n.set(s,l);for(let s of o)s.provider===e&&n.set(s.id,{...s,enabled:this.modelEnabledOverrides.get(s.id)??s.enabled});let r=`${e}:`;for(let s of this.modelEnabledOverrides.keys())s.startsWith(r)&&!n.has(s)&&this.modelEnabledOverrides.delete(s);this.models=n;for(let[s,l]of Object.entries(this.bindings))l&&!this.models.has(l)&&delete this.bindings[s];this.emitChange()}migrateModelIds(e){for(let[o,n]of e){let r=this.modelEnabledOverrides.get(o);r!==void 0&&!this.modelEnabledOverrides.has(n)&&this.modelEnabledOverrides.set(n,r),this.modelEnabledOverrides.delete(o);for(let[s,l]of Object.entries(this.bindings))l===o&&(this.bindings[s]=n)}this.emitChange()}removeModel(e){this.models.delete(e),this.modelEnabledOverrides.delete(e);for(let[o,n]of Object.entries(this.bindings))n===e&&delete this.bindings[o];this.emitChange()}enableModel(e){let o=this.models.get(e);o&&(o.enabled=!0),this.modelEnabledOverrides.set(e,!0),this.emitChange()}disableModel(e){let o=this.models.get(e);o&&(o.enabled=!1),this.modelEnabledOverrides.set(e,!1),this.emitChange()}listModels(e){let o=[...this.models.values()];return e?.purpose&&(o=o.filter(n=>n.purposes.includes(e.purpose))),e?.provider&&(o=o.filter(n=>n.provider===e.provider)),e?.enabledOnly&&(o=o.filter(n=>n.enabled)),o}getModel(e){return this.models.get(e)??null}setBinding(e,o){let n=this.models.get(o);if(!n)throw new Error(`Model "${o}" not found in pool.`);if(!n.purposes.includes(e))throw new Error(`Model "${o}" does not support purpose "${e}".`);this.bindings[e]=o,this.emitChange()}removeBinding(e){delete this.bindings[e],this.emitChange()}getBinding(e){let o=this.bindings[e];return o?this.models.get(o)??null:null}getAllBindings(){let e={};for(let o of Ar){let n=this.bindings[o];e[o]=n?this.models.get(n)??null:null}return e}getProviderStatus(e){return this.keyPool.getPoolStatus(e)}getAllProviderStatus(){return this.keyPool.getAllStatus()}save(){let e={};try{F.existsSync(this.settingsPath)&&(e=JSON.parse(F.readFileSync(this.settingsPath,"utf-8")))}catch{e={}}delete e.provider,delete e.apiKey,delete e.model,delete e.baseUrl;let o={...e,providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}},n=this.settingsPath.replace(/[/\\][^/\\]+$/,"");F.existsSync(n)||F.mkdirSync(n,{recursive:!0}),F.writeFileSync(this.settingsPath,JSON.stringify(o,null,2),"utf-8")}load(){try{if(!F.existsSync(this.settingsPath))return!1;let e=F.readFileSync(this.settingsPath,"utf-8"),o=JSON.parse(e);return o.providers&&this.keyPool.reloadConfig(o.providers),this.models.clear(),this.modelEnabledOverrides.clear(),o.models&&this.loadModelState(o.models),this.hydrateCatalogModels(),this.bindings=o.bindings??{},this.emitChange(),!0}catch{return!1}}exportConfig(){return{providers:this.keyPool.exportConfig(),models:this.exportModelState(),bindings:{...this.bindings}}}getTunable(e){try{if(!F.existsSync(this.settingsPath))return;let o=F.readFileSync(this.settingsPath,"utf-8");return JSON.parse(o).tunables?.[e]}catch{return}}getModelInfo(e,o){let n=this.listModels({provider:e}).find(r=>r.model===o);if(n)return{id:n.model,name:n.displayName,contextWindow:n.contextWindow,maxOutput:n.maxOutput,streamRequired:n.streamRequired}}getProviderDefaultModel(e){return this.listModels({provider:e,enabledOnly:!0})[0]?.model??this.listModels({provider:e})[0]?.model}hasConfiguredKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(o=>!!this.keyPool.getPoolStatus(o)?.keys.some(r=>r.enabled))}hasAvailableKeyForProviderVariant(e){return this.providerVariantKeyCandidates(e).some(o=>this.keyPool.hasAvailableKey(o))}listProviderDefs(){return this.keyPool.getAllStatus().map(e=>({id:e.providerId,name:e.providerId,transport:"",baseUrl:e.baseUrl??"",defaultModel:this.getProviderDefaultModel(e.providerId),models:this.listModels({provider:e.providerId}).map(o=>({id:o.model,name:o.displayName,contextWindow:o.contextWindow,maxOutput:o.maxOutput,streamRequired:o.streamRequired}))}))}getKnownProviderDef(e){let o=this.coreProviderRegistry.getProvider(e);return o?{id:o.id,name:o.name,transport:o.transport,baseUrl:o.baseUrl,defaultModel:o.defaultModel,group:o.group,models:this.coreProviderRegistry.listModels(o.id).map(n=>({id:n.aliases?.[0]??n.id,name:n.name,contextWindow:n.contextWindow,maxOutput:n.maxOutput,streamRequired:n.streamRequired,vision:n.vision,mediaType:n.mediaType}))}:null}resolveProviderApiKey(e){return this.getKeyForProvider(e)??void 0}onChange(e){return this.changeListeners.push(e),()=>{let o=this.changeListeners.indexOf(e);o>=0&&this.changeListeners.splice(o,1)}}getKeyForProvider(e){let n=this.acquireKeyForProviderVariant(e)?.keyHandle;if(!n)return null;let r=n.apiKey;return n.release({success:!0}),r}snapshotProviderKeys(){let e={};for(let o of this.keyPool.getAllStatus()){let n=this.getKeyForProvider(o.providerId);n&&(e[o.providerId]=n)}return e}getProviderBaseUrl(e){return this.coreProviderRegistry.getProvider(e)?.baseUrl??this.keyPool.getPoolStatus(e)?.baseUrl}acquireKeyForProviderVariant(e){for(let o of this.providerVariantKeyCandidates(e)){let n=this.keyPool.acquireKey(o);if(n)return{keyHandle:n,keyProviderId:o}}return null}resolveTechnicalVariant(e,o){let n=this.providerVariantKeyCandidates(e.provider).filter(s=>this.hasConfiguredKeyForProviderVariant(s));if(n.length===0)return;let r=this.providerVariantResolver.resolveBest({publicModel:e.model,requestedProtocol:Ir(o,e.transport),capabilities:Pr(o),purpose:o,userPreference:{providerIds:n}});if(r)return{provider:r.provider,nativeModelId:r.nativeModelId}}providerVariantKeyCandidates(e){let o=[e],n=this.coreProviderRegistry.getProvider(e),r=n?.group??n?.id??e;for(let s of this.coreProviderRegistry.listProviders())(s.group??s.id)===r&&o.push(s.id);return r!==e&&o.push(r),[...new Set(o)]}loadModelState(e){for(let o of e)typeof o.id!="string"||!o.id||typeof o.enabled=="boolean"&&this.modelEnabledOverrides.set(o.id,o.enabled)}hydrateCatalogModels(){let e=[];for(let n of this.coreProviderRegistry.listProviders())for(let r of this.coreProviderRegistry.listModels(n.id)){let s=r.aliases?.[0]??r.id,l=`${n.id}:${s}`;e.push({id:l,provider:n.id,model:s,displayName:r.name,purposes:Er(r),baseUrl:n.baseUrl,enabled:this.modelEnabledOverrides.get(l)??!1,nativeModelId:r.id,transport:n.transport,contextWindow:r.contextWindow,maxOutput:r.maxOutput,streamRequired:r.streamRequired,capabilities:[...r.toolCall?["toolCall"]:[],...r.reasoning?["reasoning"]:[],...r.vision?["vision"]:[],...r.mediaType?[r.mediaType]:[]],pricing:{inputPer1M:r.costInput,outputPer1M:r.costOutput,cacheReadPer1M:r.costCacheRead,cacheWritePer1M:r.costCacheWrite}})}let o=new Map;for(let n of e)o.set(n.id,n);this.models=o}exportModelState(){let e=new Map;for(let[o,n]of this.modelEnabledOverrides)e.set(o,n);for(let o of this.models.values())e.set(o.id,o.enabled);return[...e.entries()].map(([o,n])=>({id:o,enabled:n}))}emitChange(){for(let e of this.changeListeners)try{e()}catch{}}},Pe=null;function pt(){return Pe||(Pe=new dt,Pe.load()),Pe}function Er(t){let e=[];switch((!t.mediaType||t.mediaType==="image_understanding"||t.mediaType==="video_understanding")&&e.push("textGeneration"),(t.vision||t.mediaType==="image_understanding")&&e.push("imageUnderstanding"),t.mediaType==="video_understanding"&&e.push("videoUnderstanding"),t.mediaType){case"image":e.push("imageGeneration");break;case"video":e.push("videoGeneration");break;case"tts":e.push("tts");break;case"stt":e.push("stt");break;case"music":case"music_realtime":e.push("musicGeneration");break;case"voice_clone":e.push("voiceClone");break;case"embedding":e.push("embedding");break;case"3d":e.push("threeDGeneration");break;case"realtime_audio":e.push("realtimeAudio");break}return e.includes("textGeneration")&&e.push("smallModel"),[...new Set(e.length>0?e:["textGeneration"])]}function wr(t){switch(t){case"openai-chat":case"openai-responses":case"anthropic-messages":case"volcengine-responses":return t;default:return}}function Ir(t,e){switch(t){case"imageUnderstanding":case"videoUnderstanding":case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return;default:return wr(e)}}function Pr(t){switch(t){case"imageUnderstanding":case"videoUnderstanding":return["vision"];case"imageGeneration":case"videoGeneration":case"threeDGeneration":case"stt":case"tts":case"voiceClone":case"musicGeneration":case"realtimeAudio":case"realtimeVideo":case"embedding":return["media"];default:return[]}}function ft(t){let e=typeof t.content=="string"?t.content:t.content!=null?JSON.stringify(t.content):"";return Math.ceil(e.length/4)}function gt(t){let e=0;for(let o of t)e+=ft(o);return e}var mt={"deepseek-v4-flash":1e6,"deepseek-v4-pro":1e6,"deepseek-chat":1e6,"deepseek-reasoner":1e6,"gpt-4o":128e3,"gpt-4o-mini":128e3,"claude-sonnet-4-20250514":2e5,"claude-3-5-haiku-20241022":2e5,"gemini-3.1-pro-preview":1e6,"gemini-3-flash-preview":1e6,"gemini-3.1-flash-lite":1e6};function Lr(t){if(!t)return 128e3;if(t in mt)return mt[t];let e=t.toLowerCase();for(let[o,n]of Object.entries(mt))if(e.startsWith(o.toLowerCase()))return n;return 128e3}var Or=8e3;var Nr=new ae(200);var Dr=new le;function xn(){return Dr}function Ur(){return Be(new ie(Or),new Y(20,ft),new se(ft))}var Fr=null;function vn(t,e){let o=e?.budget??$e({modelContextWindow:Lr(e?.model)}),r=(e?.pipeline??Ur()).compress(t,o);if(r.droppedCount>0){let s=gt(t),l=gt(r.messages);Nr.record({timestamp:Date.now(),strategy:r.strategy,tokensBefore:s,tokensAfter:l,droppedCount:r.droppedCount,latencyMs:r.metrics?.latencyMs??0,usedLlm:!1,cacheInvalidated:r.metrics?.cacheInvalidated??!1,tier:je(s,o)})}return r.droppedCount>0&&Fr?.(r.droppedCount,gt(r.messages)),r}function Mn(t,e,o){let n=o-e;return`[Budget] ${Math.round(t)}% used (${e.toLocaleString()} / ${o.toLocaleString()} tokens). ${n.toLocaleString()} tokens remaining. `+(t>=90?"Wrap up your current taskyou are near the token limit.":"Continue workingdo not summarize prematurely.")}var Wr=new Set(["write","edit","patch","apply_patch"]);function Xr(t){let e=t.split(".").pop()?.toLowerCase()??"";return["png","jpg","jpeg","gif","webp","svg","bmp","ico"].includes(e)?"image":["md","txt","pdf","doc","docx","rtf","html"].includes(e)?"document":["mermaid","mmd","dot","puml","plantuml"].includes(e)?"diagram":["csv","tsv","xlsx","xls"].includes(e)?"table":["ts","tsx","js","jsx","py","rs","go","java","c","cpp","h","cs","rb","sh","sql","json","yaml","yml","toml","xml","css","scss","vue","svelte"].includes(e)?"code":"file"}function Vr(t){let e=t.split(".").pop()?.toLowerCase()??"";return{ts:"typescript",tsx:"typescriptreact",js:"javascript",jsx:"javascriptreact",py:"python",rs:"rust",go:"go",java:"java",c:"c",cpp:"cpp",h:"c",cs:"csharp",rb:"ruby",sh:"shellscript",sql:"sql",json:"json",yaml:"yaml",yml:"yaml",toml:"toml",xml:"xml",html:"html",css:"css",scss:"scss",vue:"vue",svelte:"svelte",md:"markdown"}[e]}var Yr=/^no (matches|files|results) found\.?$|^file not found|^not found|^0 results|^\(exit code \d+, no output\)$/i,Jr=new Set(["search","grep","glob","find","list","read","exec"]);function Qr(t){if(!Jr.has(t.toolName))return!1;let e=typeof t.message?.content=="string"?t.message.content.trim():"";return e.length>0&&e.length<200&&Yr.test(e)}function wn(t,e){for(let o=t.length-1;o>=0;o--){let n=t[o];if(!n||n.role!=="tool")continue;let r=typeof n.content=="string"?n.content:"";if(r.startsWith("Error: "))return r.slice(7).trim()}}function Zr(t){return typeof t=="number"&&Number.isFinite(t)&&t>=1?Math.min(Math.round(t),100):$t}function In(t){let e=t.message.toLowerCase();return t.status===413||e.includes("prompt_too_long")||e.includes("context_length_exceeded")||e.includes("maximum context length")}function es(t){return t==="length"||t==="max_tokens"}function Pn(t){let e=t.message.toLowerCase();return(e.includes("image")||e.includes("media")||e.includes("file too large")||e.includes("payload too large"))&&(t.status===413||e.includes("too large")||e.includes("size"))}function ts(t){let e=t.headers;if(!e)return null;let o=e["retry-after"]??e["Retry-After"];if(!o)return null;let n=parseInt(o,10);return!isNaN(n)&&n>0?n*1e3:null}function ns(t){if(t.status!==400)return null;let e=t.message.match(/input length and `max_tokens` exceed context limit: (\d+) \+ (\d+) > (\d+)/);if(!e?.[1]||!e?.[3])return null;let o=parseInt(e[1],10),n=parseInt(e[3],10);if(isNaN(o)||isNaN(n))return null;let r=n-o-1e3;return r>=3e3?r:null}function os(t){return t.filter(e=>e.role!=="assistant"?!0:!(typeof e.content=="string"&&e.content.trim()===""))}async function*Ln(t,e,o,n){let{turnId:r,sessionId:s,messages:l,tools:i,model:p,apiKey:h,temperature:g=0,hooks:f,signal:M}=t,_={sessionId:s,turnId:r},b=t.maxTurns??0,S=t.querySource,{resolveToolEligibility:x}=await Promise.resolve().then(()=>(En(),An)),w=x(i,t.toolEligibilityContext),R=w.eligibleTools;for(let T of w.blockedTools)yield{type:"tool_blocked",turnId:r,callId:"",name:T.toolName,reason:"blocked-by-policy"};if(!R.length){yield*ss(r,p,l,h,g,M,e,n);return}let L=Zr(t.maxRounds),A={contextWindowTokens:t.contextWindowTokens??Gt,responseBufferTokens:Ht,maxOutputTokens:t.maxOutputTokens??qt,abortSignal:M,reactiveCompactEnabled:!0,outputEscalationEnabled:!0},k=new Set,O=0,J=R,pe,ge=!1,ht=0,a={messages:[...l],maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:1,transition:void 0,guardState:rt(A),reactiveCompactState:ct(),toolLoopState:ve({maxRounds:L,replayMessages:[...l]}).state,consecutiveFailedRounds:0,finalText:"",totalUsage:{inputTokens:0,outputTokens:0},collapseStore:Ge(),currentModel:p,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:void 0,lastResponseId:void 0,snipRemovedIds:new Set,contentReplacementState:yn(),budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:new Map,toolFailureCounts:new Map,fileReadCounts:new Map},yt=Math.max(b*5,200),Tt=0;for(;;){if(Tt++,Tt>yt){n.info(`hard iteration cap reached (${yt}), forcing completion`);let c=a.finalText||de(a.messages,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}let{messages:T,maxOutputTokensRecoveryCount:ee,hasAttemptedReactiveCompact:hs,maxOutputTokensOverride:bt,turnCount:te,guardState:I,reactiveCompactState:q,collapseStore:Le}=a,{toolLoopState:B}=a;if(pe){try{let c=await pe;c&&(yield{type:"tool_use_summary",turnId:r,summary:c})}catch{}pe=void 0}if(t.refreshTools&&te>1){let c=t.refreshTools();c!==J&&(J=c,n.debug(`tools refreshed: ${c.length} tools`))}if(lt(I,A)){n.info(`turn aborted by guard at turn ${te}`),yield{type:"error",turnId:r,error:"Turn aborted",code:"ABORTED",usage:a.totalUsage};return}let z=st(I,A);if(z.level==="blocking"){z.reason==="prompt_too_long"&&Z(q)&&(q.attemptedThisTurn=!0,I.hasAttemptedReactiveCompact=!0,n.info(`token budget blocking (${z.reason}), reactive compact needed`),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"token budget pre-check"}),n.info(`token budget blocking (${z.reason}), ending tool loop`);break}z.level==="warning"&&n.info(`token budget warning: ${z.usagePercent}% used, ${z.remainingTokens} remaining`);let P;{let c=await _n(T,a.contentReplacementState,s);P=c.messages,c.newlyReplacedCount>0&&(n.info(`tool-result-budget: persisted ${c.newlyReplacedCount} oversized tool results`),yield{type:"recovery",turnId:r,action:"tool_result_budget",detail:`${c.newlyReplacedCount} persisted`})}{let c=Ke(P,a.snipRemovedIds);P=c.messages,c.removedCount>0&&(n.info(`snip: removed ${c.removedCount} messages, freed ~${c.tokensFreed} tokens`),yield{type:"recovery",turnId:r,action:"snip",detail:`${c.removedCount} messages`})}{let u=new Y().compress(P,0);u.droppedCount>0&&(P=u.messages,n.info(`microcompact: cleared ${u.droppedCount} old tool results`))}if(P=He(P,Le).messages,I.promptTokens>0){let c=A.contextWindowTokens*.75,u=xn().getActive(),d;u?d=await u.compressAsync(P,c,{model:a.currentModel,sessionId:s}):d=vn(P,{budget:c,model:a.currentModel}),d.droppedCount>0&&(P=d.messages,n.info(`autocompact: ${d.strategy}, dropped ${d.droppedCount}`),yield{type:"recovery",turnId:r,action:"autocompact",detail:`${d.strategy}: ${d.droppedCount} dropped`},a.hasAttemptedReactiveCompact=!1,f?.invoke("context.after_compact",{..._,removedCount:d.droppedCount}).catch(()=>{}))}P=os(P);let $n=t.toolChoice==="required"&&ge?"auto":t.toolChoice??"auto",me=Ye({tools:J,toolChoice:$n}),ne=ve({maxRounds:L,replayMessages:P,lastStopReason:B.lastStopReason,options:{stopReason:B.lastStopReason}}),Ct=me.extraSystemPrompt?[{role:"system",content:me.extraSystemPrompt},...ne.state.replayMessages]:ne.state.replayMessages;B=ne.state,ne.recoveryActions.length>0&&n.debug(`tool loop recovery: ${ne.recoveryActions.map(c=>c.detail??c.kind).join("; ")}`),n.debug(`turn ${te}, messages: ${Ct.length}`),f?.invoke("turn.before_inference",{..._,model:a.currentModel}).catch(()=>{});let fe=!1,kt=[],Rt=new Map,_t="stop",$,C=null,he=!1,oe=[],D=[];try{for await(let c of e.stream({model:a.currentModel,messages:Ct,tools:me.tools,toolChoice:me.normalizedToolChoice??"auto",temperature:g,maxTokens:(bt??I.currentMaxOutputTokens)||void 0,streamRequired:t.streamRequired,previousResponseId:a.lastResponseId,reasoning:t.reasoning,promptCacheKey:t.promptCacheKey,promptCacheRetention:t.promptCacheRetention,serviceTier:t.serviceTier,openaiBuiltinTools:t.openaiBuiltinTools,maxToolCalls:t.maxToolCalls,parallelToolCalls:t.parallelToolCalls,textVerbosity:t.textVerbosity},h,M))switch(c.type){case"delta":kt.push(c.text),!fe&&!(t.toolChoice==="required"&&!ge)&&(yield{type:"delta",turnId:r,text:c.text});break;case"tool_call_delta":fe=!0,zr(Rt,c);break;case"reasoning_delta":oe.push(c.text);break;case"reasoning_block_complete":c.signature&&D.push({thinking:oe.join(""),signature:c.signature}),oe.length=0;break;case"usage":$={inputTokens:c.promptTokens,outputTokens:c.completionTokens,reasoningTokens:c.reasoningTokens,cacheRead:c.cacheReadTokens,cacheWrite:c.cacheCreationTokens};break;case"response_id":a.lastResponseId=c.id;break;case"annotations":yield{type:"annotations",turnId:r,annotations:c.annotations};break;case"builtin_tool_status":yield{type:"heartbeat",turnId:r,message:`${c.toolType}: ${c.event}`};break;case"done":_t=c.finishReason;break}if(fe||f?.invoke("turn.after_inference",{..._,model:a.currentModel}).catch(()=>{}),t.postSamplingHooks&&t.postSamplingHooks.length>0){let c=a.currentModel;for(let u of t.postSamplingHooks)try{u({messages:[...P],model:c,sessionId:s})}catch{}}}catch(c){if(c instanceof ue&&t.fallbackModel){n.info(`model fallback triggered: ${c.originalModel} \u2192 ${c.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`${c.originalModel} \u2192 ${c.fallbackModel}`},a={...a,currentModel:c.fallbackModel,consecutive529Errors:0,consecutiveApiRetries:0,transition:void 0};continue}let u=c instanceof Error?c.message:String(c),d=typeof c?.status=="number"?c.status:void 0;if(!d&&u&&(u.includes("ECONNRESET")||u.includes("EPIPE"))){let y=(a.consecutiveApiRetries??0)+1;if(y>ce){n.info(`stale connection retry limit reached (${ce}), aborting`),yield{type:"error",turnId:r,error:u,code:"RETRIES_EXHAUSTED",usage:a.totalUsage};return}n.info(`stale connection (${u.includes("ECONNRESET")?"ECONNRESET":"EPIPE"}): retrying`),yield{type:"recovery",turnId:r,action:"stale_connection_retry",detail:u.slice(0,80)},a={...a,consecutiveApiRetries:y,transition:void 0};continue}let m=ns({status:d,message:u});if(m!==null){n.info(`max_tokens overflow: adjusting to ${m}`),I.currentMaxOutputTokens=m,a={...a,maxOutputTokensOverride:m,transition:void 0};continue}if(ot(d)){a.consecutive529Errors++;let y=2,E=t.fallbackModel&&a.currentModel!==t.fallbackModel;if(a.consecutive529Errors>y&&!E&&!Ae()){n.info(`transient ${d} \xD7 ${a.consecutive529Errors}: hard limit reached, aborting`),yield{type:"error",turnId:r,error:`API unavailable after ${a.consecutive529Errors} consecutive ${d} errors`,code:"API_ERROR",usage:a.totalUsage};return}if(a.consecutive529Errors>=Zt&&t.fallbackModel&&a.currentModel!==t.fallbackModel){n.info(`529 \xD7 ${a.consecutive529Errors}: triggering fallback to ${t.fallbackModel}`),yield{type:"recovery",turnId:r,action:"model_fallback",detail:`529 \xD7 ${a.consecutive529Errors}`},a={...a,currentModel:t.fallbackModel,consecutive529Errors:0,transition:void 0};continue}if(Ae()){let N=Me(a.consecutive529Errors);n.info(`persistent retry: waiting ${N}ms (attempt ${a.consecutive529Errors})`);let U=N;for(;U>0;){if(M?.aborted){yield{type:"error",turnId:r,error:"Aborted during retry wait",code:"ABORTED",usage:a.totalUsage};return}yield{type:"heartbeat",turnId:r,message:`Retrying in ${Math.ceil(U/1e3)}s (${d})`};let j=Math.min(U,Qt);await new Promise(K=>setTimeout(K,j)),U-=j}a={...a,transition:void 0};continue}if(nt(S)){let U=ts({status:d,message:u})??Me(a.consecutive529Errors);n.info(`transient ${d}: retry in ${U}ms`),yield{type:"recovery",turnId:r,action:"retry",detail:`${d} retry in ${U}ms`},await new Promise(j=>setTimeout(j,U)),a={...a,transition:void 0};continue}n.info(`background source ${S}: not retrying ${d}`)}C={status:d,message:u}}if(C&&f?.invoke("turn.after_inference",{..._,model:a.currentModel,response:{error:C.message}}).catch(()=>{}),C)if(In(C))he=!0,n.info(`withheld prompt_too_long error (status=${C.status})`);else if(Pn(C))he=!0,n.info(`withheld media_size error (status=${C.status})`);else{let c=it({status:C.status??500,message:C.message},I,A);if(c.action==="reactive_compact"&&Z(q)&&(q.attemptedThisTurn=!0,I.hasAttemptedReactiveCompact=!0,yield{type:"recovery",turnId:r,action:"reactive_compact",detail:`API ${C.status??500}: ${C.message}`}),c.action==="retry"){let d=(a.consecutiveApiRetries??0)+1;if(d>ce){n.info(`API retry limit reached (${ce}), aborting`);let m=Q(C.status,C.message);yield{type:"error",turnId:r,error:C.message,code:m,usage:a.totalUsage};return}yield{type:"recovery",turnId:r,action:"retry",detail:c.reason},a={...a,consecutiveApiRetries:d,transition:void 0};continue}let u=Q(C.status,C.message);f?.invoke("stop.failure",{sessionId:s,reason:u,error:C.message}).catch(()=>{}),yield{type:"error",turnId:r,error:C.message,code:u,usage:a.totalUsage};return}$&&(a.totalUsage.inputTokens+=$.inputTokens,a.totalUsage.outputTokens+=$.outputTokens,$.reasoningTokens&&(a.totalUsage.reasoningTokens=(a.totalUsage.reasoningTokens??0)+$.reasoningTokens),$.cacheRead&&(a.totalUsage.cacheRead=(a.totalUsage.cacheRead??0)+$.cacheRead),$.cacheWrite&&(a.totalUsage.cacheWrite=(a.totalUsage.cacheWrite??0)+$.cacheWrite)),$?.inputTokens&&(I.promptTokens=$.inputTokens);let St=kt.join("");St&&(a.finalText=St);let G=[...Rt.values()].map(c=>({id:c.id||`tc_${r}_${te}_${Math.random().toString(36).slice(2,8)}`,type:"function",function:{name:c.name,arguments:c.arguments}}));if(G.length===0&&!fe){if(t.toolChoice==="required"&&!ge&&J.length>0&&ht<2){ht++;let d=J.map(m=>m.function.name).filter(Boolean).slice(0,8).join(", ");a={...a,messages:[...T,{role:"user",content:`You must call one available tool before answering. Available tools for this request: ${d}. Do not answer from memory, prior context, or guesses.`}],finalText:"",transition:{reason:"next_turn"}};continue}if(he&&C&&In(C)){if(a.transition?.reason!=="collapse_drain_retry"){let d=qe(P,Le);if(d.committed>0){n.info(`collapse drain: committed ${d.committed} stages`),yield{type:"recovery",turnId:r,action:"collapse_drain",detail:`${d.committed} stages committed`},a={...a,messages:d.messages,transition:{reason:"collapse_drain_retry",committed:d.committed}};continue}}if(Z(q)){q.attemptedThisTurn=!0,I.hasAttemptedReactiveCompact=!0,n.info("withheld 413: reactive compact attempt"),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"withheld prompt_too_long"},a={...a,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}n.info("withheld 413: recovery exhausted, surfacing error"),f?.invoke("stop.failure",{sessionId:s,reason:"prompt_too_long",error:C.message}).catch(()=>{}),yield{type:"error",turnId:r,error:C.message,code:"PROMPT_TOO_LONG",usage:a.totalUsage};return}if(he&&C&&Pn(C)){if(Z(q)){q.attemptedThisTurn=!0,I.hasAttemptedReactiveCompact=!0,n.info("withheld media error: reactive compact strip-retry"),yield{type:"recovery",turnId:r,action:"reactive_compact",detail:"media error strip-retry"},a={...a,hasAttemptedReactiveCompact:!0,transition:{reason:"reactive_compact_retry"}};continue}n.info("withheld media error: recovery exhausted"),f?.invoke("stop.failure",{sessionId:s,reason:"media_error",error:C.message}).catch(()=>{}),yield{type:"error",turnId:r,error:C.message,code:"IMAGE_ERROR",usage:a.totalUsage};return}if(es(_t)){I.consecutiveTruncations+=1;let d=t.modelMaxOutputTokens??zt,m=at(I,A,d);if(m.shouldEscalate&&bt===void 0){I.currentMaxOutputTokens=m.newMax,n.info(`max_output_tokens escalate: ${m.newMax} tokens`),yield{type:"recovery",turnId:r,action:"output_escalation",detail:`${m.newMax} tokens`},a={...a,maxOutputTokensOverride:Xt,transition:{reason:"max_output_tokens_escalate"}};continue}if(ee<Wt){let y={role:"user",content:"Output token limit hit. Resume directly \u2014 no apology, no recap of what you were doing. Pick up mid-thought if that is where the cut happened. Break remaining work into smaller pieces."};n.info(`max_output_tokens recovery #${ee+1}`),yield{type:"recovery",turnId:r,action:"max_output_tokens_recovery",detail:`attempt ${ee+1}`},a={...a,messages:[...P,y],maxOutputTokensRecoveryCount:ee+1,maxOutputTokensOverride:void 0,transition:{reason:"max_output_tokens_recovery",attempt:ee+1}};continue}n.info("max_output_tokens recovery exhausted, completing with partial content")}else I.consecutiveTruncations=0;if(B=xe(B,{replayMessages:T,lastStopReason:"completed"}),f){let d=await f.invoke("stop",{sessionId:s,reason:"completed"});if(d.action==="prevent"){n.info(`stop hook prevented continuation: ${d.reason??"no reason"}`),yield{type:"end",turnId:r,content:a.finalText,usage:a.totalUsage,model:a.currentModel};return}if(d.action==="abort"){let m=d.reason??"Stop hook requested continuation";n.info(`stop hook blocking: ${m}`);let y={role:"user",content:m},E={role:"assistant",content:a.finalText,...D.length>0&&{thinkingBlocks:[...D]}};a={...a,messages:[...T,E,y],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(t.tokenBudget&&t.tokenBudget>0&&a.budgetContinuationCount<5){let d=a.totalUsage.inputTokens+a.totalUsage.outputTokens+(a.totalUsage.reasoningTokens??0),m=d/t.tokenBudget*100,y=d-a.lastBudgetGlobalTokens,E=a.budgetContinuationCount>=Vt&&y<ze&&a.lastBudgetDeltaTokens<ze;if(E&&n.info(`token budget early stop: diminishing returns at ${Math.round(m)}% (delta=${y})`),!E&&m<90){let N=a.budgetContinuationCount+1,U={role:"user",content:Mn(m,d,t.tokenBudget)};n.info(`token budget continuation #${N}: ${Math.round(m)}% used`),yield{type:"recovery",turnId:r,action:"budget_continuation",detail:`${Math.round(m)}% used (#${N})`};let j={role:"assistant",content:a.finalText,...D.length>0&&{thinkingBlocks:[...D]}};a={...a,messages:[...T,j,U],budgetContinuationCount:N,lastBudgetDeltaTokens:y,lastBudgetGlobalTokens:d,transition:{reason:"token_budget_continuation"}};continue}}if(!a.stopHookActive){let d=l.find(N=>N.role==="user"),m=typeof d?.content=="string"?d.content:"",y=/创建(?:文件)?|生成文件|写入|写一个|建一个|新建|重写|改写|修改|改成|把.*改|修复|实现|create\s+(?:a\s+)?file|write\s+(?:a\s+)?file|make\s+(?:a\s+)?file|fix|implement|文件名叫/i.test(m),E=k.has("write")||k.has("edit");if(y&&!E){if(n.info("AP1 action-verification: user requested file action but no write/edit tool was called, injecting nudge"),O>0){let j=[...T].reverse().find(K=>K.role==="tool");j&&typeof j.content=="string"&&(j.content+=`
|
|
18
18
|
|
|
19
|
-
\u26A0\uFE0F NOTE: You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail silently or produce incorrect results on this platform. Please use the 'write' tool directly to create the requested file with the correct content.`)}let h={role:"user",content:L===0?"You described what to do but did not actually call any tool to write or edit a file. Please use the write or edit tool now to perform the requested action. Do not just describe the changes \u2014 actually make them.":"You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail on this platform. Please use the write tool directly to create the requested file with the correct content."},v={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,v,h],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!a.stopHookActive&&L>=3&&M.has("write")){let d=0;for(let m of b){let T=m,E=T.is_error===!0||typeof T.content=="string"&&T.content.startsWith("Error:");T.role==="tool"&&typeof T.content=="string"&&!E&&d++}if(d>=3){n.info("AP3 verification nudge: 3+ files created, injecting completeness check");let m={role:"user",content:"You created multiple files. Before completing, verify: (1) All imports between your files resolve to real exports. (2) No TODO, placeholder, or 'not implemented' stubs remain. (3) Functions that are imported are actually called, not just declared. If everything is correct, confirm completion. If not, fix the issues now."},T={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,T,m],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(L>0){let d={ok:!0,toolCallCount:L,distinctToolCount:M.size,multiStep:L>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},m=Ce(d,{tools:[...M],projectRoot:t.projectRoot});m&&(yield{type:"skill_instruction",turnId:r,instruction:m})}let u=a.finalText||le(b,n);yield{type:"end",turnId:r,content:u,usage:a.totalUsage,model:a.currentModel};return}let Nn=O.length===0&&ee.length>0?ee.join(""):void 0;b.push(Pe(K,a.finalText||void 0,O.length>0?O:void 0,Nn)),U=Je(U,{replayMessages:b,pendingToolCallIds:K.map(c=>c.id),completedToolCallIds:U.completedToolCallIds,lastStopReason:"tool_calls"});let me=a.identicalCallCounts,bt=[],fe=[],Ct=!1;for(let c of K){let u=`${c.function.name}::${c.function.arguments}`,d=me.get(u)??0;me.set(u,d+1),d+1>Dt?(fe.push(c),Ct||(Ct=!0,n.info(`AP4 blocked: ${c.function.name} repeated ${d+1}x`))):bt.push(c)}let he=[];for(let c of fe){let u=me.get(`${c.function.name}::${c.function.arguments}`),d=vn(b,c.function.name),m=d?`This exact tool call has been attempted ${u} times. Last error: ${d}. Do not retry. Report this error to the user.`:`This exact tool call has been attempted ${u} times and keeps failing. Do not retry it. Report the issue to the user or try a completely different approach.`,T=G(c.id,{ok:!1,error:m});b.push(T),he.push(c.id),M.add(c.function.name),L++,yield{type:"tool_result",turnId:r,callId:c.id,name:c.function.name,ok:!1,error:m}}if(fe.length>0){let c=vn(b,fe[0].function.name),u={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(c?`The error was: "${c}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};b.push(u)}let ye=[],Ee=[];for(let c of bt)(a.toolFailureCounts.get(c.function.name)??0)>=Te?Ee.push(c):ye.push(c);if(Ee.length>0){for(let u of Ee){let d=a.toolFailureCounts.get(u.function.name),m=`Tool "${u.function.name}" has failed ${d} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,T=G(u.id,{ok:!1,error:m});b.push(T),he.push(u.id),M.add(u.function.name),L++,yield{type:"tool_result",turnId:r,callId:u.id,name:u.function.name,ok:!1,error:m},n.info(`AP4-variant blocked: ${u.function.name} failed ${d}x with different args`)}let c={role:"user",content:"Tool calls were blocked because the tool has failed too many times with different arguments. The resource you are looking for does not exist. Stop trying variations and tell the user what happened."};b.push(c)}for(let c of ye){let u=c.function.arguments,d=ce.find(m=>m.function.name===c.function.name);if(d?.backfillObservableInput)try{let m=JSON.parse(c.function.arguments),T={...m};d.backfillObservableInput(T),Object.keys(T).some(h=>!(h in m))&&(u=JSON.stringify(T))}catch{}yield{type:"tool_call",turnId:r,callId:c.id,name:c.function.name,arguments:u}}let Dn=new Map(a.toolFailureCounts);try{let c=new ve({toolInvoker:o,hooks:f,sessionId:s,turnId:r,log:n,signal:A,maxConcurrentTools:t?.maxConcurrentTools});for(let u of ye)c.addTool(u);for await(let u of c.getRemainingResults()){u.blocked&&(yield{type:"tool_blocked",turnId:r,callId:u.callId,name:u.toolName,reason:u.blockReason??"blocked"}),b.push(u.message),he.push(u.callId),M.add(u.toolName),L++;let d=u.ok&&Kr(u);if(!u.ok||d){let h=(a.toolFailureCounts.get(u.toolName)??0)+1;a.toolFailureCounts.set(u.toolName,h)}if(u.ok&&u.toolName==="read"){let E=ye.find(h=>h.id===u.callId);if(E)try{let h=JSON.parse(E.function.arguments),v=h.file_path??h.path??h.filePath??"";if(v){let $=a.fileReadCounts.get(v)??0;a.fileReadCounts.set(v,$+1)}}catch{}}let m=typeof u.message?.content=="string"?u.message.content:"",T=u.ok&&m?m.slice(0,2e3):void 0;if(yield{type:"tool_result",turnId:r,callId:u.callId,name:u.toolName,ok:u.ok,error:u.error,outputPreview:T},u.ok){let E=K.find(h=>h.id===u.callId);if(E){if(u.toolName==="plan_mode")try{let h=JSON.parse(E.function.arguments);h.action==="exit"&&typeof h.plan=="string"&&h.plan.length>0&&(yield{type:"plan_update",turnId:r,slug:"approved-plan",content:h.plan})}catch{}if(Fr.has(u.toolName))try{let h=JSON.parse(E.function.arguments),v=typeof h.file_path=="string"?h.file_path:typeof h.filePath=="string"?h.filePath:typeof h.path=="string"?h.path:void 0;v&&(yield{type:"artifact",turnId:r,artifactId:`artifact-${u.callId}`,artifactType:Ur(v),title:v.split(/[\\/]/).pop()||v,filePath:v,language:Br(v)})}catch{}}}}}catch(c){let u=c instanceof Error?c.message:String(c);yield{type:"error",turnId:r,error:u,code:"TOOL_EXECUTION_ERROR",usage:a.totalUsage};return}for(let[c,u]of a.toolFailureCounts)u>=Te&&(Dn.get(c)??0)<Te&&b.push({role:"user",content:`Tool "${c}" has now failed/returned empty results ${u} times with different arguments. The target clearly does not exist. Do NOT call "${c}" again. Report the result to the user immediately.`});if(U=ke(U,{replayMessages:b,completedToolCallIds:[...U.completedToolCallIds,...he],lastStopReason:"tool_calls"}),t.generateToolUseSummary&&K.length>0){let c=K.map(u=>({name:u.function.name,arguments:u.function.arguments}));ue=t.generateToolUseSummary(c).catch(()=>null)}let Fn=K.length>0&&K.every(c=>{let u=b.find(m=>m?.role==="tool"&&m?.tool_call_id===c.id);if(!u)return!0;let d=u.content;return typeof d=="string"&&d.startsWith("Error: ")}),te=a.consecutiveFailedRounds;if(Fn){if(te+=1,te>=Nt){let c=a.finalText||le(b,n);n.info(`early exit: ${te} consecutive failed rounds, returning ${a.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}}else te=0;let Un=3,kt=[...a.fileReadCounts.entries()].filter(([,c])=>c>=Un);if(kt.length>0){let c=kt.map(([d])=>d).join(", ");n.info(`AP5: file read cycle detected on ${c}, injecting nudge`);let u={role:"user",content:`You are reading the same files repeatedly (${c}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};b.push(u),a.fileReadCounts.clear()}let we=Q+1;if(x>0&&we>x){if(n.info(`max turns reached (${x}), completing`),f){let u=await f.invoke("stop",{sessionId:s,reason:"max_turns"});if(u.action==="abort"){let d=u.reason??"Stop hook requested continuation after max_turns",m={role:"assistant",content:a.finalText,...O.length>0&&{thinkingBlocks:[...O]}};a={...a,messages:[...b,m,{role:"user",content:d}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let c=a.finalText||le(b,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}if(we>w){if(n.info(`tool loop budget exhausted (${w} rounds), returning`),L>0){let u={ok:!0,toolCallCount:L,distinctToolCount:M.size,multiStep:L>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},d=Ce(u,{tools:[...M],projectRoot:t.projectRoot});d&&(yield{type:"skill_instruction",turnId:r,instruction:d})}let c=a.finalText||le(b,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}a={messages:b,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:we,transition:{reason:"next_turn"},guardState:I,reactiveCompactState:j,toolLoopState:U,consecutiveFailedRounds:te,finalText:a.finalText,totalUsage:a.totalUsage,collapseStore:Ae,currentModel:a.currentModel,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:a.stopHookActive,lastResponseId:a.lastResponseId,snipRemovedIds:a.snipRemovedIds,contentReplacementState:a.contentReplacementState,budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:me,toolFailureCounts:a.toolFailureCounts,fileReadCounts:a.fileReadCounts}}}function le(t,e){let o=[];for(let n=t.length-1;n>=0;n--){let r=t[n];if(r.role==="tool"&&typeof r.content=="string")o.unshift(r.content.slice(0,500));else if(r.role==="assistant"){if(typeof r.content=="string"&&r.content.trim())return e.info("synthesizeFallbackContent: found assistant text, using it"),r.content;break}else break}return o.length>0?(e.info(`synthesizeFallbackContent: synthesized from ${o.length} tool result(s)`),o.join(`
|
|
19
|
+
\u26A0\uFE0F NOTE: You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail silently or produce incorrect results on this platform. Please use the 'write' tool directly to create the requested file with the correct content.`)}let N={role:"user",content:O===0?"You described what to do but did not actually call any tool to write or edit a file. Please use the write or edit tool now to perform the requested action. Do not just describe the changes \u2014 actually make them.":"You used shell commands but did not call the write or edit tool to create/modify the file. Shell commands may fail on this platform. Please use the write tool directly to create the requested file with the correct content."},U={role:"assistant",content:a.finalText,...D.length>0&&{thinkingBlocks:[...D]}};a={...a,messages:[...T,U,N],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(!a.stopHookActive&&O>=3&&k.has("write")){let d=0;for(let m of T){let y=m,E=y.is_error===!0||typeof y.content=="string"&&y.content.startsWith("Error:");y.role==="tool"&&typeof y.content=="string"&&!E&&d++}if(d>=3){n.info("AP3 verification nudge: 3+ files created, injecting completeness check");let m={role:"user",content:"You created multiple files. Before completing, verify: (1) All imports between your files resolve to real exports. (2) No TODO, placeholder, or 'not implemented' stubs remain. (3) Functions that are imported are actually called, not just declared. If everything is correct, confirm completion. If not, fix the issues now."},y={role:"assistant",content:a.finalText,...D.length>0&&{thinkingBlocks:[...D]}};a={...a,messages:[...T,y,m],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}if(O>0){let d={ok:!0,toolCallCount:O,distinctToolCount:k.size,multiStep:O>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},m=Se(d,{tools:[...k],projectRoot:t.projectRoot});m&&(yield{type:"skill_instruction",turnId:r,instruction:m})}let u=a.finalText||de(T,n);yield{type:"end",turnId:r,content:u,usage:a.totalUsage,model:a.currentModel};return}let jn=D.length===0&&oe.length>0?oe.join(""):void 0;T.push(De(G,a.finalText||void 0,D.length>0?D:void 0,jn)),B=tt(B,{replayMessages:T,pendingToolCallIds:G.map(c=>c.id),completedToolCallIds:B.completedToolCallIds,lastStopReason:"tool_calls"});let ye=a.identicalCallCounts,xt=[],Te=[],vt=!1;for(let c of G){let u=`${c.function.name}::${c.function.arguments}`,d=ye.get(u)??0;ye.set(u,d+1),d+1>Kt?(Te.push(c),vt||(vt=!0,n.info(`AP4 blocked: ${c.function.name} repeated ${d+1}x`))):xt.push(c)}let be=[];for(let c of Te){let u=ye.get(`${c.function.name}::${c.function.arguments}`),d=wn(T,c.function.name),m=d?`This exact tool call has been attempted ${u} times. Last error: ${d}. Do not retry. Report this error to the user.`:`This exact tool call has been attempted ${u} times and keeps failing. Do not retry it. Report the issue to the user or try a completely different approach.`,y=ke(c.id,{ok:!1,error:m});T.push(y),be.push(c.id),k.add(c.function.name),O++,yield{type:"tool_result",turnId:r,callId:c.id,name:c.function.name,ok:!1,error:m}}if(Te.length>0){let c=wn(T,Te[0].function.name),u={role:"user",content:"Tool calls were blocked because you repeated them with identical arguments too many times. "+(c?`The error was: "${c}". Tell the user about this error. `:"The operation is not working. ")+"Stop retrying and report the result to the user."};T.push(u)}let Ce=[],Oe=[];for(let c of xt)(a.toolFailureCounts.get(c.function.name)??0)>=Re?Oe.push(c):Ce.push(c);if(Oe.length>0){for(let u of Oe){let d=a.toolFailureCounts.get(u.function.name),m=`Tool "${u.function.name}" has failed ${d} times this turn with different arguments. The target likely does not exist. Stop trying variations and report the issue to the user.`,y=ke(u.id,{ok:!1,error:m});T.push(y),be.push(u.id),k.add(u.function.name),O++,yield{type:"tool_result",turnId:r,callId:u.id,name:u.function.name,ok:!1,error:m},n.info(`AP4-variant blocked: ${u.function.name} failed ${d}x with different args`)}let c={role:"user",content:"Tool calls were blocked because the tool has failed too many times with different arguments. The resource you are looking for does not exist. Stop trying variations and tell the user what happened."};T.push(c)}for(let c of Ce){let u=c.function.arguments,d=J.find(m=>m.function.name===c.function.name);if(d?.backfillObservableInput)try{let m=JSON.parse(c.function.arguments),y={...m};d.backfillObservableInput(y),Object.keys(y).some(N=>!(N in m))&&(u=JSON.stringify(y))}catch{}yield{type:"tool_call",turnId:r,callId:c.id,name:c.function.name,arguments:u,inputSummary:rs(u)}}let Kn=new Map(a.toolFailureCounts);try{let c=new we({toolInvoker:o,hooks:f,sessionId:s,turnId:r,log:n,signal:M,maxConcurrentTools:t?.maxConcurrentTools});for(let u of Ce)c.addTool(u);for await(let u of c.getRemainingResults()){u.blocked&&(yield{type:"tool_blocked",turnId:r,callId:u.callId,name:u.toolName,reason:u.blockReason??"blocked"}),T.push(u.message),be.push(u.callId),k.add(u.toolName),O++;let d=u.ok&&Qr(u);if(!u.ok||d){let v=(a.toolFailureCounts.get(u.toolName)??0)+1;a.toolFailureCounts.set(u.toolName,v)}if(u.ok&&u.toolName==="read"){let K=Ce.find(v=>v.id===u.callId);if(K)try{let v=JSON.parse(K.function.arguments),H=v.file_path??v.path??v.filePath??"";if(H){let qn=a.fileReadCounts.get(H)??0;a.fileReadCounts.set(H,qn+1)}}catch{}}let m=typeof u.message?.content=="string"?u.message.content:"",y=m?m.slice(0,2e3):void 0,E=u.details,N=typeof E?.stdout=="string"?E.stdout.slice(0,8e3):void 0,U=typeof E?.stderr=="string"?E.stderr.slice(0,4e3):void 0,j=typeof E?.exitCode=="number"?E.exitCode:void 0;if(yield{type:"tool_result",turnId:r,callId:u.callId,name:u.toolName,ok:u.ok,error:u.error,outputPreview:y,durationMs:u.durationMs,exitCode:j,stdout:N,stderr:U,details:E},u.ok){let K=G.find(v=>v.id===u.callId);if(K){if(u.toolName==="plan_mode")try{let v=JSON.parse(K.function.arguments);v.action==="exit"&&typeof v.plan=="string"&&v.plan.length>0&&(yield{type:"plan_update",turnId:r,slug:"approved-plan",content:v.plan})}catch{}if(Wr.has(u.toolName))try{let v=JSON.parse(K.function.arguments),H=typeof v.file_path=="string"?v.file_path:typeof v.filePath=="string"?v.filePath:typeof v.path=="string"?v.path:void 0;H&&(yield{type:"artifact",turnId:r,artifactId:`artifact-${u.callId}`,artifactType:Xr(H),title:H.split(/[\\/]/).pop()||H,filePath:H,language:Vr(H)})}catch{}}}}}catch(c){let u=c instanceof Error?c.message:String(c);yield{type:"error",turnId:r,error:u,code:"TOOL_EXECUTION_ERROR",usage:a.totalUsage};return}for(let[c,u]of a.toolFailureCounts)u>=Re&&(Kn.get(c)??0)<Re&&T.push({role:"user",content:`Tool "${c}" has now failed/returned empty results ${u} times with different arguments. The target clearly does not exist. Do NOT call "${c}" again. Report the result to the user immediately.`});if(B=xe(B,{replayMessages:T,completedToolCallIds:[...B.completedToolCallIds,...be],lastStopReason:"tool_calls"}),t.toolChoice==="required"&&G.length>0&&(ge=!0),t.generateToolUseSummary&&G.length>0){let c=G.map(u=>({name:u.function.name,arguments:u.function.arguments}));pe=t.generateToolUseSummary(c).catch(()=>null)}let Gn=G.length>0&&G.every(c=>{let u=T.find(m=>m?.role==="tool"&&m?.tool_call_id===c.id);if(!u)return!0;let d=u.content;return typeof d=="string"&&d.startsWith("Error: ")}),re=a.consecutiveFailedRounds;if(Gn){if(re+=1,re>=jt){let c=a.finalText||de(T,n);n.info(`early exit: ${re} consecutive failed rounds, returning ${a.finalText?"partial":"fallback"} response`),yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}}else re=0;let Hn=3,Mt=[...a.fileReadCounts.entries()].filter(([,c])=>c>=Hn);if(Mt.length>0){let c=Mt.map(([d])=>d).join(", ");n.info(`AP5: file read cycle detected on ${c}, injecting nudge`);let u={role:"user",content:`You are reading the same files repeatedly (${c}). This indicates a circular dependency or cycle. Stop reading files, summarize your findings so far, and explain the circular structure to the user.`};T.push(u),a.fileReadCounts.clear()}let Ne=te+1;if(b>0&&Ne>b){if(n.info(`max turns reached (${b}), completing`),f){let u=await f.invoke("stop",{sessionId:s,reason:"max_turns"});if(u.action==="abort"){let d=u.reason??"Stop hook requested continuation after max_turns",m={role:"assistant",content:a.finalText,...D.length>0&&{thinkingBlocks:[...D]}};a={...a,messages:[...T,m,{role:"user",content:d}],stopHookActive:!0,transition:{reason:"stop_hook_blocking"}};continue}}let c=a.finalText||de(T,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}if(Ne>L){if(n.info(`tool loop budget exhausted (${L} rounds), returning`),O>0){let u={ok:!0,toolCallCount:O,distinctToolCount:k.size,multiStep:O>=2,hasSubAgent:!1,feedback:null,existingSkillName:null},d=Se(u,{tools:[...k],projectRoot:t.projectRoot});d&&(yield{type:"skill_instruction",turnId:r,instruction:d})}let c=a.finalText||de(T,n);yield{type:"end",turnId:r,content:c,usage:a.totalUsage,model:a.currentModel};return}a={messages:T,maxOutputTokensRecoveryCount:0,hasAttemptedReactiveCompact:!1,maxOutputTokensOverride:void 0,turnCount:Ne,transition:{reason:"next_turn"},guardState:I,reactiveCompactState:q,toolLoopState:B,consecutiveFailedRounds:re,finalText:a.finalText,totalUsage:a.totalUsage,collapseStore:Le,currentModel:a.currentModel,consecutive529Errors:0,consecutiveApiRetries:0,stopHookActive:a.stopHookActive,lastResponseId:a.lastResponseId,snipRemovedIds:a.snipRemovedIds,contentReplacementState:a.contentReplacementState,budgetContinuationCount:0,lastBudgetDeltaTokens:0,lastBudgetGlobalTokens:0,identicalCallCounts:ye,toolFailureCounts:a.toolFailureCounts,fileReadCounts:a.fileReadCounts}}}function de(t,e){let o=[];for(let n=t.length-1;n>=0;n--){let r=t[n];if(r.role==="tool"&&typeof r.content=="string")o.unshift(r.content.slice(0,500));else if(r.role==="assistant"){if(typeof r.content=="string"&&r.content.trim())return e.info("synthesizeFallbackContent: found assistant text, using it"),r.content;break}else break}return o.length>0?(e.info(`synthesizeFallbackContent: synthesized from ${o.length} tool result(s)`),o.join(`
|
|
20
20
|
|
|
21
|
-
`)):""}async function*
|
|
22
|
-
`)}function
|
|
23
|
-
${
|
|
21
|
+
`)):""}function rs(t){try{let e=JSON.parse(t),n=[e.description,e.command,e.query,e.url,e.path,e.file_path,e.filePath,e.pattern,e.model].find(s=>typeof s=="string"&&s.trim().length>0);if(typeof n=="string")return n.trim().slice(0,240);let r=Object.keys(e);return r.length>0?r.slice(0,5).join(" / "):void 0}catch{return}}async function*ss(t,e,o,n,r,s,l,i){let p=[],h;i.debug(`single LLM round, messages: ${o.length}`);for await(let g of l.stream({model:e,messages:o,temperature:r},n,s))switch(g.type){case"delta":p.push(g.text),yield{type:"delta",turnId:t,text:g.text};break;case"usage":h={inputTokens:g.promptTokens,outputTokens:g.completionTokens,reasoningTokens:g.reasoningTokens,cacheRead:g.cacheReadTokens,cacheWrite:g.cacheCreationTokens};break;case"done":break}yield{type:"end",turnId:t,content:p.join(""),usage:h??{inputTokens:0,outputTokens:0},model:e}}var is={coding:[/(?:bug|error|fix|debug|报错|修复|编译|compile|build|lint)/i,/(?:implement|refactor|重构|实现|代码|code|function|method|class)/i,/(?:test|测试|vitest|jest|断言|assert)/i,/(?:type(?:script)?|接口|interface|generic|泛型)/i,/(?:import|export|module|依赖|package|npm|pnpm)/i,/(?:git|commit|branch|merge|rebase|PR|MR)/i],config:[/(?:deploy|部署|运维|docker|container|kubernetes|k8s)/i,/(?:port|端口|config|配置|env|环境变量|.env)/i,/(?:server|service|daemon|进程|systemd|nginx|redis)/i,/(?:版本|version|upgrade|migrate|迁移)/i,/(?:domain|域名|ssl|cert|证书|DNS)/i],conversation:[/(?:你好|hi|hello|hey|请问|问一下)/i,/(?:我(?:喜欢|偏好|习惯|想)|prefer|I (?:like|want|need))/i,/(?:帮我|help me|能不能|可以吗|would you)/i,/(?:style|风格|format|格式|命名|naming)/i],learning:[/(?:best practice|最佳实践|pattern|模式|惯例|convention)/i,/(?:怎么做|how to|how do|what's the|推荐|recommend)/i,/(?:为什么|why|原因|reason|explain|解释)/i,/(?:lesson|经验|教训|gotcha|pitfall|坑)/i],decision:[/(?:should|应该|选择|choose|decision|决定|trade-?off|权衡)/i,/(?:vs|versus|对比|compare|区别|difference)/i,/(?:architecture|架构|方案|approach|strategy)/i,/(?:pros|cons|优缺点|利弊|好处|坏处)/i],general:[]},as={coding:{preferred:["lesson","pattern","fact"],deprioritized:["preference"]},config:{preferred:["fact","decision","lesson"],deprioritized:["preference","skill-learning"]},conversation:{preferred:["preference","fact"],deprioritized:["pattern","skill-learning"]},learning:{preferred:["lesson","pattern","skill-learning"],deprioritized:["preference"]},decision:{preferred:["decision","fact","lesson"],deprioritized:["skill-learning","preference"]},general:{preferred:[],deprioritized:[]}};function On(t){if(!t||t.length<5)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};let e=[];for(let[r,s]of Object.entries(is)){if(r==="general")continue;let l=s.filter(i=>i.test(t)).length;if(l>0){let i=Math.min(1,l/2);e.push({scenario:r,score:i})}}if(e.length===0)return{scenario:"general",preferred:[],deprioritized:[],confidence:0};e.sort((r,s)=>s.score-r.score);let o=e[0];if(o.score<.5)return{scenario:"general",preferred:[],deprioritized:[],confidence:o.score};let n=as[o.scenario];return{scenario:o.scenario,preferred:n.preferred,deprioritized:n.deprioritized,confidence:o.score}}var ls=["\u63A5\u5355\u91D1\u989D","\u5408\u540C\u91D1\u989D","\u62A5\u4EF7","\u9884\u7B97","\u91D1\u989D","price","amount","contract amount"];function Un(t){let e=cs(t),o=["[Recalled memories]","- L1 project MD is project-scoped working memory.","- L2 long-term memory is cross-project canonical memory.","- If L1 and L2 conflict on the same entity/fact, do not silently merge or choose. Surface the conflict and ask the user to confirm. For current-project operational tasks, use L1 only as a project-scoped clue until confirmed into L2."];if(e.length>0){o.push("[Memory conflict detected]");for(let n of e)o.push(`- entity: ${n.entity}; fact: ${n.predicate}; L1 project MD says: ${Dn(n.l1Amount)}; L2 long-term says: ${Dn(n.l2Amount)}; action: ask the user which value is current before using it.`)}for(let n of t){let r=ps(n);o.push(`- [${r}] ${n.text}`)}return o.join(`
|
|
22
|
+
`)}function cs(t){let e=t.filter(r=>r.source==="l1-project-md").flatMap(r=>Nn(r.text)),o=t.filter(r=>r.source==="l2-long-term").flatMap(r=>Nn(r.text)),n=[];for(let r of e)for(let s of o)r.entity===s.entity&&r.predicate===s.predicate&&r.amount!==s.amount&&n.push({entity:r.entity,predicate:r.predicate,l1Amount:r.amount,l2Amount:s.amount,l1Text:r.text,l2Text:s.text});return gs(n)}function Nn(t){let e=[];for(let o of t.split(/\r?\n/)){let n=o.trim();if(n)for(let r of ls){if(r==="\u91D1\u989D"&&/(接单金额|合同金额)/u.test(n))continue;let s=new RegExp(`${ms(r)}[^0-9.\u4E07kK,]{0,12}([0-9][0-9.,]*\\s*(?:\u4E07|k|K)?)`,"gi");for(let l of n.matchAll(s)){let i=ds(l[1]);i!==null&&e.push({entity:us(n,r),predicate:r,amount:i,text:n})}}}return e}function us(t,e){if(/Galaxy\s+Tech/i.test(t))return"Galaxy Tech";if(t.includes("\u7528\u6237"))return"\u7528\u6237";let o=t.toLowerCase().indexOf(e.toLowerCase()),r=(o>=0?t.slice(0,o):"").replace(/[#*`:\-,。;;,.]/g," ").trim().split(/\s+/).filter(Boolean);return r[r.length-1]??"unknown"}function ds(t){let e=t.replace(/,/g,"").replace(/\s+/g,"").trim(),o=e.endsWith("\u4E07")?1e4:/k$/i.test(e)?1e3:1,n=Number(e.replace(/[万kK]$/u,""));return Number.isFinite(n)?n*o:null}function ps(t){if(t.label)return t.label;switch(t.source){case"l1-project-md":return"L1 project MD";case"l2-long-term":return"L2 long-term";case"skill":return"Skill";case"system":return"System";default:return"Memory"}}function Dn(t){return Number.isInteger(t)?String(t):String(Number(t.toFixed(4)))}function gs(t){let e=new Set;return t.filter(o=>{let n=`${o.entity}\0${o.predicate}\0${o.l1Amount}\0${o.l2Amount}`;return e.has(n)?!1:(e.add(n),!0)})}function ms(t){return t.replace(/[.*+?^${}()|[\]\\]/g,"\\$&")}var Bn=class{transport;apiKey;toolInvoker;log;hooks;maxRounds;projectRoot;constructor(e){this.transport=e.llmTransport,this.apiKey=e.apiKey,this.toolInvoker=e.toolInvoker,this.log=e.log,this.hooks=e.hooks,this.projectRoot=e.projectRoot,this.maxRounds=Math.min(e.maxRounds??25,100)}async*run(e,o){let{turnId:n,messages:r,tools:s,systemPrompt:l,config:i}=e,p={sessionId:e.sessionId,turnId:n};yield{type:"start",turnId:n},this.hooks?.invoke("turn.submitted",{...p,prompt:r[r.length-1]?.content??void 0}).catch(()=>{});let h=et(r),g=[];if(l&&g.push({role:"system",content:l}),g.push(...h),this.hooks){let _=h.filter(S=>S.role==="user").pop(),b=typeof _?.content=="string"?_.content.slice(0,500):void 0;if(b)try{let S=On(b),x=await this.hooks.invoke("memory.before_recall",{sessionId:e.sessionId,turnId:n,query:b,preferredCategories:S.preferred.length>0?S.preferred:void 0,deprioritizedCategories:S.deprioritized.length>0?S.deprioritized:void 0}),w=x?.context?.recalledMemories;if(w&&w.length>0){let L=0,A=[];for(let k of w){let O=(k.text?.length??0)*2;if(L+O>8192)break;A.push(k),L+=O}if(A.length>0){let k=Un(A);g.splice(l?1:0,0,{role:"system",content:`[Recalled memories \u2014 context priority: project-specific facts override general user preferences when they conflict]
|
|
23
|
+
${k}`})}}this.hooks.invoke("memory.after_recall",{sessionId:e.sessionId,turnId:n,blockCount:x?.context?.recalledMemories?.length??0}).catch(()=>{})}catch{}}let f=i?.model??"",M=Math.min(i?.maxRounds??this.maxRounds,100);try{let _=async x=>{let w=pt().resolveModelForPurpose("smallModel");if(!w)return null;try{let R=x.map(k=>`${k.name}(${k.arguments.slice(0,200)})`).join(", "),L=this.transport.stream({model:w,messages:[{role:"system",content:"Summarize the tool usage in ~30 chars, git-commit-subject style. Reply with ONLY the summary, nothing else."},{role:"user",content:R}],tools:[],maxTokens:60},i?.apiKey??this.apiKey),A="";for await(let k of L)k.type==="delta"&&(A+=k.text);return A.trim()||null}catch{return null}},b={turnId:n,sessionId:e.sessionId,messages:g,tools:s,model:f,apiKey:i?.apiKey??this.apiKey,temperature:i?.temperature,maxRounds:M,contextWindowTokens:i?.contextWindowTokens,maxOutputTokens:i?.maxOutputTokens,modelMaxOutputTokens:i?.modelMaxOutputTokens,toolChoice:i?.toolChoice,parentDepth:i?.parentDepth,hooks:this.hooks,fallbackModel:i?.fallbackModel,maxTurns:i?.maxTurns,tokenBudget:i?.tokenBudget,maxConcurrentTools:i?.maxConcurrentTools,streamRequired:i?.streamRequired,reasoning:i?.reasoning,promptCacheKey:i?.promptCacheKey,promptCacheRetention:i?.promptCacheRetention,serviceTier:i?.serviceTier,openaiBuiltinTools:i?.openaiBuiltinTools,maxToolCalls:i?.maxToolCalls,parallelToolCalls:i?.parallelToolCalls,textVerbosity:i?.textVerbosity,projectRoot:this.projectRoot,generateToolUseSummary:_,signal:o},S;for await(let x of Ln(b,this.transport,this.toolInvoker,this.log))S=x,yield x;S?.type==="end"?this.hooks?.invoke("turn.completed",{...p}).catch(()=>{}):S?.type==="error"&&this.hooks?.invoke("turn.failed",{...p,code:S.code,error:S.error}).catch(()=>{})}catch(_){if(o?.aborted)this.hooks?.invoke("turn.failed",{...p,code:"ABORTED",error:"Turn aborted"}).catch(()=>{}),yield{type:"error",turnId:n,error:"Turn aborted",code:"ABORTED"};else{let b=_ instanceof Error?_.message:String(_),S=typeof _?.status=="number"?_.status:void 0,x=Q(S,b);this.log.error(`turn ${n} error [${x}, retryable=${Fe(x)}]: ${b}`),this.hooks?.invoke("turn.failed",{...p,code:x,error:b}).catch(()=>{}),yield{type:"error",turnId:n,error:b,code:x}}}}};export{Bn as Agent};
|