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,413 @@
|
|
|
1
|
+
import { createHash } from 'node:crypto';
|
|
2
|
+
import { assertLedgerIdAllocationInvariant } from './ledger-validation.js';
|
|
3
|
+
import { validateFindingManagerOutput } from './manager-output-validation.js';
|
|
4
|
+
function formatFindingId(nextId) {
|
|
5
|
+
return `F-${String(nextId).padStart(4, '0')}`;
|
|
6
|
+
}
|
|
7
|
+
function formatConflictId(conflict) {
|
|
8
|
+
const ids = conflict.findingIds.length > 0 ? conflict.findingIds : conflict.rawFindingIds;
|
|
9
|
+
const signature = [...ids].sort().join('\0');
|
|
10
|
+
const hash = createHash('sha256').update(signature).digest('hex').slice(0, 12).toUpperCase();
|
|
11
|
+
return `C-${hash}`;
|
|
12
|
+
}
|
|
13
|
+
function assertKnownFinding(findingIds, findingId) {
|
|
14
|
+
if (!findingIds.has(findingId)) {
|
|
15
|
+
throw new Error(`Unknown finding id "${findingId}"`);
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
function assertKnownConflict(conflictsById, conflictId) {
|
|
19
|
+
if (!conflictsById.has(conflictId)) {
|
|
20
|
+
throw new Error(`Unknown conflict id "${conflictId}"`);
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
function assertKnownRawFindings(rawFindingIds, referencedIds) {
|
|
24
|
+
if (referencedIds.length === 0) {
|
|
25
|
+
throw new Error('Manager output must reference at least one raw finding id');
|
|
26
|
+
}
|
|
27
|
+
assertUniqueIds(referencedIds, 'raw finding id');
|
|
28
|
+
for (const rawFindingId of referencedIds) {
|
|
29
|
+
if (!rawFindingIds.has(rawFindingId)) {
|
|
30
|
+
throw new Error(`Unknown raw finding id "${rawFindingId}"`);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
function assertUniqueIds(ids, label) {
|
|
35
|
+
const seen = new Set();
|
|
36
|
+
for (const id of ids) {
|
|
37
|
+
if (seen.has(id)) {
|
|
38
|
+
throw new Error(`Duplicate ${label} "${id}"`);
|
|
39
|
+
}
|
|
40
|
+
seen.add(id);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
function assertFindingStatus(finding, expectedStatus, action) {
|
|
44
|
+
if (finding.status !== expectedStatus) {
|
|
45
|
+
throw new Error(`Cannot ${action} finding "${finding.id}" because it is not ${expectedStatus}`);
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
function markRawFindingIdsUsed(usedRawFindingIds, rawFindingIds) {
|
|
49
|
+
for (const rawFindingId of rawFindingIds) {
|
|
50
|
+
if (usedRawFindingIds.has(rawFindingId)) {
|
|
51
|
+
throw new Error(`Raw finding id "${rawFindingId}" is referenced by multiple manager decisions`);
|
|
52
|
+
}
|
|
53
|
+
usedRawFindingIds.add(rawFindingId);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
function markFindingIdDecision(usedFindingDecisions, findingId, decision) {
|
|
57
|
+
const previousDecision = usedFindingDecisions.get(findingId);
|
|
58
|
+
if (previousDecision !== undefined) {
|
|
59
|
+
throw new Error(`Finding id "${findingId}" appears in multiple manager decisions: ${previousDecision} and ${decision}`);
|
|
60
|
+
}
|
|
61
|
+
usedFindingDecisions.set(findingId, decision);
|
|
62
|
+
}
|
|
63
|
+
function assertFindingIdsHaveSingleDecision(managerOutput) {
|
|
64
|
+
const usedFindingDecisions = new Map();
|
|
65
|
+
for (const match of managerOutput.matches) {
|
|
66
|
+
markFindingIdDecision(usedFindingDecisions, match.findingId, 'match');
|
|
67
|
+
}
|
|
68
|
+
for (const resolved of managerOutput.resolvedFindings) {
|
|
69
|
+
markFindingIdDecision(usedFindingDecisions, resolved.findingId, 'resolve');
|
|
70
|
+
}
|
|
71
|
+
for (const reopened of managerOutput.reopenedFindings) {
|
|
72
|
+
markFindingIdDecision(usedFindingDecisions, reopened.findingId, 'reopen');
|
|
73
|
+
}
|
|
74
|
+
for (const conflict of managerOutput.conflicts) {
|
|
75
|
+
assertUniqueIds(conflict.findingIds, 'finding id');
|
|
76
|
+
for (const findingId of conflict.findingIds) {
|
|
77
|
+
markFindingIdDecision(usedFindingDecisions, findingId, 'conflict');
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
function assertNonEmptyIds(ids, label) {
|
|
82
|
+
if (ids.length === 0) {
|
|
83
|
+
throw new Error(`Manager output must reference at least one ${label}`);
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
function mergeRawFindingIds(current, next) {
|
|
87
|
+
return Array.from(new Set([...current, ...next]));
|
|
88
|
+
}
|
|
89
|
+
function mergeReviewers(current, rawFindings) {
|
|
90
|
+
return Array.from(new Set([...current, ...rawFindings.map((finding) => finding.reviewer)]));
|
|
91
|
+
}
|
|
92
|
+
function mergeRawFindingDetails(current, next) {
|
|
93
|
+
const byId = new Map();
|
|
94
|
+
for (const rawFinding of current) {
|
|
95
|
+
byId.set(rawFinding.rawFindingId, rawFinding);
|
|
96
|
+
}
|
|
97
|
+
for (const rawFinding of next) {
|
|
98
|
+
byId.set(rawFinding.rawFindingId, rawFinding);
|
|
99
|
+
}
|
|
100
|
+
return [...byId.values()];
|
|
101
|
+
}
|
|
102
|
+
function assertResolvedEvidenceRawFindings(input) {
|
|
103
|
+
assertKnownRawFindings(new Set(input.finding.rawFindingIds), input.resolvedRawFindingIds);
|
|
104
|
+
for (const rawFindingId of input.resolvedRawFindingIds) {
|
|
105
|
+
const rawFinding = input.previousRawFindingsById.get(rawFindingId);
|
|
106
|
+
if (rawFinding === undefined) {
|
|
107
|
+
throw new Error(`Resolved finding "${input.finding.id}" references previous raw finding "${rawFindingId}" that is not in the ledger`);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
function getRawFinding(rawFindings, rawFindingIds) {
|
|
112
|
+
const rawFinding = rawFindings.find((finding) => rawFindingIds.includes(finding.rawFindingId));
|
|
113
|
+
if (rawFinding === undefined) {
|
|
114
|
+
throw new Error(`Raw finding ids were validated but not found: ${rawFindingIds.join(', ')}`);
|
|
115
|
+
}
|
|
116
|
+
return rawFinding;
|
|
117
|
+
}
|
|
118
|
+
function getRawFindings(rawFindings, rawFindingIds) {
|
|
119
|
+
return rawFindingIds.map((rawFindingId) => {
|
|
120
|
+
const rawFinding = rawFindings.find((finding) => finding.rawFindingId === rawFindingId);
|
|
121
|
+
if (rawFinding === undefined) {
|
|
122
|
+
throw new Error(`Raw finding id was validated but not found: ${rawFindingId}`);
|
|
123
|
+
}
|
|
124
|
+
return rawFinding;
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
function assertSameFamilyTag(rawFindings, action) {
|
|
128
|
+
const [primary, ...rest] = rawFindings;
|
|
129
|
+
if (primary === undefined) {
|
|
130
|
+
throw new Error('At least one raw finding is required to validate familyTag');
|
|
131
|
+
}
|
|
132
|
+
for (const rawFinding of rest) {
|
|
133
|
+
if (rawFinding.familyTag !== primary.familyTag) {
|
|
134
|
+
throw new Error(`Cannot ${action} raw findings with different familyTag values: "${primary.familyTag}" and "${rawFinding.familyTag}"`);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
function getPreviousRawFindingsForFinding(input) {
|
|
139
|
+
return input.finding.rawFindingIds.map((rawFindingId) => {
|
|
140
|
+
const rawFinding = input.previousRawFindingsById.get(rawFindingId);
|
|
141
|
+
if (rawFinding === undefined) {
|
|
142
|
+
throw new Error(`Finding "${input.finding.id}" references previous raw finding "${rawFindingId}" that is not in the ledger`);
|
|
143
|
+
}
|
|
144
|
+
return rawFinding;
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
function assertFindingFamilyTagCompatible(input) {
|
|
148
|
+
const previousRawFindings = getPreviousRawFindingsForFinding({
|
|
149
|
+
finding: input.finding,
|
|
150
|
+
previousRawFindingsById: input.previousRawFindingsById,
|
|
151
|
+
});
|
|
152
|
+
assertSameFamilyTag([...previousRawFindings, ...input.currentRawFindings], input.action);
|
|
153
|
+
}
|
|
154
|
+
function rawEvidenceFields(rawFindings) {
|
|
155
|
+
const primary = rawFindings[0];
|
|
156
|
+
if (primary === undefined) {
|
|
157
|
+
throw new Error('At least one raw finding is required to build finding evidence');
|
|
158
|
+
}
|
|
159
|
+
return {
|
|
160
|
+
...(primary.location !== undefined ? { location: primary.location } : {}),
|
|
161
|
+
description: primary.description,
|
|
162
|
+
...(primary.suggestion !== undefined ? { suggestion: primary.suggestion } : {}),
|
|
163
|
+
reviewers: Array.from(new Set(rawFindings.map((finding) => finding.reviewer))),
|
|
164
|
+
};
|
|
165
|
+
}
|
|
166
|
+
function buildNewFinding(input) {
|
|
167
|
+
const observation = {
|
|
168
|
+
runId: input.context.runId,
|
|
169
|
+
stepName: input.firstSeenStepName,
|
|
170
|
+
timestamp: input.context.timestamp,
|
|
171
|
+
};
|
|
172
|
+
return {
|
|
173
|
+
id: input.id,
|
|
174
|
+
status: 'open',
|
|
175
|
+
lifecycle: 'new',
|
|
176
|
+
severity: input.severity,
|
|
177
|
+
title: input.title,
|
|
178
|
+
...rawEvidenceFields(input.rawFindings),
|
|
179
|
+
rawFindingIds: input.rawFindingIds,
|
|
180
|
+
firstSeen: observation,
|
|
181
|
+
lastSeen: observationFromContext(input.context),
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
function observationFromContext(context) {
|
|
185
|
+
return {
|
|
186
|
+
stepName: context.stepName,
|
|
187
|
+
runId: context.runId,
|
|
188
|
+
timestamp: context.timestamp,
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
function withoutResolutionFields(finding) {
|
|
192
|
+
return {
|
|
193
|
+
id: finding.id,
|
|
194
|
+
status: finding.status,
|
|
195
|
+
lifecycle: finding.lifecycle,
|
|
196
|
+
severity: finding.severity,
|
|
197
|
+
title: finding.title,
|
|
198
|
+
rawFindingIds: finding.rawFindingIds,
|
|
199
|
+
...(finding.location !== undefined ? { location: finding.location } : {}),
|
|
200
|
+
...(finding.description !== undefined ? { description: finding.description } : {}),
|
|
201
|
+
...(finding.suggestion !== undefined ? { suggestion: finding.suggestion } : {}),
|
|
202
|
+
reviewers: finding.reviewers,
|
|
203
|
+
firstSeen: finding.firstSeen,
|
|
204
|
+
lastSeen: finding.lastSeen,
|
|
205
|
+
...(finding.reopenedEvidence !== undefined ? { reopenedEvidence: finding.reopenedEvidence } : {}),
|
|
206
|
+
};
|
|
207
|
+
}
|
|
208
|
+
function withoutConflictResolutionFields(conflict) {
|
|
209
|
+
return {
|
|
210
|
+
id: conflict.id,
|
|
211
|
+
status: conflict.status,
|
|
212
|
+
findingIds: conflict.findingIds,
|
|
213
|
+
rawFindingIds: conflict.rawFindingIds,
|
|
214
|
+
description: conflict.description,
|
|
215
|
+
firstSeen: conflict.firstSeen,
|
|
216
|
+
lastSeen: conflict.lastSeen,
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
function reconcileLedgerConflicts(input) {
|
|
220
|
+
const conflictsById = new Map(input.previousLedger.conflicts.map((conflict) => [conflict.id, { ...conflict }]));
|
|
221
|
+
for (const resolvedConflict of input.managerOutput.resolvedConflicts) {
|
|
222
|
+
assertKnownConflict(conflictsById, resolvedConflict.conflictId);
|
|
223
|
+
const conflict = conflictsById.get(resolvedConflict.conflictId);
|
|
224
|
+
if (conflict.status !== 'active') {
|
|
225
|
+
throw new Error(`Cannot resolve conflict "${conflict.id}" because it is not active`);
|
|
226
|
+
}
|
|
227
|
+
conflictsById.set(conflict.id, {
|
|
228
|
+
...conflict,
|
|
229
|
+
status: 'resolved',
|
|
230
|
+
resolvedAt: input.context.timestamp,
|
|
231
|
+
resolvedEvidence: resolvedConflict.evidence,
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
for (const conflict of input.managerOutput.conflicts) {
|
|
235
|
+
if (conflict.findingIds.length === 0) {
|
|
236
|
+
assertNonEmptyIds(conflict.rawFindingIds, 'raw finding id');
|
|
237
|
+
}
|
|
238
|
+
assertUniqueIds(conflict.rawFindingIds, 'raw finding id');
|
|
239
|
+
for (const findingId of conflict.findingIds) {
|
|
240
|
+
assertKnownFinding(input.knownFindingIds, findingId);
|
|
241
|
+
}
|
|
242
|
+
if (conflict.rawFindingIds.length > 0) {
|
|
243
|
+
assertKnownRawFindings(input.rawFindingIds, conflict.rawFindingIds);
|
|
244
|
+
markRawFindingIdsUsed(input.usedRawFindingIds, conflict.rawFindingIds);
|
|
245
|
+
}
|
|
246
|
+
const conflictId = formatConflictId(conflict);
|
|
247
|
+
const existing = conflictsById.get(conflictId);
|
|
248
|
+
const base = existing !== undefined
|
|
249
|
+
? withoutConflictResolutionFields(existing)
|
|
250
|
+
: {
|
|
251
|
+
id: conflictId,
|
|
252
|
+
status: 'active',
|
|
253
|
+
findingIds: [...conflict.findingIds],
|
|
254
|
+
rawFindingIds: [],
|
|
255
|
+
description: conflict.description,
|
|
256
|
+
firstSeen: observationFromContext(input.context),
|
|
257
|
+
lastSeen: observationFromContext(input.context),
|
|
258
|
+
};
|
|
259
|
+
conflictsById.set(conflictId, {
|
|
260
|
+
...base,
|
|
261
|
+
status: 'active',
|
|
262
|
+
rawFindingIds: mergeRawFindingIds(base.rawFindingIds, conflict.rawFindingIds),
|
|
263
|
+
description: conflict.description,
|
|
264
|
+
lastSeen: observationFromContext(input.context),
|
|
265
|
+
});
|
|
266
|
+
}
|
|
267
|
+
return [...conflictsById.values()];
|
|
268
|
+
}
|
|
269
|
+
export function reconcileFindingLedger(input) {
|
|
270
|
+
const validation = validateFindingManagerOutput({
|
|
271
|
+
previousLedger: input.previousLedger,
|
|
272
|
+
rawFindings: input.rawFindings,
|
|
273
|
+
managerOutput: input.managerOutput,
|
|
274
|
+
});
|
|
275
|
+
if (!validation.ok) {
|
|
276
|
+
throw new Error(validation.errors.join('\n'));
|
|
277
|
+
}
|
|
278
|
+
const rawFindingIds = new Set(input.rawFindings.map((finding) => finding.rawFindingId));
|
|
279
|
+
assertUniqueIds(input.rawFindings.map((finding) => finding.rawFindingId), 'raw finding id');
|
|
280
|
+
assertLedgerIdAllocationInvariant(input.previousLedger);
|
|
281
|
+
const previousById = new Map(input.previousLedger.findings.map((finding) => [finding.id, finding]));
|
|
282
|
+
const previousRawFindingsById = new Map(input.previousLedger.rawFindings.map((finding) => [
|
|
283
|
+
finding.rawFindingId,
|
|
284
|
+
finding,
|
|
285
|
+
]));
|
|
286
|
+
const knownFindingIds = new Set(previousById.keys());
|
|
287
|
+
assertFindingIdsHaveSingleDecision(input.managerOutput);
|
|
288
|
+
let nextId = input.previousLedger.nextId;
|
|
289
|
+
const usedRawFindingIds = new Set();
|
|
290
|
+
const updatedById = new Map(input.previousLedger.findings.map((finding) => [finding.id, { ...finding }]));
|
|
291
|
+
for (const match of input.managerOutput.matches) {
|
|
292
|
+
assertKnownFinding(knownFindingIds, match.findingId);
|
|
293
|
+
assertKnownRawFindings(rawFindingIds, match.rawFindingIds);
|
|
294
|
+
markRawFindingIdsUsed(usedRawFindingIds, match.rawFindingIds);
|
|
295
|
+
const finding = updatedById.get(match.findingId);
|
|
296
|
+
assertFindingStatus(finding, 'open', 'match');
|
|
297
|
+
const matchedRawFindings = getRawFindings(input.rawFindings, match.rawFindingIds);
|
|
298
|
+
assertFindingFamilyTagCompatible({
|
|
299
|
+
finding,
|
|
300
|
+
previousRawFindingsById,
|
|
301
|
+
currentRawFindings: matchedRawFindings,
|
|
302
|
+
action: 'match',
|
|
303
|
+
});
|
|
304
|
+
const evidence = rawEvidenceFields(matchedRawFindings);
|
|
305
|
+
updatedById.set(match.findingId, {
|
|
306
|
+
...finding,
|
|
307
|
+
status: 'open',
|
|
308
|
+
lifecycle: finding.lifecycle === 'reopened' ? 'reopened' : 'persists',
|
|
309
|
+
rawFindingIds: mergeRawFindingIds(finding.rawFindingIds, match.rawFindingIds),
|
|
310
|
+
location: evidence.location ?? finding.location,
|
|
311
|
+
description: evidence.description,
|
|
312
|
+
suggestion: evidence.suggestion ?? finding.suggestion,
|
|
313
|
+
reviewers: mergeReviewers(finding.reviewers, matchedRawFindings),
|
|
314
|
+
lastSeen: observationFromContext(input.context),
|
|
315
|
+
});
|
|
316
|
+
}
|
|
317
|
+
for (const resolved of input.managerOutput.resolvedFindings) {
|
|
318
|
+
assertKnownFinding(knownFindingIds, resolved.findingId);
|
|
319
|
+
const finding = updatedById.get(resolved.findingId);
|
|
320
|
+
assertFindingStatus(finding, 'open', 'resolve');
|
|
321
|
+
assertResolvedEvidenceRawFindings({
|
|
322
|
+
finding,
|
|
323
|
+
resolvedRawFindingIds: resolved.rawFindingIds,
|
|
324
|
+
previousRawFindingsById,
|
|
325
|
+
});
|
|
326
|
+
updatedById.set(resolved.findingId, {
|
|
327
|
+
...finding,
|
|
328
|
+
status: 'resolved',
|
|
329
|
+
lifecycle: 'resolved',
|
|
330
|
+
resolvedAt: input.context.timestamp,
|
|
331
|
+
resolvedEvidence: resolved.evidence,
|
|
332
|
+
});
|
|
333
|
+
}
|
|
334
|
+
for (const reopened of input.managerOutput.reopenedFindings) {
|
|
335
|
+
assertKnownFinding(knownFindingIds, reopened.findingId);
|
|
336
|
+
assertKnownRawFindings(rawFindingIds, reopened.rawFindingIds);
|
|
337
|
+
markRawFindingIdsUsed(usedRawFindingIds, reopened.rawFindingIds);
|
|
338
|
+
const finding = updatedById.get(reopened.findingId);
|
|
339
|
+
assertFindingStatus(finding, 'resolved', 'reopen');
|
|
340
|
+
const reopenedRawFindings = getRawFindings(input.rawFindings, reopened.rawFindingIds);
|
|
341
|
+
assertFindingFamilyTagCompatible({
|
|
342
|
+
finding,
|
|
343
|
+
previousRawFindingsById,
|
|
344
|
+
currentRawFindings: reopenedRawFindings,
|
|
345
|
+
action: 'reopen',
|
|
346
|
+
});
|
|
347
|
+
const evidence = rawEvidenceFields(reopenedRawFindings);
|
|
348
|
+
const reopenedFinding = withoutResolutionFields(finding);
|
|
349
|
+
updatedById.set(reopened.findingId, {
|
|
350
|
+
...reopenedFinding,
|
|
351
|
+
status: 'open',
|
|
352
|
+
lifecycle: 'reopened',
|
|
353
|
+
rawFindingIds: mergeRawFindingIds(finding.rawFindingIds, reopened.rawFindingIds),
|
|
354
|
+
location: evidence.location ?? finding.location,
|
|
355
|
+
description: evidence.description,
|
|
356
|
+
suggestion: evidence.suggestion ?? finding.suggestion,
|
|
357
|
+
reviewers: mergeReviewers(finding.reviewers, reopenedRawFindings),
|
|
358
|
+
lastSeen: observationFromContext(input.context),
|
|
359
|
+
reopenedEvidence: reopened.evidence,
|
|
360
|
+
});
|
|
361
|
+
}
|
|
362
|
+
const newFindings = input.managerOutput.newFindings.map((newFinding) => {
|
|
363
|
+
assertKnownRawFindings(rawFindingIds, newFinding.rawFindingIds);
|
|
364
|
+
markRawFindingIdsUsed(usedRawFindingIds, newFinding.rawFindingIds);
|
|
365
|
+
const rawFinding = getRawFinding(input.rawFindings, newFinding.rawFindingIds);
|
|
366
|
+
const newRawFindings = getRawFindings(input.rawFindings, newFinding.rawFindingIds);
|
|
367
|
+
assertSameFamilyTag(newRawFindings, 'create a new finding from');
|
|
368
|
+
const id = formatFindingId(nextId);
|
|
369
|
+
nextId += 1;
|
|
370
|
+
return buildNewFinding({
|
|
371
|
+
id,
|
|
372
|
+
severity: newFinding.severity,
|
|
373
|
+
title: newFinding.title,
|
|
374
|
+
rawFindingIds: [...newFinding.rawFindingIds],
|
|
375
|
+
rawFindings: newRawFindings,
|
|
376
|
+
firstSeenStepName: rawFinding.stepName,
|
|
377
|
+
context: input.context,
|
|
378
|
+
});
|
|
379
|
+
});
|
|
380
|
+
const conflicts = reconcileLedgerConflicts({
|
|
381
|
+
previousLedger: input.previousLedger,
|
|
382
|
+
managerOutput: input.managerOutput,
|
|
383
|
+
knownFindingIds,
|
|
384
|
+
rawFindingIds,
|
|
385
|
+
usedRawFindingIds,
|
|
386
|
+
context: input.context,
|
|
387
|
+
});
|
|
388
|
+
const unmentionedNewFindings = input.rawFindings
|
|
389
|
+
.filter((rawFinding) => !usedRawFindingIds.has(rawFinding.rawFindingId))
|
|
390
|
+
.map((rawFinding) => {
|
|
391
|
+
const id = formatFindingId(nextId);
|
|
392
|
+
nextId += 1;
|
|
393
|
+
return buildNewFinding({
|
|
394
|
+
id,
|
|
395
|
+
severity: rawFinding.severity,
|
|
396
|
+
title: rawFinding.title,
|
|
397
|
+
rawFindingIds: [rawFinding.rawFindingId],
|
|
398
|
+
rawFindings: [rawFinding],
|
|
399
|
+
firstSeenStepName: rawFinding.stepName,
|
|
400
|
+
context: input.context,
|
|
401
|
+
});
|
|
402
|
+
});
|
|
403
|
+
return {
|
|
404
|
+
version: 1,
|
|
405
|
+
workflowName: input.context.workflowName,
|
|
406
|
+
nextId,
|
|
407
|
+
updatedAt: input.context.timestamp,
|
|
408
|
+
findings: [...updatedById.values(), ...newFindings, ...unmentionedNewFindings],
|
|
409
|
+
rawFindings: mergeRawFindingDetails(input.previousLedger.rawFindings, input.rawFindings),
|
|
410
|
+
conflicts,
|
|
411
|
+
};
|
|
412
|
+
}
|
|
413
|
+
//# sourceMappingURL=reconciler.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"reconciler.js","sourceRoot":"","sources":["../../../../src/core/workflow/findings/reconciler.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { FindingContractConfigRawSchema, FindingContractManagerConfigRawSchema, FindingLifecycleSchema, FindingLedgerEntrySchema, FindingLedgerSchema, FindingManagerOutputJsonSchema, FindingManagerOutputSchema, FindingObservationSchema, FindingSeveritySchema, FindingStatusSchema, RawFindingsOutputJsonSchema, RawFindingSchema, ReviewerRawFindingSchema, parseFindingLedger, parseFindingManagerOutput, parseRawFindings, parseReviewerRawFindings, } from '../../models/finding-schemas.js';
|
|
2
|
+
//# sourceMappingURL=schemas.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schemas.d.ts","sourceRoot":"","sources":["../../../../src/core/workflow/findings/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,8BAA8B,EAC9B,qCAAqC,EACrC,sBAAsB,EACtB,wBAAwB,EACxB,mBAAmB,EACnB,8BAA8B,EAC9B,0BAA0B,EAC1B,wBAAwB,EACxB,qBAAqB,EACrB,mBAAmB,EACnB,2BAA2B,EAC3B,gBAAgB,EAChB,wBAAwB,EACxB,kBAAkB,EAClB,yBAAyB,EACzB,gBAAgB,EAChB,wBAAwB,GACzB,MAAM,iCAAiC,CAAC"}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { FindingContractConfigRawSchema, FindingContractManagerConfigRawSchema, FindingLifecycleSchema, FindingLedgerEntrySchema, FindingLedgerSchema, FindingManagerOutputJsonSchema, FindingManagerOutputSchema, FindingObservationSchema, FindingSeveritySchema, FindingStatusSchema, RawFindingsOutputJsonSchema, RawFindingSchema, ReviewerRawFindingSchema, parseFindingLedger, parseFindingManagerOutput, parseRawFindings, parseReviewerRawFindings, } from '../../models/finding-schemas.js';
|
|
2
|
+
//# sourceMappingURL=schemas.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"schemas.js","sourceRoot":"","sources":["../../../../src/core/workflow/findings/schemas.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,8BAA8B,EAC9B,qCAAqC,EACrC,sBAAsB,EACtB,wBAAwB,EACxB,mBAAmB,EACnB,8BAA8B,EAC9B,0BAA0B,EAC1B,wBAAwB,EACxB,qBAAqB,EACrB,mBAAmB,EACnB,2BAA2B,EAC3B,gBAAgB,EAChB,wBAAwB,EACxB,kBAAkB,EAClB,yBAAyB,EACzB,gBAAgB,EAChB,wBAAwB,GACzB,MAAM,iCAAiC,CAAC"}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { FindingLedger, RawFinding } from './types.js';
|
|
2
|
+
interface FindingLedgerStoreOptions {
|
|
3
|
+
projectCwd: string;
|
|
4
|
+
reportDir: string;
|
|
5
|
+
workflowName: string;
|
|
6
|
+
ledgerPath: string;
|
|
7
|
+
rawFindingsPath: string;
|
|
8
|
+
}
|
|
9
|
+
export interface FindingLedgerStore {
|
|
10
|
+
loadLedger: () => FindingLedger;
|
|
11
|
+
saveLedger: (ledger: FindingLedger) => void;
|
|
12
|
+
createRunCopy: () => string;
|
|
13
|
+
saveRawFindings: (runId: string, stepName: string, rawFindings: RawFinding[]) => string;
|
|
14
|
+
saveManagerValidationReport: (report: FindingManagerValidationReport) => string;
|
|
15
|
+
}
|
|
16
|
+
export interface FindingManagerValidationAttemptReport {
|
|
17
|
+
attempt: number;
|
|
18
|
+
managerOutput: unknown;
|
|
19
|
+
validationErrors: string[];
|
|
20
|
+
}
|
|
21
|
+
export interface FindingManagerValidationReport {
|
|
22
|
+
version: 1;
|
|
23
|
+
runId: string;
|
|
24
|
+
stepName: string;
|
|
25
|
+
retryCount: number;
|
|
26
|
+
ledgerUpdated: boolean;
|
|
27
|
+
finalErrors: string[];
|
|
28
|
+
attempts: FindingManagerValidationAttemptReport[];
|
|
29
|
+
}
|
|
30
|
+
export declare function createFindingLedgerStore(options: FindingLedgerStoreOptions): FindingLedgerStore;
|
|
31
|
+
export declare function resolveFindingLedgerRoot(projectCwd: string): string;
|
|
32
|
+
export {};
|
|
33
|
+
//# sourceMappingURL=store.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../../../src/core/workflow/findings/store.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,YAAY,CAAC;AAK5D,UAAU,yBAAyB;IACjC,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;IAClB,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;CACzB;AAMD,MAAM,WAAW,kBAAkB;IACjC,UAAU,EAAE,MAAM,aAAa,CAAC;IAChC,UAAU,EAAE,CAAC,MAAM,EAAE,aAAa,KAAK,IAAI,CAAC;IAC5C,aAAa,EAAE,MAAM,MAAM,CAAC;IAC5B,eAAe,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,KAAK,MAAM,CAAC;IACxF,2BAA2B,EAAE,CAAC,MAAM,EAAE,8BAA8B,KAAK,MAAM,CAAC;CACjF;AAED,MAAM,WAAW,qCAAqC;IACpD,OAAO,EAAE,MAAM,CAAC;IAChB,aAAa,EAAE,OAAO,CAAC;IACvB,gBAAgB,EAAE,MAAM,EAAE,CAAC;CAC5B;AAED,MAAM,WAAW,8BAA8B;IAC7C,OAAO,EAAE,CAAC,CAAC;IACX,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;IACnB,aAAa,EAAE,OAAO,CAAC;IACvB,WAAW,EAAE,MAAM,EAAE,CAAC;IACtB,QAAQ,EAAE,qCAAqC,EAAE,CAAC;CACnD;AA4HD,wBAAgB,wBAAwB,CAAC,OAAO,EAAE,yBAAyB,GAAG,kBAAkB,CAiD/F;AAED,wBAAgB,wBAAwB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM,CAEnE"}
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
import { chmodSync, lstatSync, mkdirSync, readFileSync, realpathSync, writeFileSync } from 'node:fs';
|
|
2
|
+
import { dirname, resolve, sep } from 'node:path';
|
|
3
|
+
import { parseFindingLedger, parseRawFindings } from './schemas.js';
|
|
4
|
+
import { assertLedgerIdAllocationInvariant } from './ledger-validation.js';
|
|
5
|
+
import { writeReportFile } from '../report-writer.js';
|
|
6
|
+
const PRIVATE_DIR_MODE = 0o700;
|
|
7
|
+
const PRIVATE_FILE_MODE = 0o600;
|
|
8
|
+
const READ_ONLY_PRIVATE_FILE_MODE = 0o400;
|
|
9
|
+
function resolveInside(baseDir, path) {
|
|
10
|
+
const resolvedBase = resolve(baseDir);
|
|
11
|
+
const resolvedPath = resolve(resolvedBase, path);
|
|
12
|
+
assertPathInside(resolvedBase, resolvedPath, path);
|
|
13
|
+
return resolvedPath;
|
|
14
|
+
}
|
|
15
|
+
function assertPathInside(resolvedBase, resolvedPath, path) {
|
|
16
|
+
const basePrefix = resolvedBase.endsWith(sep) ? resolvedBase : resolvedBase + sep;
|
|
17
|
+
if (resolvedPath !== resolvedBase && !resolvedPath.startsWith(basePrefix)) {
|
|
18
|
+
throw new Error(`Finding ledger path escapes base directory: ${path}`);
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
function pathExists(path) {
|
|
22
|
+
try {
|
|
23
|
+
lstatSync(path);
|
|
24
|
+
return true;
|
|
25
|
+
}
|
|
26
|
+
catch (error) {
|
|
27
|
+
if (error.code === 'ENOENT') {
|
|
28
|
+
return false;
|
|
29
|
+
}
|
|
30
|
+
throw error;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
function assertNotSymlink(path) {
|
|
34
|
+
if (pathExists(path) && lstatSync(path).isSymbolicLink()) {
|
|
35
|
+
throw new Error(`Finding ledger path must not be a symbolic link: ${path}`);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
function findExistingAncestor(path) {
|
|
39
|
+
let current = path;
|
|
40
|
+
while (!pathExists(current)) {
|
|
41
|
+
const parent = dirname(current);
|
|
42
|
+
if (parent === current) {
|
|
43
|
+
throw new Error(`Finding ledger parent directory does not exist: ${path}`);
|
|
44
|
+
}
|
|
45
|
+
current = parent;
|
|
46
|
+
}
|
|
47
|
+
return current;
|
|
48
|
+
}
|
|
49
|
+
function assertRealPathInside(baseDir, path) {
|
|
50
|
+
const resolvedBase = realpathSync(baseDir);
|
|
51
|
+
const resolvedPath = realpathSync(path);
|
|
52
|
+
assertPathInside(resolvedBase, resolvedPath, path);
|
|
53
|
+
}
|
|
54
|
+
function prepareWritableFilePath(baseDir, filePath) {
|
|
55
|
+
const parentDir = dirname(filePath);
|
|
56
|
+
assertRealPathInside(baseDir, findExistingAncestor(parentDir));
|
|
57
|
+
mkdirSync(parentDir, { recursive: true, mode: PRIVATE_DIR_MODE });
|
|
58
|
+
chmodSync(parentDir, PRIVATE_DIR_MODE);
|
|
59
|
+
assertRealPathInside(baseDir, parentDir);
|
|
60
|
+
assertNotSymlink(filePath);
|
|
61
|
+
if (pathExists(filePath)) {
|
|
62
|
+
chmodSync(filePath, PRIVATE_FILE_MODE);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
function prepareWritableCopyPath(baseDir, filePath) {
|
|
66
|
+
prepareWritableFilePath(baseDir, filePath);
|
|
67
|
+
}
|
|
68
|
+
function prepareWritableDirectory(baseDir, dirPath) {
|
|
69
|
+
assertRealPathInside(baseDir, findExistingAncestor(dirPath));
|
|
70
|
+
mkdirSync(dirPath, { recursive: true, mode: PRIVATE_DIR_MODE });
|
|
71
|
+
chmodSync(dirPath, PRIVATE_DIR_MODE);
|
|
72
|
+
assertRealPathInside(baseDir, dirPath);
|
|
73
|
+
}
|
|
74
|
+
function createEmptyLedger(workflowName) {
|
|
75
|
+
return {
|
|
76
|
+
version: 1,
|
|
77
|
+
workflowName,
|
|
78
|
+
nextId: 1,
|
|
79
|
+
findings: [],
|
|
80
|
+
rawFindings: [],
|
|
81
|
+
conflicts: [],
|
|
82
|
+
updatedAt: new Date().toISOString(),
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
function readLedgerFile(path) {
|
|
86
|
+
const ledger = parseFindingLedger(JSON.parse(readFileSync(path, 'utf-8')));
|
|
87
|
+
assertLedgerIdAllocationInvariant(ledger);
|
|
88
|
+
return ledger;
|
|
89
|
+
}
|
|
90
|
+
function readProjectLedgerFile(baseDir, path) {
|
|
91
|
+
assertNotSymlink(path);
|
|
92
|
+
assertRealPathInside(baseDir, path);
|
|
93
|
+
return readLedgerFile(path);
|
|
94
|
+
}
|
|
95
|
+
function readProjectLedgerOrEmpty(baseDir, path, workflowName) {
|
|
96
|
+
assertRealPathInside(baseDir, findExistingAncestor(dirname(path)));
|
|
97
|
+
assertNotSymlink(path);
|
|
98
|
+
if (!pathExists(path)) {
|
|
99
|
+
return createEmptyLedger(workflowName);
|
|
100
|
+
}
|
|
101
|
+
const ledger = readProjectLedgerFile(baseDir, path);
|
|
102
|
+
assertLedgerWorkflowName(ledger, workflowName, path);
|
|
103
|
+
return ledger;
|
|
104
|
+
}
|
|
105
|
+
function assertLedgerWorkflowName(ledger, workflowName, source) {
|
|
106
|
+
if (ledger.workflowName !== workflowName) {
|
|
107
|
+
throw new Error(`Finding ledger workflowName mismatch in ${source}: expected "${workflowName}", got "${ledger.workflowName}"`);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
function sanitizeFileSegment(value) {
|
|
111
|
+
const sanitized = value.replace(/[^A-Za-z0-9._-]+/g, '-').replace(/^-+|-+$/g, '');
|
|
112
|
+
if (sanitized.length === 0) {
|
|
113
|
+
throw new Error(`Invalid finding file segment: ${value}`);
|
|
114
|
+
}
|
|
115
|
+
return sanitized;
|
|
116
|
+
}
|
|
117
|
+
export function createFindingLedgerStore(options) {
|
|
118
|
+
const ledgerRoot = resolveFindingLedgerRoot(options.projectCwd);
|
|
119
|
+
assertNotSymlink(ledgerRoot);
|
|
120
|
+
const ledgerPath = resolveInside(ledgerRoot, options.ledgerPath);
|
|
121
|
+
const copyPath = resolveInside(options.reportDir, 'findings-ledger.json');
|
|
122
|
+
const rawFindingsDir = resolveInside(ledgerRoot, options.rawFindingsPath);
|
|
123
|
+
return {
|
|
124
|
+
loadLedger: () => {
|
|
125
|
+
return readProjectLedgerOrEmpty(ledgerRoot, ledgerPath, options.workflowName);
|
|
126
|
+
},
|
|
127
|
+
saveLedger: (ledger) => {
|
|
128
|
+
assertLedgerWorkflowName(ledger, options.workflowName, ledgerPath);
|
|
129
|
+
assertLedgerIdAllocationInvariant(ledger);
|
|
130
|
+
prepareWritableFilePath(ledgerRoot, ledgerPath);
|
|
131
|
+
writeFileSync(ledgerPath, JSON.stringify(ledger, null, 2), { encoding: 'utf-8', mode: PRIVATE_FILE_MODE });
|
|
132
|
+
chmodSync(ledgerPath, PRIVATE_FILE_MODE);
|
|
133
|
+
},
|
|
134
|
+
createRunCopy: () => {
|
|
135
|
+
const ledger = readProjectLedgerOrEmpty(ledgerRoot, ledgerPath, options.workflowName);
|
|
136
|
+
prepareWritableCopyPath(options.reportDir, copyPath);
|
|
137
|
+
writeFileSync(copyPath, JSON.stringify(ledger, null, 2), { encoding: 'utf-8', mode: PRIVATE_FILE_MODE });
|
|
138
|
+
chmodSync(copyPath, READ_ONLY_PRIVATE_FILE_MODE);
|
|
139
|
+
return copyPath;
|
|
140
|
+
},
|
|
141
|
+
saveRawFindings: (runId, stepName, rawFindings) => {
|
|
142
|
+
const parsedRawFindings = parseRawFindings(rawFindings);
|
|
143
|
+
prepareWritableDirectory(ledgerRoot, rawFindingsDir);
|
|
144
|
+
const baseName = `${sanitizeFileSegment(runId)}.${sanitizeFileSegment(stepName)}`;
|
|
145
|
+
let rawFindingsFile = `${baseName}.json`;
|
|
146
|
+
let generation = 2;
|
|
147
|
+
while (pathExists(resolveInside(rawFindingsDir, rawFindingsFile))) {
|
|
148
|
+
rawFindingsFile = `${baseName}.${generation}.json`;
|
|
149
|
+
generation += 1;
|
|
150
|
+
}
|
|
151
|
+
const rawFindingsFilePath = resolveInside(rawFindingsDir, rawFindingsFile);
|
|
152
|
+
assertNotSymlink(rawFindingsFilePath);
|
|
153
|
+
writeFileSync(rawFindingsFilePath, JSON.stringify(parsedRawFindings, null, 2), {
|
|
154
|
+
encoding: 'utf-8',
|
|
155
|
+
mode: PRIVATE_FILE_MODE,
|
|
156
|
+
});
|
|
157
|
+
chmodSync(rawFindingsFilePath, PRIVATE_FILE_MODE);
|
|
158
|
+
return rawFindingsFilePath;
|
|
159
|
+
},
|
|
160
|
+
saveManagerValidationReport: (report) => {
|
|
161
|
+
const fileName = `findings-manager-validation.${sanitizeFileSegment(report.stepName)}.json`;
|
|
162
|
+
return writeReportFile(options.reportDir, fileName, JSON.stringify(report, null, 2));
|
|
163
|
+
},
|
|
164
|
+
};
|
|
165
|
+
}
|
|
166
|
+
export function resolveFindingLedgerRoot(projectCwd) {
|
|
167
|
+
return resolve(projectCwd);
|
|
168
|
+
}
|
|
169
|
+
//# sourceMappingURL=store.js.map
|