@evolith/core-domain 1.0.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/dist/application/agents/agent-ruleset-builder.d.ts +30 -0
- package/dist/application/agents/agent-ruleset-builder.js +75 -0
- package/dist/application/agents/agent-ruleset-builder.js.map +1 -0
- package/dist/application/agents/agent-ruleset-builder.spec.d.ts +1 -0
- package/dist/application/agents/agent-ruleset-builder.spec.js +135 -0
- package/dist/application/agents/agent-ruleset-builder.spec.js.map +1 -0
- package/dist/application/architecture/workspace-manager.strategy.d.ts +8 -0
- package/dist/application/architecture/workspace-manager.strategy.js +3 -0
- package/dist/application/architecture/workspace-manager.strategy.js.map +1 -0
- package/dist/application/generators/hexagonal-scaffolder.d.ts +6 -0
- package/dist/application/generators/hexagonal-scaffolder.js +259 -0
- package/dist/application/generators/hexagonal-scaffolder.js.map +1 -0
- package/dist/application/generators/hexagonal-scaffolder.spec.d.ts +1 -0
- package/dist/application/generators/hexagonal-scaffolder.spec.js +166 -0
- package/dist/application/generators/hexagonal-scaffolder.spec.js.map +1 -0
- package/dist/application/generators/mermaid-class-parser.d.ts +38 -0
- package/dist/application/generators/mermaid-class-parser.js +183 -0
- package/dist/application/generators/mermaid-class-parser.js.map +1 -0
- package/dist/application/generators/mermaid-class-parser.spec.d.ts +1 -0
- package/dist/application/generators/mermaid-class-parser.spec.js +148 -0
- package/dist/application/generators/mermaid-class-parser.spec.js.map +1 -0
- package/dist/application/index.d.ts +9 -0
- package/dist/application/index.js +26 -0
- package/dist/application/index.js.map +1 -0
- package/dist/application/ports/blueprint-repository.port.d.ts +6 -0
- package/dist/application/ports/blueprint-repository.port.js +3 -0
- package/dist/application/ports/blueprint-repository.port.js.map +1 -0
- package/dist/application/ports/event-bus.port.d.ts +5 -0
- package/dist/application/ports/event-bus.port.js +3 -0
- package/dist/application/ports/event-bus.port.js.map +1 -0
- package/dist/application/ports/index.d.ts +5 -0
- package/dist/application/ports/index.js +22 -0
- package/dist/application/ports/index.js.map +1 -0
- package/dist/application/ports/platform-detection.port.d.ts +9 -0
- package/dist/application/ports/platform-detection.port.js +3 -0
- package/dist/application/ports/platform-detection.port.js.map +1 -0
- package/dist/application/ports/webhook-notifier.port.d.ts +3 -0
- package/dist/application/ports/webhook-notifier.port.js +3 -0
- package/dist/application/ports/webhook-notifier.port.js.map +1 -0
- package/dist/application/ports/webhook-subscription.port.d.ts +13 -0
- package/dist/application/ports/webhook-subscription.port.js +3 -0
- package/dist/application/ports/webhook-subscription.port.js.map +1 -0
- package/dist/application/services/audit.service.d.ts +12 -0
- package/dist/application/services/audit.service.js +36 -0
- package/dist/application/services/audit.service.js.map +1 -0
- package/dist/application/services/catalog.service.d.ts +10 -0
- package/dist/application/services/catalog.service.js +84 -0
- package/dist/application/services/catalog.service.js.map +1 -0
- package/dist/application/services/evolith-config.service.d.ts +25 -0
- package/dist/application/services/evolith-config.service.js +120 -0
- package/dist/application/services/evolith-config.service.js.map +1 -0
- package/dist/application/services/gate-registry.service.d.ts +34 -0
- package/dist/application/services/gate-registry.service.js +104 -0
- package/dist/application/services/gate-registry.service.js.map +1 -0
- package/dist/application/services/index.d.ts +41 -0
- package/dist/application/services/index.js +25 -0
- package/dist/application/services/index.js.map +1 -0
- package/dist/application/services/initialize-project.spec.d.ts +5 -0
- package/dist/application/services/initialize-project.spec.js +228 -0
- package/dist/application/services/initialize-project.spec.js.map +1 -0
- package/dist/application/services/phase-transition.use-case.spec.d.ts +1 -0
- package/dist/application/services/phase-transition.use-case.spec.js +303 -0
- package/dist/application/services/phase-transition.use-case.spec.js.map +1 -0
- package/dist/application/services/project-scaffolder.service.d.ts +19 -0
- package/dist/application/services/project-scaffolder.service.js +194 -0
- package/dist/application/services/project-scaffolder.service.js.map +1 -0
- package/dist/application/services/satellite-evaluation-pipeline.service.d.ts +18 -0
- package/dist/application/services/satellite-evaluation-pipeline.service.js +206 -0
- package/dist/application/services/satellite-evaluation-pipeline.service.js.map +1 -0
- package/dist/application/services/sdlc-data-loader.service.d.ts +39 -0
- package/dist/application/services/sdlc-data-loader.service.js +112 -0
- package/dist/application/services/sdlc-data-loader.service.js.map +1 -0
- package/dist/application/services/services/command-executor.service.d.ts +3 -0
- package/dist/application/services/services/command-executor.service.js +13 -0
- package/dist/application/services/services/command-executor.service.js.map +1 -0
- package/dist/application/services/services/command-history.service.d.ts +39 -0
- package/dist/application/services/services/command-history.service.js +150 -0
- package/dist/application/services/services/command-history.service.js.map +1 -0
- package/dist/application/services/services/command-history.service.spec.d.ts +1 -0
- package/dist/application/services/services/command-history.service.spec.js +266 -0
- package/dist/application/services/services/command-history.service.spec.js.map +1 -0
- package/dist/application/services/services/command-providers.d.ts +1 -0
- package/dist/application/services/services/command-providers.js +17 -0
- package/dist/application/services/services/command-providers.js.map +1 -0
- package/dist/application/services/topology-catalog.service.d.ts +58 -0
- package/dist/application/services/topology-catalog.service.js +85 -0
- package/dist/application/services/topology-catalog.service.js.map +1 -0
- package/dist/application/sync/sync.service.d.ts +9 -0
- package/dist/application/sync/sync.service.js +88 -0
- package/dist/application/sync/sync.service.js.map +1 -0
- package/dist/application/sync/sync.service.spec.d.ts +1 -0
- package/dist/application/sync/sync.service.spec.js +76 -0
- package/dist/application/sync/sync.service.spec.js.map +1 -0
- package/dist/application/upgrade/satellite-upgrade-apply.d.ts +5 -0
- package/dist/application/upgrade/satellite-upgrade-apply.js +102 -0
- package/dist/application/upgrade/satellite-upgrade-apply.js.map +1 -0
- package/dist/application/upgrade/satellite-upgrade-diff.d.ts +6 -0
- package/dist/application/upgrade/satellite-upgrade-diff.js +130 -0
- package/dist/application/upgrade/satellite-upgrade-diff.js.map +1 -0
- package/dist/application/upgrade/satellite-upgrade-fs.d.ts +4 -0
- package/dist/application/upgrade/satellite-upgrade-fs.js +97 -0
- package/dist/application/upgrade/satellite-upgrade-fs.js.map +1 -0
- package/dist/application/upgrade/satellite-upgrade.service.d.ts +14 -0
- package/dist/application/upgrade/satellite-upgrade.service.js +78 -0
- package/dist/application/upgrade/satellite-upgrade.service.js.map +1 -0
- package/dist/application/upgrade/satellite-upgrade.service.spec.d.ts +1 -0
- package/dist/application/upgrade/satellite-upgrade.service.spec.js +231 -0
- package/dist/application/upgrade/satellite-upgrade.service.spec.js.map +1 -0
- package/dist/application/upgrade/satellite-upgrade.types.d.ts +31 -0
- package/dist/application/upgrade/satellite-upgrade.types.js +3 -0
- package/dist/application/upgrade/satellite-upgrade.types.js.map +1 -0
- package/dist/application/use-cases/evaluate-gate.use-case.d.ts +25 -0
- package/dist/application/use-cases/evaluate-gate.use-case.js +124 -0
- package/dist/application/use-cases/evaluate-gate.use-case.js.map +1 -0
- package/dist/application/use-cases/evaluate-gate.use-case.spec.d.ts +1 -0
- package/dist/application/use-cases/evaluate-gate.use-case.spec.js +112 -0
- package/dist/application/use-cases/evaluate-gate.use-case.spec.js.map +1 -0
- package/dist/application/use-cases/index.d.ts +7 -0
- package/dist/application/use-cases/index.js +24 -0
- package/dist/application/use-cases/index.js.map +1 -0
- package/dist/application/use-cases/initialize-project.use-case.d.ts +10 -0
- package/dist/application/use-cases/initialize-project.use-case.js +71 -0
- package/dist/application/use-cases/initialize-project.use-case.js.map +1 -0
- package/dist/application/use-cases/phase-transition.use-case.d.ts +22 -0
- package/dist/application/use-cases/phase-transition.use-case.js +100 -0
- package/dist/application/use-cases/phase-transition.use-case.js.map +1 -0
- package/dist/application/use-cases/propose-phase-advance.use-case.d.ts +15 -0
- package/dist/application/use-cases/propose-phase-advance.use-case.js +42 -0
- package/dist/application/use-cases/propose-phase-advance.use-case.js.map +1 -0
- package/dist/application/use-cases/propose-phase-advance.use-case.spec.d.ts +1 -0
- package/dist/application/use-cases/propose-phase-advance.use-case.spec.js +64 -0
- package/dist/application/use-cases/propose-phase-advance.use-case.spec.js.map +1 -0
- package/dist/application/use-cases/validate-blueprint.use-case.d.ts +32 -0
- package/dist/application/use-cases/validate-blueprint.use-case.js +179 -0
- package/dist/application/use-cases/validate-blueprint.use-case.js.map +1 -0
- package/dist/application/use-cases/validate-satellite.use-case.d.ts +25 -0
- package/dist/application/use-cases/validate-satellite.use-case.js +192 -0
- package/dist/application/use-cases/validate-satellite.use-case.js.map +1 -0
- package/dist/application/use-cases/validate-satellite.use-case.spec.d.ts +1 -0
- package/dist/application/use-cases/validate-satellite.use-case.spec.js +102 -0
- package/dist/application/use-cases/validate-satellite.use-case.spec.js.map +1 -0
- package/dist/application/use-cases/validate-workflow.use-case.d.ts +11 -0
- package/dist/application/use-cases/validate-workflow.use-case.js +121 -0
- package/dist/application/use-cases/validate-workflow.use-case.js.map +1 -0
- package/dist/application/validators/architecture/detectors.d.ts +7 -0
- package/dist/application/validators/architecture/detectors.js +128 -0
- package/dist/application/validators/architecture/detectors.js.map +1 -0
- package/dist/application/validators/architecture/import-graph.d.ts +5 -0
- package/dist/application/validators/architecture/import-graph.js +132 -0
- package/dist/application/validators/architecture/import-graph.js.map +1 -0
- package/dist/application/validators/architecture/types.d.ts +44 -0
- package/dist/application/validators/architecture/types.js +39 -0
- package/dist/application/validators/architecture/types.js.map +1 -0
- package/dist/application/validators/architecture-drift.service.d.ts +74 -0
- package/dist/application/validators/architecture-drift.service.js +268 -0
- package/dist/application/validators/architecture-drift.service.js.map +1 -0
- package/dist/application/validators/architecture-drift.service.spec.d.ts +1 -0
- package/dist/application/validators/architecture-drift.service.spec.js +144 -0
- package/dist/application/validators/architecture-drift.service.spec.js.map +1 -0
- package/dist/application/validators/architecture-validator.d.ts +14 -0
- package/dist/application/validators/architecture-validator.js +125 -0
- package/dist/application/validators/architecture-validator.js.map +1 -0
- package/dist/application/validators/blocking-criteria-validator.d.ts +29 -0
- package/dist/application/validators/blocking-criteria-validator.js +255 -0
- package/dist/application/validators/blocking-criteria-validator.js.map +1 -0
- package/dist/application/validators/build-vs-compose.schema.spec.d.ts +1 -0
- package/dist/application/validators/build-vs-compose.schema.spec.js +143 -0
- package/dist/application/validators/build-vs-compose.schema.spec.js.map +1 -0
- package/dist/application/validators/deep-architecture-analyzer.d.ts +9 -0
- package/dist/application/validators/deep-architecture-analyzer.js +73 -0
- package/dist/application/validators/deep-architecture-analyzer.js.map +1 -0
- package/dist/application/validators/deep-architecture-analyzer.spec.d.ts +1 -0
- package/dist/application/validators/deep-architecture-analyzer.spec.js +186 -0
- package/dist/application/validators/deep-architecture-analyzer.spec.js.map +1 -0
- package/dist/application/validators/evaluators/architecture-equivalence.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/architecture-equivalence.spec.js +58 -0
- package/dist/application/validators/evaluators/architecture-equivalence.spec.js.map +1 -0
- package/dist/application/validators/evaluators/evaluator.interface.d.ts +14 -0
- package/dist/application/validators/evaluators/evaluator.interface.js +3 -0
- package/dist/application/validators/evaluators/evaluator.interface.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/acl-rule.handler.d.ts +16 -0
- package/dist/application/validators/evaluators/handlers/acl-rule.handler.js +139 -0
- package/dist/application/validators/evaluators/handlers/acl-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/architecture/agent-rules.d.ts +6 -0
- package/dist/application/validators/evaluators/handlers/architecture/agent-rules.js +131 -0
- package/dist/application/validators/evaluators/handlers/architecture/agent-rules.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/architecture/ast-rules.d.ts +6 -0
- package/dist/application/validators/evaluators/handlers/architecture/ast-rules.js +151 -0
- package/dist/application/validators/evaluators/handlers/architecture/ast-rules.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/architecture/config-rules.d.ts +6 -0
- package/dist/application/validators/evaluators/handlers/architecture/config-rules.js +60 -0
- package/dist/application/validators/evaluators/handlers/architecture/config-rules.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/architecture/shared.d.ts +14 -0
- package/dist/application/validators/evaluators/handlers/architecture/shared.js +91 -0
- package/dist/application/validators/evaluators/handlers/architecture/shared.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/architecture/structural-rules.d.ts +6 -0
- package/dist/application/validators/evaluators/handlers/architecture/structural-rules.js +208 -0
- package/dist/application/validators/evaluators/handlers/architecture/structural-rules.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/architecture-rule.handler.d.ts +11 -0
- package/dist/application/validators/evaluators/handlers/architecture-rule.handler.js +39 -0
- package/dist/application/validators/evaluators/handlers/architecture-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/architecture-rule.handler.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/handlers/architecture-rule.handler.spec.js +212 -0
- package/dist/application/validators/evaluators/handlers/architecture-rule.handler.spec.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.d.ts +17 -0
- package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.js +133 -0
- package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.spec.js +89 -0
- package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.spec.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/cross-cutting-rule.handler.d.ts +25 -0
- package/dist/application/validators/evaluators/handlers/cross-cutting-rule.handler.js +244 -0
- package/dist/application/validators/evaluators/handlers/cross-cutting-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/dependency-rule.handler.d.ts +17 -0
- package/dist/application/validators/evaluators/handlers/dependency-rule.handler.js +163 -0
- package/dist/application/validators/evaluators/handlers/dependency-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/dependency-rule.handler.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/handlers/dependency-rule.handler.spec.js +115 -0
- package/dist/application/validators/evaluators/handlers/dependency-rule.handler.spec.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/evidence-rule.handler.d.ts +10 -0
- package/dist/application/validators/evaluators/handlers/evidence-rule.handler.js +102 -0
- package/dist/application/validators/evaluators/handlers/evidence-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/evidence-rule.handler.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/handlers/evidence-rule.handler.spec.js +94 -0
- package/dist/application/validators/evaluators/handlers/evidence-rule.handler.spec.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/executive-scorecard-rule.handler.d.ts +15 -0
- package/dist/application/validators/evaluators/handlers/executive-scorecard-rule.handler.js +126 -0
- package/dist/application/validators/evaluators/handlers/executive-scorecard-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/governance-rule.handler.d.ts +11 -0
- package/dist/application/validators/evaluators/handlers/governance-rule.handler.js +120 -0
- package/dist/application/validators/evaluators/handlers/governance-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/governance-rule.handler.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/handlers/governance-rule.handler.spec.js +107 -0
- package/dist/application/validators/evaluators/handlers/governance-rule.handler.spec.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/mcp-rule.handler.d.ts +12 -0
- package/dist/application/validators/evaluators/handlers/mcp-rule.handler.js +91 -0
- package/dist/application/validators/evaluators/handlers/mcp-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/mcp-rule.handler.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/handlers/mcp-rule.handler.spec.js +92 -0
- package/dist/application/validators/evaluators/handlers/mcp-rule.handler.spec.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/rule-handler.interface.d.ts +6 -0
- package/dist/application/validators/evaluators/handlers/rule-handler.interface.js +3 -0
- package/dist/application/validators/evaluators/handlers/rule-handler.interface.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/satellite-contract-rule.handler.d.ts +14 -0
- package/dist/application/validators/evaluators/handlers/satellite-contract-rule.handler.js +105 -0
- package/dist/application/validators/evaluators/handlers/satellite-contract-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/sdlc-rule.handler.d.ts +12 -0
- package/dist/application/validators/evaluators/handlers/sdlc-rule.handler.js +81 -0
- package/dist/application/validators/evaluators/handlers/sdlc-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.d.ts +13 -0
- package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.js +136 -0
- package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.js.map +1 -0
- package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.spec.js +96 -0
- package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.spec.js.map +1 -0
- package/dist/application/validators/evaluators/native-evaluator.d.ts +12 -0
- package/dist/application/validators/evaluators/native-evaluator.js +63 -0
- package/dist/application/validators/evaluators/native-evaluator.js.map +1 -0
- package/dist/application/validators/evaluators/opa-evaluator.d.ts +14 -0
- package/dist/application/validators/evaluators/opa-evaluator.js +151 -0
- package/dist/application/validators/evaluators/opa-evaluator.js.map +1 -0
- package/dist/application/validators/evaluators/opa-evaluator.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/opa-evaluator.spec.js +96 -0
- package/dist/application/validators/evaluators/opa-evaluator.spec.js.map +1 -0
- package/dist/application/validators/evaluators/opa-input-builder.d.ts +27 -0
- package/dist/application/validators/evaluators/opa-input-builder.js +357 -0
- package/dist/application/validators/evaluators/opa-input-builder.js.map +1 -0
- package/dist/application/validators/evaluators/opa-input-builder.spec.d.ts +1 -0
- package/dist/application/validators/evaluators/opa-input-builder.spec.js +138 -0
- package/dist/application/validators/evaluators/opa-input-builder.spec.js.map +1 -0
- package/dist/application/validators/evidence-validator.d.ts +13 -0
- package/dist/application/validators/evidence-validator.js +195 -0
- package/dist/application/validators/evidence-validator.js.map +1 -0
- package/dist/application/validators/index.d.ts +4 -0
- package/dist/application/validators/index.js +21 -0
- package/dist/application/validators/index.js.map +1 -0
- package/dist/application/validators/modes/adhoc-validation.mode.d.ts +8 -0
- package/dist/application/validators/modes/adhoc-validation.mode.js +156 -0
- package/dist/application/validators/modes/adhoc-validation.mode.js.map +1 -0
- package/dist/application/validators/modes/adr-validation.mode.d.ts +7 -0
- package/dist/application/validators/modes/adr-validation.mode.js +183 -0
- package/dist/application/validators/modes/adr-validation.mode.js.map +1 -0
- package/dist/application/validators/modes/architecture-validation.mode.d.ts +7 -0
- package/dist/application/validators/modes/architecture-validation.mode.js +154 -0
- package/dist/application/validators/modes/architecture-validation.mode.js.map +1 -0
- package/dist/application/validators/modes/composable-validation-engine.d.ts +20 -0
- package/dist/application/validators/modes/composable-validation-engine.js +110 -0
- package/dist/application/validators/modes/composable-validation-engine.js.map +1 -0
- package/dist/application/validators/modes/index.d.ts +7 -0
- package/dist/application/validators/modes/index.js +16 -0
- package/dist/application/validators/modes/index.js.map +1 -0
- package/dist/application/validators/modes/ruleset-validation.mode.d.ts +6 -0
- package/dist/application/validators/modes/ruleset-validation.mode.js +143 -0
- package/dist/application/validators/modes/ruleset-validation.mode.js.map +1 -0
- package/dist/application/validators/modes/sdlc-validation.mode.d.ts +7 -0
- package/dist/application/validators/modes/sdlc-validation.mode.js +151 -0
- package/dist/application/validators/modes/sdlc-validation.mode.js.map +1 -0
- package/dist/application/validators/modes/validation-mode.interface.d.ts +34 -0
- package/dist/application/validators/modes/validation-mode.interface.js +3 -0
- package/dist/application/validators/modes/validation-mode.interface.js.map +1 -0
- package/dist/application/validators/phase-gate-validator.service.d.ts +77 -0
- package/dist/application/validators/phase-gate-validator.service.js +183 -0
- package/dist/application/validators/phase-gate-validator.service.js.map +1 -0
- package/dist/application/validators/phase-gate-validator.service.spec.d.ts +1 -0
- package/dist/application/validators/phase-gate-validator.service.spec.js +383 -0
- package/dist/application/validators/phase-gate-validator.service.spec.js.map +1 -0
- package/dist/application/validators/rule-evaluation-engine.d.ts +29 -0
- package/dist/application/validators/rule-evaluation-engine.js +41 -0
- package/dist/application/validators/rule-evaluation-engine.js.map +1 -0
- package/dist/application/validators/ruleset-id-loader.d.ts +3 -0
- package/dist/application/validators/ruleset-id-loader.js +109 -0
- package/dist/application/validators/ruleset-id-loader.js.map +1 -0
- package/dist/application/validators/ruleset-loader.d.ts +13 -0
- package/dist/application/validators/ruleset-loader.js +83 -0
- package/dist/application/validators/ruleset-loader.js.map +1 -0
- package/dist/application/validators/ruleset-validator-architecture.spec.d.ts +1 -0
- package/dist/application/validators/ruleset-validator-architecture.spec.js +174 -0
- package/dist/application/validators/ruleset-validator-architecture.spec.js.map +1 -0
- package/dist/application/validators/ruleset-validator.service.d.ts +18 -0
- package/dist/application/validators/ruleset-validator.service.js +154 -0
- package/dist/application/validators/ruleset-validator.service.js.map +1 -0
- package/dist/application/validators/ruleset-validator.types.d.ts +57 -0
- package/dist/application/validators/ruleset-validator.types.js +5 -0
- package/dist/application/validators/ruleset-validator.types.js.map +1 -0
- package/dist/common/request-context.d.ts +10 -0
- package/dist/common/request-context.js +14 -0
- package/dist/common/request-context.js.map +1 -0
- package/dist/domain/audit/audit-entry.d.ts +19 -0
- package/dist/domain/audit/audit-entry.js +3 -0
- package/dist/domain/audit/audit-entry.js.map +1 -0
- package/dist/domain/audit/audit-repository.port.d.ts +6 -0
- package/dist/domain/audit/audit-repository.port.js +3 -0
- package/dist/domain/audit/audit-repository.port.js.map +1 -0
- package/dist/domain/audit/index.d.ts +2 -0
- package/dist/domain/audit/index.js +19 -0
- package/dist/domain/audit/index.js.map +1 -0
- package/dist/domain/entities/blueprint.d.ts +41 -0
- package/dist/domain/entities/blueprint.js +82 -0
- package/dist/domain/entities/blueprint.js.map +1 -0
- package/dist/domain/entities/index.d.ts +73 -0
- package/dist/domain/entities/index.js +134 -0
- package/dist/domain/entities/index.js.map +1 -0
- package/dist/domain/errors/gate-authorization.error.d.ts +9 -0
- package/dist/domain/errors/gate-authorization.error.js +17 -0
- package/dist/domain/errors/gate-authorization.error.js.map +1 -0
- package/dist/domain/errors/index.d.ts +29 -0
- package/dist/domain/errors/index.js +73 -0
- package/dist/domain/errors/index.js.map +1 -0
- package/dist/domain/events/domain-event.d.ts +9 -0
- package/dist/domain/events/domain-event.js +14 -0
- package/dist/domain/events/domain-event.js.map +1 -0
- package/dist/domain/events/domain-events.d.ts +99 -0
- package/dist/domain/events/domain-events.js +49 -0
- package/dist/domain/events/domain-events.js.map +1 -0
- package/dist/domain/events/event-catalog.d.ts +7 -0
- package/dist/domain/events/event-catalog.js +82 -0
- package/dist/domain/events/event-catalog.js.map +1 -0
- package/dist/domain/events/index.d.ts +4 -0
- package/dist/domain/events/index.js +21 -0
- package/dist/domain/events/index.js.map +1 -0
- package/dist/domain/gate-evidence.d.ts +70 -0
- package/dist/domain/gate-evidence.js +46 -0
- package/dist/domain/gate-evidence.js.map +1 -0
- package/dist/domain/gate-evidence.spec.d.ts +1 -0
- package/dist/domain/gate-evidence.spec.js +173 -0
- package/dist/domain/gate-evidence.spec.js.map +1 -0
- package/dist/domain/index.d.ts +12 -0
- package/dist/domain/index.js +29 -0
- package/dist/domain/index.js.map +1 -0
- package/dist/domain/interfaces.d.ts +301 -0
- package/dist/domain/interfaces.js +5 -0
- package/dist/domain/interfaces.js.map +1 -0
- package/dist/domain/lifecycle/artifact-state-machine.d.ts +23 -0
- package/dist/domain/lifecycle/artifact-state-machine.js +50 -0
- package/dist/domain/lifecycle/artifact-state-machine.js.map +1 -0
- package/dist/domain/lifecycle/index.d.ts +2 -0
- package/dist/domain/lifecycle/index.js +19 -0
- package/dist/domain/lifecycle/index.js.map +1 -0
- package/dist/domain/lifecycle/phase-state-machine.d.ts +24 -0
- package/dist/domain/lifecycle/phase-state-machine.js +50 -0
- package/dist/domain/lifecycle/phase-state-machine.js.map +1 -0
- package/dist/domain/metrics/dora-calculator.d.ts +18 -0
- package/dist/domain/metrics/dora-calculator.js +146 -0
- package/dist/domain/metrics/dora-calculator.js.map +1 -0
- package/dist/domain/metrics/dora-calculator.spec.d.ts +1 -0
- package/dist/domain/metrics/dora-calculator.spec.js +172 -0
- package/dist/domain/metrics/dora-calculator.spec.js.map +1 -0
- package/dist/domain/metrics/git-log-reader.d.ts +14 -0
- package/dist/domain/metrics/git-log-reader.js +39 -0
- package/dist/domain/metrics/git-log-reader.js.map +1 -0
- package/dist/domain/metrics/git-log-reader.spec.d.ts +8 -0
- package/dist/domain/metrics/git-log-reader.spec.js +121 -0
- package/dist/domain/metrics/git-log-reader.spec.js.map +1 -0
- package/dist/domain/metrics/index.d.ts +2 -0
- package/dist/domain/metrics/index.js +19 -0
- package/dist/domain/metrics/index.js.map +1 -0
- package/dist/domain/models/normalized-rule.d.ts +10 -0
- package/dist/domain/models/normalized-rule.js +3 -0
- package/dist/domain/models/normalized-rule.js.map +1 -0
- package/dist/domain/ports/index.d.ts +2 -0
- package/dist/domain/ports/index.js +19 -0
- package/dist/domain/ports/index.js.map +1 -0
- package/dist/domain/ports/ruleset-repository.port.d.ts +4 -0
- package/dist/domain/ports/ruleset-repository.port.js +3 -0
- package/dist/domain/ports/ruleset-repository.port.js.map +1 -0
- package/dist/domain/ports/workflow-definition.port.d.ts +24 -0
- package/dist/domain/ports/workflow-definition.port.js +3 -0
- package/dist/domain/ports/workflow-definition.port.js.map +1 -0
- package/dist/domain/rbac/gate-role-enforcer.d.ts +16 -0
- package/dist/domain/rbac/gate-role-enforcer.js +46 -0
- package/dist/domain/rbac/gate-role-enforcer.js.map +1 -0
- package/dist/domain/rbac/index.d.ts +1 -0
- package/dist/domain/rbac/index.js +12 -0
- package/dist/domain/rbac/index.js.map +1 -0
- package/dist/domain/rbac/role.d.ts +19 -0
- package/dist/domain/rbac/role.js +79 -0
- package/dist/domain/rbac/role.js.map +1 -0
- package/dist/domain/satellite-manifest.d.ts +44 -0
- package/dist/domain/satellite-manifest.js +3 -0
- package/dist/domain/satellite-manifest.js.map +1 -0
- package/dist/domain/services/adr.service.d.ts +50 -0
- package/dist/domain/services/adr.service.js +129 -0
- package/dist/domain/services/adr.service.js.map +1 -0
- package/dist/domain/services/adr.service.spec.d.ts +1 -0
- package/dist/domain/services/adr.service.spec.js +141 -0
- package/dist/domain/services/adr.service.spec.js.map +1 -0
- package/dist/domain/services/default-workflow-definition.d.ts +40 -0
- package/dist/domain/services/default-workflow-definition.js +94 -0
- package/dist/domain/services/default-workflow-definition.js.map +1 -0
- package/dist/domain/services/index.d.ts +37 -0
- package/dist/domain/services/index.js +110 -0
- package/dist/domain/services/index.js.map +1 -0
- package/dist/domain/services/standards.service.d.ts +47 -0
- package/dist/domain/services/standards.service.js +129 -0
- package/dist/domain/services/standards.service.js.map +1 -0
- package/dist/domain/services/standards.service.spec.d.ts +1 -0
- package/dist/domain/services/standards.service.spec.js +600 -0
- package/dist/domain/services/standards.service.spec.js.map +1 -0
- package/dist/domain/verdict/index.d.ts +1 -0
- package/dist/domain/verdict/index.js +18 -0
- package/dist/domain/verdict/index.js.map +1 -0
- package/dist/domain/verdict/verdict.d.ts +22 -0
- package/dist/domain/verdict/verdict.js +50 -0
- package/dist/domain/verdict/verdict.js.map +1 -0
- package/dist/domain/webhook/webhook-subscription.d.ts +27 -0
- package/dist/domain/webhook/webhook-subscription.js +9 -0
- package/dist/domain/webhook/webhook-subscription.js.map +1 -0
- package/dist/domain/workflow/index.d.ts +1 -0
- package/dist/domain/workflow/index.js +18 -0
- package/dist/domain/workflow/index.js.map +1 -0
- package/dist/domain/workflow/workflow-definition.d.ts +33 -0
- package/dist/domain/workflow/workflow-definition.js +3 -0
- package/dist/domain/workflow/workflow-definition.js.map +1 -0
- package/dist/evidence/evidence-graph.d.ts +29 -0
- package/dist/evidence/evidence-graph.js +27 -0
- package/dist/evidence/evidence-graph.js.map +1 -0
- package/dist/evidence/index.d.ts +1 -0
- package/dist/evidence/index.js +18 -0
- package/dist/evidence/index.js.map +1 -0
- package/dist/gates/decision/gate-decision.d.ts +18 -0
- package/dist/gates/decision/gate-decision.js +23 -0
- package/dist/gates/decision/gate-decision.js.map +1 -0
- package/dist/gates/decision/index.d.ts +1 -0
- package/dist/gates/decision/index.js +18 -0
- package/dist/gates/decision/index.js.map +1 -0
- package/dist/gates/gate-evaluator.d.ts +15 -0
- package/dist/gates/gate-evaluator.js +37 -0
- package/dist/gates/gate-evaluator.js.map +1 -0
- package/dist/gates/index.d.ts +1 -0
- package/dist/gates/index.js +18 -0
- package/dist/gates/index.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +19 -0
- package/dist/index.js.map +1 -0
- package/dist/infrastructure/audit/in-memory-audit-repository.d.ts +10 -0
- package/dist/infrastructure/audit/in-memory-audit-repository.js +44 -0
- package/dist/infrastructure/audit/in-memory-audit-repository.js.map +1 -0
- package/dist/infrastructure/audit/index.d.ts +2 -0
- package/dist/infrastructure/audit/index.js +19 -0
- package/dist/infrastructure/audit/index.js.map +1 -0
- package/dist/infrastructure/audit/jsonl-audit-repository.d.ts +12 -0
- package/dist/infrastructure/audit/jsonl-audit-repository.js +103 -0
- package/dist/infrastructure/audit/jsonl-audit-repository.js.map +1 -0
- package/dist/infrastructure/events/in-memory-event-bus.d.ts +9 -0
- package/dist/infrastructure/events/in-memory-event-bus.js +25 -0
- package/dist/infrastructure/events/in-memory-event-bus.js.map +1 -0
- package/dist/infrastructure/events/index.d.ts +4 -0
- package/dist/infrastructure/events/index.js +21 -0
- package/dist/infrastructure/events/index.js.map +1 -0
- package/dist/infrastructure/events/outbox.d.ts +27 -0
- package/dist/infrastructure/events/outbox.js +43 -0
- package/dist/infrastructure/events/outbox.js.map +1 -0
- package/dist/infrastructure/webhook/hmac-signer.d.ts +6 -0
- package/dist/infrastructure/webhook/hmac-signer.js +25 -0
- package/dist/infrastructure/webhook/hmac-signer.js.map +1 -0
- package/dist/infrastructure/webhook/in-memory-delivery-repository.d.ts +10 -0
- package/dist/infrastructure/webhook/in-memory-delivery-repository.js +25 -0
- package/dist/infrastructure/webhook/in-memory-delivery-repository.js.map +1 -0
- package/dist/infrastructure/webhook/in-memory-subscription-repository.d.ts +11 -0
- package/dist/infrastructure/webhook/in-memory-subscription-repository.js +28 -0
- package/dist/infrastructure/webhook/in-memory-subscription-repository.js.map +1 -0
- package/dist/infrastructure/webhook/index.d.ts +4 -0
- package/dist/infrastructure/webhook/index.js +21 -0
- package/dist/infrastructure/webhook/index.js.map +1 -0
- package/dist/infrastructure/webhook/webhook-dispatcher.d.ts +13 -0
- package/dist/infrastructure/webhook/webhook-dispatcher.js +91 -0
- package/dist/infrastructure/webhook/webhook-dispatcher.js.map +1 -0
- package/dist/phases/index.d.ts +1 -0
- package/dist/phases/index.js +18 -0
- package/dist/phases/index.js.map +1 -0
- package/dist/phases/phase-transition.d.ts +19 -0
- package/dist/phases/phase-transition.js +31 -0
- package/dist/phases/phase-transition.js.map +1 -0
- package/dist/phases/transition/index.d.ts +1 -0
- package/dist/phases/transition/index.js +18 -0
- package/dist/phases/transition/index.js.map +1 -0
- package/dist/phases/transition/phase-transition.model.d.ts +13 -0
- package/dist/phases/transition/phase-transition.model.js +21 -0
- package/dist/phases/transition/phase-transition.model.js.map +1 -0
- package/dist/providers/index.d.ts +1 -0
- package/dist/providers/index.js +18 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/providers/provider.ports.d.ts +39 -0
- package/dist/providers/provider.ports.js +18 -0
- package/dist/providers/provider.ports.js.map +1 -0
- package/dist/tenancy/index.d.ts +1 -0
- package/dist/tenancy/index.js +18 -0
- package/dist/tenancy/index.js.map +1 -0
- package/dist/tenancy/tenant-authority.d.ts +22 -0
- package/dist/tenancy/tenant-authority.js +31 -0
- package/dist/tenancy/tenant-authority.js.map +1 -0
- package/package.json +80 -0
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ValidationContext, ValidationMode, ModeValidationResult } from './validation-mode.interface';
|
|
2
|
+
export declare class AdrValidationMode implements ValidationMode {
|
|
3
|
+
readonly name: "adr";
|
|
4
|
+
canHandle(context: ValidationContext): boolean;
|
|
5
|
+
validate(context: ValidationContext): Promise<ModeValidationResult>;
|
|
6
|
+
private findAdrDocument;
|
|
7
|
+
}
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.AdrValidationMode = void 0;
|
|
37
|
+
const ADR_IDS = [
|
|
38
|
+
'adr-0002',
|
|
39
|
+
'adr-0005',
|
|
40
|
+
'adr-0010',
|
|
41
|
+
'adr-0018',
|
|
42
|
+
'adr-0032',
|
|
43
|
+
'adr-0040',
|
|
44
|
+
'adr-0050',
|
|
45
|
+
];
|
|
46
|
+
const ADR_RULESET_MAP = {
|
|
47
|
+
'adr-0002': 'rulesets/adr/adr-0002-hexagonal-architecture.rules.json',
|
|
48
|
+
'adr-0005': 'rulesets/adr/adr-0005-cicd-quality-gates.rules.json',
|
|
49
|
+
'adr-0010': 'rulesets/adr/adr-0010-multi-tenancy.rules.json',
|
|
50
|
+
'adr-0018': 'rulesets/adr/adr-0018-testing-pyramid.rules.json',
|
|
51
|
+
'adr-0032': 'rulesets/adr/adr-0032-protocol-selection.rules.json',
|
|
52
|
+
'adr-0040': 'rulesets/adr/adr-0040-multi-runtime.rules.json',
|
|
53
|
+
'adr-0050': 'rulesets/adr/adr-0050-gitflow-branching.rules.json',
|
|
54
|
+
};
|
|
55
|
+
class AdrValidationMode {
|
|
56
|
+
constructor() {
|
|
57
|
+
this.name = 'adr';
|
|
58
|
+
}
|
|
59
|
+
canHandle(context) {
|
|
60
|
+
return !!(context.adrId);
|
|
61
|
+
}
|
|
62
|
+
async validate(context) {
|
|
63
|
+
const issues = [];
|
|
64
|
+
let rulesChecked = 0;
|
|
65
|
+
try {
|
|
66
|
+
const { promises: fs } = await Promise.resolve().then(() => __importStar(require('fs')));
|
|
67
|
+
const path = await Promise.resolve().then(() => __importStar(require('path')));
|
|
68
|
+
const adrId = context.adrId;
|
|
69
|
+
if (!ADR_IDS.includes(adrId)) {
|
|
70
|
+
return {
|
|
71
|
+
mode: 'adr',
|
|
72
|
+
status: 'failed',
|
|
73
|
+
rulesChecked: 0,
|
|
74
|
+
metadata: {
|
|
75
|
+
adrId,
|
|
76
|
+
},
|
|
77
|
+
issues: [{
|
|
78
|
+
ruleId: 'ADR_UNKNOWN',
|
|
79
|
+
status: 'fail',
|
|
80
|
+
message: `Unknown ADR '${adrId}'. Supported: ${ADR_IDS.join(', ')}`,
|
|
81
|
+
severity: 'error',
|
|
82
|
+
}],
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
const rulesetPath = ADR_RULESET_MAP[adrId];
|
|
86
|
+
const fullRulesetPath = path.join(context.corePath || context.satellitePath, rulesetPath);
|
|
87
|
+
let rulesetContent;
|
|
88
|
+
try {
|
|
89
|
+
rulesetContent = await fs.readFile(fullRulesetPath, 'utf-8');
|
|
90
|
+
}
|
|
91
|
+
catch {
|
|
92
|
+
return {
|
|
93
|
+
mode: 'adr',
|
|
94
|
+
status: 'failed',
|
|
95
|
+
rulesChecked: 0,
|
|
96
|
+
metadata: {
|
|
97
|
+
adrId,
|
|
98
|
+
},
|
|
99
|
+
issues: [{
|
|
100
|
+
ruleId: 'ADR_RULESET_NOT_FOUND',
|
|
101
|
+
status: 'fail',
|
|
102
|
+
message: `ADR ruleset for '${adrId}' not found at ${rulesetPath}`,
|
|
103
|
+
severity: 'error',
|
|
104
|
+
remediation: `Create ruleset for ${adrId}`,
|
|
105
|
+
}],
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
const ruleset = JSON.parse(rulesetContent);
|
|
109
|
+
const rules = ruleset.rules || [];
|
|
110
|
+
for (const rule of rules) {
|
|
111
|
+
rulesChecked++;
|
|
112
|
+
issues.push({
|
|
113
|
+
ruleId: rule.id || `ADR-${adrId}-${rules.indexOf(rule)}`,
|
|
114
|
+
status: 'pass',
|
|
115
|
+
message: `ADR rule '${rule.id || rule.title}' loaded and registered`,
|
|
116
|
+
severity: 'info',
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
const adrDocPath = await this.findAdrDocument(adrId, context);
|
|
120
|
+
if (adrDocPath) {
|
|
121
|
+
rulesChecked++;
|
|
122
|
+
issues.push({
|
|
123
|
+
ruleId: `ADR-DOC-${adrId.toUpperCase()}`,
|
|
124
|
+
status: 'pass',
|
|
125
|
+
message: `ADR document exists: ${adrDocPath}`,
|
|
126
|
+
severity: 'info',
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
else {
|
|
130
|
+
rulesChecked++;
|
|
131
|
+
issues.push({
|
|
132
|
+
ruleId: `ADR-DOC-${adrId.toUpperCase()}`,
|
|
133
|
+
status: 'fail',
|
|
134
|
+
message: `ADR document not found for '${adrId}'`,
|
|
135
|
+
severity: 'warning',
|
|
136
|
+
remediation: `Create ADR document for ${adrId}`,
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
catch (error) {
|
|
141
|
+
issues.push({
|
|
142
|
+
ruleId: 'ADR_VALIDATION_ERROR',
|
|
143
|
+
status: 'fail',
|
|
144
|
+
message: `ADR validation error: ${error.message}`,
|
|
145
|
+
severity: 'error',
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
const hasFailures = issues.some(i => i.status === 'fail');
|
|
149
|
+
return {
|
|
150
|
+
mode: 'adr',
|
|
151
|
+
status: hasFailures ? 'failed' : 'passed',
|
|
152
|
+
rulesChecked,
|
|
153
|
+
issues,
|
|
154
|
+
metadata: {
|
|
155
|
+
adrId: context.adrId,
|
|
156
|
+
},
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
async findAdrDocument(adrId, context) {
|
|
160
|
+
const { promises: fs } = await Promise.resolve().then(() => __importStar(require('fs')));
|
|
161
|
+
const path = await Promise.resolve().then(() => __importStar(require('path')));
|
|
162
|
+
const possiblePaths = [
|
|
163
|
+
path.join(context.corePath || context.satellitePath, 'reference', 'architecture', 'adrs'),
|
|
164
|
+
path.join(context.satellitePath, 'docs', 'adrs'),
|
|
165
|
+
];
|
|
166
|
+
const adrNumber = adrId.replace('adr-', '');
|
|
167
|
+
for (const dir of possiblePaths) {
|
|
168
|
+
try {
|
|
169
|
+
const files = await fs.readdir(dir);
|
|
170
|
+
const match = files.find(f => f.includes(adrNumber) || f.includes(adrId));
|
|
171
|
+
if (match) {
|
|
172
|
+
return path.join(dir, match);
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
catch {
|
|
176
|
+
continue;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
return null;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
exports.AdrValidationMode = AdrValidationMode;
|
|
183
|
+
//# sourceMappingURL=adr-validation.mode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adr-validation.mode.js","sourceRoot":"","sources":["../../../../src/application/validators/modes/adr-validation.mode.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { ValidationContext, ValidationMode, ModeValidationResult } from './validation-mode.interface';
|
|
2
|
+
export declare class ArchitectureValidationMode implements ValidationMode {
|
|
3
|
+
readonly name: "architecture";
|
|
4
|
+
canHandle(context: ValidationContext): boolean;
|
|
5
|
+
validate(context: ValidationContext): Promise<ModeValidationResult>;
|
|
6
|
+
private evaluateComplianceCheck;
|
|
7
|
+
}
|
|
@@ -0,0 +1,154 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
36
|
+
exports.ArchitectureValidationMode = void 0;
|
|
37
|
+
class ArchitectureValidationMode {
|
|
38
|
+
constructor() {
|
|
39
|
+
this.name = 'architecture';
|
|
40
|
+
}
|
|
41
|
+
canHandle(context) {
|
|
42
|
+
return !!(context.topology);
|
|
43
|
+
}
|
|
44
|
+
async validate(context) {
|
|
45
|
+
const issues = [];
|
|
46
|
+
let rulesChecked = 0;
|
|
47
|
+
try {
|
|
48
|
+
const { promises: fs } = await Promise.resolve().then(() => __importStar(require('fs')));
|
|
49
|
+
const path = await Promise.resolve().then(() => __importStar(require('path')));
|
|
50
|
+
const topologyId = context.topology;
|
|
51
|
+
const manifestPath = path.join(context.corePath || context.satellitePath, 'reference', 'architecture', 'topologies', topologyId, 'topology.manifest.json');
|
|
52
|
+
let manifestContent;
|
|
53
|
+
try {
|
|
54
|
+
manifestContent = await fs.readFile(manifestPath, 'utf-8');
|
|
55
|
+
}
|
|
56
|
+
catch {
|
|
57
|
+
return {
|
|
58
|
+
mode: 'architecture',
|
|
59
|
+
status: 'failed',
|
|
60
|
+
rulesChecked: 0,
|
|
61
|
+
metadata: {
|
|
62
|
+
topology: topologyId,
|
|
63
|
+
},
|
|
64
|
+
issues: [{
|
|
65
|
+
ruleId: 'TOPOLOGY_NOT_FOUND',
|
|
66
|
+
status: 'fail',
|
|
67
|
+
message: `Topology '${topologyId}' not found in topology catalog`,
|
|
68
|
+
severity: 'error',
|
|
69
|
+
remediation: `Create topology.manifest.json for '${topologyId}'`,
|
|
70
|
+
}],
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
const manifest = JSON.parse(manifestContent);
|
|
74
|
+
const rulesets = manifest.spec?.artifacts?.rulesets || [];
|
|
75
|
+
for (const rulesetPath of rulesets) {
|
|
76
|
+
rulesChecked++;
|
|
77
|
+
const fullRulesetPath = path.join(context.corePath || context.satellitePath, rulesetPath);
|
|
78
|
+
try {
|
|
79
|
+
await fs.access(fullRulesetPath);
|
|
80
|
+
issues.push({
|
|
81
|
+
ruleId: `ARCH-RULESET-${rulesetPath}`,
|
|
82
|
+
status: 'pass',
|
|
83
|
+
message: `Ruleset exists: ${rulesetPath}`,
|
|
84
|
+
severity: 'info',
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
catch {
|
|
88
|
+
issues.push({
|
|
89
|
+
ruleId: `ARCH-RULESET-${rulesetPath}`,
|
|
90
|
+
status: 'fail',
|
|
91
|
+
message: `Ruleset not found: ${rulesetPath}`,
|
|
92
|
+
severity: 'error',
|
|
93
|
+
remediation: `Create ruleset at ${rulesetPath}`,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
const complianceChecks = [
|
|
98
|
+
{ id: 'HEXAGONAL_LIMITS', name: 'Hexagonal architecture limits' },
|
|
99
|
+
{ id: 'DOMAIN_ISOLATION', name: 'Domain layer isolation' },
|
|
100
|
+
{ id: 'MULTI_TENANCY', name: 'Multi-tenancy enforcement' },
|
|
101
|
+
{ id: 'BOUNDARY_CONTEXTS', name: 'Bounded context boundaries' },
|
|
102
|
+
];
|
|
103
|
+
for (const check of complianceChecks) {
|
|
104
|
+
rulesChecked++;
|
|
105
|
+
const result = await this.evaluateComplianceCheck(check.id, context);
|
|
106
|
+
issues.push({
|
|
107
|
+
ruleId: check.id,
|
|
108
|
+
status: result.passed ? 'pass' : 'fail',
|
|
109
|
+
message: result.passed
|
|
110
|
+
? `${check.name}: compliant`
|
|
111
|
+
: `${check.name}: non-compliant - ${result.reason}`,
|
|
112
|
+
severity: result.passed ? 'info' : 'warning',
|
|
113
|
+
remediation: result.passed ? undefined : `Review ${check.name.toLowerCase()}`,
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
catch (error) {
|
|
118
|
+
issues.push({
|
|
119
|
+
ruleId: 'ARCHITECTURE_VALIDATION_ERROR',
|
|
120
|
+
status: 'fail',
|
|
121
|
+
message: `Architecture validation error: ${error.message}`,
|
|
122
|
+
severity: 'error',
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
const hasFailures = issues.some(i => i.status === 'fail');
|
|
126
|
+
const hasWarnings = issues.some(i => i.severity === 'warning');
|
|
127
|
+
return {
|
|
128
|
+
mode: 'architecture',
|
|
129
|
+
status: hasFailures ? 'failed' : hasWarnings ? 'warning' : 'passed',
|
|
130
|
+
rulesChecked,
|
|
131
|
+
issues,
|
|
132
|
+
metadata: {
|
|
133
|
+
topology: context.topology,
|
|
134
|
+
},
|
|
135
|
+
};
|
|
136
|
+
}
|
|
137
|
+
async evaluateComplianceCheck(checkId, context) {
|
|
138
|
+
const { promises: fs } = await Promise.resolve().then(() => __importStar(require('fs')));
|
|
139
|
+
const path = await Promise.resolve().then(() => __importStar(require('path')));
|
|
140
|
+
try {
|
|
141
|
+
const srcPath = path.join(context.satellitePath, 'src');
|
|
142
|
+
await fs.access(srcPath);
|
|
143
|
+
return { passed: true };
|
|
144
|
+
}
|
|
145
|
+
catch {
|
|
146
|
+
return {
|
|
147
|
+
passed: false,
|
|
148
|
+
reason: 'src directory not found - cannot validate architecture compliance',
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
exports.ArchitectureValidationMode = ArchitectureValidationMode;
|
|
154
|
+
//# sourceMappingURL=architecture-validation.mode.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"architecture-validation.mode.js","sourceRoot":"","sources":["../../../../src/application/validators/modes/architecture-validation.mode.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAOA,MAAa,0BAA0B;IAAvC;QACW,SAAI,GAAG,cAAuB,CAAC;IAoI1C,CAAC;IAlIC,SAAS,CAAC,OAA0B;QAClC,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,OAA0B;QACvC,MAAM,MAAM,GAA0B,EAAE,CAAC;QACzC,IAAI,YAAY,GAAG,CAAC,CAAC;QAErB,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,GAAG,wDAAa,IAAI,GAAC,CAAC;YAC5C,MAAM,IAAI,GAAG,wDAAa,MAAM,GAAC,CAAC;YAElC,MAAM,UAAU,GAAG,OAAO,CAAC,QAAS,CAAC;YACrC,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAC5B,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,aAAa,EACzC,WAAW,EAAE,cAAc,EAAE,YAAY,EAAE,UAAU,EAAE,wBAAwB,CAChF,CAAC;YAEF,IAAI,eAAuB,CAAC;YAC5B,IAAI,CAAC;gBACH,eAAe,GAAG,MAAM,EAAE,CAAC,QAAQ,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;YAC7D,CAAC;YAAC,MAAM,CAAC;gBACP,OAAO;oBACL,IAAI,EAAE,cAAc;oBACpB,MAAM,EAAE,QAAQ;oBAChB,YAAY,EAAE,CAAC;oBACf,QAAQ,EAAE;wBACR,QAAQ,EAAE,UAAU;qBACrB;oBACD,MAAM,EAAE,CAAC;4BACP,MAAM,EAAE,oBAAoB;4BAC5B,MAAM,EAAE,MAAM;4BACd,OAAO,EAAE,aAAa,UAAU,iCAAiC;4BACjE,QAAQ,EAAE,OAAO;4BACjB,WAAW,EAAE,sCAAsC,UAAU,GAAG;yBACjE,CAAC;iBACH,CAAC;YACJ,CAAC;YAED,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;YAC7C,MAAM,QAAQ,GAAG,QAAQ,CAAC,IAAI,EAAE,SAAS,EAAE,QAAQ,IAAI,EAAE,CAAC;YAE1D,KAAK,MAAM,WAAW,IAAI,QAAQ,EAAE,CAAC;gBACnC,YAAY,EAAE,CAAC;gBACf,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAC/B,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,aAAa,EACzC,WAAW,CACZ,CAAC;gBAEF,IAAI,CAAC;oBACH,MAAM,EAAE,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;oBACjC,MAAM,CAAC,IAAI,CAAC;wBACV,MAAM,EAAE,gBAAgB,WAAW,EAAE;wBACrC,MAAM,EAAE,MAAM;wBACd,OAAO,EAAE,mBAAmB,WAAW,EAAE;wBACzC,QAAQ,EAAE,MAAM;qBACjB,CAAC,CAAC;gBACL,CAAC;gBAAC,MAAM,CAAC;oBACP,MAAM,CAAC,IAAI,CAAC;wBACV,MAAM,EAAE,gBAAgB,WAAW,EAAE;wBACrC,MAAM,EAAE,MAAM;wBACd,OAAO,EAAE,sBAAsB,WAAW,EAAE;wBAC5C,QAAQ,EAAE,OAAO;wBACjB,WAAW,EAAE,qBAAqB,WAAW,EAAE;qBAChD,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAED,MAAM,gBAAgB,GAAG;gBACvB,EAAE,EAAE,EAAE,kBAAkB,EAAE,IAAI,EAAE,+BAA+B,EAAE;gBACjE,EAAE,EAAE,EAAE,kBAAkB,EAAE,IAAI,EAAE,wBAAwB,EAAE;gBAC1D,EAAE,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE,2BAA2B,EAAE;gBAC1D,EAAE,EAAE,EAAE,mBAAmB,EAAE,IAAI,EAAE,4BAA4B,EAAE;aAChE,CAAC;YAEF,KAAK,MAAM,KAAK,IAAI,gBAAgB,EAAE,CAAC;gBACrC,YAAY,EAAE,CAAC;gBACf,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,uBAAuB,CAAC,KAAK,CAAC,EAAE,EAAE,OAAO,CAAC,CAAC;gBACrE,MAAM,CAAC,IAAI,CAAC;oBACV,MAAM,EAAE,KAAK,CAAC,EAAE;oBAChB,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM;oBACvC,OAAO,EAAE,MAAM,CAAC,MAAM;wBACpB,CAAC,CAAC,GAAG,KAAK,CAAC,IAAI,aAAa;wBAC5B,CAAC,CAAC,GAAG,KAAK,CAAC,IAAI,qBAAqB,MAAM,CAAC,MAAM,EAAE;oBACrD,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS;oBAC5C,WAAW,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,EAAE;iBAC9E,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,IAAI,CAAC;gBACV,MAAM,EAAE,+BAA+B;gBACvC,MAAM,EAAE,MAAM;gBACd,OAAO,EAAE,kCAAmC,KAAe,CAAC,OAAO,EAAE;gBACrE,QAAQ,EAAE,OAAO;aAClB,CAAC,CAAC;QACL,CAAC;QAED,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC;QAC1D,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC;QAE/D,OAAO;YACL,IAAI,EAAE,cAAc;YACpB,MAAM,EAAE,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ;YACnE,YAAY;YACZ,MAAM;YACN,QAAQ,EAAE;gBACR,QAAQ,EAAE,OAAO,CAAC,QAAQ;aAC3B;SACF,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,uBAAuB,CACnC,OAAe,EACf,OAA0B;QAE1B,MAAM,EAAE,QAAQ,EAAE,EAAE,EAAE,GAAG,wDAAa,IAAI,GAAC,CAAC;QAC5C,MAAM,IAAI,GAAG,wDAAa,MAAM,GAAC,CAAC;QAElC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;YACxD,MAAM,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC;YAEzB,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC;QAC1B,CAAC;QAAC,MAAM,CAAC;YACP,OAAO;gBACL,MAAM,EAAE,KAAK;gBACb,MAAM,EAAE,mEAAmE;aAC5E,CAAC;QACJ,CAAC;IACH,CAAC;CACF;AArID,gEAqIC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { ValidationContext, ValidationMode, ModeValidationResult } from './validation-mode.interface';
|
|
2
|
+
import { EvolithConfig } from '../../services/evolith-config.service';
|
|
3
|
+
export interface ComposableValidationResult {
|
|
4
|
+
status: 'passed' | 'failed' | 'warning';
|
|
5
|
+
modes: ModeValidationResult[];
|
|
6
|
+
totalRulesChecked: number;
|
|
7
|
+
totalIssues: number;
|
|
8
|
+
passedRules: number;
|
|
9
|
+
failedRules: number;
|
|
10
|
+
performanceMs: number;
|
|
11
|
+
config?: EvolithConfig;
|
|
12
|
+
}
|
|
13
|
+
export declare class ComposableValidationEngine {
|
|
14
|
+
private modes;
|
|
15
|
+
private configService;
|
|
16
|
+
constructor();
|
|
17
|
+
registerMode(mode: ValidationMode): void;
|
|
18
|
+
resolveModes(context: ValidationContext): ValidationMode[];
|
|
19
|
+
execute(context: ValidationContext): Promise<ComposableValidationResult>;
|
|
20
|
+
}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ComposableValidationEngine = void 0;
|
|
4
|
+
const evolith_config_service_1 = require("../../services/evolith-config.service");
|
|
5
|
+
class ComposableValidationEngine {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.modes = [];
|
|
8
|
+
this.configService = new evolith_config_service_1.EvolithConfigService();
|
|
9
|
+
}
|
|
10
|
+
registerMode(mode) {
|
|
11
|
+
this.modes.push(mode);
|
|
12
|
+
}
|
|
13
|
+
resolveModes(context) {
|
|
14
|
+
const resolved = [];
|
|
15
|
+
for (const mode of this.modes) {
|
|
16
|
+
if (mode.canHandle(context)) {
|
|
17
|
+
resolved.push(mode);
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
if (resolved.length === 0) {
|
|
21
|
+
return this.modes.filter(m => m.name === 'ruleset');
|
|
22
|
+
}
|
|
23
|
+
return resolved;
|
|
24
|
+
}
|
|
25
|
+
async execute(context) {
|
|
26
|
+
const startTime = Date.now();
|
|
27
|
+
let config;
|
|
28
|
+
try {
|
|
29
|
+
config = await this.configService.loadConfig(context.satellitePath);
|
|
30
|
+
}
|
|
31
|
+
catch {
|
|
32
|
+
}
|
|
33
|
+
const mergedContext = {
|
|
34
|
+
...context,
|
|
35
|
+
topology: context.topology || config?.topology,
|
|
36
|
+
phase: context.phase || config?.phase,
|
|
37
|
+
rulesetId: context.rulesetId || config?.rulesets?.[0],
|
|
38
|
+
adrId: context.adrId || config?.adrRules?.[0],
|
|
39
|
+
engine: context.engine || config?.engine || 'native',
|
|
40
|
+
};
|
|
41
|
+
const modesToRun = this.resolveModes(mergedContext);
|
|
42
|
+
const modeResults = [];
|
|
43
|
+
const shouldParallel = config?.validation?.parallel !== false;
|
|
44
|
+
const timeout = config?.validation?.timeout || 2000;
|
|
45
|
+
if (shouldParallel) {
|
|
46
|
+
const modePromises = modesToRun.map(mode => Promise.race([
|
|
47
|
+
mode.validate(mergedContext),
|
|
48
|
+
new Promise((_, reject) => setTimeout(() => reject(new Error(`Mode ${mode.name} timed out after ${timeout}ms`)), timeout)),
|
|
49
|
+
]));
|
|
50
|
+
const results = await Promise.allSettled(modePromises);
|
|
51
|
+
for (const result of results) {
|
|
52
|
+
if (result.status === 'fulfilled') {
|
|
53
|
+
modeResults.push(result.value);
|
|
54
|
+
}
|
|
55
|
+
else {
|
|
56
|
+
modeResults.push({
|
|
57
|
+
mode: 'adhoc',
|
|
58
|
+
status: 'failed',
|
|
59
|
+
rulesChecked: 0,
|
|
60
|
+
issues: [{
|
|
61
|
+
ruleId: 'MODE_EXECUTION_ERROR',
|
|
62
|
+
status: 'fail',
|
|
63
|
+
message: result.reason?.message || 'Mode execution failed',
|
|
64
|
+
severity: 'error',
|
|
65
|
+
}],
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
for (const mode of modesToRun) {
|
|
72
|
+
try {
|
|
73
|
+
const result = await mode.validate(mergedContext);
|
|
74
|
+
modeResults.push(result);
|
|
75
|
+
}
|
|
76
|
+
catch (error) {
|
|
77
|
+
modeResults.push({
|
|
78
|
+
mode: mode.name,
|
|
79
|
+
status: 'failed',
|
|
80
|
+
rulesChecked: 0,
|
|
81
|
+
issues: [{
|
|
82
|
+
ruleId: 'MODE_EXECUTION_ERROR',
|
|
83
|
+
status: 'fail',
|
|
84
|
+
message: error.message || 'Mode execution failed',
|
|
85
|
+
severity: 'error',
|
|
86
|
+
}],
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
const totalRulesChecked = modeResults.reduce((sum, r) => sum + r.rulesChecked, 0);
|
|
92
|
+
const totalIssues = modeResults.reduce((sum, r) => sum + r.issues.length, 0);
|
|
93
|
+
const failedRules = modeResults.reduce((sum, r) => sum + r.issues.filter(i => i.status === 'fail').length, 0);
|
|
94
|
+
const passedRules = totalRulesChecked - failedRules;
|
|
95
|
+
const hasFailures = modeResults.some(r => r.status === 'failed');
|
|
96
|
+
const hasWarnings = modeResults.some(r => r.status === 'warning');
|
|
97
|
+
return {
|
|
98
|
+
status: hasFailures ? 'failed' : hasWarnings ? 'warning' : 'passed',
|
|
99
|
+
modes: modeResults,
|
|
100
|
+
totalRulesChecked,
|
|
101
|
+
totalIssues,
|
|
102
|
+
passedRules,
|
|
103
|
+
failedRules,
|
|
104
|
+
performanceMs: Date.now() - startTime,
|
|
105
|
+
config,
|
|
106
|
+
};
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
exports.ComposableValidationEngine = ComposableValidationEngine;
|
|
110
|
+
//# sourceMappingURL=composable-validation-engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"composable-validation-engine.js","sourceRoot":"","sources":["../../../../src/application/validators/modes/composable-validation-engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export { ValidationMode, ValidationModeName, ValidationContext, ModeValidationResult, ModeValidationIssue } from './validation-mode.interface';
|
|
2
|
+
export { ComposableValidationEngine, ComposableValidationResult } from './composable-validation-engine';
|
|
3
|
+
export { SdlcValidationMode } from './sdlc-validation.mode';
|
|
4
|
+
export { ArchitectureValidationMode } from './architecture-validation.mode';
|
|
5
|
+
export { RulesetValidationMode } from './ruleset-validation.mode';
|
|
6
|
+
export { AdrValidationMode } from './adr-validation.mode';
|
|
7
|
+
export { AdhocValidationMode } from './adhoc-validation.mode';
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AdhocValidationMode = exports.AdrValidationMode = exports.RulesetValidationMode = exports.ArchitectureValidationMode = exports.SdlcValidationMode = exports.ComposableValidationEngine = void 0;
|
|
4
|
+
var composable_validation_engine_1 = require("./composable-validation-engine");
|
|
5
|
+
Object.defineProperty(exports, "ComposableValidationEngine", { enumerable: true, get: function () { return composable_validation_engine_1.ComposableValidationEngine; } });
|
|
6
|
+
var sdlc_validation_mode_1 = require("./sdlc-validation.mode");
|
|
7
|
+
Object.defineProperty(exports, "SdlcValidationMode", { enumerable: true, get: function () { return sdlc_validation_mode_1.SdlcValidationMode; } });
|
|
8
|
+
var architecture_validation_mode_1 = require("./architecture-validation.mode");
|
|
9
|
+
Object.defineProperty(exports, "ArchitectureValidationMode", { enumerable: true, get: function () { return architecture_validation_mode_1.ArchitectureValidationMode; } });
|
|
10
|
+
var ruleset_validation_mode_1 = require("./ruleset-validation.mode");
|
|
11
|
+
Object.defineProperty(exports, "RulesetValidationMode", { enumerable: true, get: function () { return ruleset_validation_mode_1.RulesetValidationMode; } });
|
|
12
|
+
var adr_validation_mode_1 = require("./adr-validation.mode");
|
|
13
|
+
Object.defineProperty(exports, "AdrValidationMode", { enumerable: true, get: function () { return adr_validation_mode_1.AdrValidationMode; } });
|
|
14
|
+
var adhoc_validation_mode_1 = require("./adhoc-validation.mode");
|
|
15
|
+
Object.defineProperty(exports, "AdhocValidationMode", { enumerable: true, get: function () { return adhoc_validation_mode_1.AdhocValidationMode; } });
|
|
16
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/application/validators/modes/index.ts"],"names":[],"mappings":";;;AAKA,+EAAwG;AAA/F,0IAAA,0BAA0B,OAAA;AACnC,+DAA4D;AAAnD,0HAAA,kBAAkB,OAAA;AAC3B,+EAA4E;AAAnE,0IAAA,0BAA0B,OAAA;AACnC,qEAAkE;AAAzD,gIAAA,qBAAqB,OAAA;AAC9B,6DAA0D;AAAjD,wHAAA,iBAAiB,OAAA;AAC1B,iEAA8D;AAArD,4HAAA,mBAAmB,OAAA"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ValidationContext, ValidationMode, ModeValidationResult } from './validation-mode.interface';
|
|
2
|
+
export declare class RulesetValidationMode implements ValidationMode {
|
|
3
|
+
readonly name: "ruleset";
|
|
4
|
+
canHandle(context: ValidationContext): boolean;
|
|
5
|
+
validate(context: ValidationContext): Promise<ModeValidationResult>;
|
|
6
|
+
}
|