@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.
Files changed (532) hide show
  1. package/dist/application/agents/agent-ruleset-builder.d.ts +30 -0
  2. package/dist/application/agents/agent-ruleset-builder.js +75 -0
  3. package/dist/application/agents/agent-ruleset-builder.js.map +1 -0
  4. package/dist/application/agents/agent-ruleset-builder.spec.d.ts +1 -0
  5. package/dist/application/agents/agent-ruleset-builder.spec.js +135 -0
  6. package/dist/application/agents/agent-ruleset-builder.spec.js.map +1 -0
  7. package/dist/application/architecture/workspace-manager.strategy.d.ts +8 -0
  8. package/dist/application/architecture/workspace-manager.strategy.js +3 -0
  9. package/dist/application/architecture/workspace-manager.strategy.js.map +1 -0
  10. package/dist/application/generators/hexagonal-scaffolder.d.ts +6 -0
  11. package/dist/application/generators/hexagonal-scaffolder.js +259 -0
  12. package/dist/application/generators/hexagonal-scaffolder.js.map +1 -0
  13. package/dist/application/generators/hexagonal-scaffolder.spec.d.ts +1 -0
  14. package/dist/application/generators/hexagonal-scaffolder.spec.js +166 -0
  15. package/dist/application/generators/hexagonal-scaffolder.spec.js.map +1 -0
  16. package/dist/application/generators/mermaid-class-parser.d.ts +38 -0
  17. package/dist/application/generators/mermaid-class-parser.js +183 -0
  18. package/dist/application/generators/mermaid-class-parser.js.map +1 -0
  19. package/dist/application/generators/mermaid-class-parser.spec.d.ts +1 -0
  20. package/dist/application/generators/mermaid-class-parser.spec.js +148 -0
  21. package/dist/application/generators/mermaid-class-parser.spec.js.map +1 -0
  22. package/dist/application/index.d.ts +9 -0
  23. package/dist/application/index.js +26 -0
  24. package/dist/application/index.js.map +1 -0
  25. package/dist/application/ports/blueprint-repository.port.d.ts +6 -0
  26. package/dist/application/ports/blueprint-repository.port.js +3 -0
  27. package/dist/application/ports/blueprint-repository.port.js.map +1 -0
  28. package/dist/application/ports/event-bus.port.d.ts +5 -0
  29. package/dist/application/ports/event-bus.port.js +3 -0
  30. package/dist/application/ports/event-bus.port.js.map +1 -0
  31. package/dist/application/ports/index.d.ts +5 -0
  32. package/dist/application/ports/index.js +22 -0
  33. package/dist/application/ports/index.js.map +1 -0
  34. package/dist/application/ports/platform-detection.port.d.ts +9 -0
  35. package/dist/application/ports/platform-detection.port.js +3 -0
  36. package/dist/application/ports/platform-detection.port.js.map +1 -0
  37. package/dist/application/ports/webhook-notifier.port.d.ts +3 -0
  38. package/dist/application/ports/webhook-notifier.port.js +3 -0
  39. package/dist/application/ports/webhook-notifier.port.js.map +1 -0
  40. package/dist/application/ports/webhook-subscription.port.d.ts +13 -0
  41. package/dist/application/ports/webhook-subscription.port.js +3 -0
  42. package/dist/application/ports/webhook-subscription.port.js.map +1 -0
  43. package/dist/application/services/audit.service.d.ts +12 -0
  44. package/dist/application/services/audit.service.js +36 -0
  45. package/dist/application/services/audit.service.js.map +1 -0
  46. package/dist/application/services/catalog.service.d.ts +10 -0
  47. package/dist/application/services/catalog.service.js +84 -0
  48. package/dist/application/services/catalog.service.js.map +1 -0
  49. package/dist/application/services/evolith-config.service.d.ts +25 -0
  50. package/dist/application/services/evolith-config.service.js +120 -0
  51. package/dist/application/services/evolith-config.service.js.map +1 -0
  52. package/dist/application/services/gate-registry.service.d.ts +34 -0
  53. package/dist/application/services/gate-registry.service.js +104 -0
  54. package/dist/application/services/gate-registry.service.js.map +1 -0
  55. package/dist/application/services/index.d.ts +41 -0
  56. package/dist/application/services/index.js +25 -0
  57. package/dist/application/services/index.js.map +1 -0
  58. package/dist/application/services/initialize-project.spec.d.ts +5 -0
  59. package/dist/application/services/initialize-project.spec.js +228 -0
  60. package/dist/application/services/initialize-project.spec.js.map +1 -0
  61. package/dist/application/services/phase-transition.use-case.spec.d.ts +1 -0
  62. package/dist/application/services/phase-transition.use-case.spec.js +303 -0
  63. package/dist/application/services/phase-transition.use-case.spec.js.map +1 -0
  64. package/dist/application/services/project-scaffolder.service.d.ts +19 -0
  65. package/dist/application/services/project-scaffolder.service.js +194 -0
  66. package/dist/application/services/project-scaffolder.service.js.map +1 -0
  67. package/dist/application/services/satellite-evaluation-pipeline.service.d.ts +18 -0
  68. package/dist/application/services/satellite-evaluation-pipeline.service.js +206 -0
  69. package/dist/application/services/satellite-evaluation-pipeline.service.js.map +1 -0
  70. package/dist/application/services/sdlc-data-loader.service.d.ts +39 -0
  71. package/dist/application/services/sdlc-data-loader.service.js +112 -0
  72. package/dist/application/services/sdlc-data-loader.service.js.map +1 -0
  73. package/dist/application/services/services/command-executor.service.d.ts +3 -0
  74. package/dist/application/services/services/command-executor.service.js +13 -0
  75. package/dist/application/services/services/command-executor.service.js.map +1 -0
  76. package/dist/application/services/services/command-history.service.d.ts +39 -0
  77. package/dist/application/services/services/command-history.service.js +150 -0
  78. package/dist/application/services/services/command-history.service.js.map +1 -0
  79. package/dist/application/services/services/command-history.service.spec.d.ts +1 -0
  80. package/dist/application/services/services/command-history.service.spec.js +266 -0
  81. package/dist/application/services/services/command-history.service.spec.js.map +1 -0
  82. package/dist/application/services/services/command-providers.d.ts +1 -0
  83. package/dist/application/services/services/command-providers.js +17 -0
  84. package/dist/application/services/services/command-providers.js.map +1 -0
  85. package/dist/application/services/topology-catalog.service.d.ts +58 -0
  86. package/dist/application/services/topology-catalog.service.js +85 -0
  87. package/dist/application/services/topology-catalog.service.js.map +1 -0
  88. package/dist/application/sync/sync.service.d.ts +9 -0
  89. package/dist/application/sync/sync.service.js +88 -0
  90. package/dist/application/sync/sync.service.js.map +1 -0
  91. package/dist/application/sync/sync.service.spec.d.ts +1 -0
  92. package/dist/application/sync/sync.service.spec.js +76 -0
  93. package/dist/application/sync/sync.service.spec.js.map +1 -0
  94. package/dist/application/upgrade/satellite-upgrade-apply.d.ts +5 -0
  95. package/dist/application/upgrade/satellite-upgrade-apply.js +102 -0
  96. package/dist/application/upgrade/satellite-upgrade-apply.js.map +1 -0
  97. package/dist/application/upgrade/satellite-upgrade-diff.d.ts +6 -0
  98. package/dist/application/upgrade/satellite-upgrade-diff.js +130 -0
  99. package/dist/application/upgrade/satellite-upgrade-diff.js.map +1 -0
  100. package/dist/application/upgrade/satellite-upgrade-fs.d.ts +4 -0
  101. package/dist/application/upgrade/satellite-upgrade-fs.js +97 -0
  102. package/dist/application/upgrade/satellite-upgrade-fs.js.map +1 -0
  103. package/dist/application/upgrade/satellite-upgrade.service.d.ts +14 -0
  104. package/dist/application/upgrade/satellite-upgrade.service.js +78 -0
  105. package/dist/application/upgrade/satellite-upgrade.service.js.map +1 -0
  106. package/dist/application/upgrade/satellite-upgrade.service.spec.d.ts +1 -0
  107. package/dist/application/upgrade/satellite-upgrade.service.spec.js +231 -0
  108. package/dist/application/upgrade/satellite-upgrade.service.spec.js.map +1 -0
  109. package/dist/application/upgrade/satellite-upgrade.types.d.ts +31 -0
  110. package/dist/application/upgrade/satellite-upgrade.types.js +3 -0
  111. package/dist/application/upgrade/satellite-upgrade.types.js.map +1 -0
  112. package/dist/application/use-cases/evaluate-gate.use-case.d.ts +25 -0
  113. package/dist/application/use-cases/evaluate-gate.use-case.js +124 -0
  114. package/dist/application/use-cases/evaluate-gate.use-case.js.map +1 -0
  115. package/dist/application/use-cases/evaluate-gate.use-case.spec.d.ts +1 -0
  116. package/dist/application/use-cases/evaluate-gate.use-case.spec.js +112 -0
  117. package/dist/application/use-cases/evaluate-gate.use-case.spec.js.map +1 -0
  118. package/dist/application/use-cases/index.d.ts +7 -0
  119. package/dist/application/use-cases/index.js +24 -0
  120. package/dist/application/use-cases/index.js.map +1 -0
  121. package/dist/application/use-cases/initialize-project.use-case.d.ts +10 -0
  122. package/dist/application/use-cases/initialize-project.use-case.js +71 -0
  123. package/dist/application/use-cases/initialize-project.use-case.js.map +1 -0
  124. package/dist/application/use-cases/phase-transition.use-case.d.ts +22 -0
  125. package/dist/application/use-cases/phase-transition.use-case.js +100 -0
  126. package/dist/application/use-cases/phase-transition.use-case.js.map +1 -0
  127. package/dist/application/use-cases/propose-phase-advance.use-case.d.ts +15 -0
  128. package/dist/application/use-cases/propose-phase-advance.use-case.js +42 -0
  129. package/dist/application/use-cases/propose-phase-advance.use-case.js.map +1 -0
  130. package/dist/application/use-cases/propose-phase-advance.use-case.spec.d.ts +1 -0
  131. package/dist/application/use-cases/propose-phase-advance.use-case.spec.js +64 -0
  132. package/dist/application/use-cases/propose-phase-advance.use-case.spec.js.map +1 -0
  133. package/dist/application/use-cases/validate-blueprint.use-case.d.ts +32 -0
  134. package/dist/application/use-cases/validate-blueprint.use-case.js +179 -0
  135. package/dist/application/use-cases/validate-blueprint.use-case.js.map +1 -0
  136. package/dist/application/use-cases/validate-satellite.use-case.d.ts +25 -0
  137. package/dist/application/use-cases/validate-satellite.use-case.js +192 -0
  138. package/dist/application/use-cases/validate-satellite.use-case.js.map +1 -0
  139. package/dist/application/use-cases/validate-satellite.use-case.spec.d.ts +1 -0
  140. package/dist/application/use-cases/validate-satellite.use-case.spec.js +102 -0
  141. package/dist/application/use-cases/validate-satellite.use-case.spec.js.map +1 -0
  142. package/dist/application/use-cases/validate-workflow.use-case.d.ts +11 -0
  143. package/dist/application/use-cases/validate-workflow.use-case.js +121 -0
  144. package/dist/application/use-cases/validate-workflow.use-case.js.map +1 -0
  145. package/dist/application/validators/architecture/detectors.d.ts +7 -0
  146. package/dist/application/validators/architecture/detectors.js +128 -0
  147. package/dist/application/validators/architecture/detectors.js.map +1 -0
  148. package/dist/application/validators/architecture/import-graph.d.ts +5 -0
  149. package/dist/application/validators/architecture/import-graph.js +132 -0
  150. package/dist/application/validators/architecture/import-graph.js.map +1 -0
  151. package/dist/application/validators/architecture/types.d.ts +44 -0
  152. package/dist/application/validators/architecture/types.js +39 -0
  153. package/dist/application/validators/architecture/types.js.map +1 -0
  154. package/dist/application/validators/architecture-drift.service.d.ts +74 -0
  155. package/dist/application/validators/architecture-drift.service.js +268 -0
  156. package/dist/application/validators/architecture-drift.service.js.map +1 -0
  157. package/dist/application/validators/architecture-drift.service.spec.d.ts +1 -0
  158. package/dist/application/validators/architecture-drift.service.spec.js +144 -0
  159. package/dist/application/validators/architecture-drift.service.spec.js.map +1 -0
  160. package/dist/application/validators/architecture-validator.d.ts +14 -0
  161. package/dist/application/validators/architecture-validator.js +125 -0
  162. package/dist/application/validators/architecture-validator.js.map +1 -0
  163. package/dist/application/validators/blocking-criteria-validator.d.ts +29 -0
  164. package/dist/application/validators/blocking-criteria-validator.js +255 -0
  165. package/dist/application/validators/blocking-criteria-validator.js.map +1 -0
  166. package/dist/application/validators/build-vs-compose.schema.spec.d.ts +1 -0
  167. package/dist/application/validators/build-vs-compose.schema.spec.js +143 -0
  168. package/dist/application/validators/build-vs-compose.schema.spec.js.map +1 -0
  169. package/dist/application/validators/deep-architecture-analyzer.d.ts +9 -0
  170. package/dist/application/validators/deep-architecture-analyzer.js +73 -0
  171. package/dist/application/validators/deep-architecture-analyzer.js.map +1 -0
  172. package/dist/application/validators/deep-architecture-analyzer.spec.d.ts +1 -0
  173. package/dist/application/validators/deep-architecture-analyzer.spec.js +186 -0
  174. package/dist/application/validators/deep-architecture-analyzer.spec.js.map +1 -0
  175. package/dist/application/validators/evaluators/architecture-equivalence.spec.d.ts +1 -0
  176. package/dist/application/validators/evaluators/architecture-equivalence.spec.js +58 -0
  177. package/dist/application/validators/evaluators/architecture-equivalence.spec.js.map +1 -0
  178. package/dist/application/validators/evaluators/evaluator.interface.d.ts +14 -0
  179. package/dist/application/validators/evaluators/evaluator.interface.js +3 -0
  180. package/dist/application/validators/evaluators/evaluator.interface.js.map +1 -0
  181. package/dist/application/validators/evaluators/handlers/acl-rule.handler.d.ts +16 -0
  182. package/dist/application/validators/evaluators/handlers/acl-rule.handler.js +139 -0
  183. package/dist/application/validators/evaluators/handlers/acl-rule.handler.js.map +1 -0
  184. package/dist/application/validators/evaluators/handlers/architecture/agent-rules.d.ts +6 -0
  185. package/dist/application/validators/evaluators/handlers/architecture/agent-rules.js +131 -0
  186. package/dist/application/validators/evaluators/handlers/architecture/agent-rules.js.map +1 -0
  187. package/dist/application/validators/evaluators/handlers/architecture/ast-rules.d.ts +6 -0
  188. package/dist/application/validators/evaluators/handlers/architecture/ast-rules.js +151 -0
  189. package/dist/application/validators/evaluators/handlers/architecture/ast-rules.js.map +1 -0
  190. package/dist/application/validators/evaluators/handlers/architecture/config-rules.d.ts +6 -0
  191. package/dist/application/validators/evaluators/handlers/architecture/config-rules.js +60 -0
  192. package/dist/application/validators/evaluators/handlers/architecture/config-rules.js.map +1 -0
  193. package/dist/application/validators/evaluators/handlers/architecture/shared.d.ts +14 -0
  194. package/dist/application/validators/evaluators/handlers/architecture/shared.js +91 -0
  195. package/dist/application/validators/evaluators/handlers/architecture/shared.js.map +1 -0
  196. package/dist/application/validators/evaluators/handlers/architecture/structural-rules.d.ts +6 -0
  197. package/dist/application/validators/evaluators/handlers/architecture/structural-rules.js +208 -0
  198. package/dist/application/validators/evaluators/handlers/architecture/structural-rules.js.map +1 -0
  199. package/dist/application/validators/evaluators/handlers/architecture-rule.handler.d.ts +11 -0
  200. package/dist/application/validators/evaluators/handlers/architecture-rule.handler.js +39 -0
  201. package/dist/application/validators/evaluators/handlers/architecture-rule.handler.js.map +1 -0
  202. package/dist/application/validators/evaluators/handlers/architecture-rule.handler.spec.d.ts +1 -0
  203. package/dist/application/validators/evaluators/handlers/architecture-rule.handler.spec.js +212 -0
  204. package/dist/application/validators/evaluators/handlers/architecture-rule.handler.spec.js.map +1 -0
  205. package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.d.ts +17 -0
  206. package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.js +133 -0
  207. package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.js.map +1 -0
  208. package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.spec.d.ts +1 -0
  209. package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.spec.js +89 -0
  210. package/dist/application/validators/evaluators/handlers/cli-release-rule.handler.spec.js.map +1 -0
  211. package/dist/application/validators/evaluators/handlers/cross-cutting-rule.handler.d.ts +25 -0
  212. package/dist/application/validators/evaluators/handlers/cross-cutting-rule.handler.js +244 -0
  213. package/dist/application/validators/evaluators/handlers/cross-cutting-rule.handler.js.map +1 -0
  214. package/dist/application/validators/evaluators/handlers/dependency-rule.handler.d.ts +17 -0
  215. package/dist/application/validators/evaluators/handlers/dependency-rule.handler.js +163 -0
  216. package/dist/application/validators/evaluators/handlers/dependency-rule.handler.js.map +1 -0
  217. package/dist/application/validators/evaluators/handlers/dependency-rule.handler.spec.d.ts +1 -0
  218. package/dist/application/validators/evaluators/handlers/dependency-rule.handler.spec.js +115 -0
  219. package/dist/application/validators/evaluators/handlers/dependency-rule.handler.spec.js.map +1 -0
  220. package/dist/application/validators/evaluators/handlers/evidence-rule.handler.d.ts +10 -0
  221. package/dist/application/validators/evaluators/handlers/evidence-rule.handler.js +102 -0
  222. package/dist/application/validators/evaluators/handlers/evidence-rule.handler.js.map +1 -0
  223. package/dist/application/validators/evaluators/handlers/evidence-rule.handler.spec.d.ts +1 -0
  224. package/dist/application/validators/evaluators/handlers/evidence-rule.handler.spec.js +94 -0
  225. package/dist/application/validators/evaluators/handlers/evidence-rule.handler.spec.js.map +1 -0
  226. package/dist/application/validators/evaluators/handlers/executive-scorecard-rule.handler.d.ts +15 -0
  227. package/dist/application/validators/evaluators/handlers/executive-scorecard-rule.handler.js +126 -0
  228. package/dist/application/validators/evaluators/handlers/executive-scorecard-rule.handler.js.map +1 -0
  229. package/dist/application/validators/evaluators/handlers/governance-rule.handler.d.ts +11 -0
  230. package/dist/application/validators/evaluators/handlers/governance-rule.handler.js +120 -0
  231. package/dist/application/validators/evaluators/handlers/governance-rule.handler.js.map +1 -0
  232. package/dist/application/validators/evaluators/handlers/governance-rule.handler.spec.d.ts +1 -0
  233. package/dist/application/validators/evaluators/handlers/governance-rule.handler.spec.js +107 -0
  234. package/dist/application/validators/evaluators/handlers/governance-rule.handler.spec.js.map +1 -0
  235. package/dist/application/validators/evaluators/handlers/mcp-rule.handler.d.ts +12 -0
  236. package/dist/application/validators/evaluators/handlers/mcp-rule.handler.js +91 -0
  237. package/dist/application/validators/evaluators/handlers/mcp-rule.handler.js.map +1 -0
  238. package/dist/application/validators/evaluators/handlers/mcp-rule.handler.spec.d.ts +1 -0
  239. package/dist/application/validators/evaluators/handlers/mcp-rule.handler.spec.js +92 -0
  240. package/dist/application/validators/evaluators/handlers/mcp-rule.handler.spec.js.map +1 -0
  241. package/dist/application/validators/evaluators/handlers/rule-handler.interface.d.ts +6 -0
  242. package/dist/application/validators/evaluators/handlers/rule-handler.interface.js +3 -0
  243. package/dist/application/validators/evaluators/handlers/rule-handler.interface.js.map +1 -0
  244. package/dist/application/validators/evaluators/handlers/satellite-contract-rule.handler.d.ts +14 -0
  245. package/dist/application/validators/evaluators/handlers/satellite-contract-rule.handler.js +105 -0
  246. package/dist/application/validators/evaluators/handlers/satellite-contract-rule.handler.js.map +1 -0
  247. package/dist/application/validators/evaluators/handlers/sdlc-rule.handler.d.ts +12 -0
  248. package/dist/application/validators/evaluators/handlers/sdlc-rule.handler.js +81 -0
  249. package/dist/application/validators/evaluators/handlers/sdlc-rule.handler.js.map +1 -0
  250. package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.d.ts +13 -0
  251. package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.js +136 -0
  252. package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.js.map +1 -0
  253. package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.spec.d.ts +1 -0
  254. package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.spec.js +96 -0
  255. package/dist/application/validators/evaluators/handlers/taxonomy-rule.handler.spec.js.map +1 -0
  256. package/dist/application/validators/evaluators/native-evaluator.d.ts +12 -0
  257. package/dist/application/validators/evaluators/native-evaluator.js +63 -0
  258. package/dist/application/validators/evaluators/native-evaluator.js.map +1 -0
  259. package/dist/application/validators/evaluators/opa-evaluator.d.ts +14 -0
  260. package/dist/application/validators/evaluators/opa-evaluator.js +151 -0
  261. package/dist/application/validators/evaluators/opa-evaluator.js.map +1 -0
  262. package/dist/application/validators/evaluators/opa-evaluator.spec.d.ts +1 -0
  263. package/dist/application/validators/evaluators/opa-evaluator.spec.js +96 -0
  264. package/dist/application/validators/evaluators/opa-evaluator.spec.js.map +1 -0
  265. package/dist/application/validators/evaluators/opa-input-builder.d.ts +27 -0
  266. package/dist/application/validators/evaluators/opa-input-builder.js +357 -0
  267. package/dist/application/validators/evaluators/opa-input-builder.js.map +1 -0
  268. package/dist/application/validators/evaluators/opa-input-builder.spec.d.ts +1 -0
  269. package/dist/application/validators/evaluators/opa-input-builder.spec.js +138 -0
  270. package/dist/application/validators/evaluators/opa-input-builder.spec.js.map +1 -0
  271. package/dist/application/validators/evidence-validator.d.ts +13 -0
  272. package/dist/application/validators/evidence-validator.js +195 -0
  273. package/dist/application/validators/evidence-validator.js.map +1 -0
  274. package/dist/application/validators/index.d.ts +4 -0
  275. package/dist/application/validators/index.js +21 -0
  276. package/dist/application/validators/index.js.map +1 -0
  277. package/dist/application/validators/modes/adhoc-validation.mode.d.ts +8 -0
  278. package/dist/application/validators/modes/adhoc-validation.mode.js +156 -0
  279. package/dist/application/validators/modes/adhoc-validation.mode.js.map +1 -0
  280. package/dist/application/validators/modes/adr-validation.mode.d.ts +7 -0
  281. package/dist/application/validators/modes/adr-validation.mode.js +183 -0
  282. package/dist/application/validators/modes/adr-validation.mode.js.map +1 -0
  283. package/dist/application/validators/modes/architecture-validation.mode.d.ts +7 -0
  284. package/dist/application/validators/modes/architecture-validation.mode.js +154 -0
  285. package/dist/application/validators/modes/architecture-validation.mode.js.map +1 -0
  286. package/dist/application/validators/modes/composable-validation-engine.d.ts +20 -0
  287. package/dist/application/validators/modes/composable-validation-engine.js +110 -0
  288. package/dist/application/validators/modes/composable-validation-engine.js.map +1 -0
  289. package/dist/application/validators/modes/index.d.ts +7 -0
  290. package/dist/application/validators/modes/index.js +16 -0
  291. package/dist/application/validators/modes/index.js.map +1 -0
  292. package/dist/application/validators/modes/ruleset-validation.mode.d.ts +6 -0
  293. package/dist/application/validators/modes/ruleset-validation.mode.js +143 -0
  294. package/dist/application/validators/modes/ruleset-validation.mode.js.map +1 -0
  295. package/dist/application/validators/modes/sdlc-validation.mode.d.ts +7 -0
  296. package/dist/application/validators/modes/sdlc-validation.mode.js +151 -0
  297. package/dist/application/validators/modes/sdlc-validation.mode.js.map +1 -0
  298. package/dist/application/validators/modes/validation-mode.interface.d.ts +34 -0
  299. package/dist/application/validators/modes/validation-mode.interface.js +3 -0
  300. package/dist/application/validators/modes/validation-mode.interface.js.map +1 -0
  301. package/dist/application/validators/phase-gate-validator.service.d.ts +77 -0
  302. package/dist/application/validators/phase-gate-validator.service.js +183 -0
  303. package/dist/application/validators/phase-gate-validator.service.js.map +1 -0
  304. package/dist/application/validators/phase-gate-validator.service.spec.d.ts +1 -0
  305. package/dist/application/validators/phase-gate-validator.service.spec.js +383 -0
  306. package/dist/application/validators/phase-gate-validator.service.spec.js.map +1 -0
  307. package/dist/application/validators/rule-evaluation-engine.d.ts +29 -0
  308. package/dist/application/validators/rule-evaluation-engine.js +41 -0
  309. package/dist/application/validators/rule-evaluation-engine.js.map +1 -0
  310. package/dist/application/validators/ruleset-id-loader.d.ts +3 -0
  311. package/dist/application/validators/ruleset-id-loader.js +109 -0
  312. package/dist/application/validators/ruleset-id-loader.js.map +1 -0
  313. package/dist/application/validators/ruleset-loader.d.ts +13 -0
  314. package/dist/application/validators/ruleset-loader.js +83 -0
  315. package/dist/application/validators/ruleset-loader.js.map +1 -0
  316. package/dist/application/validators/ruleset-validator-architecture.spec.d.ts +1 -0
  317. package/dist/application/validators/ruleset-validator-architecture.spec.js +174 -0
  318. package/dist/application/validators/ruleset-validator-architecture.spec.js.map +1 -0
  319. package/dist/application/validators/ruleset-validator.service.d.ts +18 -0
  320. package/dist/application/validators/ruleset-validator.service.js +154 -0
  321. package/dist/application/validators/ruleset-validator.service.js.map +1 -0
  322. package/dist/application/validators/ruleset-validator.types.d.ts +57 -0
  323. package/dist/application/validators/ruleset-validator.types.js +5 -0
  324. package/dist/application/validators/ruleset-validator.types.js.map +1 -0
  325. package/dist/common/request-context.d.ts +10 -0
  326. package/dist/common/request-context.js +14 -0
  327. package/dist/common/request-context.js.map +1 -0
  328. package/dist/domain/audit/audit-entry.d.ts +19 -0
  329. package/dist/domain/audit/audit-entry.js +3 -0
  330. package/dist/domain/audit/audit-entry.js.map +1 -0
  331. package/dist/domain/audit/audit-repository.port.d.ts +6 -0
  332. package/dist/domain/audit/audit-repository.port.js +3 -0
  333. package/dist/domain/audit/audit-repository.port.js.map +1 -0
  334. package/dist/domain/audit/index.d.ts +2 -0
  335. package/dist/domain/audit/index.js +19 -0
  336. package/dist/domain/audit/index.js.map +1 -0
  337. package/dist/domain/entities/blueprint.d.ts +41 -0
  338. package/dist/domain/entities/blueprint.js +82 -0
  339. package/dist/domain/entities/blueprint.js.map +1 -0
  340. package/dist/domain/entities/index.d.ts +73 -0
  341. package/dist/domain/entities/index.js +134 -0
  342. package/dist/domain/entities/index.js.map +1 -0
  343. package/dist/domain/errors/gate-authorization.error.d.ts +9 -0
  344. package/dist/domain/errors/gate-authorization.error.js +17 -0
  345. package/dist/domain/errors/gate-authorization.error.js.map +1 -0
  346. package/dist/domain/errors/index.d.ts +29 -0
  347. package/dist/domain/errors/index.js +73 -0
  348. package/dist/domain/errors/index.js.map +1 -0
  349. package/dist/domain/events/domain-event.d.ts +9 -0
  350. package/dist/domain/events/domain-event.js +14 -0
  351. package/dist/domain/events/domain-event.js.map +1 -0
  352. package/dist/domain/events/domain-events.d.ts +99 -0
  353. package/dist/domain/events/domain-events.js +49 -0
  354. package/dist/domain/events/domain-events.js.map +1 -0
  355. package/dist/domain/events/event-catalog.d.ts +7 -0
  356. package/dist/domain/events/event-catalog.js +82 -0
  357. package/dist/domain/events/event-catalog.js.map +1 -0
  358. package/dist/domain/events/index.d.ts +4 -0
  359. package/dist/domain/events/index.js +21 -0
  360. package/dist/domain/events/index.js.map +1 -0
  361. package/dist/domain/gate-evidence.d.ts +70 -0
  362. package/dist/domain/gate-evidence.js +46 -0
  363. package/dist/domain/gate-evidence.js.map +1 -0
  364. package/dist/domain/gate-evidence.spec.d.ts +1 -0
  365. package/dist/domain/gate-evidence.spec.js +173 -0
  366. package/dist/domain/gate-evidence.spec.js.map +1 -0
  367. package/dist/domain/index.d.ts +12 -0
  368. package/dist/domain/index.js +29 -0
  369. package/dist/domain/index.js.map +1 -0
  370. package/dist/domain/interfaces.d.ts +301 -0
  371. package/dist/domain/interfaces.js +5 -0
  372. package/dist/domain/interfaces.js.map +1 -0
  373. package/dist/domain/lifecycle/artifact-state-machine.d.ts +23 -0
  374. package/dist/domain/lifecycle/artifact-state-machine.js +50 -0
  375. package/dist/domain/lifecycle/artifact-state-machine.js.map +1 -0
  376. package/dist/domain/lifecycle/index.d.ts +2 -0
  377. package/dist/domain/lifecycle/index.js +19 -0
  378. package/dist/domain/lifecycle/index.js.map +1 -0
  379. package/dist/domain/lifecycle/phase-state-machine.d.ts +24 -0
  380. package/dist/domain/lifecycle/phase-state-machine.js +50 -0
  381. package/dist/domain/lifecycle/phase-state-machine.js.map +1 -0
  382. package/dist/domain/metrics/dora-calculator.d.ts +18 -0
  383. package/dist/domain/metrics/dora-calculator.js +146 -0
  384. package/dist/domain/metrics/dora-calculator.js.map +1 -0
  385. package/dist/domain/metrics/dora-calculator.spec.d.ts +1 -0
  386. package/dist/domain/metrics/dora-calculator.spec.js +172 -0
  387. package/dist/domain/metrics/dora-calculator.spec.js.map +1 -0
  388. package/dist/domain/metrics/git-log-reader.d.ts +14 -0
  389. package/dist/domain/metrics/git-log-reader.js +39 -0
  390. package/dist/domain/metrics/git-log-reader.js.map +1 -0
  391. package/dist/domain/metrics/git-log-reader.spec.d.ts +8 -0
  392. package/dist/domain/metrics/git-log-reader.spec.js +121 -0
  393. package/dist/domain/metrics/git-log-reader.spec.js.map +1 -0
  394. package/dist/domain/metrics/index.d.ts +2 -0
  395. package/dist/domain/metrics/index.js +19 -0
  396. package/dist/domain/metrics/index.js.map +1 -0
  397. package/dist/domain/models/normalized-rule.d.ts +10 -0
  398. package/dist/domain/models/normalized-rule.js +3 -0
  399. package/dist/domain/models/normalized-rule.js.map +1 -0
  400. package/dist/domain/ports/index.d.ts +2 -0
  401. package/dist/domain/ports/index.js +19 -0
  402. package/dist/domain/ports/index.js.map +1 -0
  403. package/dist/domain/ports/ruleset-repository.port.d.ts +4 -0
  404. package/dist/domain/ports/ruleset-repository.port.js +3 -0
  405. package/dist/domain/ports/ruleset-repository.port.js.map +1 -0
  406. package/dist/domain/ports/workflow-definition.port.d.ts +24 -0
  407. package/dist/domain/ports/workflow-definition.port.js +3 -0
  408. package/dist/domain/ports/workflow-definition.port.js.map +1 -0
  409. package/dist/domain/rbac/gate-role-enforcer.d.ts +16 -0
  410. package/dist/domain/rbac/gate-role-enforcer.js +46 -0
  411. package/dist/domain/rbac/gate-role-enforcer.js.map +1 -0
  412. package/dist/domain/rbac/index.d.ts +1 -0
  413. package/dist/domain/rbac/index.js +12 -0
  414. package/dist/domain/rbac/index.js.map +1 -0
  415. package/dist/domain/rbac/role.d.ts +19 -0
  416. package/dist/domain/rbac/role.js +79 -0
  417. package/dist/domain/rbac/role.js.map +1 -0
  418. package/dist/domain/satellite-manifest.d.ts +44 -0
  419. package/dist/domain/satellite-manifest.js +3 -0
  420. package/dist/domain/satellite-manifest.js.map +1 -0
  421. package/dist/domain/services/adr.service.d.ts +50 -0
  422. package/dist/domain/services/adr.service.js +129 -0
  423. package/dist/domain/services/adr.service.js.map +1 -0
  424. package/dist/domain/services/adr.service.spec.d.ts +1 -0
  425. package/dist/domain/services/adr.service.spec.js +141 -0
  426. package/dist/domain/services/adr.service.spec.js.map +1 -0
  427. package/dist/domain/services/default-workflow-definition.d.ts +40 -0
  428. package/dist/domain/services/default-workflow-definition.js +94 -0
  429. package/dist/domain/services/default-workflow-definition.js.map +1 -0
  430. package/dist/domain/services/index.d.ts +37 -0
  431. package/dist/domain/services/index.js +110 -0
  432. package/dist/domain/services/index.js.map +1 -0
  433. package/dist/domain/services/standards.service.d.ts +47 -0
  434. package/dist/domain/services/standards.service.js +129 -0
  435. package/dist/domain/services/standards.service.js.map +1 -0
  436. package/dist/domain/services/standards.service.spec.d.ts +1 -0
  437. package/dist/domain/services/standards.service.spec.js +600 -0
  438. package/dist/domain/services/standards.service.spec.js.map +1 -0
  439. package/dist/domain/verdict/index.d.ts +1 -0
  440. package/dist/domain/verdict/index.js +18 -0
  441. package/dist/domain/verdict/index.js.map +1 -0
  442. package/dist/domain/verdict/verdict.d.ts +22 -0
  443. package/dist/domain/verdict/verdict.js +50 -0
  444. package/dist/domain/verdict/verdict.js.map +1 -0
  445. package/dist/domain/webhook/webhook-subscription.d.ts +27 -0
  446. package/dist/domain/webhook/webhook-subscription.js +9 -0
  447. package/dist/domain/webhook/webhook-subscription.js.map +1 -0
  448. package/dist/domain/workflow/index.d.ts +1 -0
  449. package/dist/domain/workflow/index.js +18 -0
  450. package/dist/domain/workflow/index.js.map +1 -0
  451. package/dist/domain/workflow/workflow-definition.d.ts +33 -0
  452. package/dist/domain/workflow/workflow-definition.js +3 -0
  453. package/dist/domain/workflow/workflow-definition.js.map +1 -0
  454. package/dist/evidence/evidence-graph.d.ts +29 -0
  455. package/dist/evidence/evidence-graph.js +27 -0
  456. package/dist/evidence/evidence-graph.js.map +1 -0
  457. package/dist/evidence/index.d.ts +1 -0
  458. package/dist/evidence/index.js +18 -0
  459. package/dist/evidence/index.js.map +1 -0
  460. package/dist/gates/decision/gate-decision.d.ts +18 -0
  461. package/dist/gates/decision/gate-decision.js +23 -0
  462. package/dist/gates/decision/gate-decision.js.map +1 -0
  463. package/dist/gates/decision/index.d.ts +1 -0
  464. package/dist/gates/decision/index.js +18 -0
  465. package/dist/gates/decision/index.js.map +1 -0
  466. package/dist/gates/gate-evaluator.d.ts +15 -0
  467. package/dist/gates/gate-evaluator.js +37 -0
  468. package/dist/gates/gate-evaluator.js.map +1 -0
  469. package/dist/gates/index.d.ts +1 -0
  470. package/dist/gates/index.js +18 -0
  471. package/dist/gates/index.js.map +1 -0
  472. package/dist/index.d.ts +2 -0
  473. package/dist/index.js +19 -0
  474. package/dist/index.js.map +1 -0
  475. package/dist/infrastructure/audit/in-memory-audit-repository.d.ts +10 -0
  476. package/dist/infrastructure/audit/in-memory-audit-repository.js +44 -0
  477. package/dist/infrastructure/audit/in-memory-audit-repository.js.map +1 -0
  478. package/dist/infrastructure/audit/index.d.ts +2 -0
  479. package/dist/infrastructure/audit/index.js +19 -0
  480. package/dist/infrastructure/audit/index.js.map +1 -0
  481. package/dist/infrastructure/audit/jsonl-audit-repository.d.ts +12 -0
  482. package/dist/infrastructure/audit/jsonl-audit-repository.js +103 -0
  483. package/dist/infrastructure/audit/jsonl-audit-repository.js.map +1 -0
  484. package/dist/infrastructure/events/in-memory-event-bus.d.ts +9 -0
  485. package/dist/infrastructure/events/in-memory-event-bus.js +25 -0
  486. package/dist/infrastructure/events/in-memory-event-bus.js.map +1 -0
  487. package/dist/infrastructure/events/index.d.ts +4 -0
  488. package/dist/infrastructure/events/index.js +21 -0
  489. package/dist/infrastructure/events/index.js.map +1 -0
  490. package/dist/infrastructure/events/outbox.d.ts +27 -0
  491. package/dist/infrastructure/events/outbox.js +43 -0
  492. package/dist/infrastructure/events/outbox.js.map +1 -0
  493. package/dist/infrastructure/webhook/hmac-signer.d.ts +6 -0
  494. package/dist/infrastructure/webhook/hmac-signer.js +25 -0
  495. package/dist/infrastructure/webhook/hmac-signer.js.map +1 -0
  496. package/dist/infrastructure/webhook/in-memory-delivery-repository.d.ts +10 -0
  497. package/dist/infrastructure/webhook/in-memory-delivery-repository.js +25 -0
  498. package/dist/infrastructure/webhook/in-memory-delivery-repository.js.map +1 -0
  499. package/dist/infrastructure/webhook/in-memory-subscription-repository.d.ts +11 -0
  500. package/dist/infrastructure/webhook/in-memory-subscription-repository.js +28 -0
  501. package/dist/infrastructure/webhook/in-memory-subscription-repository.js.map +1 -0
  502. package/dist/infrastructure/webhook/index.d.ts +4 -0
  503. package/dist/infrastructure/webhook/index.js +21 -0
  504. package/dist/infrastructure/webhook/index.js.map +1 -0
  505. package/dist/infrastructure/webhook/webhook-dispatcher.d.ts +13 -0
  506. package/dist/infrastructure/webhook/webhook-dispatcher.js +91 -0
  507. package/dist/infrastructure/webhook/webhook-dispatcher.js.map +1 -0
  508. package/dist/phases/index.d.ts +1 -0
  509. package/dist/phases/index.js +18 -0
  510. package/dist/phases/index.js.map +1 -0
  511. package/dist/phases/phase-transition.d.ts +19 -0
  512. package/dist/phases/phase-transition.js +31 -0
  513. package/dist/phases/phase-transition.js.map +1 -0
  514. package/dist/phases/transition/index.d.ts +1 -0
  515. package/dist/phases/transition/index.js +18 -0
  516. package/dist/phases/transition/index.js.map +1 -0
  517. package/dist/phases/transition/phase-transition.model.d.ts +13 -0
  518. package/dist/phases/transition/phase-transition.model.js +21 -0
  519. package/dist/phases/transition/phase-transition.model.js.map +1 -0
  520. package/dist/providers/index.d.ts +1 -0
  521. package/dist/providers/index.js +18 -0
  522. package/dist/providers/index.js.map +1 -0
  523. package/dist/providers/provider.ports.d.ts +39 -0
  524. package/dist/providers/provider.ports.js +18 -0
  525. package/dist/providers/provider.ports.js.map +1 -0
  526. package/dist/tenancy/index.d.ts +1 -0
  527. package/dist/tenancy/index.js +18 -0
  528. package/dist/tenancy/index.js.map +1 -0
  529. package/dist/tenancy/tenant-authority.d.ts +22 -0
  530. package/dist/tenancy/tenant-authority.js +31 -0
  531. package/dist/tenancy/tenant-authority.js.map +1 -0
  532. 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":"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"}
@@ -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
+ }