@hivehub/rulebook 5.5.2 → 5.8.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 (834) hide show
  1. package/.claude/commands/analysis.md +35 -35
  2. package/.claude/commands/continue.md +33 -33
  3. package/.claude/commands/rulebook-decision-create.md +55 -55
  4. package/.claude/commands/rulebook-decision-list.md +15 -15
  5. package/.claude/commands/rulebook-knowledge-add.md +41 -41
  6. package/.claude/commands/rulebook-knowledge-list.md +15 -15
  7. package/.claude/commands/rulebook-learn-capture.md +41 -48
  8. package/.claude/commands/rulebook-learn-list.md +13 -13
  9. package/.claude/commands/rulebook-memory-save.md +48 -48
  10. package/.claude/commands/rulebook-memory-search.md +47 -47
  11. package/.claude/commands/rulebook-task-apply.md +67 -67
  12. package/.claude/commands/rulebook-task-archive.md +94 -94
  13. package/.claude/commands/rulebook-task-create.md +93 -93
  14. package/.claude/commands/rulebook-task-list.md +42 -42
  15. package/.claude/commands/rulebook-task-show.md +52 -52
  16. package/.claude/commands/rulebook-task-validate.md +53 -53
  17. package/.claude-plugin/marketplace.json +28 -28
  18. package/.claude-plugin/plugin.json +8 -8
  19. package/README.md +418 -394
  20. package/dist/cli/commands/claude.d.ts +17 -0
  21. package/dist/cli/commands/claude.d.ts.map +1 -0
  22. package/dist/cli/commands/claude.js +56 -0
  23. package/dist/cli/commands/claude.js.map +1 -0
  24. package/dist/cli/commands/context-intelligence.d.ts +0 -1
  25. package/dist/cli/commands/context-intelligence.d.ts.map +1 -1
  26. package/dist/cli/commands/context-intelligence.js +12 -33
  27. package/dist/cli/commands/context-intelligence.js.map +1 -1
  28. package/dist/cli/commands/index.d.ts +4 -7
  29. package/dist/cli/commands/index.d.ts.map +1 -1
  30. package/dist/cli/commands/index.js +4 -7
  31. package/dist/cli/commands/index.js.map +1 -1
  32. package/dist/cli/commands/init.d.ts.map +1 -1
  33. package/dist/cli/commands/init.js +58 -83
  34. package/dist/cli/commands/init.js.map +1 -1
  35. package/dist/cli/commands/mcp.d.ts +0 -1
  36. package/dist/cli/commands/mcp.d.ts.map +1 -1
  37. package/dist/cli/commands/mcp.js +1 -7
  38. package/dist/cli/commands/mcp.js.map +1 -1
  39. package/dist/cli/commands/memory.d.ts +7 -1
  40. package/dist/cli/commands/memory.d.ts.map +1 -1
  41. package/dist/cli/commands/memory.js +51 -57
  42. package/dist/cli/commands/memory.js.map +1 -1
  43. package/dist/cli/commands/misc.d.ts +1 -15
  44. package/dist/cli/commands/misc.d.ts.map +1 -1
  45. package/dist/cli/commands/misc.js +36 -215
  46. package/dist/cli/commands/misc.js.map +1 -1
  47. package/dist/cli/commands/plans.d.ts +0 -6
  48. package/dist/cli/commands/plans.d.ts.map +1 -1
  49. package/dist/cli/commands/plans.js +9 -77
  50. package/dist/cli/commands/plans.js.map +1 -1
  51. package/dist/cli/commands/skills.js +6 -6
  52. package/dist/cli/commands/skills.js.map +1 -1
  53. package/dist/cli/commands/task.js +4 -4
  54. package/dist/cli/commands/task.js.map +1 -1
  55. package/dist/cli/commands/update.d.ts.map +1 -1
  56. package/dist/cli/commands/update.js +128 -53
  57. package/dist/cli/commands/update.js.map +1 -1
  58. package/dist/cli/prompts.d.ts +13 -0
  59. package/dist/cli/prompts.d.ts.map +1 -1
  60. package/dist/cli/prompts.js +107 -78
  61. package/dist/cli/prompts.js.map +1 -1
  62. package/dist/core/{claude-mcp.d.ts → claude/claude-mcp.d.ts} +9 -0
  63. package/dist/core/claude/claude-mcp.d.ts.map +1 -0
  64. package/dist/core/{claude-mcp.js → claude/claude-mcp.js} +33 -3
  65. package/dist/core/claude/claude-mcp.js.map +1 -0
  66. package/dist/core/claude/claude-md-generator.d.ts.map +1 -0
  67. package/dist/core/{claude-md-generator.js → claude/claude-md-generator.js} +2 -2
  68. package/dist/core/claude/claude-md-generator.js.map +1 -0
  69. package/dist/core/{claude-settings-manager.d.ts → claude/claude-settings-manager.d.ts} +12 -0
  70. package/dist/core/claude/claude-settings-manager.d.ts.map +1 -0
  71. package/dist/core/{claude-settings-manager.js → claude/claude-settings-manager.js} +81 -22
  72. package/dist/core/claude/claude-settings-manager.js.map +1 -0
  73. package/dist/core/{cli-bridge.d.ts → console/cli-bridge.d.ts} +2 -2
  74. package/dist/core/console/cli-bridge.d.ts.map +1 -0
  75. package/dist/core/{cli-bridge.js → console/cli-bridge.js} +3 -3
  76. package/dist/core/console/cli-bridge.js.map +1 -0
  77. package/dist/core/{detector.d.ts → detect/detector.d.ts} +16 -1
  78. package/dist/core/detect/detector.d.ts.map +1 -0
  79. package/dist/core/detect/detector.js +766 -0
  80. package/dist/core/detect/detector.js.map +1 -0
  81. package/dist/core/detect/library-registry.d.ts +40 -0
  82. package/dist/core/detect/library-registry.d.ts.map +1 -0
  83. package/dist/core/detect/library-registry.js +239 -0
  84. package/dist/core/detect/library-registry.js.map +1 -0
  85. package/dist/core/docs/docs-generator.d.ts.map +1 -0
  86. package/dist/core/{docs-generator.js → docs/docs-generator.js} +1 -1
  87. package/dist/core/docs/docs-generator.js.map +1 -0
  88. package/dist/core/docs/mcp-reference-generator.d.ts.map +1 -0
  89. package/dist/core/{mcp-reference-generator.js → docs/mcp-reference-generator.js} +2 -2
  90. package/dist/core/docs/mcp-reference-generator.js.map +1 -0
  91. package/dist/core/{generator.d.ts → generators/generator.d.ts} +3 -4
  92. package/dist/core/generators/generator.d.ts.map +1 -0
  93. package/dist/core/{generator.js → generators/generator.js} +42 -157
  94. package/dist/core/generators/generator.js.map +1 -0
  95. package/dist/core/{gitignore-generator.d.ts → generators/gitignore-generator.d.ts} +1 -1
  96. package/dist/core/generators/gitignore-generator.d.ts.map +1 -0
  97. package/dist/core/{gitignore-generator.js → generators/gitignore-generator.js} +1 -1
  98. package/dist/core/generators/gitignore-generator.js.map +1 -0
  99. package/dist/core/generators/minimal-scaffolder.d.ts.map +1 -0
  100. package/dist/core/{minimal-scaffolder.js → generators/minimal-scaffolder.js} +2 -2
  101. package/dist/core/generators/minimal-scaffolder.js.map +1 -0
  102. package/dist/core/{rules-generator.d.ts → generators/rules-generator.d.ts} +2 -6
  103. package/dist/core/generators/rules-generator.d.ts.map +1 -0
  104. package/dist/core/{rules-generator.js → generators/rules-generator.js} +41 -2
  105. package/dist/core/generators/rules-generator.js.map +1 -0
  106. package/dist/core/{workflow-generator.d.ts → generators/workflow-generator.d.ts} +1 -1
  107. package/dist/core/generators/workflow-generator.d.ts.map +1 -0
  108. package/dist/core/{workflow-generator.js → generators/workflow-generator.js} +2 -3
  109. package/dist/core/generators/workflow-generator.js.map +1 -0
  110. package/dist/core/{multi-tool-generator.d.ts → ide/multi-tool-generator.d.ts} +1 -1
  111. package/dist/core/ide/multi-tool-generator.d.ts.map +1 -0
  112. package/dist/core/{multi-tool-generator.js → ide/multi-tool-generator.js} +1 -1
  113. package/dist/core/ide/multi-tool-generator.js.map +1 -0
  114. package/dist/core/ide/opencode-generator.d.ts +72 -0
  115. package/dist/core/ide/opencode-generator.d.ts.map +1 -0
  116. package/dist/core/ide/opencode-generator.js +450 -0
  117. package/dist/core/ide/opencode-generator.js.map +1 -0
  118. package/dist/core/merger.d.ts +1 -1
  119. package/dist/core/merger.d.ts.map +1 -1
  120. package/dist/core/merger.js +5 -5
  121. package/dist/core/merger.js.map +1 -1
  122. package/dist/core/migrator.d.ts +0 -1
  123. package/dist/core/migrator.d.ts.map +1 -1
  124. package/dist/core/migrator.js +4 -29
  125. package/dist/core/migrator.js.map +1 -1
  126. package/dist/core/quality/coverage-checker.d.ts.map +1 -0
  127. package/dist/core/{coverage-checker.js → quality/coverage-checker.js} +2 -2
  128. package/dist/core/quality/coverage-checker.js.map +1 -0
  129. package/dist/core/quality/dependency-checker.d.ts.map +1 -0
  130. package/dist/core/{dependency-checker.js → quality/dependency-checker.js} +1 -1
  131. package/dist/core/quality/dependency-checker.js.map +1 -0
  132. package/dist/core/quality/doctor.d.ts.map +1 -0
  133. package/dist/core/{doctor.js → quality/doctor.js} +1 -67
  134. package/dist/core/quality/doctor.js.map +1 -0
  135. package/dist/core/quality/validator.d.ts.map +1 -0
  136. package/dist/core/{validator.js → quality/validator.js} +1 -1
  137. package/dist/core/quality/validator.js.map +1 -0
  138. package/dist/core/{skills-manager.d.ts → skills/skills-manager.d.ts} +1 -1
  139. package/dist/core/skills/skills-manager.d.ts.map +1 -0
  140. package/dist/core/{skills-manager.js → skills/skills-manager.js} +1 -25
  141. package/dist/core/skills/skills-manager.js.map +1 -0
  142. package/dist/core/{config-manager.d.ts → state/config-manager.d.ts} +1 -1
  143. package/dist/core/state/config-manager.d.ts.map +1 -0
  144. package/dist/core/{config-manager.js → state/config-manager.js} +2 -61
  145. package/dist/core/state/config-manager.js.map +1 -0
  146. package/dist/core/state/override-manager.d.ts.map +1 -0
  147. package/dist/core/{override-manager.js → state/override-manager.js} +1 -1
  148. package/dist/core/state/override-manager.js.map +1 -0
  149. package/dist/core/{state-writer.d.ts → state/state-writer.d.ts} +2 -3
  150. package/dist/core/state/state-writer.d.ts.map +1 -0
  151. package/dist/core/{state-writer.js → state/state-writer.js} +6 -9
  152. package/dist/core/state/state-writer.js.map +1 -0
  153. package/dist/core/state/version-bumper.d.ts.map +1 -0
  154. package/dist/core/{version-bumper.js → state/version-bumper.js} +1 -1
  155. package/dist/core/state/version-bumper.js.map +1 -0
  156. package/dist/core/{decision-manager.d.ts → tasks/decision-manager.d.ts} +1 -1
  157. package/dist/core/tasks/decision-manager.d.ts.map +1 -0
  158. package/dist/core/{decision-manager.js → tasks/decision-manager.js} +1 -1
  159. package/dist/core/tasks/decision-manager.js.map +1 -0
  160. package/dist/core/{knowledge-manager.d.ts → tasks/knowledge-manager.d.ts} +1 -1
  161. package/dist/core/tasks/knowledge-manager.d.ts.map +1 -0
  162. package/dist/core/{knowledge-manager.js → tasks/knowledge-manager.js} +1 -1
  163. package/dist/core/tasks/knowledge-manager.js.map +1 -0
  164. package/dist/core/{learn-manager.d.ts → tasks/learn-manager.d.ts} +1 -3
  165. package/dist/core/tasks/learn-manager.d.ts.map +1 -0
  166. package/dist/core/{learn-manager.js → tasks/learn-manager.js} +1 -39
  167. package/dist/core/tasks/learn-manager.js.map +1 -0
  168. package/dist/core/tasks/plans-manager.d.ts.map +1 -0
  169. package/dist/core/{plans-manager.js → tasks/plans-manager.js} +1 -1
  170. package/dist/core/tasks/plans-manager.js.map +1 -0
  171. package/dist/core/tasks/task-manager.d.ts.map +1 -0
  172. package/dist/core/{task-manager.js → tasks/task-manager.js} +2 -2
  173. package/dist/core/tasks/task-manager.js.map +1 -0
  174. package/dist/core/workspace/project-worker.d.ts +6 -6
  175. package/dist/core/workspace/project-worker.d.ts.map +1 -1
  176. package/dist/core/workspace/project-worker.js +6 -6
  177. package/dist/core/workspace/project-worker.js.map +1 -1
  178. package/dist/index.d.ts +1 -1
  179. package/dist/index.d.ts.map +1 -1
  180. package/dist/index.js +31 -176
  181. package/dist/index.js.map +1 -1
  182. package/dist/mcp/rulebook-server.d.ts.map +1 -1
  183. package/dist/mcp/rulebook-server.js +16 -960
  184. package/dist/mcp/rulebook-server.js.map +1 -1
  185. package/dist/memory/file-search.d.ts +43 -0
  186. package/dist/memory/file-search.d.ts.map +1 -0
  187. package/dist/memory/file-search.js +228 -0
  188. package/dist/memory/file-search.js.map +1 -0
  189. package/dist/memory/file-store.d.ts +99 -0
  190. package/dist/memory/file-store.d.ts.map +1 -0
  191. package/dist/memory/file-store.js +615 -0
  192. package/dist/memory/file-store.js.map +1 -0
  193. package/dist/memory/legacy-migrator.d.ts +27 -0
  194. package/dist/memory/legacy-migrator.d.ts.map +1 -0
  195. package/dist/memory/legacy-migrator.js +185 -0
  196. package/dist/memory/legacy-migrator.js.map +1 -0
  197. package/dist/memory/memory-manager.d.ts +25 -24
  198. package/dist/memory/memory-manager.d.ts.map +1 -1
  199. package/dist/memory/memory-manager.js +97 -140
  200. package/dist/memory/memory-manager.js.map +1 -1
  201. package/dist/memory/memory-types.d.ts +1 -1
  202. package/dist/memory/memory-types.d.ts.map +1 -1
  203. package/dist/types.d.ts +20 -118
  204. package/dist/types.d.ts.map +1 -1
  205. package/package.json +23 -27
  206. package/templates/agents/accessibility-reviewer.md +43 -43
  207. package/templates/agents/api-designer.md +42 -42
  208. package/templates/agents/architect.md +51 -51
  209. package/templates/agents/build-engineer.md +36 -36
  210. package/templates/agents/code-reviewer.md +47 -47
  211. package/templates/agents/compiler/codegen-debugger.md +34 -34
  212. package/templates/agents/compiler/stdlib-engineer.md +28 -28
  213. package/templates/agents/compiler/test-coverage-guardian.md +31 -31
  214. package/templates/agents/context-intelligence.md +50 -52
  215. package/templates/agents/database-architect.md +41 -41
  216. package/templates/agents/devops-engineer.md +42 -42
  217. package/templates/agents/docs-writer.md +38 -38
  218. package/templates/agents/game-engine/cpp-core-expert.md +35 -35
  219. package/templates/agents/game-engine/render-engineer.md +22 -22
  220. package/templates/agents/game-engine/shader-engineer.md +38 -38
  221. package/templates/agents/game-engine/systems-integration.md +43 -43
  222. package/templates/agents/generic/code-reviewer.md +41 -41
  223. package/templates/agents/generic/docs-writer.md +25 -25
  224. package/templates/agents/generic/project-manager.md +36 -36
  225. package/templates/agents/generic/researcher.md +34 -34
  226. package/templates/agents/generic/test-engineer.md +41 -41
  227. package/templates/agents/i18n-engineer.md +42 -42
  228. package/templates/agents/implementer.md +42 -42
  229. package/templates/agents/migration-engineer.md +42 -42
  230. package/templates/agents/mobile/platform-specialist.md +22 -22
  231. package/templates/agents/mobile/ui-engineer.md +22 -22
  232. package/templates/agents/performance-engineer.md +49 -49
  233. package/templates/agents/project-manager.md +215 -0
  234. package/templates/agents/quality-gatekeeper.md +205 -0
  235. package/templates/agents/refactoring-agent.md +41 -41
  236. package/templates/agents/researcher.md +38 -38
  237. package/templates/agents/security-reviewer.md +40 -40
  238. package/templates/agents/team-lead.md +37 -37
  239. package/templates/agents/tester.md +48 -48
  240. package/templates/agents/ux-reviewer.md +43 -43
  241. package/templates/agents/web-app/api-designer.md +22 -22
  242. package/templates/agents/web-app/backend-engineer.md +30 -30
  243. package/templates/agents/web-app/database-engineer.md +22 -22
  244. package/templates/agents/web-app/frontend-engineer.md +29 -29
  245. package/templates/agents/web-app/security-reviewer.md +32 -32
  246. package/templates/ci/rulebook-review.yml +26 -26
  247. package/templates/claude-workflows/bugfix.js +94 -0
  248. package/templates/claude-workflows/feature-pipeline.js +88 -0
  249. package/templates/claude-workflows/release-gate.js +64 -0
  250. package/templates/claude-workflows/review-fanout.js +118 -0
  251. package/templates/claude-workflows/rulebook-driver.js +343 -0
  252. package/templates/claude-workflows/spec-author.js +133 -0
  253. package/templates/cli/AIDER.md +49 -49
  254. package/templates/cli/AMAZON_Q.md +25 -25
  255. package/templates/cli/AUGGIE.md +32 -32
  256. package/templates/cli/CLAUDE.md +117 -117
  257. package/templates/cli/CLINE.md +99 -99
  258. package/templates/cli/CODEBUDDY.md +20 -20
  259. package/templates/cli/CODEIUM.md +20 -20
  260. package/templates/cli/CODEX.md +21 -21
  261. package/templates/cli/CONTINUE.md +34 -34
  262. package/templates/cli/CURSOR_CLI.md +62 -62
  263. package/templates/cli/FACTORY.md +18 -18
  264. package/templates/cli/GEMINI.md +35 -35
  265. package/templates/cli/KILOCODE.md +18 -18
  266. package/templates/cli/OPENCODE.md +85 -18
  267. package/templates/cli/_GENERIC_TEMPLATE.md +29 -29
  268. package/templates/commands/rulebook-decision-create.md +55 -55
  269. package/templates/commands/rulebook-decision-list.md +15 -15
  270. package/templates/commands/rulebook-knowledge-add.md +41 -41
  271. package/templates/commands/rulebook-knowledge-list.md +15 -15
  272. package/templates/commands/rulebook-learn-capture.md +41 -48
  273. package/templates/commands/rulebook-learn-list.md +13 -13
  274. package/templates/commands/rulebook-memory-save.md +48 -48
  275. package/templates/commands/rulebook-memory-search.md +47 -47
  276. package/templates/commands/rulebook-task-apply.md +67 -67
  277. package/templates/commands/rulebook-task-archive.md +94 -94
  278. package/templates/commands/rulebook-task-create.md +93 -93
  279. package/templates/commands/rulebook-task-list.md +42 -42
  280. package/templates/commands/rulebook-task-show.md +52 -52
  281. package/templates/commands/rulebook-task-validate.md +53 -53
  282. package/templates/compact-context/_default.md +23 -23
  283. package/templates/compact-context/cpp.md +26 -26
  284. package/templates/compact-context/go.md +26 -26
  285. package/templates/compact-context/python.md +26 -26
  286. package/templates/compact-context/rust.md +28 -28
  287. package/templates/compact-context/typescript.md +29 -29
  288. package/templates/core/AGENTS_LEAN.md +0 -14
  289. package/templates/core/AGENTS_OVERRIDE.md +16 -16
  290. package/templates/core/AGENT_AUTOMATION.md +296 -296
  291. package/templates/core/CLAUDE_MD_v2.md +90 -90
  292. package/templates/core/DAG.md +304 -304
  293. package/templates/core/DECISIONS.md +38 -38
  294. package/templates/core/DOCUMENTATION_RULES.md +36 -36
  295. package/templates/core/KNOWLEDGE.md +49 -49
  296. package/templates/core/MULTI_AGENT.md +74 -74
  297. package/templates/core/PLANS.md +28 -28
  298. package/templates/core/QUALITY_ENFORCEMENT.md +68 -68
  299. package/templates/core/RULEBOOK.md +1947 -1947
  300. package/templates/core/TIER1_PROHIBITIONS.md +154 -154
  301. package/templates/core/TOKEN_OPTIMIZATION.md +49 -49
  302. package/templates/git/CI_CD_PATTERNS.md +661 -661
  303. package/templates/git/GITHUB_ACTIONS.md +728 -728
  304. package/templates/git/GITLAB_CI.md +730 -730
  305. package/templates/git/GIT_WORKFLOW.md +1192 -1192
  306. package/templates/git/SECRETS_MANAGEMENT.md +585 -585
  307. package/templates/hooks/COMMIT_MSG.md +530 -530
  308. package/templates/hooks/POST_CHECKOUT.md +546 -546
  309. package/templates/hooks/PREPARE_COMMIT_MSG.md +619 -619
  310. package/templates/hooks/PRE_COMMIT.md +414 -414
  311. package/templates/hooks/PRE_PUSH.md +601 -601
  312. package/templates/hooks/check-context-and-handoff.sh +24 -16
  313. package/templates/hooks/enforce-pre-tool.sh +70 -0
  314. package/templates/hooks/terse-mode-tracker.sh +146 -143
  315. package/templates/hooks/update-check.ps1 +84 -0
  316. package/templates/hooks/update-check.sh +103 -0
  317. package/templates/ides/CONTINUE_RULES.md +16 -16
  318. package/templates/ides/COPILOT_INSTRUCTIONS.md +23 -23
  319. package/templates/ides/GEMINI_RULES.md +17 -17
  320. package/templates/ides/OPENCODE.md +63 -0
  321. package/templates/ides/WINDSURF_RULES.md +14 -14
  322. package/templates/languages/C.md +333 -333
  323. package/templates/languages/CPP.md +743 -743
  324. package/templates/languages/CSHARP.md +417 -417
  325. package/templates/languages/ELIXIR.md +454 -454
  326. package/templates/languages/ERLANG.md +361 -361
  327. package/templates/languages/GO.md +645 -645
  328. package/templates/languages/HASKELL.md +177 -177
  329. package/templates/languages/JAVA.md +607 -607
  330. package/templates/languages/JAVASCRIPT.md +631 -631
  331. package/templates/languages/JULIA.md +97 -97
  332. package/templates/languages/KOTLIN.md +511 -511
  333. package/templates/languages/LISP.md +100 -100
  334. package/templates/languages/LUA.md +74 -74
  335. package/templates/languages/OBJECTIVEC.md +90 -90
  336. package/templates/languages/PHP.md +416 -416
  337. package/templates/languages/PYTHON.md +682 -682
  338. package/templates/languages/RUBY.md +421 -421
  339. package/templates/languages/RUST.md +477 -477
  340. package/templates/languages/SAS.md +73 -73
  341. package/templates/languages/SCALA.md +348 -348
  342. package/templates/languages/SOLIDITY.md +580 -580
  343. package/templates/languages/SQL.md +137 -137
  344. package/templates/languages/SWIFT.md +466 -466
  345. package/templates/languages/TYPESCRIPT.md +591 -591
  346. package/templates/languages/ZIG.md +265 -265
  347. package/templates/libraries/go/ECHO.md +18 -0
  348. package/templates/libraries/go/GIN.md +18 -0
  349. package/templates/libraries/go/GORM.md +18 -0
  350. package/templates/libraries/python/DJANGO.md +18 -0
  351. package/templates/libraries/python/FASTAPI.md +18 -0
  352. package/templates/libraries/python/FLASK.md +17 -0
  353. package/templates/libraries/python/PYDANTIC.md +17 -0
  354. package/templates/libraries/python/PYTEST.md +17 -0
  355. package/templates/libraries/python/SQLALCHEMY.md +17 -0
  356. package/templates/libraries/rust/ACTIX.md +17 -0
  357. package/templates/libraries/rust/AXUM.md +18 -0
  358. package/templates/libraries/rust/SERDE.md +16 -0
  359. package/templates/libraries/rust/SQLX.md +17 -0
  360. package/templates/libraries/rust/TOKIO.md +16 -0
  361. package/templates/libraries/typescript/ANGULAR.md +17 -0
  362. package/templates/libraries/typescript/DRIZZLE.md +16 -0
  363. package/templates/libraries/typescript/EXPRESS.md +17 -0
  364. package/templates/libraries/typescript/HEROUI.md +16 -0
  365. package/templates/libraries/typescript/JEST.md +17 -0
  366. package/templates/libraries/typescript/NESTJS.md +17 -0
  367. package/templates/libraries/typescript/NEXT.md +18 -0
  368. package/templates/libraries/typescript/PRISMA.md +16 -0
  369. package/templates/libraries/typescript/RADIX.md +16 -0
  370. package/templates/libraries/typescript/REACT.md +18 -0
  371. package/templates/libraries/typescript/SHADCN.md +16 -0
  372. package/templates/libraries/typescript/SVELTE.md +16 -0
  373. package/templates/libraries/typescript/TAILWIND.md +16 -0
  374. package/templates/libraries/typescript/TRPC.md +16 -0
  375. package/templates/libraries/typescript/VITEST.md +17 -0
  376. package/templates/libraries/typescript/VUE.md +17 -0
  377. package/templates/libraries/typescript/ZOD.md +17 -0
  378. package/templates/modules/ATLASSIAN.md +255 -255
  379. package/templates/modules/CONTEXT7.md +54 -54
  380. package/templates/modules/FIGMA.md +267 -267
  381. package/templates/modules/GITHUB_MCP.md +64 -64
  382. package/templates/modules/GRAFANA.md +328 -328
  383. package/templates/modules/MEMORY.md +126 -126
  384. package/templates/modules/NOTION.md +247 -247
  385. package/templates/modules/PLAYWRIGHT.md +90 -90
  386. package/templates/modules/RULEBOOK_MCP.md +208 -208
  387. package/templates/modules/SERENA.md +337 -337
  388. package/templates/modules/SUPABASE.md +223 -223
  389. package/templates/modules/SYNAP.md +69 -69
  390. package/templates/modules/VECTORIZER.md +63 -63
  391. package/templates/modules/sequential-thinking.md +42 -42
  392. package/templates/rules/consult-analysis-before-implementing.md +23 -23
  393. package/templates/rules/cpp.md +46 -46
  394. package/templates/rules/csharp.md +44 -44
  395. package/templates/rules/diagnostic-first.md +39 -39
  396. package/templates/rules/fail-twice-escalate.md +46 -46
  397. package/templates/rules/follow-task-sequence.md +36 -36
  398. package/templates/rules/git-safety.md +29 -29
  399. package/templates/rules/go.md +40 -40
  400. package/templates/rules/incremental-implementation.md +56 -56
  401. package/templates/rules/incremental-tests.md +29 -29
  402. package/templates/rules/java.md +43 -43
  403. package/templates/rules/javascript.md +39 -39
  404. package/templates/rules/knowledge-base-usage.md +41 -41
  405. package/templates/rules/multi-agent-teams.md +75 -75
  406. package/templates/rules/no-deferred.md +31 -31
  407. package/templates/rules/no-shortcuts.md +30 -30
  408. package/templates/rules/python.md +43 -43
  409. package/templates/rules/research-first.md +30 -30
  410. package/templates/rules/respect-handoff-trigger.md +41 -41
  411. package/templates/rules/rust.md +40 -40
  412. package/templates/rules/sequential-editing.md +21 -21
  413. package/templates/rules/session-workflow.md +24 -24
  414. package/templates/rules/task-decomposition.md +32 -32
  415. package/templates/rules/typescript.md +40 -40
  416. package/templates/skills/cli/aider/SKILL.md +59 -59
  417. package/templates/skills/cli/amazon-q/SKILL.md +35 -35
  418. package/templates/skills/cli/auggie/SKILL.md +42 -42
  419. package/templates/skills/cli/claude/SKILL.md +42 -42
  420. package/templates/skills/cli/cline/SKILL.md +42 -42
  421. package/templates/skills/cli/codebuddy/SKILL.md +30 -30
  422. package/templates/skills/cli/codeium/SKILL.md +30 -30
  423. package/templates/skills/cli/codex/SKILL.md +31 -31
  424. package/templates/skills/cli/continue/SKILL.md +44 -44
  425. package/templates/skills/cli/cursor-cli/SKILL.md +38 -38
  426. package/templates/skills/cli/factory/SKILL.md +28 -28
  427. package/templates/skills/cli/gemini/SKILL.md +45 -45
  428. package/templates/skills/cli/kilocode/SKILL.md +28 -28
  429. package/templates/skills/cli/opencode/SKILL.md +82 -28
  430. package/templates/skills/core/agent-automation/SKILL.md +194 -194
  431. package/templates/skills/core/dag/SKILL.md +314 -314
  432. package/templates/skills/core/documentation-rules/SKILL.md +46 -46
  433. package/templates/skills/core/quality-enforcement/SKILL.md +78 -78
  434. package/templates/skills/core/rulebook/SKILL.md +176 -176
  435. package/templates/skills/core/rulebook-terse/SKILL.md +116 -116
  436. package/templates/skills/core/rulebook-terse-commit/SKILL.md +96 -96
  437. package/templates/skills/core/rulebook-terse-review/SKILL.md +112 -112
  438. package/templates/skills/dev/accessibility/SKILL.md +17 -17
  439. package/templates/skills/dev/analysis/SKILL.md +19 -19
  440. package/templates/skills/dev/api-design/SKILL.md +15 -15
  441. package/templates/skills/dev/architect/SKILL.md +17 -17
  442. package/templates/skills/dev/build-fix/SKILL.md +17 -17
  443. package/templates/skills/dev/db-design/SKILL.md +15 -15
  444. package/templates/skills/dev/debug/SKILL.md +16 -16
  445. package/templates/skills/dev/deploy/SKILL.md +17 -17
  446. package/templates/skills/dev/docs/SKILL.md +17 -17
  447. package/templates/skills/dev/handoff/SKILL.md +27 -27
  448. package/templates/skills/dev/migrate/SKILL.md +15 -15
  449. package/templates/skills/dev/perf/SKILL.md +17 -17
  450. package/templates/skills/dev/refactor/SKILL.md +17 -17
  451. package/templates/skills/dev/research/SKILL.md +14 -14
  452. package/templates/skills/dev/review/SKILL.md +18 -18
  453. package/templates/skills/dev/security-audit/SKILL.md +17 -17
  454. package/templates/skills/dev/spec/SKILL.md +65 -0
  455. package/templates/skills/ides/copilot/SKILL.md +47 -47
  456. package/templates/skills/ides/cursor/SKILL.md +53 -53
  457. package/templates/skills/ides/jetbrains-ai/SKILL.md +45 -45
  458. package/templates/skills/ides/replit/SKILL.md +46 -46
  459. package/templates/skills/ides/tabnine/SKILL.md +39 -39
  460. package/templates/skills/ides/vscode/SKILL.md +50 -50
  461. package/templates/skills/ides/windsurf/SKILL.md +46 -46
  462. package/templates/skills/ides/zed/SKILL.md +42 -42
  463. package/templates/skills/languages/c/SKILL.md +343 -343
  464. package/templates/skills/languages/cpp/SKILL.md +753 -753
  465. package/templates/skills/languages/csharp/SKILL.md +427 -427
  466. package/templates/skills/languages/elixir/SKILL.md +464 -464
  467. package/templates/skills/languages/erlang/SKILL.md +371 -371
  468. package/templates/skills/languages/go/SKILL.md +655 -655
  469. package/templates/skills/languages/haskell/SKILL.md +187 -187
  470. package/templates/skills/languages/java/SKILL.md +617 -617
  471. package/templates/skills/languages/javascript/SKILL.md +641 -641
  472. package/templates/skills/languages/julia/SKILL.md +107 -107
  473. package/templates/skills/languages/kotlin/SKILL.md +521 -521
  474. package/templates/skills/languages/lisp/SKILL.md +110 -110
  475. package/templates/skills/languages/lua/SKILL.md +84 -84
  476. package/templates/skills/languages/objectivec/SKILL.md +100 -100
  477. package/templates/skills/languages/php/SKILL.md +426 -426
  478. package/templates/skills/languages/python/SKILL.md +692 -692
  479. package/templates/skills/languages/ruby/SKILL.md +431 -431
  480. package/templates/skills/languages/rust/SKILL.md +487 -487
  481. package/templates/skills/languages/sas/SKILL.md +83 -83
  482. package/templates/skills/languages/scala/SKILL.md +358 -358
  483. package/templates/skills/languages/solidity/SKILL.md +590 -590
  484. package/templates/skills/languages/sql/SKILL.md +147 -147
  485. package/templates/skills/languages/swift/SKILL.md +476 -476
  486. package/templates/skills/languages/typescript/SKILL.md +302 -302
  487. package/templates/skills/languages/zig/SKILL.md +275 -275
  488. package/templates/skills/modules/atlassian/SKILL.md +265 -265
  489. package/templates/skills/modules/context7/SKILL.md +64 -64
  490. package/templates/skills/modules/figma/SKILL.md +277 -277
  491. package/templates/skills/modules/github-mcp/SKILL.md +74 -74
  492. package/templates/skills/modules/grafana/SKILL.md +338 -338
  493. package/templates/skills/modules/memory/SKILL.md +73 -73
  494. package/templates/skills/modules/notion/SKILL.md +257 -257
  495. package/templates/skills/modules/playwright/SKILL.md +100 -100
  496. package/templates/skills/modules/rulebook-mcp/SKILL.md +166 -166
  497. package/templates/skills/modules/serena/SKILL.md +347 -347
  498. package/templates/skills/modules/supabase/SKILL.md +233 -233
  499. package/templates/skills/modules/synap/SKILL.md +79 -79
  500. package/templates/skills/modules/vectorizer/SKILL.md +73 -73
  501. package/.claude/commands/ralph-config.md +0 -112
  502. package/.claude/commands/ralph-history.md +0 -110
  503. package/.claude/commands/ralph-init.md +0 -72
  504. package/.claude/commands/ralph-pause-resume.md +0 -105
  505. package/.claude/commands/ralph-run.md +0 -101
  506. package/.claude/commands/ralph-status.md +0 -76
  507. package/dist/agents/ralph-parser.d.ts +0 -91
  508. package/dist/agents/ralph-parser.d.ts.map +0 -1
  509. package/dist/agents/ralph-parser.js +0 -415
  510. package/dist/agents/ralph-parser.js.map +0 -1
  511. package/dist/cli/commands/analysis.d.ts +0 -8
  512. package/dist/cli/commands/analysis.d.ts.map +0 -1
  513. package/dist/cli/commands/analysis.js +0 -78
  514. package/dist/cli/commands/analysis.js.map +0 -1
  515. package/dist/cli/commands/compress.d.ts +0 -18
  516. package/dist/cli/commands/compress.d.ts.map +0 -1
  517. package/dist/cli/commands/compress.js +0 -100
  518. package/dist/cli/commands/compress.js.map +0 -1
  519. package/dist/cli/commands/ralph.d.ts +0 -45
  520. package/dist/cli/commands/ralph.d.ts.map +0 -1
  521. package/dist/cli/commands/ralph.js +0 -694
  522. package/dist/cli/commands/ralph.js.map +0 -1
  523. package/dist/cli/docs-prompts.d.ts +0 -3
  524. package/dist/cli/docs-prompts.d.ts.map +0 -1
  525. package/dist/cli/docs-prompts.js +0 -45
  526. package/dist/cli/docs-prompts.js.map +0 -1
  527. package/dist/core/agent-manager.d.ts +0 -69
  528. package/dist/core/agent-manager.d.ts.map +0 -1
  529. package/dist/core/agent-manager.js +0 -476
  530. package/dist/core/agent-manager.js.map +0 -1
  531. package/dist/core/agent-template-engine.d.ts +0 -51
  532. package/dist/core/agent-template-engine.d.ts.map +0 -1
  533. package/dist/core/agent-template-engine.js +0 -291
  534. package/dist/core/agent-template-engine.js.map +0 -1
  535. package/dist/core/analysis-manager.d.ts +0 -56
  536. package/dist/core/analysis-manager.d.ts.map +0 -1
  537. package/dist/core/analysis-manager.js +0 -218
  538. package/dist/core/analysis-manager.js.map +0 -1
  539. package/dist/core/auto-fixer.d.ts +0 -14
  540. package/dist/core/auto-fixer.d.ts.map +0 -1
  541. package/dist/core/auto-fixer.js +0 -207
  542. package/dist/core/auto-fixer.js.map +0 -1
  543. package/dist/core/changelog-generator.d.ts +0 -44
  544. package/dist/core/changelog-generator.d.ts.map +0 -1
  545. package/dist/core/changelog-generator.js +0 -222
  546. package/dist/core/changelog-generator.js.map +0 -1
  547. package/dist/core/claude-mcp.d.ts.map +0 -1
  548. package/dist/core/claude-mcp.js.map +0 -1
  549. package/dist/core/claude-md-generator.d.ts.map +0 -1
  550. package/dist/core/claude-md-generator.js.map +0 -1
  551. package/dist/core/claude-settings-manager.d.ts.map +0 -1
  552. package/dist/core/claude-settings-manager.js.map +0 -1
  553. package/dist/core/cli-bridge.d.ts.map +0 -1
  554. package/dist/core/cli-bridge.js.map +0 -1
  555. package/dist/core/compact-context-manager.d.ts +0 -34
  556. package/dist/core/compact-context-manager.d.ts.map +0 -1
  557. package/dist/core/compact-context-manager.js +0 -60
  558. package/dist/core/compact-context-manager.js.map +0 -1
  559. package/dist/core/complexity-detector.d.ts +0 -36
  560. package/dist/core/complexity-detector.d.ts.map +0 -1
  561. package/dist/core/complexity-detector.js +0 -334
  562. package/dist/core/complexity-detector.js.map +0 -1
  563. package/dist/core/compress/compressor.d.ts +0 -60
  564. package/dist/core/compress/compressor.d.ts.map +0 -1
  565. package/dist/core/compress/compressor.js +0 -232
  566. package/dist/core/compress/compressor.js.map +0 -1
  567. package/dist/core/compress/discover.d.ts +0 -19
  568. package/dist/core/compress/discover.d.ts.map +0 -1
  569. package/dist/core/compress/discover.js +0 -100
  570. package/dist/core/compress/discover.js.map +0 -1
  571. package/dist/core/compress/validator.d.ts +0 -47
  572. package/dist/core/compress/validator.d.ts.map +0 -1
  573. package/dist/core/compress/validator.js +0 -131
  574. package/dist/core/compress/validator.js.map +0 -1
  575. package/dist/core/config-manager.d.ts.map +0 -1
  576. package/dist/core/config-manager.js.map +0 -1
  577. package/dist/core/coverage-checker.d.ts.map +0 -1
  578. package/dist/core/coverage-checker.js.map +0 -1
  579. package/dist/core/cursor-mdc-generator.d.ts +0 -30
  580. package/dist/core/cursor-mdc-generator.d.ts.map +0 -1
  581. package/dist/core/cursor-mdc-generator.js +0 -98
  582. package/dist/core/cursor-mdc-generator.js.map +0 -1
  583. package/dist/core/decision-manager.d.ts.map +0 -1
  584. package/dist/core/decision-manager.js.map +0 -1
  585. package/dist/core/dependency-checker.d.ts.map +0 -1
  586. package/dist/core/dependency-checker.js.map +0 -1
  587. package/dist/core/detector.d.ts.map +0 -1
  588. package/dist/core/detector.js +0 -1763
  589. package/dist/core/detector.js.map +0 -1
  590. package/dist/core/docs-generator.d.ts.map +0 -1
  591. package/dist/core/docs-generator.js.map +0 -1
  592. package/dist/core/doctor.d.ts.map +0 -1
  593. package/dist/core/doctor.js.map +0 -1
  594. package/dist/core/generator.d.ts.map +0 -1
  595. package/dist/core/generator.js.map +0 -1
  596. package/dist/core/github-issues-importer.d.ts +0 -82
  597. package/dist/core/github-issues-importer.d.ts.map +0 -1
  598. package/dist/core/github-issues-importer.js +0 -161
  599. package/dist/core/github-issues-importer.js.map +0 -1
  600. package/dist/core/gitignore-generator.d.ts.map +0 -1
  601. package/dist/core/gitignore-generator.js.map +0 -1
  602. package/dist/core/health-scorer.d.ts +0 -61
  603. package/dist/core/health-scorer.d.ts.map +0 -1
  604. package/dist/core/health-scorer.js +0 -638
  605. package/dist/core/health-scorer.js.map +0 -1
  606. package/dist/core/iteration-tracker.d.ts +0 -85
  607. package/dist/core/iteration-tracker.d.ts.map +0 -1
  608. package/dist/core/iteration-tracker.js +0 -295
  609. package/dist/core/iteration-tracker.js.map +0 -1
  610. package/dist/core/knowledge-manager.d.ts.map +0 -1
  611. package/dist/core/knowledge-manager.js.map +0 -1
  612. package/dist/core/learn-manager.d.ts.map +0 -1
  613. package/dist/core/learn-manager.js.map +0 -1
  614. package/dist/core/mcp-reference-generator.d.ts.map +0 -1
  615. package/dist/core/mcp-reference-generator.js.map +0 -1
  616. package/dist/core/minimal-scaffolder.d.ts.map +0 -1
  617. package/dist/core/minimal-scaffolder.js.map +0 -1
  618. package/dist/core/modern-console.d.ts +0 -98
  619. package/dist/core/modern-console.d.ts.map +0 -1
  620. package/dist/core/modern-console.js +0 -556
  621. package/dist/core/modern-console.js.map +0 -1
  622. package/dist/core/multi-tool-generator.d.ts.map +0 -1
  623. package/dist/core/multi-tool-generator.js.map +0 -1
  624. package/dist/core/override-manager.d.ts.map +0 -1
  625. package/dist/core/override-manager.js.map +0 -1
  626. package/dist/core/plans-manager.d.ts.map +0 -1
  627. package/dist/core/plans-manager.js.map +0 -1
  628. package/dist/core/prd-generator.d.ts +0 -48
  629. package/dist/core/prd-generator.d.ts.map +0 -1
  630. package/dist/core/prd-generator.js +0 -233
  631. package/dist/core/prd-generator.js.map +0 -1
  632. package/dist/core/ralph-manager.d.ts +0 -163
  633. package/dist/core/ralph-manager.d.ts.map +0 -1
  634. package/dist/core/ralph-manager.js +0 -555
  635. package/dist/core/ralph-manager.js.map +0 -1
  636. package/dist/core/ralph-parallel.d.ts +0 -55
  637. package/dist/core/ralph-parallel.d.ts.map +0 -1
  638. package/dist/core/ralph-parallel.js +0 -201
  639. package/dist/core/ralph-parallel.js.map +0 -1
  640. package/dist/core/ralph-plan-checkpoint.d.ts +0 -58
  641. package/dist/core/ralph-plan-checkpoint.d.ts.map +0 -1
  642. package/dist/core/ralph-plan-checkpoint.js +0 -154
  643. package/dist/core/ralph-plan-checkpoint.js.map +0 -1
  644. package/dist/core/ralph-scripts.d.ts +0 -12
  645. package/dist/core/ralph-scripts.d.ts.map +0 -1
  646. package/dist/core/ralph-scripts.js +0 -50
  647. package/dist/core/ralph-scripts.js.map +0 -1
  648. package/dist/core/review-manager.d.ts +0 -74
  649. package/dist/core/review-manager.d.ts.map +0 -1
  650. package/dist/core/review-manager.js +0 -371
  651. package/dist/core/review-manager.js.map +0 -1
  652. package/dist/core/rules-generator.d.ts.map +0 -1
  653. package/dist/core/rules-generator.js.map +0 -1
  654. package/dist/core/skills-manager.d.ts.map +0 -1
  655. package/dist/core/skills-manager.js.map +0 -1
  656. package/dist/core/state-writer.d.ts.map +0 -1
  657. package/dist/core/state-writer.js.map +0 -1
  658. package/dist/core/task-manager.d.ts.map +0 -1
  659. package/dist/core/task-manager.js.map +0 -1
  660. package/dist/core/telemetry.d.ts +0 -29
  661. package/dist/core/telemetry.d.ts.map +0 -1
  662. package/dist/core/telemetry.js +0 -57
  663. package/dist/core/telemetry.js.map +0 -1
  664. package/dist/core/validator.d.ts.map +0 -1
  665. package/dist/core/validator.js.map +0 -1
  666. package/dist/core/version-bumper.d.ts.map +0 -1
  667. package/dist/core/version-bumper.js.map +0 -1
  668. package/dist/core/watcher.d.ts +0 -9
  669. package/dist/core/watcher.d.ts.map +0 -1
  670. package/dist/core/watcher.js +0 -22
  671. package/dist/core/watcher.js.map +0 -1
  672. package/dist/core/workflow-generator.d.ts.map +0 -1
  673. package/dist/core/workflow-generator.js.map +0 -1
  674. package/dist/hooks/terse-activate.d.ts +0 -59
  675. package/dist/hooks/terse-activate.d.ts.map +0 -1
  676. package/dist/hooks/terse-activate.js +0 -149
  677. package/dist/hooks/terse-activate.js.map +0 -1
  678. package/dist/hooks/terse-config.d.ts +0 -51
  679. package/dist/hooks/terse-config.d.ts.map +0 -1
  680. package/dist/hooks/terse-config.js +0 -130
  681. package/dist/hooks/terse-config.js.map +0 -1
  682. package/dist/hooks/terse-mode-tracker.d.ts +0 -78
  683. package/dist/hooks/terse-mode-tracker.d.ts.map +0 -1
  684. package/dist/hooks/terse-mode-tracker.js +0 -213
  685. package/dist/hooks/terse-mode-tracker.js.map +0 -1
  686. package/dist/memory/hnsw-index.d.ts +0 -68
  687. package/dist/memory/hnsw-index.d.ts.map +0 -1
  688. package/dist/memory/hnsw-index.js +0 -544
  689. package/dist/memory/hnsw-index.js.map +0 -1
  690. package/dist/memory/memory-cache.d.ts +0 -33
  691. package/dist/memory/memory-cache.d.ts.map +0 -1
  692. package/dist/memory/memory-cache.js +0 -85
  693. package/dist/memory/memory-cache.js.map +0 -1
  694. package/dist/memory/memory-search.d.ts +0 -42
  695. package/dist/memory/memory-search.d.ts.map +0 -1
  696. package/dist/memory/memory-search.js +0 -180
  697. package/dist/memory/memory-search.js.map +0 -1
  698. package/dist/memory/memory-store.d.ts +0 -84
  699. package/dist/memory/memory-store.d.ts.map +0 -1
  700. package/dist/memory/memory-store.js +0 -566
  701. package/dist/memory/memory-store.js.map +0 -1
  702. package/dist/memory/memory-vectorizer.d.ts +0 -29
  703. package/dist/memory/memory-vectorizer.d.ts.map +0 -1
  704. package/dist/memory/memory-vectorizer.js +0 -199
  705. package/dist/memory/memory-vectorizer.js.map +0 -1
  706. package/templates/core/RALPH.md +0 -471
  707. package/templates/frameworks/ANGULAR.md +0 -36
  708. package/templates/frameworks/DJANGO.md +0 -83
  709. package/templates/frameworks/ELECTRON.md +0 -147
  710. package/templates/frameworks/FLASK.md +0 -38
  711. package/templates/frameworks/FLUTTER.md +0 -55
  712. package/templates/frameworks/JQUERY.md +0 -32
  713. package/templates/frameworks/LARAVEL.md +0 -38
  714. package/templates/frameworks/NESTJS.md +0 -43
  715. package/templates/frameworks/NEXTJS.md +0 -127
  716. package/templates/frameworks/NUXT.md +0 -40
  717. package/templates/frameworks/RAILS.md +0 -66
  718. package/templates/frameworks/REACT.md +0 -38
  719. package/templates/frameworks/REACT_NATIVE.md +0 -47
  720. package/templates/frameworks/SPRING.md +0 -39
  721. package/templates/frameworks/SYMFONY.md +0 -36
  722. package/templates/frameworks/VUE.md +0 -36
  723. package/templates/frameworks/ZEND.md +0 -35
  724. package/templates/hooks/enforce-mcp-for-tasks.sh +0 -31
  725. package/templates/hooks/enforce-no-deferred.sh +0 -21
  726. package/templates/hooks/enforce-no-shortcuts.sh +0 -31
  727. package/templates/ides/COPILOT.md +0 -37
  728. package/templates/ides/CURSOR.md +0 -43
  729. package/templates/ides/JETBRAINS_AI.md +0 -35
  730. package/templates/ides/REPLIT.md +0 -36
  731. package/templates/ides/TABNINE.md +0 -29
  732. package/templates/ides/VSCODE.md +0 -40
  733. package/templates/ides/WINDSURF.md +0 -36
  734. package/templates/ides/ZED.md +0 -32
  735. package/templates/ides/cursor-mdc/go.mdc +0 -24
  736. package/templates/ides/cursor-mdc/python.mdc +0 -24
  737. package/templates/ides/cursor-mdc/quality.mdc +0 -25
  738. package/templates/ides/cursor-mdc/ralph.mdc +0 -39
  739. package/templates/ides/cursor-mdc/rulebook.mdc +0 -38
  740. package/templates/ides/cursor-mdc/rust.mdc +0 -24
  741. package/templates/ides/cursor-mdc/typescript.mdc +0 -25
  742. package/templates/ralph/ralph-history.bat +0 -4
  743. package/templates/ralph/ralph-history.sh +0 -5
  744. package/templates/ralph/ralph-init.bat +0 -5
  745. package/templates/ralph/ralph-init.sh +0 -5
  746. package/templates/ralph/ralph-pause.bat +0 -5
  747. package/templates/ralph/ralph-pause.sh +0 -5
  748. package/templates/ralph/ralph-run.bat +0 -5
  749. package/templates/ralph/ralph-run.sh +0 -5
  750. package/templates/ralph/ralph-status.bat +0 -4
  751. package/templates/ralph/ralph-status.sh +0 -5
  752. package/templates/services/AZURE_BLOB.md +0 -184
  753. package/templates/services/CASSANDRA.md +0 -239
  754. package/templates/services/DATADOG.md +0 -26
  755. package/templates/services/DOCKER.md +0 -124
  756. package/templates/services/DOCKER_COMPOSE.md +0 -168
  757. package/templates/services/DYNAMODB.md +0 -308
  758. package/templates/services/ELASTICSEARCH.md +0 -347
  759. package/templates/services/GCS.md +0 -178
  760. package/templates/services/HELM.md +0 -194
  761. package/templates/services/INFLUXDB.md +0 -265
  762. package/templates/services/KAFKA.md +0 -341
  763. package/templates/services/KUBERNETES.md +0 -208
  764. package/templates/services/MARIADB.md +0 -183
  765. package/templates/services/MEMCACHED.md +0 -242
  766. package/templates/services/MINIO.md +0 -201
  767. package/templates/services/MONGODB.md +0 -268
  768. package/templates/services/MYSQL.md +0 -358
  769. package/templates/services/NEO4J.md +0 -247
  770. package/templates/services/OPENTELEMETRY.md +0 -25
  771. package/templates/services/ORACLE.md +0 -290
  772. package/templates/services/PINO.md +0 -24
  773. package/templates/services/POSTGRESQL.md +0 -326
  774. package/templates/services/PROMETHEUS.md +0 -33
  775. package/templates/services/RABBITMQ.md +0 -286
  776. package/templates/services/REDIS.md +0 -292
  777. package/templates/services/S3.md +0 -298
  778. package/templates/services/SENTRY.md +0 -23
  779. package/templates/services/SQLITE.md +0 -294
  780. package/templates/services/SQLSERVER.md +0 -294
  781. package/templates/services/WINSTON.md +0 -30
  782. package/templates/skills/frameworks/angular/SKILL.md +0 -46
  783. package/templates/skills/frameworks/django/SKILL.md +0 -93
  784. package/templates/skills/frameworks/electron/SKILL.md +0 -157
  785. package/templates/skills/frameworks/flask/SKILL.md +0 -48
  786. package/templates/skills/frameworks/flutter/SKILL.md +0 -65
  787. package/templates/skills/frameworks/jquery/SKILL.md +0 -42
  788. package/templates/skills/frameworks/laravel/SKILL.md +0 -48
  789. package/templates/skills/frameworks/nestjs/SKILL.md +0 -53
  790. package/templates/skills/frameworks/nextjs/SKILL.md +0 -137
  791. package/templates/skills/frameworks/nuxt/SKILL.md +0 -50
  792. package/templates/skills/frameworks/rails/SKILL.md +0 -76
  793. package/templates/skills/frameworks/react/SKILL.md +0 -48
  794. package/templates/skills/frameworks/react-native/SKILL.md +0 -57
  795. package/templates/skills/frameworks/spring/SKILL.md +0 -49
  796. package/templates/skills/frameworks/symfony/SKILL.md +0 -46
  797. package/templates/skills/frameworks/vue/SKILL.md +0 -46
  798. package/templates/skills/frameworks/zend/SKILL.md +0 -45
  799. package/templates/skills/services/azure-blob/SKILL.md +0 -194
  800. package/templates/skills/services/cassandra/SKILL.md +0 -249
  801. package/templates/skills/services/dynamodb/SKILL.md +0 -318
  802. package/templates/skills/services/elasticsearch/SKILL.md +0 -357
  803. package/templates/skills/services/gcs/SKILL.md +0 -188
  804. package/templates/skills/services/influxdb/SKILL.md +0 -275
  805. package/templates/skills/services/kafka/SKILL.md +0 -351
  806. package/templates/skills/services/mariadb/SKILL.md +0 -193
  807. package/templates/skills/services/memcached/SKILL.md +0 -252
  808. package/templates/skills/services/minio/SKILL.md +0 -211
  809. package/templates/skills/services/mongodb/SKILL.md +0 -278
  810. package/templates/skills/services/mysql/SKILL.md +0 -368
  811. package/templates/skills/services/neo4j/SKILL.md +0 -257
  812. package/templates/skills/services/oracle/SKILL.md +0 -300
  813. package/templates/skills/services/postgresql/SKILL.md +0 -336
  814. package/templates/skills/services/rabbitmq/SKILL.md +0 -296
  815. package/templates/skills/services/redis/SKILL.md +0 -302
  816. package/templates/skills/services/s3/SKILL.md +0 -308
  817. package/templates/skills/services/sqlite/SKILL.md +0 -304
  818. package/templates/skills/services/sqlserver/SKILL.md +0 -304
  819. package/templates/skills/workflows/ralph/SETUP.md +0 -228
  820. package/templates/skills/workflows/ralph/SKILL.md +0 -309
  821. package/templates/skills/workflows/ralph/install.sh +0 -87
  822. package/templates/skills/workflows/ralph/manifest.json +0 -158
  823. /package/dist/core/{claude-md-generator.d.ts → claude/claude-md-generator.d.ts} +0 -0
  824. /package/dist/core/{docs-generator.d.ts → docs/docs-generator.d.ts} +0 -0
  825. /package/dist/core/{mcp-reference-generator.d.ts → docs/mcp-reference-generator.d.ts} +0 -0
  826. /package/dist/core/{minimal-scaffolder.d.ts → generators/minimal-scaffolder.d.ts} +0 -0
  827. /package/dist/core/{coverage-checker.d.ts → quality/coverage-checker.d.ts} +0 -0
  828. /package/dist/core/{dependency-checker.d.ts → quality/dependency-checker.d.ts} +0 -0
  829. /package/dist/core/{doctor.d.ts → quality/doctor.d.ts} +0 -0
  830. /package/dist/core/{validator.d.ts → quality/validator.d.ts} +0 -0
  831. /package/dist/core/{override-manager.d.ts → state/override-manager.d.ts} +0 -0
  832. /package/dist/core/{version-bumper.d.ts → state/version-bumper.d.ts} +0 -0
  833. /package/dist/core/{plans-manager.d.ts → tasks/plans-manager.d.ts} +0 -0
  834. /package/dist/core/{task-manager.d.ts → tasks/task-manager.d.ts} +0 -0
@@ -1,1763 +0,0 @@
1
- import path from 'path';
2
- import { existsSync } from 'fs';
3
- import { readdir } from 'fs/promises';
4
- import { fileExists, findFiles, readFile, readJsonFile } from '../utils/file-system.js';
5
- export async function detectProject(cwd = process.cwd()) {
6
- const languages = await detectLanguages(cwd);
7
- const modules = await detectModules(cwd);
8
- const frameworks = await detectFrameworks(cwd, languages);
9
- const services = await detectServices(cwd);
10
- const existingAgents = await detectExistingAgents(cwd);
11
- const gitHooks = await detectGitHooks(cwd);
12
- const monorepo = await detectMonorepo(cwd);
13
- const cursor = await detectCursor(cwd);
14
- const geminiCli = await detectGeminiCli(cwd);
15
- const continueDev = await detectContinueDev(cwd);
16
- const windsurf = await detectWindsurf(cwd);
17
- const githubCopilot = await detectGithubCopilot(cwd);
18
- return {
19
- languages,
20
- modules,
21
- frameworks,
22
- services,
23
- existingAgents,
24
- gitHooks,
25
- monorepo,
26
- cursor,
27
- geminiCli,
28
- continueDev,
29
- windsurf,
30
- githubCopilot,
31
- };
32
- }
33
- /**
34
- * Detect Cursor IDE presence and configuration status.
35
- */
36
- export async function detectCursor(cwd) {
37
- const cursorDir = path.join(cwd, '.cursor');
38
- const cursorrules = path.join(cwd, '.cursorrules');
39
- const rulesDir = path.join(cursorDir, 'rules');
40
- const hasCursorDir = existsSync(cursorDir);
41
- const hasCursorrules = existsSync(cursorrules);
42
- const detected = hasCursorDir || hasCursorrules;
43
- let hasMdcRules = false;
44
- if (existsSync(rulesDir)) {
45
- try {
46
- const files = await readdir(rulesDir);
47
- hasMdcRules = files.some((f) => f.endsWith('.mdc'));
48
- }
49
- catch {
50
- // ignore
51
- }
52
- }
53
- return { detected, hasCursorrules, hasMdcRules };
54
- }
55
- /**
56
- * Detect Gemini CLI presence by checking for GEMINI.md in the project root.
57
- */
58
- export async function detectGeminiCli(cwd) {
59
- const geminiMd = path.join(cwd, 'GEMINI.md');
60
- const detected = existsSync(geminiMd);
61
- return { detected };
62
- }
63
- /**
64
- * Detect Continue.dev IDE extension by checking for the .continue/ directory.
65
- */
66
- export async function detectContinueDev(cwd) {
67
- const continueDir = path.join(cwd, '.continue');
68
- const rulesDir = path.join(continueDir, 'rules');
69
- const detected = existsSync(continueDir);
70
- return { detected, rulesDir };
71
- }
72
- /**
73
- * Detect Windsurf IDE by checking for .windsurfrules in the project root.
74
- */
75
- export async function detectWindsurf(cwd) {
76
- const windsurfrules = path.join(cwd, '.windsurfrules');
77
- const detected = existsSync(windsurfrules);
78
- return { detected };
79
- }
80
- /**
81
- * Detect GitHub Copilot by checking for .github/copilot-instructions.md.
82
- */
83
- export async function detectGithubCopilot(cwd) {
84
- const copilotInstructions = path.join(cwd, '.github', 'copilot-instructions.md');
85
- const detected = existsSync(copilotInstructions);
86
- return { detected };
87
- }
88
- /**
89
- * Detect monorepo structure: Turborepo, Nx, pnpm workspaces, Lerna, or manual.
90
- */
91
- export async function detectMonorepo(cwd) {
92
- // Turborepo
93
- if (existsSync(path.join(cwd, 'turbo.json'))) {
94
- const packages = await discoverPackages(cwd);
95
- return { detected: true, tool: 'turborepo', packages };
96
- }
97
- // Nx
98
- if (existsSync(path.join(cwd, 'nx.json'))) {
99
- const packages = await discoverPackages(cwd);
100
- return { detected: true, tool: 'nx', packages };
101
- }
102
- // pnpm workspaces
103
- if (existsSync(path.join(cwd, 'pnpm-workspace.yaml'))) {
104
- const packages = await discoverPackages(cwd);
105
- return { detected: true, tool: 'pnpm', packages };
106
- }
107
- // Lerna
108
- if (existsSync(path.join(cwd, 'lerna.json'))) {
109
- const packages = await discoverPackages(cwd);
110
- return { detected: true, tool: 'lerna', packages };
111
- }
112
- // Manual monorepo — packages/ or apps/ directory with multiple package.json files
113
- const packages = await discoverPackages(cwd);
114
- if (packages.length >= 2) {
115
- return { detected: true, tool: 'manual', packages };
116
- }
117
- return { detected: false, tool: null, packages: [] };
118
- }
119
- /**
120
- * Discover package directories by looking for package.json in packages/ and apps/.
121
- */
122
- async function discoverPackages(cwd) {
123
- const packageDirs = [];
124
- const searchDirs = ['packages', 'apps', 'libs', 'services'];
125
- for (const searchDir of searchDirs) {
126
- const absDir = path.join(cwd, searchDir);
127
- if (!existsSync(absDir))
128
- continue;
129
- try {
130
- const entries = await readdir(absDir, { withFileTypes: true });
131
- for (const entry of entries) {
132
- if (!entry.isDirectory())
133
- continue;
134
- const pkgJson = path.join(absDir, entry.name, 'package.json');
135
- if (existsSync(pkgJson)) {
136
- packageDirs.push(`${searchDir}/${entry.name}`);
137
- }
138
- }
139
- }
140
- catch {
141
- // ignore unreadable dirs
142
- }
143
- }
144
- return packageDirs;
145
- }
146
- async function detectLanguages(cwd) {
147
- const detections = [];
148
- // Detect Rust
149
- const cargoToml = path.join(cwd, 'Cargo.toml');
150
- if (await fileExists(cargoToml)) {
151
- const rsFiles = await findFiles('**/*.rs', cwd);
152
- detections.push({
153
- language: 'rust',
154
- confidence: rsFiles.length > 0 ? 1.0 : 0.8,
155
- indicators: ['Cargo.toml', `${rsFiles.length} .rs files`],
156
- });
157
- }
158
- // Detect TypeScript
159
- const packageJson = path.join(cwd, 'package.json');
160
- const tsConfig = path.join(cwd, 'tsconfig.json');
161
- if ((await fileExists(packageJson)) || (await fileExists(tsConfig))) {
162
- const tsFiles = await findFiles('**/*.ts', cwd);
163
- detections.push({
164
- language: 'typescript',
165
- confidence: tsFiles.length > 0 ? 1.0 : 0.7,
166
- indicators: [
167
- (await fileExists(packageJson)) ? 'package.json' : '',
168
- (await fileExists(tsConfig)) ? 'tsconfig.json' : '',
169
- `${tsFiles.length} .ts files`,
170
- ].filter(Boolean),
171
- });
172
- }
173
- // Detect Python
174
- const pyprojectToml = path.join(cwd, 'pyproject.toml');
175
- const requirementsTxt = path.join(cwd, 'requirements.txt');
176
- const setupPy = path.join(cwd, 'setup.py');
177
- if ((await fileExists(pyprojectToml)) ||
178
- (await fileExists(requirementsTxt)) ||
179
- (await fileExists(setupPy))) {
180
- const pyFiles = await findFiles('**/*.py', cwd);
181
- detections.push({
182
- language: 'python',
183
- confidence: pyFiles.length > 0 ? 1.0 : 0.7,
184
- indicators: [
185
- (await fileExists(pyprojectToml)) ? 'pyproject.toml' : '',
186
- (await fileExists(requirementsTxt)) ? 'requirements.txt' : '',
187
- (await fileExists(setupPy)) ? 'setup.py' : '',
188
- `${pyFiles.length} .py files`,
189
- ].filter(Boolean),
190
- });
191
- }
192
- // Detect Go
193
- const goMod = path.join(cwd, 'go.mod');
194
- if (await fileExists(goMod)) {
195
- const goFiles = await findFiles('**/*.go', cwd);
196
- detections.push({
197
- language: 'go',
198
- confidence: goFiles.length > 0 ? 1.0 : 0.8,
199
- indicators: ['go.mod', `${goFiles.length} .go files`],
200
- });
201
- }
202
- // Detect Java
203
- const pomXml = path.join(cwd, 'pom.xml');
204
- const buildGradle = path.join(cwd, 'build.gradle');
205
- const buildGradleKts = path.join(cwd, 'build.gradle.kts');
206
- if ((await fileExists(pomXml)) ||
207
- (await fileExists(buildGradle)) ||
208
- (await fileExists(buildGradleKts))) {
209
- const javaFiles = await findFiles('**/*.java', cwd);
210
- detections.push({
211
- language: 'java',
212
- confidence: javaFiles.length > 0 ? 1.0 : 0.7,
213
- indicators: [
214
- (await fileExists(pomXml)) ? 'pom.xml' : '',
215
- (await fileExists(buildGradle)) ? 'build.gradle' : '',
216
- (await fileExists(buildGradleKts)) ? 'build.gradle.kts' : '',
217
- `${javaFiles.length} .java files`,
218
- ].filter(Boolean),
219
- });
220
- }
221
- // Detect C/C++
222
- const cmakeLists = path.join(cwd, 'CMakeLists.txt');
223
- const makeFile = path.join(cwd, 'Makefile');
224
- if ((await fileExists(cmakeLists)) || (await fileExists(makeFile))) {
225
- const cppFiles = await findFiles('**/*.{cpp,hpp,cc,h,c}', cwd);
226
- detections.push({
227
- language: 'cpp',
228
- confidence: cppFiles.length > 0 ? 1.0 : 0.8,
229
- indicators: [
230
- (await fileExists(cmakeLists)) ? 'CMakeLists.txt' : '',
231
- (await fileExists(makeFile)) ? 'Makefile' : '',
232
- `${cppFiles.length} C/C++ files`,
233
- ].filter(Boolean),
234
- });
235
- }
236
- // Detect Solidity
237
- const hardhatConfig = path.join(cwd, 'hardhat.config.js');
238
- const foundryToml = path.join(cwd, 'foundry.toml');
239
- if ((await fileExists(hardhatConfig)) || (await fileExists(foundryToml))) {
240
- const solFiles = await findFiles('**/*.sol', cwd);
241
- detections.push({
242
- language: 'solidity',
243
- confidence: solFiles.length > 0 ? 1.0 : 0.8,
244
- indicators: [
245
- (await fileExists(hardhatConfig)) ? 'hardhat.config.js' : '',
246
- (await fileExists(foundryToml)) ? 'foundry.toml' : '',
247
- `${solFiles.length} .sol files`,
248
- ].filter(Boolean),
249
- });
250
- }
251
- // Detect Zig
252
- const buildZig = path.join(cwd, 'build.zig');
253
- if (await fileExists(buildZig)) {
254
- const zigFiles = await findFiles('**/*.zig', cwd);
255
- detections.push({
256
- language: 'zig',
257
- confidence: zigFiles.length > 0 ? 1.0 : 0.9,
258
- indicators: ['build.zig', `${zigFiles.length} .zig files`],
259
- });
260
- }
261
- // Detect Erlang
262
- const rebarConfig = path.join(cwd, 'rebar.config');
263
- if (await fileExists(rebarConfig)) {
264
- const erlFiles = await findFiles('**/*.erl', cwd);
265
- detections.push({
266
- language: 'erlang',
267
- confidence: erlFiles.length > 0 ? 1.0 : 0.8,
268
- indicators: ['rebar.config', `${erlFiles.length} .erl files`],
269
- });
270
- }
271
- // Detect JavaScript (pure, not TypeScript)
272
- if (await fileExists(packageJson)) {
273
- const jsFiles = await findFiles('**/*.js', cwd);
274
- const hasTS = detections.some((d) => d.language === 'typescript');
275
- if (!hasTS && jsFiles.length > 0) {
276
- const pkg = await readJsonFile(packageJson);
277
- detections.push({
278
- language: 'javascript',
279
- confidence: 0.9,
280
- indicators: [
281
- 'package.json',
282
- `${jsFiles.length} .js files`,
283
- pkg?.type === 'module' ? 'ESM' : '',
284
- ].filter(Boolean),
285
- });
286
- }
287
- }
288
- // Detect Dart
289
- const pubspecYaml = path.join(cwd, 'pubspec.yaml');
290
- if (await fileExists(pubspecYaml)) {
291
- const dartFiles = await findFiles('**/*.dart', cwd);
292
- detections.push({
293
- language: 'dart',
294
- confidence: dartFiles.length > 0 ? 1.0 : 0.8,
295
- indicators: ['pubspec.yaml', `${dartFiles.length} .dart files`],
296
- });
297
- }
298
- // Detect Ruby
299
- const gemfile = path.join(cwd, 'Gemfile');
300
- const gemspec = await findFiles('**/*.gemspec', cwd);
301
- if ((await fileExists(gemfile)) || gemspec.length > 0) {
302
- const rbFiles = await findFiles('**/*.rb', cwd);
303
- detections.push({
304
- language: 'ruby',
305
- confidence: rbFiles.length > 0 ? 1.0 : 0.7,
306
- indicators: [
307
- (await fileExists(gemfile)) ? 'Gemfile' : '',
308
- gemspec.length > 0 ? `${gemspec.length} .gemspec` : '',
309
- `${rbFiles.length} .rb files`,
310
- ].filter(Boolean),
311
- });
312
- }
313
- // Detect Scala
314
- const buildSbt = path.join(cwd, 'build.sbt');
315
- if (await fileExists(buildSbt)) {
316
- const scalaFiles = await findFiles('**/*.scala', cwd);
317
- detections.push({
318
- language: 'scala',
319
- confidence: scalaFiles.length > 0 ? 1.0 : 0.8,
320
- indicators: ['build.sbt', `${scalaFiles.length} .scala files`],
321
- });
322
- }
323
- // Detect R
324
- const descriptionFile = path.join(cwd, 'DESCRIPTION');
325
- if (await fileExists(descriptionFile)) {
326
- const rFiles = await findFiles('**/*.R', cwd);
327
- detections.push({
328
- language: 'r',
329
- confidence: rFiles.length > 0 ? 1.0 : 0.8,
330
- indicators: ['DESCRIPTION', `${rFiles.length} .R files`],
331
- });
332
- }
333
- // Detect Haskell
334
- const stackYaml = path.join(cwd, 'stack.yaml');
335
- const cabalFiles = await findFiles('**/*.cabal', cwd);
336
- if ((await fileExists(stackYaml)) || cabalFiles.length > 0) {
337
- const hsFiles = await findFiles('**/*.hs', cwd);
338
- detections.push({
339
- language: 'haskell',
340
- confidence: hsFiles.length > 0 ? 1.0 : 0.8,
341
- indicators: [
342
- (await fileExists(stackYaml)) ? 'stack.yaml' : '',
343
- cabalFiles.length > 0 ? `${cabalFiles.length} .cabal` : '',
344
- `${hsFiles.length} .hs files`,
345
- ].filter(Boolean),
346
- });
347
- }
348
- // Detect Julia
349
- const projectToml = path.join(cwd, 'Project.toml');
350
- if (await fileExists(projectToml)) {
351
- const jlFiles = await findFiles('**/*.jl', cwd);
352
- detections.push({
353
- language: 'julia',
354
- confidence: jlFiles.length > 0 ? 1.0 : 0.8,
355
- indicators: ['Project.toml', `${jlFiles.length} .jl files`],
356
- });
357
- }
358
- // Detect Lua
359
- const luaFiles = await findFiles('**/*.lua', cwd);
360
- if (luaFiles.length > 5) {
361
- detections.push({
362
- language: 'lua',
363
- confidence: 0.9,
364
- indicators: [`${luaFiles.length} .lua files`],
365
- });
366
- }
367
- // Sort by confidence
368
- return detections.sort((a, b) => b.confidence - a.confidence);
369
- }
370
- async function detectFrameworks(cwd, languages) {
371
- const packageJsonPath = path.join(cwd, 'package.json');
372
- let packageJson = null;
373
- if (await fileExists(packageJsonPath)) {
374
- try {
375
- packageJson = await readJsonFile(packageJsonPath);
376
- }
377
- catch {
378
- packageJson = null;
379
- }
380
- }
381
- const composerJsonPath = path.join(cwd, 'composer.json');
382
- let composerJson = null;
383
- if (await fileExists(composerJsonPath)) {
384
- try {
385
- composerJson = await readJsonFile(composerJsonPath);
386
- }
387
- catch {
388
- composerJson = null;
389
- }
390
- }
391
- const languageSet = new Set(languages.map((l) => l.language));
392
- const npmDeps = {
393
- ...(packageJson && typeof packageJson === 'object'
394
- ? (packageJson.dependencies ?? {})
395
- : {}),
396
- ...(packageJson && typeof packageJson === 'object'
397
- ? (packageJson.devDependencies ?? {})
398
- : {}),
399
- };
400
- const phpDeps = {
401
- ...(composerJson && typeof composerJson === 'object'
402
- ? (composerJson.require ?? {})
403
- : {}),
404
- ...(composerJson && typeof composerJson === 'object'
405
- ? (composerJson['require-dev'] ?? {})
406
- : {}),
407
- };
408
- const frameworkDefinitions = [
409
- {
410
- id: 'nestjs',
411
- label: 'NestJS',
412
- languages: ['typescript', 'javascript'],
413
- detect: async () => {
414
- if (npmDeps['@nestjs/core'] || npmDeps['@nestjs/common']) {
415
- return {
416
- detected: true,
417
- confidence: 0.95,
418
- indicators: ['package.json:@nestjs/core'],
419
- };
420
- }
421
- const nestCli = path.join(cwd, 'nest-cli.json');
422
- if (await fileExists(nestCli)) {
423
- return {
424
- detected: true,
425
- confidence: 0.9,
426
- indicators: ['nest-cli.json'],
427
- };
428
- }
429
- return { detected: false, confidence: 0, indicators: [] };
430
- },
431
- },
432
- {
433
- id: 'spring',
434
- label: 'Spring Boot',
435
- languages: ['java', 'kotlin'],
436
- detect: async () => {
437
- const pomPath = path.join(cwd, 'pom.xml');
438
- if (await fileExists(pomPath)) {
439
- const content = await readFile(pomPath);
440
- if (content.includes('spring-boot-starter')) {
441
- return {
442
- detected: true,
443
- confidence: 0.95,
444
- indicators: ['pom.xml:spring-boot-starter'],
445
- };
446
- }
447
- }
448
- const gradlePath = await findFirstExisting([
449
- path.join(cwd, 'build.gradle'),
450
- path.join(cwd, 'build.gradle.kts'),
451
- ]);
452
- if (gradlePath) {
453
- const content = await readFile(gradlePath);
454
- if (content.includes('spring-boot-starter')) {
455
- return {
456
- detected: true,
457
- confidence: 0.9,
458
- indicators: [`${path.basename(gradlePath)}:spring-boot-starter`],
459
- };
460
- }
461
- }
462
- return { detected: false, confidence: 0, indicators: [] };
463
- },
464
- },
465
- {
466
- id: 'laravel',
467
- label: 'Laravel',
468
- languages: ['php'],
469
- detect: async () => {
470
- if (phpDeps['laravel/framework']) {
471
- return {
472
- detected: true,
473
- confidence: 0.95,
474
- indicators: ['composer.json:laravel/framework'],
475
- };
476
- }
477
- const artisanPath = path.join(cwd, 'artisan');
478
- if (await fileExists(artisanPath)) {
479
- return {
480
- detected: true,
481
- confidence: 0.9,
482
- indicators: ['artisan'],
483
- };
484
- }
485
- return { detected: false, confidence: 0, indicators: [] };
486
- },
487
- },
488
- {
489
- id: 'angular',
490
- label: 'Angular',
491
- languages: ['typescript', 'javascript'],
492
- detect: async () => {
493
- if (npmDeps['@angular/core']) {
494
- return {
495
- detected: true,
496
- confidence: 0.95,
497
- indicators: ['package.json:@angular/core'],
498
- };
499
- }
500
- const angularConfig = path.join(cwd, 'angular.json');
501
- if (await fileExists(angularConfig)) {
502
- return {
503
- detected: true,
504
- confidence: 0.9,
505
- indicators: ['angular.json'],
506
- };
507
- }
508
- return { detected: false, confidence: 0, indicators: [] };
509
- },
510
- },
511
- {
512
- id: 'react',
513
- label: 'React',
514
- languages: ['typescript', 'javascript'],
515
- detect: async () => {
516
- if (npmDeps.react && (npmDeps['react-dom'] || npmDeps['react-native'])) {
517
- const indicator = npmDeps['react-dom'] ? 'react-dom' : 'react-native';
518
- return {
519
- detected: true,
520
- confidence: 0.9,
521
- indicators: [`package.json:react`, `package.json:${indicator}`],
522
- };
523
- }
524
- return { detected: false, confidence: 0, indicators: [] };
525
- },
526
- },
527
- {
528
- id: 'vue',
529
- label: 'Vue.js',
530
- languages: ['typescript', 'javascript'],
531
- detect: async () => {
532
- if (npmDeps.vue) {
533
- return {
534
- detected: true,
535
- confidence: 0.9,
536
- indicators: ['package.json:vue'],
537
- };
538
- }
539
- const vueConfig = await findFirstExisting([
540
- path.join(cwd, 'vite.config.ts'),
541
- path.join(cwd, 'vite.config.js'),
542
- ]);
543
- if (vueConfig) {
544
- const content = await readFile(vueConfig);
545
- if (content.includes('@vitejs/plugin-vue') || content.includes('vue()')) {
546
- return {
547
- detected: true,
548
- confidence: 0.8,
549
- indicators: [path.basename(vueConfig)],
550
- };
551
- }
552
- }
553
- return { detected: false, confidence: 0, indicators: [] };
554
- },
555
- },
556
- {
557
- id: 'nuxt',
558
- label: 'Nuxt',
559
- languages: ['typescript', 'javascript'],
560
- detect: async () => {
561
- if (npmDeps.nuxt) {
562
- return {
563
- detected: true,
564
- confidence: 0.9,
565
- indicators: ['package.json:nuxt'],
566
- };
567
- }
568
- const nuxtConfig = await findFiles('nuxt.config.*', cwd);
569
- if (nuxtConfig.length > 0) {
570
- return {
571
- detected: true,
572
- confidence: 0.85,
573
- indicators: [path.basename(nuxtConfig[0])],
574
- };
575
- }
576
- return { detected: false, confidence: 0, indicators: [] };
577
- },
578
- },
579
- {
580
- id: 'django',
581
- label: 'Django',
582
- languages: ['python'],
583
- detect: async () => {
584
- const requirementsPath = path.join(cwd, 'requirements.txt');
585
- if (await fileExists(requirementsPath)) {
586
- const content = await readFile(requirementsPath);
587
- if (content.includes('Django')) {
588
- return {
589
- detected: true,
590
- confidence: 0.95,
591
- indicators: ['requirements.txt:Django'],
592
- };
593
- }
594
- }
595
- const managePy = path.join(cwd, 'manage.py');
596
- if (await fileExists(managePy)) {
597
- const content = await readFile(managePy);
598
- if (content.includes('django')) {
599
- return {
600
- detected: true,
601
- confidence: 0.9,
602
- indicators: ['manage.py'],
603
- };
604
- }
605
- }
606
- return { detected: false, confidence: 0, indicators: [] };
607
- },
608
- },
609
- {
610
- id: 'flask',
611
- label: 'Flask',
612
- languages: ['python'],
613
- detect: async () => {
614
- const requirementsPath = path.join(cwd, 'requirements.txt');
615
- if (await fileExists(requirementsPath)) {
616
- const content = await readFile(requirementsPath);
617
- if (content.includes('Flask')) {
618
- return {
619
- detected: true,
620
- confidence: 0.95,
621
- indicators: ['requirements.txt:Flask'],
622
- };
623
- }
624
- }
625
- return { detected: false, confidence: 0, indicators: [] };
626
- },
627
- },
628
- {
629
- id: 'rails',
630
- label: 'Ruby on Rails',
631
- languages: ['ruby'],
632
- detect: async () => {
633
- const gemfilePath = path.join(cwd, 'Gemfile');
634
- if (await fileExists(gemfilePath)) {
635
- const content = await readFile(gemfilePath);
636
- if (content.includes('rails')) {
637
- return {
638
- detected: true,
639
- confidence: 0.95,
640
- indicators: ['Gemfile:rails'],
641
- };
642
- }
643
- }
644
- const railsPath = path.join(cwd, 'bin', 'rails');
645
- if (await fileExists(railsPath)) {
646
- return {
647
- detected: true,
648
- confidence: 0.9,
649
- indicators: ['bin/rails'],
650
- };
651
- }
652
- return { detected: false, confidence: 0, indicators: [] };
653
- },
654
- },
655
- {
656
- id: 'symfony',
657
- label: 'Symfony',
658
- languages: ['php'],
659
- detect: async () => {
660
- if (phpDeps['symfony/framework-bundle']) {
661
- return {
662
- detected: true,
663
- confidence: 0.95,
664
- indicators: ['composer.json:symfony/framework-bundle'],
665
- };
666
- }
667
- const symfonyConfig = path.join(cwd, 'symfony.lock');
668
- if (await fileExists(symfonyConfig)) {
669
- return {
670
- detected: true,
671
- confidence: 0.9,
672
- indicators: ['symfony.lock'],
673
- };
674
- }
675
- return { detected: false, confidence: 0, indicators: [] };
676
- },
677
- },
678
- {
679
- id: 'zend',
680
- label: 'Zend Framework',
681
- languages: ['php'],
682
- detect: async () => {
683
- if (phpDeps['zendframework/zendframework'] || phpDeps['laminas/laminas-mvc']) {
684
- return {
685
- detected: true,
686
- confidence: 0.95,
687
- indicators: ['composer.json:zendframework or laminas'],
688
- };
689
- }
690
- return { detected: false, confidence: 0, indicators: [] };
691
- },
692
- },
693
- {
694
- id: 'jquery',
695
- label: 'jQuery',
696
- languages: ['javascript', 'typescript'],
697
- detect: async () => {
698
- if (npmDeps['jquery']) {
699
- return {
700
- detected: true,
701
- confidence: 0.95,
702
- indicators: ['package.json:jquery'],
703
- };
704
- }
705
- // Check for jQuery in HTML files
706
- const indexHtml = path.join(cwd, 'index.html');
707
- if (await fileExists(indexHtml)) {
708
- const content = await readFile(indexHtml);
709
- if (content.includes('jquery') || content.includes('jQuery')) {
710
- return {
711
- detected: true,
712
- confidence: 0.8,
713
- indicators: ['index.html:jquery'],
714
- };
715
- }
716
- }
717
- return { detected: false, confidence: 0, indicators: [] };
718
- },
719
- },
720
- {
721
- id: 'reactnative',
722
- label: 'React Native',
723
- languages: ['javascript', 'typescript'],
724
- detect: async () => {
725
- if (npmDeps['react-native']) {
726
- return {
727
- detected: true,
728
- confidence: 0.95,
729
- indicators: ['package.json:react-native'],
730
- };
731
- }
732
- const appJson = path.join(cwd, 'app.json');
733
- if (await fileExists(appJson)) {
734
- const content = await readFile(appJson);
735
- if (content.includes('react-native') || content.includes('expo')) {
736
- return {
737
- detected: true,
738
- confidence: 0.9,
739
- indicators: ['app.json'],
740
- };
741
- }
742
- }
743
- return { detected: false, confidence: 0, indicators: [] };
744
- },
745
- },
746
- {
747
- id: 'flutter',
748
- label: 'Flutter',
749
- languages: ['dart'],
750
- detect: async () => {
751
- const pubspecPath = path.join(cwd, 'pubspec.yaml');
752
- if (await fileExists(pubspecPath)) {
753
- const content = await readFile(pubspecPath);
754
- if (content.includes('flutter:')) {
755
- return {
756
- detected: true,
757
- confidence: 0.95,
758
- indicators: ['pubspec.yaml:flutter'],
759
- };
760
- }
761
- }
762
- return { detected: false, confidence: 0, indicators: [] };
763
- },
764
- },
765
- {
766
- id: 'nextjs',
767
- label: 'Next.js',
768
- languages: ['typescript', 'javascript'],
769
- detect: async () => {
770
- if (npmDeps['next']) {
771
- return {
772
- detected: true,
773
- confidence: 0.95,
774
- indicators: ['package.json:next'],
775
- };
776
- }
777
- const nextConfig = await findFirstExisting([
778
- path.join(cwd, 'next.config.js'),
779
- path.join(cwd, 'next.config.mjs'),
780
- path.join(cwd, 'next.config.ts'),
781
- ]);
782
- if (nextConfig) {
783
- return {
784
- detected: true,
785
- confidence: 0.9,
786
- indicators: [path.basename(nextConfig)],
787
- };
788
- }
789
- return { detected: false, confidence: 0, indicators: [] };
790
- },
791
- },
792
- {
793
- id: 'electron',
794
- label: 'Electron',
795
- languages: ['typescript', 'javascript'],
796
- detect: async () => {
797
- if (npmDeps['electron']) {
798
- return {
799
- detected: true,
800
- confidence: 0.95,
801
- indicators: ['package.json:electron'],
802
- };
803
- }
804
- // Check for electron-builder or electron-forge
805
- if (npmDeps['electron-builder'] || npmDeps['@electron-forge/cli']) {
806
- return {
807
- detected: true,
808
- confidence: 0.9,
809
- indicators: ['package.json:electron-builder or electron-forge'],
810
- };
811
- }
812
- return { detected: false, confidence: 0, indicators: [] };
813
- },
814
- },
815
- ];
816
- const detections = [];
817
- for (const definition of frameworkDefinitions) {
818
- const match = await definition.detect();
819
- const availableLanguages = definition.languages.filter((lang) => languageSet.has(lang));
820
- const languagesForFramework = availableLanguages.length > 0 ? availableLanguages : definition.languages;
821
- detections.push({
822
- framework: definition.id,
823
- detected: match.detected,
824
- languages: languagesForFramework,
825
- confidence: match.confidence,
826
- indicators: match.indicators,
827
- });
828
- }
829
- return detections.sort((a, b) => b.confidence - a.confidence);
830
- }
831
- async function detectModules(cwd) {
832
- const modules = [];
833
- // Check for MCP configuration files
834
- const mcpConfigPaths = [
835
- path.join(cwd, 'mcp.json'),
836
- path.join(cwd, 'mcp-config.json'),
837
- path.join(cwd, '.cursor', 'mcp.json'),
838
- ];
839
- for (const mcpPath of mcpConfigPaths) {
840
- if (await fileExists(mcpPath)) {
841
- try {
842
- const config = await readJsonFile(mcpPath);
843
- if (config) {
844
- // Check for Vectorizer
845
- if (config.mcpServers?.vectorizer || config.servers?.vectorizer) {
846
- modules.push({
847
- module: 'vectorizer',
848
- detected: true,
849
- source: mcpPath,
850
- });
851
- }
852
- // Check for Synap
853
- if (config.mcpServers?.synap || config.servers?.synap) {
854
- modules.push({
855
- module: 'synap',
856
- detected: true,
857
- source: mcpPath,
858
- });
859
- }
860
- // Check for Context7
861
- if (config.mcpServers?.context7 || config.servers?.context7) {
862
- modules.push({
863
- module: 'context7',
864
- detected: true,
865
- source: mcpPath,
866
- });
867
- }
868
- // Check for GitHub MCP Server
869
- if (config.mcpServers?.github || config.servers?.github) {
870
- modules.push({
871
- module: 'github',
872
- detected: true,
873
- source: mcpPath,
874
- });
875
- }
876
- // Check for Playwright MCP Server
877
- if (config.mcpServers?.playwright || config.servers?.playwright) {
878
- modules.push({
879
- module: 'playwright',
880
- detected: true,
881
- source: mcpPath,
882
- });
883
- }
884
- // Check for Rulebook MCP Server
885
- if (config.mcpServers?.rulebook || config.servers?.rulebook) {
886
- modules.push({
887
- module: 'rulebook_mcp',
888
- detected: true,
889
- source: mcpPath,
890
- });
891
- }
892
- // Check for Sequential Thinking MCP Server (various key names)
893
- const seqKeys = ['sequential-thinking', 'sequential_thinking', 'sequentialThinking'];
894
- const hasSeqThinking = seqKeys.some((k) => config.mcpServers?.[k] || config.servers?.[k]) ||
895
- Object.entries(config.mcpServers ?? {}).some(([, v]) => typeof v === 'object' &&
896
- v !== null &&
897
- 'args' in v &&
898
- Array.isArray(v.args) &&
899
- v.args.some((a) => typeof a === 'string' && a.includes('sequential-thinking')));
900
- if (hasSeqThinking) {
901
- modules.push({
902
- module: 'sequential_thinking',
903
- detected: true,
904
- source: mcpPath,
905
- });
906
- }
907
- }
908
- }
909
- catch {
910
- // Ignore JSON parse errors
911
- }
912
- }
913
- }
914
- // Add undetected modules
915
- const detectedModules = new Set(modules.map((m) => m.module));
916
- const allModules = [
917
- 'vectorizer',
918
- 'synap',
919
- 'context7',
920
- 'github',
921
- 'playwright',
922
- 'rulebook_mcp',
923
- 'sequential_thinking',
924
- ];
925
- for (const module of allModules) {
926
- if (!detectedModules.has(module)) {
927
- modules.push({
928
- module,
929
- detected: false,
930
- });
931
- }
932
- }
933
- return modules;
934
- }
935
- async function detectExistingAgents(cwd) {
936
- const agentsPath = path.join(cwd, 'AGENTS.md');
937
- if (!(await fileExists(agentsPath))) {
938
- return null;
939
- }
940
- const content = await readFile(agentsPath);
941
- const blocks = parseAgentBlocks(content);
942
- return {
943
- exists: true,
944
- path: agentsPath,
945
- content,
946
- blocks,
947
- };
948
- }
949
- function parseAgentBlocks(content) {
950
- const blocks = [];
951
- const lines = content.split('\n');
952
- let currentBlock = null;
953
- for (let i = 0; i < lines.length; i++) {
954
- const line = lines[i];
955
- const startMatch = line.match(/<!--\s*([A-Z_]+):START\s*-->/);
956
- const endMatch = line.match(/<!--\s*([A-Z_]+):END\s*-->/);
957
- if (startMatch) {
958
- currentBlock = {
959
- name: startMatch[1],
960
- startLine: i,
961
- content: [line],
962
- };
963
- }
964
- else if (endMatch && currentBlock) {
965
- currentBlock.content.push(line);
966
- blocks.push({
967
- name: currentBlock.name,
968
- startLine: currentBlock.startLine,
969
- endLine: i,
970
- content: currentBlock.content.join('\n'),
971
- });
972
- currentBlock = null;
973
- }
974
- else if (currentBlock) {
975
- currentBlock.content.push(line);
976
- }
977
- }
978
- return blocks;
979
- }
980
- async function detectGitHooks(cwd) {
981
- const preCommitPath = path.join(cwd, '.git', 'hooks', 'pre-commit');
982
- const prePushPath = path.join(cwd, '.git', 'hooks', 'pre-push');
983
- return {
984
- preCommitExists: await fileExists(preCommitPath),
985
- prePushExists: await fileExists(prePushPath),
986
- };
987
- }
988
- async function findFirstExisting(pathsToCheck) {
989
- for (const filePath of pathsToCheck) {
990
- if (await fileExists(filePath)) {
991
- return filePath;
992
- }
993
- }
994
- return null;
995
- }
996
- async function detectServices(cwd) {
997
- const services = [];
998
- const packageJson = path.join(cwd, 'package.json');
999
- const envFile = path.join(cwd, '.env');
1000
- const dockerCompose = path.join(cwd, 'docker-compose.yml');
1001
- const dockerComposeYaml = path.join(cwd, 'docker-compose.yaml');
1002
- // Check package.json for database drivers
1003
- if (await fileExists(packageJson)) {
1004
- try {
1005
- const pkg = await readJsonFile(packageJson);
1006
- const allDeps = { ...(pkg?.dependencies || {}), ...(pkg?.devDependencies || {}) };
1007
- // PostgreSQL
1008
- if (allDeps['pg'] || allDeps['postgres'] || allDeps['@prisma/client']) {
1009
- services.push({
1010
- service: 'postgresql',
1011
- detected: true,
1012
- confidence: 0.9,
1013
- indicators: ['pg', 'postgres', '@prisma/client'].filter((dep) => allDeps[dep]),
1014
- source: packageJson,
1015
- });
1016
- }
1017
- // MySQL/MariaDB
1018
- if (allDeps['mysql2'] || allDeps['mysql'] || allDeps['mariadb']) {
1019
- services.push({
1020
- service: allDeps['mariadb'] ? 'mariadb' : 'mysql',
1021
- detected: true,
1022
- confidence: 0.9,
1023
- indicators: ['mysql2', 'mysql', 'mariadb'].filter((dep) => allDeps[dep]),
1024
- source: packageJson,
1025
- });
1026
- }
1027
- // MongoDB
1028
- if (allDeps['mongodb'] || allDeps['mongoose']) {
1029
- services.push({
1030
- service: 'mongodb',
1031
- detected: true,
1032
- confidence: 0.9,
1033
- indicators: ['mongodb', 'mongoose'].filter((dep) => allDeps[dep]),
1034
- source: packageJson,
1035
- });
1036
- }
1037
- // Redis
1038
- if (allDeps['redis'] || allDeps['ioredis'] || allDeps['@redis/client']) {
1039
- services.push({
1040
- service: 'redis',
1041
- detected: true,
1042
- confidence: 0.9,
1043
- indicators: ['redis', 'ioredis', '@redis/client'].filter((dep) => allDeps[dep]),
1044
- source: packageJson,
1045
- });
1046
- }
1047
- // Memcached
1048
- if (allDeps['memcached']) {
1049
- services.push({
1050
- service: 'memcached',
1051
- detected: true,
1052
- confidence: 0.9,
1053
- indicators: ['memcached'],
1054
- source: packageJson,
1055
- });
1056
- }
1057
- // Elasticsearch
1058
- if (allDeps['@elastic/elasticsearch'] || allDeps['elasticsearch']) {
1059
- services.push({
1060
- service: 'elasticsearch',
1061
- detected: true,
1062
- confidence: 0.9,
1063
- indicators: ['@elastic/elasticsearch', 'elasticsearch'].filter((dep) => allDeps[dep]),
1064
- source: packageJson,
1065
- });
1066
- }
1067
- // Neo4j
1068
- if (allDeps['neo4j-driver']) {
1069
- services.push({
1070
- service: 'neo4j',
1071
- detected: true,
1072
- confidence: 0.9,
1073
- indicators: ['neo4j-driver'],
1074
- source: packageJson,
1075
- });
1076
- }
1077
- // InfluxDB
1078
- if (allDeps['@influxdata/influxdb-client']) {
1079
- services.push({
1080
- service: 'influxdb',
1081
- detected: true,
1082
- confidence: 0.9,
1083
- indicators: ['@influxdata/influxdb-client'],
1084
- source: packageJson,
1085
- });
1086
- }
1087
- // RabbitMQ
1088
- if (allDeps['amqplib'] || allDeps['amqp-connection-manager']) {
1089
- services.push({
1090
- service: 'rabbitmq',
1091
- detected: true,
1092
- confidence: 0.9,
1093
- indicators: ['amqplib', 'amqp-connection-manager'].filter((dep) => allDeps[dep]),
1094
- source: packageJson,
1095
- });
1096
- }
1097
- // Kafka
1098
- if (allDeps['kafkajs'] || allDeps['node-rdkafka']) {
1099
- services.push({
1100
- service: 'kafka',
1101
- detected: true,
1102
- confidence: 0.9,
1103
- indicators: ['kafkajs', 'node-rdkafka'].filter((dep) => allDeps[dep]),
1104
- source: packageJson,
1105
- });
1106
- }
1107
- // AWS S3
1108
- if (allDeps['@aws-sdk/client-s3'] || allDeps['aws-sdk']) {
1109
- services.push({
1110
- service: 's3',
1111
- detected: true,
1112
- confidence: 0.8,
1113
- indicators: ['@aws-sdk/client-s3', 'aws-sdk'].filter((dep) => allDeps[dep]),
1114
- source: packageJson,
1115
- });
1116
- }
1117
- // Azure Blob
1118
- if (allDeps['@azure/storage-blob']) {
1119
- services.push({
1120
- service: 'azure_blob',
1121
- detected: true,
1122
- confidence: 0.9,
1123
- indicators: ['@azure/storage-blob'],
1124
- source: packageJson,
1125
- });
1126
- }
1127
- // Google Cloud Storage
1128
- if (allDeps['@google-cloud/storage']) {
1129
- services.push({
1130
- service: 'gcs',
1131
- detected: true,
1132
- confidence: 0.9,
1133
- indicators: ['@google-cloud/storage'],
1134
- source: packageJson,
1135
- });
1136
- }
1137
- // MinIO
1138
- if (allDeps['minio']) {
1139
- services.push({
1140
- service: 'minio',
1141
- detected: true,
1142
- confidence: 0.9,
1143
- indicators: ['minio'],
1144
- source: packageJson,
1145
- });
1146
- }
1147
- // SQLite
1148
- if (allDeps['better-sqlite3'] || allDeps['sqlite3']) {
1149
- services.push({
1150
- service: 'sqlite',
1151
- detected: true,
1152
- confidence: 0.9,
1153
- indicators: ['better-sqlite3', 'sqlite3'].filter((dep) => allDeps[dep]),
1154
- source: packageJson,
1155
- });
1156
- }
1157
- // Cassandra
1158
- if (allDeps['cassandra-driver']) {
1159
- services.push({
1160
- service: 'cassandra',
1161
- detected: true,
1162
- confidence: 0.9,
1163
- indicators: ['cassandra-driver'],
1164
- source: packageJson,
1165
- });
1166
- }
1167
- // DynamoDB
1168
- if (allDeps['@aws-sdk/client-dynamodb'] || allDeps['aws-sdk']) {
1169
- services.push({
1170
- service: 'dynamodb',
1171
- detected: true,
1172
- confidence: 0.8,
1173
- indicators: ['@aws-sdk/client-dynamodb', 'aws-sdk'].filter((dep) => allDeps[dep]),
1174
- source: packageJson,
1175
- });
1176
- }
1177
- // SQL Server
1178
- if (allDeps['mssql'] || allDeps['tedious']) {
1179
- services.push({
1180
- service: 'sqlserver',
1181
- detected: true,
1182
- confidence: 0.9,
1183
- indicators: ['mssql', 'tedious'].filter((dep) => allDeps[dep]),
1184
- source: packageJson,
1185
- });
1186
- }
1187
- // Oracle
1188
- if (allDeps['oracledb']) {
1189
- services.push({
1190
- service: 'oracle',
1191
- detected: true,
1192
- confidence: 0.9,
1193
- indicators: ['oracledb'],
1194
- source: packageJson,
1195
- });
1196
- }
1197
- // Sentry
1198
- if (allDeps['@sentry/node'] ||
1199
- allDeps['@sentry/react'] ||
1200
- allDeps['@sentry/nextjs'] ||
1201
- allDeps['@sentry/browser']) {
1202
- services.push({
1203
- service: 'sentry',
1204
- detected: true,
1205
- confidence: 0.9,
1206
- indicators: ['@sentry/node', '@sentry/react', '@sentry/nextjs', '@sentry/browser'].filter((dep) => allDeps[dep]),
1207
- source: packageJson,
1208
- });
1209
- }
1210
- // OpenTelemetry
1211
- if (allDeps['@opentelemetry/sdk-node'] ||
1212
- allDeps['@opentelemetry/api'] ||
1213
- allDeps['@opentelemetry/auto-instrumentations-node']) {
1214
- services.push({
1215
- service: 'opentelemetry',
1216
- detected: true,
1217
- confidence: 0.9,
1218
- indicators: [
1219
- '@opentelemetry/sdk-node',
1220
- '@opentelemetry/api',
1221
- '@opentelemetry/auto-instrumentations-node',
1222
- ].filter((dep) => allDeps[dep]),
1223
- source: packageJson,
1224
- });
1225
- }
1226
- // Datadog
1227
- if (allDeps['dd-trace'] || allDeps['datadog-lambda-js']) {
1228
- services.push({
1229
- service: 'datadog',
1230
- detected: true,
1231
- confidence: 0.9,
1232
- indicators: ['dd-trace', 'datadog-lambda-js'].filter((dep) => allDeps[dep]),
1233
- source: packageJson,
1234
- });
1235
- }
1236
- // Pino
1237
- if (allDeps['pino'] || allDeps['pino-http']) {
1238
- services.push({
1239
- service: 'pino',
1240
- detected: true,
1241
- confidence: 0.9,
1242
- indicators: ['pino', 'pino-http'].filter((dep) => allDeps[dep]),
1243
- source: packageJson,
1244
- });
1245
- }
1246
- // Winston
1247
- if (allDeps['winston'] || allDeps['winston-transport']) {
1248
- services.push({
1249
- service: 'winston',
1250
- detected: true,
1251
- confidence: 0.9,
1252
- indicators: ['winston', 'winston-transport'].filter((dep) => allDeps[dep]),
1253
- source: packageJson,
1254
- });
1255
- }
1256
- // Prometheus
1257
- if (allDeps['prom-client'] || allDeps['express-prometheus-middleware']) {
1258
- services.push({
1259
- service: 'prometheus',
1260
- detected: true,
1261
- confidence: 0.9,
1262
- indicators: ['prom-client', 'express-prometheus-middleware'].filter((dep) => allDeps[dep]),
1263
- source: packageJson,
1264
- });
1265
- }
1266
- }
1267
- catch {
1268
- // Ignore JSON parse errors
1269
- }
1270
- }
1271
- // Check .env file for service connection strings
1272
- if (await fileExists(envFile)) {
1273
- try {
1274
- const envContent = await readFile(envFile);
1275
- const envLines = envContent.split('\n');
1276
- for (const line of envLines) {
1277
- const upperLine = line.toUpperCase();
1278
- // PostgreSQL
1279
- if (upperLine.includes('POSTGRES') ||
1280
- (upperLine.includes('DATABASE_URL') && upperLine.includes('POSTGRES'))) {
1281
- if (!services.find((s) => s.service === 'postgresql')) {
1282
- services.push({
1283
- service: 'postgresql',
1284
- detected: true,
1285
- confidence: 0.8,
1286
- indicators: ['DATABASE_URL or POSTGRES_* env vars'],
1287
- source: envFile,
1288
- });
1289
- }
1290
- }
1291
- // MySQL
1292
- if (upperLine.includes('MYSQL') && !upperLine.includes('MARIADB')) {
1293
- if (!services.find((s) => s.service === 'mysql')) {
1294
- services.push({
1295
- service: 'mysql',
1296
- detected: true,
1297
- confidence: 0.8,
1298
- indicators: ['MYSQL_* env vars'],
1299
- source: envFile,
1300
- });
1301
- }
1302
- }
1303
- // MariaDB
1304
- if (upperLine.includes('MARIADB')) {
1305
- if (!services.find((s) => s.service === 'mariadb')) {
1306
- services.push({
1307
- service: 'mariadb',
1308
- detected: true,
1309
- confidence: 0.8,
1310
- indicators: ['MARIADB_* env vars'],
1311
- source: envFile,
1312
- });
1313
- }
1314
- }
1315
- // MongoDB
1316
- if (upperLine.includes('MONGODB')) {
1317
- if (!services.find((s) => s.service === 'mongodb')) {
1318
- services.push({
1319
- service: 'mongodb',
1320
- detected: true,
1321
- confidence: 0.8,
1322
- indicators: ['MONGODB_* env vars'],
1323
- source: envFile,
1324
- });
1325
- }
1326
- }
1327
- // Redis
1328
- if (upperLine.includes('REDIS')) {
1329
- if (!services.find((s) => s.service === 'redis')) {
1330
- services.push({
1331
- service: 'redis',
1332
- detected: true,
1333
- confidence: 0.8,
1334
- indicators: ['REDIS_* env vars'],
1335
- source: envFile,
1336
- });
1337
- }
1338
- }
1339
- // Elasticsearch
1340
- if (upperLine.includes('ELASTICSEARCH')) {
1341
- if (!services.find((s) => s.service === 'elasticsearch')) {
1342
- services.push({
1343
- service: 'elasticsearch',
1344
- detected: true,
1345
- confidence: 0.8,
1346
- indicators: ['ELASTICSEARCH_* env vars'],
1347
- source: envFile,
1348
- });
1349
- }
1350
- }
1351
- // RabbitMQ
1352
- if (upperLine.includes('RABBITMQ') || upperLine.includes('AMQP')) {
1353
- if (!services.find((s) => s.service === 'rabbitmq')) {
1354
- services.push({
1355
- service: 'rabbitmq',
1356
- detected: true,
1357
- confidence: 0.8,
1358
- indicators: ['RABBITMQ_* or AMQP_* env vars'],
1359
- source: envFile,
1360
- });
1361
- }
1362
- }
1363
- // Kafka
1364
- if (upperLine.includes('KAFKA')) {
1365
- if (!services.find((s) => s.service === 'kafka')) {
1366
- services.push({
1367
- service: 'kafka',
1368
- detected: true,
1369
- confidence: 0.8,
1370
- indicators: ['KAFKA_* env vars'],
1371
- source: envFile,
1372
- });
1373
- }
1374
- }
1375
- // AWS S3
1376
- if (upperLine.includes('S3_') || (upperLine.includes('AWS_') && upperLine.includes('S3'))) {
1377
- if (!services.find((s) => s.service === 's3')) {
1378
- services.push({
1379
- service: 's3',
1380
- detected: true,
1381
- confidence: 0.7,
1382
- indicators: ['S3_* or AWS_* env vars'],
1383
- source: envFile,
1384
- });
1385
- }
1386
- }
1387
- // Azure Blob
1388
- if (upperLine.includes('AZURE_STORAGE') || upperLine.includes('AZURE_BLOB')) {
1389
- if (!services.find((s) => s.service === 'azure_blob')) {
1390
- services.push({
1391
- service: 'azure_blob',
1392
- detected: true,
1393
- confidence: 0.8,
1394
- indicators: ['AZURE_STORAGE_* or AZURE_BLOB_* env vars'],
1395
- source: envFile,
1396
- });
1397
- }
1398
- }
1399
- // Google Cloud Storage
1400
- if (upperLine.includes('GCS_') || upperLine.includes('GCP_STORAGE')) {
1401
- if (!services.find((s) => s.service === 'gcs')) {
1402
- services.push({
1403
- service: 'gcs',
1404
- detected: true,
1405
- confidence: 0.8,
1406
- indicators: ['GCS_* or GCP_STORAGE_* env vars'],
1407
- source: envFile,
1408
- });
1409
- }
1410
- }
1411
- // MinIO
1412
- if (upperLine.includes('MINIO')) {
1413
- if (!services.find((s) => s.service === 'minio')) {
1414
- services.push({
1415
- service: 'minio',
1416
- detected: true,
1417
- confidence: 0.8,
1418
- indicators: ['MINIO_* env vars'],
1419
- source: envFile,
1420
- });
1421
- }
1422
- }
1423
- // InfluxDB
1424
- if (upperLine.includes('INFLUXDB')) {
1425
- if (!services.find((s) => s.service === 'influxdb')) {
1426
- services.push({
1427
- service: 'influxdb',
1428
- detected: true,
1429
- confidence: 0.8,
1430
- indicators: ['INFLUXDB_* env vars'],
1431
- source: envFile,
1432
- });
1433
- }
1434
- }
1435
- // Neo4j
1436
- if (upperLine.includes('NEO4J')) {
1437
- if (!services.find((s) => s.service === 'neo4j')) {
1438
- services.push({
1439
- service: 'neo4j',
1440
- detected: true,
1441
- confidence: 0.8,
1442
- indicators: ['NEO4J_* env vars'],
1443
- source: envFile,
1444
- });
1445
- }
1446
- }
1447
- // SQL Server
1448
- if (upperLine.includes('SQL_SERVER') || upperLine.includes('MSSQL')) {
1449
- if (!services.find((s) => s.service === 'sqlserver')) {
1450
- services.push({
1451
- service: 'sqlserver',
1452
- detected: true,
1453
- confidence: 0.8,
1454
- indicators: ['SQL_SERVER_* or MSSQL_* env vars'],
1455
- source: envFile,
1456
- });
1457
- }
1458
- }
1459
- // Oracle
1460
- if (upperLine.includes('ORACLE')) {
1461
- if (!services.find((s) => s.service === 'oracle')) {
1462
- services.push({
1463
- service: 'oracle',
1464
- detected: true,
1465
- confidence: 0.8,
1466
- indicators: ['ORACLE_* env vars'],
1467
- source: envFile,
1468
- });
1469
- }
1470
- }
1471
- }
1472
- }
1473
- catch {
1474
- // Ignore file read errors
1475
- }
1476
- }
1477
- // Check docker-compose.yml for services
1478
- const composeFiles = [dockerCompose, dockerComposeYaml];
1479
- for (const composeFile of composeFiles) {
1480
- if (await fileExists(composeFile)) {
1481
- try {
1482
- const composeContent = await readFile(composeFile);
1483
- const upperContent = composeContent.toUpperCase();
1484
- // PostgreSQL
1485
- if (upperContent.includes('POSTGRES') &&
1486
- !services.find((s) => s.service === 'postgresql')) {
1487
- services.push({
1488
- service: 'postgresql',
1489
- detected: true,
1490
- confidence: 0.7,
1491
- indicators: ['docker-compose.yml postgres service'],
1492
- source: composeFile,
1493
- });
1494
- }
1495
- // MySQL
1496
- if (upperContent.includes('MYSQL') &&
1497
- !upperContent.includes('MARIADB') &&
1498
- !services.find((s) => s.service === 'mysql')) {
1499
- services.push({
1500
- service: 'mysql',
1501
- detected: true,
1502
- confidence: 0.7,
1503
- indicators: ['docker-compose.yml mysql service'],
1504
- source: composeFile,
1505
- });
1506
- }
1507
- // MariaDB
1508
- if (upperContent.includes('MARIADB') && !services.find((s) => s.service === 'mariadb')) {
1509
- services.push({
1510
- service: 'mariadb',
1511
- detected: true,
1512
- confidence: 0.7,
1513
- indicators: ['docker-compose.yml mariadb service'],
1514
- source: composeFile,
1515
- });
1516
- }
1517
- // MongoDB
1518
- if (upperContent.includes('MONGO') && !services.find((s) => s.service === 'mongodb')) {
1519
- services.push({
1520
- service: 'mongodb',
1521
- detected: true,
1522
- confidence: 0.7,
1523
- indicators: ['docker-compose.yml mongo service'],
1524
- source: composeFile,
1525
- });
1526
- }
1527
- // Redis
1528
- if (upperContent.includes('REDIS') && !services.find((s) => s.service === 'redis')) {
1529
- services.push({
1530
- service: 'redis',
1531
- detected: true,
1532
- confidence: 0.7,
1533
- indicators: ['docker-compose.yml redis service'],
1534
- source: composeFile,
1535
- });
1536
- }
1537
- // Memcached
1538
- if (upperContent.includes('MEMCACHED') &&
1539
- !services.find((s) => s.service === 'memcached')) {
1540
- services.push({
1541
- service: 'memcached',
1542
- detected: true,
1543
- confidence: 0.7,
1544
- indicators: ['docker-compose.yml memcached service'],
1545
- source: composeFile,
1546
- });
1547
- }
1548
- // Elasticsearch
1549
- if (upperContent.includes('ELASTICSEARCH') &&
1550
- !services.find((s) => s.service === 'elasticsearch')) {
1551
- services.push({
1552
- service: 'elasticsearch',
1553
- detected: true,
1554
- confidence: 0.7,
1555
- indicators: ['docker-compose.yml elasticsearch service'],
1556
- source: composeFile,
1557
- });
1558
- }
1559
- // Neo4j
1560
- if (upperContent.includes('NEO4J') && !services.find((s) => s.service === 'neo4j')) {
1561
- services.push({
1562
- service: 'neo4j',
1563
- detected: true,
1564
- confidence: 0.7,
1565
- indicators: ['docker-compose.yml neo4j service'],
1566
- source: composeFile,
1567
- });
1568
- }
1569
- // InfluxDB
1570
- if (upperContent.includes('INFLUXDB') && !services.find((s) => s.service === 'influxdb')) {
1571
- services.push({
1572
- service: 'influxdb',
1573
- detected: true,
1574
- confidence: 0.7,
1575
- indicators: ['docker-compose.yml influxdb service'],
1576
- source: composeFile,
1577
- });
1578
- }
1579
- // RabbitMQ
1580
- if (upperContent.includes('RABBITMQ') && !services.find((s) => s.service === 'rabbitmq')) {
1581
- services.push({
1582
- service: 'rabbitmq',
1583
- detected: true,
1584
- confidence: 0.7,
1585
- indicators: ['docker-compose.yml rabbitmq service'],
1586
- source: composeFile,
1587
- });
1588
- }
1589
- // Kafka
1590
- if (upperContent.includes('KAFKA') && !services.find((s) => s.service === 'kafka')) {
1591
- services.push({
1592
- service: 'kafka',
1593
- detected: true,
1594
- confidence: 0.7,
1595
- indicators: ['docker-compose.yml kafka service'],
1596
- source: composeFile,
1597
- });
1598
- }
1599
- // MinIO
1600
- if (upperContent.includes('MINIO') && !services.find((s) => s.service === 'minio')) {
1601
- services.push({
1602
- service: 'minio',
1603
- detected: true,
1604
- confidence: 0.7,
1605
- indicators: ['docker-compose.yml minio service'],
1606
- source: composeFile,
1607
- });
1608
- }
1609
- // SQL Server
1610
- if ((upperContent.includes('SQLSERVER') || upperContent.includes('MSSQL')) &&
1611
- !services.find((s) => s.service === 'sqlserver')) {
1612
- services.push({
1613
- service: 'sqlserver',
1614
- detected: true,
1615
- confidence: 0.7,
1616
- indicators: ['docker-compose.yml sqlserver service'],
1617
- source: composeFile,
1618
- });
1619
- }
1620
- }
1621
- catch {
1622
- // Ignore file read errors
1623
- }
1624
- }
1625
- }
1626
- // Detect container/orchestration services (Docker, Docker Compose, Kubernetes, Helm)
1627
- const dockerfile = path.join(cwd, 'Dockerfile');
1628
- const dockerignore = path.join(cwd, '.dockerignore');
1629
- const k8sDir = path.join(cwd, 'k8s');
1630
- const kubernetesDir = path.join(cwd, 'kubernetes');
1631
- const chartYaml = path.join(cwd, 'Chart.yaml');
1632
- const chartsDir = path.join(cwd, 'charts');
1633
- // Docker
1634
- if ((await fileExists(dockerfile)) || (await fileExists(dockerignore))) {
1635
- const indicators = [];
1636
- if (await fileExists(dockerfile))
1637
- indicators.push('Dockerfile');
1638
- if (await fileExists(dockerignore))
1639
- indicators.push('.dockerignore');
1640
- services.push({
1641
- service: 'docker',
1642
- detected: true,
1643
- confidence: 0.95,
1644
- indicators,
1645
- source: indicators[0],
1646
- });
1647
- }
1648
- // Docker Compose
1649
- if ((await fileExists(dockerCompose)) || (await fileExists(dockerComposeYaml))) {
1650
- const indicators = [];
1651
- if (await fileExists(dockerCompose))
1652
- indicators.push('docker-compose.yml');
1653
- if (await fileExists(dockerComposeYaml))
1654
- indicators.push('docker-compose.yaml');
1655
- services.push({
1656
- service: 'docker-compose',
1657
- detected: true,
1658
- confidence: 0.95,
1659
- indicators,
1660
- source: indicators[0],
1661
- });
1662
- }
1663
- // Kubernetes
1664
- const k8sDirExists = existsSync(k8sDir);
1665
- const kubernetesDirExists = existsSync(kubernetesDir);
1666
- let k8sYamlDetected = false;
1667
- if (!k8sDirExists && !kubernetesDirExists) {
1668
- // Scan root-level YAML files for Kubernetes resource kinds
1669
- try {
1670
- const rootFiles = await readdir(cwd);
1671
- const yamlFiles = rootFiles.filter((f) => f.endsWith('.yml') || f.endsWith('.yaml'));
1672
- for (const yamlFile of yamlFiles) {
1673
- const content = await readFile(path.join(cwd, yamlFile));
1674
- if (content.includes('kind: Deployment') ||
1675
- content.includes('kind: Service') ||
1676
- content.includes('kind: Ingress')) {
1677
- k8sYamlDetected = true;
1678
- break;
1679
- }
1680
- }
1681
- }
1682
- catch {
1683
- // Ignore read errors
1684
- }
1685
- }
1686
- if (k8sDirExists || kubernetesDirExists || k8sYamlDetected) {
1687
- const indicators = [];
1688
- if (k8sDirExists)
1689
- indicators.push('k8s/ directory');
1690
- if (kubernetesDirExists)
1691
- indicators.push('kubernetes/ directory');
1692
- if (k8sYamlDetected)
1693
- indicators.push('YAML with kind: Deployment/Service/Ingress');
1694
- services.push({
1695
- service: 'kubernetes',
1696
- detected: true,
1697
- confidence: 0.9,
1698
- indicators,
1699
- });
1700
- }
1701
- // Helm
1702
- const chartYamlExists = await fileExists(chartYaml);
1703
- const chartsDirExists = existsSync(chartsDir);
1704
- if (chartYamlExists || chartsDirExists) {
1705
- const indicators = [];
1706
- if (chartYamlExists)
1707
- indicators.push('Chart.yaml');
1708
- if (chartsDirExists)
1709
- indicators.push('charts/ directory');
1710
- services.push({
1711
- service: 'helm',
1712
- detected: true,
1713
- confidence: 0.9,
1714
- indicators,
1715
- });
1716
- }
1717
- // Add undetected services (for manual selection)
1718
- const detectedServices = new Set(services.map((s) => s.service));
1719
- const allServices = [
1720
- 'postgresql',
1721
- 'mysql',
1722
- 'mariadb',
1723
- 'sqlserver',
1724
- 'oracle',
1725
- 'sqlite',
1726
- 'mongodb',
1727
- 'cassandra',
1728
- 'dynamodb',
1729
- 'redis',
1730
- 'memcached',
1731
- 'elasticsearch',
1732
- 'neo4j',
1733
- 'influxdb',
1734
- 'rabbitmq',
1735
- 'kafka',
1736
- 's3',
1737
- 'azure_blob',
1738
- 'gcs',
1739
- 'minio',
1740
- 'docker',
1741
- 'docker-compose',
1742
- 'kubernetes',
1743
- 'helm',
1744
- 'sentry',
1745
- 'opentelemetry',
1746
- 'datadog',
1747
- 'pino',
1748
- 'winston',
1749
- 'prometheus',
1750
- ];
1751
- for (const service of allServices) {
1752
- if (!detectedServices.has(service)) {
1753
- services.push({
1754
- service,
1755
- detected: false,
1756
- confidence: 0,
1757
- indicators: [],
1758
- });
1759
- }
1760
- }
1761
- return services;
1762
- }
1763
- //# sourceMappingURL=detector.js.map