@namzu/sdk 0.1.1 → 0.1.3
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 +6 -0
- 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 +21 -6
- 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
package/src/store/task/disk.ts
CHANGED
|
@@ -1,333 +1,337 @@
|
|
|
1
1
|
import { mkdir, readFile, readdir, rename, unlink, writeFile } from 'node:fs/promises'
|
|
2
2
|
import { join } from 'node:path'
|
|
3
|
-
import type {
|
|
3
|
+
import type { RunId, TaskId, TenantId } from '../../types/ids/index.js'
|
|
4
4
|
import type {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
5
|
+
CreateTaskParams,
|
|
6
|
+
Task,
|
|
7
|
+
TaskEvent,
|
|
8
|
+
TaskEventListener,
|
|
9
|
+
TaskStatus,
|
|
10
|
+
TaskStore,
|
|
11
|
+
UpdateTaskParams,
|
|
12
12
|
} from '../../types/task/index.js'
|
|
13
13
|
import { generateTaskId } from '../../utils/id.js'
|
|
14
|
-
import {
|
|
14
|
+
import { type Logger, getRootLogger } from '../../utils/logger.js'
|
|
15
15
|
|
|
16
16
|
export interface DiskTaskStoreConfig {
|
|
17
|
-
|
|
17
|
+
baseDir: string
|
|
18
18
|
|
|
19
|
-
|
|
19
|
+
defaultRunId: RunId
|
|
20
20
|
|
|
21
|
-
|
|
21
|
+
tenantId?: TenantId
|
|
22
22
|
|
|
23
|
-
|
|
23
|
+
logger?: Logger
|
|
24
24
|
}
|
|
25
25
|
|
|
26
26
|
const STATUS_ORDER: Record<TaskStatus, number> = {
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
27
|
+
pending: 0,
|
|
28
|
+
in_progress: 1,
|
|
29
|
+
completed: 2,
|
|
30
30
|
}
|
|
31
31
|
|
|
32
32
|
function isForwardTransition(from: TaskStatus, to: TaskStatus): boolean {
|
|
33
|
-
|
|
33
|
+
return STATUS_ORDER[to] > STATUS_ORDER[from]
|
|
34
34
|
}
|
|
35
35
|
|
|
36
36
|
export class DiskTaskStore implements TaskStore {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
37
|
+
private baseDir: string
|
|
38
|
+
private defaultRunId: RunId
|
|
39
|
+
private tenantId?: TenantId
|
|
40
|
+
private log: Logger
|
|
41
|
+
private listeners: TaskEventListener[] = []
|
|
42
|
+
|
|
43
|
+
private locks = new Map<TaskId, Promise<void>>()
|
|
44
|
+
|
|
45
|
+
constructor(config: DiskTaskStoreConfig) {
|
|
46
|
+
this.baseDir = config.baseDir
|
|
47
|
+
this.defaultRunId = config.defaultRunId
|
|
48
|
+
this.tenantId = config.tenantId
|
|
49
|
+
this.log = (config.logger ?? getRootLogger()).child({ component: 'DiskTaskStore' })
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
private taskDir(runId: RunId): string {
|
|
53
|
+
if (this.tenantId) {
|
|
54
|
+
return join(this.baseDir, 'tenants', this.tenantId, 'tasks', runId)
|
|
55
|
+
}
|
|
56
|
+
return join(this.baseDir, 'tasks', runId)
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
private taskPath(runId: RunId, taskId: TaskId): string {
|
|
60
|
+
return join(this.taskDir(runId), `${taskId}.json`)
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
private async withLock<T>(taskId: TaskId, fn: () => Promise<T>): Promise<T> {
|
|
64
|
+
const existing = this.locks.get(taskId)
|
|
65
|
+
if (existing) {
|
|
66
|
+
await existing.catch(() => undefined)
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
let resolve!: () => void
|
|
70
|
+
const lock = new Promise<void>((r) => {
|
|
71
|
+
resolve = r
|
|
72
|
+
})
|
|
73
|
+
this.locks.set(taskId, lock)
|
|
74
|
+
|
|
75
|
+
try {
|
|
76
|
+
return await fn()
|
|
77
|
+
} finally {
|
|
78
|
+
resolve?.()
|
|
79
|
+
if (this.locks.get(taskId) === lock) {
|
|
80
|
+
this.locks.delete(taskId)
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
on(listener: TaskEventListener): () => void {
|
|
86
|
+
this.listeners.push(listener)
|
|
87
|
+
return () => {
|
|
88
|
+
this.listeners = this.listeners.filter((l) => l !== listener)
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
private emit(event: TaskEvent): void {
|
|
93
|
+
for (const listener of this.listeners) {
|
|
94
|
+
try {
|
|
95
|
+
listener(event)
|
|
96
|
+
} catch {}
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
async create(params: CreateTaskParams): Promise<Task> {
|
|
101
|
+
const taskId = generateTaskId()
|
|
102
|
+
const runId = params.runId ?? this.defaultRunId
|
|
103
|
+
|
|
104
|
+
const task: Task = {
|
|
105
|
+
id: taskId,
|
|
106
|
+
runId,
|
|
107
|
+
tenantId: params.tenantId ?? this.tenantId,
|
|
108
|
+
subject: params.subject,
|
|
109
|
+
description: params.description,
|
|
110
|
+
activeForm: params.activeForm,
|
|
111
|
+
status: 'pending',
|
|
112
|
+
owner: params.owner,
|
|
113
|
+
blocks: [],
|
|
114
|
+
blockedBy: params.blockedBy ? [...params.blockedBy] : [],
|
|
115
|
+
metadata: params.metadata ? { ...params.metadata } : undefined,
|
|
116
|
+
createdAt: Date.now(),
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
const dir = this.taskDir(runId)
|
|
120
|
+
await mkdir(dir, { recursive: true })
|
|
121
|
+
await atomicWriteJson(this.taskPath(runId, taskId), task)
|
|
122
|
+
|
|
123
|
+
if (params.blockedBy) {
|
|
124
|
+
for (const blockerId of params.blockedBy) {
|
|
125
|
+
await this.withLock(blockerId, async () => {
|
|
126
|
+
const blocker = await this.readTask(runId, blockerId)
|
|
127
|
+
if (blocker && !blocker.blocks.includes(taskId)) {
|
|
128
|
+
blocker.blocks.push(taskId)
|
|
129
|
+
await atomicWriteJson(this.taskPath(runId, blockerId), blocker)
|
|
130
|
+
}
|
|
131
|
+
})
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
this.log.info('Task created', { taskId, subject: params.subject, runId })
|
|
136
|
+
this.emit({ type: 'task.created', taskId, task, timestamp: Date.now() })
|
|
137
|
+
return task
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
async get(id: TaskId): Promise<Task | undefined> {
|
|
141
|
+
return this.findTask(id)
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
async update(id: TaskId, updates: UpdateTaskParams): Promise<Task | undefined> {
|
|
145
|
+
const found = await this.findTask(id)
|
|
146
|
+
if (!found) return undefined
|
|
147
|
+
|
|
148
|
+
return this.withLock(id, async () => {
|
|
149
|
+
const task = await this.readTask(found.runId, id)
|
|
150
|
+
if (!task) return undefined
|
|
151
|
+
|
|
152
|
+
const previousStatus = task.status
|
|
153
|
+
|
|
154
|
+
if (updates.subject !== undefined) task.subject = updates.subject
|
|
155
|
+
if (updates.description !== undefined) task.description = updates.description
|
|
156
|
+
if (updates.activeForm !== undefined) task.activeForm = updates.activeForm
|
|
157
|
+
if (updates.owner !== undefined) task.owner = updates.owner
|
|
158
|
+
if (updates.metadata !== undefined) {
|
|
159
|
+
task.metadata = task.metadata
|
|
160
|
+
? { ...task.metadata, ...updates.metadata }
|
|
161
|
+
: { ...updates.metadata }
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
if (
|
|
165
|
+
updates.status !== undefined &&
|
|
166
|
+
updates.status !== previousStatus &&
|
|
167
|
+
isForwardTransition(previousStatus, updates.status)
|
|
168
|
+
) {
|
|
169
|
+
task.status = updates.status
|
|
170
|
+
if (updates.status === 'in_progress' && !task.startedAt) {
|
|
171
|
+
task.startedAt = Date.now()
|
|
172
|
+
}
|
|
173
|
+
if (updates.status === 'completed') {
|
|
174
|
+
task.completedAt = Date.now()
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
await atomicWriteJson(this.taskPath(task.runId, id), task)
|
|
179
|
+
this.emit({ type: 'task.updated', taskId: id, task, previousStatus, timestamp: Date.now() })
|
|
180
|
+
return task
|
|
181
|
+
})
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
async delete(id: TaskId): Promise<boolean> {
|
|
185
|
+
const found = await this.findTask(id)
|
|
186
|
+
if (!found) return false
|
|
187
|
+
|
|
188
|
+
return this.withLock(id, async () => {
|
|
189
|
+
const task = await this.readTask(found.runId, id)
|
|
190
|
+
if (!task) return false
|
|
191
|
+
|
|
192
|
+
for (const blockerId of task.blockedBy) {
|
|
193
|
+
await this.withLock(blockerId, async () => {
|
|
194
|
+
const blocker = await this.readTask(task.runId, blockerId)
|
|
195
|
+
if (blocker) {
|
|
196
|
+
blocker.blocks = blocker.blocks.filter((bid) => bid !== id)
|
|
197
|
+
await atomicWriteJson(this.taskPath(task.runId, blockerId), blocker)
|
|
198
|
+
}
|
|
199
|
+
})
|
|
200
|
+
}
|
|
201
|
+
for (const blockedId of task.blocks) {
|
|
202
|
+
await this.withLock(blockedId, async () => {
|
|
203
|
+
const blocked = await this.readTask(task.runId, blockedId)
|
|
204
|
+
if (blocked) {
|
|
205
|
+
blocked.blockedBy = blocked.blockedBy.filter((bid) => bid !== id)
|
|
206
|
+
await atomicWriteJson(this.taskPath(task.runId, blockedId), blocked)
|
|
207
|
+
}
|
|
208
|
+
})
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
await unlink(this.taskPath(task.runId, id)).catch(() => undefined)
|
|
212
|
+
this.log.info('Task deleted', { taskId: id })
|
|
213
|
+
this.emit({ type: 'task.deleted', taskId: id, task, timestamp: Date.now() })
|
|
214
|
+
return true
|
|
215
|
+
})
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
async list(filter?: { status?: TaskStatus; owner?: string; runId?: RunId }): Promise<Task[]> {
|
|
219
|
+
const runId = filter?.runId ?? this.defaultRunId
|
|
220
|
+
const dir = this.taskDir(runId)
|
|
221
|
+
|
|
222
|
+
let files: string[]
|
|
223
|
+
try {
|
|
224
|
+
files = await readdir(dir)
|
|
225
|
+
} catch {
|
|
226
|
+
return []
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
const tasks: Task[] = []
|
|
230
|
+
for (const file of files) {
|
|
231
|
+
if (!file.endsWith('.json')) continue
|
|
232
|
+
try {
|
|
233
|
+
const raw = await readFile(join(dir, file), 'utf-8')
|
|
234
|
+
const task = JSON.parse(raw) as Task
|
|
235
|
+
tasks.push(task)
|
|
236
|
+
} catch {
|
|
237
|
+
this.log.warn('Failed to read task file', { file })
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
let results = tasks
|
|
242
|
+
if (filter?.status) {
|
|
243
|
+
results = results.filter((t) => t.status === filter.status)
|
|
244
|
+
}
|
|
245
|
+
if (filter?.owner) {
|
|
246
|
+
results = results.filter((t) => t.owner === filter.owner)
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
return results.sort((a, b) => a.createdAt - b.createdAt)
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
async claim(id: TaskId, owner: string): Promise<Task | undefined> {
|
|
253
|
+
const found = await this.findTask(id)
|
|
254
|
+
if (!found) return undefined
|
|
255
|
+
|
|
256
|
+
return this.withLock(id, async () => {
|
|
257
|
+
const task = await this.readTask(found.runId, id)
|
|
258
|
+
if (!task) return undefined
|
|
259
|
+
if (task.status !== 'pending') return undefined
|
|
260
|
+
if (task.owner !== undefined) return undefined
|
|
261
|
+
|
|
262
|
+
task.owner = owner
|
|
263
|
+
task.status = 'in_progress'
|
|
264
|
+
task.startedAt = Date.now()
|
|
265
|
+
|
|
266
|
+
await atomicWriteJson(this.taskPath(task.runId, id), task)
|
|
267
|
+
this.emit({ type: 'task.claimed', taskId: id, task, timestamp: Date.now() })
|
|
268
|
+
return task
|
|
269
|
+
})
|
|
270
|
+
}
|
|
271
|
+
|
|
272
|
+
async block(blockerId: TaskId, blockedId: TaskId): Promise<void> {
|
|
273
|
+
const blockerFound = await this.findTask(blockerId)
|
|
274
|
+
const blockedFound = await this.findTask(blockedId)
|
|
275
|
+
if (!blockerFound || !blockedFound) return
|
|
276
|
+
|
|
277
|
+
await this.withLock(blockerId, async () => {
|
|
278
|
+
const blocker = await this.readTask(blockerFound.runId, blockerId)
|
|
279
|
+
if (blocker && !blocker.blocks.includes(blockedId)) {
|
|
280
|
+
blocker.blocks.push(blockedId)
|
|
281
|
+
await atomicWriteJson(this.taskPath(blocker.runId, blockerId), blocker)
|
|
282
|
+
}
|
|
283
|
+
})
|
|
284
|
+
|
|
285
|
+
await this.withLock(blockedId, async () => {
|
|
286
|
+
const blocked = await this.readTask(blockedFound.runId, blockedId)
|
|
287
|
+
if (blocked && !blocked.blockedBy.includes(blockerId)) {
|
|
288
|
+
blocked.blockedBy.push(blockerId)
|
|
289
|
+
await atomicWriteJson(this.taskPath(blocked.runId, blockedId), blocked)
|
|
290
|
+
}
|
|
291
|
+
})
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
async reset(): Promise<void> {
|
|
295
|
+
const dir = this.taskDir(this.defaultRunId)
|
|
296
|
+
let files: string[]
|
|
297
|
+
try {
|
|
298
|
+
files = await readdir(dir)
|
|
299
|
+
} catch {
|
|
300
|
+
return
|
|
301
|
+
}
|
|
302
|
+
for (const file of files) {
|
|
303
|
+
if (file.endsWith('.json')) {
|
|
304
|
+
await unlink(join(dir, file)).catch(() => undefined)
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
|
|
309
|
+
private async readTask(runId: RunId, taskId: TaskId): Promise<Task | null> {
|
|
310
|
+
try {
|
|
311
|
+
const raw = await readFile(this.taskPath(runId, taskId), 'utf-8')
|
|
312
|
+
return JSON.parse(raw) as Task
|
|
313
|
+
} catch {
|
|
314
|
+
return null
|
|
315
|
+
}
|
|
316
|
+
}
|
|
317
|
+
|
|
318
|
+
private async findTask(id: TaskId): Promise<Task | undefined> {
|
|
319
|
+
const task = await this.readTask(this.defaultRunId, id)
|
|
320
|
+
return task ?? undefined
|
|
321
|
+
}
|
|
318
322
|
}
|
|
319
323
|
|
|
320
324
|
async function atomicWriteFile(filePath: string, content: string): Promise<void> {
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
325
|
+
const tempPath = `${filePath}.tmp`
|
|
326
|
+
try {
|
|
327
|
+
await writeFile(tempPath, content, 'utf-8')
|
|
328
|
+
await rename(tempPath, filePath)
|
|
329
|
+
} catch (err) {
|
|
330
|
+
await unlink(tempPath).catch(() => undefined)
|
|
331
|
+
throw err
|
|
332
|
+
}
|
|
329
333
|
}
|
|
330
334
|
|
|
331
335
|
async function atomicWriteJson(filePath: string, value: unknown): Promise<void> {
|
|
332
|
-
|
|
336
|
+
await atomicWriteFile(filePath, JSON.stringify(value, null, 2))
|
|
333
337
|
}
|