takt 0.45.0 → 0.47.0
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 +55 -2
- package/builtins/en/config.yaml +37 -12
- package/builtins/en/facets/instructions/findings-manager.md +13 -0
- package/builtins/en/facets/instructions/fix.md +9 -4
- package/builtins/en/facets/instructions/implement-maintenance.md +5 -32
- package/builtins/en/facets/instructions/implement.md +3 -2
- package/builtins/en/facets/instructions/loop-monitor-reviewers-fix.md +5 -1
- package/builtins/en/facets/instructions/plan-test.md +4 -3
- package/builtins/en/facets/instructions/review-arch.md +1 -1
- package/builtins/en/facets/instructions/review-coding.md +11 -5
- package/builtins/en/facets/instructions/review-cqrs-es.md +1 -1
- package/builtins/en/facets/instructions/review-pure.md +9 -0
- package/builtins/en/facets/instructions/review-qa.md +2 -0
- package/builtins/en/facets/instructions/review-terraform.md +1 -1
- package/builtins/en/facets/instructions/review-test.md +3 -0
- package/builtins/en/facets/instructions/supervise-maintenance.md +7 -77
- package/builtins/en/facets/instructions/supervise.md +12 -65
- package/builtins/en/facets/instructions/write-tests-first.md +1 -0
- package/builtins/en/facets/instructions/write-tests-maintenance.md +1 -0
- package/builtins/en/facets/knowledge/architecture.md +31 -0
- package/builtins/en/facets/knowledge/backend.md +25 -1
- package/builtins/en/facets/knowledge/cqrs-es.md +57 -0
- package/builtins/en/facets/knowledge/e2e-testing.md +11 -1
- package/builtins/en/facets/knowledge/unit-testing.md +11 -0
- package/builtins/en/facets/output-contracts/ai-antipattern-review-finding-contract.md +31 -0
- package/builtins/en/facets/output-contracts/architecture-review-finding-contract.md +35 -0
- package/builtins/en/facets/output-contracts/coding-review-finding-contract.md +25 -0
- package/builtins/en/facets/output-contracts/coding-review.md +11 -4
- package/builtins/en/facets/output-contracts/cqrs-es-review-finding-contract.md +31 -0
- package/builtins/en/facets/output-contracts/findings-manager.md +45 -0
- package/builtins/en/facets/output-contracts/frontend-review-finding-contract.md +30 -0
- package/builtins/en/facets/output-contracts/maintenance-scope.md +5 -0
- package/builtins/en/facets/output-contracts/pure-review-finding-contract.md +45 -0
- package/builtins/en/facets/output-contracts/pure-review.md +61 -0
- package/builtins/en/facets/output-contracts/qa-review-finding-contract.md +35 -0
- package/builtins/en/facets/output-contracts/qa-review.md +15 -3
- package/builtins/en/facets/output-contracts/security-review-finding-contract.md +36 -0
- package/builtins/en/facets/output-contracts/supervisor-validation.md +35 -11
- package/builtins/en/facets/output-contracts/terraform-review-finding-contract.md +31 -0
- package/builtins/en/facets/output-contracts/testing-review-finding-contract.md +41 -0
- package/builtins/en/facets/output-contracts/testing-review.md +6 -1
- package/builtins/en/facets/personas/ai-antipattern-reviewer.md +2 -2
- package/builtins/en/facets/personas/architecture-reviewer.md +1 -1
- package/builtins/en/facets/personas/findings-manager.md +18 -0
- package/builtins/en/facets/personas/pr-commenter.md +2 -2
- package/builtins/en/facets/personas/pure-reviewer.md +22 -0
- package/builtins/en/facets/personas/supervisor.md +1 -1
- package/builtins/en/facets/personas/terraform-reviewer.md +3 -3
- package/builtins/en/facets/policies/ai-antipattern.md +33 -0
- package/builtins/en/facets/policies/coding.md +36 -0
- package/builtins/en/facets/policies/review.md +90 -17
- package/builtins/en/facets/policies/testing.md +49 -0
- package/builtins/en/provider-options/edit.yaml +21 -0
- package/builtins/en/provider-options/review-files.yaml +10 -0
- package/builtins/en/provider-options/review-readonly.yaml +16 -0
- package/builtins/en/provider-options/review-web.yaml +14 -0
- package/builtins/en/workflow-categories.yaml +1 -0
- package/builtins/en/workflows/audit-architecture-backend.yaml +8 -0
- package/builtins/en/workflows/audit-architecture-dual.yaml +8 -0
- package/builtins/en/workflows/audit-architecture-frontend.yaml +8 -0
- package/builtins/en/workflows/audit-architecture.yaml +8 -0
- package/builtins/en/workflows/audit-e2e.yaml +8 -0
- package/builtins/en/workflows/audit-security.yaml +8 -0
- package/builtins/en/workflows/audit-unit.yaml +8 -0
- package/builtins/en/workflows/auto-improvement-loop.yaml +6 -0
- package/builtins/en/workflows/backend-cqrs-mini.yaml +20 -0
- package/builtins/en/workflows/backend-cqrs.yaml +60 -1
- package/builtins/en/workflows/backend-mini.yaml +20 -0
- package/builtins/en/workflows/backend.yaml +60 -1
- package/builtins/en/workflows/compound-eye.yaml +8 -0
- package/builtins/en/workflows/deep-research.yaml +8 -0
- package/builtins/en/workflows/default-draft.yaml +6 -0
- package/builtins/en/workflows/default-high.yaml +7 -1
- package/builtins/en/workflows/default-mini.yaml +2 -0
- package/builtins/en/workflows/default-peer-review.yaml +41 -4
- package/builtins/en/workflows/default.yaml +4 -0
- package/builtins/en/workflows/draft.yaml +12 -32
- package/builtins/en/workflows/dual-cqrs-mini.yaml +20 -0
- package/builtins/en/workflows/dual-cqrs.yaml +56 -1
- package/builtins/en/workflows/dual-mini.yaml +20 -0
- package/builtins/en/workflows/dual.yaml +44 -6
- package/builtins/en/workflows/frontend-maintenance.yaml +62 -1
- package/builtins/en/workflows/frontend-mini.yaml +20 -0
- package/builtins/en/workflows/frontend.yaml +62 -1
- package/builtins/en/workflows/magi.yaml +6 -0
- package/builtins/en/workflows/peer-review-with-fc.yaml +206 -0
- package/builtins/en/workflows/peer-review.yaml +35 -72
- package/builtins/en/workflows/research.yaml +6 -0
- package/builtins/en/workflows/review-backend-cqrs.yaml +42 -1
- package/builtins/en/workflows/review-backend.yaml +40 -1
- package/builtins/en/workflows/review-default.yaml +27 -7
- package/builtins/en/workflows/review-dual-cqrs.yaml +44 -1
- package/builtins/en/workflows/review-dual.yaml +42 -1
- package/builtins/en/workflows/review-fix-backend-cqrs.yaml +46 -1
- package/builtins/en/workflows/review-fix-backend.yaml +44 -1
- package/builtins/en/workflows/review-fix-default.yaml +31 -7
- package/builtins/en/workflows/review-fix-dual-cqrs.yaml +48 -1
- package/builtins/en/workflows/review-fix-dual.yaml +46 -1
- package/builtins/en/workflows/review-fix-frontend.yaml +46 -1
- package/builtins/en/workflows/review-fix-takt-default.yaml +38 -6
- package/builtins/en/workflows/review-frontend.yaml +42 -1
- package/builtins/en/workflows/review-takt-default.yaml +29 -7
- package/builtins/en/workflows/takt-default-refresh-all.yaml +36 -6
- package/builtins/en/workflows/takt-default-refresh-fast.yaml +35 -5
- package/builtins/en/workflows/takt-default-with-fc.yaml +110 -0
- package/builtins/en/workflows/takt-default.yaml +10 -27
- package/builtins/en/workflows/terraform.yaml +52 -3
- package/builtins/ja/config.yaml +37 -12
- package/builtins/ja/facets/instructions/findings-manager.md +13 -0
- package/builtins/ja/facets/instructions/fix.md +9 -4
- package/builtins/ja/facets/instructions/implement-maintenance.md +5 -32
- package/builtins/ja/facets/instructions/implement.md +3 -2
- package/builtins/ja/facets/instructions/loop-monitor-reviewers-fix.md +5 -1
- package/builtins/ja/facets/instructions/plan-test.md +4 -3
- package/builtins/ja/facets/instructions/review-arch.md +1 -1
- package/builtins/ja/facets/instructions/review-coding.md +11 -5
- package/builtins/ja/facets/instructions/review-cqrs-es.md +1 -1
- package/builtins/ja/facets/instructions/review-pure.md +9 -0
- package/builtins/ja/facets/instructions/review-qa.md +2 -0
- package/builtins/ja/facets/instructions/review-terraform.md +1 -1
- package/builtins/ja/facets/instructions/review-test.md +3 -0
- package/builtins/ja/facets/instructions/supervise-maintenance.md +7 -77
- package/builtins/ja/facets/instructions/supervise.md +12 -66
- package/builtins/ja/facets/instructions/write-tests-first.md +1 -0
- package/builtins/ja/facets/instructions/write-tests-maintenance.md +1 -0
- package/builtins/ja/facets/knowledge/architecture.md +31 -0
- package/builtins/ja/facets/knowledge/backend.md +25 -1
- package/builtins/ja/facets/knowledge/cqrs-es.md +31 -0
- package/builtins/ja/facets/knowledge/e2e-testing.md +11 -1
- package/builtins/ja/facets/knowledge/unit-testing.md +11 -0
- package/builtins/ja/facets/output-contracts/ai-antipattern-review-finding-contract.md +31 -0
- package/builtins/ja/facets/output-contracts/architecture-review-finding-contract.md +35 -0
- package/builtins/ja/facets/output-contracts/coding-review-finding-contract.md +25 -0
- package/builtins/ja/facets/output-contracts/coding-review.md +11 -4
- package/builtins/ja/facets/output-contracts/cqrs-es-review-finding-contract.md +31 -0
- package/builtins/ja/facets/output-contracts/findings-manager.md +45 -0
- package/builtins/ja/facets/output-contracts/frontend-review-finding-contract.md +30 -0
- package/builtins/ja/facets/output-contracts/maintenance-scope.md +5 -0
- package/builtins/ja/facets/output-contracts/pure-review-finding-contract.md +45 -0
- package/builtins/ja/facets/output-contracts/pure-review.md +61 -0
- package/builtins/ja/facets/output-contracts/qa-review-finding-contract.md +35 -0
- package/builtins/ja/facets/output-contracts/qa-review.md +15 -3
- package/builtins/ja/facets/output-contracts/security-review-finding-contract.md +36 -0
- package/builtins/ja/facets/output-contracts/supervisor-validation.md +35 -11
- package/builtins/ja/facets/output-contracts/terraform-review-finding-contract.md +31 -0
- package/builtins/ja/facets/output-contracts/testing-review-finding-contract.md +41 -0
- package/builtins/ja/facets/output-contracts/testing-review.md +6 -1
- package/builtins/ja/facets/personas/ai-antipattern-reviewer.md +2 -2
- package/builtins/ja/facets/personas/architecture-reviewer.md +2 -2
- package/builtins/ja/facets/personas/findings-manager.md +18 -0
- package/builtins/ja/facets/personas/pr-commenter.md +3 -3
- package/builtins/ja/facets/personas/pure-reviewer.md +22 -0
- package/builtins/ja/facets/personas/supervisor.md +1 -1
- package/builtins/ja/facets/personas/terraform-reviewer.md +3 -3
- package/builtins/ja/facets/policies/ai-antipattern.md +17 -0
- package/builtins/ja/facets/policies/coding.md +36 -0
- package/builtins/ja/facets/policies/review.md +88 -17
- package/builtins/ja/facets/policies/testing.md +49 -0
- package/builtins/ja/provider-options/edit.yaml +21 -0
- package/builtins/ja/provider-options/review-files.yaml +10 -0
- package/builtins/ja/provider-options/review-readonly.yaml +16 -0
- package/builtins/ja/provider-options/review-web.yaml +14 -0
- package/builtins/ja/workflow-categories.yaml +1 -0
- package/builtins/ja/workflows/audit-architecture-backend.yaml +8 -0
- package/builtins/ja/workflows/audit-architecture-dual.yaml +8 -0
- package/builtins/ja/workflows/audit-architecture-frontend.yaml +8 -0
- package/builtins/ja/workflows/audit-architecture.yaml +8 -0
- package/builtins/ja/workflows/audit-e2e.yaml +8 -0
- package/builtins/ja/workflows/audit-security.yaml +8 -0
- package/builtins/ja/workflows/audit-unit.yaml +8 -0
- package/builtins/ja/workflows/auto-improvement-loop.yaml +6 -0
- package/builtins/ja/workflows/backend-cqrs-mini.yaml +20 -0
- package/builtins/ja/workflows/backend-cqrs.yaml +60 -1
- package/builtins/ja/workflows/backend-mini.yaml +20 -0
- package/builtins/ja/workflows/backend.yaml +60 -1
- package/builtins/ja/workflows/compound-eye.yaml +8 -0
- package/builtins/ja/workflows/deep-research.yaml +8 -0
- package/builtins/ja/workflows/default-draft.yaml +6 -0
- package/builtins/ja/workflows/default-high.yaml +7 -1
- package/builtins/ja/workflows/default-mini.yaml +2 -0
- package/builtins/ja/workflows/default-peer-review.yaml +41 -4
- package/builtins/ja/workflows/default.yaml +4 -0
- package/builtins/ja/workflows/draft.yaml +12 -32
- package/builtins/ja/workflows/dual-cqrs-mini.yaml +20 -0
- package/builtins/ja/workflows/dual-cqrs.yaml +56 -1
- package/builtins/ja/workflows/dual-mini.yaml +20 -0
- package/builtins/ja/workflows/dual.yaml +44 -6
- package/builtins/ja/workflows/frontend-maintenance.yaml +62 -1
- package/builtins/ja/workflows/frontend-mini.yaml +20 -0
- package/builtins/ja/workflows/frontend.yaml +62 -1
- package/builtins/ja/workflows/magi.yaml +6 -0
- package/builtins/ja/workflows/peer-review-with-fc.yaml +206 -0
- package/builtins/ja/workflows/peer-review.yaml +35 -72
- package/builtins/ja/workflows/research.yaml +6 -0
- package/builtins/ja/workflows/review-backend-cqrs.yaml +42 -1
- package/builtins/ja/workflows/review-backend.yaml +40 -1
- package/builtins/ja/workflows/review-default.yaml +28 -8
- package/builtins/ja/workflows/review-dual-cqrs.yaml +44 -1
- package/builtins/ja/workflows/review-dual.yaml +42 -1
- package/builtins/ja/workflows/review-fix-backend-cqrs.yaml +46 -1
- package/builtins/ja/workflows/review-fix-backend.yaml +44 -1
- package/builtins/ja/workflows/review-fix-default.yaml +31 -7
- package/builtins/ja/workflows/review-fix-dual-cqrs.yaml +48 -1
- package/builtins/ja/workflows/review-fix-dual.yaml +46 -1
- package/builtins/ja/workflows/review-fix-frontend.yaml +46 -1
- package/builtins/ja/workflows/review-fix-takt-default.yaml +39 -7
- package/builtins/ja/workflows/review-frontend.yaml +42 -1
- package/builtins/ja/workflows/review-takt-default.yaml +30 -8
- package/builtins/ja/workflows/takt-default-refresh-all.yaml +36 -6
- package/builtins/ja/workflows/takt-default-refresh-fast.yaml +35 -5
- package/builtins/ja/workflows/takt-default-with-fc.yaml +110 -0
- package/builtins/ja/workflows/takt-default.yaml +10 -27
- package/builtins/ja/workflows/terraform.yaml +51 -2
- package/builtins/skill/references/yaml-schema.md +4 -0
- package/builtins/skill-codex/references/yaml-schema.md +4 -0
- package/dist/agents/decompose-task-usecase.d.ts +2 -1
- package/dist/agents/decompose-task-usecase.d.ts.map +1 -1
- package/dist/agents/decompose-task-usecase.js +7 -5
- package/dist/agents/decompose-task-usecase.js.map +1 -1
- package/dist/agents/judge-status-usecase.d.ts +4 -1
- package/dist/agents/judge-status-usecase.d.ts.map +1 -1
- package/dist/agents/judge-status-usecase.js +5 -0
- package/dist/agents/judge-status-usecase.js.map +1 -1
- package/dist/agents/runner-prompt.d.ts +3 -1
- package/dist/agents/runner-prompt.d.ts.map +1 -1
- package/dist/agents/runner-prompt.js +11 -4
- package/dist/agents/runner-prompt.js.map +1 -1
- package/dist/agents/runner.d.ts.map +1 -1
- package/dist/agents/runner.js +23 -5
- package/dist/agents/runner.js.map +1 -1
- package/dist/agents/structured-caller/capability-aware-structured-caller.d.ts +1 -1
- package/dist/agents/structured-caller/capability-aware-structured-caller.d.ts.map +1 -1
- package/dist/agents/structured-caller/capability-aware-structured-caller.js +3 -3
- package/dist/agents/structured-caller/capability-aware-structured-caller.js.map +1 -1
- package/dist/agents/structured-caller/contracts.d.ts +1 -1
- package/dist/agents/structured-caller/contracts.d.ts.map +1 -1
- package/dist/agents/structured-caller/default-structured-caller.d.ts +1 -1
- package/dist/agents/structured-caller/default-structured-caller.d.ts.map +1 -1
- package/dist/agents/structured-caller/default-structured-caller.js +2 -2
- package/dist/agents/structured-caller/default-structured-caller.js.map +1 -1
- package/dist/agents/structured-caller/prompt-based-structured-caller.d.ts +1 -1
- package/dist/agents/structured-caller/prompt-based-structured-caller.d.ts.map +1 -1
- package/dist/agents/structured-caller/prompt-based-structured-caller.js +9 -3
- package/dist/agents/structured-caller/prompt-based-structured-caller.js.map +1 -1
- package/dist/agents/team-leader-structured-output.d.ts +3 -3
- package/dist/agents/team-leader-structured-output.d.ts.map +1 -1
- package/dist/agents/team-leader-structured-output.js +14 -10
- package/dist/agents/team-leader-structured-output.js.map +1 -1
- package/dist/agents/types.d.ts +1 -0
- package/dist/agents/types.d.ts.map +1 -1
- package/dist/app/cli/routing-inputs.d.ts +1 -0
- package/dist/app/cli/routing-inputs.d.ts.map +1 -1
- package/dist/app/cli/routing-inputs.js +5 -2
- package/dist/app/cli/routing-inputs.js.map +1 -1
- package/dist/app/cli/routing.d.ts.map +1 -1
- package/dist/app/cli/routing.js +14 -0
- package/dist/app/cli/routing.js.map +1 -1
- package/dist/commands/repertoire/add.d.ts.map +1 -1
- package/dist/commands/repertoire/add.js +45 -4
- package/dist/commands/repertoire/add.js.map +1 -1
- package/dist/commands/repertoire/remove.d.ts.map +1 -1
- package/dist/commands/repertoire/remove.js +19 -3
- package/dist/commands/repertoire/remove.js.map +1 -1
- package/dist/core/models/config-schemas.d.ts +787 -0
- package/dist/core/models/config-schemas.d.ts.map +1 -1
- package/dist/core/models/config-schemas.js +6 -0
- package/dist/core/models/config-schemas.js.map +1 -1
- package/dist/core/models/config-types.d.ts +8 -0
- package/dist/core/models/config-types.d.ts.map +1 -1
- package/dist/core/models/finding-schemas.d.ts +447 -0
- package/dist/core/models/finding-schemas.d.ts.map +1 -0
- package/dist/core/models/finding-schemas.js +234 -0
- package/dist/core/models/finding-schemas.js.map +1 -0
- package/dist/core/models/finding-types.d.ts +146 -0
- package/dist/core/models/finding-types.d.ts.map +1 -0
- package/dist/core/models/finding-types.js +5 -0
- package/dist/core/models/finding-types.js.map +1 -0
- package/dist/core/models/index.d.ts +1 -1
- package/dist/core/models/index.d.ts.map +1 -1
- package/dist/core/models/index.js.map +1 -1
- package/dist/core/models/part.d.ts +2 -1
- package/dist/core/models/part.d.ts.map +1 -1
- package/dist/core/models/schema-base.d.ts +66 -0
- package/dist/core/models/schema-base.d.ts.map +1 -1
- package/dist/core/models/schema-base.js +7 -2
- package/dist/core/models/schema-base.js.map +1 -1
- package/dist/core/models/types.d.ts +2 -2
- package/dist/core/models/types.d.ts.map +1 -1
- package/dist/core/models/workflow-condition-expression.d.ts +3 -0
- package/dist/core/models/workflow-condition-expression.d.ts.map +1 -1
- package/dist/core/models/workflow-condition-expression.js +223 -4
- package/dist/core/models/workflow-condition-expression.js.map +1 -1
- package/dist/core/models/workflow-provider-options.d.ts +5 -0
- package/dist/core/models/workflow-provider-options.d.ts.map +1 -1
- package/dist/core/models/workflow-provider-options.js.map +1 -1
- package/dist/core/models/workflow-schemas.d.ts +197 -31
- package/dist/core/models/workflow-schemas.d.ts.map +1 -1
- package/dist/core/models/workflow-schemas.js +67 -18
- package/dist/core/models/workflow-schemas.js.map +1 -1
- package/dist/core/models/workflow-system-schemas.d.ts.map +1 -1
- package/dist/core/models/workflow-system-schemas.js +1 -0
- package/dist/core/models/workflow-system-schemas.js.map +1 -1
- package/dist/core/models/workflow-types.d.ts +14 -1
- package/dist/core/models/workflow-types.d.ts.map +1 -1
- package/dist/core/models/workflow-types.js.map +1 -1
- package/dist/core/workflow/engine/ArpeggioRunner.d.ts +2 -0
- package/dist/core/workflow/engine/ArpeggioRunner.d.ts.map +1 -1
- package/dist/core/workflow/engine/ArpeggioRunner.js +1 -0
- package/dist/core/workflow/engine/ArpeggioRunner.js.map +1 -1
- package/dist/core/workflow/engine/OptionsBuilder.d.ts +4 -1
- package/dist/core/workflow/engine/OptionsBuilder.d.ts.map +1 -1
- package/dist/core/workflow/engine/OptionsBuilder.js +23 -8
- package/dist/core/workflow/engine/OptionsBuilder.js.map +1 -1
- package/dist/core/workflow/engine/ParallelRunner.d.ts +15 -0
- package/dist/core/workflow/engine/ParallelRunner.d.ts.map +1 -1
- package/dist/core/workflow/engine/ParallelRunner.js +155 -18
- package/dist/core/workflow/engine/ParallelRunner.js.map +1 -1
- package/dist/core/workflow/engine/StepExecutor.d.ts +4 -2
- package/dist/core/workflow/engine/StepExecutor.d.ts.map +1 -1
- package/dist/core/workflow/engine/StepExecutor.js +11 -3
- package/dist/core/workflow/engine/StepExecutor.js.map +1 -1
- package/dist/core/workflow/engine/TeamLeaderRunner.d.ts.map +1 -1
- package/dist/core/workflow/engine/TeamLeaderRunner.js +9 -4
- package/dist/core/workflow/engine/TeamLeaderRunner.js.map +1 -1
- package/dist/core/workflow/engine/WorkflowCallExecutor.d.ts +3 -1
- package/dist/core/workflow/engine/WorkflowCallExecutor.d.ts.map +1 -1
- package/dist/core/workflow/engine/WorkflowCallExecutor.js +23 -5
- package/dist/core/workflow/engine/WorkflowCallExecutor.js.map +1 -1
- package/dist/core/workflow/engine/WorkflowCallRunner.d.ts +1 -0
- package/dist/core/workflow/engine/WorkflowCallRunner.d.ts.map +1 -1
- package/dist/core/workflow/engine/WorkflowCallRunner.js +5 -1
- package/dist/core/workflow/engine/WorkflowCallRunner.js.map +1 -1
- package/dist/core/workflow/engine/WorkflowEngine.d.ts +7 -1
- package/dist/core/workflow/engine/WorkflowEngine.d.ts.map +1 -1
- package/dist/core/workflow/engine/WorkflowEngine.js +63 -9
- package/dist/core/workflow/engine/WorkflowEngine.js.map +1 -1
- package/dist/core/workflow/engine/WorkflowEngineSetup.d.ts +3 -0
- package/dist/core/workflow/engine/WorkflowEngineSetup.d.ts.map +1 -1
- package/dist/core/workflow/engine/WorkflowEngineSetup.js +29 -1
- package/dist/core/workflow/engine/WorkflowEngineSetup.js.map +1 -1
- package/dist/core/workflow/engine/WorkflowRunLoop.d.ts +11 -7
- package/dist/core/workflow/engine/WorkflowRunLoop.d.ts.map +1 -1
- package/dist/core/workflow/engine/WorkflowRunLoop.js +66 -33
- package/dist/core/workflow/engine/WorkflowRunLoop.js.map +1 -1
- package/dist/core/workflow/engine/WorkflowValidator.d.ts.map +1 -1
- package/dist/core/workflow/engine/WorkflowValidator.js +78 -1
- package/dist/core/workflow/engine/WorkflowValidator.js.map +1 -1
- package/dist/core/workflow/engine/engine-provider-options.d.ts.map +1 -1
- package/dist/core/workflow/engine/engine-provider-options.js +3 -3
- package/dist/core/workflow/engine/engine-provider-options.js.map +1 -1
- package/dist/core/workflow/engine/parallel-logger.d.ts +1 -1
- package/dist/core/workflow/engine/parallel-logger.d.ts.map +1 -1
- package/dist/core/workflow/engine/parallel-logger.js +3 -1
- package/dist/core/workflow/engine/parallel-logger.js.map +1 -1
- package/dist/core/workflow/engine/task-decomposer.d.ts +1 -1
- package/dist/core/workflow/engine/task-decomposer.d.ts.map +1 -1
- package/dist/core/workflow/engine/task-decomposer.js +3 -3
- package/dist/core/workflow/engine/task-decomposer.js.map +1 -1
- package/dist/core/workflow/engine/team-leader-budget-errors.d.ts +2 -0
- package/dist/core/workflow/engine/team-leader-budget-errors.d.ts.map +1 -0
- package/dist/core/workflow/engine/team-leader-budget-errors.js +12 -0
- package/dist/core/workflow/engine/team-leader-budget-errors.js.map +1 -0
- package/dist/core/workflow/engine/team-leader-common.d.ts.map +1 -1
- package/dist/core/workflow/engine/team-leader-common.js +11 -0
- package/dist/core/workflow/engine/team-leader-common.js.map +1 -1
- package/dist/core/workflow/engine/team-leader-execution.d.ts.map +1 -1
- package/dist/core/workflow/engine/team-leader-execution.js +16 -2
- package/dist/core/workflow/engine/team-leader-execution.js.map +1 -1
- package/dist/core/workflow/engine/team-leader-part-runner.d.ts.map +1 -1
- package/dist/core/workflow/engine/team-leader-part-runner.js +22 -1
- package/dist/core/workflow/engine/team-leader-part-runner.js.map +1 -1
- package/dist/core/workflow/evaluation/AggregateEvaluator.d.ts.map +1 -1
- package/dist/core/workflow/evaluation/AggregateEvaluator.js +7 -4
- package/dist/core/workflow/evaluation/AggregateEvaluator.js.map +1 -1
- package/dist/core/workflow/evaluation/RuleEvaluator.d.ts +3 -0
- package/dist/core/workflow/evaluation/RuleEvaluator.d.ts.map +1 -1
- package/dist/core/workflow/evaluation/RuleEvaluator.js +16 -1
- package/dist/core/workflow/evaluation/RuleEvaluator.js.map +1 -1
- package/dist/core/workflow/evaluation/rule-utils.d.ts +5 -1
- package/dist/core/workflow/evaluation/rule-utils.d.ts.map +1 -1
- package/dist/core/workflow/evaluation/rule-utils.js +34 -1
- package/dist/core/workflow/evaluation/rule-utils.js.map +1 -1
- package/dist/core/workflow/evaluation/when-evaluator.d.ts.map +1 -1
- package/dist/core/workflow/evaluation/when-evaluator.js +4 -1
- package/dist/core/workflow/evaluation/when-evaluator.js.map +1 -1
- package/dist/core/workflow/findings/context.d.ts +5 -0
- package/dist/core/workflow/findings/context.d.ts.map +1 -0
- package/dist/core/workflow/findings/context.js +82 -0
- package/dist/core/workflow/findings/context.js.map +1 -0
- package/dist/core/workflow/findings/ledger-validation.d.ts +3 -0
- package/dist/core/workflow/findings/ledger-validation.d.ts.map +1 -0
- package/dist/core/workflow/findings/ledger-validation.js +26 -0
- package/dist/core/workflow/findings/ledger-validation.js.map +1 -0
- package/dist/core/workflow/findings/manager-output-validation.d.ts +15 -0
- package/dist/core/workflow/findings/manager-output-validation.d.ts.map +1 -0
- package/dist/core/workflow/findings/manager-output-validation.js +221 -0
- package/dist/core/workflow/findings/manager-output-validation.js.map +1 -0
- package/dist/core/workflow/findings/manager-runner.d.ts +89 -0
- package/dist/core/workflow/findings/manager-runner.d.ts.map +1 -0
- package/dist/core/workflow/findings/manager-runner.js +291 -0
- package/dist/core/workflow/findings/manager-runner.js.map +1 -0
- package/dist/core/workflow/findings/reconciler.d.ts +10 -0
- package/dist/core/workflow/findings/reconciler.d.ts.map +1 -0
- package/dist/core/workflow/findings/reconciler.js +413 -0
- package/dist/core/workflow/findings/reconciler.js.map +1 -0
- package/dist/core/workflow/findings/schemas.d.ts +2 -0
- package/dist/core/workflow/findings/schemas.d.ts.map +1 -0
- package/dist/core/workflow/findings/schemas.js +2 -0
- package/dist/core/workflow/findings/schemas.js.map +1 -0
- package/dist/core/workflow/findings/store.d.ts +33 -0
- package/dist/core/workflow/findings/store.d.ts.map +1 -0
- package/dist/core/workflow/findings/store.js +169 -0
- package/dist/core/workflow/findings/store.js.map +1 -0
- package/dist/core/workflow/findings/types.d.ts +3 -0
- package/dist/core/workflow/findings/types.d.ts.map +1 -0
- package/dist/core/workflow/findings/types.js +2 -0
- package/dist/core/workflow/findings/types.js.map +1 -0
- package/dist/core/workflow/instruction/InstructionBuilder.d.ts +1 -0
- package/dist/core/workflow/instruction/InstructionBuilder.d.ts.map +1 -1
- package/dist/core/workflow/instruction/InstructionBuilder.js +35 -11
- package/dist/core/workflow/instruction/InstructionBuilder.js.map +1 -1
- package/dist/core/workflow/instruction/ReportInstructionBuilder.d.ts +4 -0
- package/dist/core/workflow/instruction/ReportInstructionBuilder.d.ts.map +1 -1
- package/dist/core/workflow/instruction/ReportInstructionBuilder.js +22 -1
- package/dist/core/workflow/instruction/ReportInstructionBuilder.js.map +1 -1
- package/dist/core/workflow/instruction/fenced-json.d.ts +2 -0
- package/dist/core/workflow/instruction/fenced-json.d.ts.map +1 -0
- package/dist/core/workflow/instruction/fenced-json.js +11 -0
- package/dist/core/workflow/instruction/fenced-json.js.map +1 -0
- package/dist/core/workflow/instruction/instruction-context.d.ts +8 -0
- package/dist/core/workflow/instruction/instruction-context.d.ts.map +1 -1
- package/dist/core/workflow/instruction/instruction-context.js.map +1 -1
- package/dist/core/workflow/observability/traceDiscovery.d.ts +33 -0
- package/dist/core/workflow/observability/traceDiscovery.d.ts.map +1 -0
- package/dist/core/workflow/observability/traceDiscovery.js +104 -0
- package/dist/core/workflow/observability/traceDiscovery.js.map +1 -0
- package/dist/core/workflow/observability/workflowSpans.d.ts +5 -2
- package/dist/core/workflow/observability/workflowSpans.d.ts.map +1 -1
- package/dist/core/workflow/observability/workflowSpans.js +60 -13
- package/dist/core/workflow/observability/workflowSpans.js.map +1 -1
- package/dist/core/workflow/phase-runner.d.ts +4 -0
- package/dist/core/workflow/phase-runner.d.ts.map +1 -1
- package/dist/core/workflow/phase-runner.js.map +1 -1
- package/dist/core/workflow/promotion/PromotionEvaluator.d.ts +2 -0
- package/dist/core/workflow/promotion/PromotionEvaluator.d.ts.map +1 -1
- package/dist/core/workflow/promotion/PromotionEvaluator.js +1 -0
- package/dist/core/workflow/promotion/PromotionEvaluator.js.map +1 -1
- package/dist/core/workflow/promotion/promotion-runtime.d.ts +2 -0
- package/dist/core/workflow/promotion/promotion-runtime.d.ts.map +1 -1
- package/dist/core/workflow/promotion/promotion-runtime.js +1 -0
- package/dist/core/workflow/promotion/promotion-runtime.js.map +1 -1
- package/dist/core/workflow/provider-options-trace.d.ts +3 -2
- package/dist/core/workflow/provider-options-trace.d.ts.map +1 -1
- package/dist/core/workflow/provider-resolution.d.ts +11 -3
- package/dist/core/workflow/provider-resolution.d.ts.map +1 -1
- package/dist/core/workflow/provider-resolution.js +68 -2
- package/dist/core/workflow/provider-resolution.js.map +1 -1
- package/dist/core/workflow/quality-gates/commandGateRunner.d.ts +1 -1
- package/dist/core/workflow/quality-gates/commandGateRunner.d.ts.map +1 -1
- package/dist/core/workflow/quality-gates/commandGateRunner.js +11 -6
- package/dist/core/workflow/quality-gates/commandGateRunner.js.map +1 -1
- package/dist/core/workflow/quality-gates/qualityGateRunner.d.ts +1 -1
- package/dist/core/workflow/quality-gates/qualityGateRunner.d.ts.map +1 -1
- package/dist/core/workflow/quality-gates/qualityGateRunner.js +2 -2
- package/dist/core/workflow/quality-gates/qualityGateRunner.js.map +1 -1
- package/dist/core/workflow/quality-gates/types.d.ts +2 -0
- package/dist/core/workflow/quality-gates/types.d.ts.map +1 -1
- package/dist/core/workflow/report-phase-runner.d.ts.map +1 -1
- package/dist/core/workflow/report-phase-runner.js +59 -44
- package/dist/core/workflow/report-phase-runner.js.map +1 -1
- package/dist/core/workflow/report-writer.d.ts +2 -0
- package/dist/core/workflow/report-writer.d.ts.map +1 -0
- package/dist/core/workflow/report-writer.js +42 -0
- package/dist/core/workflow/report-writer.js.map +1 -0
- package/dist/core/workflow/run/run-meta.d.ts +5 -0
- package/dist/core/workflow/run/run-meta.d.ts.map +1 -1
- package/dist/core/workflow/run/run-meta.js.map +1 -1
- package/dist/core/workflow/state/workflow-state-access.d.ts +2 -2
- package/dist/core/workflow/state/workflow-state-access.d.ts.map +1 -1
- package/dist/core/workflow/state/workflow-state-access.js +17 -2
- package/dist/core/workflow/state/workflow-state-access.js.map +1 -1
- package/dist/core/workflow/status-judgment-phase.d.ts.map +1 -1
- package/dist/core/workflow/status-judgment-phase.js +1 -0
- package/dist/core/workflow/status-judgment-phase.js.map +1 -1
- package/dist/core/workflow/types.d.ts +27 -1
- package/dist/core/workflow/types.d.ts.map +1 -1
- package/dist/features/analytics/events.d.ts +1 -1
- package/dist/features/analytics/events.d.ts.map +1 -1
- package/dist/features/analytics/index.d.ts +1 -1
- package/dist/features/analytics/index.d.ts.map +1 -1
- package/dist/features/analytics/index.js +1 -1
- package/dist/features/analytics/index.js.map +1 -1
- package/dist/features/analytics/report-parser.d.ts +5 -3
- package/dist/features/analytics/report-parser.d.ts.map +1 -1
- package/dist/features/analytics/report-parser.js +42 -7
- package/dist/features/analytics/report-parser.js.map +1 -1
- package/dist/features/interactive/aiCaller.d.ts.map +1 -1
- package/dist/features/interactive/aiCaller.js +4 -2
- package/dist/features/interactive/aiCaller.js.map +1 -1
- package/dist/features/pipeline/execute.d.ts.map +1 -1
- package/dist/features/pipeline/execute.js +2 -3
- package/dist/features/pipeline/execute.js.map +1 -1
- package/dist/features/pipeline/steps.d.ts +4 -3
- package/dist/features/pipeline/steps.d.ts.map +1 -1
- package/dist/features/pipeline/steps.js +46 -8
- package/dist/features/pipeline/steps.js.map +1 -1
- package/dist/features/repertoire/file-filter.d.ts +3 -3
- package/dist/features/repertoire/file-filter.d.ts.map +1 -1
- package/dist/features/repertoire/file-filter.js +3 -3
- package/dist/features/repertoire/file-filter.js.map +1 -1
- package/dist/features/repertoire/pack-summary.d.ts +21 -7
- package/dist/features/repertoire/pack-summary.d.ts.map +1 -1
- package/dist/features/repertoire/pack-summary.js +156 -24
- package/dist/features/repertoire/pack-summary.js.map +1 -1
- package/dist/features/repertoire/remove.d.ts +5 -2
- package/dist/features/repertoire/remove.d.ts.map +1 -1
- package/dist/features/repertoire/remove.js +9 -2
- package/dist/features/repertoire/remove.js.map +1 -1
- package/dist/features/repertoire/takt-repertoire-config.d.ts +3 -3
- package/dist/features/repertoire/takt-repertoire-config.d.ts.map +1 -1
- package/dist/features/repertoire/takt-repertoire-config.js +31 -16
- package/dist/features/repertoire/takt-repertoire-config.js.map +1 -1
- package/dist/features/tasks/add/index.d.ts +1 -0
- package/dist/features/tasks/add/index.d.ts.map +1 -1
- package/dist/features/tasks/add/index.js +1 -0
- package/dist/features/tasks/add/index.js.map +1 -1
- package/dist/features/tasks/execute/analyticsEmitter.d.ts +4 -1
- package/dist/features/tasks/execute/analyticsEmitter.d.ts.map +1 -1
- package/dist/features/tasks/execute/analyticsEmitter.js +30 -3
- package/dist/features/tasks/execute/analyticsEmitter.js.map +1 -1
- package/dist/features/tasks/execute/runAllTasks.d.ts.map +1 -1
- package/dist/features/tasks/execute/runAllTasks.js +2 -2
- package/dist/features/tasks/execute/runAllTasks.js.map +1 -1
- package/dist/features/tasks/execute/runMeta.d.ts +5 -1
- package/dist/features/tasks/execute/runMeta.d.ts.map +1 -1
- package/dist/features/tasks/execute/runMeta.js +6 -1
- package/dist/features/tasks/execute/runMeta.js.map +1 -1
- package/dist/features/tasks/execute/selectAndExecute.d.ts.map +1 -1
- package/dist/features/tasks/execute/selectAndExecute.js +12 -0
- package/dist/features/tasks/execute/selectAndExecute.js.map +1 -1
- package/dist/features/tasks/execute/slackSummaryAdapter.d.ts +0 -1
- package/dist/features/tasks/execute/slackSummaryAdapter.d.ts.map +1 -1
- package/dist/features/tasks/execute/slackSummaryAdapter.js +0 -5
- package/dist/features/tasks/execute/slackSummaryAdapter.js.map +1 -1
- package/dist/features/tasks/execute/taskExecution.d.ts.map +1 -1
- package/dist/features/tasks/execute/taskExecution.js +9 -0
- package/dist/features/tasks/execute/taskExecution.js.map +1 -1
- package/dist/features/tasks/execute/taskWorkflowExecution.d.ts.map +1 -1
- package/dist/features/tasks/execute/taskWorkflowExecution.js +20 -1
- package/dist/features/tasks/execute/taskWorkflowExecution.js.map +1 -1
- package/dist/features/tasks/execute/traceTaskMetadata.d.ts +20 -0
- package/dist/features/tasks/execute/traceTaskMetadata.d.ts.map +1 -0
- package/dist/features/tasks/execute/traceTaskMetadata.js +54 -0
- package/dist/features/tasks/execute/traceTaskMetadata.js.map +1 -0
- package/dist/features/tasks/execute/types.d.ts +13 -1
- package/dist/features/tasks/execute/types.d.ts.map +1 -1
- package/dist/features/tasks/execute/workflowExecution.d.ts.map +1 -1
- package/dist/features/tasks/execute/workflowExecution.js +44 -1
- package/dist/features/tasks/execute/workflowExecution.js.map +1 -1
- package/dist/features/tasks/execute/workflowExecutionBootstrap.d.ts +2 -0
- package/dist/features/tasks/execute/workflowExecutionBootstrap.d.ts.map +1 -1
- package/dist/features/tasks/execute/workflowExecutionBootstrap.js +16 -2
- package/dist/features/tasks/execute/workflowExecutionBootstrap.js.map +1 -1
- package/dist/features/tasks/execute/workflowExecutionEvents.d.ts +2 -0
- package/dist/features/tasks/execute/workflowExecutionEvents.d.ts.map +1 -1
- package/dist/features/tasks/execute/workflowExecutionEvents.js +16 -2
- package/dist/features/tasks/execute/workflowExecutionEvents.js.map +1 -1
- package/dist/features/tasks/execute/workflowExecutionReporting.d.ts +3 -2
- package/dist/features/tasks/execute/workflowExecutionReporting.d.ts.map +1 -1
- package/dist/features/tasks/execute/workflowExecutionReporting.js +14 -2
- package/dist/features/tasks/execute/workflowExecutionReporting.js.map +1 -1
- package/dist/features/tasks/index.d.ts +1 -1
- package/dist/features/tasks/index.d.ts.map +1 -1
- package/dist/features/tasks/index.js.map +1 -1
- package/dist/features/tasks/resume/index.d.ts.map +1 -1
- package/dist/features/tasks/resume/index.js +5 -0
- package/dist/features/tasks/resume/index.js.map +1 -1
- package/dist/infra/claude/client.d.ts.map +1 -1
- package/dist/infra/claude/client.js +1 -0
- package/dist/infra/claude/client.js.map +1 -1
- package/dist/infra/claude/options-builder.d.ts.map +1 -1
- package/dist/infra/claude/options-builder.js +2 -3
- package/dist/infra/claude/options-builder.js.map +1 -1
- package/dist/infra/claude/types.d.ts +2 -0
- package/dist/infra/claude/types.d.ts.map +1 -1
- package/dist/infra/claude-headless/headless-spawn.d.ts.map +1 -1
- package/dist/infra/claude-headless/headless-spawn.js +2 -1
- package/dist/infra/claude-headless/headless-spawn.js.map +1 -1
- package/dist/infra/claude-headless/types.d.ts +1 -0
- package/dist/infra/claude-headless/types.d.ts.map +1 -1
- package/dist/infra/claude-terminal/client.d.ts.map +1 -1
- package/dist/infra/claude-terminal/client.js +1 -0
- package/dist/infra/claude-terminal/client.js.map +1 -1
- package/dist/infra/claude-terminal/response-normalizer.js.map +1 -1
- package/dist/infra/claude-terminal/tmux-backend.d.ts.map +1 -1
- package/dist/infra/claude-terminal/tmux-backend.js +15 -1
- package/dist/infra/claude-terminal/tmux-backend.js.map +1 -1
- package/dist/infra/claude-terminal/types.d.ts +2 -0
- package/dist/infra/claude-terminal/types.d.ts.map +1 -1
- package/dist/infra/codex/client.d.ts.map +1 -1
- package/dist/infra/codex/client.js +3 -1
- package/dist/infra/codex/client.js.map +1 -1
- package/dist/infra/codex/types.d.ts +1 -0
- package/dist/infra/codex/types.d.ts.map +1 -1
- package/dist/infra/config/configNormalizers.d.ts +18 -7
- package/dist/infra/config/configNormalizers.d.ts.map +1 -1
- package/dist/infra/config/configNormalizers.js +55 -14
- package/dist/infra/config/configNormalizers.js.map +1 -1
- package/dist/infra/config/env/global-current-env-specs.d.ts.map +1 -1
- package/dist/infra/config/env/global-current-env-specs.js +1 -0
- package/dist/infra/config/env/global-current-env-specs.js.map +1 -1
- package/dist/infra/config/env/project-current-env-specs.d.ts.map +1 -1
- package/dist/infra/config/env/project-current-env-specs.js +1 -0
- package/dist/infra/config/env/project-current-env-specs.js.map +1 -1
- package/dist/infra/config/global/globalConfigCore.d.ts.map +1 -1
- package/dist/infra/config/global/globalConfigCore.js +2 -1
- package/dist/infra/config/global/globalConfigCore.js.map +1 -1
- package/dist/infra/config/global/globalConfigSerializer.d.ts.map +1 -1
- package/dist/infra/config/global/globalConfigSerializer.js +5 -1
- package/dist/infra/config/global/globalConfigSerializer.js.map +1 -1
- package/dist/infra/config/loaders/namedResourceResolver.d.ts +18 -0
- package/dist/infra/config/loaders/namedResourceResolver.d.ts.map +1 -0
- package/dist/infra/config/loaders/namedResourceResolver.js +49 -0
- package/dist/infra/config/loaders/namedResourceResolver.js.map +1 -0
- package/dist/infra/config/loaders/providerOptionsLookupDirectories.d.ts +13 -0
- package/dist/infra/config/loaders/providerOptionsLookupDirectories.d.ts.map +1 -0
- package/dist/infra/config/loaders/providerOptionsLookupDirectories.js +61 -0
- package/dist/infra/config/loaders/providerOptionsLookupDirectories.js.map +1 -0
- package/dist/infra/config/loaders/workflowDiscovery.js +1 -1
- package/dist/infra/config/loaders/workflowDiscovery.js.map +1 -1
- package/dist/infra/config/loaders/workflowLoopMonitorNormalizer.d.ts.map +1 -1
- package/dist/infra/config/loaders/workflowLoopMonitorNormalizer.js +1 -1
- package/dist/infra/config/loaders/workflowLoopMonitorNormalizer.js.map +1 -1
- package/dist/infra/config/loaders/workflowParser.d.ts.map +1 -1
- package/dist/infra/config/loaders/workflowParser.js +64 -3
- package/dist/infra/config/loaders/workflowParser.js.map +1 -1
- package/dist/infra/config/loaders/workflowPreview.d.ts.map +1 -1
- package/dist/infra/config/loaders/workflowPreview.js +8 -3
- package/dist/infra/config/loaders/workflowPreview.js.map +1 -1
- package/dist/infra/config/loaders/workflowProviderOptionsResolver.d.ts +25 -0
- package/dist/infra/config/loaders/workflowProviderOptionsResolver.d.ts.map +1 -0
- package/dist/infra/config/loaders/workflowProviderOptionsResolver.js +150 -0
- package/dist/infra/config/loaders/workflowProviderOptionsResolver.js.map +1 -0
- package/dist/infra/config/loaders/workflowRuleNormalizer.d.ts.map +1 -1
- package/dist/infra/config/loaders/workflowRuleNormalizer.js +5 -16
- package/dist/infra/config/loaders/workflowRuleNormalizer.js.map +1 -1
- package/dist/infra/config/loaders/workflowStepFeaturesNormalizer.d.ts.map +1 -1
- package/dist/infra/config/loaders/workflowStepFeaturesNormalizer.js +5 -3
- package/dist/infra/config/loaders/workflowStepFeaturesNormalizer.js.map +1 -1
- package/dist/infra/config/loaders/workflowStepNormalizer.d.ts +3 -2
- package/dist/infra/config/loaders/workflowStepNormalizer.d.ts.map +1 -1
- package/dist/infra/config/loaders/workflowStepNormalizer.js +65 -13
- package/dist/infra/config/loaders/workflowStepNormalizer.js.map +1 -1
- package/dist/infra/config/paths.d.ts +4 -0
- package/dist/infra/config/paths.d.ts.map +1 -1
- package/dist/infra/config/paths.js +13 -0
- package/dist/infra/config/paths.js.map +1 -1
- package/dist/infra/config/project/projectConfig.d.ts.map +1 -1
- package/dist/infra/config/project/projectConfig.js +12 -3
- package/dist/infra/config/project/projectConfig.js.map +1 -1
- package/dist/infra/config/providerOptions.d.ts +24 -7
- package/dist/infra/config/providerOptions.d.ts.map +1 -1
- package/dist/infra/config/providerOptions.js +85 -11
- package/dist/infra/config/providerOptions.js.map +1 -1
- package/dist/infra/config/providerOptionsContract.d.ts +3 -3
- package/dist/infra/config/providerOptionsContract.d.ts.map +1 -1
- package/dist/infra/config/providerOptionsContract.js +8 -0
- package/dist/infra/config/providerOptionsContract.js.map +1 -1
- package/dist/infra/config/traced/tracedConfigSchema.d.ts.map +1 -1
- package/dist/infra/config/traced/tracedConfigSchema.js +8 -0
- package/dist/infra/config/traced/tracedConfigSchema.js.map +1 -1
- package/dist/infra/copilot/client.d.ts.map +1 -1
- package/dist/infra/copilot/client.js +7 -8
- package/dist/infra/copilot/client.js.map +1 -1
- package/dist/infra/copilot/types.d.ts +1 -0
- package/dist/infra/copilot/types.d.ts.map +1 -1
- package/dist/infra/cursor/client.d.ts.map +1 -1
- package/dist/infra/cursor/client.js +120 -55
- package/dist/infra/cursor/client.js.map +1 -1
- package/dist/infra/cursor/types.d.ts +1 -0
- package/dist/infra/cursor/types.d.ts.map +1 -1
- package/dist/infra/kiro/client.d.ts.map +1 -1
- package/dist/infra/kiro/client.js +10 -0
- package/dist/infra/kiro/client.js.map +1 -1
- package/dist/infra/kiro/process.d.ts.map +1 -1
- package/dist/infra/kiro/process.js +4 -2
- package/dist/infra/kiro/process.js.map +1 -1
- package/dist/infra/kiro/types.d.ts +2 -0
- package/dist/infra/kiro/types.d.ts.map +1 -1
- package/dist/infra/observability/otelFoundation.d.ts.map +1 -1
- package/dist/infra/observability/otelFoundation.js +93 -20
- package/dist/infra/observability/otelFoundation.js.map +1 -1
- package/dist/infra/opencode/OpenCodeStreamHandler.d.ts +19 -0
- package/dist/infra/opencode/OpenCodeStreamHandler.d.ts.map +1 -1
- package/dist/infra/opencode/OpenCodeStreamHandler.js +10 -0
- package/dist/infra/opencode/OpenCodeStreamHandler.js.map +1 -1
- package/dist/infra/opencode/allowedTools.d.ts +2 -0
- package/dist/infra/opencode/allowedTools.d.ts.map +1 -0
- package/dist/infra/opencode/allowedTools.js +10 -0
- package/dist/infra/opencode/allowedTools.js.map +1 -0
- package/dist/infra/opencode/client.d.ts +4 -2
- package/dist/infra/opencode/client.d.ts.map +1 -1
- package/dist/infra/opencode/client.js +304 -124
- package/dist/infra/opencode/client.js.map +1 -1
- package/dist/infra/opencode/index.d.ts +1 -1
- package/dist/infra/opencode/index.d.ts.map +1 -1
- package/dist/infra/opencode/index.js +1 -1
- package/dist/infra/opencode/index.js.map +1 -1
- package/dist/infra/opencode/types.d.ts +12 -10
- package/dist/infra/opencode/types.d.ts.map +1 -1
- package/dist/infra/opencode/types.js +101 -36
- package/dist/infra/opencode/types.js.map +1 -1
- package/dist/infra/opencode/unavailable-tool-loop.d.ts +7 -0
- package/dist/infra/opencode/unavailable-tool-loop.d.ts.map +1 -0
- package/dist/infra/opencode/unavailable-tool-loop.js +33 -0
- package/dist/infra/opencode/unavailable-tool-loop.js.map +1 -0
- package/dist/infra/providers/allowed-tool-edit-policy.d.ts +3 -0
- package/dist/infra/providers/allowed-tool-edit-policy.d.ts.map +1 -0
- package/dist/infra/providers/allowed-tool-edit-policy.js +10 -0
- package/dist/infra/providers/allowed-tool-edit-policy.js.map +1 -0
- package/dist/infra/providers/claude-headless.d.ts +2 -0
- package/dist/infra/providers/claude-headless.d.ts.map +1 -1
- package/dist/infra/providers/claude-headless.js +8 -0
- package/dist/infra/providers/claude-headless.js.map +1 -1
- package/dist/infra/providers/claude-terminal.d.ts +2 -0
- package/dist/infra/providers/claude-terminal.d.ts.map +1 -1
- package/dist/infra/providers/claude-terminal.js +8 -0
- package/dist/infra/providers/claude-terminal.js.map +1 -1
- package/dist/infra/providers/claude.d.ts +2 -0
- package/dist/infra/providers/claude.d.ts.map +1 -1
- package/dist/infra/providers/claude.js +8 -0
- package/dist/infra/providers/claude.js.map +1 -1
- package/dist/infra/providers/codex.d.ts +2 -0
- package/dist/infra/providers/codex.d.ts.map +1 -1
- package/dist/infra/providers/codex.js +7 -0
- package/dist/infra/providers/codex.js.map +1 -1
- package/dist/infra/providers/copilot.d.ts +2 -0
- package/dist/infra/providers/copilot.d.ts.map +1 -1
- package/dist/infra/providers/copilot.js +7 -0
- package/dist/infra/providers/copilot.js.map +1 -1
- package/dist/infra/providers/cursor.d.ts +2 -0
- package/dist/infra/providers/cursor.d.ts.map +1 -1
- package/dist/infra/providers/cursor.js +7 -0
- package/dist/infra/providers/cursor.js.map +1 -1
- package/dist/infra/providers/kiro.d.ts +2 -0
- package/dist/infra/providers/kiro.d.ts.map +1 -1
- package/dist/infra/providers/kiro.js +8 -0
- package/dist/infra/providers/kiro.js.map +1 -1
- package/dist/infra/providers/mock.d.ts +2 -0
- package/dist/infra/providers/mock.d.ts.map +1 -1
- package/dist/infra/providers/mock.js +7 -0
- package/dist/infra/providers/mock.js.map +1 -1
- package/dist/infra/providers/opencode.d.ts +3 -1
- package/dist/infra/providers/opencode.d.ts.map +1 -1
- package/dist/infra/providers/opencode.js +16 -3
- package/dist/infra/providers/opencode.js.map +1 -1
- package/dist/infra/providers/provider-capabilities.d.ts +2 -0
- package/dist/infra/providers/provider-capabilities.d.ts.map +1 -1
- package/dist/infra/providers/provider-capabilities.js +13 -1
- package/dist/infra/providers/provider-capabilities.js.map +1 -1
- package/dist/infra/providers/runtimeSystemPrompt.d.ts +2 -0
- package/dist/infra/providers/runtimeSystemPrompt.d.ts.map +1 -0
- package/dist/infra/providers/runtimeSystemPrompt.js +11 -0
- package/dist/infra/providers/runtimeSystemPrompt.js.map +1 -0
- package/dist/infra/providers/types.d.ts +3 -0
- package/dist/infra/providers/types.d.ts.map +1 -1
- package/dist/infra/rate-limit/detection.d.ts +1 -1
- package/dist/infra/rate-limit/detection.d.ts.map +1 -1
- package/dist/infra/rate-limit/detection.js +6 -7
- package/dist/infra/rate-limit/detection.js.map +1 -1
- package/dist/infra/resources/schema-loader.d.ts +1 -1
- package/dist/infra/resources/schema-loader.d.ts.map +1 -1
- package/dist/infra/resources/schema-loader.js +8 -4
- package/dist/infra/resources/schema-loader.js.map +1 -1
- package/dist/infra/service/runSyncConflictResolver.d.ts.map +1 -1
- package/dist/infra/service/runSyncConflictResolver.js +3 -1
- package/dist/infra/service/runSyncConflictResolver.js.map +1 -1
- package/dist/infra/task/clone-base-branch.d.ts +1 -0
- package/dist/infra/task/clone-base-branch.d.ts.map +1 -1
- package/dist/infra/task/clone-base-branch.js +22 -14
- package/dist/infra/task/clone-base-branch.js.map +1 -1
- package/dist/infra/task/clone.d.ts +2 -0
- package/dist/infra/task/clone.d.ts.map +1 -1
- package/dist/infra/task/clone.js +7 -1
- package/dist/infra/task/clone.js.map +1 -1
- package/dist/infra/task/index.d.ts +1 -1
- package/dist/infra/task/index.d.ts.map +1 -1
- package/dist/infra/task/index.js +1 -1
- package/dist/infra/task/index.js.map +1 -1
- package/dist/infra/task/mapper.d.ts.map +1 -1
- package/dist/infra/task/mapper.js +1 -0
- package/dist/infra/task/mapper.js.map +1 -1
- package/dist/infra/task/summarize.d.ts.map +1 -1
- package/dist/infra/task/summarize.js +3 -1
- package/dist/infra/task/summarize.js.map +1 -1
- package/dist/infra/task/taskExecutionSchemas.d.ts +3 -3
- package/dist/infra/task/taskRecordSchemas.d.ts +2 -2
- package/dist/infra/task/types.d.ts +1 -0
- package/dist/infra/task/types.d.ts.map +1 -1
- package/dist/shared/constants.d.ts +2 -0
- package/dist/shared/constants.d.ts.map +1 -1
- package/dist/shared/constants.js +2 -0
- package/dist/shared/constants.js.map +1 -1
- package/dist/shared/prompts/en/perform_agent_system_prompt.md +9 -1
- package/dist/shared/prompts/en/perform_phase2_message.md +1 -0
- package/dist/shared/prompts/en/provider_runtime_system_prompt.md +18 -0
- package/dist/shared/prompts/index.d.ts +1 -1
- package/dist/shared/prompts/index.d.ts.map +1 -1
- package/dist/shared/prompts/index.js +7 -1
- package/dist/shared/prompts/index.js.map +1 -1
- package/dist/shared/prompts/ja/perform_agent_system_prompt.md +9 -1
- package/dist/shared/prompts/ja/perform_phase2_message.md +1 -0
- package/dist/shared/prompts/ja/provider_runtime_system_prompt.md +18 -0
- package/dist/shared/telemetry/childProcessEnv.d.ts +7 -0
- package/dist/shared/telemetry/childProcessEnv.d.ts.map +1 -0
- package/dist/shared/telemetry/childProcessEnv.js +176 -0
- package/dist/shared/telemetry/childProcessEnv.js.map +1 -0
- package/dist/shared/telemetry/index.d.ts +3 -0
- package/dist/shared/telemetry/index.d.ts.map +1 -0
- package/dist/shared/telemetry/index.js +3 -0
- package/dist/shared/telemetry/index.js.map +1 -0
- package/dist/shared/telemetry/otlp.d.ts +40 -0
- package/dist/shared/telemetry/otlp.d.ts.map +1 -0
- package/dist/shared/telemetry/otlp.js +72 -0
- package/dist/shared/telemetry/otlp.js.map +1 -0
- package/dist/shared/types/provider.d.ts +25 -0
- package/dist/shared/types/provider.d.ts.map +1 -1
- package/dist/shared/ui/StreamDisplay.d.ts.map +1 -1
- package/dist/shared/ui/StreamDisplay.js +2 -1
- package/dist/shared/ui/StreamDisplay.js.map +1 -1
- package/dist/shared/utils/index.d.ts +1 -0
- package/dist/shared/utils/index.d.ts.map +1 -1
- package/dist/shared/utils/index.js +1 -0
- package/dist/shared/utils/index.js.map +1 -1
- package/dist/shared/utils/runId.d.ts +2 -0
- package/dist/shared/utils/runId.d.ts.map +1 -0
- package/dist/shared/utils/runId.js +18 -0
- package/dist/shared/utils/runId.js.map +1 -0
- package/package.json +25 -10
- package/builtins/en/facets/instructions/review-requirements.md +0 -17
- package/builtins/en/facets/output-contracts/requirements-review.md +0 -56
- package/builtins/en/facets/personas/requirements-reviewer.md +0 -33
- package/builtins/ja/facets/instructions/review-requirements.md +0 -17
- package/builtins/ja/facets/output-contracts/requirements-review.md +0 -56
- package/builtins/ja/facets/personas/requirements-reviewer.md +0 -33
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import { FINDING_SEVERITIES } from './types.js';
|
|
2
|
+
export function renderFindingLedgerInstructionSummary(ledger) {
|
|
3
|
+
return JSON.stringify({
|
|
4
|
+
version: ledger.version,
|
|
5
|
+
workflowName: ledger.workflowName,
|
|
6
|
+
open: ledger.findings
|
|
7
|
+
.filter((finding) => finding.status === 'open')
|
|
8
|
+
.map((finding) => ({
|
|
9
|
+
id: finding.id,
|
|
10
|
+
lifecycle: finding.lifecycle,
|
|
11
|
+
severity: finding.severity,
|
|
12
|
+
title: finding.title,
|
|
13
|
+
location: finding.location,
|
|
14
|
+
description: finding.description,
|
|
15
|
+
suggestion: finding.suggestion,
|
|
16
|
+
reviewers: finding.reviewers,
|
|
17
|
+
})),
|
|
18
|
+
resolved: ledger.findings
|
|
19
|
+
.filter((finding) => finding.status === 'resolved')
|
|
20
|
+
.map((finding) => ({
|
|
21
|
+
id: finding.id,
|
|
22
|
+
lifecycle: finding.lifecycle,
|
|
23
|
+
severity: finding.severity,
|
|
24
|
+
title: finding.title,
|
|
25
|
+
})),
|
|
26
|
+
conflicts: ledger.conflicts.map((conflict) => ({
|
|
27
|
+
id: conflict.id,
|
|
28
|
+
status: conflict.status,
|
|
29
|
+
findingIds: conflict.findingIds,
|
|
30
|
+
rawFindingIds: conflict.rawFindingIds,
|
|
31
|
+
description: conflict.description,
|
|
32
|
+
})),
|
|
33
|
+
}, null, 2);
|
|
34
|
+
}
|
|
35
|
+
export function renderFindingLedgerReportSummary(ledger) {
|
|
36
|
+
return JSON.stringify({
|
|
37
|
+
openFindingIds: ledger.findings
|
|
38
|
+
.filter((finding) => finding.status === 'open')
|
|
39
|
+
.map((finding) => finding.id),
|
|
40
|
+
resolvedFindingIds: ledger.findings
|
|
41
|
+
.filter((finding) => finding.status === 'resolved')
|
|
42
|
+
.map((finding) => finding.id),
|
|
43
|
+
conflictIds: ledger.conflicts.map((conflict) => conflict.id),
|
|
44
|
+
}, null, 2);
|
|
45
|
+
}
|
|
46
|
+
export function buildFindingsRuleContext(ledger) {
|
|
47
|
+
const openItems = ledger.findings.filter((finding) => finding.status === 'open');
|
|
48
|
+
const activeConflicts = ledger.conflicts.filter((conflict) => conflict.status === 'active');
|
|
49
|
+
const bySeverity = Object.fromEntries(FINDING_SEVERITIES.map((severity) => [severity, 0]));
|
|
50
|
+
for (const finding of openItems) {
|
|
51
|
+
bySeverity[finding.severity] += 1;
|
|
52
|
+
}
|
|
53
|
+
return {
|
|
54
|
+
open: {
|
|
55
|
+
count: openItems.length,
|
|
56
|
+
bySeverity,
|
|
57
|
+
items: openItems.map((finding) => ({
|
|
58
|
+
id: finding.id,
|
|
59
|
+
severity: finding.severity,
|
|
60
|
+
title: finding.title,
|
|
61
|
+
...(finding.location !== undefined ? { location: finding.location } : {}),
|
|
62
|
+
...(finding.description !== undefined ? { description: finding.description } : {}),
|
|
63
|
+
...(finding.suggestion !== undefined ? { suggestion: finding.suggestion } : {}),
|
|
64
|
+
reviewers: finding.reviewers,
|
|
65
|
+
})),
|
|
66
|
+
},
|
|
67
|
+
resolved: {
|
|
68
|
+
count: ledger.findings.filter((finding) => finding.status === 'resolved').length,
|
|
69
|
+
},
|
|
70
|
+
conflicts: {
|
|
71
|
+
count: activeConflicts.length,
|
|
72
|
+
items: activeConflicts.map((conflict) => ({
|
|
73
|
+
id: conflict.id,
|
|
74
|
+
status: conflict.status,
|
|
75
|
+
findingIds: conflict.findingIds,
|
|
76
|
+
rawFindingIds: conflict.rawFindingIds,
|
|
77
|
+
description: conflict.description,
|
|
78
|
+
})),
|
|
79
|
+
},
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
//# sourceMappingURL=context.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context.js","sourceRoot":"","sources":["../../../../src/core/workflow/findings/context.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ledger-validation.d.ts","sourceRoot":"","sources":["../../../../src/core/workflow/findings/ledger-validation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAgBhD,wBAAgB,iCAAiC,CAAC,MAAM,EAAE,aAAa,GAAG,IAAI,CAe7E"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
const FINDING_ID_PATTERN = /^F-(\d{4})$/;
|
|
2
|
+
function formatFindingIdNumber(idNumber) {
|
|
3
|
+
return `F-${String(idNumber).padStart(4, '0')}`;
|
|
4
|
+
}
|
|
5
|
+
function parseFindingIdNumber(findingId) {
|
|
6
|
+
const match = FINDING_ID_PATTERN.exec(findingId);
|
|
7
|
+
if (!match) {
|
|
8
|
+
throw new Error(`Invalid finding id format "${findingId}"`);
|
|
9
|
+
}
|
|
10
|
+
return Number(match[1]);
|
|
11
|
+
}
|
|
12
|
+
export function assertLedgerIdAllocationInvariant(ledger) {
|
|
13
|
+
const seen = new Set();
|
|
14
|
+
let maxFindingId = 0;
|
|
15
|
+
for (const finding of ledger.findings) {
|
|
16
|
+
if (seen.has(finding.id)) {
|
|
17
|
+
throw new Error(`Duplicate finding id "${finding.id}"`);
|
|
18
|
+
}
|
|
19
|
+
seen.add(finding.id);
|
|
20
|
+
maxFindingId = Math.max(maxFindingId, parseFindingIdNumber(finding.id));
|
|
21
|
+
}
|
|
22
|
+
if (ledger.nextId <= maxFindingId) {
|
|
23
|
+
throw new Error(`Finding ledger nextId ${ledger.nextId} must be greater than existing finding id ${formatFindingIdNumber(maxFindingId)}`);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=ledger-validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ledger-validation.js","sourceRoot":"","sources":["../../../../src/core/workflow/findings/ledger-validation.ts"],"names":[],"mappings":"AAEA,MAAM,kBAAkB,GAAG,aAAa,CAAC;AAEzC,SAAS,qBAAqB,CAAC,QAAgB;IAC7C,OAAO,KAAK,MAAM,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,EAAE,CAAC;AAClD,CAAC;AAED,SAAS,oBAAoB,CAAC,SAAiB;IAC7C,MAAM,KAAK,GAAG,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACjD,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,8BAA8B,SAAS,GAAG,CAAC,CAAC;IAC9D,CAAC;IACD,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,UAAU,iCAAiC,CAAC,MAAqB;IACrE,MAAM,IAAI,GAAG,IAAI,GAAG,EAAU,CAAC;IAC/B,IAAI,YAAY,GAAG,CAAC,CAAC;IACrB,KAAK,MAAM,OAAO,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;QACtC,IAAI,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,EAAE,CAAC;YACzB,MAAM,IAAI,KAAK,CAAC,yBAAyB,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC;QAC1D,CAAC;QACD,IAAI,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;QACrB,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,oBAAoB,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC;IAC1E,CAAC;IACD,IAAI,MAAM,CAAC,MAAM,IAAI,YAAY,EAAE,CAAC;QAClC,MAAM,IAAI,KAAK,CACb,yBAAyB,MAAM,CAAC,MAAM,6CAA6C,qBAAqB,CAAC,YAAY,CAAC,EAAE,CACzH,CAAC;IACJ,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { FindingLedger, FindingManagerOutput, RawFinding } from './types.js';
|
|
2
|
+
export type FindingManagerValidationResult = {
|
|
3
|
+
ok: true;
|
|
4
|
+
} | {
|
|
5
|
+
ok: false;
|
|
6
|
+
errors: string[];
|
|
7
|
+
};
|
|
8
|
+
interface ValidateFindingManagerOutputInput {
|
|
9
|
+
previousLedger: FindingLedger;
|
|
10
|
+
rawFindings: RawFinding[];
|
|
11
|
+
managerOutput: FindingManagerOutput;
|
|
12
|
+
}
|
|
13
|
+
export declare function validateFindingManagerOutput(input: ValidateFindingManagerOutputInput): FindingManagerValidationResult;
|
|
14
|
+
export {};
|
|
15
|
+
//# sourceMappingURL=manager-output-validation.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manager-output-validation.d.ts","sourceRoot":"","sources":["../../../../src/core/workflow/findings/manager-output-validation.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,aAAa,EAEb,oBAAoB,EAEpB,UAAU,EACX,MAAM,YAAY,CAAC;AAEpB,MAAM,MAAM,8BAA8B,GACtC;IAAE,EAAE,EAAE,IAAI,CAAA;CAAE,GACZ;IAAE,EAAE,EAAE,KAAK,CAAC;IAAC,MAAM,EAAE,MAAM,EAAE,CAAA;CAAE,CAAC;AAEpC,UAAU,iCAAiC;IACzC,cAAc,EAAE,aAAa,CAAC;IAC9B,WAAW,EAAE,UAAU,EAAE,CAAC;IAC1B,aAAa,EAAE,oBAAoB,CAAC;CACrC;AAoBD,wBAAgB,4BAA4B,CAC1C,KAAK,EAAE,iCAAiC,GACvC,8BAA8B,CAehC"}
|
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
export function validateFindingManagerOutput(input) {
|
|
2
|
+
const context = {
|
|
3
|
+
previousFindingsById: new Map(input.previousLedger.findings.map((finding) => [finding.id, finding])),
|
|
4
|
+
previousConflictsById: new Map(input.previousLedger.conflicts.map((conflict) => [conflict.id, conflict])),
|
|
5
|
+
currentRawFindingIds: new Set(input.rawFindings.map((finding) => finding.rawFindingId)),
|
|
6
|
+
currentRawFindingsById: new Map(input.rawFindings.map((finding) => [finding.rawFindingId, finding])),
|
|
7
|
+
previousRawFindingsById: new Map(input.previousLedger.rawFindings.map((finding) => [finding.rawFindingId, finding])),
|
|
8
|
+
};
|
|
9
|
+
const errors = [
|
|
10
|
+
...validateRawFindingDecisionRefs(input.managerOutput, context),
|
|
11
|
+
...validateFindingDecisionRefs(input.managerOutput, context),
|
|
12
|
+
...validateResolvedConflicts(input.managerOutput, context),
|
|
13
|
+
];
|
|
14
|
+
return errors.length === 0 ? { ok: true } : { ok: false, errors };
|
|
15
|
+
}
|
|
16
|
+
function validateRawFindingDecisionRefs(managerOutput, context) {
|
|
17
|
+
const decisionRefs = collectRawFindingDecisionRefs(managerOutput);
|
|
18
|
+
const matchErrors = managerOutput.matches.flatMap((match, index) => {
|
|
19
|
+
const decision = `matches[${index}]`;
|
|
20
|
+
const finding = context.previousFindingsById.get(match.findingId);
|
|
21
|
+
return [
|
|
22
|
+
...validateCurrentRawFindingIds(match.rawFindingIds, decision, context),
|
|
23
|
+
...(finding === undefined ? [] : validateFindingFamilyTagCompatible(finding, match.rawFindingIds, 'match', decision, context)),
|
|
24
|
+
];
|
|
25
|
+
});
|
|
26
|
+
const newFindingErrors = managerOutput.newFindings.flatMap((finding, index) => {
|
|
27
|
+
const decision = `newFindings[${index}]`;
|
|
28
|
+
return [
|
|
29
|
+
...validateCurrentRawFindingIds(finding.rawFindingIds, decision, context),
|
|
30
|
+
...validateCurrentRawFindingFamilyTags(finding.rawFindingIds, 'create a new finding from', decision, context),
|
|
31
|
+
];
|
|
32
|
+
});
|
|
33
|
+
const reopenedErrors = managerOutput.reopenedFindings.flatMap((reopened, index) => {
|
|
34
|
+
const decision = `reopenedFindings[${index}]`;
|
|
35
|
+
const finding = context.previousFindingsById.get(reopened.findingId);
|
|
36
|
+
return [
|
|
37
|
+
...validateCurrentRawFindingIds(reopened.rawFindingIds, decision, context),
|
|
38
|
+
...(finding === undefined ? [] : validateFindingFamilyTagCompatible(finding, reopened.rawFindingIds, 'reopen', decision, context)),
|
|
39
|
+
];
|
|
40
|
+
});
|
|
41
|
+
const conflictErrors = managerOutput.conflicts.flatMap((conflict, index) => {
|
|
42
|
+
const decision = `conflicts[${index}]`;
|
|
43
|
+
return [
|
|
44
|
+
...(conflict.findingIds.length === 0 && conflict.rawFindingIds.length === 0
|
|
45
|
+
? [`${decision} must reference at least one finding id or current raw finding id`]
|
|
46
|
+
: []),
|
|
47
|
+
...(conflict.rawFindingIds.length > 0
|
|
48
|
+
? validateCurrentRawFindingIds(conflict.rawFindingIds, decision, context)
|
|
49
|
+
: []),
|
|
50
|
+
];
|
|
51
|
+
});
|
|
52
|
+
return [
|
|
53
|
+
...matchErrors,
|
|
54
|
+
...newFindingErrors,
|
|
55
|
+
...reopenedErrors,
|
|
56
|
+
...conflictErrors,
|
|
57
|
+
...validateDuplicateRawFindingDecisionRefs(decisionRefs),
|
|
58
|
+
];
|
|
59
|
+
}
|
|
60
|
+
function collectRawFindingDecisionRefs(managerOutput) {
|
|
61
|
+
return [
|
|
62
|
+
...managerOutput.matches.flatMap((match, index) => rawFindingDecisionRefs(`matches[${index}]`, match.rawFindingIds)),
|
|
63
|
+
...managerOutput.newFindings.flatMap((finding, index) => rawFindingDecisionRefs(`newFindings[${index}]`, finding.rawFindingIds)),
|
|
64
|
+
...managerOutput.resolvedFindings.flatMap((resolved, index) => rawFindingDecisionRefs(`resolvedFindings[${index}]`, resolved.rawFindingIds)),
|
|
65
|
+
...managerOutput.reopenedFindings.flatMap((reopened, index) => rawFindingDecisionRefs(`reopenedFindings[${index}]`, reopened.rawFindingIds)),
|
|
66
|
+
...managerOutput.conflicts.flatMap((conflict, index) => rawFindingDecisionRefs(`conflicts[${index}]`, conflict.rawFindingIds)),
|
|
67
|
+
];
|
|
68
|
+
}
|
|
69
|
+
function rawFindingDecisionRefs(decision, rawFindingIds) {
|
|
70
|
+
return Array.from(new Set(rawFindingIds)).map((rawFindingId) => ({ decision, rawFindingId }));
|
|
71
|
+
}
|
|
72
|
+
function validateDuplicateRawFindingDecisionRefs(refs) {
|
|
73
|
+
return refs.flatMap((ref, index) => {
|
|
74
|
+
const previousRef = refs.slice(0, index).find((candidate) => (candidate.rawFindingId === ref.rawFindingId && candidate.decision !== ref.decision));
|
|
75
|
+
return previousRef === undefined
|
|
76
|
+
? []
|
|
77
|
+
: [`Raw finding id "${ref.rawFindingId}" appears in multiple manager decisions: ${previousRef.decision} and ${ref.decision}`];
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
function validateCurrentRawFindingIds(rawFindingIds, decision, context) {
|
|
81
|
+
if (rawFindingIds.length === 0) {
|
|
82
|
+
return [`${decision} must reference at least one current raw finding id`];
|
|
83
|
+
}
|
|
84
|
+
return [
|
|
85
|
+
...rawFindingIds.flatMap((rawFindingId, index) => (rawFindingIds.indexOf(rawFindingId) === index
|
|
86
|
+
? []
|
|
87
|
+
: [`Duplicate raw finding id "${rawFindingId}" in ${decision}`])),
|
|
88
|
+
...Array.from(new Set(rawFindingIds))
|
|
89
|
+
.filter((rawFindingId) => !context.currentRawFindingIds.has(rawFindingId))
|
|
90
|
+
.map((rawFindingId) => `Unknown raw finding id "${rawFindingId}" in ${decision}`),
|
|
91
|
+
];
|
|
92
|
+
}
|
|
93
|
+
function getCurrentRawFindings(rawFindingIds, context) {
|
|
94
|
+
return rawFindingIds
|
|
95
|
+
.map((rawFindingId) => context.currentRawFindingsById.get(rawFindingId))
|
|
96
|
+
.filter((rawFinding) => rawFinding !== undefined);
|
|
97
|
+
}
|
|
98
|
+
function validateCurrentRawFindingFamilyTags(rawFindingIds, action, decision, context) {
|
|
99
|
+
const rawFindings = getCurrentRawFindings(rawFindingIds, context);
|
|
100
|
+
const [primary, ...rest] = rawFindings;
|
|
101
|
+
if (primary === undefined) {
|
|
102
|
+
return [];
|
|
103
|
+
}
|
|
104
|
+
return rest
|
|
105
|
+
.filter((rawFinding) => rawFinding.familyTag !== primary.familyTag)
|
|
106
|
+
.map((rawFinding) => (`Cannot ${action} raw findings with different familyTag values: "${primary.familyTag}" and "${rawFinding.familyTag}" (${decision})`));
|
|
107
|
+
}
|
|
108
|
+
function validateFindingFamilyTagCompatible(finding, currentRawFindingIds, action, decision, context) {
|
|
109
|
+
const missingPreviousRawFindingErrors = finding.rawFindingIds
|
|
110
|
+
.filter((rawFindingId) => !context.previousRawFindingsById.has(rawFindingId))
|
|
111
|
+
.map((rawFindingId) => `Finding "${finding.id}" references previous raw finding "${rawFindingId}" that is not in the ledger`);
|
|
112
|
+
const previousRawFindings = finding.rawFindingIds
|
|
113
|
+
.map((rawFindingId) => context.previousRawFindingsById.get(rawFindingId))
|
|
114
|
+
.filter((rawFinding) => rawFinding !== undefined);
|
|
115
|
+
const currentRawFindings = getCurrentRawFindings(currentRawFindingIds, context);
|
|
116
|
+
const [primary, ...rest] = [...previousRawFindings, ...currentRawFindings];
|
|
117
|
+
if (primary === undefined) {
|
|
118
|
+
return missingPreviousRawFindingErrors;
|
|
119
|
+
}
|
|
120
|
+
return [
|
|
121
|
+
...missingPreviousRawFindingErrors,
|
|
122
|
+
...rest
|
|
123
|
+
.filter((rawFinding) => rawFinding.familyTag !== primary.familyTag)
|
|
124
|
+
.map((rawFinding) => (`Cannot ${action} raw findings with different familyTag values: "${primary.familyTag}" and "${rawFinding.familyTag}" (${decision}, finding "${finding.id}")`)),
|
|
125
|
+
];
|
|
126
|
+
}
|
|
127
|
+
function validateFindingDecisionRefs(managerOutput, context) {
|
|
128
|
+
const decisionRefs = collectFindingDecisionRefs(managerOutput);
|
|
129
|
+
const matchErrors = managerOutput.matches.flatMap((match, index) => (validateFindingDecision(match.findingId, `matches[${index}]`, 'match', 'open', context)));
|
|
130
|
+
const resolvedErrors = managerOutput.resolvedFindings.flatMap((resolved, index) => {
|
|
131
|
+
const decision = `resolvedFindings[${index}]`;
|
|
132
|
+
const finding = context.previousFindingsById.get(resolved.findingId);
|
|
133
|
+
return [
|
|
134
|
+
...validateFindingDecision(resolved.findingId, decision, 'resolve', 'open', context),
|
|
135
|
+
...(finding === undefined ? [] : validateResolvedFindingRawFindingIds(finding, resolved.rawFindingIds, context)),
|
|
136
|
+
];
|
|
137
|
+
});
|
|
138
|
+
const reopenedErrors = managerOutput.reopenedFindings.flatMap((reopened, index) => (validateFindingDecision(reopened.findingId, `reopenedFindings[${index}]`, 'reopen', 'resolved', context)));
|
|
139
|
+
const conflictErrors = managerOutput.conflicts.flatMap((conflict, index) => (validateConflictFindingIds(conflict.findingIds, `conflicts[${index}]`, context)));
|
|
140
|
+
return [
|
|
141
|
+
...matchErrors,
|
|
142
|
+
...resolvedErrors,
|
|
143
|
+
...reopenedErrors,
|
|
144
|
+
...conflictErrors,
|
|
145
|
+
...validateDuplicateFindingDecisionRefs(decisionRefs),
|
|
146
|
+
];
|
|
147
|
+
}
|
|
148
|
+
function collectFindingDecisionRefs(managerOutput) {
|
|
149
|
+
return [
|
|
150
|
+
...managerOutput.matches.map((match, index) => ({ decision: `matches[${index}]`, findingId: match.findingId })),
|
|
151
|
+
...managerOutput.resolvedFindings.map((resolved, index) => ({
|
|
152
|
+
decision: `resolvedFindings[${index}]`,
|
|
153
|
+
findingId: resolved.findingId,
|
|
154
|
+
})),
|
|
155
|
+
...managerOutput.reopenedFindings.map((reopened, index) => ({
|
|
156
|
+
decision: `reopenedFindings[${index}]`,
|
|
157
|
+
findingId: reopened.findingId,
|
|
158
|
+
})),
|
|
159
|
+
...managerOutput.conflicts.flatMap((conflict, index) => (Array.from(new Set(conflict.findingIds)).map((findingId) => ({ decision: `conflicts[${index}]`, findingId })))),
|
|
160
|
+
];
|
|
161
|
+
}
|
|
162
|
+
function validateDuplicateFindingDecisionRefs(refs) {
|
|
163
|
+
return refs.flatMap((ref, index) => {
|
|
164
|
+
const previousRef = refs.slice(0, index).find((candidate) => (candidate.findingId === ref.findingId && candidate.decision !== ref.decision));
|
|
165
|
+
return previousRef === undefined
|
|
166
|
+
? []
|
|
167
|
+
: [`Finding id "${ref.findingId}" appears in multiple manager decisions: ${previousRef.decision} and ${ref.decision}`];
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
function validateFindingDecision(findingId, decision, action, expectedStatus, context) {
|
|
171
|
+
const finding = context.previousFindingsById.get(findingId);
|
|
172
|
+
if (finding === undefined) {
|
|
173
|
+
return [`Unknown finding id "${findingId}" in ${decision}`];
|
|
174
|
+
}
|
|
175
|
+
return finding.status === expectedStatus
|
|
176
|
+
? []
|
|
177
|
+
: [`Cannot ${action} finding "${findingId}" because it is not ${expectedStatus}`];
|
|
178
|
+
}
|
|
179
|
+
function validateConflictFindingIds(findingIds, decision, context) {
|
|
180
|
+
return findingIds.flatMap((findingId, index) => {
|
|
181
|
+
if (findingIds.indexOf(findingId) !== index) {
|
|
182
|
+
return [`Duplicate finding id "${findingId}" in ${decision}`];
|
|
183
|
+
}
|
|
184
|
+
return context.previousFindingsById.has(findingId)
|
|
185
|
+
? []
|
|
186
|
+
: [`Unknown finding id "${findingId}" in ${decision}`];
|
|
187
|
+
});
|
|
188
|
+
}
|
|
189
|
+
function validateResolvedFindingRawFindingIds(finding, rawFindingIds, context) {
|
|
190
|
+
if (rawFindingIds.length === 0) {
|
|
191
|
+
return [`Resolved finding "${finding.id}" must reference at least one previous raw finding id`];
|
|
192
|
+
}
|
|
193
|
+
const findingRawFindingIds = new Set(finding.rawFindingIds);
|
|
194
|
+
return rawFindingIds.flatMap((rawFindingId, index) => {
|
|
195
|
+
if (rawFindingIds.indexOf(rawFindingId) !== index) {
|
|
196
|
+
return [`Duplicate raw finding id "${rawFindingId}" in resolvedFindings for "${finding.id}"`];
|
|
197
|
+
}
|
|
198
|
+
if (!findingRawFindingIds.has(rawFindingId)) {
|
|
199
|
+
return [`Resolved finding "${finding.id}" references raw finding id "${rawFindingId}" that does not belong to the finding`];
|
|
200
|
+
}
|
|
201
|
+
return context.previousRawFindingsById.has(rawFindingId)
|
|
202
|
+
? []
|
|
203
|
+
: [`Resolved finding "${finding.id}" references previous raw finding "${rawFindingId}" that is not in the ledger`];
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
function validateResolvedConflicts(managerOutput, context) {
|
|
207
|
+
return managerOutput.resolvedConflicts.flatMap((resolvedConflict, index) => {
|
|
208
|
+
const decision = `resolvedConflicts[${index}]`;
|
|
209
|
+
if (managerOutput.resolvedConflicts.findIndex((candidate) => (candidate.conflictId === resolvedConflict.conflictId)) !== index) {
|
|
210
|
+
return [`Duplicate conflict id "${resolvedConflict.conflictId}" in ${decision}`];
|
|
211
|
+
}
|
|
212
|
+
const conflict = context.previousConflictsById.get(resolvedConflict.conflictId);
|
|
213
|
+
if (conflict === undefined) {
|
|
214
|
+
return [`Unknown conflict id "${resolvedConflict.conflictId}" in ${decision}`];
|
|
215
|
+
}
|
|
216
|
+
return conflict.status === 'active'
|
|
217
|
+
? []
|
|
218
|
+
: [`Cannot resolve conflict "${conflict.id}" because it is not active`];
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
//# sourceMappingURL=manager-output-validation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manager-output-validation.js","sourceRoot":"","sources":["../../../../src/core/workflow/findings/manager-output-validation.ts"],"names":[],"mappings":"AAoCA,MAAM,UAAU,4BAA4B,CAC1C,KAAwC;IAExC,MAAM,OAAO,GAAsB;QACjC,oBAAoB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC;QACpG,qBAAqB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE,QAAQ,CAAC,CAAC,CAAC;QACzG,oBAAoB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QACvF,sBAAsB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,CAAC;QACpG,uBAAuB,EAAE,IAAI,GAAG,CAAC,KAAK,CAAC,cAAc,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC,CAAC;KACrH,CAAC;IACF,MAAM,MAAM,GAAG;QACb,GAAG,8BAA8B,CAAC,KAAK,CAAC,aAAa,EAAE,OAAO,CAAC;QAC/D,GAAG,2BAA2B,CAAC,KAAK,CAAC,aAAa,EAAE,OAAO,CAAC;QAC5D,GAAG,yBAAyB,CAAC,KAAK,CAAC,aAAa,EAAE,OAAO,CAAC;KAC3D,CAAC;IAEF,OAAO,MAAM,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC;AACpE,CAAC;AAED,SAAS,8BAA8B,CACrC,aAAmC,EACnC,OAA0B;IAE1B,MAAM,YAAY,GAAG,6BAA6B,CAAC,aAAa,CAAC,CAAC;IAClE,MAAM,WAAW,GAAG,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE;QACjE,MAAM,QAAQ,GAAG,WAAW,KAAK,GAAG,CAAC;QACrC,MAAM,OAAO,GAAG,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;QAClE,OAAO;YACL,GAAG,4BAA4B,CAAC,KAAK,CAAC,aAAa,EAAE,QAAQ,EAAE,OAAO,CAAC;YACvE,GAAG,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,kCAAkC,CAAC,OAAO,EAAE,KAAK,CAAC,aAAa,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;SAC/H,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,MAAM,gBAAgB,GAAG,aAAa,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;QAC5E,MAAM,QAAQ,GAAG,eAAe,KAAK,GAAG,CAAC;QACzC,OAAO;YACL,GAAG,4BAA4B,CAAC,OAAO,CAAC,aAAa,EAAE,QAAQ,EAAE,OAAO,CAAC;YACzE,GAAG,mCAAmC,CAAC,OAAO,CAAC,aAAa,EAAE,2BAA2B,EAAE,QAAQ,EAAE,OAAO,CAAC;SAC9G,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,MAAM,cAAc,GAAG,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE;QAChF,MAAM,QAAQ,GAAG,oBAAoB,KAAK,GAAG,CAAC;QAC9C,MAAM,OAAO,GAAG,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACrE,OAAO;YACL,GAAG,4BAA4B,CAAC,QAAQ,CAAC,aAAa,EAAE,QAAQ,EAAE,OAAO,CAAC;YAC1E,GAAG,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,kCAAkC,CAAC,OAAO,EAAE,QAAQ,CAAC,aAAa,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;SACnI,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,MAAM,cAAc,GAAG,aAAa,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE;QACzE,MAAM,QAAQ,GAAG,aAAa,KAAK,GAAG,CAAC;QACvC,OAAO;YACL,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,MAAM,KAAK,CAAC,IAAI,QAAQ,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC;gBACzE,CAAC,CAAC,CAAC,GAAG,QAAQ,mEAAmE,CAAC;gBAClF,CAAC,CAAC,EAAE,CAAC;YACP,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC;gBACnC,CAAC,CAAC,4BAA4B,CAAC,QAAQ,CAAC,aAAa,EAAE,QAAQ,EAAE,OAAO,CAAC;gBACzE,CAAC,CAAC,EAAE,CAAC;SACR,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,OAAO;QACL,GAAG,WAAW;QACd,GAAG,gBAAgB;QACnB,GAAG,cAAc;QACjB,GAAG,cAAc;QACjB,GAAG,uCAAuC,CAAC,YAAY,CAAC;KACzD,CAAC;AACJ,CAAC;AAED,SAAS,6BAA6B,CAAC,aAAmC;IACxE,OAAO;QACL,GAAG,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,sBAAsB,CAAC,WAAW,KAAK,GAAG,EAAE,KAAK,CAAC,aAAa,CAAC,CAAC;QACpH,GAAG,aAAa,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE,CAAC,sBAAsB,CAAC,eAAe,KAAK,GAAG,EAAE,OAAO,CAAC,aAAa,CAAC,CAAC;QAChI,GAAG,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,sBAAsB,CAAC,oBAAoB,KAAK,GAAG,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC5I,GAAG,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,sBAAsB,CAAC,oBAAoB,KAAK,GAAG,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;QAC5I,GAAG,aAAa,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,sBAAsB,CAAC,aAAa,KAAK,GAAG,EAAE,QAAQ,CAAC,aAAa,CAAC,CAAC;KAC/H,CAAC;AACJ,CAAC;AAED,SAAS,sBAAsB,CAAC,QAAgB,EAAE,aAAgC;IAChF,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,YAAY,EAAE,CAAC,CAAC,CAAC;AAChG,CAAC;AAED,SAAS,uCAAuC,CAAC,IAAsC;IACrF,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;QACjC,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAC3D,SAAS,CAAC,YAAY,KAAK,GAAG,CAAC,YAAY,IAAI,SAAS,CAAC,QAAQ,KAAK,GAAG,CAAC,QAAQ,CACnF,CAAC,CAAC;QACH,OAAO,WAAW,KAAK,SAAS;YAC9B,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,CAAC,mBAAmB,GAAG,CAAC,YAAY,4CAA4C,WAAW,CAAC,QAAQ,QAAQ,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;IAClI,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,4BAA4B,CACnC,aAAgC,EAChC,QAAgB,EAChB,OAA0B;IAE1B,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC/B,OAAO,CAAC,GAAG,QAAQ,qDAAqD,CAAC,CAAC;IAC5E,CAAC;IAED,OAAO;QACL,GAAG,aAAa,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,KAAK,EAAE,EAAE,CAAC,CAChD,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,KAAK;YAC3C,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,CAAC,6BAA6B,YAAY,QAAQ,QAAQ,EAAE,CAAC,CAClE,CAAC;QACF,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,aAAa,CAAC,CAAC;aAClC,MAAM,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;aACzE,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,2BAA2B,YAAY,QAAQ,QAAQ,EAAE,CAAC;KACpF,CAAC;AACJ,CAAC;AAED,SAAS,qBAAqB,CAC5B,aAAgC,EAChC,OAA0B;IAE1B,OAAO,aAAa;SACjB,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,OAAO,CAAC,sBAAsB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;SACvE,MAAM,CAAC,CAAC,UAAU,EAA4B,EAAE,CAAC,UAAU,KAAK,SAAS,CAAC,CAAC;AAChF,CAAC;AAED,SAAS,mCAAmC,CAC1C,aAAgC,EAChC,MAAc,EACd,QAAgB,EAChB,OAA0B;IAE1B,MAAM,WAAW,GAAG,qBAAqB,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IAClE,MAAM,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,GAAG,WAAW,CAAC;IACvC,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;QAC1B,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,OAAO,IAAI;SACR,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS,KAAK,OAAO,CAAC,SAAS,CAAC;SAClE,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CACnB,UAAU,MAAM,mDAAmD,OAAO,CAAC,SAAS,UAAU,UAAU,CAAC,SAAS,MAAM,QAAQ,GAAG,CACpI,CAAC,CAAC;AACP,CAAC;AAED,SAAS,kCAAkC,CACzC,OAAsB,EACtB,oBAAuC,EACvC,MAAc,EACd,QAAgB,EAChB,OAA0B;IAE1B,MAAM,+BAA+B,GAAG,OAAO,CAAC,aAAa;SAC1D,MAAM,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,uBAAuB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;SAC5E,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,YAAY,OAAO,CAAC,EAAE,sCAAsC,YAAY,6BAA6B,CAAC,CAAC;IAChI,MAAM,mBAAmB,GAAG,OAAO,CAAC,aAAa;SAC9C,GAAG,CAAC,CAAC,YAAY,EAAE,EAAE,CAAC,OAAO,CAAC,uBAAuB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;SACxE,MAAM,CAAC,CAAC,UAAU,EAA4B,EAAE,CAAC,UAAU,KAAK,SAAS,CAAC,CAAC;IAC9E,MAAM,kBAAkB,GAAG,qBAAqB,CAAC,oBAAoB,EAAE,OAAO,CAAC,CAAC;IAChF,MAAM,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,mBAAmB,EAAE,GAAG,kBAAkB,CAAC,CAAC;IAC3E,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;QAC1B,OAAO,+BAA+B,CAAC;IACzC,CAAC;IAED,OAAO;QACL,GAAG,+BAA+B;QAClC,GAAG,IAAI;aACJ,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS,KAAK,OAAO,CAAC,SAAS,CAAC;aAClE,GAAG,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,CACnB,UAAU,MAAM,mDAAmD,OAAO,CAAC,SAAS,UAAU,UAAU,CAAC,SAAS,MAAM,QAAQ,cAAc,OAAO,CAAC,EAAE,IAAI,CAC7J,CAAC;KACL,CAAC;AACJ,CAAC;AAED,SAAS,2BAA2B,CAClC,aAAmC,EACnC,OAA0B;IAE1B,MAAM,YAAY,GAAG,0BAA0B,CAAC,aAAa,CAAC,CAAC;IAC/D,MAAM,WAAW,GAAG,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAClE,uBAAuB,CAAC,KAAK,CAAC,SAAS,EAAE,WAAW,KAAK,GAAG,EAAE,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,CACxF,CAAC,CAAC;IACH,MAAM,cAAc,GAAG,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE;QAChF,MAAM,QAAQ,GAAG,oBAAoB,KAAK,GAAG,CAAC;QAC9C,MAAM,OAAO,GAAG,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QACrE,OAAO;YACL,GAAG,uBAAuB,CAAC,QAAQ,CAAC,SAAS,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,CAAC;YACpF,GAAG,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,oCAAoC,CAAC,OAAO,EAAE,QAAQ,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;SACjH,CAAC;IACJ,CAAC,CAAC,CAAC;IACH,MAAM,cAAc,GAAG,aAAa,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,CACjF,uBAAuB,CAAC,QAAQ,CAAC,SAAS,EAAE,oBAAoB,KAAK,GAAG,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,CAAC,CACzG,CAAC,CAAC;IACH,MAAM,cAAc,GAAG,aAAa,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,CAC1E,0BAA0B,CAAC,QAAQ,CAAC,UAAU,EAAE,aAAa,KAAK,GAAG,EAAE,OAAO,CAAC,CAChF,CAAC,CAAC;IAEH,OAAO;QACL,GAAG,WAAW;QACd,GAAG,cAAc;QACjB,GAAG,cAAc;QACjB,GAAG,cAAc;QACjB,GAAG,oCAAoC,CAAC,YAAY,CAAC;KACtD,CAAC;AACJ,CAAC;AAED,SAAS,0BAA0B,CAAC,aAAmC;IACrE,OAAO;QACL,GAAG,aAAa,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,WAAW,KAAK,GAAG,EAAE,SAAS,EAAE,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;QAC/G,GAAG,aAAa,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;YAC1D,QAAQ,EAAE,oBAAoB,KAAK,GAAG;YACtC,SAAS,EAAE,QAAQ,CAAC,SAAS;SAC9B,CAAC,CAAC;QACH,GAAG,aAAa,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;YAC1D,QAAQ,EAAE,oBAAoB,KAAK,GAAG;YACtC,SAAS,EAAE,QAAQ,CAAC,SAAS;SAC9B,CAAC,CAAC;QACH,GAAG,aAAa,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,EAAE,CAAC,CACtD,KAAK,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC,EAAE,QAAQ,EAAE,aAAa,KAAK,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAC9G,CAAC;KACH,CAAC;AACJ,CAAC;AAED,SAAS,oCAAoC,CAAC,IAAmC;IAC/E,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;QACjC,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAC3D,SAAS,CAAC,SAAS,KAAK,GAAG,CAAC,SAAS,IAAI,SAAS,CAAC,QAAQ,KAAK,GAAG,CAAC,QAAQ,CAC7E,CAAC,CAAC;QACH,OAAO,WAAW,KAAK,SAAS;YAC9B,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,CAAC,eAAe,GAAG,CAAC,SAAS,4CAA4C,WAAW,CAAC,QAAQ,QAAQ,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC3H,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,uBAAuB,CAC9B,SAAiB,EACjB,QAAgB,EAChB,MAAc,EACd,cAAuC,EACvC,OAA0B;IAE1B,MAAM,OAAO,GAAG,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IAC5D,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;QAC1B,OAAO,CAAC,uBAAuB,SAAS,QAAQ,QAAQ,EAAE,CAAC,CAAC;IAC9D,CAAC;IACD,OAAO,OAAO,CAAC,MAAM,KAAK,cAAc;QACtC,CAAC,CAAC,EAAE;QACJ,CAAC,CAAC,CAAC,UAAU,MAAM,aAAa,SAAS,uBAAuB,cAAc,EAAE,CAAC,CAAC;AACtF,CAAC;AAED,SAAS,0BAA0B,CACjC,UAA6B,EAC7B,QAAgB,EAChB,OAA0B;IAE1B,OAAO,UAAU,CAAC,OAAO,CAAC,CAAC,SAAS,EAAE,KAAK,EAAE,EAAE;QAC7C,IAAI,UAAU,CAAC,OAAO,CAAC,SAAS,CAAC,KAAK,KAAK,EAAE,CAAC;YAC5C,OAAO,CAAC,yBAAyB,SAAS,QAAQ,QAAQ,EAAE,CAAC,CAAC;QAChE,CAAC;QACD,OAAO,OAAO,CAAC,oBAAoB,CAAC,GAAG,CAAC,SAAS,CAAC;YAChD,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,CAAC,uBAAuB,SAAS,QAAQ,QAAQ,EAAE,CAAC,CAAC;IAC3D,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,oCAAoC,CAC3C,OAAsB,EACtB,aAAgC,EAChC,OAA0B;IAE1B,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC/B,OAAO,CAAC,qBAAqB,OAAO,CAAC,EAAE,uDAAuD,CAAC,CAAC;IAClG,CAAC;IACD,MAAM,oBAAoB,GAAG,IAAI,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;IAC5D,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC,YAAY,EAAE,KAAK,EAAE,EAAE;QACnD,IAAI,aAAa,CAAC,OAAO,CAAC,YAAY,CAAC,KAAK,KAAK,EAAE,CAAC;YAClD,OAAO,CAAC,6BAA6B,YAAY,8BAA8B,OAAO,CAAC,EAAE,GAAG,CAAC,CAAC;QAChG,CAAC;QACD,IAAI,CAAC,oBAAoB,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,CAAC;YAC5C,OAAO,CAAC,qBAAqB,OAAO,CAAC,EAAE,gCAAgC,YAAY,uCAAuC,CAAC,CAAC;QAC9H,CAAC;QACD,OAAO,OAAO,CAAC,uBAAuB,CAAC,GAAG,CAAC,YAAY,CAAC;YACtD,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,CAAC,qBAAqB,OAAO,CAAC,EAAE,sCAAsC,YAAY,6BAA6B,CAAC,CAAC;IACvH,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,yBAAyB,CAChC,aAAmC,EACnC,OAA0B;IAE1B,OAAO,aAAa,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC,gBAAgB,EAAE,KAAK,EAAE,EAAE;QACzE,MAAM,QAAQ,GAAG,qBAAqB,KAAK,GAAG,CAAC;QAC/C,IAAI,aAAa,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE,CAAC,CAC3D,SAAS,CAAC,UAAU,KAAK,gBAAgB,CAAC,UAAU,CACrD,CAAC,KAAK,KAAK,EAAE,CAAC;YACb,OAAO,CAAC,0BAA0B,gBAAgB,CAAC,UAAU,QAAQ,QAAQ,EAAE,CAAC,CAAC;QACnF,CAAC;QACD,MAAM,QAAQ,GAAG,OAAO,CAAC,qBAAqB,CAAC,GAAG,CAAC,gBAAgB,CAAC,UAAU,CAAC,CAAC;QAChF,IAAI,QAAQ,KAAK,SAAS,EAAE,CAAC;YAC3B,OAAO,CAAC,wBAAwB,gBAAgB,CAAC,UAAU,QAAQ,QAAQ,EAAE,CAAC,CAAC;QACjF,CAAC;QACD,OAAO,QAAQ,CAAC,MAAM,KAAK,QAAQ;YACjC,CAAC,CAAC,EAAE;YACJ,CAAC,CAAC,CAAC,4BAA4B,QAAQ,CAAC,EAAE,4BAA4B,CAAC,CAAC;IAC5E,CAAC,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
import type { AgentResponse, FindingContractConfig, WorkflowStep } from '../../models/types.js';
|
|
2
|
+
import type { FindingLedgerStore } from './store.js';
|
|
3
|
+
import type { FindingLedger } from './types.js';
|
|
4
|
+
import type { OptionsBuilder } from '../engine/OptionsBuilder.js';
|
|
5
|
+
import type { StepExecutor } from '../engine/StepExecutor.js';
|
|
6
|
+
import type { StepProviderInfo } from '../types.js';
|
|
7
|
+
export interface FindingManagerSubStepResult {
|
|
8
|
+
subStep: WorkflowStep;
|
|
9
|
+
response: AgentResponse;
|
|
10
|
+
}
|
|
11
|
+
interface RunFindingManagerForParallelStepInput {
|
|
12
|
+
contract: FindingContractConfig;
|
|
13
|
+
ledgerStore: FindingLedgerStore;
|
|
14
|
+
optionsBuilder: OptionsBuilder;
|
|
15
|
+
stepExecutor: Pick<StepExecutor, 'buildPhase1Instruction' | 'normalizeStructuredOutput'>;
|
|
16
|
+
parentStep: WorkflowStep;
|
|
17
|
+
stepIteration: number;
|
|
18
|
+
subResults: FindingManagerSubStepResult[];
|
|
19
|
+
workflowName: string;
|
|
20
|
+
runId: string;
|
|
21
|
+
timestamp: string;
|
|
22
|
+
ledgerCopyPath?: string;
|
|
23
|
+
}
|
|
24
|
+
export declare const RAW_FINDINGS_SCHEMA_REF = "takt.findings.raw.v1";
|
|
25
|
+
export declare const FINDING_MANAGER_SCHEMA_REF = "takt.findings.manager.v1";
|
|
26
|
+
export declare const RawFindingsStructuredOutput: {
|
|
27
|
+
readonly schemaRef: "takt.findings.raw.v1";
|
|
28
|
+
readonly schema: {
|
|
29
|
+
readonly type: "object";
|
|
30
|
+
readonly additionalProperties: false;
|
|
31
|
+
readonly required: readonly ["rawFindings"];
|
|
32
|
+
readonly properties: {
|
|
33
|
+
readonly rawFindings: {
|
|
34
|
+
readonly type: "array";
|
|
35
|
+
readonly items: {
|
|
36
|
+
readonly type: "object";
|
|
37
|
+
readonly additionalProperties: false;
|
|
38
|
+
readonly required: readonly ["rawFindingId", "familyTag", "severity", "title", "location", "description", "suggestion"];
|
|
39
|
+
readonly properties: {
|
|
40
|
+
readonly rawFindingId: {
|
|
41
|
+
readonly type: "string";
|
|
42
|
+
readonly minLength: 1;
|
|
43
|
+
};
|
|
44
|
+
readonly familyTag: {
|
|
45
|
+
readonly type: "string";
|
|
46
|
+
readonly minLength: 1;
|
|
47
|
+
readonly description: "Structured form of the Observed Findings family_tag value.";
|
|
48
|
+
};
|
|
49
|
+
readonly severity: {
|
|
50
|
+
readonly enum: readonly ["critical", "high", "medium", "low"];
|
|
51
|
+
};
|
|
52
|
+
readonly title: {
|
|
53
|
+
readonly type: "string";
|
|
54
|
+
readonly minLength: 1;
|
|
55
|
+
};
|
|
56
|
+
readonly location: {
|
|
57
|
+
readonly type: "string";
|
|
58
|
+
readonly minLength: 1;
|
|
59
|
+
};
|
|
60
|
+
readonly description: {
|
|
61
|
+
readonly type: "string";
|
|
62
|
+
readonly minLength: 1;
|
|
63
|
+
};
|
|
64
|
+
readonly suggestion: {
|
|
65
|
+
readonly type: "string";
|
|
66
|
+
readonly minLength: 1;
|
|
67
|
+
};
|
|
68
|
+
};
|
|
69
|
+
};
|
|
70
|
+
};
|
|
71
|
+
};
|
|
72
|
+
};
|
|
73
|
+
};
|
|
74
|
+
export type FindingManagerRunResult = {
|
|
75
|
+
status: 'updated';
|
|
76
|
+
ledgerPath: string;
|
|
77
|
+
providerInfo: StepProviderInfo;
|
|
78
|
+
ledger: FindingLedger;
|
|
79
|
+
} | {
|
|
80
|
+
status: 'invalid_manager_output';
|
|
81
|
+
ledgerPath: string;
|
|
82
|
+
providerInfo: StepProviderInfo;
|
|
83
|
+
reportPath: string;
|
|
84
|
+
errors: string[];
|
|
85
|
+
retryCount: number;
|
|
86
|
+
};
|
|
87
|
+
export declare function runFindingManagerForParallelStep(input: RunFindingManagerForParallelStepInput): Promise<FindingManagerRunResult>;
|
|
88
|
+
export {};
|
|
89
|
+
//# sourceMappingURL=manager-runner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"manager-runner.d.ts","sourceRoot":"","sources":["../../../../src/core/workflow/findings/manager-runner.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAqB,qBAAqB,EAAE,YAAY,EAAE,MAAM,uBAAuB,CAAC;AAQnH,OAAO,KAAK,EAAE,kBAAkB,EAAyC,MAAM,YAAY,CAAC;AAC5F,OAAO,KAAK,EAAE,aAAa,EAAoC,MAAM,YAAY,CAAC;AAKlF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,6BAA6B,CAAC;AAClE,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAC9D,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAGpD,MAAM,WAAW,2BAA2B;IAC1C,OAAO,EAAE,YAAY,CAAC;IACtB,QAAQ,EAAE,aAAa,CAAC;CACzB;AAED,UAAU,qCAAqC;IAC7C,QAAQ,EAAE,qBAAqB,CAAC;IAChC,WAAW,EAAE,kBAAkB,CAAC;IAChC,cAAc,EAAE,cAAc,CAAC;IAC/B,YAAY,EAAE,IAAI,CAAC,YAAY,EAAE,wBAAwB,GAAG,2BAA2B,CAAC,CAAC;IACzF,UAAU,EAAE,YAAY,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,2BAA2B,EAAE,CAAC;IAC1C,YAAY,EAAE,MAAM,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;IAClB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,eAAO,MAAM,uBAAuB,yBAAyB,CAAC;AAC9D,eAAO,MAAM,0BAA0B,6BAA6B,CAAC;AACrE,eAAO,MAAM,2BAA2B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAG9B,CAAC;AAGX,MAAM,MAAM,uBAAuB,GAC/B;IAAE,MAAM,EAAE,SAAS,CAAC;IAAC,UAAU,EAAE,MAAM,CAAC;IAAC,YAAY,EAAE,gBAAgB,CAAC;IAAC,MAAM,EAAE,aAAa,CAAA;CAAE,GAChG;IACA,MAAM,EAAE,wBAAwB,CAAC;IACjC,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,gBAAgB,CAAC;IAC/B,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,EAAE,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAkQJ,wBAAsB,gCAAgC,CACpD,KAAK,EAAE,qCAAqC,GAC3C,OAAO,CAAC,uBAAuB,CAAC,CAiFlC"}
|