@namzu/sdk 0.1.1 → 0.1.2
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/dist/agents/AbstractAgent.d.ts +5 -5
- package/dist/agents/AbstractAgent.d.ts.map +1 -1
- package/dist/agents/AbstractAgent.js +7 -7
- package/dist/agents/AbstractAgent.js.map +1 -1
- package/dist/agents/PipelineAgent.d.ts +1 -1
- package/dist/agents/PipelineAgent.d.ts.map +1 -1
- package/dist/agents/PipelineAgent.js +3 -1
- package/dist/agents/PipelineAgent.js.map +1 -1
- package/dist/agents/ReactiveAgent.d.ts +1 -1
- package/dist/agents/ReactiveAgent.d.ts.map +1 -1
- package/dist/agents/ReactiveAgent.js +4 -1
- package/dist/agents/ReactiveAgent.js.map +1 -1
- package/dist/agents/RouterAgent.d.ts +1 -1
- package/dist/agents/RouterAgent.d.ts.map +1 -1
- package/dist/agents/RouterAgent.js +5 -9
- package/dist/agents/RouterAgent.js.map +1 -1
- package/dist/agents/SupervisorAgent.d.ts +4 -4
- package/dist/agents/SupervisorAgent.d.ts.map +1 -1
- package/dist/agents/SupervisorAgent.js +16 -14
- package/dist/agents/SupervisorAgent.js.map +1 -1
- package/dist/agents/defineAgent.d.ts +1 -1
- package/dist/agents/defineAgent.d.ts.map +1 -1
- package/dist/agents/defineAgent.js +1 -6
- package/dist/agents/defineAgent.js.map +1 -1
- package/dist/bridge/a2a/agent-card.d.ts.map +1 -1
- package/dist/bridge/a2a/agent-card.js +1 -1
- package/dist/bridge/a2a/agent-card.js.map +1 -1
- package/dist/bridge/a2a/index.d.ts.map +1 -1
- package/dist/bridge/a2a/index.js.map +1 -1
- package/dist/bridge/a2a/mapper.d.ts +2 -2
- package/dist/bridge/a2a/mapper.d.ts.map +1 -1
- package/dist/bridge/a2a/mapper.js +28 -28
- package/dist/bridge/a2a/mapper.js.map +1 -1
- package/dist/bridge/a2a/message.d.ts +1 -1
- package/dist/bridge/a2a/message.d.ts.map +1 -1
- package/dist/bridge/a2a/message.js.map +1 -1
- package/dist/bridge/a2a/task.d.ts +2 -2
- package/dist/bridge/a2a/task.d.ts.map +1 -1
- package/dist/bridge/a2a/task.js +8 -18
- package/dist/bridge/a2a/task.js.map +1 -1
- package/dist/bridge/mcp/connector/adapter.d.ts +2 -2
- package/dist/bridge/mcp/connector/adapter.d.ts.map +1 -1
- package/dist/bridge/mcp/connector/adapter.js +1 -3
- package/dist/bridge/mcp/connector/adapter.js.map +1 -1
- package/dist/bridge/sse/index.d.ts +2 -2
- package/dist/bridge/sse/index.d.ts.map +1 -1
- package/dist/bridge/sse/index.js +1 -1
- package/dist/bridge/sse/index.js.map +1 -1
- package/dist/bridge/sse/mapper.d.ts +3 -3
- package/dist/bridge/sse/mapper.d.ts.map +1 -1
- package/dist/bridge/sse/mapper.js +26 -26
- package/dist/bridge/sse/mapper.js.map +1 -1
- package/dist/bridge/tools/connector/adapter.d.ts +2 -2
- package/dist/bridge/tools/connector/adapter.d.ts.map +1 -1
- package/dist/bridge/tools/connector/adapter.js +2 -6
- package/dist/bridge/tools/connector/adapter.js.map +1 -1
- package/dist/bridge/tools/connector/definitions.d.ts +1 -1
- package/dist/bridge/tools/connector/definitions.d.ts.map +1 -1
- package/dist/bridge/tools/connector/definitions.js +5 -16
- package/dist/bridge/tools/connector/definitions.js.map +1 -1
- package/dist/bridge/tools/connector/index.d.ts.map +1 -1
- package/dist/bridge/tools/connector/index.js.map +1 -1
- package/dist/bridge/tools/connector/router.d.ts +1 -1
- package/dist/bridge/tools/connector/router.d.ts.map +1 -1
- package/dist/bridge/tools/connector/router.js +2 -2
- package/dist/bridge/tools/connector/router.js.map +1 -1
- package/dist/config/runtime.d.ts +4 -4
- package/dist/config/runtime.js.map +1 -1
- package/dist/connector/BaseConnector.d.ts +1 -1
- package/dist/connector/BaseConnector.d.ts.map +1 -1
- package/dist/connector/BaseConnector.js +1 -3
- package/dist/connector/BaseConnector.js.map +1 -1
- package/dist/connector/builtins/http.d.ts +1 -1
- package/dist/connector/builtins/http.d.ts.map +1 -1
- package/dist/connector/builtins/http.js +6 -6
- package/dist/connector/builtins/http.js.map +1 -1
- package/dist/connector/builtins/webhook.d.ts +2 -2
- package/dist/connector/builtins/webhook.d.ts.map +1 -1
- package/dist/connector/builtins/webhook.js +4 -6
- package/dist/connector/builtins/webhook.js.map +1 -1
- package/dist/connector/execution/factory.d.ts +4 -4
- package/dist/connector/execution/factory.d.ts.map +1 -1
- package/dist/connector/execution/factory.js +1 -1
- package/dist/connector/execution/factory.js.map +1 -1
- package/dist/connector/execution/hybrid.d.ts +1 -1
- package/dist/connector/execution/hybrid.d.ts.map +1 -1
- package/dist/connector/execution/hybrid.js +4 -2
- package/dist/connector/execution/hybrid.js.map +1 -1
- package/dist/connector/execution/remote.d.ts +1 -1
- package/dist/connector/execution/remote.d.ts.map +1 -1
- package/dist/connector/execution/remote.js +1 -2
- package/dist/connector/execution/remote.js.map +1 -1
- package/dist/connector/index.d.ts.map +1 -1
- package/dist/connector/index.js.map +1 -1
- package/dist/connector/mcp/adapter.d.ts +1 -1
- package/dist/connector/mcp/adapter.d.ts.map +1 -1
- package/dist/connector/mcp/adapter.js +1 -1
- package/dist/connector/mcp/adapter.js.map +1 -1
- package/dist/connector/mcp/client.d.ts +1 -1
- package/dist/connector/mcp/client.d.ts.map +1 -1
- package/dist/connector/mcp/client.js +13 -12
- package/dist/connector/mcp/client.js.map +1 -1
- package/dist/connector/mcp/discovery.d.ts +1 -1
- package/dist/connector/mcp/discovery.d.ts.map +1 -1
- package/dist/connector/mcp/discovery.js +1 -1
- package/dist/connector/mcp/discovery.js.map +1 -1
- package/dist/connector/mcp/http-sse.d.ts +1 -1
- package/dist/connector/mcp/http-sse.d.ts.map +1 -1
- package/dist/connector/mcp/http-sse.js.map +1 -1
- package/dist/connector/mcp/index.d.ts.map +1 -1
- package/dist/connector/mcp/index.js.map +1 -1
- package/dist/connector/mcp/server.d.ts +1 -1
- package/dist/connector/mcp/server.d.ts.map +1 -1
- package/dist/connector/mcp/server.js +4 -4
- package/dist/connector/mcp/server.js.map +1 -1
- package/dist/connector/mcp/stdio.d.ts +1 -1
- package/dist/connector/mcp/stdio.d.ts.map +1 -1
- package/dist/connector/mcp/stdio.js +3 -3
- package/dist/connector/mcp/stdio.js.map +1 -1
- package/dist/constants/a2a/index.d.ts +6 -0
- package/dist/constants/a2a/index.d.ts.map +1 -0
- package/dist/constants/a2a/index.js +17 -0
- package/dist/constants/a2a/index.js.map +1 -0
- package/dist/constants/agent/index.d.ts +6 -0
- package/dist/constants/agent/index.d.ts.map +1 -0
- package/dist/constants/agent/index.js +13 -0
- package/dist/constants/agent/index.js.map +1 -0
- package/dist/constants/index.d.ts +9 -0
- package/dist/constants/index.d.ts.map +1 -0
- package/dist/constants/index.js +9 -0
- package/dist/constants/index.js.map +1 -0
- package/dist/constants/limits.d.ts +4 -0
- package/dist/constants/limits.d.ts.map +1 -0
- package/dist/constants/limits.js +14 -0
- package/dist/constants/limits.js.map +1 -0
- package/dist/constants/mcp/index.d.ts +2 -0
- package/dist/constants/mcp/index.d.ts.map +1 -0
- package/dist/constants/mcp/index.js +2 -0
- package/dist/constants/mcp/index.js.map +1 -0
- package/dist/constants/provider/index.d.ts +5 -0
- package/dist/constants/provider/index.d.ts.map +1 -0
- package/dist/constants/provider/index.js +20 -0
- package/dist/constants/provider/index.js.map +1 -0
- package/dist/constants/rag/index.d.ts +6 -0
- package/dist/constants/rag/index.d.ts.map +1 -0
- package/dist/constants/rag/index.js +24 -0
- package/dist/constants/rag/index.js.map +1 -0
- package/dist/constants/telemetry/index.d.ts +29 -0
- package/dist/constants/telemetry/index.d.ts.map +1 -0
- package/dist/constants/telemetry/index.js +29 -0
- package/dist/constants/telemetry/index.js.map +1 -0
- package/dist/constants/tools/index.d.ts +3 -0
- package/dist/constants/tools/index.d.ts.map +1 -0
- package/dist/constants/tools/index.js +3 -0
- package/dist/constants/tools/index.js.map +1 -0
- package/dist/contracts/a2a.d.ts +116 -116
- package/dist/contracts/a2a.d.ts.map +1 -1
- package/dist/contracts/a2a.js +44 -22
- package/dist/contracts/a2a.js.map +1 -1
- package/dist/contracts/api.d.ts +2 -2
- package/dist/contracts/api.d.ts.map +1 -1
- package/dist/contracts/index.d.ts +1 -1
- package/dist/contracts/index.d.ts.map +1 -1
- package/dist/contracts/index.js.map +1 -1
- package/dist/contracts/schemas.d.ts +2 -2
- package/dist/contracts/schemas.d.ts.map +1 -1
- package/dist/contracts/schemas.js +20 -10
- package/dist/contracts/schemas.js.map +1 -1
- package/dist/execution/base.d.ts +1 -1
- package/dist/execution/base.d.ts.map +1 -1
- package/dist/execution/base.js +1 -1
- package/dist/execution/base.js.map +1 -1
- package/dist/execution/local.d.ts +1 -1
- package/dist/execution/local.d.ts.map +1 -1
- package/dist/execution/local.js +2 -3
- package/dist/execution/local.js.map +1 -1
- package/dist/gateway/local.d.ts +3 -3
- package/dist/gateway/local.d.ts.map +1 -1
- package/dist/gateway/local.js +8 -4
- package/dist/gateway/local.js.map +1 -1
- package/dist/index.d.ts +92 -91
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +74 -73
- package/dist/index.js.map +1 -1
- package/dist/manager/agent/index.d.ts +1 -1
- package/dist/manager/agent/index.d.ts.map +1 -1
- package/dist/manager/agent/index.js +1 -1
- package/dist/manager/agent/index.js.map +1 -1
- package/dist/manager/agent/lifecycle.d.ts +6 -6
- package/dist/manager/agent/lifecycle.d.ts.map +1 -1
- package/dist/manager/agent/lifecycle.js +32 -34
- package/dist/manager/agent/lifecycle.js.map +1 -1
- package/dist/manager/connector/environment.d.ts +5 -5
- package/dist/manager/connector/environment.d.ts.map +1 -1
- package/dist/manager/connector/environment.js +2 -2
- package/dist/manager/connector/environment.js.map +1 -1
- package/dist/manager/connector/index.d.ts.map +1 -1
- package/dist/manager/connector/lifecycle.d.ts +3 -3
- package/dist/manager/connector/lifecycle.d.ts.map +1 -1
- package/dist/manager/connector/lifecycle.js +19 -4
- package/dist/manager/connector/lifecycle.js.map +1 -1
- package/dist/manager/connector/tenant.d.ts +3 -3
- package/dist/manager/connector/tenant.d.ts.map +1 -1
- package/dist/manager/connector/tenant.js +6 -5
- package/dist/manager/connector/tenant.js.map +1 -1
- package/dist/manager/index.d.ts.map +1 -1
- package/dist/manager/plan/lifecycle.d.ts +2 -2
- package/dist/manager/plan/lifecycle.d.ts.map +1 -1
- package/dist/manager/plan/lifecycle.js +3 -4
- package/dist/manager/plan/lifecycle.js.map +1 -1
- package/dist/manager/run/persistence.d.ts +3 -3
- package/dist/manager/run/persistence.d.ts.map +1 -1
- package/dist/manager/run/persistence.js +2 -2
- package/dist/manager/run/persistence.js.map +1 -1
- package/dist/persona/assembler.d.ts.map +1 -1
- package/dist/persona/assembler.js +1 -4
- package/dist/persona/assembler.js.map +1 -1
- package/dist/provider/bedrock/client.d.ts +2 -2
- package/dist/provider/bedrock/client.d.ts.map +1 -1
- package/dist/provider/bedrock/client.js +75 -79
- package/dist/provider/bedrock/client.js.map +1 -1
- package/dist/provider/factory.d.ts +1 -1
- package/dist/provider/factory.d.ts.map +1 -1
- package/dist/provider/factory.js +4 -21
- package/dist/provider/factory.js.map +1 -1
- package/dist/provider/openrouter/client.d.ts.map +1 -1
- package/dist/provider/openrouter/client.js +12 -6
- package/dist/provider/openrouter/client.js.map +1 -1
- package/dist/provider/telemetry/setup.d.ts +1 -1
- package/dist/provider/telemetry/setup.d.ts.map +1 -1
- package/dist/provider/telemetry/setup.js +9 -13
- package/dist/provider/telemetry/setup.js.map +1 -1
- package/dist/rag/chunking.d.ts +3 -2
- package/dist/rag/chunking.d.ts.map +1 -1
- package/dist/rag/chunking.js +6 -15
- package/dist/rag/chunking.js.map +1 -1
- package/dist/rag/context-assembler.d.ts +2 -1
- package/dist/rag/context-assembler.d.ts.map +1 -1
- package/dist/rag/context-assembler.js +2 -6
- package/dist/rag/context-assembler.js.map +1 -1
- package/dist/rag/embedding.d.ts.map +1 -1
- package/dist/rag/embedding.js +5 -4
- package/dist/rag/embedding.js.map +1 -1
- package/dist/rag/index.d.ts.map +1 -1
- package/dist/rag/ingestion.d.ts.map +1 -1
- package/dist/rag/ingestion.js +3 -3
- package/dist/rag/ingestion.js.map +1 -1
- package/dist/rag/knowledge-base.d.ts.map +1 -1
- package/dist/rag/knowledge-base.js +2 -2
- package/dist/rag/knowledge-base.js.map +1 -1
- package/dist/rag/rag-tool.d.ts.map +1 -1
- package/dist/rag/rag-tool.js +3 -1
- package/dist/rag/rag-tool.js.map +1 -1
- package/dist/rag/retriever.d.ts +2 -1
- package/dist/rag/retriever.d.ts.map +1 -1
- package/dist/rag/retriever.js +6 -12
- package/dist/rag/retriever.js.map +1 -1
- package/dist/rag/vector-store.d.ts +1 -1
- package/dist/rag/vector-store.d.ts.map +1 -1
- package/dist/rag/vector-store.js +7 -3
- package/dist/rag/vector-store.js.map +1 -1
- package/dist/registry/ManagedRegistry.d.ts +2 -2
- package/dist/registry/ManagedRegistry.d.ts.map +1 -1
- package/dist/registry/ManagedRegistry.js +21 -5
- package/dist/registry/ManagedRegistry.js.map +1 -1
- package/dist/registry/Registry.d.ts.map +1 -1
- package/dist/registry/Registry.js.map +1 -1
- package/dist/registry/agent/definitions.d.ts +3 -3
- package/dist/registry/agent/definitions.d.ts.map +1 -1
- package/dist/registry/agent/definitions.js +19 -6
- package/dist/registry/agent/definitions.js.map +1 -1
- package/dist/registry/agent/index.d.ts +1 -1
- package/dist/registry/agent/index.d.ts.map +1 -1
- package/dist/registry/agent/index.js +1 -1
- package/dist/registry/agent/index.js.map +1 -1
- package/dist/registry/connector/definitions.d.ts +3 -3
- package/dist/registry/connector/definitions.d.ts.map +1 -1
- package/dist/registry/connector/definitions.js +19 -6
- package/dist/registry/connector/definitions.js.map +1 -1
- package/dist/registry/connector/scoped.d.ts +1 -1
- package/dist/registry/connector/scoped.d.ts.map +1 -1
- package/dist/registry/connector/scoped.js.map +1 -1
- package/dist/registry/tool/execute.d.ts +2 -2
- package/dist/registry/tool/execute.d.ts.map +1 -1
- package/dist/registry/tool/execute.js +50 -50
- package/dist/registry/tool/execute.js.map +1 -1
- package/dist/run/LimitChecker.d.ts +1 -1
- package/dist/run/LimitChecker.d.ts.map +1 -1
- package/dist/run/LimitChecker.js.map +1 -1
- package/dist/run/reporter.d.ts +2 -2
- package/dist/run/reporter.d.ts.map +1 -1
- package/dist/run/reporter.js +40 -40
- package/dist/run/reporter.js.map +1 -1
- package/dist/runtime/decision/fallback.d.ts +1 -1
- package/dist/runtime/decision/fallback.d.ts.map +1 -1
- package/dist/runtime/decision/fallback.js +2 -2
- package/dist/runtime/decision/fallback.js.map +1 -1
- package/dist/runtime/decision/parser.d.ts +1 -1
- package/dist/runtime/decision/parser.d.ts.map +1 -1
- package/dist/runtime/decision/parser.js +2 -2
- package/dist/runtime/decision/parser.js.map +1 -1
- package/dist/runtime/query/checkpoint.d.ts +1 -1
- package/dist/runtime/query/checkpoint.d.ts.map +1 -1
- package/dist/runtime/query/checkpoint.js +2 -4
- package/dist/runtime/query/checkpoint.js.map +1 -1
- package/dist/runtime/query/context-cache.d.ts +1 -1
- package/dist/runtime/query/context-cache.d.ts.map +1 -1
- package/dist/runtime/query/context-cache.js +3 -6
- package/dist/runtime/query/context-cache.js.map +1 -1
- package/dist/runtime/query/context.d.ts +8 -8
- package/dist/runtime/query/context.d.ts.map +1 -1
- package/dist/runtime/query/context.js +4 -4
- package/dist/runtime/query/context.js.map +1 -1
- package/dist/runtime/query/events.d.ts +4 -4
- package/dist/runtime/query/events.d.ts.map +1 -1
- package/dist/runtime/query/events.js +4 -2
- package/dist/runtime/query/events.js.map +1 -1
- package/dist/runtime/query/executor.d.ts +8 -8
- package/dist/runtime/query/executor.d.ts.map +1 -1
- package/dist/runtime/query/executor.js +6 -6
- package/dist/runtime/query/executor.js.map +1 -1
- package/dist/runtime/query/guard.d.ts +1 -1
- package/dist/runtime/query/guard.d.ts.map +1 -1
- package/dist/runtime/query/guard.js +1 -1
- package/dist/runtime/query/guard.js.map +1 -1
- package/dist/runtime/query/index.d.ts +9 -9
- package/dist/runtime/query/index.d.ts.map +1 -1
- package/dist/runtime/query/index.js +15 -9
- package/dist/runtime/query/index.js.map +1 -1
- package/dist/runtime/query/iteration/index.d.ts +15 -15
- package/dist/runtime/query/iteration/index.d.ts.map +1 -1
- package/dist/runtime/query/iteration/index.js +47 -49
- package/dist/runtime/query/iteration/index.js.map +1 -1
- package/dist/runtime/query/iteration/phases/checkpoint.d.ts +2 -2
- package/dist/runtime/query/iteration/phases/checkpoint.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/checkpoint.js +5 -5
- package/dist/runtime/query/iteration/phases/checkpoint.js.map +1 -1
- package/dist/runtime/query/iteration/phases/context.d.ts +16 -16
- package/dist/runtime/query/iteration/phases/context.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/context.js +19 -19
- package/dist/runtime/query/iteration/phases/context.js.map +1 -1
- package/dist/runtime/query/iteration/phases/index.d.ts +6 -6
- package/dist/runtime/query/iteration/phases/index.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/index.js +4 -4
- package/dist/runtime/query/iteration/phases/index.js.map +1 -1
- package/dist/runtime/query/iteration/phases/plan.d.ts +2 -2
- package/dist/runtime/query/iteration/phases/plan.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/plan.js +6 -6
- package/dist/runtime/query/iteration/phases/plan.js.map +1 -1
- package/dist/runtime/query/iteration/phases/tool-review.d.ts +4 -4
- package/dist/runtime/query/iteration/phases/tool-review.d.ts.map +1 -1
- package/dist/runtime/query/iteration/phases/tool-review.js +40 -41
- package/dist/runtime/query/iteration/phases/tool-review.js.map +1 -1
- package/dist/runtime/query/prompt.d.ts +2 -2
- package/dist/runtime/query/prompt.d.ts.map +1 -1
- package/dist/runtime/query/prompt.js +2 -2
- package/dist/runtime/query/prompt.js.map +1 -1
- package/dist/runtime/query/result.d.ts +3 -3
- package/dist/runtime/query/result.d.ts.map +1 -1
- package/dist/runtime/query/result.js +1 -1
- package/dist/runtime/query/result.js.map +1 -1
- package/dist/runtime/query/tooling.d.ts +3 -3
- package/dist/runtime/query/tooling.d.ts.map +1 -1
- package/dist/runtime/query/tooling.js.map +1 -1
- package/dist/skills/loader.d.ts.map +1 -1
- package/dist/skills/loader.js +11 -12
- package/dist/skills/loader.js.map +1 -1
- package/dist/skills/registry.d.ts.map +1 -1
- package/dist/skills/registry.js +2 -4
- package/dist/skills/registry.js.map +1 -1
- package/dist/store/InMemoryStore.d.ts +1 -1
- package/dist/store/InMemoryStore.d.ts.map +1 -1
- package/dist/store/InMemoryStore.js.map +1 -1
- package/dist/store/activity/memory.d.ts +1 -1
- package/dist/store/activity/memory.d.ts.map +1 -1
- package/dist/store/activity/memory.js +1 -2
- package/dist/store/activity/memory.js.map +1 -1
- package/dist/store/conversation/memory.d.ts +2 -2
- package/dist/store/conversation/memory.d.ts.map +1 -1
- package/dist/store/conversation/memory.js +4 -6
- package/dist/store/conversation/memory.js.map +1 -1
- package/dist/store/run/disk.d.ts +1 -1
- package/dist/store/run/disk.d.ts.map +1 -1
- package/dist/store/run/disk.js +7 -6
- package/dist/store/run/disk.js.map +1 -1
- package/dist/store/task/disk.d.ts +2 -2
- package/dist/store/task/disk.d.ts.map +1 -1
- package/dist/store/task/disk.js +8 -6
- package/dist/store/task/disk.js.map +1 -1
- package/dist/store/task/memory.d.ts +2 -2
- package/dist/store/task/memory.d.ts.map +1 -1
- package/dist/store/task/memory.js +4 -4
- package/dist/store/task/memory.js.map +1 -1
- package/dist/telemetry/attributes.d.ts +1 -28
- package/dist/telemetry/attributes.d.ts.map +1 -1
- package/dist/telemetry/attributes.js +1 -28
- package/dist/telemetry/attributes.js.map +1 -1
- package/dist/telemetry/index.d.ts.map +1 -1
- package/dist/telemetry/index.js.map +1 -1
- package/dist/telemetry/metrics.d.ts.map +1 -1
- package/dist/telemetry/metrics.js.map +1 -1
- package/dist/tools/builtins/bash.d.ts +2 -2
- package/dist/tools/builtins/bash.d.ts.map +1 -1
- package/dist/tools/builtins/bash.js +7 -13
- package/dist/tools/builtins/bash.js.map +1 -1
- package/dist/tools/builtins/glob.d.ts.map +1 -1
- package/dist/tools/builtins/glob.js +3 -3
- package/dist/tools/builtins/glob.js.map +1 -1
- package/dist/tools/builtins/index.d.ts +6 -6
- package/dist/tools/builtins/index.d.ts.map +1 -1
- package/dist/tools/builtins/index.js +10 -10
- package/dist/tools/builtins/index.js.map +1 -1
- package/dist/tools/builtins/read-file.d.ts +1 -1
- package/dist/tools/builtins/read-file.d.ts.map +1 -1
- package/dist/tools/builtins/read-file.js +6 -11
- package/dist/tools/builtins/read-file.js.map +1 -1
- package/dist/tools/builtins/search-tools.d.ts.map +1 -1
- package/dist/tools/builtins/search-tools.js +10 -12
- package/dist/tools/builtins/search-tools.js.map +1 -1
- package/dist/tools/builtins/write-file.js +2 -2
- package/dist/tools/builtins/write-file.js.map +1 -1
- package/dist/tools/coordinator/index.d.ts +1 -1
- package/dist/tools/coordinator/index.d.ts.map +1 -1
- package/dist/tools/coordinator/index.js +36 -13
- package/dist/tools/coordinator/index.js.map +1 -1
- package/dist/tools/defineTool.d.ts +1 -1
- package/dist/tools/defineTool.d.ts.map +1 -1
- package/dist/tools/defineTool.js.map +1 -1
- package/dist/tools/task/create.d.ts +1 -1
- package/dist/tools/task/create.d.ts.map +1 -1
- package/dist/tools/task/create.js +12 -3
- package/dist/tools/task/create.js.map +1 -1
- package/dist/tools/task/index.d.ts +1 -1
- package/dist/tools/task/index.d.ts.map +1 -1
- package/dist/tools/task/index.js +1 -1
- package/dist/tools/task/index.js.map +1 -1
- package/dist/tools/task/list.d.ts +1 -1
- package/dist/tools/task/list.d.ts.map +1 -1
- package/dist/tools/task/list.js +1 -3
- package/dist/tools/task/list.js.map +1 -1
- package/dist/tools/task/update.d.ts.map +1 -1
- package/dist/tools/task/update.js +13 -4
- package/dist/tools/task/update.js.map +1 -1
- package/dist/types/a2a/index.d.ts.map +1 -1
- package/dist/types/a2a/index.js.map +1 -1
- package/dist/types/activity/index.d.ts.map +1 -1
- package/dist/types/activity/index.js +1 -1
- package/dist/types/activity/index.js.map +1 -1
- package/dist/types/agent/base.d.ts +2 -2
- package/dist/types/agent/base.d.ts.map +1 -1
- package/dist/types/agent/core.d.ts +1 -1
- package/dist/types/agent/core.d.ts.map +1 -1
- package/dist/types/agent/factory.d.ts +1 -1
- package/dist/types/agent/factory.d.ts.map +1 -1
- package/dist/types/agent/gateway.d.ts +1 -1
- package/dist/types/agent/gateway.d.ts.map +1 -1
- package/dist/types/agent/lifecycle-event.d.ts +9 -9
- package/dist/types/agent/lifecycle-event.d.ts.map +1 -1
- package/dist/types/agent/pipeline.d.ts.map +1 -1
- package/dist/types/agent/reactive.d.ts +2 -2
- package/dist/types/agent/reactive.d.ts.map +1 -1
- package/dist/types/agent/router.d.ts.map +1 -1
- package/dist/types/agent/supervisor.d.ts +1 -1
- package/dist/types/agent/supervisor.d.ts.map +1 -1
- package/dist/types/agent/task.d.ts +10 -10
- package/dist/types/agent/task.d.ts.map +1 -1
- package/dist/types/agent/task.js +3 -10
- package/dist/types/agent/task.js.map +1 -1
- package/dist/types/common/index.d.ts +1 -1
- package/dist/types/common/index.d.ts.map +1 -1
- package/dist/types/common/index.js +1 -7
- package/dist/types/common/index.js.map +1 -1
- package/dist/types/connector/core.d.ts.map +1 -1
- package/dist/types/connector/core.js.map +1 -1
- package/dist/types/connector/definition.d.ts +1 -1
- package/dist/types/connector/definition.d.ts.map +1 -1
- package/dist/types/connector/execution-context.d.ts +3 -3
- package/dist/types/connector/execution-context.d.ts.map +1 -1
- package/dist/types/connector/http.d.ts.map +1 -1
- package/dist/types/connector/mcp.d.ts +2 -2
- package/dist/types/connector/mcp.d.ts.map +1 -1
- package/dist/types/connector/scope.d.ts.map +1 -1
- package/dist/types/connector/scope.js.map +1 -1
- package/dist/types/connector/tenant.d.ts +2 -2
- package/dist/types/connector/tenant.d.ts.map +1 -1
- package/dist/types/connector/webhook.d.ts.map +1 -1
- package/dist/types/conversation/index.d.ts +1 -1
- package/dist/types/conversation/index.d.ts.map +1 -1
- package/dist/types/decision/index.d.ts.map +1 -1
- package/dist/types/decision/index.js +4 -2
- package/dist/types/decision/index.js.map +1 -1
- package/dist/types/execution/index.d.ts.map +1 -1
- package/dist/types/hitl/index.d.ts +3 -3
- package/dist/types/hitl/index.d.ts.map +1 -1
- package/dist/types/hitl/index.js.map +1 -1
- package/dist/types/message/index.d.ts.map +1 -1
- package/dist/types/message/index.js.map +1 -1
- package/dist/types/persona/index.d.ts.map +1 -1
- package/dist/types/plan/index.d.ts.map +1 -1
- package/dist/types/plan/index.js.map +1 -1
- package/dist/types/provider/chat.d.ts +1 -1
- package/dist/types/provider/chat.d.ts.map +1 -1
- package/dist/types/provider/config.d.ts.map +1 -1
- package/dist/types/provider/index.d.ts +1 -1
- package/dist/types/provider/index.d.ts.map +1 -1
- package/dist/types/provider/interface.d.ts +1 -1
- package/dist/types/provider/interface.d.ts.map +1 -1
- package/dist/types/provider/model.d.ts.map +1 -1
- package/dist/types/provider/stream.d.ts.map +1 -1
- package/dist/types/rag/chunking.d.ts.map +1 -1
- package/dist/types/rag/context.d.ts.map +1 -1
- package/dist/types/rag/embedding.d.ts.map +1 -1
- package/dist/types/rag/ingestion.d.ts.map +1 -1
- package/dist/types/rag/knowledge-base.d.ts +2 -2
- package/dist/types/rag/knowledge-base.d.ts.map +1 -1
- package/dist/types/rag/retrieval.d.ts +1 -1
- package/dist/types/rag/retrieval.d.ts.map +1 -1
- package/dist/types/rag/scope.d.ts.map +1 -1
- package/dist/types/rag/storage.d.ts +1 -1
- package/dist/types/rag/storage.d.ts.map +1 -1
- package/dist/types/rag/vector.d.ts.map +1 -1
- package/dist/types/run/config.d.ts +2 -2
- package/dist/types/run/config.d.ts.map +1 -1
- package/dist/types/run/events.d.ts +36 -36
- package/dist/types/run/events.d.ts.map +1 -1
- package/dist/types/run/metadata.d.ts +2 -2
- package/dist/types/run/metadata.d.ts.map +1 -1
- package/dist/types/run/state.d.ts +2 -2
- package/dist/types/run/state.d.ts.map +1 -1
- package/dist/types/skills/index.d.ts.map +1 -1
- package/dist/types/task/index.d.ts +1 -1
- package/dist/types/task/index.d.ts.map +1 -1
- package/dist/types/task/index.js.map +1 -1
- package/dist/types/telemetry/index.d.ts.map +1 -1
- package/dist/types/tool/index.d.ts +9 -9
- package/dist/types/tool/index.d.ts.map +1 -1
- package/dist/utils/abort.d.ts.map +1 -1
- package/dist/utils/abort.js +3 -3
- package/dist/utils/abort.js.map +1 -1
- package/dist/utils/conversation.d.ts +1 -1
- package/dist/utils/conversation.d.ts.map +1 -1
- package/dist/utils/conversation.js +2 -0
- package/dist/utils/conversation.js.map +1 -1
- package/dist/utils/cost.d.ts +3 -2
- package/dist/utils/cost.d.ts.map +1 -1
- package/dist/utils/cost.js +2 -6
- package/dist/utils/cost.js.map +1 -1
- package/dist/utils/error.js.map +1 -1
- package/dist/utils/hash.d.ts.map +1 -1
- package/dist/utils/hash.js.map +1 -1
- package/dist/utils/id.d.ts +1 -1
- package/dist/utils/id.d.ts.map +1 -1
- package/dist/utils/id.js +14 -6
- package/dist/utils/id.js.map +1 -1
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +6 -3
- package/dist/utils/logger.js.map +1 -1
- package/dist/utils/memoize.d.ts.map +1 -1
- package/dist/utils/memoize.js.map +1 -1
- package/dist/vault/InMemoryCredentialVault.d.ts +2 -2
- package/dist/vault/InMemoryCredentialVault.d.ts.map +1 -1
- package/dist/vault/InMemoryCredentialVault.js.map +1 -1
- package/package.json +17 -2
- package/src/agents/AbstractAgent.ts +31 -44
- package/src/agents/PipelineAgent.ts +152 -157
- package/src/agents/ReactiveAgent.ts +89 -85
- package/src/agents/RouterAgent.ts +216 -228
- package/src/agents/SupervisorAgent.ts +43 -48
- package/src/agents/defineAgent.ts +53 -63
- package/src/bridge/a2a/agent-card.ts +57 -62
- package/src/bridge/a2a/index.ts +9 -9
- package/src/bridge/a2a/mapper.ts +53 -61
- package/src/bridge/a2a/message.ts +66 -71
- package/src/bridge/a2a/task.ts +77 -97
- package/src/bridge/mcp/connector/adapter.ts +116 -117
- package/src/bridge/sse/index.ts +2 -2
- package/src/bridge/sse/mapper.ts +52 -60
- package/src/bridge/tools/connector/adapter.ts +111 -116
- package/src/bridge/tools/connector/definitions.ts +105 -125
- package/src/bridge/tools/connector/index.ts +7 -7
- package/src/bridge/tools/connector/router.ts +51 -54
- package/src/config/runtime.ts +6 -6
- package/src/connector/BaseConnector.ts +65 -69
- package/src/connector/builtins/http.ts +175 -177
- package/src/connector/builtins/webhook.ts +134 -141
- package/src/connector/execution/factory.ts +43 -43
- package/src/connector/execution/hybrid.ts +193 -192
- package/src/connector/execution/remote.ts +121 -123
- package/src/connector/index.ts +13 -13
- package/src/connector/mcp/adapter.ts +100 -100
- package/src/connector/mcp/client.ts +229 -217
- package/src/connector/mcp/discovery.ts +53 -53
- package/src/connector/mcp/http-sse.ts +133 -132
- package/src/connector/mcp/index.ts +6 -6
- package/src/connector/mcp/server.ts +193 -191
- package/src/connector/mcp/stdio.ts +99 -97
- package/src/constants/a2a/index.ts +21 -0
- package/src/constants/agent/index.ts +17 -0
- package/src/constants/index.ts +8 -0
- package/src/constants/limits.ts +16 -0
- package/src/constants/mcp/index.ts +1 -0
- package/src/constants/provider/index.ts +23 -0
- package/src/constants/rag/index.ts +34 -0
- package/src/constants/telemetry/index.ts +34 -0
- package/src/constants/tools/index.ts +3 -0
- package/src/contracts/a2a.ts +111 -89
- package/src/contracts/api.ts +147 -147
- package/src/contracts/index.ts +34 -34
- package/src/contracts/schemas.ts +57 -47
- package/src/execution/base.ts +59 -62
- package/src/execution/local.ts +147 -148
- package/src/gateway/local.ts +89 -89
- package/src/index.ts +107 -100
- package/src/manager/agent/index.ts +1 -1
- package/src/manager/agent/lifecycle.ts +159 -184
- package/src/manager/connector/environment.ts +242 -234
- package/src/manager/connector/index.ts +2 -2
- package/src/manager/connector/lifecycle.ts +243 -230
- package/src/manager/connector/tenant.ts +279 -283
- package/src/manager/index.ts +2 -2
- package/src/manager/plan/lifecycle.ts +226 -223
- package/src/manager/run/persistence.ts +166 -165
- package/src/persona/assembler.ts +52 -64
- package/src/provider/bedrock/client.ts +203 -234
- package/src/provider/factory.ts +139 -158
- package/src/provider/openrouter/client.ts +368 -374
- package/src/provider/telemetry/setup.ts +100 -110
- package/src/rag/chunking.ts +131 -141
- package/src/rag/context-assembler.ts +39 -43
- package/src/rag/embedding.ts +57 -56
- package/src/rag/index.ts +25 -25
- package/src/rag/ingestion.ts +60 -60
- package/src/rag/knowledge-base.ts +54 -54
- package/src/rag/rag-tool.ts +54 -51
- package/src/rag/retriever.ts +170 -177
- package/src/rag/vector-store.ts +66 -63
- package/src/registry/ManagedRegistry.ts +41 -30
- package/src/registry/Registry.ts +25 -25
- package/src/registry/agent/definitions.ts +42 -34
- package/src/registry/agent/index.ts +1 -1
- package/src/registry/connector/definitions.ts +36 -26
- package/src/registry/connector/scoped.ts +120 -120
- package/src/registry/tool/execute.ts +130 -151
- package/src/run/LimitChecker.ts +61 -61
- package/src/run/reporter.ts +90 -96
- package/src/runtime/decision/fallback.ts +78 -81
- package/src/runtime/decision/parser.ts +150 -146
- package/src/runtime/query/checkpoint.ts +70 -66
- package/src/runtime/query/context-cache.ts +58 -62
- package/src/runtime/query/context.ts +82 -82
- package/src/runtime/query/events.ts +129 -127
- package/src/runtime/query/executor.ts +59 -67
- package/src/runtime/query/guard.ts +52 -55
- package/src/runtime/query/index.ts +290 -292
- package/src/runtime/query/iteration/index.ts +284 -310
- package/src/runtime/query/iteration/phases/checkpoint.ts +12 -20
- package/src/runtime/query/iteration/phases/context.ts +64 -73
- package/src/runtime/query/iteration/phases/index.ts +6 -6
- package/src/runtime/query/iteration/phases/plan.ts +14 -21
- package/src/runtime/query/iteration/phases/tool-review.ts +82 -91
- package/src/runtime/query/prompt.ts +49 -50
- package/src/runtime/query/result.ts +72 -72
- package/src/runtime/query/tooling.ts +29 -29
- package/src/skills/loader.ts +127 -123
- package/src/skills/registry.ts +91 -85
- package/src/store/InMemoryStore.ts +48 -51
- package/src/store/activity/memory.ts +217 -209
- package/src/store/conversation/memory.ts +88 -90
- package/src/store/run/disk.ts +204 -205
- package/src/store/task/disk.ts +311 -307
- package/src/store/task/memory.ts +173 -171
- package/src/telemetry/attributes.ts +5 -38
- package/src/telemetry/index.ts +5 -5
- package/src/telemetry/metrics.ts +53 -54
- package/src/tools/builtins/bash.ts +44 -55
- package/src/tools/builtins/glob.ts +75 -79
- package/src/tools/builtins/index.ts +12 -12
- package/src/tools/builtins/read-file.ts +37 -42
- package/src/tools/builtins/search-tools.ts +17 -19
- package/src/tools/builtins/write-file.ts +23 -23
- package/src/tools/coordinator/index.ts +227 -189
- package/src/tools/defineTool.ts +42 -36
- package/src/tools/task/create.ts +45 -38
- package/src/tools/task/index.ts +8 -11
- package/src/tools/task/list.ts +45 -48
- package/src/tools/task/update.ts +78 -60
- package/src/types/a2a/index.ts +143 -143
- package/src/types/activity/index.ts +40 -32
- package/src/types/agent/base.ts +41 -41
- package/src/types/agent/core.ts +13 -17
- package/src/types/agent/factory.ts +27 -27
- package/src/types/agent/gateway.ts +18 -18
- package/src/types/agent/lifecycle-event.ts +14 -16
- package/src/types/agent/pipeline.ts +23 -23
- package/src/types/agent/reactive.ts +9 -9
- package/src/types/agent/router.ts +17 -17
- package/src/types/agent/supervisor.ts +14 -14
- package/src/types/agent/task.ts +54 -63
- package/src/types/common/index.ts +24 -39
- package/src/types/connector/core.ts +22 -22
- package/src/types/connector/definition.ts +59 -45
- package/src/types/connector/execution-context.ts +37 -30
- package/src/types/connector/http.ts +12 -12
- package/src/types/connector/mcp.ts +123 -115
- package/src/types/connector/scope.ts +19 -19
- package/src/types/connector/tenant.ts +28 -23
- package/src/types/connector/webhook.ts +10 -10
- package/src/types/conversation/index.ts +3 -3
- package/src/types/decision/index.ts +18 -16
- package/src/types/execution/index.ts +21 -21
- package/src/types/hitl/index.ts +80 -69
- package/src/types/message/index.ts +26 -29
- package/src/types/persona/index.ts +31 -31
- package/src/types/plan/index.ts +38 -38
- package/src/types/provider/chat.ts +47 -44
- package/src/types/provider/config.ts +26 -23
- package/src/types/provider/index.ts +16 -10
- package/src/types/provider/interface.ts +7 -7
- package/src/types/provider/model.ts +8 -8
- package/src/types/provider/stream.ts +16 -16
- package/src/types/rag/chunking.ts +7 -7
- package/src/types/rag/context.ts +14 -14
- package/src/types/rag/embedding.ts +10 -10
- package/src/types/rag/ingestion.ts +11 -11
- package/src/types/rag/knowledge-base.ts +16 -16
- package/src/types/rag/retrieval.ts +19 -19
- package/src/types/rag/scope.ts +8 -8
- package/src/types/rag/storage.ts +18 -18
- package/src/types/rag/vector.ts +13 -13
- package/src/types/run/config.ts +30 -30
- package/src/types/run/events.ts +113 -115
- package/src/types/run/metadata.ts +29 -29
- package/src/types/run/state.ts +20 -20
- package/src/types/skills/index.ts +13 -13
- package/src/types/task/index.ts +55 -59
- package/src/types/telemetry/index.ts +6 -6
- package/src/types/tool/index.ts +43 -43
- package/src/utils/abort.ts +13 -15
- package/src/utils/conversation.ts +14 -13
- package/src/utils/cost.ts +31 -35
- package/src/utils/error.ts +1 -1
- package/src/utils/hash.ts +8 -8
- package/src/utils/id.ts +70 -41
- package/src/utils/logger.ts +41 -50
- package/src/utils/memoize.ts +14 -12
- package/src/vault/InMemoryCredentialVault.ts +50 -54
- package/dist/manager/session/lifecycle.d.ts +0 -3
- package/dist/manager/session/lifecycle.d.ts.map +0 -1
- package/dist/manager/session/lifecycle.js +0 -3
- package/dist/manager/session/lifecycle.js.map +0 -1
- package/dist/session/LimitChecker.d.ts +0 -3
- package/dist/session/LimitChecker.d.ts.map +0 -1
- package/dist/session/LimitChecker.js +0 -3
- package/dist/session/LimitChecker.js.map +0 -1
- package/dist/session/index.d.ts +0 -3
- package/dist/session/index.d.ts.map +0 -1
- package/dist/session/index.js +0 -3
- package/dist/session/index.js.map +0 -1
- package/dist/session/reporter.d.ts +0 -3
- package/dist/session/reporter.d.ts.map +0 -1
- package/dist/session/reporter.js +0 -3
- package/dist/session/reporter.js.map +0 -1
- package/dist/store/session/disk.d.ts +0 -3
- package/dist/store/session/disk.d.ts.map +0 -1
- package/dist/store/session/disk.js +0 -3
- package/dist/store/session/disk.js.map +0 -1
- package/dist/types/session/config.d.ts +0 -2
- package/dist/types/session/config.d.ts.map +0 -1
- package/dist/types/session/config.js +0 -2
- package/dist/types/session/config.js.map +0 -1
- package/dist/types/session/events.d.ts +0 -2
- package/dist/types/session/events.d.ts.map +0 -1
- package/dist/types/session/events.js +0 -2
- package/dist/types/session/events.js.map +0 -1
- package/dist/types/session/index.d.ts +0 -4
- package/dist/types/session/index.d.ts.map +0 -1
- package/dist/types/session/index.js +0 -4
- package/dist/types/session/index.js.map +0 -1
- package/dist/types/session/state.d.ts +0 -2
- package/dist/types/session/state.d.ts.map +0 -1
- package/dist/types/session/state.js +0 -2
- package/dist/types/session/state.js.map +0 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { SpanStatusCode } from
|
|
2
|
-
import { zodToJsonSchema } from
|
|
3
|
-
import { getTracer } from
|
|
4
|
-
import { GENAI, NAMZU, toolSpanName } from
|
|
1
|
+
import { SpanStatusCode } from '@opentelemetry/api'
|
|
2
|
+
import { zodToJsonSchema } from 'zod-to-json-schema'
|
|
3
|
+
import { getTracer } from '../../provider/telemetry/setup.js'
|
|
4
|
+
import { GENAI, NAMZU, toolSpanName } from '../../telemetry/attributes.js'
|
|
5
5
|
import type {
|
|
6
6
|
LLMToolSchema,
|
|
7
7
|
ToolAvailability,
|
|
@@ -9,183 +9,171 @@ import type {
|
|
|
9
9
|
ToolDefinition,
|
|
10
10
|
ToolRegistryConfig,
|
|
11
11
|
ToolResult,
|
|
12
|
-
} from
|
|
13
|
-
import { toErrorMessage } from
|
|
14
|
-
import { type Logger, getRootLogger } from
|
|
15
|
-
import { Registry } from
|
|
12
|
+
} from '../../types/tool/index.js'
|
|
13
|
+
import { toErrorMessage } from '../../utils/error.js'
|
|
14
|
+
import { type Logger, getRootLogger } from '../../utils/logger.js'
|
|
15
|
+
import { Registry } from '../Registry.js'
|
|
16
16
|
|
|
17
17
|
export interface ToolExecutionResult extends ToolResult {
|
|
18
|
-
permissionDenied?: boolean
|
|
19
|
-
permissionMessage?: string
|
|
18
|
+
permissionDenied?: boolean
|
|
19
|
+
permissionMessage?: string
|
|
20
20
|
}
|
|
21
21
|
|
|
22
22
|
export class ToolRegistry extends Registry<ToolDefinition> {
|
|
23
|
-
private log: Logger
|
|
24
|
-
private availability: Map<string, ToolAvailability> = new Map()
|
|
23
|
+
private log: Logger
|
|
24
|
+
private availability: Map<string, ToolAvailability> = new Map()
|
|
25
25
|
|
|
26
26
|
constructor(config?: ToolRegistryConfig) {
|
|
27
|
-
super()
|
|
27
|
+
super()
|
|
28
28
|
this.log = (config?.logger ?? getRootLogger()).child({
|
|
29
|
-
component:
|
|
30
|
-
})
|
|
29
|
+
component: 'ToolRegistry',
|
|
30
|
+
})
|
|
31
31
|
}
|
|
32
32
|
|
|
33
|
-
override register(id: string, tool: ToolDefinition): void
|
|
34
|
-
register(tool: ToolDefinition, initialState?: ToolAvailability): void
|
|
35
|
-
register(tools: ToolDefinition[], initialState?: ToolAvailability): void
|
|
36
|
-
register(
|
|
33
|
+
override register(id: string, tool: ToolDefinition): void
|
|
34
|
+
override register(tool: ToolDefinition, initialState?: ToolAvailability): void
|
|
35
|
+
override register(tools: ToolDefinition[], initialState?: ToolAvailability): void
|
|
36
|
+
override register(
|
|
37
37
|
idOrToolOrTools: string | ToolDefinition | ToolDefinition[],
|
|
38
38
|
maybeTool?: ToolDefinition | ToolAvailability,
|
|
39
39
|
): void {
|
|
40
40
|
if (Array.isArray(idOrToolOrTools)) {
|
|
41
|
-
const state = (
|
|
42
|
-
typeof maybeTool === "string" ? maybeTool : "active"
|
|
43
|
-
) as ToolAvailability;
|
|
41
|
+
const state = (typeof maybeTool === 'string' ? maybeTool : 'active') as ToolAvailability
|
|
44
42
|
for (const tool of idOrToolOrTools) {
|
|
45
|
-
this.registerOne(tool.name, tool, state)
|
|
43
|
+
this.registerOne(tool.name, tool, state)
|
|
46
44
|
}
|
|
47
|
-
return
|
|
45
|
+
return
|
|
48
46
|
}
|
|
49
47
|
|
|
50
|
-
|
|
51
|
-
typeof
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
typeof maybeTool === "string" ? maybeTool : "active";
|
|
48
|
+
if (typeof idOrToolOrTools === 'string') {
|
|
49
|
+
if (!maybeTool || typeof maybeTool === 'string') {
|
|
50
|
+
throw new Error('register(id, tool) requires a ToolDefinition argument')
|
|
51
|
+
}
|
|
52
|
+
this.registerOne(idOrToolOrTools, maybeTool, 'active')
|
|
53
|
+
return
|
|
54
|
+
}
|
|
58
55
|
|
|
59
|
-
|
|
56
|
+
const tool = idOrToolOrTools
|
|
57
|
+
const id = tool.name
|
|
58
|
+
const state: ToolAvailability = typeof maybeTool === 'string' ? maybeTool : 'active'
|
|
59
|
+
|
|
60
|
+
this.registerOne(id, tool, state)
|
|
60
61
|
}
|
|
61
62
|
|
|
62
|
-
private registerOne(
|
|
63
|
-
id: string,
|
|
64
|
-
tool: ToolDefinition,
|
|
65
|
-
state: ToolAvailability,
|
|
66
|
-
): void {
|
|
63
|
+
private registerOne(id: string, tool: ToolDefinition, state: ToolAvailability): void {
|
|
67
64
|
if (this.has(id)) {
|
|
68
|
-
this.log.warn(`Tool "${id}" is already registered, overwriting.`)
|
|
65
|
+
this.log.warn(`Tool "${id}" is already registered, overwriting.`)
|
|
69
66
|
}
|
|
70
|
-
super.register(id, tool)
|
|
71
|
-
this.availability.set(id, state)
|
|
72
|
-
this.log.info(`Tool registered: ${id} (${state})`)
|
|
67
|
+
super.register(id, tool)
|
|
68
|
+
this.availability.set(id, state)
|
|
69
|
+
this.log.info(`Tool registered: ${id} (${state})`)
|
|
73
70
|
}
|
|
74
71
|
|
|
75
72
|
override unregister(id: string): boolean {
|
|
76
|
-
this.availability.delete(id)
|
|
77
|
-
return super.unregister(id)
|
|
73
|
+
this.availability.delete(id)
|
|
74
|
+
return super.unregister(id)
|
|
78
75
|
}
|
|
79
76
|
|
|
80
77
|
override clear(): void {
|
|
81
|
-
this.availability.clear()
|
|
82
|
-
super.clear()
|
|
78
|
+
this.availability.clear()
|
|
79
|
+
super.clear()
|
|
83
80
|
}
|
|
84
81
|
|
|
85
82
|
activate(names: string[]): void {
|
|
86
83
|
for (const name of names) {
|
|
87
|
-
this.getOrThrow(name)
|
|
88
|
-
this.availability.set(name,
|
|
89
|
-
this.log.debug(`Tool activated: ${name}`)
|
|
84
|
+
this.getOrThrow(name)
|
|
85
|
+
this.availability.set(name, 'active')
|
|
86
|
+
this.log.debug(`Tool activated: ${name}`)
|
|
90
87
|
}
|
|
91
88
|
}
|
|
92
89
|
|
|
93
90
|
defer(names: string[]): void {
|
|
94
91
|
for (const name of names) {
|
|
95
|
-
this.getOrThrow(name)
|
|
96
|
-
this.availability.set(name,
|
|
97
|
-
this.log.debug(`Tool deferred: ${name}`)
|
|
92
|
+
this.getOrThrow(name)
|
|
93
|
+
this.availability.set(name, 'deferred')
|
|
94
|
+
this.log.debug(`Tool deferred: ${name}`)
|
|
98
95
|
}
|
|
99
96
|
}
|
|
100
97
|
|
|
101
98
|
suspendAll(): void {
|
|
102
99
|
for (const name of this.listIds()) {
|
|
103
|
-
if (this.getAvailability(name) ===
|
|
104
|
-
this.availability.set(name,
|
|
100
|
+
if (this.getAvailability(name) === 'active') {
|
|
101
|
+
this.availability.set(name, 'suspended')
|
|
105
102
|
}
|
|
106
103
|
}
|
|
107
|
-
this.log.info(
|
|
104
|
+
this.log.info('All active tools suspended')
|
|
108
105
|
}
|
|
109
106
|
|
|
110
107
|
hasSuspended(): boolean {
|
|
111
108
|
for (const state of this.availability.values()) {
|
|
112
|
-
if (state ===
|
|
109
|
+
if (state === 'suspended') return true
|
|
113
110
|
}
|
|
114
|
-
return false
|
|
111
|
+
return false
|
|
115
112
|
}
|
|
116
113
|
|
|
117
114
|
getAvailability(name: string): ToolAvailability {
|
|
118
|
-
return this.availability.get(name) ??
|
|
115
|
+
return this.availability.get(name) ?? 'active'
|
|
119
116
|
}
|
|
120
117
|
|
|
121
118
|
searchDeferred(query: string): ToolDefinition[] {
|
|
122
|
-
const q = query.toLowerCase()
|
|
123
|
-
return this.getByAvailability([
|
|
124
|
-
(t) =>
|
|
125
|
-
|
|
126
|
-
t.description.toLowerCase().includes(q),
|
|
127
|
-
);
|
|
119
|
+
const q = query.toLowerCase()
|
|
120
|
+
return this.getByAvailability(['deferred']).filter(
|
|
121
|
+
(t) => t.name.toLowerCase().includes(q) || t.description.toLowerCase().includes(q),
|
|
122
|
+
)
|
|
128
123
|
}
|
|
129
124
|
|
|
130
125
|
getOrThrow(name: string): ToolDefinition {
|
|
131
|
-
const tool = this.get(name)
|
|
126
|
+
const tool = this.get(name)
|
|
132
127
|
if (!tool) {
|
|
133
|
-
throw new Error(
|
|
134
|
-
`Tool not found: "${name}". Available tools: ${this.listIds().join(", ")}`,
|
|
135
|
-
);
|
|
128
|
+
throw new Error(`Tool not found: "${name}". Available tools: ${this.listIds().join(', ')}`)
|
|
136
129
|
}
|
|
137
|
-
return tool
|
|
130
|
+
return tool
|
|
138
131
|
}
|
|
139
132
|
|
|
140
133
|
listNames(): string[] {
|
|
141
|
-
return this.listIds()
|
|
134
|
+
return this.listIds()
|
|
142
135
|
}
|
|
143
136
|
|
|
144
137
|
toPromptSection(toolNames?: string[]): string {
|
|
145
|
-
const active = this.getByAvailability([
|
|
146
|
-
const deferred = this.getByAvailability([
|
|
138
|
+
const active = this.getByAvailability(['active'], toolNames)
|
|
139
|
+
const deferred = this.getByAvailability(['deferred'], toolNames)
|
|
147
140
|
|
|
148
|
-
const parts: string[] = []
|
|
141
|
+
const parts: string[] = []
|
|
149
142
|
|
|
150
143
|
if (active.length > 0) {
|
|
151
|
-
const entries = active
|
|
152
|
-
|
|
153
|
-
.join("\n");
|
|
154
|
-
parts.push(`<available_tools>\n${entries}\n</available_tools>`);
|
|
144
|
+
const entries = active.map((t) => `- ${t.name}: ${t.description}`).join('\n')
|
|
145
|
+
parts.push(`<available_tools>\n${entries}\n</available_tools>`)
|
|
155
146
|
}
|
|
156
147
|
|
|
157
148
|
if (deferred.length > 0) {
|
|
158
|
-
const entries = deferred.map((t) => `- ${t.name}`).join(
|
|
149
|
+
const entries = deferred.map((t) => `- ${t.name}`).join('\n')
|
|
159
150
|
parts.push(
|
|
160
151
|
`<deferred_tools>\nUse search_tools to load these before use:\n${entries}\n</deferred_tools>`,
|
|
161
|
-
)
|
|
152
|
+
)
|
|
162
153
|
}
|
|
163
154
|
|
|
164
|
-
if (parts.length === 0) return
|
|
165
|
-
return parts.join(
|
|
155
|
+
if (parts.length === 0) return ''
|
|
156
|
+
return parts.join('\n\n')
|
|
166
157
|
}
|
|
167
158
|
|
|
168
159
|
toLLMTools(toolNames?: string[]): LLMToolSchema[] {
|
|
169
|
-
const toolsToConvert = this.getByAvailability(
|
|
170
|
-
["active", "suspended"],
|
|
171
|
-
toolNames,
|
|
172
|
-
);
|
|
160
|
+
const toolsToConvert = this.getByAvailability(['active', 'suspended'], toolNames)
|
|
173
161
|
|
|
174
162
|
return toolsToConvert.map((tool) => ({
|
|
175
|
-
type:
|
|
163
|
+
type: 'function' as const,
|
|
176
164
|
function: {
|
|
177
165
|
name: tool.name,
|
|
178
166
|
description: tool.description,
|
|
179
167
|
parameters: zodToJsonSchema(tool.inputSchema, {
|
|
180
|
-
target:
|
|
181
|
-
$refStrategy:
|
|
168
|
+
target: 'jsonSchema7',
|
|
169
|
+
$refStrategy: 'none',
|
|
182
170
|
}) as Record<string, unknown>,
|
|
183
171
|
},
|
|
184
|
-
}))
|
|
172
|
+
}))
|
|
185
173
|
}
|
|
186
174
|
|
|
187
175
|
getCallableTools(toolNames?: string[]): ToolDefinition[] {
|
|
188
|
-
return this.getByAvailability([
|
|
176
|
+
return this.getByAvailability(['active'], toolNames)
|
|
189
177
|
}
|
|
190
178
|
|
|
191
179
|
async execute(
|
|
@@ -193,131 +181,122 @@ export class ToolRegistry extends Registry<ToolDefinition> {
|
|
|
193
181
|
rawInput: unknown,
|
|
194
182
|
context: ToolContext,
|
|
195
183
|
): Promise<ToolExecutionResult> {
|
|
196
|
-
const tracer = getTracer()
|
|
184
|
+
const tracer = getTracer()
|
|
197
185
|
|
|
198
186
|
return tracer.startActiveSpan(toolSpanName(toolName), async (span) => {
|
|
199
187
|
span.setAttributes({
|
|
200
188
|
[GENAI.TOOL_NAME]: toolName,
|
|
201
|
-
[GENAI.TOOL_TYPE]:
|
|
202
|
-
})
|
|
189
|
+
[GENAI.TOOL_TYPE]: 'function',
|
|
190
|
+
})
|
|
203
191
|
|
|
204
|
-
const tool = this.getOrThrow(toolName)
|
|
192
|
+
const tool = this.getOrThrow(toolName)
|
|
205
193
|
|
|
206
|
-
const availability = this.getAvailability(toolName)
|
|
207
|
-
if (availability !==
|
|
208
|
-
const msg = `Tool "${toolName}" is ${availability} and cannot be executed
|
|
209
|
-
this.log.warn(msg)
|
|
194
|
+
const availability = this.getAvailability(toolName)
|
|
195
|
+
if (availability !== 'active') {
|
|
196
|
+
const msg = `Tool "${toolName}" is ${availability} and cannot be executed`
|
|
197
|
+
this.log.warn(msg)
|
|
210
198
|
span.setAttributes({
|
|
211
199
|
[NAMZU.TOOL_SUCCESS]: false,
|
|
212
200
|
[NAMZU.TOOL_ERROR]: msg,
|
|
213
|
-
})
|
|
214
|
-
span.setStatus({ code: SpanStatusCode.ERROR, message: msg })
|
|
215
|
-
span.end()
|
|
201
|
+
})
|
|
202
|
+
span.setStatus({ code: SpanStatusCode.ERROR, message: msg })
|
|
203
|
+
span.end()
|
|
216
204
|
return {
|
|
217
205
|
success: false,
|
|
218
|
-
output:
|
|
206
|
+
output: '',
|
|
219
207
|
error: msg,
|
|
220
|
-
}
|
|
208
|
+
}
|
|
221
209
|
}
|
|
222
210
|
|
|
223
|
-
const mode = context.permissionContext?.mode ??
|
|
224
|
-
if (mode ===
|
|
225
|
-
const isReadOnly = tool.isReadOnly ? tool.isReadOnly(rawInput) : false
|
|
211
|
+
const mode = context.permissionContext?.mode ?? 'auto'
|
|
212
|
+
if (mode === 'plan') {
|
|
213
|
+
const isReadOnly = tool.isReadOnly ? tool.isReadOnly(rawInput) : false
|
|
226
214
|
if (!isReadOnly) {
|
|
227
|
-
const msg = `plan mode: non-read-only tool "${toolName}" blocked
|
|
215
|
+
const msg = `plan mode: non-read-only tool "${toolName}" blocked`
|
|
228
216
|
span.setAttributes({
|
|
229
217
|
[NAMZU.TOOL_SUCCESS]: false,
|
|
230
218
|
[NAMZU.TOOL_ERROR]: msg,
|
|
231
|
-
})
|
|
232
|
-
span.setStatus({ code: SpanStatusCode.ERROR, message: msg })
|
|
233
|
-
span.end()
|
|
219
|
+
})
|
|
220
|
+
span.setStatus({ code: SpanStatusCode.ERROR, message: msg })
|
|
221
|
+
span.end()
|
|
234
222
|
return {
|
|
235
223
|
success: false,
|
|
236
|
-
output:
|
|
224
|
+
output: '',
|
|
237
225
|
error: msg,
|
|
238
226
|
permissionDenied: true,
|
|
239
227
|
permissionMessage: msg,
|
|
240
|
-
}
|
|
228
|
+
}
|
|
241
229
|
}
|
|
242
230
|
}
|
|
243
231
|
|
|
244
|
-
const parseResult = tool.inputSchema.safeParse(rawInput)
|
|
232
|
+
const parseResult = tool.inputSchema.safeParse(rawInput)
|
|
245
233
|
if (!parseResult.success) {
|
|
246
234
|
const errorMessage = parseResult.error.issues
|
|
247
|
-
.map((i) => `${i.path.join(
|
|
248
|
-
.join(
|
|
235
|
+
.map((i) => `${i.path.join('.')}: ${i.message}`)
|
|
236
|
+
.join('; ')
|
|
249
237
|
|
|
250
238
|
this.log.error(`Tool input validation failed: ${toolName}`, {
|
|
251
239
|
errors: errorMessage,
|
|
252
|
-
})
|
|
240
|
+
})
|
|
253
241
|
|
|
254
242
|
span.setAttributes({
|
|
255
243
|
[NAMZU.TOOL_SUCCESS]: false,
|
|
256
244
|
[NAMZU.TOOL_ERROR]: `Validation: ${errorMessage}`,
|
|
257
|
-
})
|
|
258
|
-
span.setStatus({ code: SpanStatusCode.ERROR, message: errorMessage })
|
|
259
|
-
span.end()
|
|
245
|
+
})
|
|
246
|
+
span.setStatus({ code: SpanStatusCode.ERROR, message: errorMessage })
|
|
247
|
+
span.end()
|
|
260
248
|
|
|
261
249
|
return {
|
|
262
250
|
success: false,
|
|
263
|
-
output:
|
|
251
|
+
output: '',
|
|
264
252
|
error: `Invalid input for tool "${toolName}": ${errorMessage}`,
|
|
265
|
-
}
|
|
253
|
+
}
|
|
266
254
|
}
|
|
267
255
|
|
|
268
|
-
const finalInput = parseResult.data
|
|
256
|
+
const finalInput = parseResult.data
|
|
269
257
|
|
|
270
258
|
try {
|
|
271
|
-
this.log.debug(`Executing tool: ${toolName}`)
|
|
272
|
-
const result = await tool.execute(finalInput, context)
|
|
259
|
+
this.log.debug(`Executing tool: ${toolName}`)
|
|
260
|
+
const result = await tool.execute(finalInput, context)
|
|
273
261
|
this.log.debug(`Tool completed: ${toolName}`, {
|
|
274
262
|
success: result.success,
|
|
275
|
-
})
|
|
263
|
+
})
|
|
276
264
|
|
|
277
|
-
span.setAttribute(NAMZU.TOOL_SUCCESS, result.success)
|
|
265
|
+
span.setAttribute(NAMZU.TOOL_SUCCESS, result.success)
|
|
278
266
|
if (!result.success && result.error) {
|
|
279
|
-
span.setAttribute(NAMZU.TOOL_ERROR, result.error)
|
|
280
|
-
span.setStatus({ code: SpanStatusCode.ERROR, message: result.error })
|
|
267
|
+
span.setAttribute(NAMZU.TOOL_ERROR, result.error)
|
|
268
|
+
span.setStatus({ code: SpanStatusCode.ERROR, message: result.error })
|
|
281
269
|
} else {
|
|
282
|
-
span.setStatus({ code: SpanStatusCode.OK })
|
|
270
|
+
span.setStatus({ code: SpanStatusCode.OK })
|
|
283
271
|
}
|
|
284
272
|
|
|
285
|
-
return result
|
|
273
|
+
return result
|
|
286
274
|
} catch (err) {
|
|
287
|
-
const errorMessage = toErrorMessage(err)
|
|
275
|
+
const errorMessage = toErrorMessage(err)
|
|
288
276
|
this.log.error(`Tool execution error: ${toolName}`, {
|
|
289
277
|
error: errorMessage,
|
|
290
|
-
})
|
|
278
|
+
})
|
|
291
279
|
|
|
292
280
|
span.setAttributes({
|
|
293
281
|
[NAMZU.TOOL_SUCCESS]: false,
|
|
294
282
|
[NAMZU.TOOL_ERROR]: errorMessage,
|
|
295
|
-
})
|
|
296
|
-
span.setStatus({ code: SpanStatusCode.ERROR, message: errorMessage })
|
|
297
|
-
span.recordException(
|
|
298
|
-
err instanceof Error ? err : new Error(errorMessage),
|
|
299
|
-
);
|
|
283
|
+
})
|
|
284
|
+
span.setStatus({ code: SpanStatusCode.ERROR, message: errorMessage })
|
|
285
|
+
span.recordException(err instanceof Error ? err : new Error(errorMessage))
|
|
300
286
|
|
|
301
287
|
return {
|
|
302
288
|
success: false,
|
|
303
|
-
output:
|
|
289
|
+
output: '',
|
|
304
290
|
error: `Tool "${toolName}" execution failed: ${errorMessage}`,
|
|
305
|
-
}
|
|
291
|
+
}
|
|
306
292
|
} finally {
|
|
307
|
-
span.end()
|
|
293
|
+
span.end()
|
|
308
294
|
}
|
|
309
|
-
})
|
|
295
|
+
})
|
|
310
296
|
}
|
|
311
297
|
|
|
312
|
-
private getByAvailability(
|
|
313
|
-
|
|
314
|
-
filter
|
|
315
|
-
): ToolDefinition[] {
|
|
316
|
-
const candidates = filter
|
|
317
|
-
? filter.map((n) => this.getOrThrow(n))
|
|
318
|
-
: this.getAll();
|
|
319
|
-
return candidates.filter((t) =>
|
|
320
|
-
states.includes(this.getAvailability(t.name)),
|
|
321
|
-
);
|
|
298
|
+
private getByAvailability(states: ToolAvailability[], filter?: string[]): ToolDefinition[] {
|
|
299
|
+
const candidates = filter ? filter.map((n) => this.getOrThrow(n)) : this.getAll()
|
|
300
|
+
return candidates.filter((t) => states.includes(this.getAvailability(t.name)))
|
|
322
301
|
}
|
|
323
302
|
}
|
package/src/run/LimitChecker.ts
CHANGED
|
@@ -1,86 +1,86 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { LimitCheckerConfig, StopReason } from '../types/run/index.js'
|
|
2
2
|
|
|
3
3
|
export interface LimitCheckerState {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
4
|
+
aborted: boolean
|
|
5
|
+
totalTokens: number
|
|
6
|
+
totalCost: number
|
|
7
|
+
currentIteration: number
|
|
8
|
+
startTime: number
|
|
9
9
|
}
|
|
10
10
|
|
|
11
11
|
export type LimitCheckResult =
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
12
|
+
| { type: 'ok' }
|
|
13
|
+
| { type: 'warning'; reason: StopReason }
|
|
14
|
+
| { type: 'hard_stop'; reason: StopReason }
|
|
15
15
|
|
|
16
16
|
export function checkLimits(
|
|
17
|
-
|
|
18
|
-
|
|
17
|
+
config: LimitCheckerConfig,
|
|
18
|
+
state: LimitCheckerState,
|
|
19
19
|
): StopReason | null {
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
20
|
+
const result = checkLimitsDetailed(config, state)
|
|
21
|
+
if (result.type === 'ok') return null
|
|
22
|
+
return result.reason
|
|
23
23
|
}
|
|
24
24
|
|
|
25
25
|
export function checkLimitsDetailed(
|
|
26
|
-
|
|
27
|
-
|
|
26
|
+
config: LimitCheckerConfig,
|
|
27
|
+
state: LimitCheckerState,
|
|
28
28
|
): LimitCheckResult {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
29
|
+
if (state.aborted) {
|
|
30
|
+
return { type: 'hard_stop', reason: 'cancelled' }
|
|
31
|
+
}
|
|
32
32
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
33
|
+
if (Date.now() - state.startTime > config.timeoutMs) {
|
|
34
|
+
return { type: 'hard_stop', reason: 'timeout' }
|
|
35
|
+
}
|
|
36
36
|
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
37
|
+
if (config.tokenBudget > 0 && state.totalTokens >= config.tokenBudget) {
|
|
38
|
+
return { type: 'hard_stop', reason: 'token_budget' }
|
|
39
|
+
}
|
|
40
40
|
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
41
|
+
if (config.costLimitUsd && config.costLimitUsd > 0 && state.totalCost >= config.costLimitUsd) {
|
|
42
|
+
return { type: 'hard_stop', reason: 'cost_limit' }
|
|
43
|
+
}
|
|
44
44
|
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
45
|
+
if (state.currentIteration >= config.maxIterations) {
|
|
46
|
+
return { type: 'hard_stop', reason: 'max_iterations' }
|
|
47
|
+
}
|
|
48
48
|
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
49
|
+
if (config.tokenBudget > 0) {
|
|
50
|
+
const usageRatio = state.totalTokens / config.tokenBudget
|
|
51
|
+
if (usageRatio >= config.budgetWarningThreshold) {
|
|
52
|
+
return { type: 'warning', reason: 'token_budget' }
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
55
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
56
|
+
if (config.costLimitUsd && config.costLimitUsd > 0) {
|
|
57
|
+
const costRatio = state.totalCost / config.costLimitUsd
|
|
58
|
+
if (costRatio >= config.budgetWarningThreshold) {
|
|
59
|
+
return { type: 'warning', reason: 'cost_limit' }
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
62
|
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
63
|
+
const timeElapsed = Date.now() - state.startTime
|
|
64
|
+
const timeRatio = timeElapsed / config.timeoutMs
|
|
65
|
+
if (timeRatio >= config.budgetWarningThreshold) {
|
|
66
|
+
return { type: 'warning', reason: 'timeout' }
|
|
67
|
+
}
|
|
68
68
|
|
|
69
|
-
|
|
69
|
+
return { type: 'ok' }
|
|
70
70
|
}
|
|
71
71
|
|
|
72
72
|
export function buildLimitConfig(
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
73
|
+
tokenBudget: number,
|
|
74
|
+
timeoutMs: number,
|
|
75
|
+
costLimitUsd?: number,
|
|
76
|
+
maxIterations?: number,
|
|
77
|
+
budgetWarningThreshold?: number,
|
|
78
78
|
): LimitCheckerConfig {
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
79
|
+
return {
|
|
80
|
+
tokenBudget,
|
|
81
|
+
timeoutMs,
|
|
82
|
+
costLimitUsd,
|
|
83
|
+
maxIterations: maxIterations ?? 200,
|
|
84
|
+
budgetWarningThreshold: budgetWarningThreshold ?? 0.9,
|
|
85
|
+
}
|
|
86
86
|
}
|