@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,166 @@
|
|
|
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
|
+
const os = __importStar(require("os"));
|
|
37
|
+
const path = __importStar(require("path"));
|
|
38
|
+
const fs = __importStar(require("fs-extra"));
|
|
39
|
+
const hexagonal_scaffolder_1 = require("./hexagonal-scaffolder");
|
|
40
|
+
const mermaid_class_parser_1 = require("./mermaid-class-parser");
|
|
41
|
+
const DIAGRAM_SRC = `
|
|
42
|
+
classDiagram
|
|
43
|
+
class User {
|
|
44
|
+
<<Entity>>
|
|
45
|
+
+String id
|
|
46
|
+
+String name
|
|
47
|
+
+validate() void
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
class Email {
|
|
51
|
+
<<Value Object>>
|
|
52
|
+
+String value
|
|
53
|
+
+isValid() bool
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
class Order {
|
|
57
|
+
<<Aggregate>>
|
|
58
|
+
+String orderId
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
class UserRepository {
|
|
62
|
+
<<Repository>>
|
|
63
|
+
+findById(id String) User
|
|
64
|
+
+save(user User) void
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
class EmailService {
|
|
68
|
+
<<Service>>
|
|
69
|
+
+sendConfirmation(email String) void
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
UserRepository --> User
|
|
73
|
+
`;
|
|
74
|
+
describe('scaffoldHexagonal', () => {
|
|
75
|
+
let tmpDir;
|
|
76
|
+
let diagram;
|
|
77
|
+
beforeAll(async () => {
|
|
78
|
+
tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), 'evolith-scaffold-test-'));
|
|
79
|
+
diagram = (0, mermaid_class_parser_1.parseClassDiagram)(DIAGRAM_SRC);
|
|
80
|
+
});
|
|
81
|
+
afterAll(async () => {
|
|
82
|
+
await fs.remove(tmpDir);
|
|
83
|
+
});
|
|
84
|
+
it('parses diagram to 5 classes', () => {
|
|
85
|
+
expect(diagram.classes).toHaveLength(5);
|
|
86
|
+
});
|
|
87
|
+
describe('dryRun mode', () => {
|
|
88
|
+
it('returns created list without writing files', async () => {
|
|
89
|
+
const result = await (0, hexagonal_scaffolder_1.scaffoldHexagonal)(diagram, tmpDir, true);
|
|
90
|
+
expect(result.created.length).toBeGreaterThan(0);
|
|
91
|
+
expect(result.skipped).toHaveLength(0);
|
|
92
|
+
// dry-run must not create anything
|
|
93
|
+
const exists = await fs.pathExists(path.join(tmpDir, 'src'));
|
|
94
|
+
expect(exists).toBe(false);
|
|
95
|
+
});
|
|
96
|
+
});
|
|
97
|
+
describe('real write mode', () => {
|
|
98
|
+
let result;
|
|
99
|
+
beforeAll(async () => {
|
|
100
|
+
result = await (0, hexagonal_scaffolder_1.scaffoldHexagonal)(diagram, tmpDir);
|
|
101
|
+
});
|
|
102
|
+
it('creates Entity file', async () => {
|
|
103
|
+
const p = path.join(tmpDir, 'src/domain/entities/User.ts');
|
|
104
|
+
await expect(fs.pathExists(p)).resolves.toBe(true);
|
|
105
|
+
});
|
|
106
|
+
it('creates ValueObject file', async () => {
|
|
107
|
+
const p = path.join(tmpDir, 'src/domain/value-objects/Email.ts');
|
|
108
|
+
await expect(fs.pathExists(p)).resolves.toBe(true);
|
|
109
|
+
});
|
|
110
|
+
it('creates Aggregate file', async () => {
|
|
111
|
+
const p = path.join(tmpDir, 'src/domain/entities/Order.ts');
|
|
112
|
+
await expect(fs.pathExists(p)).resolves.toBe(true);
|
|
113
|
+
});
|
|
114
|
+
it('creates Repository interface', async () => {
|
|
115
|
+
const p = path.join(tmpDir, 'src/domain/repositories/IUserRepository.ts');
|
|
116
|
+
await expect(fs.pathExists(p)).resolves.toBe(true);
|
|
117
|
+
});
|
|
118
|
+
it('creates Repository implementation', async () => {
|
|
119
|
+
const p = path.join(tmpDir, 'src/infrastructure/persistence/UserRepository.ts');
|
|
120
|
+
await expect(fs.pathExists(p)).resolves.toBe(true);
|
|
121
|
+
});
|
|
122
|
+
it('creates Service file', async () => {
|
|
123
|
+
const p = path.join(tmpDir, 'src/domain/services/EmailService.ts');
|
|
124
|
+
await expect(fs.pathExists(p)).resolves.toBe(true);
|
|
125
|
+
});
|
|
126
|
+
it('reports all files as created', () => {
|
|
127
|
+
// Entity + VO + Aggregate + Repo interface + Repo impl + Service = 6
|
|
128
|
+
expect(result.created).toHaveLength(6);
|
|
129
|
+
expect(result.skipped).toHaveLength(0);
|
|
130
|
+
});
|
|
131
|
+
it('Entity file contains class declaration and constructor', async () => {
|
|
132
|
+
const content = await fs.readFile(path.join(tmpDir, 'src/domain/entities/User.ts'), 'utf-8');
|
|
133
|
+
expect(content).toContain('export class User');
|
|
134
|
+
expect(content).toContain('constructor(');
|
|
135
|
+
expect(content).toContain('id: string');
|
|
136
|
+
});
|
|
137
|
+
it('ValueObject file contains validate() method', async () => {
|
|
138
|
+
const content = await fs.readFile(path.join(tmpDir, 'src/domain/value-objects/Email.ts'), 'utf-8');
|
|
139
|
+
expect(content).toContain('export class Email');
|
|
140
|
+
expect(content).toContain('private validate()');
|
|
141
|
+
expect(content).toContain('this.validate()');
|
|
142
|
+
});
|
|
143
|
+
it('Aggregate file contains domainEvents', async () => {
|
|
144
|
+
const content = await fs.readFile(path.join(tmpDir, 'src/domain/entities/Order.ts'), 'utf-8');
|
|
145
|
+
expect(content).toContain('domainEvents');
|
|
146
|
+
expect(content).toContain('addDomainEvent');
|
|
147
|
+
});
|
|
148
|
+
it('Repository interface imports entity and has findById/save', async () => {
|
|
149
|
+
const content = await fs.readFile(path.join(tmpDir, 'src/domain/repositories/IUserRepository.ts'), 'utf-8');
|
|
150
|
+
expect(content).toContain('import type { User }');
|
|
151
|
+
expect(content).toContain('findById');
|
|
152
|
+
expect(content).toContain('save');
|
|
153
|
+
});
|
|
154
|
+
it('Repository impl implements the interface', async () => {
|
|
155
|
+
const content = await fs.readFile(path.join(tmpDir, 'src/infrastructure/persistence/UserRepository.ts'), 'utf-8');
|
|
156
|
+
expect(content).toContain('implements IUserRepository');
|
|
157
|
+
expect(content).toContain('Not implemented');
|
|
158
|
+
});
|
|
159
|
+
it('skips existing files on second run', async () => {
|
|
160
|
+
const result2 = await (0, hexagonal_scaffolder_1.scaffoldHexagonal)(diagram, tmpDir);
|
|
161
|
+
expect(result2.created).toHaveLength(0);
|
|
162
|
+
expect(result2.skipped).toHaveLength(6);
|
|
163
|
+
});
|
|
164
|
+
});
|
|
165
|
+
});
|
|
166
|
+
//# sourceMappingURL=hexagonal-scaffolder.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"hexagonal-scaffolder.spec.js","sourceRoot":"","sources":["../../../src/application/generators/hexagonal-scaffolder.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
export type Stereotype = 'Entity' | 'ValueObject' | 'Aggregate' | 'Repository' | 'Service' | 'unknown';
|
|
2
|
+
export type Visibility = 'public' | 'private' | 'protected' | 'package';
|
|
3
|
+
export interface PropertyDef {
|
|
4
|
+
visibility: Visibility;
|
|
5
|
+
type: string;
|
|
6
|
+
name: string;
|
|
7
|
+
}
|
|
8
|
+
export interface MethodDef {
|
|
9
|
+
visibility: Visibility;
|
|
10
|
+
name: string;
|
|
11
|
+
params: ParamDef[];
|
|
12
|
+
returnType: string;
|
|
13
|
+
}
|
|
14
|
+
export interface ParamDef {
|
|
15
|
+
name: string;
|
|
16
|
+
type: string;
|
|
17
|
+
}
|
|
18
|
+
export interface ClassDef {
|
|
19
|
+
name: string;
|
|
20
|
+
stereotype: Stereotype;
|
|
21
|
+
properties: PropertyDef[];
|
|
22
|
+
methods: MethodDef[];
|
|
23
|
+
}
|
|
24
|
+
export interface RelationshipDef {
|
|
25
|
+
from: string;
|
|
26
|
+
to: string;
|
|
27
|
+
arrow: string;
|
|
28
|
+
label?: string;
|
|
29
|
+
fromCard?: string;
|
|
30
|
+
toCard?: string;
|
|
31
|
+
}
|
|
32
|
+
export interface ClassDiagram {
|
|
33
|
+
classes: ClassDef[];
|
|
34
|
+
relationships: RelationshipDef[];
|
|
35
|
+
}
|
|
36
|
+
export declare function extractMermaidBlocks(markdown: string): string[];
|
|
37
|
+
export declare function parseClassDiagram(block: string): ClassDiagram | null;
|
|
38
|
+
export declare function parseDddModel(markdown: string): ClassDiagram | null;
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.extractMermaidBlocks = extractMermaidBlocks;
|
|
4
|
+
exports.parseClassDiagram = parseClassDiagram;
|
|
5
|
+
exports.parseDddModel = parseDddModel;
|
|
6
|
+
const VISIBILITY_MAP = {
|
|
7
|
+
'+': 'public',
|
|
8
|
+
'-': 'private',
|
|
9
|
+
'#': 'protected',
|
|
10
|
+
'~': 'package',
|
|
11
|
+
};
|
|
12
|
+
function parseVisibility(prefix) {
|
|
13
|
+
return VISIBILITY_MAP[prefix] ?? 'public';
|
|
14
|
+
}
|
|
15
|
+
function normaliseStereotype(raw) {
|
|
16
|
+
const s = raw.replace(/\s+/g, '').toLowerCase();
|
|
17
|
+
if (s === 'entity')
|
|
18
|
+
return 'Entity';
|
|
19
|
+
if (s === 'valueobject' || s === 'vo')
|
|
20
|
+
return 'ValueObject';
|
|
21
|
+
if (s === 'aggregate' || s === 'aggregateroot')
|
|
22
|
+
return 'Aggregate';
|
|
23
|
+
if (s === 'repository')
|
|
24
|
+
return 'Repository';
|
|
25
|
+
if (s === 'service' || s === 'domainservice')
|
|
26
|
+
return 'Service';
|
|
27
|
+
return 'unknown';
|
|
28
|
+
}
|
|
29
|
+
function toCamelCase(s) {
|
|
30
|
+
return s.charAt(0).toLowerCase() + s.slice(1);
|
|
31
|
+
}
|
|
32
|
+
function mapMermaidType(t) {
|
|
33
|
+
const map = {
|
|
34
|
+
String: 'string',
|
|
35
|
+
string: 'string',
|
|
36
|
+
Int: 'number',
|
|
37
|
+
int: 'number',
|
|
38
|
+
Integer: 'number',
|
|
39
|
+
Long: 'number',
|
|
40
|
+
Float: 'number',
|
|
41
|
+
Double: 'number',
|
|
42
|
+
number: 'number',
|
|
43
|
+
Boolean: 'boolean',
|
|
44
|
+
boolean: 'boolean',
|
|
45
|
+
Bool: 'boolean',
|
|
46
|
+
bool: 'boolean',
|
|
47
|
+
Void: 'void',
|
|
48
|
+
void: 'void',
|
|
49
|
+
Date: 'Date',
|
|
50
|
+
List: 'Array<unknown>',
|
|
51
|
+
Object: 'Record<string, unknown>',
|
|
52
|
+
};
|
|
53
|
+
return map[t] ?? t;
|
|
54
|
+
}
|
|
55
|
+
const METHOD_RE = /^([+\-#~]?)\s*(\w+)\s*\(([^)]*)\)\s*(\w+)?\s*$/;
|
|
56
|
+
const PROP_RE = /^([+\-#~]?)\s*(\w+)\s+(\w+)\s*$/;
|
|
57
|
+
function parseMember(line) {
|
|
58
|
+
const trimmed = line.trim();
|
|
59
|
+
if (!trimmed || trimmed.startsWith('<<'))
|
|
60
|
+
return null;
|
|
61
|
+
const mM = METHOD_RE.exec(trimmed);
|
|
62
|
+
if (mM) {
|
|
63
|
+
const [, visChar, name, rawParams, ret] = mM;
|
|
64
|
+
return {
|
|
65
|
+
visibility: parseVisibility(visChar),
|
|
66
|
+
name,
|
|
67
|
+
params: parseParams(rawParams),
|
|
68
|
+
returnType: mapMermaidType(ret ?? 'void'),
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
const mP = PROP_RE.exec(trimmed);
|
|
72
|
+
if (mP) {
|
|
73
|
+
const [, visChar, typePart, namePart] = mP;
|
|
74
|
+
return {
|
|
75
|
+
visibility: parseVisibility(visChar),
|
|
76
|
+
type: mapMermaidType(typePart),
|
|
77
|
+
name: toCamelCase(namePart),
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
return null;
|
|
81
|
+
}
|
|
82
|
+
function parseParams(raw) {
|
|
83
|
+
if (!raw.trim())
|
|
84
|
+
return [];
|
|
85
|
+
return raw.split(',').map(p => {
|
|
86
|
+
const parts = p.trim().split(/\s+/);
|
|
87
|
+
if (parts.length >= 2) {
|
|
88
|
+
return { type: mapMermaidType(parts[1]), name: parts[0] };
|
|
89
|
+
}
|
|
90
|
+
return { type: mapMermaidType(parts[0]), name: toCamelCase(parts[0]) };
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
function isMethod(m) {
|
|
94
|
+
return 'params' in m;
|
|
95
|
+
}
|
|
96
|
+
const REL_RE = /^(\w+)\s*(?:"([^"]*)")?\s*(-->|\.\.>|--\|>|\.\.\|>|o--|o\.\.|\*--|<-->|--)\s*(?:"([^"]*)")?\s*(\w+)(?:\s*:\s*(.+))?$/;
|
|
97
|
+
function parseRelationship(line) {
|
|
98
|
+
const m = REL_RE.exec(line.trim());
|
|
99
|
+
if (!m)
|
|
100
|
+
return null;
|
|
101
|
+
const [, from, fromCard, arrow, toCard, to, label] = m;
|
|
102
|
+
return {
|
|
103
|
+
from, to, arrow,
|
|
104
|
+
...(fromCard ? { fromCard } : {}),
|
|
105
|
+
...(toCard ? { toCard } : {}),
|
|
106
|
+
...(label ? { label: label.trim() } : {}),
|
|
107
|
+
};
|
|
108
|
+
}
|
|
109
|
+
function extractMermaidBlocks(markdown) {
|
|
110
|
+
const blocks = [];
|
|
111
|
+
const re = /```mermaid\s*\n([\s\S]*?)```/g;
|
|
112
|
+
let m;
|
|
113
|
+
while ((m = re.exec(markdown)) !== null) {
|
|
114
|
+
blocks.push(m[1]);
|
|
115
|
+
}
|
|
116
|
+
return blocks;
|
|
117
|
+
}
|
|
118
|
+
function parseClassDiagram(block) {
|
|
119
|
+
const lines = block.split('\n').map(l => l.trim()).filter(Boolean);
|
|
120
|
+
if (!lines.some(l => l.toLowerCase().startsWith('classdiagram'))) {
|
|
121
|
+
return null;
|
|
122
|
+
}
|
|
123
|
+
const classes = [];
|
|
124
|
+
const relationships = [];
|
|
125
|
+
let i = 0;
|
|
126
|
+
while (i < lines.length) {
|
|
127
|
+
const line = lines[i];
|
|
128
|
+
const classOpen = /^class\s+(\w+)\s*\{/.exec(line);
|
|
129
|
+
if (classOpen) {
|
|
130
|
+
const cls = {
|
|
131
|
+
name: classOpen[1],
|
|
132
|
+
stereotype: 'unknown',
|
|
133
|
+
properties: [],
|
|
134
|
+
methods: [],
|
|
135
|
+
};
|
|
136
|
+
i++;
|
|
137
|
+
while (i < lines.length && lines[i] !== '}') {
|
|
138
|
+
const inner = lines[i].trim();
|
|
139
|
+
const stereoMatch = /^<<([^>]+)>>$/.exec(inner);
|
|
140
|
+
if (stereoMatch) {
|
|
141
|
+
cls.stereotype = normaliseStereotype(stereoMatch[1]);
|
|
142
|
+
}
|
|
143
|
+
else {
|
|
144
|
+
const member = parseMember(inner);
|
|
145
|
+
if (member) {
|
|
146
|
+
if (isMethod(member))
|
|
147
|
+
cls.methods.push(member);
|
|
148
|
+
else
|
|
149
|
+
cls.properties.push(member);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
i++;
|
|
153
|
+
}
|
|
154
|
+
classes.push(cls);
|
|
155
|
+
i++;
|
|
156
|
+
continue;
|
|
157
|
+
}
|
|
158
|
+
const classNoBody = /^class\s+(\w+)\s*$/.exec(line);
|
|
159
|
+
if (classNoBody) {
|
|
160
|
+
classes.push({ name: classNoBody[1], stereotype: 'unknown', properties: [], methods: [] });
|
|
161
|
+
i++;
|
|
162
|
+
continue;
|
|
163
|
+
}
|
|
164
|
+
const rel = parseRelationship(line);
|
|
165
|
+
if (rel) {
|
|
166
|
+
relationships.push(rel);
|
|
167
|
+
i++;
|
|
168
|
+
continue;
|
|
169
|
+
}
|
|
170
|
+
i++;
|
|
171
|
+
}
|
|
172
|
+
return { classes, relationships };
|
|
173
|
+
}
|
|
174
|
+
function parseDddModel(markdown) {
|
|
175
|
+
const blocks = extractMermaidBlocks(markdown);
|
|
176
|
+
for (const block of blocks) {
|
|
177
|
+
const diagram = parseClassDiagram(block);
|
|
178
|
+
if (diagram)
|
|
179
|
+
return diagram;
|
|
180
|
+
}
|
|
181
|
+
return null;
|
|
182
|
+
}
|
|
183
|
+
//# sourceMappingURL=mermaid-class-parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mermaid-class-parser.js","sourceRoot":"","sources":["../../../src/application/generators/mermaid-class-parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,148 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const mermaid_class_parser_1 = require("./mermaid-class-parser");
|
|
4
|
+
const SAMPLE_DIAGRAM = `
|
|
5
|
+
classDiagram
|
|
6
|
+
class User {
|
|
7
|
+
<<Entity>>
|
|
8
|
+
+String id
|
|
9
|
+
+String name
|
|
10
|
+
-String email
|
|
11
|
+
+validate() void
|
|
12
|
+
+fullName() String
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
class Email {
|
|
16
|
+
<<Value Object>>
|
|
17
|
+
+String value
|
|
18
|
+
+isValid() bool
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
class UserRepository {
|
|
22
|
+
<<Repository>>
|
|
23
|
+
+findById(id String) User
|
|
24
|
+
+save(user User) void
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
class UserService {
|
|
28
|
+
<<Service>>
|
|
29
|
+
+createUser(name String) User
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
User --> Email : has
|
|
33
|
+
UserRepository --> User
|
|
34
|
+
`;
|
|
35
|
+
const SAMPLE_MARKDOWN = `
|
|
36
|
+
# DDD Model
|
|
37
|
+
|
|
38
|
+
Some text.
|
|
39
|
+
|
|
40
|
+
\`\`\`mermaid
|
|
41
|
+
${SAMPLE_DIAGRAM}
|
|
42
|
+
\`\`\`
|
|
43
|
+
|
|
44
|
+
More text.
|
|
45
|
+
`;
|
|
46
|
+
describe('extractMermaidBlocks', () => {
|
|
47
|
+
it('extracts blocks from markdown', () => {
|
|
48
|
+
const blocks = (0, mermaid_class_parser_1.extractMermaidBlocks)(SAMPLE_MARKDOWN);
|
|
49
|
+
expect(blocks).toHaveLength(1);
|
|
50
|
+
expect(blocks[0]).toContain('classDiagram');
|
|
51
|
+
});
|
|
52
|
+
it('returns empty array when no mermaid blocks', () => {
|
|
53
|
+
expect((0, mermaid_class_parser_1.extractMermaidBlocks)('# No code\nJust text.')).toHaveLength(0);
|
|
54
|
+
});
|
|
55
|
+
it('extracts multiple blocks', () => {
|
|
56
|
+
const md = '```mermaid\nclassDiagram\n class A\n```\n\n```mermaid\nclassDiagram\n class B\n```';
|
|
57
|
+
expect((0, mermaid_class_parser_1.extractMermaidBlocks)(md)).toHaveLength(2);
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
describe('parseClassDiagram', () => {
|
|
61
|
+
let diagram;
|
|
62
|
+
beforeEach(() => {
|
|
63
|
+
diagram = (0, mermaid_class_parser_1.parseClassDiagram)(SAMPLE_DIAGRAM);
|
|
64
|
+
});
|
|
65
|
+
it('returns non-null for valid classDiagram', () => {
|
|
66
|
+
expect(diagram).not.toBeNull();
|
|
67
|
+
});
|
|
68
|
+
it('returns null for non-classDiagram mermaid block', () => {
|
|
69
|
+
expect((0, mermaid_class_parser_1.parseClassDiagram)('flowchart LR\n A --> B')).toBeNull();
|
|
70
|
+
});
|
|
71
|
+
it('parses 4 classes', () => {
|
|
72
|
+
expect(diagram.classes).toHaveLength(4);
|
|
73
|
+
});
|
|
74
|
+
it('parses User as Entity with correct properties', () => {
|
|
75
|
+
const user = diagram.classes.find(c => c.name === 'User');
|
|
76
|
+
expect(user.stereotype).toBe('Entity');
|
|
77
|
+
expect(user.properties).toHaveLength(3); // id, name, email
|
|
78
|
+
expect(user.properties[0]).toMatchObject({ name: 'id', type: 'string', visibility: 'public' });
|
|
79
|
+
expect(user.properties[1]).toMatchObject({ name: 'name', type: 'string', visibility: 'public' });
|
|
80
|
+
expect(user.properties[2]).toMatchObject({ name: 'email', type: 'string', visibility: 'private' });
|
|
81
|
+
});
|
|
82
|
+
it('parses User methods', () => {
|
|
83
|
+
const user = diagram.classes.find(c => c.name === 'User');
|
|
84
|
+
expect(user.methods).toHaveLength(2);
|
|
85
|
+
expect(user.methods[0]).toMatchObject({ name: 'validate', returnType: 'void' });
|
|
86
|
+
expect(user.methods[1]).toMatchObject({ name: 'fullName', returnType: 'string' });
|
|
87
|
+
});
|
|
88
|
+
it('parses Email as ValueObject', () => {
|
|
89
|
+
const email = diagram.classes.find(c => c.name === 'Email');
|
|
90
|
+
expect(email.stereotype).toBe('ValueObject');
|
|
91
|
+
expect(email.properties).toHaveLength(1);
|
|
92
|
+
expect(email.methods).toHaveLength(1);
|
|
93
|
+
expect(email.methods[0]).toMatchObject({ name: 'isValid', returnType: 'boolean' });
|
|
94
|
+
});
|
|
95
|
+
it('parses UserRepository as Repository with methods', () => {
|
|
96
|
+
const repo = diagram.classes.find(c => c.name === 'UserRepository');
|
|
97
|
+
expect(repo.stereotype).toBe('Repository');
|
|
98
|
+
expect(repo.methods).toHaveLength(2);
|
|
99
|
+
expect(repo.methods[0]).toMatchObject({ name: 'findById' });
|
|
100
|
+
expect(repo.methods[0].params).toHaveLength(1);
|
|
101
|
+
expect(repo.methods[0].params[0]).toMatchObject({ name: 'id', type: 'string' });
|
|
102
|
+
});
|
|
103
|
+
it('parses UserService as Service', () => {
|
|
104
|
+
const svc = diagram.classes.find(c => c.name === 'UserService');
|
|
105
|
+
expect(svc.stereotype).toBe('Service');
|
|
106
|
+
});
|
|
107
|
+
it('parses 2 relationships', () => {
|
|
108
|
+
expect(diagram.relationships).toHaveLength(2);
|
|
109
|
+
expect(diagram.relationships[0]).toMatchObject({ from: 'User', to: 'Email', arrow: '-->' });
|
|
110
|
+
expect(diagram.relationships[0].label).toBe('has');
|
|
111
|
+
expect(diagram.relationships[1]).toMatchObject({ from: 'UserRepository', to: 'User' });
|
|
112
|
+
});
|
|
113
|
+
});
|
|
114
|
+
describe('parseDddModel', () => {
|
|
115
|
+
it('extracts diagram from markdown', () => {
|
|
116
|
+
const result = (0, mermaid_class_parser_1.parseDddModel)(SAMPLE_MARKDOWN);
|
|
117
|
+
expect(result).not.toBeNull();
|
|
118
|
+
expect(result.classes).toHaveLength(4);
|
|
119
|
+
});
|
|
120
|
+
it('returns null when no valid classDiagram found', () => {
|
|
121
|
+
expect((0, mermaid_class_parser_1.parseDddModel)('# Nothing here')).toBeNull();
|
|
122
|
+
});
|
|
123
|
+
});
|
|
124
|
+
describe('Aggregate stereotype', () => {
|
|
125
|
+
it('parses <<Aggregate Root>> as Aggregate', () => {
|
|
126
|
+
const d = (0, mermaid_class_parser_1.parseClassDiagram)(`
|
|
127
|
+
classDiagram
|
|
128
|
+
class Order {
|
|
129
|
+
<<Aggregate Root>>
|
|
130
|
+
+String orderId
|
|
131
|
+
}
|
|
132
|
+
`);
|
|
133
|
+
expect(d.classes[0].stereotype).toBe('Aggregate');
|
|
134
|
+
});
|
|
135
|
+
});
|
|
136
|
+
describe('type mapping', () => {
|
|
137
|
+
it('maps Int → number', () => {
|
|
138
|
+
const d = (0, mermaid_class_parser_1.parseClassDiagram)(`
|
|
139
|
+
classDiagram
|
|
140
|
+
class Counter {
|
|
141
|
+
<<Entity>>
|
|
142
|
+
+Int value
|
|
143
|
+
}
|
|
144
|
+
`);
|
|
145
|
+
expect(d.classes[0].properties[0].type).toBe('number');
|
|
146
|
+
});
|
|
147
|
+
});
|
|
148
|
+
//# sourceMappingURL=mermaid-class-parser.spec.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mermaid-class-parser.spec.js","sourceRoot":"","sources":["../../../src/application/generators/mermaid-class-parser.spec.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export * from './use-cases/index.js';
|
|
2
|
+
export * from './services/index.js';
|
|
3
|
+
export * from './validators/index.js';
|
|
4
|
+
export * from './ports/index.js';
|
|
5
|
+
export * from './agents/index.js';
|
|
6
|
+
export * from './architecture/index.js';
|
|
7
|
+
export * from './generators/index.js';
|
|
8
|
+
export * from './sync/index.js';
|
|
9
|
+
export * from './upgrade/index.js';
|
|
@@ -0,0 +1,26 @@
|
|
|
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 __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./use-cases/index.js"), exports);
|
|
18
|
+
__exportStar(require("./services/index.js"), exports);
|
|
19
|
+
__exportStar(require("./validators/index.js"), exports);
|
|
20
|
+
__exportStar(require("./ports/index.js"), exports);
|
|
21
|
+
__exportStar(require("./agents/index.js"), exports);
|
|
22
|
+
__exportStar(require("./architecture/index.js"), exports);
|
|
23
|
+
__exportStar(require("./generators/index.js"), exports);
|
|
24
|
+
__exportStar(require("./sync/index.js"), exports);
|
|
25
|
+
__exportStar(require("./upgrade/index.js"), exports);
|
|
26
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/application/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,uDAAqC;AACrC,sDAAoC;AACpC,wDAAsC;AACtC,mDAAiC;AACjC,oDAAkC;AAClC,0DAAwC;AACxC,wDAAsC;AACtC,kDAAgC;AAChC,qDAAmC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"blueprint-repository.port.js","sourceRoot":"","sources":["../../../src/application/ports/blueprint-repository.port.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-bus.port.js","sourceRoot":"","sources":["../../../src/application/ports/event-bus.port.ts"],"names":[],"mappings":""}
|