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,408 +0,0 @@
1
- import path from "node:path";
2
- import { RefineTasksService, WorkspaceResolver } from "@mcoda/core";
3
- import type { RefineStrategy } from "@mcoda/shared";
4
-
5
- interface ParsedRefineArgs {
6
- workspaceRoot?: string;
7
- projectKey?: string;
8
- epicKey?: string;
9
- storyKey?: string;
10
- taskKeys: string[];
11
- statusFilter: string[];
12
- maxTasks?: number;
13
- strategy?: RefineStrategy;
14
- agentName?: string;
15
- agentStream: boolean;
16
- fromDb: boolean;
17
- dryRun: boolean;
18
- apply: boolean;
19
- resume: boolean;
20
- runAll: boolean;
21
- batchSize?: number;
22
- maxBatches?: number;
23
- json: boolean;
24
- planIn?: string;
25
- planOut?: string;
26
- jobId?: string;
27
- }
28
-
29
- const usage = `mcoda refine-tasks --project <PROJECT_KEY> [--workspace-root <PATH>] [--epic <EPIC_KEY>] [--story <STORY_KEY>] [--task <TASK_KEY> ...] [--status <STATUS>] [--max-tasks N] [--strategy split|merge|enrich|estimate|auto] [--agent <NAME>] [--agent-stream [true|false]] [--from-db [true|false]] [--dry-run] [--apply] [--resume|--skip-refined] [--run-all] [--batch-size N] [--max-batches N] [--plan-in <PATH>] [--plan-out <PATH>] [--json]`;
30
-
31
- const parseBooleanFlag = (value: string | undefined, defaultValue: boolean): boolean => {
32
- if (value === undefined) return defaultValue;
33
- const normalized = value.toLowerCase();
34
- if (["false", "0", "no"].includes(normalized)) return false;
35
- if (["true", "1", "yes"].includes(normalized)) return true;
36
- return defaultValue;
37
- };
38
-
39
- const parseCsv = (value: string | undefined): string[] => {
40
- if (!value) return [];
41
- return value
42
- .split(",")
43
- .map((v) => v.trim())
44
- .filter(Boolean);
45
- };
46
-
47
- const formatCounts = (ops: any[]): string => {
48
- const counts = ops.reduce<Record<string, number>>((acc, op) => {
49
- acc[op.op] = (acc[op.op] ?? 0) + 1;
50
- return acc;
51
- }, {});
52
- return Object.entries(counts)
53
- .map(([op, count]) => `${op}: ${count}`)
54
- .join(", ");
55
- };
56
-
57
- export const parseRefineTasksArgs = (argv: string[]): ParsedRefineArgs => {
58
- let workspaceRoot: string | undefined;
59
- let projectKey: string | undefined;
60
- let epicKey: string | undefined;
61
- let storyKey: string | undefined;
62
- const taskKeys: string[] = [];
63
- const statusFilter: string[] = [];
64
- let maxTasks: number | undefined;
65
- let strategy: RefineStrategy | undefined;
66
- let agentName: string | undefined;
67
- let agentStream: boolean | undefined;
68
- let fromDb: boolean | undefined;
69
- let dryRun = false;
70
- let apply = false;
71
- let resume = false;
72
- let runAll = false;
73
- let batchSize: number | undefined;
74
- let maxBatches: number | undefined;
75
- let json = false;
76
- let planIn: string | undefined;
77
- let planOut: string | undefined;
78
- let jobId: string | undefined;
79
-
80
- for (let i = 0; i < argv.length; i += 1) {
81
- const arg = argv[i];
82
- if (arg.startsWith("--status=")) {
83
- const [, raw] = arg.split("=", 2);
84
- statusFilter.push(...parseCsv(raw));
85
- continue;
86
- }
87
- if (arg.startsWith("--task=")) {
88
- const [, raw] = arg.split("=", 2);
89
- if (raw) taskKeys.push(raw);
90
- continue;
91
- }
92
- if (arg.startsWith("--agent-stream=")) {
93
- const [, raw] = arg.split("=", 2);
94
- agentStream = parseBooleanFlag(raw, true);
95
- continue;
96
- }
97
- if (arg.startsWith("--from-db=")) {
98
- const [, raw] = arg.split("=", 2);
99
- fromDb = parseBooleanFlag(raw, true);
100
- continue;
101
- }
102
- if (arg.startsWith("--apply=")) {
103
- const [, raw] = arg.split("=", 2);
104
- apply = parseBooleanFlag(raw, true);
105
- continue;
106
- }
107
- if (arg.startsWith("--resume=")) {
108
- const [, raw] = arg.split("=", 2);
109
- resume = parseBooleanFlag(raw, true);
110
- continue;
111
- }
112
- if (arg.startsWith("--skip-refined=")) {
113
- const [, raw] = arg.split("=", 2);
114
- resume = parseBooleanFlag(raw, true);
115
- continue;
116
- }
117
- if (arg.startsWith("--run-all=")) {
118
- const [, raw] = arg.split("=", 2);
119
- runAll = parseBooleanFlag(raw, true);
120
- continue;
121
- }
122
- switch (arg) {
123
- case "--workspace-root":
124
- workspaceRoot = argv[i + 1] ? path.resolve(argv[i + 1]) : undefined;
125
- i += 1;
126
- break;
127
- case "--project":
128
- case "--project-key":
129
- projectKey = argv[i + 1];
130
- i += 1;
131
- break;
132
- case "--epic":
133
- epicKey = argv[i + 1];
134
- i += 1;
135
- break;
136
- case "--story":
137
- storyKey = argv[i + 1];
138
- i += 1;
139
- break;
140
- case "--task":
141
- if (argv[i + 1]) {
142
- taskKeys.push(argv[i + 1]);
143
- i += 1;
144
- }
145
- break;
146
- case "--status":
147
- statusFilter.push(...parseCsv(argv[i + 1]));
148
- i += 1;
149
- break;
150
- case "--max-tasks":
151
- maxTasks = Number(argv[i + 1]);
152
- i += 1;
153
- break;
154
- case "--strategy":
155
- strategy = argv[i + 1] as RefineStrategy;
156
- i += 1;
157
- break;
158
- case "--agent":
159
- agentName = argv[i + 1];
160
- i += 1;
161
- break;
162
- case "--agent-stream": {
163
- const next = argv[i + 1];
164
- if (next && !next.startsWith("--")) {
165
- agentStream = parseBooleanFlag(next, true);
166
- i += 1;
167
- } else {
168
- agentStream = true;
169
- }
170
- break;
171
- }
172
- case "--from-db": {
173
- const next = argv[i + 1];
174
- if (next && !next.startsWith("--")) {
175
- fromDb = parseBooleanFlag(next, true);
176
- i += 1;
177
- } else {
178
- fromDb = true;
179
- }
180
- break;
181
- }
182
- case "--dry-run":
183
- dryRun = true;
184
- break;
185
- case "--apply":
186
- apply = true;
187
- break;
188
- case "--resume":
189
- case "--skip-refined":
190
- resume = true;
191
- break;
192
- case "--run-all":
193
- runAll = true;
194
- break;
195
- case "--batch-size":
196
- batchSize = Number(argv[i + 1]);
197
- i += 1;
198
- break;
199
- case "--max-batches":
200
- maxBatches = Number(argv[i + 1]);
201
- i += 1;
202
- break;
203
- case "--json":
204
- json = true;
205
- break;
206
- case "--plan-in":
207
- planIn = argv[i + 1] ? path.resolve(argv[i + 1]) : undefined;
208
- i += 1;
209
- break;
210
- case "--plan-out":
211
- planOut = argv[i + 1] ? path.resolve(argv[i + 1]) : undefined;
212
- i += 1;
213
- break;
214
- case "--job-id":
215
- jobId = argv[i + 1];
216
- i += 1;
217
- break;
218
- case "--help":
219
- case "-h":
220
- // eslint-disable-next-line no-console
221
- console.log(usage);
222
- process.exit(0);
223
- break;
224
- default:
225
- break;
226
- }
227
- }
228
-
229
- return {
230
- workspaceRoot,
231
- projectKey,
232
- epicKey,
233
- storyKey,
234
- taskKeys,
235
- statusFilter,
236
- maxTasks: Number.isFinite(maxTasks) ? maxTasks : undefined,
237
- strategy,
238
- agentName,
239
- agentStream: agentStream ?? true,
240
- fromDb: fromDb ?? true,
241
- dryRun,
242
- apply,
243
- resume,
244
- runAll,
245
- batchSize: Number.isFinite(batchSize) ? batchSize : undefined,
246
- maxBatches: Number.isFinite(maxBatches) ? maxBatches : undefined,
247
- json,
248
- planIn,
249
- planOut,
250
- jobId,
251
- };
252
- };
253
-
254
- export class RefineTasksCommand {
255
- static async run(argv: string[]): Promise<void> {
256
- const parsed = parseRefineTasksArgs(argv);
257
- if (!parsed.projectKey) {
258
- // eslint-disable-next-line no-console
259
- console.error("refine-tasks requires --project <PROJECT_KEY>");
260
- process.exitCode = 1;
261
- return;
262
- }
263
- if (parsed.apply && parsed.dryRun) {
264
- // eslint-disable-next-line no-console
265
- console.error("refine-tasks: --apply cannot be used with --dry-run");
266
- process.exitCode = 1;
267
- return;
268
- }
269
- if ((parsed.runAll || parsed.resume) && !parsed.apply) {
270
- // eslint-disable-next-line no-console
271
- console.error("refine-tasks: --run-all/--resume requires --apply (needed for durable progress tracking)");
272
- process.exitCode = 1;
273
- return;
274
- }
275
- const workspace = await WorkspaceResolver.resolveWorkspace({
276
- cwd: process.cwd(),
277
- explicitWorkspace: parsed.workspaceRoot,
278
- });
279
- const service = await RefineTasksService.create(workspace);
280
- try {
281
- const baseRequest = {
282
- workspace,
283
- projectKey: parsed.projectKey,
284
- epicKey: parsed.epicKey,
285
- storyKey: parsed.storyKey,
286
- taskKeys: parsed.taskKeys.length ? parsed.taskKeys : undefined,
287
- statusFilter: parsed.statusFilter.length ? parsed.statusFilter : undefined,
288
- strategy: parsed.strategy ?? "auto",
289
- agentName: parsed.agentName,
290
- agentStream: parsed.agentStream,
291
- fromDb: parsed.fromDb,
292
- dryRun: parsed.dryRun,
293
- planInPath: parsed.planIn,
294
- planOutPath: parsed.planOut,
295
- jobId: parsed.jobId,
296
- apply: parsed.apply,
297
- excludeAlreadyRefined: parsed.runAll || parsed.resume,
298
- allowEmptySelection: parsed.runAll || parsed.resume,
299
- } as const;
300
-
301
- if (parsed.runAll) {
302
- const batchSize = parsed.batchSize ?? parsed.maxTasks ?? 250;
303
- const maxBatches = parsed.maxBatches ?? Number.POSITIVE_INFINITY;
304
- const batches: Array<{
305
- batch: number;
306
- jobId: string;
307
- commandRunId: string;
308
- tasksProcessed: number;
309
- tasksAffected: number;
310
- operations: number;
311
- }> = [];
312
- let totalProcessed = 0;
313
- let totalAffected = 0;
314
-
315
- for (let batch = 1; batch <= maxBatches; batch += 1) {
316
- const result = await service.refineTasks({
317
- ...baseRequest,
318
- maxTasks: batchSize,
319
- });
320
- const tasksProcessed = result.summary?.tasksProcessed ?? 0;
321
- const tasksAffected = result.summary?.tasksAffected ?? 0;
322
- const operations = result.plan.operations.length;
323
-
324
- if (tasksProcessed === 0 || operations === 0) break;
325
-
326
- totalProcessed += tasksProcessed;
327
- totalAffected += tasksAffected;
328
- batches.push({
329
- batch,
330
- jobId: result.jobId,
331
- commandRunId: result.commandRunId,
332
- tasksProcessed,
333
- tasksAffected,
334
- operations,
335
- });
336
-
337
- if (!parsed.json) {
338
- // eslint-disable-next-line no-console
339
- console.log(
340
- `Batch ${batch}: Job ${result.jobId}, Command Run ${result.commandRunId}\n` +
341
- `Processed: ${tasksProcessed}, affected: ${tasksAffected}, operations: ${operations}`,
342
- );
343
- }
344
- }
345
-
346
- if (parsed.json) {
347
- // eslint-disable-next-line no-console
348
- console.log(JSON.stringify({ status: "completed", totalProcessed, totalAffected, batches }, null, 2));
349
- } else {
350
- // eslint-disable-next-line no-console
351
- console.log(`Done. Total processed: ${totalProcessed}, total affected: ${totalAffected}`);
352
- }
353
- return;
354
- }
355
-
356
- const result = await service.refineTasks({
357
- ...baseRequest,
358
- maxTasks: parsed.maxTasks,
359
- });
360
-
361
- if (parsed.json) {
362
- // eslint-disable-next-line no-console
363
- console.log(
364
- JSON.stringify(
365
- {
366
- status: result.applied ? "applied" : "dry_run",
367
- summary: result.summary,
368
- plan: result.plan,
369
- warnings: result.plan.warnings ?? [],
370
- },
371
- null,
372
- 2,
373
- ),
374
- );
375
- } else {
376
- const opSummary = formatCounts(result.plan.operations);
377
- const summaryLines = [
378
- `Job: ${result.jobId}, Command Run: ${result.commandRunId}`,
379
- `Applied: ${result.applied ? "yes" : "no (dry run)"}`,
380
- `Operations: ${result.plan.operations.length}${opSummary ? ` (${opSummary})` : ""}`,
381
- result.summary
382
- ? `Tasks processed: ${result.summary.tasksProcessed}, affected: ${result.summary.tasksAffected}, story points delta: ${result.summary.storyPointsDelta ?? 0}`
383
- : undefined,
384
- result.createdTasks?.length ? `Created: ${result.createdTasks.join(", ")}` : undefined,
385
- result.updatedTasks?.length ? `Updated: ${result.updatedTasks.join(", ")}` : undefined,
386
- result.cancelledTasks?.length ? `Cancelled: ${result.cancelledTasks.join(", ")}` : undefined,
387
- ].filter(Boolean);
388
- // eslint-disable-next-line no-console
389
- console.log(summaryLines.join("\n"));
390
- if (result.plan.warnings && result.plan.warnings.length > 0) {
391
- // eslint-disable-next-line no-console
392
- console.warn(result.plan.warnings.map((w) => `! ${w}`).join("\n"));
393
- }
394
- }
395
- } catch (error) {
396
- const message = error instanceof Error ? error.message : String(error);
397
- // eslint-disable-next-line no-console
398
- console.error(`refine-tasks failed: ${message}`);
399
- process.exitCode = 1;
400
- } finally {
401
- try {
402
- await service.close();
403
- } catch {
404
- // ignore close-time errors (e.g., db already closed)
405
- }
406
- }
407
- }
408
- }
@@ -1,262 +0,0 @@
1
- import path from "node:path";
2
- import { CodeReviewService, WorkspaceResolver } from "@mcoda/core";
3
-
4
- interface ParsedArgs {
5
- workspaceRoot?: string;
6
- projectKey?: string;
7
- epicKey?: string;
8
- storyKey?: string;
9
- taskKeys: string[];
10
- statusFilter: string[];
11
- baseRef?: string;
12
- dryRun: boolean;
13
- resumeJobId?: string;
14
- limit?: number;
15
- agentName?: string;
16
- agentStream?: boolean;
17
- json: boolean;
18
- }
19
-
20
- const usage = `mcoda code-review \\
21
- [--workspace-root <PATH>] \\
22
- [--project <PROJECT_KEY>] \\
23
- [--task <TASK_KEY> ... | --epic <EPIC_KEY> | --story <STORY_KEY>] \\
24
- [--status ready_to_review] \\
25
- [--base <BRANCH>] \\
26
- [--dry-run] \\
27
- [--resume <JOB_ID>] \\
28
- [--limit N] \\
29
- [--agent <NAME>] \\
30
- [--agent-stream <true|false>] \\
31
- [--json]
32
-
33
- Runs AI code review on task branches. Side effects: writes task_comments/task_reviews, may spawn follow-up tasks for critical findings, updates task state (unless --dry-run), records jobs/command_runs/task_runs/token_usage, saves diffs/context under .mcoda/jobs/<job_id>/review/. Default status filter: ready_to_review. JSON output: { job, tasks, errors, warnings }.`;
34
-
35
- const parseBooleanFlag = (value: string | undefined, defaultValue: boolean): boolean => {
36
- if (value === undefined) return defaultValue;
37
- const normalized = value.toLowerCase();
38
- if (["false", "0", "no"].includes(normalized)) return false;
39
- if (["true", "1", "yes"].includes(normalized)) return true;
40
- return defaultValue;
41
- };
42
-
43
- const parseCsv = (value: string | undefined): string[] => {
44
- if (!value) return [];
45
- return value
46
- .split(",")
47
- .map((v) => v.trim())
48
- .filter(Boolean);
49
- };
50
-
51
- export const parseCodeReviewArgs = (argv: string[]): ParsedArgs => {
52
- let workspaceRoot: string | undefined;
53
- let projectKey: string | undefined;
54
- let epicKey: string | undefined;
55
- let storyKey: string | undefined;
56
- const taskKeys: string[] = [];
57
- const statusFilter: string[] = [];
58
- let baseRef: string | undefined;
59
- let dryRun = false;
60
- let resumeJobId: string | undefined;
61
- let limit: number | undefined;
62
- let agentName: string | undefined;
63
- let agentStream: boolean | undefined;
64
- let json = false;
65
-
66
- for (let i = 0; i < argv.length; i += 1) {
67
- const arg = argv[i];
68
- if (arg.startsWith("--status=")) {
69
- const [, raw] = arg.split("=", 2);
70
- statusFilter.push(...parseCsv(raw));
71
- continue;
72
- }
73
- if (arg.startsWith("--task=")) {
74
- const [, raw] = arg.split("=", 2);
75
- if (raw) taskKeys.push(raw);
76
- continue;
77
- }
78
- if (arg.startsWith("--agent-stream=")) {
79
- const [, raw] = arg.split("=", 2);
80
- agentStream = parseBooleanFlag(raw, true);
81
- continue;
82
- }
83
- switch (arg) {
84
- case "--workspace":
85
- case "--workspace-root":
86
- workspaceRoot = argv[i + 1] ? path.resolve(argv[i + 1]) : undefined;
87
- i += 1;
88
- break;
89
- case "--project":
90
- case "--project-key":
91
- projectKey = argv[i + 1];
92
- i += 1;
93
- break;
94
- case "--epic":
95
- epicKey = argv[i + 1];
96
- i += 1;
97
- break;
98
- case "--story":
99
- storyKey = argv[i + 1];
100
- i += 1;
101
- break;
102
- case "--task":
103
- if (argv[i + 1]) {
104
- taskKeys.push(argv[i + 1]);
105
- i += 1;
106
- }
107
- break;
108
- case "--status":
109
- statusFilter.push(...parseCsv(argv[i + 1]));
110
- i += 1;
111
- break;
112
- case "--base":
113
- baseRef = argv[i + 1];
114
- i += 1;
115
- break;
116
- case "--dry-run":
117
- dryRun = true;
118
- break;
119
- case "--resume":
120
- resumeJobId = argv[i + 1];
121
- i += 1;
122
- break;
123
- case "--limit":
124
- limit = Number(argv[i + 1]);
125
- i += 1;
126
- break;
127
- case "--agent":
128
- agentName = argv[i + 1];
129
- i += 1;
130
- break;
131
- case "--agent-stream": {
132
- const next = argv[i + 1];
133
- if (next && !next.startsWith("--")) {
134
- agentStream = parseBooleanFlag(next, true);
135
- i += 1;
136
- } else {
137
- agentStream = true;
138
- }
139
- break;
140
- }
141
- case "--json":
142
- json = true;
143
- break;
144
- case "--help":
145
- case "-h":
146
- // eslint-disable-next-line no-console
147
- console.log(usage);
148
- process.exit(0);
149
- break;
150
- default:
151
- break;
152
- }
153
- }
154
-
155
- if (statusFilter.length === 0) {
156
- statusFilter.push("ready_to_review");
157
- }
158
-
159
- return {
160
- workspaceRoot,
161
- projectKey,
162
- epicKey,
163
- storyKey,
164
- taskKeys,
165
- statusFilter,
166
- baseRef,
167
- dryRun,
168
- resumeJobId,
169
- limit: Number.isFinite(limit) ? limit : undefined,
170
- agentName,
171
- agentStream: agentStream ?? true,
172
- json,
173
- };
174
- };
175
-
176
- export class CodeReviewCommand {
177
- static async run(argv: string[]): Promise<void> {
178
- const parsed = parseCodeReviewArgs(argv);
179
- const workspace = await WorkspaceResolver.resolveWorkspace({
180
- cwd: process.cwd(),
181
- explicitWorkspace: parsed.workspaceRoot,
182
- });
183
- const service = await CodeReviewService.create(workspace);
184
- try {
185
- const result = await service.reviewTasks({
186
- workspace,
187
- projectKey: parsed.projectKey,
188
- epicKey: parsed.epicKey,
189
- storyKey: parsed.storyKey,
190
- taskKeys: parsed.taskKeys.length ? parsed.taskKeys : undefined,
191
- statusFilter: parsed.statusFilter,
192
- baseRef: parsed.baseRef,
193
- dryRun: parsed.dryRun,
194
- resumeJobId: parsed.resumeJobId,
195
- limit: parsed.limit,
196
- agentName: parsed.agentName,
197
- agentStream: parsed.agentStream,
198
- });
199
-
200
- if (parsed.json) {
201
- // eslint-disable-next-line no-console
202
- console.log(
203
- JSON.stringify(
204
- {
205
- job: { id: result.jobId, commandRunId: result.commandRunId },
206
- tasks: result.tasks.map((t) => ({
207
- taskId: t.taskId,
208
- taskKey: t.taskKey,
209
- decision: t.decision,
210
- statusBefore: t.statusBefore,
211
- statusAfter: t.statusAfter,
212
- findings: t.findings,
213
- error: t.error,
214
- followupTasks: t.followupTasks,
215
- })),
216
- errors: result.tasks.filter((t) => t.error).map((t) => ({ taskId: t.taskId, taskKey: t.taskKey, error: t.error })),
217
- warnings: result.warnings,
218
- },
219
- null,
220
- 2,
221
- ),
222
- );
223
- return;
224
- }
225
-
226
- const lines = result.tasks.map((t) => {
227
- const decision = t.decision ?? "error";
228
- const severityCounts = (t.findings ?? []).reduce<Record<string, number>>((acc, f) => {
229
- const sev = (f.severity ?? "unknown").toUpperCase();
230
- acc[sev] = (acc[sev] ?? 0) + 1;
231
- return acc;
232
- }, {});
233
- const severitySummary = Object.entries(severityCounts)
234
- .map(([s, c]) => `${s}:${c}`)
235
- .join(" ");
236
- const findingsCount = t.findings?.length ?? 0;
237
- const followups = t.followupTasks && t.followupTasks.length ? `, followups=[${t.followupTasks.map((f) => f.taskKey).join(", ")}]` : "";
238
- const statusChange = t.statusAfter ? `${t.statusBefore} -> ${t.statusAfter}` : t.statusBefore;
239
- return `${t.taskKey}: ${decision} (${statusChange}), findings=${findingsCount}${severitySummary ? ` (${severitySummary})` : ""}${
240
- t.error ? `, error=${t.error}` : ""
241
- }${followups}`;
242
- });
243
- const summary = [
244
- `Job: ${result.jobId}`,
245
- `Artifacts: ${path.join(workspace.mcodaDir, "jobs", result.jobId, "review")}`,
246
- ...lines,
247
- ];
248
- if (result.warnings.length) {
249
- summary.push(`Warnings: ${result.warnings.join("; ")}`);
250
- }
251
- // eslint-disable-next-line no-console
252
- console.log(summary.join("\n"));
253
- } catch (error) {
254
- const message = error instanceof Error ? error.message : String(error);
255
- // eslint-disable-next-line no-console
256
- console.error(`code-review failed: ${message}`);
257
- process.exitCode = 1;
258
- } finally {
259
- await service.close();
260
- }
261
- }
262
- }
File without changes