@girardelli/architect 5.0.0 → 8.1.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 (335) hide show
  1. package/dist/{cli.d.ts → src/adapters/cli.d.ts} +1 -2
  2. package/dist/{cli.js → src/adapters/cli.js} +191 -213
  3. package/dist/src/adapters/cli.js.map +1 -0
  4. package/dist/src/adapters/github-action.d.ts +9 -0
  5. package/dist/src/adapters/github-action.js +94 -0
  6. package/dist/src/adapters/github-action.js.map +1 -0
  7. package/dist/src/adapters/html-reporter/scripts.d.ts +5 -0
  8. package/dist/src/adapters/html-reporter/scripts.js +400 -0
  9. package/dist/src/adapters/html-reporter/scripts.js.map +1 -0
  10. package/dist/src/adapters/html-reporter/sections/agents.d.ts +2 -0
  11. package/dist/src/adapters/html-reporter/sections/agents.js +260 -0
  12. package/dist/src/adapters/html-reporter/sections/agents.js.map +1 -0
  13. package/dist/src/adapters/html-reporter/sections/anti-patterns.d.ts +13 -0
  14. package/dist/src/adapters/html-reporter/sections/anti-patterns.js +64 -0
  15. package/dist/src/adapters/html-reporter/sections/anti-patterns.js.map +1 -0
  16. package/dist/src/adapters/html-reporter/sections/header.d.ts +3 -0
  17. package/dist/src/adapters/html-reporter/sections/header.js +30 -0
  18. package/dist/src/adapters/html-reporter/sections/header.js.map +1 -0
  19. package/dist/src/adapters/html-reporter/sections/layers.d.ts +9 -0
  20. package/dist/src/adapters/html-reporter/sections/layers.js +143 -0
  21. package/dist/src/adapters/html-reporter/sections/layers.js.map +1 -0
  22. package/dist/src/adapters/html-reporter/sections/overview.d.ts +2 -0
  23. package/dist/src/adapters/html-reporter/sections/overview.js +58 -0
  24. package/dist/src/adapters/html-reporter/sections/overview.js.map +1 -0
  25. package/dist/src/adapters/html-reporter/sections/refactoring-plan.d.ts +3 -0
  26. package/dist/src/adapters/html-reporter/sections/refactoring-plan.js +151 -0
  27. package/dist/src/adapters/html-reporter/sections/refactoring-plan.js.map +1 -0
  28. package/dist/src/adapters/html-reporter/sections/score.d.ts +7 -0
  29. package/dist/src/adapters/html-reporter/sections/score.js +70 -0
  30. package/dist/src/adapters/html-reporter/sections/score.js.map +1 -0
  31. package/dist/src/adapters/html-reporter/sections/suggestions.d.ts +7 -0
  32. package/dist/src/adapters/html-reporter/sections/suggestions.js +34 -0
  33. package/dist/src/adapters/html-reporter/sections/suggestions.js.map +1 -0
  34. package/dist/src/adapters/html-reporter/styles.d.ts +1 -0
  35. package/dist/src/adapters/html-reporter/styles.js +526 -0
  36. package/dist/src/adapters/html-reporter/styles.js.map +1 -0
  37. package/dist/src/adapters/html-reporter/utils_adapters.d.ts +20 -0
  38. package/dist/src/adapters/html-reporter/utils_adapters.js +32 -0
  39. package/dist/src/adapters/html-reporter/utils_adapters.js.map +1 -0
  40. package/dist/src/adapters/html-reporter/utils_sections.d.ts +7 -0
  41. package/dist/src/adapters/html-reporter/utils_sections.js +58 -0
  42. package/dist/src/adapters/html-reporter/utils_sections.js.map +1 -0
  43. package/dist/src/adapters/html-reporter.d.ts +10 -0
  44. package/dist/src/adapters/html-reporter.js +97 -0
  45. package/dist/src/adapters/html-reporter.js.map +1 -0
  46. package/dist/src/adapters/progress-logger.d.ts +55 -0
  47. package/dist/src/adapters/progress-logger.js +200 -0
  48. package/dist/src/adapters/progress-logger.js.map +1 -0
  49. package/dist/{refactor-reporter.d.ts → src/adapters/refactor-reporter.d.ts} +1 -2
  50. package/dist/{refactor-reporter.js → src/adapters/refactor-reporter.js} +1 -1
  51. package/dist/src/adapters/refactor-reporter.js.map +1 -0
  52. package/dist/{reporter.d.ts → src/adapters/reporter.d.ts} +1 -2
  53. package/dist/src/adapters/reporter.js.map +1 -0
  54. package/dist/src/core/GenesisTerminal.d.ts +8 -0
  55. package/dist/src/core/GenesisTerminal.js +105 -0
  56. package/dist/src/core/GenesisTerminal.js.map +1 -0
  57. package/dist/{index.d.ts → src/core/architect.d.ts} +4 -18
  58. package/dist/{index.js → src/core/architect.js} +22 -21
  59. package/dist/src/core/architect.js.map +1 -0
  60. package/dist/tests/architect-adapter-enrichment.test.d.ts +1 -0
  61. package/dist/tests/architect-adapter-enrichment.test.js +11 -0
  62. package/dist/tests/architect-adapter-enrichment.test.js.map +1 -0
  63. package/dist/tests/github-action.test.d.ts +1 -0
  64. package/dist/tests/github-action.test.js +92 -0
  65. package/dist/tests/github-action.test.js.map +1 -0
  66. package/package.json +15 -65
  67. package/src/adapters/cli.ts +492 -0
  68. package/src/adapters/github-action.ts +109 -0
  69. package/src/adapters/html-reporter/scripts.ts +402 -0
  70. package/src/adapters/html-reporter/sections/agents.ts +267 -0
  71. package/src/adapters/html-reporter/sections/anti-patterns.ts +81 -0
  72. package/src/adapters/html-reporter/sections/header.ts +35 -0
  73. package/src/adapters/html-reporter/sections/layers.ts +165 -0
  74. package/src/adapters/html-reporter/sections/overview.ts +64 -0
  75. package/src/adapters/html-reporter/sections/refactoring-plan.ts +166 -0
  76. package/src/adapters/html-reporter/sections/score.ts +80 -0
  77. package/src/adapters/html-reporter/sections/suggestions.ts +39 -0
  78. package/src/adapters/html-reporter/styles.ts +525 -0
  79. package/src/adapters/html-reporter/utils_adapters.ts +39 -0
  80. package/src/adapters/html-reporter/utils_sections.ts +55 -0
  81. package/src/adapters/html-reporter.ts +102 -0
  82. package/src/adapters/progress-logger.ts +236 -0
  83. package/src/{refactor-reporter.ts → adapters/refactor-reporter.ts} +2 -2
  84. package/src/{reporter.ts → adapters/reporter.ts} +1 -1
  85. package/src/core/GenesisTerminal.ts +127 -0
  86. package/src/{index.ts → core/architect.ts} +27 -45
  87. package/tests/github-action.test.ts +109 -0
  88. package/tsconfig.json +12 -19
  89. package/CONTRIBUTING.md +0 -140
  90. package/LICENSE +0 -21
  91. package/PROJECT_STRUCTURE.txt +0 -168
  92. package/README.md +0 -257
  93. package/architect-run.sh +0 -431
  94. package/assets/banner-v3.html +0 -561
  95. package/dist/agent-generator/context-enricher.d.ts +0 -58
  96. package/dist/agent-generator/context-enricher.d.ts.map +0 -1
  97. package/dist/agent-generator/context-enricher.js +0 -613
  98. package/dist/agent-generator/context-enricher.js.map +0 -1
  99. package/dist/agent-generator/domain-inferrer.d.ts +0 -52
  100. package/dist/agent-generator/domain-inferrer.d.ts.map +0 -1
  101. package/dist/agent-generator/domain-inferrer.js +0 -585
  102. package/dist/agent-generator/domain-inferrer.js.map +0 -1
  103. package/dist/agent-generator/framework-detector.d.ts +0 -40
  104. package/dist/agent-generator/framework-detector.d.ts.map +0 -1
  105. package/dist/agent-generator/framework-detector.js +0 -611
  106. package/dist/agent-generator/framework-detector.js.map +0 -1
  107. package/dist/agent-generator/index.d.ts +0 -47
  108. package/dist/agent-generator/index.d.ts.map +0 -1
  109. package/dist/agent-generator/index.js +0 -545
  110. package/dist/agent-generator/index.js.map +0 -1
  111. package/dist/agent-generator/stack-detector.d.ts +0 -14
  112. package/dist/agent-generator/stack-detector.d.ts.map +0 -1
  113. package/dist/agent-generator/stack-detector.js +0 -124
  114. package/dist/agent-generator/stack-detector.js.map +0 -1
  115. package/dist/agent-generator/templates/core/agents.d.ts +0 -17
  116. package/dist/agent-generator/templates/core/agents.d.ts.map +0 -1
  117. package/dist/agent-generator/templates/core/agents.js +0 -1256
  118. package/dist/agent-generator/templates/core/agents.js.map +0 -1
  119. package/dist/agent-generator/templates/core/architecture-rules.d.ts +0 -7
  120. package/dist/agent-generator/templates/core/architecture-rules.d.ts.map +0 -1
  121. package/dist/agent-generator/templates/core/architecture-rules.js +0 -274
  122. package/dist/agent-generator/templates/core/architecture-rules.js.map +0 -1
  123. package/dist/agent-generator/templates/core/general-rules.d.ts +0 -8
  124. package/dist/agent-generator/templates/core/general-rules.d.ts.map +0 -1
  125. package/dist/agent-generator/templates/core/general-rules.js +0 -301
  126. package/dist/agent-generator/templates/core/general-rules.js.map +0 -1
  127. package/dist/agent-generator/templates/core/hooks-generator.d.ts +0 -21
  128. package/dist/agent-generator/templates/core/hooks-generator.d.ts.map +0 -1
  129. package/dist/agent-generator/templates/core/hooks-generator.js +0 -233
  130. package/dist/agent-generator/templates/core/hooks-generator.js.map +0 -1
  131. package/dist/agent-generator/templates/core/index-md.d.ts +0 -7
  132. package/dist/agent-generator/templates/core/index-md.d.ts.map +0 -1
  133. package/dist/agent-generator/templates/core/index-md.js +0 -246
  134. package/dist/agent-generator/templates/core/index-md.js.map +0 -1
  135. package/dist/agent-generator/templates/core/orchestrator.d.ts +0 -8
  136. package/dist/agent-generator/templates/core/orchestrator.d.ts.map +0 -1
  137. package/dist/agent-generator/templates/core/orchestrator.js +0 -422
  138. package/dist/agent-generator/templates/core/orchestrator.js.map +0 -1
  139. package/dist/agent-generator/templates/core/preflight.d.ts +0 -8
  140. package/dist/agent-generator/templates/core/preflight.d.ts.map +0 -1
  141. package/dist/agent-generator/templates/core/preflight.js +0 -213
  142. package/dist/agent-generator/templates/core/preflight.js.map +0 -1
  143. package/dist/agent-generator/templates/core/quality-gates.d.ts +0 -11
  144. package/dist/agent-generator/templates/core/quality-gates.d.ts.map +0 -1
  145. package/dist/agent-generator/templates/core/quality-gates.js +0 -254
  146. package/dist/agent-generator/templates/core/quality-gates.js.map +0 -1
  147. package/dist/agent-generator/templates/core/security-rules.d.ts +0 -7
  148. package/dist/agent-generator/templates/core/security-rules.d.ts.map +0 -1
  149. package/dist/agent-generator/templates/core/security-rules.js +0 -528
  150. package/dist/agent-generator/templates/core/security-rules.js.map +0 -1
  151. package/dist/agent-generator/templates/core/skills-generator.d.ts +0 -19
  152. package/dist/agent-generator/templates/core/skills-generator.d.ts.map +0 -1
  153. package/dist/agent-generator/templates/core/skills-generator.js +0 -546
  154. package/dist/agent-generator/templates/core/skills-generator.js.map +0 -1
  155. package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts +0 -7
  156. package/dist/agent-generator/templates/core/workflow-fix-bug.d.ts.map +0 -1
  157. package/dist/agent-generator/templates/core/workflow-fix-bug.js +0 -237
  158. package/dist/agent-generator/templates/core/workflow-fix-bug.js.map +0 -1
  159. package/dist/agent-generator/templates/core/workflow-new-feature.d.ts +0 -8
  160. package/dist/agent-generator/templates/core/workflow-new-feature.d.ts.map +0 -1
  161. package/dist/agent-generator/templates/core/workflow-new-feature.js +0 -321
  162. package/dist/agent-generator/templates/core/workflow-new-feature.js.map +0 -1
  163. package/dist/agent-generator/templates/core/workflow-review.d.ts +0 -7
  164. package/dist/agent-generator/templates/core/workflow-review.d.ts.map +0 -1
  165. package/dist/agent-generator/templates/core/workflow-review.js +0 -104
  166. package/dist/agent-generator/templates/core/workflow-review.js.map +0 -1
  167. package/dist/agent-generator/templates/domain/index.d.ts +0 -22
  168. package/dist/agent-generator/templates/domain/index.d.ts.map +0 -1
  169. package/dist/agent-generator/templates/domain/index.js +0 -1176
  170. package/dist/agent-generator/templates/domain/index.js.map +0 -1
  171. package/dist/agent-generator/templates/stack/index.d.ts +0 -8
  172. package/dist/agent-generator/templates/stack/index.d.ts.map +0 -1
  173. package/dist/agent-generator/templates/stack/index.js +0 -695
  174. package/dist/agent-generator/templates/stack/index.js.map +0 -1
  175. package/dist/agent-generator/templates/template-helpers.d.ts +0 -75
  176. package/dist/agent-generator/templates/template-helpers.d.ts.map +0 -1
  177. package/dist/agent-generator/templates/template-helpers.js +0 -726
  178. package/dist/agent-generator/templates/template-helpers.js.map +0 -1
  179. package/dist/agent-generator/types.d.ts +0 -196
  180. package/dist/agent-generator/types.d.ts.map +0 -1
  181. package/dist/agent-generator/types.js +0 -27
  182. package/dist/agent-generator/types.js.map +0 -1
  183. package/dist/analyzer.d.ts +0 -38
  184. package/dist/analyzer.d.ts.map +0 -1
  185. package/dist/analyzer.js +0 -383
  186. package/dist/analyzer.js.map +0 -1
  187. package/dist/analyzers/forecast.d.ts +0 -85
  188. package/dist/analyzers/forecast.d.ts.map +0 -1
  189. package/dist/analyzers/forecast.js +0 -337
  190. package/dist/analyzers/forecast.js.map +0 -1
  191. package/dist/analyzers/git-cache.d.ts +0 -7
  192. package/dist/analyzers/git-cache.d.ts.map +0 -1
  193. package/dist/analyzers/git-cache.js +0 -41
  194. package/dist/analyzers/git-cache.js.map +0 -1
  195. package/dist/analyzers/git-history.d.ts +0 -113
  196. package/dist/analyzers/git-history.d.ts.map +0 -1
  197. package/dist/analyzers/git-history.js +0 -333
  198. package/dist/analyzers/git-history.js.map +0 -1
  199. package/dist/analyzers/index.d.ts +0 -10
  200. package/dist/analyzers/index.d.ts.map +0 -1
  201. package/dist/analyzers/index.js +0 -7
  202. package/dist/analyzers/index.js.map +0 -1
  203. package/dist/analyzers/temporal-scorer.d.ts +0 -72
  204. package/dist/analyzers/temporal-scorer.d.ts.map +0 -1
  205. package/dist/analyzers/temporal-scorer.js +0 -140
  206. package/dist/analyzers/temporal-scorer.js.map +0 -1
  207. package/dist/anti-patterns.d.ts +0 -24
  208. package/dist/anti-patterns.d.ts.map +0 -1
  209. package/dist/anti-patterns.js +0 -230
  210. package/dist/anti-patterns.js.map +0 -1
  211. package/dist/cli.d.ts.map +0 -1
  212. package/dist/cli.js.map +0 -1
  213. package/dist/config.d.ts +0 -12
  214. package/dist/config.d.ts.map +0 -1
  215. package/dist/config.js +0 -110
  216. package/dist/config.js.map +0 -1
  217. package/dist/diagram.d.ts +0 -9
  218. package/dist/diagram.d.ts.map +0 -1
  219. package/dist/diagram.js +0 -116
  220. package/dist/diagram.js.map +0 -1
  221. package/dist/html-reporter.d.ts +0 -47
  222. package/dist/html-reporter.d.ts.map +0 -1
  223. package/dist/html-reporter.js +0 -1747
  224. package/dist/html-reporter.js.map +0 -1
  225. package/dist/index.d.ts.map +0 -1
  226. package/dist/index.js.map +0 -1
  227. package/dist/project-summarizer.d.ts +0 -38
  228. package/dist/project-summarizer.d.ts.map +0 -1
  229. package/dist/project-summarizer.js +0 -463
  230. package/dist/project-summarizer.js.map +0 -1
  231. package/dist/refactor-engine.d.ts +0 -18
  232. package/dist/refactor-engine.d.ts.map +0 -1
  233. package/dist/refactor-engine.js +0 -86
  234. package/dist/refactor-engine.js.map +0 -1
  235. package/dist/refactor-reporter.d.ts.map +0 -1
  236. package/dist/refactor-reporter.js.map +0 -1
  237. package/dist/reporter.d.ts.map +0 -1
  238. package/dist/reporter.js.map +0 -1
  239. package/dist/rules/barrel-optimizer.d.ts +0 -13
  240. package/dist/rules/barrel-optimizer.d.ts.map +0 -1
  241. package/dist/rules/barrel-optimizer.js +0 -77
  242. package/dist/rules/barrel-optimizer.js.map +0 -1
  243. package/dist/rules/dead-code-detector.d.ts +0 -21
  244. package/dist/rules/dead-code-detector.d.ts.map +0 -1
  245. package/dist/rules/dead-code-detector.js +0 -117
  246. package/dist/rules/dead-code-detector.js.map +0 -1
  247. package/dist/rules/hub-splitter.d.ts +0 -13
  248. package/dist/rules/hub-splitter.d.ts.map +0 -1
  249. package/dist/rules/hub-splitter.js +0 -110
  250. package/dist/rules/hub-splitter.js.map +0 -1
  251. package/dist/rules/import-organizer.d.ts +0 -13
  252. package/dist/rules/import-organizer.d.ts.map +0 -1
  253. package/dist/rules/import-organizer.js +0 -85
  254. package/dist/rules/import-organizer.js.map +0 -1
  255. package/dist/rules/module-grouper.d.ts +0 -13
  256. package/dist/rules/module-grouper.d.ts.map +0 -1
  257. package/dist/rules/module-grouper.js +0 -110
  258. package/dist/rules/module-grouper.js.map +0 -1
  259. package/dist/scanner.d.ts +0 -31
  260. package/dist/scanner.d.ts.map +0 -1
  261. package/dist/scanner.js +0 -328
  262. package/dist/scanner.js.map +0 -1
  263. package/dist/scorer.d.ts +0 -27
  264. package/dist/scorer.d.ts.map +0 -1
  265. package/dist/scorer.js +0 -229
  266. package/dist/scorer.js.map +0 -1
  267. package/dist/types.d.ts +0 -186
  268. package/dist/types.d.ts.map +0 -1
  269. package/dist/types.js +0 -2
  270. package/dist/types.js.map +0 -1
  271. package/examples/sample-report.md +0 -207
  272. package/jest.config.js +0 -18
  273. package/src/agent-generator/context-enricher.ts +0 -672
  274. package/src/agent-generator/domain-inferrer.ts +0 -635
  275. package/src/agent-generator/framework-detector.ts +0 -669
  276. package/src/agent-generator/index.ts +0 -634
  277. package/src/agent-generator/stack-detector.ts +0 -115
  278. package/src/agent-generator/templates/core/agents.ts +0 -1296
  279. package/src/agent-generator/templates/core/architecture-rules.ts +0 -287
  280. package/src/agent-generator/templates/core/general-rules.ts +0 -306
  281. package/src/agent-generator/templates/core/hooks-generator.ts +0 -242
  282. package/src/agent-generator/templates/core/index-md.ts +0 -260
  283. package/src/agent-generator/templates/core/orchestrator.ts +0 -459
  284. package/src/agent-generator/templates/core/preflight.ts +0 -215
  285. package/src/agent-generator/templates/core/quality-gates.ts +0 -256
  286. package/src/agent-generator/templates/core/security-rules.ts +0 -543
  287. package/src/agent-generator/templates/core/skills-generator.ts +0 -585
  288. package/src/agent-generator/templates/core/workflow-fix-bug.ts +0 -239
  289. package/src/agent-generator/templates/core/workflow-new-feature.ts +0 -323
  290. package/src/agent-generator/templates/core/workflow-review.ts +0 -106
  291. package/src/agent-generator/templates/domain/index.ts +0 -1201
  292. package/src/agent-generator/templates/stack/index.ts +0 -705
  293. package/src/agent-generator/templates/template-helpers.ts +0 -776
  294. package/src/agent-generator/types.ts +0 -232
  295. package/src/analyzer.ts +0 -447
  296. package/src/analyzers/forecast.ts +0 -496
  297. package/src/analyzers/git-cache.ts +0 -52
  298. package/src/analyzers/git-history.ts +0 -488
  299. package/src/analyzers/index.ts +0 -33
  300. package/src/analyzers/temporal-scorer.ts +0 -227
  301. package/src/anti-patterns.ts +0 -287
  302. package/src/cli.ts +0 -517
  303. package/src/config.ts +0 -123
  304. package/src/diagram.ts +0 -144
  305. package/src/html-reporter.ts +0 -1830
  306. package/src/project-summarizer.ts +0 -521
  307. package/src/refactor-engine.ts +0 -117
  308. package/src/rules/barrel-optimizer.ts +0 -97
  309. package/src/rules/dead-code-detector.ts +0 -132
  310. package/src/rules/hub-splitter.ts +0 -123
  311. package/src/rules/import-organizer.ts +0 -98
  312. package/src/rules/module-grouper.ts +0 -124
  313. package/src/scanner.ts +0 -344
  314. package/src/scorer.ts +0 -254
  315. package/src/types.ts +0 -193
  316. package/tests/agent-generator.test.ts +0 -427
  317. package/tests/analyzers-integration.test.ts +0 -174
  318. package/tests/anti-patterns.test.ts +0 -94
  319. package/tests/context-enricher.test.ts +0 -971
  320. package/tests/fixtures/monorepo/package.json +0 -6
  321. package/tests/fixtures/monorepo/packages/app/package.json +0 -12
  322. package/tests/fixtures/monorepo/packages/app/src/index.ts +0 -6
  323. package/tests/fixtures/monorepo/packages/core/package.json +0 -7
  324. package/tests/fixtures/monorepo/packages/core/src/index.ts +0 -7
  325. package/tests/forecast.test.ts +0 -509
  326. package/tests/framework-detector.test.ts +0 -1172
  327. package/tests/git-history.test.ts +0 -254
  328. package/tests/monorepo-scan.test.ts +0 -170
  329. package/tests/scanner.test.ts +0 -54
  330. package/tests/scorer.test.ts +0 -674
  331. package/tests/stack-detector.test.ts +0 -241
  332. package/tests/template-generation.test.ts +0 -706
  333. package/tests/template-helpers.test.ts +0 -1152
  334. package/tests/temporal-scorer.test.ts +0 -307
  335. /package/dist/{reporter.js → src/adapters/reporter.js} +0 -0
@@ -1,634 +0,0 @@
1
- import { existsSync, mkdirSync, readdirSync, readFileSync, writeFileSync, statSync } from 'fs';
2
- import { join } from 'path';
3
- import { AnalysisReport, RefactoringPlan } from '../types.js';
4
- import {
5
- StackInfo,
6
- AgentAuditFinding,
7
- AgentItem,
8
- AgentItemStatus,
9
- AgentSuggestion,
10
- TemplateContext,
11
- EnrichedTemplateContext,
12
- DomainInsights,
13
- ModuleDetail,
14
- DetectedEndpoint,
15
- FrameworkInfo,
16
- DetectedToolchain,
17
- AgentGeneratorConfig,
18
- DEFAULT_AGENT_CONFIG,
19
- } from './types.js';
20
- import { StackDetector } from './stack-detector.js';
21
- import { ContextEnricher } from './context-enricher.js';
22
-
23
- // ── Core Templates (Enterprise-Grade) ──
24
- import { generateIndexMd } from './templates/core/index-md.js';
25
- import { generateOrchestrator } from './templates/core/orchestrator.js';
26
- import { generatePreflight } from './templates/core/preflight.js';
27
- import { generateQualityGates } from './templates/core/quality-gates.js';
28
- import { generateGeneralRules } from './templates/core/general-rules.js';
29
- import { generateArchitectureRules } from './templates/core/architecture-rules.js';
30
- import { generateSecurityRules } from './templates/core/security-rules.js';
31
- import { generateNewFeatureWorkflow } from './templates/core/workflow-new-feature.js';
32
- import { generateFixBugWorkflow } from './templates/core/workflow-fix-bug.js';
33
- import { generateReviewWorkflow } from './templates/core/workflow-review.js';
34
- import {
35
- generateBackendAgent,
36
- generateFrontendAgent,
37
- generateSecurityAgent,
38
- generateQAAgent,
39
- generateTechDebtAgent,
40
- generateCodeReviewChecklist,
41
- generateDatabaseAgent,
42
- generateMobileAgent,
43
- } from './templates/core/agents.js';
44
-
45
- // ── Stack-Specific Templates ──
46
- import { generateStackRules, getStackRuleFileName } from './templates/stack/index.js';
47
-
48
- // ── Domain Templates ──
49
- import {
50
- generateC4Template,
51
- generateBddTemplate,
52
- generateTddTemplate,
53
- generateAdrTemplate,
54
- generateThreatModelTemplate,
55
- } from './templates/domain/index.js';
56
-
57
- // ── Skills Generator ──
58
- import { generateProjectSkills, generateArchitectIntegrationSkill, generateCIPipelineSkill, generateMonorepoGuideSkill } from './templates/core/skills-generator.js';
59
-
60
- // ── Hooks Generator ──
61
- import { generatePreCommitHook, generatePrePushHook, generatePostAnalysisHook } from './templates/core/hooks-generator.js';
62
-
63
- // Re-export types for backward compatibility
64
- export type { StackInfo, AgentAuditFinding, AgentItem, AgentItemStatus, AgentSuggestion, EnrichedTemplateContext, DomainInsights, ModuleDetail, DetectedEndpoint, FrameworkInfo, DetectedToolchain };
65
-
66
- /**
67
- * Agent Generator v3.1 — Enterprise-Grade
68
- *
69
- * Generates or audits .agent/ directories with enterprise-grade
70
- * agent frameworks: detailed workflows, approval gates, quality enforcement,
71
- * stack-specific agents, and domain templates.
72
- */
73
- export class AgentGenerator {
74
- private stackDetector = new StackDetector();
75
- private contextEnricher = new ContextEnricher();
76
-
77
- /** Max lines for any single generated .agent file */
78
- private static readonly MAX_FILE_LINES = 500;
79
-
80
- /** Paths that indicate third-party code — filter from agent context */
81
- private static readonly EXCLUDED_SEGMENTS = [
82
- 'node_modules', '/dist/', '/build/', '/coverage/',
83
- '/.next/', '/venv/', '/__pycache__/', '/target/',
84
- ];
85
-
86
- /**
87
- * Sanitize the report before passing to agent generation.
88
- * Removes anti-patterns, dependency nodes, and suggestions
89
- * that reference node_modules or build artifacts.
90
- */
91
- private sanitizeReport(report: AnalysisReport): AnalysisReport {
92
- const isProjectPath = (path: string): boolean => {
93
- const normalized = path.replace(/\\/g, '/');
94
- return !AgentGenerator.EXCLUDED_SEGMENTS.some(seg => normalized.includes(seg));
95
- };
96
-
97
- return {
98
- ...report,
99
- antiPatterns: report.antiPatterns.filter(ap => {
100
- if (!isProjectPath(ap.location)) return false;
101
- if (ap.affectedFiles?.some(f => !isProjectPath(f))) {
102
- // Keep the pattern but clean affected files
103
- ap.affectedFiles = ap.affectedFiles.filter(f => isProjectPath(f));
104
- }
105
- return true;
106
- }),
107
- dependencyGraph: {
108
- nodes: report.dependencyGraph.nodes.filter(n => isProjectPath(n)),
109
- edges: report.dependencyGraph.edges.filter(
110
- e => isProjectPath(e.from) && isProjectPath(e.to)
111
- ),
112
- },
113
- suggestions: report.suggestions.filter(
114
- s => !s.description.includes('node_modules')
115
- ),
116
- };
117
- }
118
-
119
- /**
120
- * Cap content to max lines to prevent oversized agent files.
121
- */
122
- private capContent(content: string): string {
123
- const lines = content.split('\n');
124
- if (lines.length <= AgentGenerator.MAX_FILE_LINES) return content;
125
-
126
- const truncated = lines.slice(0, AgentGenerator.MAX_FILE_LINES);
127
- truncated.push('');
128
- truncated.push('<!-- Content truncated at ' + AgentGenerator.MAX_FILE_LINES + ' lines. Run `architect agents` to regenerate. -->');
129
- return truncated.join('\n');
130
- }
131
-
132
- /**
133
- * Suggest agents without writing files — for unified report.
134
- */
135
- suggest(
136
- report: AnalysisReport,
137
- plan: RefactoringPlan,
138
- projectPath: string,
139
- ): AgentSuggestion {
140
- const cleanReport = this.sanitizeReport(report);
141
- const stack = this.stackDetector.detect(cleanReport);
142
- const agentDir = join(projectPath, '.agent');
143
- const isExisting = existsSync(agentDir);
144
-
145
- const existingFiles = (subdir: string): Set<string> => {
146
- const dir = join(agentDir, subdir);
147
- if (!existsSync(dir)) return new Set();
148
- return new Set(readdirSync(dir).map(f => f.replace(/\.md$/, '')));
149
- };
150
-
151
- let audit: AgentAuditFinding[] = [];
152
- if (isExisting) {
153
- audit = this.auditExisting(agentDir, stack, report, plan);
154
- }
155
-
156
- const ctx = this.buildContext(cleanReport, plan, stack, projectPath);
157
-
158
- const existingAgents = existingFiles('agents');
159
- const existingRules = existingFiles('rules');
160
- const existingGuards = existingFiles('guards');
161
- const existingWorkflows = existingFiles('workflows');
162
- const existingSkillsDir = join(agentDir, 'skills');
163
- const existingSkillNames = existsSync(existingSkillsDir)
164
- ? new Set(readdirSync(existingSkillsDir).filter(f => {
165
- try { return statSync(join(existingSkillsDir, f)).isDirectory(); } catch { return false; }
166
- }))
167
- : new Set<string>();
168
-
169
- const itemStatus = (name: string, existing: Set<string>): AgentItemStatus => {
170
- const found = [...existing].some(e => e.toLowerCase() === name.toLowerCase());
171
- if (!found) return 'CREATE';
172
- const hasImprovement = audit.some(
173
- f => f.file.toLowerCase().includes(name.toLowerCase()) && (f.type === 'IMPROVEMENT' || f.type === 'OUTDATED')
174
- );
175
- return hasImprovement ? 'MODIFY' : 'KEEP';
176
- };
177
-
178
- // ── Agent definitions ──
179
- const agentDefs: { name: string; desc: string }[] = [
180
- { name: 'AGENT-ORCHESTRATOR', desc: 'Centro de comando — decompõe requisições, enforça gates, coordena agentes' },
181
- ];
182
- if (stack.hasBackend) agentDefs.push({
183
- name: `${stack.primary.toUpperCase()}-BACKEND-DEVELOPER`,
184
- desc: `Especialista em ${stack.primary} — APIs, serviços, lógica de negócio, integration docs`,
185
- });
186
- if (stack.hasFrontend) {
187
- const FRONTEND_FWS = ['Angular', 'Vue', 'Vue.js', 'Next.js', 'React', 'Nuxt', 'Svelte', 'Remix'];
188
- const detectedFw = ctx.detectedFrameworks?.find(f => FRONTEND_FWS.includes(f.name));
189
- const fw = detectedFw?.name ||
190
- stack.frameworks.find(f => FRONTEND_FWS.includes(f)) || 'FRONTEND';
191
- agentDefs.push({
192
- name: `${fw.toUpperCase().replace('.', '').replace(/\s/g, '-')}-FRONTEND-DEVELOPER`,
193
- desc: `Componentes ${fw}, state management, UX responsiva, todos os estados UI`,
194
- });
195
- }
196
- if (stack.hasMobile) agentDefs.push({
197
- name: 'FLUTTER-UI-DEVELOPER',
198
- desc: 'Screens mobile, widgets, navegação, integração API, padrão visual do app',
199
- });
200
- if (stack.hasDatabase) agentDefs.push({
201
- name: 'DATABASE-ENGINEER',
202
- desc: 'Schema design, migrations reversíveis, indexação, performance de queries',
203
- });
204
- agentDefs.push(
205
- { name: 'SECURITY-AUDITOR', desc: 'OWASP Top 10, STRIDE threat model, compliance, vulnerabilidades' },
206
- { name: 'QA-TEST-ENGINEER', desc: 'BDD/TDD, cobertura mínima, planos de teste, regressão' },
207
- { name: 'TECH-DEBT-CONTROLLER', desc: 'Score tracking, anti-patterns, refatorações, metas de qualidade' },
208
- );
209
-
210
- const ruleDefs: { name: string; desc: string }[] = [
211
- { name: '00-general', desc: '9 Regras de Ouro, Git Flow, naming conventions, ações proibidas' },
212
- { name: '01-architecture', desc: 'Separação de camadas, dependency rules, padrões de módulo' },
213
- { name: '02-security', desc: 'Sanitização, secrets management, validação, OWASP' },
214
- ];
215
- const stackRuleName = getStackRuleFileName(ctx);
216
- if (stackRuleName) {
217
- const fwLabel = stack.frameworks[0] || stack.primary;
218
- ruleDefs.push({ name: stackRuleName, desc: `Regras específicas ${fwLabel} — patterns, anti-patterns, checklist` });
219
- }
220
-
221
- const guardDefs = [
222
- { name: 'PREFLIGHT', desc: '6-phase checklist pré-ação: ambiente → leitura → negócio → camada → commit → done' },
223
- { name: 'QUALITY-GATES', desc: '3 níveis (CRITICAL/IMPORTANT/DESIRABLE), métricas, blockers, verificação em 4 estágios' },
224
- { name: 'CODE-REVIEW-CHECKLIST', desc: 'Review em 6 dimensões: funcional, qualidade, testes, segurança, performance, arquitetura' },
225
- ];
226
-
227
- const workflowDefs = [
228
- { name: 'new-feature', desc: '10 steps com 6 approval gates, mockup-first, backend-first, integration doc' },
229
- { name: 'fix-bug', desc: '10 steps: diagnóstico → root cause → RED test → fix mínimo → regressão → docs' },
230
- { name: 'review', desc: 'Code review em 6 dimensões com checklist estruturado' },
231
- ];
232
-
233
- // Build items
234
- const suggestedAgents: AgentItem[] = agentDefs.map(({ name, desc }) => ({
235
- name, status: itemStatus(name, existingAgents), description: desc,
236
- }));
237
- for (const existing of existingAgents) {
238
- if (!agentDefs.some(d => d.name.toLowerCase() === existing.toLowerCase())) {
239
- suggestedAgents.push({ name: existing, status: 'KEEP', reason: 'Custom agent', description: 'Agente customizado do projeto' });
240
- }
241
- }
242
-
243
- const suggestedRules: AgentItem[] = ruleDefs.map(({ name, desc }) => ({
244
- name, status: itemStatus(name, existingRules), description: desc,
245
- }));
246
- for (const existing of existingRules) {
247
- if (!ruleDefs.some(d => d.name.toLowerCase() === existing.toLowerCase())) {
248
- suggestedRules.push({ name: existing, status: 'KEEP', reason: 'Custom rule' });
249
- }
250
- }
251
-
252
- const suggestedGuards: AgentItem[] = guardDefs.map(({ name, desc }) => ({
253
- name, status: itemStatus(name, existingGuards), description: desc,
254
- }));
255
-
256
- const suggestedWorkflows: AgentItem[] = workflowDefs.map(({ name, desc }) => ({
257
- name, status: itemStatus(name, existingWorkflows), description: desc,
258
- }));
259
- for (const existing of existingWorkflows) {
260
- if (!workflowDefs.some(d => d.name.toLowerCase() === existing.toLowerCase())) {
261
- suggestedWorkflows.push({ name: existing, status: 'KEEP', reason: 'Custom workflow' });
262
- }
263
- }
264
-
265
- // Skills
266
- const skillEntries = this.buildSkillEntries(stack, existingSkillNames);
267
-
268
- return {
269
- stack,
270
- hasExistingAgents: isExisting,
271
- suggestedAgents,
272
- suggestedRules,
273
- suggestedGuards,
274
- suggestedWorkflows,
275
- suggestedSkills: skillEntries,
276
- audit,
277
- command: `architect agents ${projectPath}`,
278
- };
279
- }
280
-
281
- /**
282
- * Generate or audit .agent/ directory for a project.
283
- */
284
- generate(
285
- report: AnalysisReport,
286
- plan: RefactoringPlan,
287
- projectPath: string,
288
- outputDir?: string
289
- ): { generated: string[]; audit: AgentAuditFinding[] } {
290
- const cleanReport = this.sanitizeReport(report);
291
- const stack = this.stackDetector.detect(cleanReport);
292
- const agentDir = outputDir || join(projectPath, '.agent');
293
- const isExisting = existsSync(agentDir);
294
-
295
- if (isExisting) {
296
- const audit = this.auditExisting(agentDir, stack, cleanReport, plan);
297
- const generated = this.generateMissing(agentDir, audit, cleanReport, plan, stack, projectPath);
298
- return { generated, audit };
299
- }
300
-
301
- const generated = this.generateFull(agentDir, cleanReport, plan, stack, projectPath);
302
- return { generated, audit: [] };
303
- }
304
-
305
- // ── Private: Build Template Context ──
306
-
307
- private buildContext(report: AnalysisReport, plan: RefactoringPlan, stack: StackInfo, projectPath?: string): EnrichedTemplateContext {
308
- if (projectPath) {
309
- return this.contextEnricher.enrich(report, plan, stack, projectPath);
310
- }
311
- // Fallback to basic enriched context for backward compatibility
312
- return {
313
- report,
314
- plan,
315
- stack,
316
- projectName: report.projectInfo.name || 'Project',
317
- stackLabel: [...stack.languages, ...stack.frameworks].join(' + '),
318
- config: DEFAULT_AGENT_CONFIG,
319
- domain: {
320
- domain: 'general',
321
- subDomain: 'general',
322
- description: '',
323
- businessEntities: [],
324
- compliance: [],
325
- integrations: [],
326
- keywords: [],
327
- confidence: 0,
328
- },
329
- modules: [],
330
- endpoints: [],
331
- untestedModules: [],
332
- criticalPaths: [],
333
- projectDepth: 'small',
334
- detectedFrameworks: [],
335
- primaryFramework: null,
336
- toolchain: {
337
- buildCmd: 'echo "No build command detected"',
338
- testCmd: 'echo "No test command detected"',
339
- lintCmd: 'echo "No lint command detected"',
340
- runCmd: 'echo "No run command detected"',
341
- coverageCmd: 'echo "No coverage command detected"',
342
- installCmd: 'echo "No install command detected"',
343
- migrateCmd: null,
344
- depsFile: 'unknown',
345
- },
346
- projectStructure: 'unknown',
347
- };
348
- }
349
-
350
- // ── Private: Full Generation ──
351
-
352
- private generateFull(agentDir: string, report: AnalysisReport, plan: RefactoringPlan, stack: StackInfo, projectPath: string): string[] {
353
- const generated: string[] = [];
354
- const ctx = this.buildContext(report, plan, stack, projectPath);
355
-
356
- // Create directories
357
- const dirs = ['agents', 'rules', 'guards', 'workflows', 'templates', 'skills', 'hooks'];
358
- for (const d of dirs) mkdirSync(join(agentDir, d), { recursive: true });
359
-
360
- // ── Core files (Enterprise-Grade) ──
361
- const coreFiles: Record<string, string> = {
362
- 'INDEX.md': generateIndexMd(ctx),
363
- 'agents/AGENT-ORCHESTRATOR.md': generateOrchestrator(ctx),
364
- 'guards/PREFLIGHT.md': generatePreflight(ctx),
365
- 'guards/QUALITY-GATES.md': generateQualityGates(ctx),
366
- 'guards/CODE-REVIEW-CHECKLIST.md': generateCodeReviewChecklist(ctx),
367
- 'rules/00-general.md': generateGeneralRules(ctx),
368
- 'rules/01-architecture.md': generateArchitectureRules(ctx),
369
- 'rules/02-security.md': generateSecurityRules(ctx),
370
- 'workflows/new-feature.md': generateNewFeatureWorkflow(ctx),
371
- 'workflows/fix-bug.md': generateFixBugWorkflow(ctx),
372
- 'workflows/review.md': generateReviewWorkflow(ctx),
373
- };
374
-
375
- // ── Stack-specific agents ──
376
- if (stack.hasBackend) {
377
- coreFiles[`agents/${stack.primary.toUpperCase()}-BACKEND-DEVELOPER.md`] = generateBackendAgent(ctx);
378
- }
379
- if (stack.hasFrontend) {
380
- const FRONTEND_FWS = ['Angular', 'Vue', 'Vue.js', 'Next.js', 'React', 'Nuxt', 'Svelte', 'Remix'];
381
- const detectedFw = ctx.detectedFrameworks?.find(f => FRONTEND_FWS.includes(f.name));
382
- const fwName = detectedFw?.name ||
383
- stack.frameworks.find(f => FRONTEND_FWS.includes(f)) || 'Frontend';
384
- coreFiles[`agents/${fwName.toUpperCase().replace('.', '').replace(/\s/g, '-')}-FRONTEND-DEVELOPER.md`] = generateFrontendAgent(ctx);
385
- }
386
- if (stack.hasMobile) {
387
- coreFiles['agents/FLUTTER-UI-DEVELOPER.md'] = generateMobileAgent(ctx);
388
- }
389
- if (stack.hasDatabase) {
390
- coreFiles['agents/DATABASE-ENGINEER.md'] = generateDatabaseAgent(ctx);
391
- }
392
- coreFiles['agents/SECURITY-AUDITOR.md'] = generateSecurityAgent(ctx);
393
- coreFiles['agents/QA-TEST-ENGINEER.md'] = generateQAAgent(ctx);
394
- coreFiles['agents/TECH-DEBT-CONTROLLER.md'] = generateTechDebtAgent(ctx);
395
-
396
- // ── Stack-specific rules ──
397
- const stackRuleContent = generateStackRules(ctx);
398
- const stackRuleFile = getStackRuleFileName(ctx);
399
- if (stackRuleContent && stackRuleFile) {
400
- coreFiles[`rules/${stackRuleFile}.md`] = stackRuleContent;
401
- }
402
-
403
- // ── Domain templates ──
404
- coreFiles['templates/C4.md'] = generateC4Template(ctx);
405
- coreFiles['templates/BDD.md'] = generateBddTemplate(ctx);
406
- coreFiles['templates/TDD.md'] = generateTddTemplate(ctx);
407
- coreFiles['templates/ADR.md'] = generateAdrTemplate(ctx);
408
- coreFiles['templates/THREAT-MODEL.md'] = generateThreatModelTemplate(ctx);
409
-
410
- // ── Project Skills (padrões detectados) ──
411
- const skillsContent = generateProjectSkills(ctx);
412
- if (skillsContent) {
413
- coreFiles['skills/PROJECT-PATTERNS.md'] = skillsContent;
414
- }
415
-
416
- // ── Data-driven Skills (real project data) ──
417
- coreFiles['skills/ARCHITECT-INTEGRATION.md'] = generateArchitectIntegrationSkill(ctx);
418
- coreFiles['skills/CI-PIPELINE.md'] = generateCIPipelineSkill(ctx);
419
-
420
- const monorepoGuide = generateMonorepoGuideSkill(ctx);
421
- if (monorepoGuide) {
422
- coreFiles['skills/MONOREPO-GUIDE.md'] = monorepoGuide;
423
- }
424
-
425
- // ── Executable Hooks ──
426
- coreFiles['hooks/pre-commit.sh'] = generatePreCommitHook(ctx);
427
- coreFiles['hooks/pre-push.sh'] = generatePrePushHook(ctx);
428
- coreFiles['hooks/post-analysis.sh'] = generatePostAnalysisHook(ctx);
429
-
430
- // ── Write all files (with size cap) ──
431
- for (const [path, content] of Object.entries(coreFiles)) {
432
- const fullPath = join(agentDir, path);
433
- const dir = join(fullPath, '..');
434
- if (!existsSync(dir)) mkdirSync(dir, { recursive: true });
435
- writeFileSync(fullPath, this.capContent(content));
436
- generated.push(path);
437
- }
438
-
439
- return generated;
440
- }
441
-
442
- // ── Private: Generate Missing (for existing .agent/) ──
443
-
444
- private generateMissing(
445
- agentDir: string,
446
- audit: AgentAuditFinding[],
447
- report: AnalysisReport,
448
- plan: RefactoringPlan,
449
- stack: StackInfo,
450
- projectPath: string,
451
- ): string[] {
452
- const generated: string[] = [];
453
- const missing = audit.filter(f => f.type === 'MISSING');
454
- const ctx = this.buildContext(report, plan, stack, projectPath);
455
-
456
- for (const finding of missing) {
457
- const fullPath = join(agentDir, finding.file);
458
- const dir = join(fullPath, '..');
459
- if (!existsSync(dir)) mkdirSync(dir, { recursive: true });
460
-
461
- const content = this.getTemplateFor(finding.file, ctx);
462
- if (content) {
463
- writeFileSync(fullPath, content);
464
- generated.push(finding.file);
465
- }
466
- }
467
-
468
- return generated;
469
- }
470
-
471
- private getTemplateFor(file: string, ctx: EnrichedTemplateContext): string | null {
472
- if (file.includes('INDEX')) return generateIndexMd(ctx);
473
- if (file.includes('ORCHESTRATOR')) return generateOrchestrator(ctx);
474
- if (file.includes('PREFLIGHT')) return generatePreflight(ctx);
475
- if (file.includes('QUALITY-GATES')) return generateQualityGates(ctx);
476
- if (file.includes('CODE-REVIEW')) return generateCodeReviewChecklist(ctx);
477
- if (file.includes('SECURITY')) return generateSecurityAgent(ctx);
478
- if (file.includes('QA')) return generateQAAgent(ctx);
479
- if (file.includes('TECH-DEBT')) return generateTechDebtAgent(ctx);
480
- if (file.includes('BACKEND')) return generateBackendAgent(ctx);
481
- if (file.includes('FRONTEND')) return generateFrontendAgent(ctx);
482
- if (file.includes('FLUTTER')) return generateMobileAgent(ctx);
483
- if (file.includes('DATABASE')) return generateDatabaseAgent(ctx);
484
- if (file.includes('00-general')) return generateGeneralRules(ctx);
485
- if (file.includes('01-architecture')) return generateArchitectureRules(ctx);
486
- if (file.includes('02-security')) return generateSecurityRules(ctx);
487
- if (file.includes('03-')) return generateStackRules(ctx);
488
- if (file.includes('new-feature') || file.includes('develop')) return generateNewFeatureWorkflow(ctx);
489
- if (file.includes('fix-bug')) return generateFixBugWorkflow(ctx);
490
- if (file.includes('review')) return generateReviewWorkflow(ctx);
491
- if (file.includes('C4')) return generateC4Template(ctx);
492
- if (file.includes('BDD')) return generateBddTemplate(ctx);
493
- if (file.includes('TDD')) return generateTddTemplate(ctx);
494
- if (file.includes('ADR')) return generateAdrTemplate(ctx);
495
- if (file.includes('THREAT')) return generateThreatModelTemplate(ctx);
496
- return null;
497
- }
498
-
499
- // ── Private: Audit ──
500
-
501
- private auditExisting(
502
- agentDir: string,
503
- stack: StackInfo,
504
- report: AnalysisReport,
505
- plan: RefactoringPlan,
506
- ): AgentAuditFinding[] {
507
- const findings: AgentAuditFinding[] = [];
508
-
509
- const checkExists = (subpath: string, category: string, desc: string): void => {
510
- const full = join(agentDir, subpath);
511
- if (!existsSync(full)) {
512
- findings.push({ type: 'MISSING', category, file: subpath, description: desc });
513
- } else {
514
- findings.push({ type: 'OK', category, file: subpath, description: `${subpath} exists` });
515
- }
516
- };
517
-
518
- // Core structure
519
- checkExists('INDEX.md', 'core', 'Master navigation guide');
520
- checkExists('agents/AGENT-ORCHESTRATOR.md', 'agents', 'Orchestrator agent with approval gates');
521
- checkExists('rules/00-general.md', 'rules', 'Golden rules and conventions');
522
- checkExists('rules/01-architecture.md', 'rules', 'Layer rules, dependency direction, module patterns');
523
- checkExists('rules/02-security.md', 'rules', 'OWASP, input validation, secrets management');
524
- checkExists('guards/PREFLIGHT.md', 'guards', '6-phase preflight checklist');
525
- checkExists('guards/QUALITY-GATES.md', 'guards', '3-level quality gates');
526
- checkExists('guards/CODE-REVIEW-CHECKLIST.md', 'guards', 'Structured code review checklist');
527
- checkExists('workflows/new-feature.md', 'workflows', '10-step feature workflow with approval gates');
528
- checkExists('workflows/fix-bug.md', 'workflows', 'Diagnostic bug fix workflow');
529
-
530
- // Domain templates
531
- checkExists('templates/C4.md', 'templates', 'C4 architecture template');
532
- checkExists('templates/BDD.md', 'templates', 'BDD scenario template');
533
- checkExists('templates/TDD.md', 'templates', 'TDD test template');
534
- checkExists('templates/ADR.md', 'templates', 'ADR decision record template');
535
- checkExists('templates/THREAT-MODEL.md', 'templates', 'STRIDE threat model template');
536
-
537
- // Stack-specific agents
538
- if (stack.hasBackend) {
539
- const found = this.findAgentByRole(agentDir, 'backend');
540
- if (!found) {
541
- findings.push({
542
- type: 'MISSING', category: 'agents',
543
- file: `agents/${stack.primary.toUpperCase()}-BACKEND-DEVELOPER.md`,
544
- description: `No backend developer agent for ${stack.primary}`,
545
- });
546
- }
547
- }
548
- if (stack.hasFrontend) {
549
- const found = this.findAgentByRole(agentDir, 'frontend');
550
- if (!found) {
551
- findings.push({
552
- type: 'MISSING', category: 'agents',
553
- file: 'agents/FRONTEND-DEVELOPER.md',
554
- description: 'No frontend developer agent',
555
- });
556
- }
557
- }
558
-
559
- // Quality improvements
560
- if (plan.steps.length > 0) {
561
- const found = this.findAgentByRole(agentDir, 'tech-debt');
562
- if (!found) {
563
- findings.push({
564
- type: 'IMPROVEMENT', category: 'agents',
565
- file: 'agents/TECH-DEBT-CONTROLLER.md',
566
- description: `${plan.steps.length} refactoring steps found but no Tech Debt agent`,
567
- suggestion: 'Create a Tech Debt Controller to track and prioritize refactoring',
568
- });
569
- }
570
- }
571
-
572
- if (report.score.overall < 80) {
573
- findings.push({
574
- type: 'IMPROVEMENT', category: 'guards',
575
- file: 'guards/QUALITY-GATES.md',
576
- description: `Score is ${report.score.overall}/100 — quality gates should enforce improvement`,
577
- suggestion: `Set minimum score threshold to ${report.score.overall + 5} and add regression guards`,
578
- });
579
- }
580
-
581
- return findings;
582
- }
583
-
584
- private findAgentByRole(agentDir: string, role: string): string | null {
585
- const dir = join(agentDir, 'agents');
586
- if (!existsSync(dir)) return null;
587
- const files = readdirSync(dir);
588
- for (const file of files) {
589
- const content = readFileSync(join(dir, file), 'utf-8').toLowerCase();
590
- if (content.includes(role)) return file;
591
- }
592
- return null;
593
- }
594
-
595
- // ── Private: Skills ──
596
-
597
- private buildSkillEntries(stack: StackInfo, existing: Set<string>) {
598
- const entries: { name: string; source: string; description: string; status: AgentItemStatus }[] = [
599
- { name: 'test-driven-development', source: 'anthropic/courses/test-driven-development', description: 'TDD: Red → Green → Refactor', status: 'CREATE' },
600
- { name: 'systematic-debugging', source: 'anthropic/courses/systematic-debugging', description: 'Structured debugging methodology', status: 'CREATE' },
601
- { name: 'code-review', source: 'anthropic/courses/requesting-code-review', description: 'Code review best practices', status: 'CREATE' },
602
- { name: 'security-best-practices', source: 'anthropic/courses/security-best-practices', description: 'Security patterns and vulnerability prevention', status: 'CREATE' },
603
- { name: 'performance-optimization', source: 'anthropic/courses/performance-optimization', description: 'Performance analysis and optimization', status: 'CREATE' },
604
- { name: 'git-workflow', source: 'anthropic/courses/git-workflow', description: 'Git branching, commits, collaboration', status: 'CREATE' },
605
- ];
606
-
607
- // Stack-specific skills
608
- if (stack.languages.includes('TypeScript') || stack.languages.includes('JavaScript')) {
609
- entries.push({ name: 'api-design-principles', source: 'anthropic/courses/api-design-principles', description: 'REST/GraphQL API design', status: 'CREATE' });
610
- }
611
- if (stack.frameworks.includes('Angular') || stack.frameworks.includes('Vue') || stack.frameworks.includes('React') || stack.frameworks.includes('Next.js')) {
612
- entries.push(
613
- { name: 'frontend-design', source: 'anthropic/courses/frontend-design', description: 'Modern frontend patterns', status: 'CREATE' },
614
- { name: 'web-accessibility', source: 'anthropic/courses/web-accessibility', description: 'WCAG accessibility standards', status: 'CREATE' },
615
- );
616
- }
617
- if (stack.languages.includes('Dart') || stack.frameworks.includes('Flutter')) {
618
- entries.push({ name: 'flutter-animations', source: 'anthropic/courses/flutter-animations', description: 'Flutter animation patterns', status: 'CREATE' });
619
- }
620
- if (stack.languages.includes('Python')) {
621
- entries.push({ name: 'python-performance', source: 'anthropic/courses/python-performance-optimization', description: 'Python optimization and profiling', status: 'CREATE' });
622
- }
623
- if (stack.hasDatabase) {
624
- entries.push({ name: 'database-schema-design', source: 'anthropic/courses/database-schema-design', description: 'Schema design, indexing, migrations', status: 'CREATE' });
625
- }
626
-
627
- // Update status based on existing
628
- for (const entry of entries) {
629
- if (existing.has(entry.name)) entry.status = 'KEEP';
630
- }
631
-
632
- return entries;
633
- }
634
- }