@evolith/smart-cli 1.1.0 → 1.1.1

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 (576) hide show
  1. package/ARCHITECTURE.md +1 -1
  2. package/LICENSE +21 -0
  3. package/README.es.md +31 -3
  4. package/README.md +906 -170
  5. package/dist/app.module.js +79 -6
  6. package/dist/app.module.js.map +1 -1
  7. package/dist/commands/adr/adr.command.d.ts +7 -3
  8. package/dist/commands/adr/adr.command.js +50 -78
  9. package/dist/commands/adr/adr.command.js.map +1 -1
  10. package/dist/commands/agents/agents.command.d.ts +14 -0
  11. package/dist/commands/agents/agents.command.js +61 -0
  12. package/dist/commands/agents/agents.command.js.map +1 -0
  13. package/dist/commands/agents/index.d.ts +1 -0
  14. package/dist/commands/agents/index.js +6 -0
  15. package/dist/commands/agents/index.js.map +1 -0
  16. package/dist/commands/alias/alias.command.d.ts +16 -0
  17. package/dist/commands/alias/alias.command.js +95 -0
  18. package/dist/commands/alias/alias.command.js.map +1 -0
  19. package/dist/commands/api/api.catalog.d.ts +38 -0
  20. package/dist/commands/api/api.catalog.js +167 -0
  21. package/dist/commands/api/api.catalog.js.map +1 -0
  22. package/dist/commands/api/api.command.d.ts +21 -0
  23. package/dist/commands/api/api.command.js +162 -0
  24. package/dist/commands/api/api.command.js.map +1 -0
  25. package/dist/commands/architecture/scaffold/index.d.ts +2 -0
  26. package/dist/commands/architecture/scaffold/index.js +6 -0
  27. package/dist/commands/architecture/scaffold/index.js.map +1 -0
  28. package/dist/commands/architecture/scaffold/scaffold-strategy.d.ts +15 -0
  29. package/dist/commands/architecture/scaffold/scaffold-strategy.js +20 -0
  30. package/dist/commands/architecture/scaffold/scaffold-strategy.js.map +1 -0
  31. package/dist/commands/architecture/scaffold.command.d.ts +11 -3
  32. package/dist/commands/architecture/scaffold.command.js +194 -57
  33. package/dist/commands/architecture/scaffold.command.js.map +1 -1
  34. package/dist/commands/completion/completion.command.d.ts +12 -4
  35. package/dist/commands/completion/completion.command.js +159 -53
  36. package/dist/commands/completion/completion.command.js.map +1 -1
  37. package/dist/commands/docs/docs.command.d.ts +6 -3
  38. package/dist/commands/docs/docs.command.js +75 -16
  39. package/dist/commands/docs/docs.command.js.map +1 -1
  40. package/dist/commands/drift/drift.command.d.ts +7 -3
  41. package/dist/commands/drift/drift.command.js +82 -49
  42. package/dist/commands/drift/drift.command.js.map +1 -1
  43. package/dist/commands/fixtures/fixtures.command.d.ts +21 -0
  44. package/dist/commands/fixtures/fixtures.command.js +310 -0
  45. package/dist/commands/fixtures/fixtures.command.js.map +1 -0
  46. package/dist/commands/gate/gate.command.d.ts +9 -3
  47. package/dist/commands/gate/gate.command.js +36 -53
  48. package/dist/commands/gate/gate.command.js.map +1 -1
  49. package/dist/commands/history/history.command.d.ts +3 -3
  50. package/dist/commands/history/history.command.js +24 -55
  51. package/dist/commands/history/history.command.js.map +1 -1
  52. package/dist/commands/init/agents.command.d.ts +6 -4
  53. package/dist/commands/init/agents.command.js +142 -314
  54. package/dist/commands/init/agents.command.js.map +1 -1
  55. package/dist/commands/init/init.command.d.ts +9 -3
  56. package/dist/commands/init/init.command.js +39 -198
  57. package/dist/commands/init/init.command.js.map +1 -1
  58. package/dist/commands/init/init.wizard.d.ts +19 -0
  59. package/dist/commands/init/init.wizard.js +181 -0
  60. package/dist/commands/init/init.wizard.js.map +1 -0
  61. package/dist/commands/init/upgrade.command.d.ts +6 -3
  62. package/dist/commands/init/upgrade.command.js +34 -66
  63. package/dist/commands/init/upgrade.command.js.map +1 -1
  64. package/dist/commands/mcp/mcp-serve.command.d.ts +7 -5
  65. package/dist/commands/mcp/mcp-serve.command.js +84 -37
  66. package/dist/commands/mcp/mcp-serve.command.js.map +1 -1
  67. package/dist/commands/phase/phase-advance.command.d.ts +30 -0
  68. package/dist/commands/phase/phase-advance.command.js +206 -0
  69. package/dist/commands/phase/phase-advance.command.js.map +1 -0
  70. package/dist/commands/profile/profile.command.d.ts +18 -0
  71. package/dist/commands/profile/profile.command.js +198 -0
  72. package/dist/commands/profile/profile.command.js.map +1 -0
  73. package/dist/commands/sdlc/gate-status.command.d.ts +6 -3
  74. package/dist/commands/sdlc/gate-status.command.js +54 -81
  75. package/dist/commands/sdlc/gate-status.command.js.map +1 -1
  76. package/dist/commands/sdlc/generate-domain.command.d.ts +4 -3
  77. package/dist/commands/sdlc/generate-domain.command.js +35 -36
  78. package/dist/commands/sdlc/generate-domain.command.js.map +1 -1
  79. package/dist/commands/sdlc/handoff.command.d.ts +9 -4
  80. package/dist/commands/sdlc/handoff.command.js +106 -104
  81. package/dist/commands/sdlc/handoff.command.js.map +1 -1
  82. package/dist/commands/sdlc/sdlc.command.d.ts +4 -3
  83. package/dist/commands/sdlc/sdlc.command.js +17 -43
  84. package/dist/commands/sdlc/sdlc.command.js.map +1 -1
  85. package/dist/commands/standards/standards.command.d.ts +6 -3
  86. package/dist/commands/standards/standards.command.js +52 -77
  87. package/dist/commands/standards/standards.command.js.map +1 -1
  88. package/dist/commands/update/update.command.d.ts +21 -0
  89. package/dist/commands/update/update.command.js +214 -0
  90. package/dist/commands/update/update.command.js.map +1 -0
  91. package/dist/commands/upgrade/index.d.ts +1 -0
  92. package/dist/commands/upgrade/index.js +6 -0
  93. package/dist/commands/upgrade/index.js.map +1 -0
  94. package/dist/commands/upgrade/upgrade.command.d.ts +14 -0
  95. package/dist/commands/upgrade/upgrade.command.js +58 -0
  96. package/dist/commands/upgrade/upgrade.command.js.map +1 -0
  97. package/dist/commands/validate/validate.command.d.ts +22 -4
  98. package/dist/commands/validate/validate.command.js +295 -65
  99. package/dist/commands/validate/validate.command.js.map +1 -1
  100. package/dist/config/alias.service.d.ts +14 -0
  101. package/dist/{core/sync/sync.service.js → config/alias.service.js} +54 -32
  102. package/dist/config/alias.service.js.map +1 -0
  103. package/dist/contributions/contribution-validator.d.ts +16 -0
  104. package/dist/contributions/contribution-validator.js +34 -0
  105. package/dist/contributions/contribution-validator.js.map +1 -0
  106. package/dist/contributions/index.d.ts +1 -0
  107. package/dist/contributions/index.js +6 -0
  108. package/dist/contributions/index.js.map +1 -0
  109. package/dist/{domain/services → infrastructure/adapters}/agent-registry.service.d.ts +6 -2
  110. package/dist/{domain/services → infrastructure/adapters}/agent-registry.service.js +33 -10
  111. package/dist/infrastructure/adapters/agent-registry.service.js.map +1 -0
  112. package/dist/{core → infrastructure}/architecture/nx-workspace.strategy.d.ts +6 -1
  113. package/dist/{core → infrastructure}/architecture/nx-workspace.strategy.js +27 -38
  114. package/dist/infrastructure/architecture/nx-workspace.strategy.js.map +1 -0
  115. package/dist/infrastructure/catalog/catalog-loader.d.ts +1 -2
  116. package/dist/infrastructure/catalog/catalog-loader.js +14 -5
  117. package/dist/infrastructure/catalog/catalog-loader.js.map +1 -1
  118. package/dist/infrastructure/cli/base-command.d.ts +14 -0
  119. package/dist/infrastructure/cli/base-command.js +41 -0
  120. package/dist/infrastructure/cli/base-command.js.map +1 -0
  121. package/dist/infrastructure/cli/command-executor.d.ts +1 -1
  122. package/dist/infrastructure/cli/command-executor.js +4 -3
  123. package/dist/infrastructure/cli/command-executor.js.map +1 -1
  124. package/dist/infrastructure/config/config.service.d.ts +34 -0
  125. package/dist/infrastructure/config/config.service.js +126 -0
  126. package/dist/infrastructure/config/config.service.js.map +1 -0
  127. package/dist/infrastructure/filesystem/file-manager.service.d.ts +12 -0
  128. package/dist/{core → infrastructure}/filesystem/file-manager.service.js +8 -25
  129. package/dist/infrastructure/filesystem/file-manager.service.js.map +1 -0
  130. package/dist/infrastructure/formatters/output-formatter.service.js +2 -1
  131. package/dist/infrastructure/formatters/output-formatter.service.js.map +1 -1
  132. package/dist/{core → infrastructure}/observability/command-watcher.js +31 -0
  133. package/dist/infrastructure/observability/command-watcher.js.map +1 -0
  134. package/dist/{core → infrastructure}/observability/error-reporter.js +5 -5
  135. package/dist/infrastructure/observability/error-reporter.js.map +1 -0
  136. package/dist/infrastructure/observability/index.d.ts +11 -0
  137. package/dist/{core → infrastructure}/observability/index.js +6 -1
  138. package/dist/infrastructure/observability/index.js.map +1 -0
  139. package/dist/infrastructure/observability/otel-tracing.d.ts +4 -0
  140. package/dist/infrastructure/observability/otel-tracing.js +34 -0
  141. package/dist/infrastructure/observability/otel-tracing.js.map +1 -0
  142. package/dist/infrastructure/observability/structured-logger.js.map +1 -0
  143. package/dist/infrastructure/observability/timing.js.map +1 -0
  144. package/dist/infrastructure/observability/tool-usage-telemetry.service.js.map +1 -0
  145. package/dist/infrastructure/plugins/plugin-loader.d.ts +10 -0
  146. package/dist/infrastructure/plugins/plugin-loader.js +145 -0
  147. package/dist/infrastructure/plugins/plugin-loader.js.map +1 -0
  148. package/dist/infrastructure/plugins/plugin.module.d.ts +4 -0
  149. package/dist/infrastructure/plugins/plugin.module.js +28 -0
  150. package/dist/infrastructure/plugins/plugin.module.js.map +1 -0
  151. package/dist/infrastructure/prompts/init-prompt-group.d.ts +3 -0
  152. package/dist/infrastructure/prompts/init-prompt-group.js +115 -0
  153. package/dist/infrastructure/prompts/init-prompt-group.js.map +1 -0
  154. package/dist/infrastructure/prompts/init-prompt-options.d.ts +10 -0
  155. package/dist/infrastructure/prompts/init-prompt-options.js +40 -0
  156. package/dist/infrastructure/prompts/init-prompt-options.js.map +1 -0
  157. package/dist/infrastructure/prompts/progress.service.d.ts +24 -0
  158. package/dist/infrastructure/prompts/progress.service.js +180 -0
  159. package/dist/infrastructure/prompts/progress.service.js.map +1 -0
  160. package/dist/infrastructure/prompts/prompt.service.d.ts +42 -0
  161. package/dist/infrastructure/prompts/prompt.service.js +142 -0
  162. package/dist/infrastructure/prompts/prompt.service.js.map +1 -0
  163. package/dist/infrastructure/prompts/wizard.service.d.ts +27 -0
  164. package/dist/infrastructure/prompts/wizard.service.js +163 -0
  165. package/dist/infrastructure/prompts/wizard.service.js.map +1 -0
  166. package/dist/{core/abstractions → infrastructure}/providers/config-parser.provider.d.ts +1 -1
  167. package/dist/infrastructure/providers/config-parser.provider.js.map +1 -0
  168. package/dist/{core/abstractions → infrastructure}/providers/logger.provider.d.ts +1 -1
  169. package/dist/infrastructure/providers/logger.provider.js.map +1 -0
  170. package/dist/{core/abstractions → infrastructure}/providers/mock-filesystem.provider.d.ts +5 -2
  171. package/dist/{core/abstractions → infrastructure}/providers/mock-filesystem.provider.js +4 -1
  172. package/dist/infrastructure/providers/mock-filesystem.provider.js.map +1 -0
  173. package/dist/{core/abstractions → infrastructure}/providers/node-filesystem.provider.d.ts +5 -2
  174. package/dist/{core/abstractions → infrastructure}/providers/node-filesystem.provider.js +9 -0
  175. package/dist/infrastructure/providers/node-filesystem.provider.js.map +1 -0
  176. package/dist/main.js +18 -1
  177. package/dist/main.js.map +1 -1
  178. package/dist/plugins/index.d.ts +1 -0
  179. package/dist/plugins/index.js +6 -0
  180. package/dist/plugins/index.js.map +1 -0
  181. package/dist/plugins/plugin-registry.d.ts +22 -0
  182. package/dist/plugins/plugin-registry.js +33 -0
  183. package/dist/plugins/plugin-registry.js.map +1 -0
  184. package/package.json +50 -41
  185. package/shell/hooks.bash +68 -0
  186. package/shell/hooks.fish +57 -0
  187. package/shell/hooks.zsh +68 -0
  188. package/dist/app.module.spec.d.ts +0 -1
  189. package/dist/app.module.spec.js +0 -305
  190. package/dist/app.module.spec.js.map +0 -1
  191. package/dist/application/ports/webhook-notifier.port.d.ts +0 -4
  192. package/dist/application/ports/webhook-notifier.port.js +0 -3
  193. package/dist/application/ports/webhook-notifier.port.js.map +0 -1
  194. package/dist/application/services/index.d.ts +0 -64
  195. package/dist/application/services/index.js +0 -371
  196. package/dist/application/services/index.js.map +0 -1
  197. package/dist/application/services/initialize-project.spec.d.ts +0 -1
  198. package/dist/application/services/initialize-project.spec.js +0 -211
  199. package/dist/application/services/initialize-project.spec.js.map +0 -1
  200. package/dist/application/services/phase-transition.use-case.spec.d.ts +0 -1
  201. package/dist/application/services/phase-transition.use-case.spec.js +0 -297
  202. package/dist/application/services/phase-transition.use-case.spec.js.map +0 -1
  203. package/dist/application/services/services.test.d.ts +0 -1
  204. package/dist/application/services/services.test.js +0 -176
  205. package/dist/application/services/services.test.js.map +0 -1
  206. package/dist/application/use-cases/evaluate-gate.use-case.d.ts +0 -20
  207. package/dist/application/use-cases/evaluate-gate.use-case.js +0 -72
  208. package/dist/application/use-cases/evaluate-gate.use-case.js.map +0 -1
  209. package/dist/application/use-cases/validate-satellite.use-case.d.ts +0 -19
  210. package/dist/application/use-cases/validate-satellite.use-case.js +0 -96
  211. package/dist/application/use-cases/validate-satellite.use-case.js.map +0 -1
  212. package/dist/application/use-cases/validate-satellite.use-case.spec.d.ts +0 -1
  213. package/dist/application/use-cases/validate-satellite.use-case.spec.js +0 -102
  214. package/dist/application/use-cases/validate-satellite.use-case.spec.js.map +0 -1
  215. package/dist/commands/adr/adr.command.spec.d.ts +0 -1
  216. package/dist/commands/adr/adr.command.spec.js +0 -409
  217. package/dist/commands/adr/adr.command.spec.js.map +0 -1
  218. package/dist/commands/architecture/scaffold.command.spec.d.ts +0 -1
  219. package/dist/commands/architecture/scaffold.command.spec.js +0 -207
  220. package/dist/commands/architecture/scaffold.command.spec.js.map +0 -1
  221. package/dist/commands/commands.test.d.ts +0 -1
  222. package/dist/commands/commands.test.js +0 -131
  223. package/dist/commands/commands.test.js.map +0 -1
  224. package/dist/commands/completion/completion.command.spec.d.ts +0 -1
  225. package/dist/commands/completion/completion.command.spec.js +0 -240
  226. package/dist/commands/completion/completion.command.spec.js.map +0 -1
  227. package/dist/commands/docs/docs.command.spec.d.ts +0 -1
  228. package/dist/commands/docs/docs.command.spec.js +0 -87
  229. package/dist/commands/docs/docs.command.spec.js.map +0 -1
  230. package/dist/commands/drift/drift.command.spec.d.ts +0 -1
  231. package/dist/commands/drift/drift.command.spec.js +0 -327
  232. package/dist/commands/drift/drift.command.spec.js.map +0 -1
  233. package/dist/commands/history/history.command.spec.d.ts +0 -1
  234. package/dist/commands/history/history.command.spec.js +0 -392
  235. package/dist/commands/history/history.command.spec.js.map +0 -1
  236. package/dist/commands/init/agents.command.spec.d.ts +0 -1
  237. package/dist/commands/init/agents.command.spec.js +0 -550
  238. package/dist/commands/init/agents.command.spec.js.map +0 -1
  239. package/dist/commands/init/init.command.spec.d.ts +0 -1
  240. package/dist/commands/init/init.command.spec.js +0 -272
  241. package/dist/commands/init/init.command.spec.js.map +0 -1
  242. package/dist/commands/init/upgrade.command.spec.d.ts +0 -1
  243. package/dist/commands/init/upgrade.command.spec.js +0 -378
  244. package/dist/commands/init/upgrade.command.spec.js.map +0 -1
  245. package/dist/commands/mcp/mcp-serve.command.spec.d.ts +0 -1
  246. package/dist/commands/mcp/mcp-serve.command.spec.js +0 -58
  247. package/dist/commands/mcp/mcp-serve.command.spec.js.map +0 -1
  248. package/dist/commands/sdlc/gate-status.command.spec.d.ts +0 -1
  249. package/dist/commands/sdlc/gate-status.command.spec.js +0 -302
  250. package/dist/commands/sdlc/gate-status.command.spec.js.map +0 -1
  251. package/dist/commands/sdlc/generate-domain.command.spec.d.ts +0 -1
  252. package/dist/commands/sdlc/generate-domain.command.spec.js +0 -121
  253. package/dist/commands/sdlc/generate-domain.command.spec.js.map +0 -1
  254. package/dist/commands/sdlc/handoff.command.spec.d.ts +0 -1
  255. package/dist/commands/sdlc/handoff.command.spec.js +0 -395
  256. package/dist/commands/sdlc/handoff.command.spec.js.map +0 -1
  257. package/dist/commands/sdlc/sdlc.command.spec.d.ts +0 -1
  258. package/dist/commands/sdlc/sdlc.command.spec.js +0 -79
  259. package/dist/commands/sdlc/sdlc.command.spec.js.map +0 -1
  260. package/dist/commands/standards/standards.command.spec.d.ts +0 -1
  261. package/dist/commands/standards/standards.command.spec.js +0 -311
  262. package/dist/commands/standards/standards.command.spec.js.map +0 -1
  263. package/dist/commands/validate/validate.command.spec.d.ts +0 -1
  264. package/dist/commands/validate/validate.command.spec.js +0 -368
  265. package/dist/commands/validate/validate.command.spec.js.map +0 -1
  266. package/dist/config/runtimes.json +0 -196
  267. package/dist/config/tool-catalog.json +0 -343
  268. package/dist/core/abstractions/index.d.ts +0 -6
  269. package/dist/core/abstractions/index.js +0 -23
  270. package/dist/core/abstractions/index.js.map +0 -1
  271. package/dist/core/abstractions/interfaces.d.ts +0 -61
  272. package/dist/core/abstractions/interfaces.js +0 -5
  273. package/dist/core/abstractions/interfaces.js.map +0 -1
  274. package/dist/core/abstractions/providers/config-parser.provider.js.map +0 -1
  275. package/dist/core/abstractions/providers/config-parser.provider.spec.d.ts +0 -1
  276. package/dist/core/abstractions/providers/config-parser.provider.spec.js +0 -18
  277. package/dist/core/abstractions/providers/config-parser.provider.spec.js.map +0 -1
  278. package/dist/core/abstractions/providers/logger.provider.js.map +0 -1
  279. package/dist/core/abstractions/providers/logger.provider.spec.d.ts +0 -1
  280. package/dist/core/abstractions/providers/logger.provider.spec.js +0 -212
  281. package/dist/core/abstractions/providers/logger.provider.spec.js.map +0 -1
  282. package/dist/core/abstractions/providers/mock-filesystem.provider.js.map +0 -1
  283. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.d.ts +0 -1
  284. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.js +0 -56
  285. package/dist/core/abstractions/providers/mock-filesystem.provider.spec.js.map +0 -1
  286. package/dist/core/abstractions/providers/node-filesystem.provider.js.map +0 -1
  287. package/dist/core/agents/agent-ruleset-builder.d.ts +0 -30
  288. package/dist/core/agents/agent-ruleset-builder.js +0 -75
  289. package/dist/core/agents/agent-ruleset-builder.js.map +0 -1
  290. package/dist/core/agents/agent-ruleset-builder.spec.d.ts +0 -1
  291. package/dist/core/agents/agent-ruleset-builder.spec.js +0 -135
  292. package/dist/core/agents/agent-ruleset-builder.spec.js.map +0 -1
  293. package/dist/core/architecture/nx-workspace.strategy.js.map +0 -1
  294. package/dist/core/architecture/nx-workspace.strategy.spec.d.ts +0 -1
  295. package/dist/core/architecture/nx-workspace.strategy.spec.js +0 -187
  296. package/dist/core/architecture/nx-workspace.strategy.spec.js.map +0 -1
  297. package/dist/core/architecture/workspace-manager.strategy.d.ts +0 -8
  298. package/dist/core/architecture/workspace-manager.strategy.js +0 -3
  299. package/dist/core/architecture/workspace-manager.strategy.js.map +0 -1
  300. package/dist/core/config/config.service.d.ts +0 -15
  301. package/dist/core/config/config.service.js +0 -55
  302. package/dist/core/config/config.service.js.map +0 -1
  303. package/dist/core/config/config.service.spec.d.ts +0 -1
  304. package/dist/core/config/config.service.spec.js +0 -43
  305. package/dist/core/config/config.service.spec.js.map +0 -1
  306. package/dist/core/di/container.d.ts +0 -25
  307. package/dist/core/di/container.js +0 -87
  308. package/dist/core/di/container.js.map +0 -1
  309. package/dist/core/di/container.spec.d.ts +0 -1
  310. package/dist/core/di/container.spec.js +0 -301
  311. package/dist/core/di/container.spec.js.map +0 -1
  312. package/dist/core/errors/index.d.ts +0 -26
  313. package/dist/core/errors/index.js +0 -67
  314. package/dist/core/errors/index.js.map +0 -1
  315. package/dist/core/filesystem/file-manager.service.d.ts +0 -4
  316. package/dist/core/filesystem/file-manager.service.js.map +0 -1
  317. package/dist/core/filesystem/file-manager.service.spec.d.ts +0 -1
  318. package/dist/core/filesystem/file-manager.service.spec.js +0 -103
  319. package/dist/core/filesystem/file-manager.service.spec.js.map +0 -1
  320. package/dist/core/generators/hexagonal-scaffolder.d.ts +0 -6
  321. package/dist/core/generators/hexagonal-scaffolder.js +0 -260
  322. package/dist/core/generators/hexagonal-scaffolder.js.map +0 -1
  323. package/dist/core/generators/hexagonal-scaffolder.spec.d.ts +0 -1
  324. package/dist/core/generators/hexagonal-scaffolder.spec.js +0 -164
  325. package/dist/core/generators/hexagonal-scaffolder.spec.js.map +0 -1
  326. package/dist/core/generators/mermaid-class-parser.d.ts +0 -38
  327. package/dist/core/generators/mermaid-class-parser.js +0 -183
  328. package/dist/core/generators/mermaid-class-parser.js.map +0 -1
  329. package/dist/core/generators/mermaid-class-parser.spec.d.ts +0 -1
  330. package/dist/core/generators/mermaid-class-parser.spec.js +0 -148
  331. package/dist/core/generators/mermaid-class-parser.spec.js.map +0 -1
  332. package/dist/core/mcp/mcp-server.service.d.ts +0 -7
  333. package/dist/core/mcp/mcp-server.service.js +0 -31
  334. package/dist/core/mcp/mcp-server.service.js.map +0 -1
  335. package/dist/core/mcp/metrics.service.d.ts +0 -37
  336. package/dist/core/mcp/metrics.service.js +0 -72
  337. package/dist/core/mcp/metrics.service.js.map +0 -1
  338. package/dist/core/mcp/metrics.service.spec.d.ts +0 -1
  339. package/dist/core/mcp/metrics.service.spec.js +0 -159
  340. package/dist/core/mcp/metrics.service.spec.js.map +0 -1
  341. package/dist/core/mcp/prompts/index.d.ts +0 -22
  342. package/dist/core/mcp/prompts/index.js +0 -211
  343. package/dist/core/mcp/prompts/index.js.map +0 -1
  344. package/dist/core/mcp/prompts/index.spec.d.ts +0 -1
  345. package/dist/core/mcp/prompts/index.spec.js +0 -150
  346. package/dist/core/mcp/prompts/index.spec.js.map +0 -1
  347. package/dist/core/mcp/resources/index.d.ts +0 -11
  348. package/dist/core/mcp/resources/index.js +0 -209
  349. package/dist/core/mcp/resources/index.js.map +0 -1
  350. package/dist/core/mcp/resources/index.spec.d.ts +0 -1
  351. package/dist/core/mcp/resources/index.spec.js +0 -212
  352. package/dist/core/mcp/resources/index.spec.js.map +0 -1
  353. package/dist/core/mcp/server.d.ts +0 -33
  354. package/dist/core/mcp/server.js +0 -693
  355. package/dist/core/mcp/server.js.map +0 -1
  356. package/dist/core/mcp/server.spec.d.ts +0 -1
  357. package/dist/core/mcp/server.spec.js +0 -579
  358. package/dist/core/mcp/server.spec.js.map +0 -1
  359. package/dist/core/mcp/tools/agent.d.ts +0 -41
  360. package/dist/core/mcp/tools/agent.js +0 -195
  361. package/dist/core/mcp/tools/agent.js.map +0 -1
  362. package/dist/core/mcp/tools/agent.spec.d.ts +0 -1
  363. package/dist/core/mcp/tools/agent.spec.js +0 -171
  364. package/dist/core/mcp/tools/agent.spec.js.map +0 -1
  365. package/dist/core/mcp/tools/architecture.d.ts +0 -29
  366. package/dist/core/mcp/tools/architecture.js +0 -234
  367. package/dist/core/mcp/tools/architecture.js.map +0 -1
  368. package/dist/core/mcp/tools/architecture.spec.d.ts +0 -1
  369. package/dist/core/mcp/tools/architecture.spec.js +0 -145
  370. package/dist/core/mcp/tools/architecture.spec.js.map +0 -1
  371. package/dist/core/mcp/tools/gate.d.ts +0 -1
  372. package/dist/core/mcp/tools/gate.js +0 -68
  373. package/dist/core/mcp/tools/gate.js.map +0 -1
  374. package/dist/core/mcp/tools/moscow.d.ts +0 -30
  375. package/dist/core/mcp/tools/moscow.js +0 -113
  376. package/dist/core/mcp/tools/moscow.js.map +0 -1
  377. package/dist/core/mcp/tools/moscow.spec.d.ts +0 -1
  378. package/dist/core/mcp/tools/moscow.spec.js +0 -209
  379. package/dist/core/mcp/tools/moscow.spec.js.map +0 -1
  380. package/dist/core/mcp/tools/sdlc.d.ts +0 -32
  381. package/dist/core/mcp/tools/sdlc.js +0 -190
  382. package/dist/core/mcp/tools/sdlc.js.map +0 -1
  383. package/dist/core/mcp/tools/sdlc.spec.d.ts +0 -1
  384. package/dist/core/mcp/tools/sdlc.spec.js +0 -170
  385. package/dist/core/mcp/tools/sdlc.spec.js.map +0 -1
  386. package/dist/core/mcp/tools/tool-utils.d.ts +0 -4
  387. package/dist/core/mcp/tools/tool-utils.js +0 -18
  388. package/dist/core/mcp/tools/tool-utils.js.map +0 -1
  389. package/dist/core/mcp/tools/validate.d.ts +0 -18
  390. package/dist/core/mcp/tools/validate.js +0 -56
  391. package/dist/core/mcp/tools/validate.js.map +0 -1
  392. package/dist/core/mcp/tools/validate.spec.d.ts +0 -1
  393. package/dist/core/mcp/tools/validate.spec.js +0 -130
  394. package/dist/core/mcp/tools/validate.spec.js.map +0 -1
  395. package/dist/core/mcp/watcher.service.d.ts +0 -8
  396. package/dist/core/mcp/watcher.service.js +0 -82
  397. package/dist/core/mcp/watcher.service.js.map +0 -1
  398. package/dist/core/mcp/watcher.service.spec.d.ts +0 -1
  399. package/dist/core/mcp/watcher.service.spec.js +0 -171
  400. package/dist/core/mcp/watcher.service.spec.js.map +0 -1
  401. package/dist/core/metrics/dora-calculator.d.ts +0 -18
  402. package/dist/core/metrics/dora-calculator.js +0 -146
  403. package/dist/core/metrics/dora-calculator.js.map +0 -1
  404. package/dist/core/metrics/dora-calculator.spec.d.ts +0 -1
  405. package/dist/core/metrics/dora-calculator.spec.js +0 -164
  406. package/dist/core/metrics/dora-calculator.spec.js.map +0 -1
  407. package/dist/core/metrics/git-log-reader.d.ts +0 -14
  408. package/dist/core/metrics/git-log-reader.js +0 -39
  409. package/dist/core/metrics/git-log-reader.js.map +0 -1
  410. package/dist/core/metrics/git-log-reader.spec.d.ts +0 -1
  411. package/dist/core/metrics/git-log-reader.spec.js +0 -108
  412. package/dist/core/metrics/git-log-reader.spec.js.map +0 -1
  413. package/dist/core/observability/command-watcher.js.map +0 -1
  414. package/dist/core/observability/command-watcher.spec.d.ts +0 -1
  415. package/dist/core/observability/command-watcher.spec.js +0 -123
  416. package/dist/core/observability/command-watcher.spec.js.map +0 -1
  417. package/dist/core/observability/error-reporter.js.map +0 -1
  418. package/dist/core/observability/error-reporter.spec.d.ts +0 -1
  419. package/dist/core/observability/error-reporter.spec.js +0 -291
  420. package/dist/core/observability/error-reporter.spec.js.map +0 -1
  421. package/dist/core/observability/index.d.ts +0 -5
  422. package/dist/core/observability/index.js.map +0 -1
  423. package/dist/core/observability/observability.test.d.ts +0 -1
  424. package/dist/core/observability/observability.test.js +0 -224
  425. package/dist/core/observability/observability.test.js.map +0 -1
  426. package/dist/core/observability/structured-logger.js.map +0 -1
  427. package/dist/core/observability/structured-logger.spec.d.ts +0 -1
  428. package/dist/core/observability/structured-logger.spec.js +0 -197
  429. package/dist/core/observability/structured-logger.spec.js.map +0 -1
  430. package/dist/core/observability/timing.js.map +0 -1
  431. package/dist/core/observability/timing.spec.d.ts +0 -1
  432. package/dist/core/observability/timing.spec.js +0 -216
  433. package/dist/core/observability/timing.spec.js.map +0 -1
  434. package/dist/core/observability/tool-usage-telemetry.service.js.map +0 -1
  435. package/dist/core/services/command-executor.service.d.ts +0 -3
  436. package/dist/core/services/command-executor.service.js +0 -12
  437. package/dist/core/services/command-executor.service.js.map +0 -1
  438. package/dist/core/services/command-history.service.d.ts +0 -39
  439. package/dist/core/services/command-history.service.js +0 -150
  440. package/dist/core/services/command-history.service.js.map +0 -1
  441. package/dist/core/services/command-history.service.spec.d.ts +0 -1
  442. package/dist/core/services/command-history.service.spec.js +0 -257
  443. package/dist/core/services/command-history.service.spec.js.map +0 -1
  444. package/dist/core/services/command-providers.d.ts +0 -1
  445. package/dist/core/services/command-providers.js +0 -17
  446. package/dist/core/services/command-providers.js.map +0 -1
  447. package/dist/core/services/runtime-catalog.service.d.ts +0 -2
  448. package/dist/core/services/runtime-catalog.service.js +0 -7
  449. package/dist/core/services/runtime-catalog.service.js.map +0 -1
  450. package/dist/core/sync/sync.service.d.ts +0 -4
  451. package/dist/core/sync/sync.service.js.map +0 -1
  452. package/dist/core/sync/sync.service.spec.d.ts +0 -1
  453. package/dist/core/sync/sync.service.spec.js +0 -63
  454. package/dist/core/sync/sync.service.spec.js.map +0 -1
  455. package/dist/core/upgrade/satellite-upgrade.service.d.ts +0 -48
  456. package/dist/core/upgrade/satellite-upgrade.service.js +0 -358
  457. package/dist/core/upgrade/satellite-upgrade.service.js.map +0 -1
  458. package/dist/core/upgrade/satellite-upgrade.service.spec.d.ts +0 -1
  459. package/dist/core/upgrade/satellite-upgrade.service.spec.js +0 -223
  460. package/dist/core/upgrade/satellite-upgrade.service.spec.js.map +0 -1
  461. package/dist/core/validators/architecture-drift.service.d.ts +0 -68
  462. package/dist/core/validators/architecture-drift.service.js +0 -266
  463. package/dist/core/validators/architecture-drift.service.js.map +0 -1
  464. package/dist/core/validators/architecture-drift.service.spec.d.ts +0 -1
  465. package/dist/core/validators/architecture-drift.service.spec.js +0 -315
  466. package/dist/core/validators/architecture-drift.service.spec.js.map +0 -1
  467. package/dist/core/validators/deep-architecture-analyzer.d.ts +0 -58
  468. package/dist/core/validators/deep-architecture-analyzer.js +0 -333
  469. package/dist/core/validators/deep-architecture-analyzer.js.map +0 -1
  470. package/dist/core/validators/deep-architecture-analyzer.spec.d.ts +0 -1
  471. package/dist/core/validators/deep-architecture-analyzer.spec.js +0 -186
  472. package/dist/core/validators/deep-architecture-analyzer.spec.js.map +0 -1
  473. package/dist/core/validators/evaluators/evaluator.interface.d.ts +0 -14
  474. package/dist/core/validators/evaluators/evaluator.interface.js +0 -3
  475. package/dist/core/validators/evaluators/evaluator.interface.js.map +0 -1
  476. package/dist/core/validators/evaluators/native-evaluator.d.ts +0 -31
  477. package/dist/core/validators/evaluators/native-evaluator.js +0 -461
  478. package/dist/core/validators/evaluators/native-evaluator.js.map +0 -1
  479. package/dist/core/validators/evaluators/opa-evaluator.d.ts +0 -20
  480. package/dist/core/validators/evaluators/opa-evaluator.js +0 -249
  481. package/dist/core/validators/evaluators/opa-evaluator.js.map +0 -1
  482. package/dist/core/validators/phase-gate-validator.service.d.ts +0 -75
  483. package/dist/core/validators/phase-gate-validator.service.js +0 -338
  484. package/dist/core/validators/phase-gate-validator.service.js.map +0 -1
  485. package/dist/core/validators/phase-gate-validator.service.spec.d.ts +0 -1
  486. package/dist/core/validators/phase-gate-validator.service.spec.js +0 -326
  487. package/dist/core/validators/phase-gate-validator.service.spec.js.map +0 -1
  488. package/dist/core/validators/rule-evaluation-engine.d.ts +0 -34
  489. package/dist/core/validators/rule-evaluation-engine.js +0 -187
  490. package/dist/core/validators/rule-evaluation-engine.js.map +0 -1
  491. package/dist/core/validators/rule-evaluation-engine.spec.d.ts +0 -1
  492. package/dist/core/validators/rule-evaluation-engine.spec.js +0 -243
  493. package/dist/core/validators/rule-evaluation-engine.spec.js.map +0 -1
  494. package/dist/core/validators/ruleset-validator-architecture.spec.d.ts +0 -1
  495. package/dist/core/validators/ruleset-validator-architecture.spec.js +0 -178
  496. package/dist/core/validators/ruleset-validator-architecture.spec.js.map +0 -1
  497. package/dist/core/validators/ruleset-validator.service.d.ts +0 -82
  498. package/dist/core/validators/ruleset-validator.service.js +0 -682
  499. package/dist/core/validators/ruleset-validator.service.js.map +0 -1
  500. package/dist/core/validators/ruleset-validator.service.spec.d.ts +0 -1
  501. package/dist/core/validators/ruleset-validator.service.spec.js +0 -469
  502. package/dist/core/validators/ruleset-validator.service.spec.js.map +0 -1
  503. package/dist/domain/entities/index.d.ts +0 -72
  504. package/dist/domain/entities/index.js +0 -119
  505. package/dist/domain/entities/index.js.map +0 -1
  506. package/dist/domain/gate-evidence.d.ts +0 -59
  507. package/dist/domain/gate-evidence.js +0 -38
  508. package/dist/domain/gate-evidence.js.map +0 -1
  509. package/dist/domain/interfaces.d.ts +0 -224
  510. package/dist/domain/interfaces.js +0 -3
  511. package/dist/domain/interfaces.js.map +0 -1
  512. package/dist/domain/services/adr.service.d.ts +0 -50
  513. package/dist/domain/services/adr.service.js +0 -129
  514. package/dist/domain/services/adr.service.js.map +0 -1
  515. package/dist/domain/services/adr.service.spec.d.ts +0 -1
  516. package/dist/domain/services/adr.service.spec.js +0 -141
  517. package/dist/domain/services/adr.service.spec.js.map +0 -1
  518. package/dist/domain/services/agent-registry.service.js.map +0 -1
  519. package/dist/domain/services/agent-registry.service.spec.d.ts +0 -1
  520. package/dist/domain/services/agent-registry.service.spec.js +0 -162
  521. package/dist/domain/services/agent-registry.service.spec.js.map +0 -1
  522. package/dist/domain/services/index.d.ts +0 -34
  523. package/dist/domain/services/index.js +0 -128
  524. package/dist/domain/services/index.js.map +0 -1
  525. package/dist/domain/services/moscow-prioritization.service.d.ts +0 -44
  526. package/dist/domain/services/moscow-prioritization.service.js +0 -213
  527. package/dist/domain/services/moscow-prioritization.service.js.map +0 -1
  528. package/dist/domain/services/moscow-prioritization.service.spec.d.ts +0 -1
  529. package/dist/domain/services/moscow-prioritization.service.spec.js +0 -285
  530. package/dist/domain/services/moscow-prioritization.service.spec.js.map +0 -1
  531. package/dist/domain/services/services.test.d.ts +0 -1
  532. package/dist/domain/services/services.test.js +0 -236
  533. package/dist/domain/services/services.test.js.map +0 -1
  534. package/dist/domain/services/standards.service.d.ts +0 -47
  535. package/dist/domain/services/standards.service.js +0 -129
  536. package/dist/domain/services/standards.service.js.map +0 -1
  537. package/dist/domain/services/standards.service.spec.d.ts +0 -1
  538. package/dist/domain/services/standards.service.spec.js +0 -600
  539. package/dist/domain/services/standards.service.spec.js.map +0 -1
  540. package/dist/domain/services/tool-usage-telemetry.service.d.ts +0 -46
  541. package/dist/domain/services/tool-usage-telemetry.service.js +0 -181
  542. package/dist/domain/services/tool-usage-telemetry.service.js.map +0 -1
  543. package/dist/domain/services/tool-usage-telemetry.service.spec.d.ts +0 -1
  544. package/dist/domain/services/tool-usage-telemetry.service.spec.js +0 -180
  545. package/dist/domain/services/tool-usage-telemetry.service.spec.js.map +0 -1
  546. package/dist/infrastructure/adapters/webhook.adapter.d.ts +0 -5
  547. package/dist/infrastructure/adapters/webhook.adapter.js +0 -19
  548. package/dist/infrastructure/adapters/webhook.adapter.js.map +0 -1
  549. package/dist/infrastructure/catalog/catalog-loader.test.d.ts +0 -1
  550. package/dist/infrastructure/catalog/catalog-loader.test.js +0 -184
  551. package/dist/infrastructure/catalog/catalog-loader.test.js.map +0 -1
  552. package/dist/infrastructure/cli/command-executor.spec.d.ts +0 -1
  553. package/dist/infrastructure/cli/command-executor.spec.js +0 -149
  554. package/dist/infrastructure/cli/command-executor.spec.js.map +0 -1
  555. package/dist/infrastructure/cli/command-executor.test.d.ts +0 -1
  556. package/dist/infrastructure/cli/command-executor.test.js +0 -98
  557. package/dist/infrastructure/cli/command-executor.test.js.map +0 -1
  558. package/dist/infrastructure/cli/providers/providers.spec.d.ts +0 -1
  559. package/dist/infrastructure/cli/providers/providers.spec.js +0 -251
  560. package/dist/infrastructure/cli/providers/providers.spec.js.map +0 -1
  561. package/dist/infrastructure/formatters/output-formatter.service.spec.d.ts +0 -1
  562. package/dist/infrastructure/formatters/output-formatter.service.spec.js +0 -164
  563. package/dist/infrastructure/formatters/output-formatter.service.spec.js.map +0 -1
  564. package/dist/test/mocks/index.d.ts +0 -44
  565. package/dist/test/mocks/index.js +0 -135
  566. package/dist/test/mocks/index.js.map +0 -1
  567. /package/dist/{core → infrastructure}/observability/command-watcher.d.ts +0 -0
  568. /package/dist/{core → infrastructure}/observability/error-reporter.d.ts +0 -0
  569. /package/dist/{core → infrastructure}/observability/structured-logger.d.ts +0 -0
  570. /package/dist/{core → infrastructure}/observability/structured-logger.js +0 -0
  571. /package/dist/{core → infrastructure}/observability/timing.d.ts +0 -0
  572. /package/dist/{core → infrastructure}/observability/timing.js +0 -0
  573. /package/dist/{core → infrastructure}/observability/tool-usage-telemetry.service.d.ts +0 -0
  574. /package/dist/{core → infrastructure}/observability/tool-usage-telemetry.service.js +0 -0
  575. /package/dist/{core/abstractions → infrastructure}/providers/config-parser.provider.js +0 -0
  576. /package/dist/{core/abstractions → infrastructure}/providers/logger.provider.js +0 -0
@@ -1,68 +0,0 @@
1
- export interface DriftReport {
2
- projectId: string;
3
- declaredLevel: string;
4
- detectedLevel: string;
5
- driftDetected: boolean;
6
- driftSeverity: 'critical' | 'high' | 'medium' | 'low' | 'none';
7
- newViolations: DriftViolation[];
8
- resolvedViolations: DriftViolation[];
9
- persistentViolations: DriftViolation[];
10
- overallScore: number;
11
- timestamp: string;
12
- historyPath: string;
13
- }
14
- export interface DriftViolation {
15
- ruleId: string;
16
- severity: 'MUST' | 'SHOULD' | 'COULD';
17
- category: string;
18
- title: string;
19
- description: string;
20
- blocking: boolean;
21
- firstDetected: string;
22
- status: 'new' | 'persistent' | 'resolved';
23
- }
24
- export interface DriftHistoryEntry {
25
- timestamp: string;
26
- declaredLevel: string;
27
- detectedLevel: string;
28
- violationsCount: number;
29
- blockingViolationsCount: number;
30
- overallScore: number;
31
- violations: DriftViolation[];
32
- }
33
- export interface DriftDetectionOptions {
34
- projectPath: string;
35
- corePath?: string;
36
- declaredLevel?: 'F1' | 'F2' | 'F3';
37
- storeHistory?: boolean;
38
- historyPath?: string;
39
- }
40
- export declare class ArchitectureDriftService {
41
- private readonly fs;
42
- private readonly logger;
43
- private readonly validator;
44
- constructor(corePath?: string);
45
- detectDrift(options: DriftDetectionOptions): Promise<DriftReport>;
46
- detectLevelDrift(projectPath: string, corePath?: string): Promise<{
47
- declared: string;
48
- detected: string;
49
- drifted: boolean;
50
- }>;
51
- getDriftHistory(projectPath: string, historyPath?: string): Promise<DriftHistoryEntry[]>;
52
- getDriftTrend(projectPath: string, historyPath?: string): Promise<{
53
- trend: 'improving' | 'stable' | 'degrading';
54
- entries: DriftHistoryEntry[];
55
- }>;
56
- private getDeclaredLevel;
57
- private detectActualLevel;
58
- private mapIssuesToViolations;
59
- private findNewViolations;
60
- private findResolvedViolations;
61
- private hasLevelDrift;
62
- private calculateDriftSeverity;
63
- private calculateOverallScore;
64
- private loadHistory;
65
- private storeHistory;
66
- private getProjectId;
67
- private findCorePath;
68
- }
@@ -1,266 +0,0 @@
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.ArchitectureDriftService = void 0;
37
- const path = __importStar(require("path"));
38
- const abstractions_1 = require("../abstractions");
39
- const ruleset_validator_service_1 = require("./ruleset-validator.service");
40
- class ArchitectureDriftService {
41
- constructor(corePath) {
42
- const container = (0, abstractions_1.getContainer)();
43
- this.fs = container.createFileSystem();
44
- this.logger = container.createLogger('ArchitectureDriftService');
45
- this.validator = new ruleset_validator_service_1.RulesetValidatorService();
46
- }
47
- async detectDrift(options) {
48
- const declaredLevel = options.declaredLevel || await this.getDeclaredLevel(options.projectPath, options.corePath);
49
- const resolvedCorePath = options.corePath || this.findCorePath(options.projectPath);
50
- this.logger.info('Starting architecture drift detection', JSON.stringify({ declaredLevel, projectPath: options.projectPath }));
51
- const validationResult = await this.validator.validateArchitecture(options.projectPath, resolvedCorePath, declaredLevel);
52
- const history = options.storeHistory !== false
53
- ? await this.loadHistory(options.projectPath, options.historyPath)
54
- : [];
55
- const previousViolations = history.length > 0
56
- ? history[history.length - 1].violations
57
- : [];
58
- const currentViolations = this.mapIssuesToViolations(validationResult.issues);
59
- const newViolations = this.findNewViolations(currentViolations, previousViolations);
60
- const resolvedViolations = this.findResolvedViolations(currentViolations, previousViolations);
61
- const persistentViolations = currentViolations.filter(v => !newViolations.some(nv => nv.ruleId === v.ruleId));
62
- const driftDetected = newViolations.length > 0 || this.hasLevelDrift(declaredLevel, validationResult);
63
- const driftSeverity = this.calculateDriftSeverity(newViolations, persistentViolations, validationResult);
64
- const overallScore = this.calculateOverallScore(validationResult);
65
- const report = {
66
- projectId: this.getProjectId(options.projectPath),
67
- declaredLevel,
68
- detectedLevel: this.detectActualLevel(options.projectPath, resolvedCorePath),
69
- driftDetected,
70
- driftSeverity,
71
- newViolations,
72
- resolvedViolations,
73
- persistentViolations,
74
- overallScore,
75
- timestamp: new Date().toISOString(),
76
- historyPath: options.historyPath || path.join(options.projectPath, '.evolith', 'drift-history.json'),
77
- };
78
- if (options.storeHistory !== false) {
79
- await this.storeHistory(options.projectPath, report, history, options.historyPath);
80
- }
81
- if (driftDetected) {
82
- this.logger.warn('Architecture drift detected', JSON.stringify({
83
- newViolations: newViolations.length,
84
- persistentViolations: persistentViolations.length,
85
- resolvedViolations: resolvedViolations.length,
86
- }));
87
- }
88
- else {
89
- this.logger.info('No architecture drift detected');
90
- }
91
- return report;
92
- }
93
- async detectLevelDrift(projectPath, corePath) {
94
- const declaredLevel = await this.getDeclaredLevel(projectPath, corePath);
95
- const resolvedCorePath = corePath || this.findCorePath(projectPath);
96
- const detectedLevel = this.detectActualLevel(projectPath, resolvedCorePath);
97
- return {
98
- declared: declaredLevel,
99
- detected: detectedLevel,
100
- drifted: declaredLevel !== detectedLevel,
101
- };
102
- }
103
- async getDriftHistory(projectPath, historyPath) {
104
- return this.loadHistory(projectPath, historyPath);
105
- }
106
- async getDriftTrend(projectPath, historyPath) {
107
- const history = await this.loadHistory(projectPath, historyPath);
108
- if (history.length < 2) {
109
- return { trend: 'stable', entries: history };
110
- }
111
- const recent = history.slice(-5);
112
- const firstScore = recent[0].overallScore;
113
- const lastScore = recent[recent.length - 1].overallScore;
114
- let trend;
115
- if (lastScore > firstScore + 5) {
116
- trend = 'improving';
117
- }
118
- else if (lastScore < firstScore - 5) {
119
- trend = 'degrading';
120
- }
121
- else {
122
- trend = 'stable';
123
- }
124
- return { trend, entries: recent };
125
- }
126
- async getDeclaredLevel(projectPath, corePath) {
127
- const resolvedCorePath = corePath || this.findCorePath(projectPath);
128
- const evolithYamlPath = path.join(projectPath, 'evolith.yaml');
129
- if (await this.fs.exists(evolithYamlPath)) {
130
- try {
131
- const content = await this.fs.readFile(evolithYamlPath);
132
- const config = JSON.parse(content);
133
- const arch = config.product?.architecture;
134
- if (arch === 'F1' || arch === 'F2' || arch === 'F3') {
135
- return arch;
136
- }
137
- }
138
- catch {
139
- }
140
- }
141
- return this.detectActualLevel(projectPath, resolvedCorePath);
142
- }
143
- detectActualLevel(projectPath, corePath) {
144
- const srcPath = path.join(projectPath, 'src');
145
- const hasDockerfile = this.fs.existsSync(path.join(projectPath, 'Dockerfile'));
146
- const hasContracts = this.fs.existsSync(path.join(projectPath, 'contracts'));
147
- const hasEvents = this.fs.existsSync(path.join(projectPath, 'events')) ||
148
- this.fs.existsSync(path.join(projectPath, 'src', 'events'));
149
- if (hasDockerfile && hasContracts && hasEvents) {
150
- return 'F3';
151
- }
152
- if (hasContracts && hasEvents) {
153
- return 'F2';
154
- }
155
- return 'F1';
156
- }
157
- mapIssuesToViolations(issues) {
158
- return issues.map(issue => ({
159
- ruleId: issue.ruleId,
160
- severity: issue.severity,
161
- category: issue.category,
162
- title: issue.title,
163
- description: issue.description,
164
- blocking: issue.blocking,
165
- firstDetected: new Date().toISOString(),
166
- status: 'new',
167
- }));
168
- }
169
- findNewViolations(current, previous) {
170
- const previousRuleIds = new Set(previous.map(v => v.ruleId));
171
- return current
172
- .filter(v => !previousRuleIds.has(v.ruleId))
173
- .map(v => ({ ...v, status: 'new' }));
174
- }
175
- findResolvedViolations(current, previous) {
176
- const currentRuleIds = new Set(current.map(v => v.ruleId));
177
- return previous
178
- .filter(v => !currentRuleIds.has(v.ruleId))
179
- .map(v => ({ ...v, status: 'resolved' }));
180
- }
181
- hasLevelDrift(declaredLevel, validationResult) {
182
- if (validationResult.status === 'failed') {
183
- const blockingIssues = validationResult.issues.filter(i => i.blocking);
184
- return blockingIssues.length > 0;
185
- }
186
- return false;
187
- }
188
- calculateDriftSeverity(newViolations, persistentViolations, validationResult) {
189
- const blockingNew = newViolations.filter(v => v.blocking);
190
- const blockingPersistent = persistentViolations.filter(v => v.blocking);
191
- if (blockingNew.length > 0) {
192
- return 'critical';
193
- }
194
- if (blockingPersistent.length > 2) {
195
- return 'high';
196
- }
197
- if (newViolations.length > 0) {
198
- return 'medium';
199
- }
200
- if (persistentViolations.length > 0) {
201
- return 'low';
202
- }
203
- return 'none';
204
- }
205
- calculateOverallScore(validationResult) {
206
- if (validationResult.rulesChecked === 0) {
207
- return 100;
208
- }
209
- const blockingIssues = validationResult.issues.filter(i => i.blocking).length;
210
- const nonBlockingIssues = validationResult.issues.filter(i => !i.blocking).length;
211
- const blockingPenalty = blockingIssues * 15;
212
- const nonBlockingPenalty = nonBlockingIssues * 5;
213
- const score = Math.max(0, 100 - blockingPenalty - nonBlockingPenalty);
214
- return Math.min(100, score);
215
- }
216
- async loadHistory(projectPath, historyPath) {
217
- const historyFile = historyPath || path.join(projectPath, '.evolith', 'drift-history.json');
218
- if (!await this.fs.exists(historyFile)) {
219
- return [];
220
- }
221
- try {
222
- const content = await this.fs.readFile(historyFile);
223
- return JSON.parse(content);
224
- }
225
- catch {
226
- return [];
227
- }
228
- }
229
- async storeHistory(projectPath, report, history, historyPath) {
230
- const historyFile = historyPath || path.join(projectPath, '.evolith', 'drift-history.json');
231
- const entry = {
232
- timestamp: report.timestamp,
233
- declaredLevel: report.declaredLevel,
234
- detectedLevel: report.detectedLevel,
235
- violationsCount: report.newViolations.length + report.persistentViolations.length,
236
- blockingViolationsCount: [...report.newViolations, ...report.persistentViolations].filter(v => v.blocking).length,
237
- overallScore: report.overallScore,
238
- violations: [...report.newViolations, ...report.persistentViolations],
239
- };
240
- history.push(entry);
241
- const maxHistoryEntries = 50;
242
- if (history.length > maxHistoryEntries) {
243
- history = history.slice(-maxHistoryEntries);
244
- }
245
- const historyDir = path.dirname(historyFile);
246
- await this.fs.ensureDir(historyDir);
247
- await this.fs.writeJson(historyFile, history);
248
- }
249
- getProjectId(projectPath) {
250
- const parts = projectPath.split(path.sep);
251
- return parts[parts.length - 1] || 'unknown';
252
- }
253
- findCorePath(projectPath) {
254
- const parts = projectPath.split(path.sep);
255
- while (parts.length > 0) {
256
- parts.pop();
257
- const candidate = path.join(parts.join(path.sep), 'rulesets');
258
- if (this.fs.existsSync(candidate)) {
259
- return parts.join(path.sep);
260
- }
261
- }
262
- return path.join(projectPath, '..', 'evolith');
263
- }
264
- }
265
- exports.ArchitectureDriftService = ArchitectureDriftService;
266
- //# sourceMappingURL=architecture-drift.service.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"architecture-drift.service.js","sourceRoot":"","sources":["../../../src/core/validators/architecture-drift.service.ts"],"names":[],"mappings":"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"}
@@ -1,315 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- const architecture_drift_service_1 = require("./architecture-drift.service");
4
- const abstractions_1 = require("../abstractions");
5
- const ruleset_validator_service_1 = require("./ruleset-validator.service");
6
- const createMockFileSystem = (overrides) => {
7
- const mock = {
8
- exists: jest.fn().mockResolvedValue(false),
9
- existsSync: jest.fn().mockReturnValue(false),
10
- readFile: jest.fn().mockResolvedValue(''),
11
- readJson: jest.fn().mockResolvedValue({}),
12
- readdirNames: jest.fn().mockResolvedValue([]),
13
- writeFile: jest.fn().mockResolvedValue(undefined),
14
- writeJson: jest.fn().mockResolvedValue(undefined),
15
- ensureDir: jest.fn().mockResolvedValue(undefined),
16
- remove: jest.fn().mockResolvedValue(undefined),
17
- stat: jest.fn().mockResolvedValue({ isDirectory: () => true, isFile: () => false }),
18
- ...overrides,
19
- };
20
- return mock;
21
- };
22
- const mockArchitectureResult = {
23
- status: 'passed',
24
- levels: ['F1'],
25
- rulesChecked: 8,
26
- issues: [],
27
- timestamp: new Date().toISOString(),
28
- };
29
- jest.mock('./ruleset-validator.service', () => {
30
- return {
31
- RulesetValidatorService: jest.fn().mockImplementation(() => ({
32
- validateArchitecture: jest.fn().mockResolvedValue(mockArchitectureResult),
33
- })),
34
- };
35
- });
36
- describe('ArchitectureDriftService', () => {
37
- let service;
38
- let mockFs;
39
- beforeEach(() => {
40
- (0, abstractions_1.resetContainer)();
41
- jest.clearAllMocks();
42
- mockFs = createMockFileSystem();
43
- const mockProvider = {
44
- createFileSystem: () => mockFs,
45
- };
46
- (0, abstractions_1.getContainer)().setFileSystemProvider(mockProvider);
47
- service = new architecture_drift_service_1.ArchitectureDriftService('/core');
48
- });
49
- afterEach(() => {
50
- (0, abstractions_1.resetContainer)();
51
- });
52
- describe('detectDrift', () => {
53
- it('should return a drift report with all required fields', async () => {
54
- const report = await service.detectDrift({
55
- projectPath: '/project',
56
- declaredLevel: 'F1',
57
- storeHistory: false,
58
- });
59
- expect(report).toHaveProperty('projectId');
60
- expect(report).toHaveProperty('declaredLevel');
61
- expect(report).toHaveProperty('detectedLevel');
62
- expect(report).toHaveProperty('driftDetected');
63
- expect(report).toHaveProperty('driftSeverity');
64
- expect(report).toHaveProperty('newViolations');
65
- expect(report).toHaveProperty('resolvedViolations');
66
- expect(report).toHaveProperty('persistentViolations');
67
- expect(report).toHaveProperty('overallScore');
68
- expect(report).toHaveProperty('timestamp');
69
- expect(report).toHaveProperty('historyPath');
70
- });
71
- it('should detect no drift when validation passes', async () => {
72
- const report = await service.detectDrift({
73
- projectPath: '/project',
74
- declaredLevel: 'F1',
75
- storeHistory: false,
76
- });
77
- expect(report.driftDetected).toBe(false);
78
- expect(report.driftSeverity).toBe('none');
79
- expect(report.overallScore).toBe(100);
80
- });
81
- it('should detect drift when validation fails', async () => {
82
- ruleset_validator_service_1.RulesetValidatorService.mockImplementation(() => ({
83
- validateArchitecture: jest.fn().mockResolvedValue({
84
- status: 'failed',
85
- levels: ['F1'],
86
- rulesChecked: 8,
87
- issues: [{
88
- ruleId: 'F1-R01',
89
- severity: 'MUST',
90
- category: 'topology',
91
- title: 'Single Deployment Unit',
92
- description: 'Multiple deployment units detected',
93
- file: 'src/',
94
- blocking: true,
95
- }],
96
- timestamp: new Date().toISOString(),
97
- }),
98
- }));
99
- const driftService = new architecture_drift_service_1.ArchitectureDriftService('/core');
100
- const report = await driftService.detectDrift({
101
- projectPath: '/project',
102
- declaredLevel: 'F1',
103
- storeHistory: false,
104
- });
105
- expect(report.driftDetected).toBe(true);
106
- expect(report.newViolations.length).toBeGreaterThan(0);
107
- });
108
- it('should calculate correct overall score', async () => {
109
- ruleset_validator_service_1.RulesetValidatorService.mockImplementation(() => ({
110
- validateArchitecture: jest.fn().mockResolvedValue({
111
- status: 'passed',
112
- levels: ['F1'],
113
- rulesChecked: 8,
114
- issues: [
115
- { ruleId: 'F1-R01', severity: 'MUST', category: 'topology', title: 'Issue 1', description: 'desc', blocking: true },
116
- { ruleId: 'F1-R02', severity: 'SHOULD', category: 'bounded-contexts', title: 'Issue 2', description: 'desc', blocking: false },
117
- ],
118
- timestamp: new Date().toISOString(),
119
- }),
120
- }));
121
- mockFs.existsSync.mockReturnValue(false);
122
- const driftService = new architecture_drift_service_1.ArchitectureDriftService('/core');
123
- const report = await driftService.detectDrift({
124
- projectPath: '/project',
125
- declaredLevel: 'F1',
126
- storeHistory: false,
127
- });
128
- expect(report.overallScore).toBe(80);
129
- });
130
- it('should store history when storeHistory is true', async () => {
131
- mockFs.exists.mockResolvedValue(false);
132
- const report = await service.detectDrift({
133
- projectPath: '/project',
134
- declaredLevel: 'F1',
135
- storeHistory: true,
136
- });
137
- expect(mockFs.writeJson).toHaveBeenCalled();
138
- });
139
- it('should not store history when storeHistory is false', async () => {
140
- await service.detectDrift({
141
- projectPath: '/project',
142
- declaredLevel: 'F1',
143
- storeHistory: false,
144
- });
145
- expect(mockFs.writeJson).not.toHaveBeenCalled();
146
- });
147
- });
148
- describe('detectLevelDrift', () => {
149
- it('should return level comparison', async () => {
150
- const result = await service.detectLevelDrift('/project');
151
- expect(result).toHaveProperty('declared');
152
- expect(result).toHaveProperty('detected');
153
- expect(result).toHaveProperty('drifted');
154
- });
155
- it('should detect drift when declared differs from detected', async () => {
156
- mockFs.exists.mockImplementation((p) => {
157
- if (p.includes('evolith.yaml'))
158
- return Promise.resolve(true);
159
- return Promise.resolve(false);
160
- });
161
- mockFs.readFile.mockResolvedValue(JSON.stringify({ product: { architecture: 'F2' } }));
162
- const result = await service.detectLevelDrift('/project');
163
- expect(result.drifted).toBe(result.declared !== result.detected);
164
- });
165
- });
166
- describe('getDriftHistory', () => {
167
- it('should return empty array when no history exists', async () => {
168
- mockFs.exists.mockResolvedValue(false);
169
- const history = await service.getDriftHistory('/project');
170
- expect(history).toEqual([]);
171
- });
172
- it('should return history entries when file exists', async () => {
173
- const mockHistory = [
174
- {
175
- timestamp: '2026-01-01T00:00:00.000Z',
176
- declaredLevel: 'F1',
177
- detectedLevel: 'F1',
178
- violationsCount: 0,
179
- blockingViolationsCount: 0,
180
- overallScore: 100,
181
- violations: [],
182
- },
183
- ];
184
- mockFs.exists.mockResolvedValue(true);
185
- mockFs.readFile.mockResolvedValue(JSON.stringify(mockHistory));
186
- const history = await service.getDriftHistory('/project');
187
- expect(history).toHaveLength(1);
188
- expect(history[0].overallScore).toBe(100);
189
- });
190
- });
191
- describe('getDriftTrend', () => {
192
- it('should return stable trend with insufficient history', async () => {
193
- mockFs.exists.mockResolvedValue(false);
194
- const { trend, entries } = await service.getDriftTrend('/project');
195
- expect(trend).toBe('stable');
196
- expect(entries).toEqual([]);
197
- });
198
- it('should detect improving trend', async () => {
199
- const mockHistory = [
200
- { timestamp: '2026-01-01', declaredLevel: 'F1', detectedLevel: 'F1', violationsCount: 5, blockingViolationsCount: 1, overallScore: 60, violations: [] },
201
- { timestamp: '2026-01-02', declaredLevel: 'F1', detectedLevel: 'F1', violationsCount: 3, blockingViolationsCount: 0, overallScore: 80, violations: [] },
202
- { timestamp: '2026-01-03', declaredLevel: 'F1', detectedLevel: 'F1', violationsCount: 1, blockingViolationsCount: 0, overallScore: 95, violations: [] },
203
- ];
204
- mockFs.exists.mockResolvedValue(true);
205
- mockFs.readFile.mockResolvedValue(JSON.stringify(mockHistory));
206
- const { trend } = await service.getDriftTrend('/project');
207
- expect(trend).toBe('improving');
208
- });
209
- it('should detect degrading trend', async () => {
210
- const mockHistory = [
211
- { timestamp: '2026-01-01', declaredLevel: 'F1', detectedLevel: 'F1', violationsCount: 0, blockingViolationsCount: 0, overallScore: 100, violations: [] },
212
- { timestamp: '2026-01-02', declaredLevel: 'F1', detectedLevel: 'F1', violationsCount: 3, blockingViolationsCount: 1, overallScore: 70, violations: [] },
213
- { timestamp: '2026-01-03', declaredLevel: 'F1', detectedLevel: 'F1', violationsCount: 5, blockingViolationsCount: 2, overallScore: 50, violations: [] },
214
- ];
215
- mockFs.exists.mockResolvedValue(true);
216
- mockFs.readFile.mockResolvedValue(JSON.stringify(mockHistory));
217
- const { trend } = await service.getDriftTrend('/project');
218
- expect(trend).toBe('degrading');
219
- });
220
- });
221
- describe('calculateDriftSeverity', () => {
222
- it('should return critical for new blocking violations', async () => {
223
- ruleset_validator_service_1.RulesetValidatorService.mockImplementation(() => ({
224
- validateArchitecture: jest.fn().mockResolvedValue({
225
- status: 'failed',
226
- levels: ['F1'],
227
- rulesChecked: 8,
228
- issues: [{ ruleId: 'F1-R01', severity: 'MUST', category: 'topology', title: 'Blocking', description: 'desc', blocking: true }],
229
- timestamp: new Date().toISOString(),
230
- }),
231
- }));
232
- const driftService = new architecture_drift_service_1.ArchitectureDriftService('/core');
233
- const report = await driftService.detectDrift({
234
- projectPath: '/project',
235
- declaredLevel: 'F1',
236
- storeHistory: false,
237
- });
238
- expect(report.driftSeverity).toBe('critical');
239
- });
240
- it('should calculate drift severity based on violations', async () => {
241
- const report = await service.detectDrift({
242
- projectPath: '/project',
243
- declaredLevel: 'F1',
244
- storeHistory: false,
245
- });
246
- expect(report).toHaveProperty('driftSeverity');
247
- expect(['critical', 'high', 'medium', 'low', 'none']).toContain(report.driftSeverity);
248
- });
249
- });
250
- describe('findNewViolations', () => {
251
- it('should identify new violations not in previous list', async () => {
252
- ruleset_validator_service_1.RulesetValidatorService.mockImplementation(() => ({
253
- validateArchitecture: jest.fn().mockResolvedValue({
254
- status: 'failed',
255
- levels: ['F1'],
256
- rulesChecked: 8,
257
- issues: [{ ruleId: 'F1-R01', severity: 'MUST', category: 'topology', title: 'New', description: 'desc', blocking: true }],
258
- timestamp: new Date().toISOString(),
259
- }),
260
- }));
261
- mockFs.exists.mockResolvedValue(true);
262
- mockFs.readFile.mockResolvedValue(JSON.stringify([
263
- { timestamp: '2026-01-01', declaredLevel: 'F1', detectedLevel: 'F1', violationsCount: 0, blockingViolationsCount: 0, overallScore: 100, violations: [] },
264
- ]));
265
- const driftService = new architecture_drift_service_1.ArchitectureDriftService('/core');
266
- const report = await driftService.detectDrift({
267
- projectPath: '/project',
268
- declaredLevel: 'F1',
269
- storeHistory: true,
270
- });
271
- expect(report.newViolations.length).toBeGreaterThan(0);
272
- expect(report.newViolations[0].status).toBe('new');
273
- });
274
- });
275
- describe('findResolvedViolations', () => {
276
- it('should identify resolved violations no longer present', async () => {
277
- ruleset_validator_service_1.RulesetValidatorService.mockImplementation(() => ({
278
- validateArchitecture: jest.fn().mockResolvedValue({
279
- status: 'passed',
280
- levels: ['F1'],
281
- rulesChecked: 8,
282
- issues: [],
283
- timestamp: new Date().toISOString(),
284
- }),
285
- }));
286
- mockFs.existsSync.mockReturnValue(false);
287
- mockFs.exists.mockResolvedValue(true);
288
- mockFs.readFile.mockImplementation((p) => {
289
- if (p.includes('drift-history')) {
290
- return Promise.resolve(JSON.stringify([
291
- {
292
- timestamp: '2026-01-01',
293
- declaredLevel: 'F1',
294
- detectedLevel: 'F1',
295
- violationsCount: 1,
296
- blockingViolationsCount: 0,
297
- overallScore: 95,
298
- violations: [{ ruleId: 'F1-R01', severity: 'SHOULD', category: 'topology', title: 'Old', description: 'desc', blocking: false, firstDetected: '2026-01-01', status: 'persistent' }],
299
- },
300
- ]));
301
- }
302
- return Promise.resolve(JSON.stringify({ product: { architecture: 'F1' } }));
303
- });
304
- const driftService = new architecture_drift_service_1.ArchitectureDriftService('/core');
305
- const report = await driftService.detectDrift({
306
- projectPath: '/project',
307
- declaredLevel: 'F1',
308
- storeHistory: true,
309
- });
310
- expect(report.resolvedViolations.length).toBeGreaterThan(0);
311
- expect(report.resolvedViolations[0].status).toBe('resolved');
312
- });
313
- });
314
- });
315
- //# sourceMappingURL=architecture-drift.service.spec.js.map