mcoda 0.1.2 → 0.1.4

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 (461) hide show
  1. package/CHANGELOG.md +2 -2
  2. package/README.md +9 -300
  3. package/dist/bin/McodaEntrypoint.d.ts +5 -0
  4. package/dist/bin/McodaEntrypoint.d.ts.map +1 -0
  5. package/dist/bin/McodaEntrypoint.js +175 -0
  6. package/dist/commands/agents/AgentsCommands.d.ts +4 -0
  7. package/dist/commands/agents/AgentsCommands.d.ts.map +1 -0
  8. package/dist/commands/agents/AgentsCommands.js +376 -0
  9. package/dist/commands/agents/GatewayAgentCommand.d.ts +4 -0
  10. package/dist/commands/agents/GatewayAgentCommand.d.ts.map +1 -0
  11. package/dist/commands/agents/GatewayAgentCommand.js +583 -0
  12. package/dist/commands/agents/TestAgentCommand.d.ts +4 -0
  13. package/dist/commands/agents/TestAgentCommand.d.ts.map +1 -0
  14. package/dist/commands/agents/TestAgentCommand.js +57 -0
  15. package/dist/commands/backlog/BacklogCommands.d.ts +17 -0
  16. package/dist/commands/backlog/BacklogCommands.d.ts.map +1 -0
  17. package/dist/commands/backlog/BacklogCommands.js +260 -0
  18. package/dist/commands/backlog/OrderTasksCommand.d.ts +16 -0
  19. package/dist/commands/backlog/OrderTasksCommand.d.ts.map +1 -0
  20. package/dist/commands/backlog/OrderTasksCommand.js +211 -0
  21. package/dist/commands/backlog/TaskShowCommands.d.ts +16 -0
  22. package/dist/commands/backlog/TaskShowCommands.d.ts.map +1 -0
  23. package/dist/commands/backlog/TaskShowCommands.js +275 -0
  24. package/dist/commands/docs/DocsCommands.d.ts +37 -0
  25. package/dist/commands/docs/DocsCommands.d.ts.map +1 -0
  26. package/dist/commands/docs/DocsCommands.js +381 -0
  27. package/dist/commands/estimate/EstimateCommands.d.ts +24 -0
  28. package/dist/commands/estimate/EstimateCommands.d.ts.map +1 -0
  29. package/dist/commands/estimate/EstimateCommands.js +259 -0
  30. package/dist/commands/jobs/JobsCommands.d.ts +24 -0
  31. package/dist/commands/jobs/JobsCommands.d.ts.map +1 -0
  32. package/dist/commands/jobs/JobsCommands.js +535 -0
  33. package/dist/commands/openapi/OpenapiCommands.d.ts +14 -0
  34. package/dist/commands/openapi/OpenapiCommands.d.ts.map +1 -0
  35. package/dist/commands/openapi/OpenapiCommands.js +157 -0
  36. package/dist/commands/planning/CreateTasksCommand.d.ts +17 -0
  37. package/dist/commands/planning/CreateTasksCommand.d.ts.map +1 -0
  38. package/dist/commands/planning/CreateTasksCommand.js +134 -0
  39. package/dist/commands/planning/MigrateTasksCommand.d.ts +15 -0
  40. package/dist/commands/planning/MigrateTasksCommand.d.ts.map +1 -0
  41. package/dist/commands/planning/MigrateTasksCommand.js +95 -0
  42. package/dist/commands/planning/PlanningCommands.d.ts +3 -0
  43. package/dist/commands/planning/PlanningCommands.d.ts.map +1 -0
  44. package/dist/commands/planning/PlanningCommands.js +2 -0
  45. package/dist/commands/planning/QaTasksCommand.d.ts +30 -0
  46. package/dist/commands/planning/QaTasksCommand.d.ts.map +1 -0
  47. package/dist/commands/planning/QaTasksCommand.js +293 -0
  48. package/dist/commands/planning/RefineTasksCommand.d.ts +30 -0
  49. package/dist/commands/planning/RefineTasksCommand.d.ts.map +1 -0
  50. package/dist/commands/planning/RefineTasksCommand.js +365 -0
  51. package/dist/commands/review/CodeReviewCommand.d.ts +21 -0
  52. package/dist/commands/review/CodeReviewCommand.d.ts.map +1 -0
  53. package/dist/commands/review/CodeReviewCommand.js +236 -0
  54. package/dist/commands/routing/RoutingCommands.d.ts +7 -0
  55. package/dist/commands/routing/RoutingCommands.d.ts.map +1 -0
  56. package/dist/commands/routing/RoutingCommands.js +484 -0
  57. package/dist/commands/telemetry/TelemetryCommands.d.ts +26 -0
  58. package/dist/commands/telemetry/TelemetryCommands.d.ts.map +1 -0
  59. package/dist/commands/telemetry/TelemetryCommands.js +313 -0
  60. package/dist/commands/update/UpdateCommands.d.ts +4 -0
  61. package/dist/commands/update/UpdateCommands.d.ts.map +1 -0
  62. package/dist/commands/update/UpdateCommands.js +280 -0
  63. package/dist/commands/work/WorkOnTasksCommand.d.ts +21 -0
  64. package/dist/commands/work/WorkOnTasksCommand.d.ts.map +1 -0
  65. package/dist/commands/work/WorkOnTasksCommand.js +238 -0
  66. package/dist/commands/workspace/SetWorkspaceCommand.d.ts +9 -0
  67. package/dist/commands/workspace/SetWorkspaceCommand.d.ts.map +1 -0
  68. package/dist/commands/workspace/SetWorkspaceCommand.js +128 -0
  69. package/dist/index.d.ts +19 -0
  70. package/dist/index.d.ts.map +1 -0
  71. package/package.json +31 -16
  72. package/.editorconfig +0 -9
  73. package/.eslintrc.cjs +0 -12
  74. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -29
  75. package/.github/ISSUE_TEMPLATE/config.yml +0 -5
  76. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -19
  77. package/.github/workflows/ci.yml +0 -37
  78. package/.github/workflows/nightly.yml +0 -38
  79. package/.github/workflows/release-dry-run.yml +0 -40
  80. package/.github/workflows/release-please.yml +0 -22
  81. package/.github/workflows/release.yml +0 -139
  82. package/.prettierrc +0 -5
  83. package/.release-please-manifest.json +0 -8
  84. package/CLA.md +0 -42
  85. package/CONTRIBUTING.md +0 -38
  86. package/docs/oss_publishing_plan.md +0 -41
  87. package/docs/pdr/.gitkeep +0 -0
  88. package/docs/quality_gates.md +0 -32
  89. package/docs/rfp/.gitkeep +0 -0
  90. package/docs/sds/sds.md +0 -11963
  91. package/docs/usage.md +0 -72
  92. package/openapi/gen-openapi.ts +0 -1
  93. package/openapi/generated/clients/.gitkeep +0 -0
  94. package/openapi/generated/types/.gitkeep +0 -0
  95. package/openapi/generated/types/index.ts +0 -118
  96. package/openapi/mcoda.yaml +0 -2063
  97. package/pack-mcoda.sh +0 -88
  98. package/packages/agents/CHANGELOG.md +0 -7
  99. package/packages/agents/LICENSE +0 -21
  100. package/packages/agents/README.md +0 -9
  101. package/packages/agents/package.json +0 -41
  102. package/packages/agents/src/AgentService/.gitkeep +0 -0
  103. package/packages/agents/src/AgentService/AgentService.d.ts +0 -21
  104. package/packages/agents/src/AgentService/AgentService.d.ts.map +0 -1
  105. package/packages/agents/src/AgentService/AgentService.js +0 -141
  106. package/packages/agents/src/AgentService/AgentService.ts +0 -308
  107. package/packages/agents/src/__tests__/AgentService.test.ts +0 -284
  108. package/packages/agents/src/adapters/AdapterTypes.d.ts +0 -29
  109. package/packages/agents/src/adapters/AdapterTypes.d.ts.map +0 -1
  110. package/packages/agents/src/adapters/AdapterTypes.js +0 -1
  111. package/packages/agents/src/adapters/AdapterTypes.ts +0 -32
  112. package/packages/agents/src/adapters/codex/.gitkeep +0 -0
  113. package/packages/agents/src/adapters/codex/CodexAdapter.d.ts +0 -11
  114. package/packages/agents/src/adapters/codex/CodexAdapter.d.ts.map +0 -1
  115. package/packages/agents/src/adapters/codex/CodexAdapter.js +0 -43
  116. package/packages/agents/src/adapters/codex/CodexAdapter.ts +0 -63
  117. package/packages/agents/src/adapters/codex/CodexCliRunner.ts +0 -154
  118. package/packages/agents/src/adapters/gemini/.gitkeep +0 -0
  119. package/packages/agents/src/adapters/gemini/GeminiAdapter.d.ts +0 -11
  120. package/packages/agents/src/adapters/gemini/GeminiAdapter.d.ts.map +0 -1
  121. package/packages/agents/src/adapters/gemini/GeminiAdapter.js +0 -42
  122. package/packages/agents/src/adapters/gemini/GeminiAdapter.ts +0 -58
  123. package/packages/agents/src/adapters/gemini/GeminiCliRunner.ts +0 -75
  124. package/packages/agents/src/adapters/local/.gitkeep +0 -0
  125. package/packages/agents/src/adapters/local/LocalAdapter.d.ts +0 -11
  126. package/packages/agents/src/adapters/local/LocalAdapter.d.ts.map +0 -1
  127. package/packages/agents/src/adapters/local/LocalAdapter.js +0 -38
  128. package/packages/agents/src/adapters/local/LocalAdapter.ts +0 -43
  129. package/packages/agents/src/adapters/ollama/OllamaCliAdapter.ts +0 -58
  130. package/packages/agents/src/adapters/ollama/OllamaCliRunner.ts +0 -70
  131. package/packages/agents/src/adapters/ollama/OllamaRemoteAdapter.ts +0 -205
  132. package/packages/agents/src/adapters/openai/.gitkeep +0 -0
  133. package/packages/agents/src/adapters/openai/OpenAiAdapter.d.ts +0 -11
  134. package/packages/agents/src/adapters/openai/OpenAiAdapter.d.ts.map +0 -1
  135. package/packages/agents/src/adapters/openai/OpenAiAdapter.js +0 -51
  136. package/packages/agents/src/adapters/openai/OpenAiAdapter.ts +0 -56
  137. package/packages/agents/src/adapters/openai/OpenAiCliAdapter.ts +0 -62
  138. package/packages/agents/src/adapters/qa/.gitkeep +0 -0
  139. package/packages/agents/src/adapters/qa/QaAdapter.d.ts +0 -11
  140. package/packages/agents/src/adapters/qa/QaAdapter.d.ts.map +0 -1
  141. package/packages/agents/src/adapters/qa/QaAdapter.js +0 -37
  142. package/packages/agents/src/adapters/qa/QaAdapter.ts +0 -42
  143. package/packages/agents/src/adapters/zhipu/ZhipuApiAdapter.ts +0 -273
  144. package/packages/agents/src/index.d.ts +0 -8
  145. package/packages/agents/src/index.d.ts.map +0 -1
  146. package/packages/agents/src/index.js +0 -7
  147. package/packages/agents/src/index.ts +0 -11
  148. package/packages/agents/tsconfig.json +0 -14
  149. package/packages/cli/CHANGELOG.md +0 -7
  150. package/packages/cli/LICENSE +0 -21
  151. package/packages/cli/README.md +0 -23
  152. package/packages/cli/package.json +0 -61
  153. package/packages/cli/src/__tests__/AgentsCommands.test.ts +0 -137
  154. package/packages/cli/src/__tests__/BacklogCommands.test.ts +0 -40
  155. package/packages/cli/src/__tests__/CodeReviewCommand.test.ts +0 -594
  156. package/packages/cli/src/__tests__/CreateTasksCommand.test.ts +0 -40
  157. package/packages/cli/src/__tests__/DocsCommands.test.ts +0 -41
  158. package/packages/cli/src/__tests__/EstimateCommands.test.ts +0 -54
  159. package/packages/cli/src/__tests__/JobsCommands.behavior.test.ts +0 -311
  160. package/packages/cli/src/__tests__/JobsCommands.test.ts +0 -49
  161. package/packages/cli/src/__tests__/MigrateTasksCommand.test.ts +0 -36
  162. package/packages/cli/src/__tests__/OpenapiCommands.test.ts +0 -34
  163. package/packages/cli/src/__tests__/OrderTasksCommand.test.ts +0 -150
  164. package/packages/cli/src/__tests__/PlanningCommands.test.ts +0 -9
  165. package/packages/cli/src/__tests__/QaTasksCommand.test.ts +0 -58
  166. package/packages/cli/src/__tests__/RefineTasksCommand.test.ts +0 -63
  167. package/packages/cli/src/__tests__/RoutingCommands.test.ts +0 -302
  168. package/packages/cli/src/__tests__/SetWorkspaceCommand.test.ts +0 -18
  169. package/packages/cli/src/__tests__/TaskShowCommands.test.ts +0 -130
  170. package/packages/cli/src/__tests__/TelemetryCommands.test.ts +0 -35
  171. package/packages/cli/src/__tests__/TestAgentCommand.test.ts +0 -41
  172. package/packages/cli/src/__tests__/UpdateCommands.test.ts +0 -292
  173. package/packages/cli/src/__tests__/WorkOnTasksCommand.test.ts +0 -42
  174. package/packages/cli/src/bin/.gitkeep +0 -0
  175. package/packages/cli/src/bin/McodaEntrypoint.ts +0 -180
  176. package/packages/cli/src/commands/agents/.gitkeep +0 -0
  177. package/packages/cli/src/commands/agents/AgentsCommands.ts +0 -374
  178. package/packages/cli/src/commands/agents/GatewayAgentCommand.ts +0 -621
  179. package/packages/cli/src/commands/agents/TestAgentCommand.ts +0 -63
  180. package/packages/cli/src/commands/backlog/.gitkeep +0 -0
  181. package/packages/cli/src/commands/backlog/BacklogCommands.ts +0 -286
  182. package/packages/cli/src/commands/backlog/OrderTasksCommand.ts +0 -237
  183. package/packages/cli/src/commands/backlog/TaskShowCommands.ts +0 -289
  184. package/packages/cli/src/commands/docs/.gitkeep +0 -0
  185. package/packages/cli/src/commands/docs/DocsCommands.ts +0 -413
  186. package/packages/cli/src/commands/estimate/EstimateCommands.ts +0 -290
  187. package/packages/cli/src/commands/jobs/.gitkeep +0 -0
  188. package/packages/cli/src/commands/jobs/JobsCommands.ts +0 -595
  189. package/packages/cli/src/commands/openapi/OpenapiCommands.ts +0 -167
  190. package/packages/cli/src/commands/planning/.gitkeep +0 -0
  191. package/packages/cli/src/commands/planning/CreateTasksCommand.ts +0 -149
  192. package/packages/cli/src/commands/planning/MigrateTasksCommand.ts +0 -105
  193. package/packages/cli/src/commands/planning/PlanningCommands.ts +0 -1
  194. package/packages/cli/src/commands/planning/QaTasksCommand.ts +0 -320
  195. package/packages/cli/src/commands/planning/RefineTasksCommand.ts +0 -408
  196. package/packages/cli/src/commands/review/CodeReviewCommand.ts +0 -262
  197. package/packages/cli/src/commands/routing/.gitkeep +0 -0
  198. package/packages/cli/src/commands/routing/RoutingCommands.ts +0 -554
  199. package/packages/cli/src/commands/telemetry/.gitkeep +0 -0
  200. package/packages/cli/src/commands/telemetry/TelemetryCommands.ts +0 -348
  201. package/packages/cli/src/commands/update/.gitkeep +0 -0
  202. package/packages/cli/src/commands/update/UpdateCommands.ts +0 -301
  203. package/packages/cli/src/commands/work/WorkOnTasksCommand.ts +0 -264
  204. package/packages/cli/src/commands/workspace/SetWorkspaceCommand.ts +0 -132
  205. package/packages/cli/test/packaging_guardrails.test.js +0 -75
  206. package/packages/cli/tsconfig.json +0 -20
  207. package/packages/core/CHANGELOG.md +0 -7
  208. package/packages/core/LICENSE +0 -21
  209. package/packages/core/README.md +0 -9
  210. package/packages/core/package.json +0 -45
  211. package/packages/core/src/__tests__/SmokeClasses.test.ts +0 -32
  212. package/packages/core/src/api/AgentsApi.ts +0 -219
  213. package/packages/core/src/api/QaTasksApi.ts +0 -38
  214. package/packages/core/src/api/TasksApi.ts +0 -35
  215. package/packages/core/src/api/__tests__/AgentsApi.test.ts +0 -203
  216. package/packages/core/src/api/__tests__/QaTasksApi.test.ts +0 -51
  217. package/packages/core/src/api/__tests__/TasksApi.test.ts +0 -56
  218. package/packages/core/src/config/.gitkeep +0 -0
  219. package/packages/core/src/config/ConfigService.ts +0 -1
  220. package/packages/core/src/domain/dependencies/.gitkeep +0 -0
  221. package/packages/core/src/domain/dependencies/Dependency.ts +0 -1
  222. package/packages/core/src/domain/epics/.gitkeep +0 -0
  223. package/packages/core/src/domain/epics/Epic.ts +0 -1
  224. package/packages/core/src/domain/projects/.gitkeep +0 -0
  225. package/packages/core/src/domain/projects/Project.ts +0 -1
  226. package/packages/core/src/domain/tasks/.gitkeep +0 -0
  227. package/packages/core/src/domain/tasks/Task.ts +0 -1
  228. package/packages/core/src/domain/userStories/.gitkeep +0 -0
  229. package/packages/core/src/domain/userStories/UserStory.ts +0 -1
  230. package/packages/core/src/index.ts +0 -27
  231. package/packages/core/src/prompts/.gitkeep +0 -0
  232. package/packages/core/src/prompts/PdrPrompts.ts +0 -23
  233. package/packages/core/src/prompts/PromptLoader.ts +0 -1
  234. package/packages/core/src/prompts/SdsPrompts.ts +0 -47
  235. package/packages/core/src/services/agents/.gitkeep +0 -0
  236. package/packages/core/src/services/agents/AgentManagementService.ts +0 -1
  237. package/packages/core/src/services/agents/GatewayAgentService.ts +0 -956
  238. package/packages/core/src/services/agents/RoutingService.ts +0 -461
  239. package/packages/core/src/services/agents/__tests__/GatewayAgentService.test.ts +0 -72
  240. package/packages/core/src/services/agents/__tests__/RoutingService.test.ts +0 -267
  241. package/packages/core/src/services/agents/generated/RoutingApiClient.ts +0 -89
  242. package/packages/core/src/services/backlog/.gitkeep +0 -0
  243. package/packages/core/src/services/backlog/BacklogService.ts +0 -580
  244. package/packages/core/src/services/backlog/TaskOrderingService.ts +0 -868
  245. package/packages/core/src/services/backlog/__tests__/BacklogService.test.ts +0 -219
  246. package/packages/core/src/services/backlog/__tests__/TaskOrderingService.test.ts +0 -268
  247. package/packages/core/src/services/docs/.gitkeep +0 -0
  248. package/packages/core/src/services/docs/DocsService.ts +0 -1913
  249. package/packages/core/src/services/docs/__tests__/DocsService.test.ts +0 -350
  250. package/packages/core/src/services/estimate/EstimateService.ts +0 -111
  251. package/packages/core/src/services/estimate/VelocityService.ts +0 -272
  252. package/packages/core/src/services/estimate/__tests__/VelocityAndEstimate.test.ts +0 -209
  253. package/packages/core/src/services/estimate/types.ts +0 -41
  254. package/packages/core/src/services/execution/.gitkeep +0 -0
  255. package/packages/core/src/services/execution/ExecutionService.ts +0 -1
  256. package/packages/core/src/services/execution/QaFollowupService.ts +0 -289
  257. package/packages/core/src/services/execution/QaProfileService.ts +0 -160
  258. package/packages/core/src/services/execution/QaTasksService.ts +0 -1303
  259. package/packages/core/src/services/execution/TaskSelectionService.ts +0 -362
  260. package/packages/core/src/services/execution/TaskStateService.ts +0 -64
  261. package/packages/core/src/services/execution/WorkOnTasksService.ts +0 -2023
  262. package/packages/core/src/services/execution/__tests__/QaFollowupService.test.ts +0 -58
  263. package/packages/core/src/services/execution/__tests__/QaProfileService.test.ts +0 -49
  264. package/packages/core/src/services/execution/__tests__/QaTasksService.test.ts +0 -157
  265. package/packages/core/src/services/execution/__tests__/TaskSelectionService.test.ts +0 -179
  266. package/packages/core/src/services/execution/__tests__/TaskStateService.test.ts +0 -51
  267. package/packages/core/src/services/execution/__tests__/WorkOnTasksService.test.ts +0 -285
  268. package/packages/core/src/services/jobs/.gitkeep +0 -0
  269. package/packages/core/src/services/jobs/JobInsightsService.ts +0 -355
  270. package/packages/core/src/services/jobs/JobResumeService.ts +0 -119
  271. package/packages/core/src/services/jobs/JobService.ts +0 -648
  272. package/packages/core/src/services/jobs/JobsApiClient.ts +0 -113
  273. package/packages/core/src/services/jobs/__tests__/JobInsightsService.test.ts +0 -17
  274. package/packages/core/src/services/jobs/__tests__/JobResumeService.test.ts +0 -45
  275. package/packages/core/src/services/jobs/__tests__/JobService.test.ts +0 -44
  276. package/packages/core/src/services/openapi/OpenApiService.ts +0 -558
  277. package/packages/core/src/services/openapi/__tests__/OpenApiService.test.ts +0 -57
  278. package/packages/core/src/services/planning/.gitkeep +0 -0
  279. package/packages/core/src/services/planning/CreateTasksService.ts +0 -1280
  280. package/packages/core/src/services/planning/KeyHelpers.ts +0 -80
  281. package/packages/core/src/services/planning/PlanningService.ts +0 -1
  282. package/packages/core/src/services/planning/RefineTasksService.ts +0 -1552
  283. package/packages/core/src/services/planning/__tests__/CreateTasksService.test.ts +0 -288
  284. package/packages/core/src/services/planning/__tests__/KeyHelpers.test.ts +0 -16
  285. package/packages/core/src/services/planning/__tests__/RefineTasksService.test.ts +0 -172
  286. package/packages/core/src/services/review/CodeReviewService.ts +0 -1386
  287. package/packages/core/src/services/review/__tests__/CodeReviewService.test.ts +0 -89
  288. package/packages/core/src/services/system/SystemUpdateService.ts +0 -177
  289. package/packages/core/src/services/system/__tests__/SystemUpdateService.test.ts +0 -40
  290. package/packages/core/src/services/tasks/TaskApiResolver.ts +0 -37
  291. package/packages/core/src/services/tasks/TaskDetailService.ts +0 -494
  292. package/packages/core/src/services/tasks/__tests__/TaskApiResolver.test.ts +0 -41
  293. package/packages/core/src/services/tasks/__tests__/TaskDetailService.test.ts +0 -178
  294. package/packages/core/src/services/telemetry/.gitkeep +0 -0
  295. package/packages/core/src/services/telemetry/TelemetryService.ts +0 -515
  296. package/packages/core/src/services/telemetry/__tests__/TelemetryService.test.ts +0 -160
  297. package/packages/core/src/workspace/.gitkeep +0 -0
  298. package/packages/core/src/workspace/WorkspaceManager.ts +0 -234
  299. package/packages/core/tsconfig.json +0 -20
  300. package/packages/db/CHANGELOG.md +0 -7
  301. package/packages/db/LICENSE +0 -21
  302. package/packages/db/README.md +0 -9
  303. package/packages/db/package.json +0 -42
  304. package/packages/db/src/__tests__/GlobalRepository.test.ts +0 -109
  305. package/packages/db/src/__tests__/SchemaAlignment.test.ts +0 -80
  306. package/packages/db/src/__tests__/WorkspaceRepository.test.ts +0 -19
  307. package/packages/db/src/index.d.ts +0 -6
  308. package/packages/db/src/index.d.ts.map +0 -1
  309. package/packages/db/src/index.js +0 -5
  310. package/packages/db/src/index.ts +0 -6
  311. package/packages/db/src/migrations/global/.gitkeep +0 -0
  312. package/packages/db/src/migrations/global/GlobalMigrations.d.ts +0 -9
  313. package/packages/db/src/migrations/global/GlobalMigrations.d.ts.map +0 -1
  314. package/packages/db/src/migrations/global/GlobalMigrations.js +0 -68
  315. package/packages/db/src/migrations/global/GlobalMigrations.ts +0 -336
  316. package/packages/db/src/migrations/workspace/.gitkeep +0 -0
  317. package/packages/db/src/migrations/workspace/WorkspaceMigrations.d.ts +0 -9
  318. package/packages/db/src/migrations/workspace/WorkspaceMigrations.d.ts.map +0 -1
  319. package/packages/db/src/migrations/workspace/WorkspaceMigrations.js +0 -251
  320. package/packages/db/src/migrations/workspace/WorkspaceMigrations.ts +0 -248
  321. package/packages/db/src/repositories/global/.gitkeep +0 -0
  322. package/packages/db/src/repositories/global/GlobalRepository.d.ts +0 -30
  323. package/packages/db/src/repositories/global/GlobalRepository.d.ts.map +0 -1
  324. package/packages/db/src/repositories/global/GlobalRepository.js +0 -209
  325. package/packages/db/src/repositories/global/GlobalRepository.ts +0 -492
  326. package/packages/db/src/repositories/workspace/.gitkeep +0 -0
  327. package/packages/db/src/repositories/workspace/WorkspaceRepository.d.ts +0 -282
  328. package/packages/db/src/repositories/workspace/WorkspaceRepository.d.ts.map +0 -1
  329. package/packages/db/src/repositories/workspace/WorkspaceRepository.js +0 -773
  330. package/packages/db/src/repositories/workspace/WorkspaceRepository.ts +0 -1511
  331. package/packages/db/src/sqlite/connection.d.ts +0 -11
  332. package/packages/db/src/sqlite/connection.d.ts.map +0 -1
  333. package/packages/db/src/sqlite/connection.js +0 -31
  334. package/packages/db/src/sqlite/connection.ts +0 -35
  335. package/packages/db/src/sqlite/pragmas.d.ts +0 -5
  336. package/packages/db/src/sqlite/pragmas.d.ts.map +0 -1
  337. package/packages/db/src/sqlite/pragmas.js +0 -6
  338. package/packages/db/src/sqlite/pragmas.ts +0 -10
  339. package/packages/db/tsconfig.json +0 -13
  340. package/packages/generators/package.json +0 -21
  341. package/packages/generators/src/__tests__/Generators.test.ts +0 -19
  342. package/packages/generators/src/index.ts +0 -1
  343. package/packages/generators/src/openapi/generateTypes.ts +0 -1
  344. package/packages/generators/src/openapi/validateSchema.ts +0 -1
  345. package/packages/generators/src/scaffolding/docs/.gitkeep +0 -0
  346. package/packages/generators/src/scaffolding/docs/DocsScaffolder.ts +0 -1
  347. package/packages/generators/src/scaffolding/global/.gitkeep +0 -0
  348. package/packages/generators/src/scaffolding/global/GlobalScaffolder.ts +0 -1
  349. package/packages/generators/src/scaffolding/workspace/.gitkeep +0 -0
  350. package/packages/generators/src/scaffolding/workspace/WorkspaceScaffolder.ts +0 -1
  351. package/packages/generators/tsconfig.json +0 -10
  352. package/packages/integrations/CHANGELOG.md +0 -7
  353. package/packages/integrations/LICENSE +0 -21
  354. package/packages/integrations/README.md +0 -9
  355. package/packages/integrations/package.json +0 -47
  356. package/packages/integrations/src/docdex/.gitkeep +0 -0
  357. package/packages/integrations/src/docdex/DocdexClient.d.ts +0 -50
  358. package/packages/integrations/src/docdex/DocdexClient.d.ts.map +0 -1
  359. package/packages/integrations/src/docdex/DocdexClient.js +0 -216
  360. package/packages/integrations/src/docdex/DocdexClient.ts +0 -261
  361. package/packages/integrations/src/docdex/__tests__/DocdexClient.test.ts +0 -29
  362. package/packages/integrations/src/index.d.ts +0 -2
  363. package/packages/integrations/src/index.d.ts.map +0 -1
  364. package/packages/integrations/src/index.js +0 -4
  365. package/packages/integrations/src/index.ts +0 -5
  366. package/packages/integrations/src/issues/.gitkeep +0 -0
  367. package/packages/integrations/src/issues/IssuesClient.ts +0 -1
  368. package/packages/integrations/src/issues/__tests__/IssuesClient.test.ts +0 -10
  369. package/packages/integrations/src/qa/.gitkeep +0 -0
  370. package/packages/integrations/src/qa/ChromiumQaAdapter.ts +0 -89
  371. package/packages/integrations/src/qa/CliQaAdapter.ts +0 -95
  372. package/packages/integrations/src/qa/MaestroQaAdapter.ts +0 -91
  373. package/packages/integrations/src/qa/QaAdapter.ts +0 -7
  374. package/packages/integrations/src/qa/QaClient.ts +0 -1
  375. package/packages/integrations/src/qa/QaTypes.ts +0 -26
  376. package/packages/integrations/src/qa/__tests__/ChromiumQaAdapter.test.ts +0 -30
  377. package/packages/integrations/src/qa/__tests__/CliQaAdapter.test.ts +0 -33
  378. package/packages/integrations/src/qa/__tests__/MaestroQaAdapter.test.ts +0 -30
  379. package/packages/integrations/src/qa/index.ts +0 -5
  380. package/packages/integrations/src/system/SystemClient.ts +0 -50
  381. package/packages/integrations/src/system/__tests__/SystemClient.test.ts +0 -40
  382. package/packages/integrations/src/telemetry/TelemetryClient.ts +0 -139
  383. package/packages/integrations/src/telemetry/__tests__/TelemetryClient.test.ts +0 -41
  384. package/packages/integrations/src/vcs/.gitkeep +0 -0
  385. package/packages/integrations/src/vcs/VcsClient.ts +0 -211
  386. package/packages/integrations/src/vcs/__tests__/VcsClient.test.ts +0 -26
  387. package/packages/integrations/tsconfig.json +0 -14
  388. package/packages/shared/CHANGELOG.md +0 -7
  389. package/packages/shared/LICENSE +0 -21
  390. package/packages/shared/README.md +0 -9
  391. package/packages/shared/package.json +0 -40
  392. package/packages/shared/src/__tests__/CommandMetadata.test.ts +0 -15
  393. package/packages/shared/src/__tests__/ServiceShells.test.ts +0 -16
  394. package/packages/shared/src/crypto/.gitkeep +0 -0
  395. package/packages/shared/src/crypto/CryptoHelper.d.ts +0 -15
  396. package/packages/shared/src/crypto/CryptoHelper.d.ts.map +0 -1
  397. package/packages/shared/src/crypto/CryptoHelper.js +0 -54
  398. package/packages/shared/src/crypto/CryptoHelper.ts +0 -57
  399. package/packages/shared/src/errors/.gitkeep +0 -0
  400. package/packages/shared/src/errors/ErrorFactory.ts +0 -1
  401. package/packages/shared/src/index.d.ts +0 -6
  402. package/packages/shared/src/index.d.ts.map +0 -1
  403. package/packages/shared/src/index.js +0 -4
  404. package/packages/shared/src/index.ts +0 -35
  405. package/packages/shared/src/logging/.gitkeep +0 -0
  406. package/packages/shared/src/logging/Logger.ts +0 -1
  407. package/packages/shared/src/metadata/CommandMetadata.ts +0 -165
  408. package/packages/shared/src/openapi/.gitkeep +0 -0
  409. package/packages/shared/src/openapi/OpenApiTypes.d.ts +0 -216
  410. package/packages/shared/src/openapi/OpenApiTypes.d.ts.map +0 -1
  411. package/packages/shared/src/openapi/OpenApiTypes.js +0 -1
  412. package/packages/shared/src/openapi/OpenApiTypes.ts +0 -312
  413. package/packages/shared/src/paths/.gitkeep +0 -0
  414. package/packages/shared/src/paths/PathHelper.d.ts +0 -12
  415. package/packages/shared/src/paths/PathHelper.d.ts.map +0 -1
  416. package/packages/shared/src/paths/PathHelper.js +0 -24
  417. package/packages/shared/src/paths/PathHelper.ts +0 -29
  418. package/packages/shared/src/qa/QaProfile.ts +0 -14
  419. package/packages/shared/src/utils/.gitkeep +0 -0
  420. package/packages/shared/src/utils/UtilityService.ts +0 -1
  421. package/packages/shared/tsconfig.json +0 -10
  422. package/packages/testing/package.json +0 -26
  423. package/packages/testing/src/__tests__/TestingFakes.test.ts +0 -15
  424. package/packages/testing/src/cli/e2e/.gitkeep +0 -0
  425. package/packages/testing/src/cli/e2e/E2eSuite.ts +0 -1
  426. package/packages/testing/src/fakes/agents/.gitkeep +0 -0
  427. package/packages/testing/src/fakes/agents/FakeAgents.ts +0 -1
  428. package/packages/testing/src/fakes/docdex/.gitkeep +0 -0
  429. package/packages/testing/src/fakes/docdex/FakeDocdexClient.ts +0 -1
  430. package/packages/testing/src/fakes/qa/.gitkeep +0 -0
  431. package/packages/testing/src/fakes/qa/FakeQaClient.ts +0 -1
  432. package/packages/testing/src/fakes/vcs/.gitkeep +0 -0
  433. package/packages/testing/src/fakes/vcs/FakeVcsClient.ts +0 -1
  434. package/packages/testing/src/fixtures/db/.gitkeep +0 -0
  435. package/packages/testing/src/fixtures/db/DbFixtures.ts +0 -1
  436. package/packages/testing/src/fixtures/workspaces/.gitkeep +0 -0
  437. package/packages/testing/src/fixtures/workspaces/WorkspaceFixtures.ts +0 -1
  438. package/packages/testing/src/index.ts +0 -1
  439. package/packages/testing/tsconfig.json +0 -10
  440. package/pnpm-workspace.yaml +0 -2
  441. package/prompts/README.md +0 -5
  442. package/prompts/code-reviewer.md +0 -23
  443. package/prompts/code-writer.md +0 -35
  444. package/prompts/gateway-agent.md +0 -27
  445. package/prompts/qa-agent.md +0 -21
  446. package/release-please-config.json +0 -39
  447. package/scripts/build-all.ts +0 -1
  448. package/scripts/dev.ts +0 -1
  449. package/scripts/install-local-cli.sh +0 -28
  450. package/scripts/pack-npm-tarballs.js +0 -63
  451. package/scripts/release.ts +0 -1
  452. package/scripts/run-node-tests.js +0 -37
  453. package/tests/all.js +0 -127
  454. package/tests/api/openapi_spec.test.js +0 -21
  455. package/tests/artifacts.md +0 -31
  456. package/tests/component/cli_version.test.js +0 -38
  457. package/tests/integration/workspace_resolver.test.js +0 -44
  458. package/tests/unit/crypto_helper.test.js +0 -36
  459. package/tests/unit/path_helper.test.js +0 -20
  460. package/tsconfig.base.json +0 -32
  461. /package/{packages/cli/src/index.ts → dist/index.js} +0 -0
@@ -1,289 +0,0 @@
1
- import {
2
- EpicInsert,
3
- StoryInsert,
4
- TaskCommentInsert,
5
- TaskDependencyInsert,
6
- TaskInsert,
7
- TaskRow,
8
- WorkspaceRepository,
9
- } from '@mcoda/db';
10
- import { createTaskKeyGenerator } from '../planning/KeyHelpers.js';
11
- import path from 'node:path';
12
- import fs from 'node:fs/promises';
13
- import { PathHelper } from '@mcoda/shared';
14
-
15
- export interface FollowupSuggestion {
16
- title: string;
17
- description?: string;
18
- type?: string;
19
- priority?: number;
20
- storyPoints?: number;
21
- tags?: string[];
22
- epicKeyHint?: string;
23
- storyKeyHint?: string;
24
- relatedTaskKey?: string;
25
- components?: string[];
26
- docLinks?: string[];
27
- testName?: string;
28
- evidenceUrl?: string;
29
- artifacts?: string[];
30
- }
31
-
32
- const BUG_EPIC_KEY = 'EPIC-BUGS';
33
- const BUG_STORY_KEY = 'US-BUGS';
34
- const FOLLOWUP_DESCRIPTION_TEMPLATE = (
35
- summary: string,
36
- actual: string,
37
- expected: string,
38
- envLines: string[],
39
- steps?: string[],
40
- ): string => {
41
- const lines = [
42
- '# Summary',
43
- summary || 'Summarize the problem discovered during QA.',
44
- '',
45
- '# Steps to Reproduce',
46
- ...(steps && steps.length
47
- ? steps.map((step, idx) => `${idx + 1}. ${step}`)
48
- : ['1. Provide minimal reproducible steps based on failing test or QA notes.']),
49
- '',
50
- '# Expected',
51
- expected || 'Describe the expected behavior per acceptance criteria / OpenAPI.',
52
- '',
53
- '# Actual',
54
- actual || 'Describe the observed behavior.',
55
- '',
56
- '# Environment',
57
- ...envLines.map((line) => `- ${line}`),
58
- ];
59
- return lines.join('\n');
60
- };
61
-
62
- export class QaFollowupService {
63
- constructor(private workspaceRepo: WorkspaceRepository, private workspaceRoot: string) {}
64
-
65
- private get cachePath(): string {
66
- return path.join(this.workspaceRoot, '.mcoda', 'qa-containers.json');
67
- }
68
-
69
- private async readCache(): Promise<Record<string, { epicId: string; storyId: string; epicKey: string; storyKey: string }>> {
70
- try {
71
- const raw = await fs.readFile(this.cachePath, 'utf8');
72
- return JSON.parse(raw) as Record<string, { epicId: string; storyId: string; epicKey: string; storyKey: string }>;
73
- } catch {
74
- return {};
75
- }
76
- }
77
-
78
- private async writeCache(data: Record<string, { epicId: string; storyId: string; epicKey: string; storyKey: string }>): Promise<void> {
79
- await PathHelper.ensureDir(path.dirname(this.cachePath));
80
- await fs.writeFile(this.cachePath, JSON.stringify(data, null, 2), 'utf8');
81
- }
82
-
83
- private async ensureBugContainer(projectId: string): Promise<{
84
- epicId: string;
85
- storyId: string;
86
- epicKey: string;
87
- storyKey: string;
88
- }> {
89
- const cache = await this.readCache();
90
- if (cache[projectId]) {
91
- return cache[projectId];
92
- }
93
-
94
- let epic = await this.workspaceRepo.getEpicByKey(projectId, BUG_EPIC_KEY);
95
- if (!epic) {
96
- const epicInsert: EpicInsert = {
97
- projectId,
98
- key: BUG_EPIC_KEY,
99
- title: 'Generic Bugs / Issues',
100
- description: 'Container epic for QA-found bugs and follow-up items.',
101
- storyPointsTotal: null,
102
- priority: 999,
103
- metadata: { tags: ['generic', 'qa-intake'] },
104
- };
105
- const [created] = await this.workspaceRepo.insertEpics([epicInsert], true);
106
- epic = created;
107
- }
108
- let story = await this.workspaceRepo.getStoryByKey(epic.id, BUG_STORY_KEY);
109
- if (!story) {
110
- const storyInsert: StoryInsert = {
111
- projectId,
112
- epicId: epic.id,
113
- key: BUG_STORY_KEY,
114
- title: 'Generic Bugs / Issues',
115
- description: 'Default story container for unmapped QA follow-ups.',
116
- acceptanceCriteria: undefined,
117
- storyPointsTotal: null,
118
- priority: 999,
119
- metadata: { tags: ['generic', 'qa-intake'] },
120
- };
121
- const [created] = await this.workspaceRepo.insertStories([storyInsert], true);
122
- story = created;
123
- }
124
- const resolved = { epicId: epic.id, storyId: story.id, epicKey: epic.key, storyKey: story.key };
125
- cache[projectId] = resolved;
126
- await this.writeCache(cache);
127
- return resolved;
128
- }
129
-
130
- async createFollowupTask(
131
- sourceTask: TaskRow & { storyKey?: string; epicKey?: string },
132
- suggestion: FollowupSuggestion,
133
- ): Promise<{ task: TaskInsert & { id: string }; dependency?: TaskDependencyInsert; comment?: TaskCommentInsert }> {
134
- const projectId = sourceTask.projectId;
135
- const resolved = await this.resolveTargetContainer(sourceTask, suggestion);
136
- const storyKeyBase =
137
- suggestion.storyKeyHint ?? resolved.storyKey ?? sourceTask.storyKey ?? sourceTask.key.split('-t')[0] ?? 'task';
138
- const existingKeys = await this.workspaceRepo.listTaskKeys(resolved.storyId);
139
- const keyGen = createTaskKeyGenerator(storyKeyBase, existingKeys);
140
- const followupKey = keyGen();
141
- const now = new Date().toISOString();
142
- const metadata: Record<string, unknown> = {
143
- tags: ['qa-found', 'auto-created', 'ready-for-ai-dev', 'source=qa', ...(suggestion.tags ?? [])],
144
- source_task: sourceTask.key,
145
- ...(suggestion.components ? { components: suggestion.components } : {}),
146
- ...(suggestion.docLinks ? { doc_links: suggestion.docLinks } : {}),
147
- ...(suggestion.testName ? { failing_test: suggestion.testName } : {}),
148
- ...(suggestion.evidenceUrl ? { evidence_url: suggestion.evidenceUrl } : {}),
149
- };
150
- const envInfo = [
151
- `Task: ${sourceTask.key}`,
152
- `Epic: ${sourceTask.epicKey ?? resolved.epicKey ?? sourceTask.epicId}`,
153
- `Story: ${sourceTask.storyKey ?? resolved.storyKey ?? sourceTask.userStoryId}`,
154
- `Branch/Commit: ${sourceTask.vcsBranch ?? 'n/a'} / ${sourceTask.vcsLastCommitSha ?? 'n/a'}`,
155
- `Components: ${Array.isArray(suggestion.components) && suggestion.components.length ? suggestion.components.join(', ') : Array.isArray((sourceTask.metadata as any)?.components) ? (sourceTask.metadata as any).components.join(', ') : 'n/a'}`,
156
- `Tests: ${suggestion.testName ?? (Array.isArray((sourceTask.metadata as any)?.tests) ? (sourceTask.metadata as any).tests.join(', ') : 'n/a')}`,
157
- `Docs: ${suggestion.docLinks?.join(', ') ?? (Array.isArray((sourceTask.metadata as any)?.doc_links) ? (sourceTask.metadata as any).doc_links.join(', ') : 'n/a')}`,
158
- suggestion.evidenceUrl ? `Evidence: ${suggestion.evidenceUrl}` : '',
159
- suggestion.artifacts && suggestion.artifacts.length ? `Artifacts: ${suggestion.artifacts.join(', ')}` : '',
160
- ].filter(Boolean);
161
- const description = FOLLOWUP_DESCRIPTION_TEMPLATE(
162
- suggestion.title ?? `Follow-up for ${sourceTask.key}`,
163
- suggestion.description ?? 'Actual behavior not provided.',
164
- 'Expected behavior per acceptance criteria/OpenAPI.',
165
- envInfo,
166
- );
167
- const taskInsert: TaskInsert = {
168
- projectId,
169
- epicId: resolved.epicId,
170
- userStoryId: resolved.storyId,
171
- key: followupKey,
172
- title: suggestion.title || `Follow-up for ${sourceTask.key}`,
173
- description,
174
- type: suggestion.type ?? 'bug',
175
- status: 'not_started',
176
- storyPoints: suggestion.storyPoints ?? 1,
177
- priority: suggestion.priority ?? 99,
178
- metadata,
179
- };
180
- const [createdTask] = await this.workspaceRepo.insertTasks([taskInsert], true);
181
- const dependency: TaskDependencyInsert = {
182
- taskId: sourceTask.id,
183
- dependsOnTaskId: createdTask.id,
184
- relationType: 'blocks',
185
- };
186
- await this.workspaceRepo.insertTaskDependencies([dependency], true);
187
- const sourceComment: TaskCommentInsert = {
188
- taskId: sourceTask.id,
189
- sourceCommand: 'qa-tasks',
190
- authorType: 'agent',
191
- category: 'qa_followup',
192
- body: `Created follow-up task ${createdTask.key} for QA findings.`,
193
- metadata: { followupTaskKey: createdTask.key },
194
- createdAt: now,
195
- };
196
- await this.workspaceRepo.createTaskComment(sourceComment);
197
- const followupComment: TaskCommentInsert = {
198
- taskId: createdTask.id,
199
- sourceCommand: 'qa-tasks',
200
- authorType: 'agent',
201
- category: 'qa_origin',
202
- body: `Created automatically from QA of ${sourceTask.key}.`,
203
- metadata: { sourceTaskKey: sourceTask.key },
204
- createdAt: now,
205
- };
206
- await this.workspaceRepo.createTaskComment(followupComment);
207
- return { task: { ...taskInsert, id: createdTask.id }, dependency, comment: sourceComment };
208
- }
209
-
210
- private async resolveTargetContainer(
211
- sourceTask: TaskRow & { storyKey?: string; epicKey?: string },
212
- suggestion: FollowupSuggestion,
213
- ): Promise<{ epicId: string; storyId: string; storyKey?: string; epicKey?: string }> {
214
- const projectId = sourceTask.projectId;
215
- if (suggestion.relatedTaskKey) {
216
- const related = await this.workspaceRepo.getTaskByKey(suggestion.relatedTaskKey);
217
- if (related) {
218
- return {
219
- epicId: related.epicId,
220
- storyId: related.userStoryId,
221
- storyKey: related.key.split('-t')[0] ?? related.key,
222
- };
223
- }
224
- }
225
- if (suggestion.storyKeyHint) {
226
- const story = await this.workspaceRepo.getStoryByProjectAndKey(projectId, suggestion.storyKeyHint);
227
- if (story) {
228
- return { epicId: story.epicId, storyId: story.id, storyKey: story.key };
229
- }
230
- }
231
- if (Array.isArray(suggestion.docLinks)) {
232
- for (const link of suggestion.docLinks) {
233
- const storyKeyCandidate = link.match(/US-[A-Za-z0-9]+/i)?.[0];
234
- if (storyKeyCandidate) {
235
- const story = await this.workspaceRepo.getStoryByProjectAndKey(projectId, storyKeyCandidate.toUpperCase());
236
- if (story) return { epicId: story.epicId, storyId: story.id, storyKey: story.key };
237
- }
238
- const epicKeyCandidate = link.match(/EPIC-[A-Za-z0-9]+/i)?.[0];
239
- if (epicKeyCandidate) {
240
- const epic = await this.workspaceRepo.getEpicByKey(projectId, epicKeyCandidate.toUpperCase());
241
- if (epic) {
242
- return {
243
- epicId: epic.id,
244
- epicKey: epic.key,
245
- storyId: sourceTask.userStoryId ?? epic.id,
246
- storyKey: sourceTask.storyKey ?? epic.key,
247
- };
248
- }
249
- }
250
- }
251
- }
252
- const branch = sourceTask.vcsBranch ?? '';
253
- const storyMatch = branch.match(/US-[A-Za-z0-9]+/i);
254
- if (storyMatch) {
255
- const story = await this.workspaceRepo.getStoryByProjectAndKey(projectId, storyMatch[0].toUpperCase());
256
- if (story) {
257
- return { epicId: story.epicId, storyId: story.id, storyKey: story.key };
258
- }
259
- }
260
- const epicMatch = branch.match(/EPIC-[A-Za-z0-9]+/i);
261
- if (epicMatch) {
262
- const epic = await this.workspaceRepo.getEpicByKey(projectId, epicMatch[0].toUpperCase());
263
- if (epic) {
264
- return {
265
- epicId: epic.id,
266
- epicKey: epic.key,
267
- storyId: sourceTask.userStoryId ?? epic.id,
268
- storyKey: sourceTask.storyKey ?? suggestion.storyKeyHint ?? epic.key,
269
- };
270
- }
271
- }
272
- if (suggestion.epicKeyHint) {
273
- const epic = await this.workspaceRepo.getEpicByKey(projectId, suggestion.epicKeyHint);
274
- if (epic) {
275
- return {
276
- epicId: epic.id,
277
- epicKey: epic.key,
278
- storyId: sourceTask.userStoryId ?? epic.id,
279
- storyKey: sourceTask.storyKey ?? suggestion.storyKeyHint ?? epic.key,
280
- };
281
- }
282
- }
283
- if (sourceTask.epicId && sourceTask.userStoryId) {
284
- return { epicId: sourceTask.epicId, storyId: sourceTask.userStoryId, storyKey: sourceTask.storyKey, epicKey: sourceTask.epicKey };
285
- }
286
- const container = await this.ensureBugContainer(projectId);
287
- return { epicId: container.epicId, storyId: container.storyId, storyKey: container.storyKey, epicKey: container.epicKey };
288
- }
289
- }
@@ -1,160 +0,0 @@
1
- import path from 'node:path';
2
- import { TaskRow } from '@mcoda/db';
3
- import { PathHelper } from '@mcoda/shared';
4
- import { QaProfile } from '@mcoda/shared/qa/QaProfile.js';
5
- import fs from 'node:fs/promises';
6
-
7
- export interface QaProfileResolutionOptions {
8
- profileName?: string;
9
- level?: string;
10
- defaultLevel?: string;
11
- }
12
-
13
- export class QaProfileService {
14
- private cache?: QaProfile[];
15
- private routingCache?: {
16
- defaultProfile?: string;
17
- levels?: Record<string, string>;
18
- taskTypes?: Record<string, string>;
19
- tags?: Record<string, string>;
20
- };
21
-
22
- constructor(private workspaceRoot: string) {}
23
-
24
- private get profilePath(): string {
25
- return path.join(this.workspaceRoot, '.mcoda', 'qa-profiles.json');
26
- }
27
-
28
- private get workspaceConfigPath(): string {
29
- return path.join(this.workspaceRoot, '.mcoda', 'config.json');
30
- }
31
-
32
- private async getConfiguredDefaultProfileName(): Promise<string | undefined> {
33
- try {
34
- const raw = await fs.readFile(this.workspaceConfigPath, 'utf8');
35
- const parsed = JSON.parse(raw);
36
- return parsed?.qa?.defaultProfile ?? parsed?.qa?.default_profile ?? parsed?.qaDefaultProfile;
37
- } catch {
38
- return undefined;
39
- }
40
- }
41
-
42
- private async getRoutingConfig(): Promise<{
43
- defaultProfile?: string;
44
- levels?: Record<string, string>;
45
- taskTypes?: Record<string, string>;
46
- tags?: Record<string, string>;
47
- }> {
48
- if (this.routingCache) return this.routingCache;
49
- try {
50
- const raw = await fs.readFile(this.workspaceConfigPath, 'utf8');
51
- const parsed = JSON.parse(raw);
52
- const qa = parsed?.qa ?? {};
53
- this.routingCache = {
54
- defaultProfile: qa.defaultProfile ?? qa.default_profile ?? qa.default,
55
- levels: qa.routing?.levels ?? qa.routing?.level ?? qa.levelRouting ?? undefined,
56
- taskTypes: qa.routing?.taskTypes ?? qa.routing?.types ?? qa.typeRouting ?? undefined,
57
- tags: qa.routing?.tags ?? undefined,
58
- };
59
- return this.routingCache;
60
- } catch {
61
- this.routingCache = {};
62
- return this.routingCache;
63
- }
64
- }
65
-
66
- async loadProfiles(): Promise<QaProfile[]> {
67
- if (this.cache) return this.cache;
68
- await PathHelper.ensureDir(path.join(this.workspaceRoot, '.mcoda'));
69
- try {
70
- const raw = await fs.readFile(this.profilePath, 'utf8');
71
- const parsed = JSON.parse(raw);
72
- if (Array.isArray(parsed)) {
73
- this.cache = parsed as QaProfile[];
74
- return this.cache;
75
- }
76
- if (Array.isArray((parsed as any)?.profiles)) {
77
- this.cache = (parsed as any).profiles as QaProfile[];
78
- return this.cache;
79
- }
80
- this.cache = [];
81
- return this.cache;
82
- } catch (error: any) {
83
- if (error?.code === 'ENOENT') {
84
- this.cache = [];
85
- return this.cache;
86
- }
87
- throw error;
88
- }
89
- }
90
-
91
- async resolveProfileForTask(task: TaskRow & { metadata?: any }, options: QaProfileResolutionOptions = {}): Promise<QaProfile | undefined> {
92
- const profiles = await this.loadProfiles();
93
- if (!profiles.length) return undefined;
94
- const envProfile = process.env.MCODA_QA_PROFILE;
95
- const routing = await this.getRoutingConfig();
96
- const configuredDefault = options.profileName ?? envProfile ?? (await this.getConfiguredDefaultProfileName()) ?? routing.defaultProfile;
97
- const pickByName = (name: string | undefined): QaProfile | undefined => {
98
- if (!name) return undefined;
99
- const match = profiles.find((p) => p.name === name);
100
- if (!match) {
101
- throw new Error(`QA profile not found: ${name}`);
102
- }
103
- return match;
104
- };
105
- const explicit = pickByName(configuredDefault);
106
- if (explicit) {
107
- return explicit;
108
- }
109
- const taskTags: string[] = Array.isArray((task.metadata as any)?.tags)
110
- ? ((task.metadata as any).tags as string[]).map((t) => t.toLowerCase())
111
- : [];
112
- let candidates = profiles.filter((profile) => {
113
- const typeMatch =
114
- !profile.matcher?.task_types ||
115
- profile.matcher.task_types.length === 0 ||
116
- (task.type ? profile.matcher.task_types.includes(task.type) : false);
117
- const tagMatch =
118
- !profile.matcher?.tags ||
119
- profile.matcher.tags.length === 0 ||
120
- profile.matcher.tags.some((tag) => taskTags.includes(tag.toLowerCase()));
121
- return typeMatch && tagMatch;
122
- });
123
- if (routing) {
124
- const levelRoute = options.level && routing.levels ? routing.levels[options.level] : undefined;
125
- const typeRoute = task.type && routing.taskTypes ? routing.taskTypes[task.type] : undefined;
126
- const tagRoute =
127
- routing.tags && taskTags.length
128
- ? taskTags.map((tag) => routing.tags?.[tag]).find((name): name is string => Boolean(name))
129
- : undefined;
130
- const routedName = levelRoute ?? typeRoute ?? tagRoute;
131
- const routed = pickByName(routedName);
132
- if (routed) return routed;
133
- }
134
- const targetLevel = options.level ?? options.defaultLevel;
135
- if (targetLevel) {
136
- const levelMatches = candidates.filter((p) => (p.level ?? (p as any).qa_level) === targetLevel);
137
- if (levelMatches.length === 1) return levelMatches[0];
138
- if (levelMatches.length > 1) candidates = levelMatches;
139
- }
140
- if (candidates.length === 1) return candidates[0];
141
- if (candidates.length > 1) {
142
- const defaults = candidates.filter((p) => p.default);
143
- if (defaults.length === 1) return defaults[0];
144
- if (defaults.length > 1) {
145
- throw new Error('Multiple default QA profiles configured; specify --profile.');
146
- }
147
- throw new Error(
148
- `Multiple QA profiles match task (${task.key}); please specify --profile. Candidates: ${candidates
149
- .map((p) => p.name)
150
- .join(', ')}`,
151
- );
152
- }
153
- const defaults = profiles.filter((p) => p.default);
154
- if (defaults.length === 1) return defaults[0];
155
- if (defaults.length > 1) {
156
- throw new Error('Multiple default QA profiles configured; please specify --profile.');
157
- }
158
- return undefined;
159
- }
160
- }