reviewflow 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (914) hide show
  1. package/CHANGELOG.md +271 -0
  2. package/LICENSE +21 -0
  3. package/README.md +209 -0
  4. package/dist/claude/invoker.d.ts +3 -0
  5. package/dist/claude/invoker.d.ts.map +1 -0
  6. package/dist/claude/invoker.js +4 -0
  7. package/dist/claude/invoker.js.map +1 -0
  8. package/dist/claude/progressParser.d.ts +3 -0
  9. package/dist/claude/progressParser.d.ts.map +1 -0
  10. package/dist/claude/progressParser.js +4 -0
  11. package/dist/claude/progressParser.js.map +1 -0
  12. package/dist/cli/parseCliArgs.d.ts +6 -0
  13. package/dist/cli/parseCliArgs.d.ts.map +1 -0
  14. package/dist/cli/parseCliArgs.js +13 -0
  15. package/dist/cli/parseCliArgs.js.map +1 -0
  16. package/dist/config/loader.d.ts +3 -0
  17. package/dist/config/loader.d.ts.map +1 -0
  18. package/dist/config/loader.js +4 -0
  19. package/dist/config/loader.js.map +1 -0
  20. package/dist/config/projectConfig.d.ts +30 -0
  21. package/dist/config/projectConfig.d.ts.map +1 -0
  22. package/dist/config/projectConfig.js +89 -0
  23. package/dist/config/projectConfig.js.map +1 -0
  24. package/dist/entities/diffMetadata/diffMetadata.gateway.d.ts +5 -0
  25. package/dist/entities/diffMetadata/diffMetadata.gateway.d.ts.map +1 -0
  26. package/dist/entities/diffMetadata/diffMetadata.gateway.js +2 -0
  27. package/dist/entities/diffMetadata/diffMetadata.gateway.js.map +1 -0
  28. package/dist/entities/github/githubPullRequestEvent.guard.d.ts +199 -0
  29. package/dist/entities/github/githubPullRequestEvent.guard.d.ts.map +1 -0
  30. package/dist/entities/github/githubPullRequestEvent.guard.js +28 -0
  31. package/dist/entities/github/githubPullRequestEvent.guard.js.map +1 -0
  32. package/dist/entities/gitlab/gitlabMergeRequestEvent.guard.d.ts +231 -0
  33. package/dist/entities/gitlab/gitlabMergeRequestEvent.guard.d.ts.map +1 -0
  34. package/dist/entities/gitlab/gitlabMergeRequestEvent.guard.js +52 -0
  35. package/dist/entities/gitlab/gitlabMergeRequestEvent.guard.js.map +1 -0
  36. package/dist/entities/job/jobContext.gateway.d.ts +10 -0
  37. package/dist/entities/job/jobContext.gateway.d.ts.map +1 -0
  38. package/dist/entities/job/jobContext.gateway.js +2 -0
  39. package/dist/entities/job/jobContext.gateway.js.map +1 -0
  40. package/dist/entities/progress/agentDefinition.type.d.ts +7 -0
  41. package/dist/entities/progress/agentDefinition.type.d.ts.map +1 -0
  42. package/dist/entities/progress/agentDefinition.type.js +18 -0
  43. package/dist/entities/progress/agentDefinition.type.js.map +1 -0
  44. package/dist/entities/progress/progress.calculator.d.ts +3 -0
  45. package/dist/entities/progress/progress.calculator.d.ts.map +1 -0
  46. package/dist/entities/progress/progress.calculator.js +17 -0
  47. package/dist/entities/progress/progress.calculator.js.map +1 -0
  48. package/dist/entities/progress/progress.factory.d.ts +4 -0
  49. package/dist/entities/progress/progress.factory.d.ts.map +1 -0
  50. package/dist/entities/progress/progress.factory.js +15 -0
  51. package/dist/entities/progress/progress.factory.js.map +1 -0
  52. package/dist/entities/progress/progress.gateway.d.ts +12 -0
  53. package/dist/entities/progress/progress.gateway.d.ts.map +1 -0
  54. package/dist/entities/progress/progress.gateway.js +2 -0
  55. package/dist/entities/progress/progress.gateway.js.map +1 -0
  56. package/dist/entities/progress/progress.type.d.ts +28 -0
  57. package/dist/entities/progress/progress.type.d.ts.map +1 -0
  58. package/dist/entities/progress/progress.type.js +2 -0
  59. package/dist/entities/progress/progress.type.js.map +1 -0
  60. package/dist/entities/review/reviewScore.valueObject.d.ts +25 -0
  61. package/dist/entities/review/reviewScore.valueObject.d.ts.map +1 -0
  62. package/dist/entities/review/reviewScore.valueObject.js +60 -0
  63. package/dist/entities/review/reviewScore.valueObject.js.map +1 -0
  64. package/dist/entities/reviewAction/reviewAction.d.ts +12 -0
  65. package/dist/entities/reviewAction/reviewAction.d.ts.map +1 -0
  66. package/dist/entities/reviewAction/reviewAction.gateway.d.ts +19 -0
  67. package/dist/entities/reviewAction/reviewAction.gateway.d.ts.map +1 -0
  68. package/dist/entities/reviewAction/reviewAction.gateway.js +2 -0
  69. package/dist/entities/reviewAction/reviewAction.gateway.js.map +1 -0
  70. package/dist/entities/reviewAction/reviewAction.guard.d.ts +27 -0
  71. package/dist/entities/reviewAction/reviewAction.guard.d.ts.map +1 -0
  72. package/dist/entities/reviewAction/reviewAction.guard.js +8 -0
  73. package/dist/entities/reviewAction/reviewAction.guard.js.map +1 -0
  74. package/dist/entities/reviewAction/reviewAction.js +2 -0
  75. package/dist/entities/reviewAction/reviewAction.js.map +1 -0
  76. package/dist/entities/reviewAction/reviewAction.schema.d.ts +51 -0
  77. package/dist/entities/reviewAction/reviewAction.schema.d.ts.map +1 -0
  78. package/dist/entities/reviewAction/reviewAction.schema.js +37 -0
  79. package/dist/entities/reviewAction/reviewAction.schema.js.map +1 -0
  80. package/dist/entities/reviewContext/reviewContext.d.ts +62 -0
  81. package/dist/entities/reviewContext/reviewContext.d.ts.map +1 -0
  82. package/dist/entities/reviewContext/reviewContext.gateway.d.ts +16 -0
  83. package/dist/entities/reviewContext/reviewContext.gateway.d.ts.map +1 -0
  84. package/dist/entities/reviewContext/reviewContext.gateway.js +2 -0
  85. package/dist/entities/reviewContext/reviewContext.gateway.js.map +1 -0
  86. package/dist/entities/reviewContext/reviewContext.js +2 -0
  87. package/dist/entities/reviewContext/reviewContext.js.map +1 -0
  88. package/dist/entities/reviewContext/reviewContext.schema.d.ts +122 -0
  89. package/dist/entities/reviewContext/reviewContext.schema.d.ts.map +1 -0
  90. package/dist/entities/reviewContext/reviewContext.schema.js +42 -0
  91. package/dist/entities/reviewContext/reviewContext.schema.js.map +1 -0
  92. package/dist/entities/reviewContext/reviewContextAction.guard.d.ts +247 -0
  93. package/dist/entities/reviewContext/reviewContextAction.guard.d.ts.map +1 -0
  94. package/dist/entities/reviewContext/reviewContextAction.guard.js +28 -0
  95. package/dist/entities/reviewContext/reviewContextAction.guard.js.map +1 -0
  96. package/dist/entities/reviewContext/reviewContextAction.schema.d.ts +16 -0
  97. package/dist/entities/reviewContext/reviewContextAction.schema.d.ts.map +1 -0
  98. package/dist/entities/reviewContext/reviewContextAction.schema.js +13 -0
  99. package/dist/entities/reviewContext/reviewContextAction.schema.js.map +1 -0
  100. package/dist/entities/reviewRequest/reviewRequest.entity.d.ts +37 -0
  101. package/dist/entities/reviewRequest/reviewRequest.entity.d.ts.map +1 -0
  102. package/dist/entities/reviewRequest/reviewRequest.entity.js +24 -0
  103. package/dist/entities/reviewRequest/reviewRequest.entity.js.map +1 -0
  104. package/dist/entities/reviewRequest/reviewRequest.guard.d.ts +20 -0
  105. package/dist/entities/reviewRequest/reviewRequest.guard.d.ts.map +1 -0
  106. package/dist/entities/reviewRequest/reviewRequest.guard.js +11 -0
  107. package/dist/entities/reviewRequest/reviewRequest.guard.js.map +1 -0
  108. package/dist/entities/reviewRequest/reviewRequestState.valueObject.d.ts +26 -0
  109. package/dist/entities/reviewRequest/reviewRequestState.valueObject.d.ts.map +1 -0
  110. package/dist/entities/reviewRequest/reviewRequestState.valueObject.js +61 -0
  111. package/dist/entities/reviewRequest/reviewRequestState.valueObject.js.map +1 -0
  112. package/dist/entities/shared/duration.valueObject.d.ts +21 -0
  113. package/dist/entities/shared/duration.valueObject.d.ts.map +1 -0
  114. package/dist/entities/shared/duration.valueObject.js +60 -0
  115. package/dist/entities/shared/duration.valueObject.js.map +1 -0
  116. package/dist/entities/threadFetch/threadFetch.gateway.d.ts +5 -0
  117. package/dist/entities/threadFetch/threadFetch.gateway.d.ts.map +1 -0
  118. package/dist/entities/threadFetch/threadFetch.gateway.js +2 -0
  119. package/dist/entities/threadFetch/threadFetch.gateway.js.map +1 -0
  120. package/dist/entities/tracking/assignmentInfo.d.ts +6 -0
  121. package/dist/entities/tracking/assignmentInfo.d.ts.map +1 -0
  122. package/dist/entities/tracking/assignmentInfo.js +2 -0
  123. package/dist/entities/tracking/assignmentInfo.js.map +1 -0
  124. package/dist/entities/tracking/mrTrackingData.d.ts +19 -0
  125. package/dist/entities/tracking/mrTrackingData.d.ts.map +1 -0
  126. package/dist/entities/tracking/mrTrackingData.js +11 -0
  127. package/dist/entities/tracking/mrTrackingData.js.map +1 -0
  128. package/dist/entities/tracking/reviewEvent.d.ts +12 -0
  129. package/dist/entities/tracking/reviewEvent.d.ts.map +1 -0
  130. package/dist/entities/tracking/reviewEvent.js +2 -0
  131. package/dist/entities/tracking/reviewEvent.js.map +1 -0
  132. package/dist/entities/tracking/trackedMr.d.ts +33 -0
  133. package/dist/entities/tracking/trackedMr.d.ts.map +1 -0
  134. package/dist/entities/tracking/trackedMr.js +4 -0
  135. package/dist/entities/tracking/trackedMr.js.map +1 -0
  136. package/dist/frameworks/claude/claudeInvoker.d.ts +30 -0
  137. package/dist/frameworks/claude/claudeInvoker.d.ts.map +1 -0
  138. package/dist/frameworks/claude/claudeInvoker.js +500 -0
  139. package/dist/frameworks/claude/claudeInvoker.js.map +1 -0
  140. package/dist/frameworks/claude/progressParser.d.ts +70 -0
  141. package/dist/frameworks/claude/progressParser.d.ts.map +1 -0
  142. package/dist/frameworks/claude/progressParser.js +196 -0
  143. package/dist/frameworks/claude/progressParser.js.map +1 -0
  144. package/dist/frameworks/config/configLoader.d.ts +34 -0
  145. package/dist/frameworks/config/configLoader.d.ts.map +1 -0
  146. package/dist/frameworks/config/configLoader.js +182 -0
  147. package/dist/frameworks/config/configLoader.js.map +1 -0
  148. package/dist/frameworks/logging/logBuffer.d.ts +38 -0
  149. package/dist/frameworks/logging/logBuffer.d.ts.map +1 -0
  150. package/dist/frameworks/logging/logBuffer.js +72 -0
  151. package/dist/frameworks/logging/logBuffer.js.map +1 -0
  152. package/dist/frameworks/queue/pQueueAdapter.d.ts +127 -0
  153. package/dist/frameworks/queue/pQueueAdapter.d.ts.map +1 -0
  154. package/dist/frameworks/queue/pQueueAdapter.js +276 -0
  155. package/dist/frameworks/queue/pQueueAdapter.js.map +1 -0
  156. package/dist/frameworks/settings/runtimeSettings.d.ts +12 -0
  157. package/dist/frameworks/settings/runtimeSettings.d.ts.map +1 -0
  158. package/dist/frameworks/settings/runtimeSettings.js +19 -0
  159. package/dist/frameworks/settings/runtimeSettings.js.map +1 -0
  160. package/dist/interface-adapters/adapters/githubPullRequest.adapter.d.ts +6 -0
  161. package/dist/interface-adapters/adapters/githubPullRequest.adapter.d.ts.map +1 -0
  162. package/dist/interface-adapters/adapters/githubPullRequest.adapter.js +27 -0
  163. package/dist/interface-adapters/adapters/githubPullRequest.adapter.js.map +1 -0
  164. package/dist/interface-adapters/adapters/gitlabMergeRequest.adapter.d.ts +6 -0
  165. package/dist/interface-adapters/adapters/gitlabMergeRequest.adapter.d.ts.map +1 -0
  166. package/dist/interface-adapters/adapters/gitlabMergeRequest.adapter.js +35 -0
  167. package/dist/interface-adapters/adapters/gitlabMergeRequest.adapter.js.map +1 -0
  168. package/dist/interface-adapters/adapters/platformAdapter.d.ts +9 -0
  169. package/dist/interface-adapters/adapters/platformAdapter.d.ts.map +1 -0
  170. package/dist/interface-adapters/adapters/platformAdapter.js +16 -0
  171. package/dist/interface-adapters/adapters/platformAdapter.js.map +1 -0
  172. package/dist/interface-adapters/controllers/http/cliStatus.routes.d.ts +3 -0
  173. package/dist/interface-adapters/controllers/http/cliStatus.routes.d.ts.map +1 -0
  174. package/dist/interface-adapters/controllers/http/cliStatus.routes.js +173 -0
  175. package/dist/interface-adapters/controllers/http/cliStatus.routes.js.map +1 -0
  176. package/dist/interface-adapters/controllers/http/health.routes.d.ts +9 -0
  177. package/dist/interface-adapters/controllers/http/health.routes.d.ts.map +1 -0
  178. package/dist/interface-adapters/controllers/http/health.routes.js +23 -0
  179. package/dist/interface-adapters/controllers/http/health.routes.js.map +1 -0
  180. package/dist/interface-adapters/controllers/http/index.d.ts +6 -0
  181. package/dist/interface-adapters/controllers/http/index.d.ts.map +1 -0
  182. package/dist/interface-adapters/controllers/http/index.js +6 -0
  183. package/dist/interface-adapters/controllers/http/index.js.map +1 -0
  184. package/dist/interface-adapters/controllers/http/logs.routes.d.ts +3 -0
  185. package/dist/interface-adapters/controllers/http/logs.routes.d.ts.map +1 -0
  186. package/dist/interface-adapters/controllers/http/logs.routes.js +12 -0
  187. package/dist/interface-adapters/controllers/http/logs.routes.js.map +1 -0
  188. package/dist/interface-adapters/controllers/http/mrTracking.routes.d.ts +8 -0
  189. package/dist/interface-adapters/controllers/http/mrTracking.routes.d.ts.map +1 -0
  190. package/dist/interface-adapters/controllers/http/mrTracking.routes.js +63 -0
  191. package/dist/interface-adapters/controllers/http/mrTracking.routes.js.map +1 -0
  192. package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.d.ts +12 -0
  193. package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.d.ts.map +1 -0
  194. package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js +265 -0
  195. package/dist/interface-adapters/controllers/http/mrTrackingAdvanced.routes.js.map +1 -0
  196. package/dist/interface-adapters/controllers/http/projectConfig.routes.d.ts +3 -0
  197. package/dist/interface-adapters/controllers/http/projectConfig.routes.d.ts.map +1 -0
  198. package/dist/interface-adapters/controllers/http/projectConfig.routes.js +75 -0
  199. package/dist/interface-adapters/controllers/http/projectConfig.routes.js.map +1 -0
  200. package/dist/interface-adapters/controllers/http/reviews.routes.d.ts +18 -0
  201. package/dist/interface-adapters/controllers/http/reviews.routes.d.ts.map +1 -0
  202. package/dist/interface-adapters/controllers/http/reviews.routes.js +96 -0
  203. package/dist/interface-adapters/controllers/http/reviews.routes.js.map +1 -0
  204. package/dist/interface-adapters/controllers/http/settings.routes.d.ts +3 -0
  205. package/dist/interface-adapters/controllers/http/settings.routes.d.ts.map +1 -0
  206. package/dist/interface-adapters/controllers/http/settings.routes.js +21 -0
  207. package/dist/interface-adapters/controllers/http/settings.routes.js.map +1 -0
  208. package/dist/interface-adapters/controllers/http/stats.routes.d.ts +13 -0
  209. package/dist/interface-adapters/controllers/http/stats.routes.d.ts.map +1 -0
  210. package/dist/interface-adapters/controllers/http/stats.routes.js +37 -0
  211. package/dist/interface-adapters/controllers/http/stats.routes.js.map +1 -0
  212. package/dist/interface-adapters/controllers/mcp/addAction.handler.d.ts +4 -0
  213. package/dist/interface-adapters/controllers/mcp/addAction.handler.d.ts.map +1 -0
  214. package/dist/interface-adapters/controllers/mcp/addAction.handler.js +87 -0
  215. package/dist/interface-adapters/controllers/mcp/addAction.handler.js.map +1 -0
  216. package/dist/interface-adapters/controllers/mcp/completeAgent.handler.d.ts +4 -0
  217. package/dist/interface-adapters/controllers/mcp/completeAgent.handler.d.ts.map +1 -0
  218. package/dist/interface-adapters/controllers/mcp/completeAgent.handler.js +62 -0
  219. package/dist/interface-adapters/controllers/mcp/completeAgent.handler.js.map +1 -0
  220. package/dist/interface-adapters/controllers/mcp/getThreads.handler.d.ts +4 -0
  221. package/dist/interface-adapters/controllers/mcp/getThreads.handler.d.ts.map +1 -0
  222. package/dist/interface-adapters/controllers/mcp/getThreads.handler.js +32 -0
  223. package/dist/interface-adapters/controllers/mcp/getThreads.handler.js.map +1 -0
  224. package/dist/interface-adapters/controllers/mcp/getWorkflow.handler.d.ts +4 -0
  225. package/dist/interface-adapters/controllers/mcp/getWorkflow.handler.d.ts.map +1 -0
  226. package/dist/interface-adapters/controllers/mcp/getWorkflow.handler.js +28 -0
  227. package/dist/interface-adapters/controllers/mcp/getWorkflow.handler.js.map +1 -0
  228. package/dist/interface-adapters/controllers/mcp/setPhase.handler.d.ts +4 -0
  229. package/dist/interface-adapters/controllers/mcp/setPhase.handler.d.ts.map +1 -0
  230. package/dist/interface-adapters/controllers/mcp/setPhase.handler.js +60 -0
  231. package/dist/interface-adapters/controllers/mcp/setPhase.handler.js.map +1 -0
  232. package/dist/interface-adapters/controllers/mcp/startAgent.handler.d.ts +4 -0
  233. package/dist/interface-adapters/controllers/mcp/startAgent.handler.d.ts.map +1 -0
  234. package/dist/interface-adapters/controllers/mcp/startAgent.handler.js +40 -0
  235. package/dist/interface-adapters/controllers/mcp/startAgent.handler.js.map +1 -0
  236. package/dist/interface-adapters/controllers/webhook/eventFilter.d.ts +71 -0
  237. package/dist/interface-adapters/controllers/webhook/eventFilter.d.ts.map +1 -0
  238. package/dist/interface-adapters/controllers/webhook/eventFilter.js +252 -0
  239. package/dist/interface-adapters/controllers/webhook/eventFilter.js.map +1 -0
  240. package/dist/interface-adapters/controllers/webhook/github.controller.d.ts +5 -0
  241. package/dist/interface-adapters/controllers/webhook/github.controller.d.ts.map +1 -0
  242. package/dist/interface-adapters/controllers/webhook/github.controller.js +266 -0
  243. package/dist/interface-adapters/controllers/webhook/github.controller.js.map +1 -0
  244. package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts +5 -0
  245. package/dist/interface-adapters/controllers/webhook/gitlab.controller.d.ts.map +1 -0
  246. package/dist/interface-adapters/controllers/webhook/gitlab.controller.js +461 -0
  247. package/dist/interface-adapters/controllers/webhook/gitlab.controller.js.map +1 -0
  248. package/dist/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.d.ts +7 -0
  249. package/dist/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.d.ts.map +1 -0
  250. package/dist/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.js +71 -0
  251. package/dist/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.js.map +1 -0
  252. package/dist/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.d.ts +7 -0
  253. package/dist/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.d.ts.map +1 -0
  254. package/dist/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.js +58 -0
  255. package/dist/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.js.map +1 -0
  256. package/dist/interface-adapters/gateways/diffMetadataFetch.github.gateway.d.ts +9 -0
  257. package/dist/interface-adapters/gateways/diffMetadataFetch.github.gateway.d.ts.map +1 -0
  258. package/dist/interface-adapters/gateways/diffMetadataFetch.github.gateway.js +16 -0
  259. package/dist/interface-adapters/gateways/diffMetadataFetch.github.gateway.js.map +1 -0
  260. package/dist/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.d.ts +9 -0
  261. package/dist/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.d.ts.map +1 -0
  262. package/dist/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.js +18 -0
  263. package/dist/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.js.map +1 -0
  264. package/dist/interface-adapters/gateways/fileSystem/reviewFile.fileSystem.d.ts +10 -0
  265. package/dist/interface-adapters/gateways/fileSystem/reviewFile.fileSystem.d.ts.map +1 -0
  266. package/dist/interface-adapters/gateways/fileSystem/reviewFile.fileSystem.js +81 -0
  267. package/dist/interface-adapters/gateways/fileSystem/reviewFile.fileSystem.js.map +1 -0
  268. package/dist/interface-adapters/gateways/fileSystem/reviewRequestTracking.fileSystem.d.ts +22 -0
  269. package/dist/interface-adapters/gateways/fileSystem/reviewRequestTracking.fileSystem.d.ts.map +1 -0
  270. package/dist/interface-adapters/gateways/fileSystem/reviewRequestTracking.fileSystem.js +142 -0
  271. package/dist/interface-adapters/gateways/fileSystem/reviewRequestTracking.fileSystem.js.map +1 -0
  272. package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts +8 -0
  273. package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.d.ts.map +1 -0
  274. package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.js +37 -0
  275. package/dist/interface-adapters/gateways/fileSystem/stats.fileSystem.js.map +1 -0
  276. package/dist/interface-adapters/gateways/jobContext.memory.gateway.d.ts +8 -0
  277. package/dist/interface-adapters/gateways/jobContext.memory.gateway.d.ts.map +1 -0
  278. package/dist/interface-adapters/gateways/jobContext.memory.gateway.js +13 -0
  279. package/dist/interface-adapters/gateways/jobContext.memory.gateway.js.map +1 -0
  280. package/dist/interface-adapters/gateways/reviewContext.fileSystem.gateway.d.ts +14 -0
  281. package/dist/interface-adapters/gateways/reviewContext.fileSystem.gateway.d.ts.map +1 -0
  282. package/dist/interface-adapters/gateways/reviewContext.fileSystem.gateway.js +87 -0
  283. package/dist/interface-adapters/gateways/reviewContext.fileSystem.gateway.js.map +1 -0
  284. package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts +18 -0
  285. package/dist/interface-adapters/gateways/reviewFile.gateway.d.ts.map +1 -0
  286. package/dist/interface-adapters/gateways/reviewFile.gateway.js +2 -0
  287. package/dist/interface-adapters/gateways/reviewFile.gateway.js.map +1 -0
  288. package/dist/interface-adapters/gateways/reviewProgress.memory.gateway.d.ts +13 -0
  289. package/dist/interface-adapters/gateways/reviewProgress.memory.gateway.d.ts.map +1 -0
  290. package/dist/interface-adapters/gateways/reviewProgress.memory.gateway.js +73 -0
  291. package/dist/interface-adapters/gateways/reviewProgress.memory.gateway.js.map +1 -0
  292. package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts +19 -0
  293. package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.d.ts.map +1 -0
  294. package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.js +2 -0
  295. package/dist/interface-adapters/gateways/reviewRequestTracking.gateway.js.map +1 -0
  296. package/dist/interface-adapters/gateways/stats.gateway.d.ts +7 -0
  297. package/dist/interface-adapters/gateways/stats.gateway.d.ts.map +1 -0
  298. package/dist/interface-adapters/gateways/stats.gateway.js +2 -0
  299. package/dist/interface-adapters/gateways/stats.gateway.js.map +1 -0
  300. package/dist/interface-adapters/gateways/threadFetch.github.gateway.d.ts +10 -0
  301. package/dist/interface-adapters/gateways/threadFetch.github.gateway.d.ts.map +1 -0
  302. package/dist/interface-adapters/gateways/threadFetch.github.gateway.js +33 -0
  303. package/dist/interface-adapters/gateways/threadFetch.github.gateway.js.map +1 -0
  304. package/dist/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts +10 -0
  305. package/dist/interface-adapters/gateways/threadFetch.gitlab.gateway.d.ts.map +1 -0
  306. package/dist/interface-adapters/gateways/threadFetch.gitlab.gateway.js +30 -0
  307. package/dist/interface-adapters/gateways/threadFetch.gitlab.gateway.js.map +1 -0
  308. package/dist/interface-adapters/presenters/jobStatus.presenter.d.ts +29 -0
  309. package/dist/interface-adapters/presenters/jobStatus.presenter.d.ts.map +1 -0
  310. package/dist/interface-adapters/presenters/jobStatus.presenter.js +57 -0
  311. package/dist/interface-adapters/presenters/jobStatus.presenter.js.map +1 -0
  312. package/dist/interface-adapters/presenters/reviewContextProgress.presenter.d.ts +8 -0
  313. package/dist/interface-adapters/presenters/reviewContextProgress.presenter.d.ts.map +1 -0
  314. package/dist/interface-adapters/presenters/reviewContextProgress.presenter.js +45 -0
  315. package/dist/interface-adapters/presenters/reviewContextProgress.presenter.js.map +1 -0
  316. package/dist/interface-adapters/presenters/reviewList.presenter.d.ts +22 -0
  317. package/dist/interface-adapters/presenters/reviewList.presenter.d.ts.map +1 -0
  318. package/dist/interface-adapters/presenters/reviewList.presenter.js +32 -0
  319. package/dist/interface-adapters/presenters/reviewList.presenter.js.map +1 -0
  320. package/dist/interface-adapters/services/projectStats.calculator.d.ts +8 -0
  321. package/dist/interface-adapters/services/projectStats.calculator.d.ts.map +1 -0
  322. package/dist/interface-adapters/services/projectStats.calculator.js +52 -0
  323. package/dist/interface-adapters/services/projectStats.calculator.js.map +1 -0
  324. package/dist/interface-adapters/views/dashboard/index.html +1537 -0
  325. package/dist/interface-adapters/views/dashboard/styles.css +1127 -0
  326. package/dist/main/cli.d.ts +12 -0
  327. package/dist/main/cli.d.ts.map +1 -0
  328. package/dist/main/cli.js +67 -0
  329. package/dist/main/cli.js.map +1 -0
  330. package/dist/main/dependencies.d.ts +20 -0
  331. package/dist/main/dependencies.d.ts.map +1 -0
  332. package/dist/main/dependencies.js +28 -0
  333. package/dist/main/dependencies.js.map +1 -0
  334. package/dist/main/mcpDependencies.d.ts +16 -0
  335. package/dist/main/mcpDependencies.d.ts.map +1 -0
  336. package/dist/main/mcpDependencies.js +35 -0
  337. package/dist/main/mcpDependencies.js.map +1 -0
  338. package/dist/main/routes.d.ts +4 -0
  339. package/dist/main/routes.d.ts.map +1 -0
  340. package/dist/main/routes.js +74 -0
  341. package/dist/main/routes.js.map +1 -0
  342. package/dist/main/server.d.ts +8 -0
  343. package/dist/main/server.d.ts.map +1 -0
  344. package/dist/main/server.js +54 -0
  345. package/dist/main/server.js.map +1 -0
  346. package/dist/main/websocket.d.ts +10 -0
  347. package/dist/main/websocket.d.ts.map +1 -0
  348. package/dist/main/websocket.js +109 -0
  349. package/dist/main/websocket.js.map +1 -0
  350. package/dist/mcp/mcpLogger.d.ts +9 -0
  351. package/dist/mcp/mcpLogger.d.ts.map +1 -0
  352. package/dist/mcp/mcpLogger.js +49 -0
  353. package/dist/mcp/mcpLogger.js.map +1 -0
  354. package/dist/mcp/mcpServerStdio.d.ts +13 -0
  355. package/dist/mcp/mcpServerStdio.d.ts.map +1 -0
  356. package/dist/mcp/mcpServerStdio.js +239 -0
  357. package/dist/mcp/mcpServerStdio.js.map +1 -0
  358. package/dist/mcp/server.d.ts +8 -0
  359. package/dist/mcp/server.d.ts.map +1 -0
  360. package/dist/mcp/server.js +24 -0
  361. package/dist/mcp/server.js.map +1 -0
  362. package/dist/mcp/types.d.ts +27 -0
  363. package/dist/mcp/types.d.ts.map +1 -0
  364. package/dist/mcp/types.js +2 -0
  365. package/dist/mcp/types.js.map +1 -0
  366. package/dist/mcpServer.d.ts +2 -0
  367. package/dist/mcpServer.d.ts.map +1 -0
  368. package/dist/mcpServer.js +16 -0
  369. package/dist/mcpServer.js.map +1 -0
  370. package/dist/queue/reviewQueue.d.ts +3 -0
  371. package/dist/queue/reviewQueue.d.ts.map +1 -0
  372. package/dist/queue/reviewQueue.js +4 -0
  373. package/dist/queue/reviewQueue.js.map +1 -0
  374. package/dist/security/verifier.d.ts +21 -0
  375. package/dist/security/verifier.d.ts.map +1 -0
  376. package/dist/security/verifier.js +67 -0
  377. package/dist/security/verifier.js.map +1 -0
  378. package/dist/server.d.ts +2 -0
  379. package/dist/server.d.ts.map +1 -0
  380. package/dist/server.js +6 -0
  381. package/dist/server.js.map +1 -0
  382. package/dist/services/agentInstructionsBuilder.d.ts +4 -0
  383. package/dist/services/agentInstructionsBuilder.d.ts.map +1 -0
  384. package/dist/services/agentInstructionsBuilder.js +65 -0
  385. package/dist/services/agentInstructionsBuilder.js.map +1 -0
  386. package/dist/services/contextActionsExecutor.d.ts +19 -0
  387. package/dist/services/contextActionsExecutor.d.ts.map +1 -0
  388. package/dist/services/contextActionsExecutor.js +18 -0
  389. package/dist/services/contextActionsExecutor.js.map +1 -0
  390. package/dist/services/logService.d.ts +3 -0
  391. package/dist/services/logService.d.ts.map +1 -0
  392. package/dist/services/logService.js +4 -0
  393. package/dist/services/logService.js.map +1 -0
  394. package/dist/services/mrTrackingService.d.ts +196 -0
  395. package/dist/services/mrTrackingService.d.ts.map +1 -0
  396. package/dist/services/mrTrackingService.js +540 -0
  397. package/dist/services/mrTrackingService.js.map +1 -0
  398. package/dist/services/reviewContextWatcher.service.d.ts +15 -0
  399. package/dist/services/reviewContextWatcher.service.d.ts.map +1 -0
  400. package/dist/services/reviewContextWatcher.service.js +44 -0
  401. package/dist/services/reviewContextWatcher.service.js.map +1 -0
  402. package/dist/services/runtimeSettings.d.ts +3 -0
  403. package/dist/services/runtimeSettings.d.ts.map +1 -0
  404. package/dist/services/runtimeSettings.js +4 -0
  405. package/dist/services/runtimeSettings.js.map +1 -0
  406. package/dist/services/statsService.d.ts +76 -0
  407. package/dist/services/statsService.d.ts.map +1 -0
  408. package/dist/services/statsService.js +250 -0
  409. package/dist/services/statsService.js.map +1 -0
  410. package/dist/services/threadActionsExecutor.d.ts +26 -0
  411. package/dist/services/threadActionsExecutor.d.ts.map +1 -0
  412. package/dist/services/threadActionsExecutor.js +27 -0
  413. package/dist/services/threadActionsExecutor.js.map +1 -0
  414. package/dist/services/threadActionsParser.d.ts +4 -0
  415. package/dist/services/threadActionsParser.d.ts.map +1 -0
  416. package/dist/services/threadActionsParser.js +50 -0
  417. package/dist/services/threadActionsParser.js.map +1 -0
  418. package/dist/shared/foundation/executionGateway.base.d.ts +14 -0
  419. package/dist/shared/foundation/executionGateway.base.d.ts.map +1 -0
  420. package/dist/shared/foundation/executionGateway.base.js +30 -0
  421. package/dist/shared/foundation/executionGateway.base.js.map +1 -0
  422. package/dist/shared/foundation/gateway.base.d.ts +9 -0
  423. package/dist/shared/foundation/gateway.base.d.ts.map +1 -0
  424. package/dist/shared/foundation/gateway.base.js +2 -0
  425. package/dist/shared/foundation/gateway.base.js.map +1 -0
  426. package/dist/shared/foundation/guard.base.d.ts +8 -0
  427. package/dist/shared/foundation/guard.base.d.ts.map +1 -0
  428. package/dist/shared/foundation/guard.base.js +17 -0
  429. package/dist/shared/foundation/guard.base.js.map +1 -0
  430. package/dist/shared/foundation/presenter.base.d.ts +4 -0
  431. package/dist/shared/foundation/presenter.base.d.ts.map +1 -0
  432. package/dist/shared/foundation/presenter.base.js +2 -0
  433. package/dist/shared/foundation/presenter.base.js.map +1 -0
  434. package/dist/shared/foundation/usecase.base.d.ts +4 -0
  435. package/dist/shared/foundation/usecase.base.d.ts.map +1 -0
  436. package/dist/shared/foundation/usecase.base.js +2 -0
  437. package/dist/shared/foundation/usecase.base.js.map +1 -0
  438. package/dist/shared/services/claudePathResolver.d.ts +3 -0
  439. package/dist/shared/services/claudePathResolver.d.ts.map +1 -0
  440. package/dist/shared/services/claudePathResolver.js +62 -0
  441. package/dist/shared/services/claudePathResolver.js.map +1 -0
  442. package/dist/shared/services/dependencyChecker.d.ts +13 -0
  443. package/dist/shared/services/dependencyChecker.d.ts.map +1 -0
  444. package/dist/shared/services/dependencyChecker.js +37 -0
  445. package/dist/shared/services/dependencyChecker.js.map +1 -0
  446. package/dist/shared/services/mcpJobContext.d.ts +3 -0
  447. package/dist/shared/services/mcpJobContext.d.ts.map +1 -0
  448. package/dist/shared/services/mcpJobContext.js +10 -0
  449. package/dist/shared/services/mcpJobContext.js.map +1 -0
  450. package/dist/tests/factories/config.factory.d.ts +4 -0
  451. package/dist/tests/factories/config.factory.d.ts.map +1 -0
  452. package/dist/tests/factories/config.factory.js +27 -0
  453. package/dist/tests/factories/config.factory.js.map +1 -0
  454. package/dist/tests/factories/gitHubEvent.factory.d.ts +14 -0
  455. package/dist/tests/factories/gitHubEvent.factory.d.ts.map +1 -0
  456. package/dist/tests/factories/gitHubEvent.factory.js +93 -0
  457. package/dist/tests/factories/gitHubEvent.factory.js.map +1 -0
  458. package/dist/tests/factories/gitLabEvent.factory.d.ts +18 -0
  459. package/dist/tests/factories/gitLabEvent.factory.d.ts.map +1 -0
  460. package/dist/tests/factories/gitLabEvent.factory.js +129 -0
  461. package/dist/tests/factories/gitLabEvent.factory.js.map +1 -0
  462. package/dist/tests/factories/githubApiResponse.factory.d.ts +21 -0
  463. package/dist/tests/factories/githubApiResponse.factory.d.ts.map +1 -0
  464. package/dist/tests/factories/githubApiResponse.factory.js +25 -0
  465. package/dist/tests/factories/githubApiResponse.factory.js.map +1 -0
  466. package/dist/tests/factories/gitlabApiResponse.factory.d.ts +26 -0
  467. package/dist/tests/factories/gitlabApiResponse.factory.d.ts.map +1 -0
  468. package/dist/tests/factories/gitlabApiResponse.factory.js +9 -0
  469. package/dist/tests/factories/gitlabApiResponse.factory.js.map +1 -0
  470. package/dist/tests/factories/projectStats.factory.d.ts +9 -0
  471. package/dist/tests/factories/projectStats.factory.d.ts.map +1 -0
  472. package/dist/tests/factories/projectStats.factory.js +48 -0
  473. package/dist/tests/factories/projectStats.factory.js.map +1 -0
  474. package/dist/tests/factories/reviewContext.factory.d.ts +9 -0
  475. package/dist/tests/factories/reviewContext.factory.d.ts.map +1 -0
  476. package/dist/tests/factories/reviewContext.factory.js +59 -0
  477. package/dist/tests/factories/reviewContext.factory.js.map +1 -0
  478. package/dist/tests/factories/reviewJob.factory.d.ts +10 -0
  479. package/dist/tests/factories/reviewJob.factory.d.ts.map +1 -0
  480. package/dist/tests/factories/reviewJob.factory.js +43 -0
  481. package/dist/tests/factories/reviewJob.factory.js.map +1 -0
  482. package/dist/tests/factories/trackedMr.factory.d.ts +10 -0
  483. package/dist/tests/factories/trackedMr.factory.d.ts.map +1 -0
  484. package/dist/tests/factories/trackedMr.factory.js +65 -0
  485. package/dist/tests/factories/trackedMr.factory.js.map +1 -0
  486. package/dist/tests/factories/webhookEvent.factory.d.ts +8 -0
  487. package/dist/tests/factories/webhookEvent.factory.d.ts.map +1 -0
  488. package/dist/tests/factories/webhookEvent.factory.js +72 -0
  489. package/dist/tests/factories/webhookEvent.factory.js.map +1 -0
  490. package/dist/tests/integration/server.integration.test.d.ts +2 -0
  491. package/dist/tests/integration/server.integration.test.d.ts.map +1 -0
  492. package/dist/tests/integration/server.integration.test.js +93 -0
  493. package/dist/tests/integration/server.integration.test.js.map +1 -0
  494. package/dist/tests/stubs/fastifyRequest.stub.d.ts +9 -0
  495. package/dist/tests/stubs/fastifyRequest.stub.d.ts.map +1 -0
  496. package/dist/tests/stubs/fastifyRequest.stub.js +11 -0
  497. package/dist/tests/stubs/fastifyRequest.stub.js.map +1 -0
  498. package/dist/tests/stubs/logger.stub.d.ts +3 -0
  499. package/dist/tests/stubs/logger.stub.d.ts.map +1 -0
  500. package/dist/tests/stubs/logger.stub.js +14 -0
  501. package/dist/tests/stubs/logger.stub.js.map +1 -0
  502. package/dist/tests/stubs/reviewContextGateway.stub.d.ts +18 -0
  503. package/dist/tests/stubs/reviewContextGateway.stub.d.ts.map +1 -0
  504. package/dist/tests/stubs/reviewContextGateway.stub.js +69 -0
  505. package/dist/tests/stubs/reviewContextGateway.stub.js.map +1 -0
  506. package/dist/tests/stubs/reviewFile.stub.d.ts +13 -0
  507. package/dist/tests/stubs/reviewFile.stub.d.ts.map +1 -0
  508. package/dist/tests/stubs/reviewFile.stub.js +56 -0
  509. package/dist/tests/stubs/reviewFile.stub.js.map +1 -0
  510. package/dist/tests/stubs/reviewQueue.stub.d.ts +20 -0
  511. package/dist/tests/stubs/reviewQueue.stub.d.ts.map +1 -0
  512. package/dist/tests/stubs/reviewQueue.stub.js +46 -0
  513. package/dist/tests/stubs/reviewQueue.stub.js.map +1 -0
  514. package/dist/tests/stubs/reviewRequestTracking.stub.d.ts +21 -0
  515. package/dist/tests/stubs/reviewRequestTracking.stub.d.ts.map +1 -0
  516. package/dist/tests/stubs/reviewRequestTracking.stub.js +121 -0
  517. package/dist/tests/stubs/reviewRequestTracking.stub.js.map +1 -0
  518. package/dist/tests/stubs/stats.stub.d.ts +10 -0
  519. package/dist/tests/stubs/stats.stub.d.ts.map +1 -0
  520. package/dist/tests/stubs/stats.stub.js +17 -0
  521. package/dist/tests/stubs/stats.stub.js.map +1 -0
  522. package/dist/tests/stubs/threadFetch.stub.d.ts +8 -0
  523. package/dist/tests/stubs/threadFetch.stub.d.ts.map +1 -0
  524. package/dist/tests/stubs/threadFetch.stub.js +10 -0
  525. package/dist/tests/stubs/threadFetch.stub.js.map +1 -0
  526. package/dist/tests/units/claude/progressParser.test.d.ts +2 -0
  527. package/dist/tests/units/claude/progressParser.test.d.ts.map +1 -0
  528. package/dist/tests/units/claude/progressParser.test.js +202 -0
  529. package/dist/tests/units/claude/progressParser.test.js.map +1 -0
  530. package/dist/tests/units/cli/cli.integration.test.d.ts +2 -0
  531. package/dist/tests/units/cli/cli.integration.test.d.ts.map +1 -0
  532. package/dist/tests/units/cli/cli.integration.test.js +18 -0
  533. package/dist/tests/units/cli/cli.integration.test.js.map +1 -0
  534. package/dist/tests/units/cli/parseCliArgs.test.d.ts +2 -0
  535. package/dist/tests/units/cli/parseCliArgs.test.d.ts.map +1 -0
  536. package/dist/tests/units/cli/parseCliArgs.test.js +35 -0
  537. package/dist/tests/units/cli/parseCliArgs.test.js.map +1 -0
  538. package/dist/tests/units/entities/duration.valueObject.test.d.ts +2 -0
  539. package/dist/tests/units/entities/duration.valueObject.test.d.ts.map +1 -0
  540. package/dist/tests/units/entities/duration.valueObject.test.js +112 -0
  541. package/dist/tests/units/entities/duration.valueObject.test.js.map +1 -0
  542. package/dist/tests/units/entities/github/githubPullRequestEvent.guard.test.d.ts +2 -0
  543. package/dist/tests/units/entities/github/githubPullRequestEvent.guard.test.d.ts.map +1 -0
  544. package/dist/tests/units/entities/github/githubPullRequestEvent.guard.test.js +53 -0
  545. package/dist/tests/units/entities/github/githubPullRequestEvent.guard.test.js.map +1 -0
  546. package/dist/tests/units/entities/gitlab/gitlabMergeRequestEvent.guard.test.d.ts +2 -0
  547. package/dist/tests/units/entities/gitlab/gitlabMergeRequestEvent.guard.test.d.ts.map +1 -0
  548. package/dist/tests/units/entities/gitlab/gitlabMergeRequestEvent.guard.test.js +97 -0
  549. package/dist/tests/units/entities/gitlab/gitlabMergeRequestEvent.guard.test.js.map +1 -0
  550. package/dist/tests/units/entities/progress/progress.test.d.ts +2 -0
  551. package/dist/tests/units/entities/progress/progress.test.d.ts.map +1 -0
  552. package/dist/tests/units/entities/progress/progress.test.js +137 -0
  553. package/dist/tests/units/entities/progress/progress.test.js.map +1 -0
  554. package/dist/tests/units/entities/reviewAction/reviewAction.guard.test.d.ts +2 -0
  555. package/dist/tests/units/entities/reviewAction/reviewAction.guard.test.d.ts.map +1 -0
  556. package/dist/tests/units/entities/reviewAction/reviewAction.guard.test.js +89 -0
  557. package/dist/tests/units/entities/reviewAction/reviewAction.guard.test.js.map +1 -0
  558. package/dist/tests/units/entities/reviewContext/reviewContext.schema.test.d.ts +2 -0
  559. package/dist/tests/units/entities/reviewContext/reviewContext.schema.test.d.ts.map +1 -0
  560. package/dist/tests/units/entities/reviewContext/reviewContext.schema.test.js +176 -0
  561. package/dist/tests/units/entities/reviewContext/reviewContext.schema.test.js.map +1 -0
  562. package/dist/tests/units/entities/reviewContext/reviewContextAction.guard.test.d.ts +2 -0
  563. package/dist/tests/units/entities/reviewContext/reviewContextAction.guard.test.d.ts.map +1 -0
  564. package/dist/tests/units/entities/reviewContext/reviewContextAction.guard.test.js +88 -0
  565. package/dist/tests/units/entities/reviewContext/reviewContextAction.guard.test.js.map +1 -0
  566. package/dist/tests/units/entities/reviewContext/reviewContextAction.schema.test.d.ts +2 -0
  567. package/dist/tests/units/entities/reviewContext/reviewContextAction.schema.test.d.ts.map +1 -0
  568. package/dist/tests/units/entities/reviewContext/reviewContextAction.schema.test.js +132 -0
  569. package/dist/tests/units/entities/reviewContext/reviewContextAction.schema.test.js.map +1 -0
  570. package/dist/tests/units/entities/reviewRequestState.valueObject.test.d.ts +2 -0
  571. package/dist/tests/units/entities/reviewRequestState.valueObject.test.d.ts.map +1 -0
  572. package/dist/tests/units/entities/reviewRequestState.valueObject.test.js +100 -0
  573. package/dist/tests/units/entities/reviewRequestState.valueObject.test.js.map +1 -0
  574. package/dist/tests/units/entities/reviewScore.valueObject.test.d.ts +2 -0
  575. package/dist/tests/units/entities/reviewScore.valueObject.test.d.ts.map +1 -0
  576. package/dist/tests/units/entities/reviewScore.valueObject.test.js +90 -0
  577. package/dist/tests/units/entities/reviewScore.valueObject.test.js.map +1 -0
  578. package/dist/tests/units/factories/factories.test.d.ts +2 -0
  579. package/dist/tests/units/factories/factories.test.d.ts.map +1 -0
  580. package/dist/tests/units/factories/factories.test.js +100 -0
  581. package/dist/tests/units/factories/factories.test.js.map +1 -0
  582. package/dist/tests/units/frameworks/claude/ensureProjectMcpConfig.test.d.ts +2 -0
  583. package/dist/tests/units/frameworks/claude/ensureProjectMcpConfig.test.d.ts.map +1 -0
  584. package/dist/tests/units/frameworks/claude/ensureProjectMcpConfig.test.js +88 -0
  585. package/dist/tests/units/frameworks/claude/ensureProjectMcpConfig.test.js.map +1 -0
  586. package/dist/tests/units/frameworks/claude/mcpContext.test.d.ts +2 -0
  587. package/dist/tests/units/frameworks/claude/mcpContext.test.d.ts.map +1 -0
  588. package/dist/tests/units/frameworks/claude/mcpContext.test.js +88 -0
  589. package/dist/tests/units/frameworks/claude/mcpContext.test.js.map +1 -0
  590. package/dist/tests/units/frameworks/claude/resolveMcpServerPath.test.d.ts +2 -0
  591. package/dist/tests/units/frameworks/claude/resolveMcpServerPath.test.d.ts.map +1 -0
  592. package/dist/tests/units/frameworks/claude/resolveMcpServerPath.test.js +20 -0
  593. package/dist/tests/units/frameworks/claude/resolveMcpServerPath.test.js.map +1 -0
  594. package/dist/tests/units/interface-adapters/adapters/platformAdapter.test.d.ts +2 -0
  595. package/dist/tests/units/interface-adapters/adapters/platformAdapter.test.d.ts.map +1 -0
  596. package/dist/tests/units/interface-adapters/adapters/platformAdapter.test.js +181 -0
  597. package/dist/tests/units/interface-adapters/adapters/platformAdapter.test.js.map +1 -0
  598. package/dist/tests/units/interface-adapters/controllers/mcp/addAction.handler.test.d.ts +2 -0
  599. package/dist/tests/units/interface-adapters/controllers/mcp/addAction.handler.test.d.ts.map +1 -0
  600. package/dist/tests/units/interface-adapters/controllers/mcp/addAction.handler.test.js +84 -0
  601. package/dist/tests/units/interface-adapters/controllers/mcp/addAction.handler.test.js.map +1 -0
  602. package/dist/tests/units/interface-adapters/controllers/mcp/completeAgent.handler.test.d.ts +2 -0
  603. package/dist/tests/units/interface-adapters/controllers/mcp/completeAgent.handler.test.d.ts.map +1 -0
  604. package/dist/tests/units/interface-adapters/controllers/mcp/completeAgent.handler.test.js +71 -0
  605. package/dist/tests/units/interface-adapters/controllers/mcp/completeAgent.handler.test.js.map +1 -0
  606. package/dist/tests/units/interface-adapters/controllers/mcp/getThreads.handler.test.d.ts +2 -0
  607. package/dist/tests/units/interface-adapters/controllers/mcp/getThreads.handler.test.d.ts.map +1 -0
  608. package/dist/tests/units/interface-adapters/controllers/mcp/getThreads.handler.test.js +52 -0
  609. package/dist/tests/units/interface-adapters/controllers/mcp/getThreads.handler.test.js.map +1 -0
  610. package/dist/tests/units/interface-adapters/controllers/mcp/getWorkflow.handler.test.d.ts +2 -0
  611. package/dist/tests/units/interface-adapters/controllers/mcp/getWorkflow.handler.test.d.ts.map +1 -0
  612. package/dist/tests/units/interface-adapters/controllers/mcp/getWorkflow.handler.test.js +32 -0
  613. package/dist/tests/units/interface-adapters/controllers/mcp/getWorkflow.handler.test.js.map +1 -0
  614. package/dist/tests/units/interface-adapters/controllers/mcp/setPhase.handler.test.d.ts +2 -0
  615. package/dist/tests/units/interface-adapters/controllers/mcp/setPhase.handler.test.d.ts.map +1 -0
  616. package/dist/tests/units/interface-adapters/controllers/mcp/setPhase.handler.test.js +44 -0
  617. package/dist/tests/units/interface-adapters/controllers/mcp/setPhase.handler.test.js.map +1 -0
  618. package/dist/tests/units/interface-adapters/controllers/mcp/startAgent.handler.test.d.ts +2 -0
  619. package/dist/tests/units/interface-adapters/controllers/mcp/startAgent.handler.test.d.ts.map +1 -0
  620. package/dist/tests/units/interface-adapters/controllers/mcp/startAgent.handler.test.js +38 -0
  621. package/dist/tests/units/interface-adapters/controllers/mcp/startAgent.handler.test.js.map +1 -0
  622. package/dist/tests/units/interface-adapters/controllers/webhook/eventFilter.test.d.ts +2 -0
  623. package/dist/tests/units/interface-adapters/controllers/webhook/eventFilter.test.d.ts.map +1 -0
  624. package/dist/tests/units/interface-adapters/controllers/webhook/eventFilter.test.js +389 -0
  625. package/dist/tests/units/interface-adapters/controllers/webhook/eventFilter.test.js.map +1 -0
  626. package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.d.ts +2 -0
  627. package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.d.ts.map +1 -0
  628. package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js +284 -0
  629. package/dist/tests/units/interface-adapters/controllers/webhook/github.controller.test.js.map +1 -0
  630. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.d.ts +2 -0
  631. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.d.ts.map +1 -0
  632. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js +202 -0
  633. package/dist/tests/units/interface-adapters/controllers/webhook/gitlab.controller.test.js.map +1 -0
  634. package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.test.d.ts +2 -0
  635. package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.test.d.ts.map +1 -0
  636. package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.test.js +83 -0
  637. package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.github.cli.gateway.test.js.map +1 -0
  638. package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.test.d.ts +2 -0
  639. package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.test.d.ts.map +1 -0
  640. package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.test.js +92 -0
  641. package/dist/tests/units/interface-adapters/gateways/cli/reviewAction.gitlab.cli.gateway.test.js.map +1 -0
  642. package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.github.gateway.test.d.ts +2 -0
  643. package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.github.gateway.test.d.ts.map +1 -0
  644. package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.github.gateway.test.js +41 -0
  645. package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.github.gateway.test.js.map +1 -0
  646. package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.test.d.ts +2 -0
  647. package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.test.d.ts.map +1 -0
  648. package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.test.js +57 -0
  649. package/dist/tests/units/interface-adapters/gateways/diffMetadataFetch.gitlab.gateway.test.js.map +1 -0
  650. package/dist/tests/units/interface-adapters/gateways/reviewContext.fileSystem.gateway.test.d.ts +2 -0
  651. package/dist/tests/units/interface-adapters/gateways/reviewContext.fileSystem.gateway.test.d.ts.map +1 -0
  652. package/dist/tests/units/interface-adapters/gateways/reviewContext.fileSystem.gateway.test.js +204 -0
  653. package/dist/tests/units/interface-adapters/gateways/reviewContext.fileSystem.gateway.test.js.map +1 -0
  654. package/dist/tests/units/interface-adapters/gateways/reviewFile.gateway.test.d.ts +2 -0
  655. package/dist/tests/units/interface-adapters/gateways/reviewFile.gateway.test.d.ts.map +1 -0
  656. package/dist/tests/units/interface-adapters/gateways/reviewFile.gateway.test.js +126 -0
  657. package/dist/tests/units/interface-adapters/gateways/reviewFile.gateway.test.js.map +1 -0
  658. package/dist/tests/units/interface-adapters/gateways/reviewProgress.memory.gateway.test.d.ts +2 -0
  659. package/dist/tests/units/interface-adapters/gateways/reviewProgress.memory.gateway.test.d.ts.map +1 -0
  660. package/dist/tests/units/interface-adapters/gateways/reviewProgress.memory.gateway.test.js +137 -0
  661. package/dist/tests/units/interface-adapters/gateways/reviewProgress.memory.gateway.test.js.map +1 -0
  662. package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.d.ts +2 -0
  663. package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.d.ts.map +1 -0
  664. package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js +242 -0
  665. package/dist/tests/units/interface-adapters/gateways/reviewRequestTracking.gateway.test.js.map +1 -0
  666. package/dist/tests/units/interface-adapters/gateways/stats.gateway.test.d.ts +2 -0
  667. package/dist/tests/units/interface-adapters/gateways/stats.gateway.test.d.ts.map +1 -0
  668. package/dist/tests/units/interface-adapters/gateways/stats.gateway.test.js +52 -0
  669. package/dist/tests/units/interface-adapters/gateways/stats.gateway.test.js.map +1 -0
  670. package/dist/tests/units/interface-adapters/gateways/threadFetch.github.gateway.test.d.ts +2 -0
  671. package/dist/tests/units/interface-adapters/gateways/threadFetch.github.gateway.test.d.ts.map +1 -0
  672. package/dist/tests/units/interface-adapters/gateways/threadFetch.github.gateway.test.js +41 -0
  673. package/dist/tests/units/interface-adapters/gateways/threadFetch.github.gateway.test.js.map +1 -0
  674. package/dist/tests/units/interface-adapters/gateways/threadFetch.gitlab.gateway.test.d.ts +2 -0
  675. package/dist/tests/units/interface-adapters/gateways/threadFetch.gitlab.gateway.test.d.ts.map +1 -0
  676. package/dist/tests/units/interface-adapters/gateways/threadFetch.gitlab.gateway.test.js +31 -0
  677. package/dist/tests/units/interface-adapters/gateways/threadFetch.gitlab.gateway.test.js.map +1 -0
  678. package/dist/tests/units/interface-adapters/presenters/jobStatus.presenter.test.d.ts +2 -0
  679. package/dist/tests/units/interface-adapters/presenters/jobStatus.presenter.test.d.ts.map +1 -0
  680. package/dist/tests/units/interface-adapters/presenters/jobStatus.presenter.test.js +128 -0
  681. package/dist/tests/units/interface-adapters/presenters/jobStatus.presenter.test.js.map +1 -0
  682. package/dist/tests/units/interface-adapters/presenters/reviewContextProgress.presenter.test.d.ts +2 -0
  683. package/dist/tests/units/interface-adapters/presenters/reviewContextProgress.presenter.test.d.ts.map +1 -0
  684. package/dist/tests/units/interface-adapters/presenters/reviewContextProgress.presenter.test.js +83 -0
  685. package/dist/tests/units/interface-adapters/presenters/reviewContextProgress.presenter.test.js.map +1 -0
  686. package/dist/tests/units/interface-adapters/presenters/reviewList.presenter.test.d.ts +2 -0
  687. package/dist/tests/units/interface-adapters/presenters/reviewList.presenter.test.d.ts.map +1 -0
  688. package/dist/tests/units/interface-adapters/presenters/reviewList.presenter.test.js +64 -0
  689. package/dist/tests/units/interface-adapters/presenters/reviewList.presenter.test.js.map +1 -0
  690. package/dist/tests/units/interface-adapters/services/projectStats.calculator.test.d.ts +2 -0
  691. package/dist/tests/units/interface-adapters/services/projectStats.calculator.test.d.ts.map +1 -0
  692. package/dist/tests/units/interface-adapters/services/projectStats.calculator.test.js +85 -0
  693. package/dist/tests/units/interface-adapters/services/projectStats.calculator.test.js.map +1 -0
  694. package/dist/tests/units/main/dependencies.test.d.ts +2 -0
  695. package/dist/tests/units/main/dependencies.test.d.ts.map +1 -0
  696. package/dist/tests/units/main/dependencies.test.js +43 -0
  697. package/dist/tests/units/main/dependencies.test.js.map +1 -0
  698. package/dist/tests/units/main/executeStart.test.d.ts +2 -0
  699. package/dist/tests/units/main/executeStart.test.d.ts.map +1 -0
  700. package/dist/tests/units/main/executeStart.test.js +61 -0
  701. package/dist/tests/units/main/executeStart.test.js.map +1 -0
  702. package/dist/tests/units/main/mcpDependencies.test.d.ts +2 -0
  703. package/dist/tests/units/main/mcpDependencies.test.d.ts.map +1 -0
  704. package/dist/tests/units/main/mcpDependencies.test.js +56 -0
  705. package/dist/tests/units/main/mcpDependencies.test.js.map +1 -0
  706. package/dist/tests/units/main/websocket.test.d.ts +2 -0
  707. package/dist/tests/units/main/websocket.test.d.ts.map +1 -0
  708. package/dist/tests/units/main/websocket.test.js +63 -0
  709. package/dist/tests/units/main/websocket.test.js.map +1 -0
  710. package/dist/tests/units/mcp/mcpServerStdio.test.d.ts +2 -0
  711. package/dist/tests/units/mcp/mcpServerStdio.test.d.ts.map +1 -0
  712. package/dist/tests/units/mcp/mcpServerStdio.test.js +179 -0
  713. package/dist/tests/units/mcp/mcpServerStdio.test.js.map +1 -0
  714. package/dist/tests/units/mcp/server.test.d.ts +2 -0
  715. package/dist/tests/units/mcp/server.test.d.ts.map +1 -0
  716. package/dist/tests/units/mcp/server.test.js +85 -0
  717. package/dist/tests/units/mcp/server.test.js.map +1 -0
  718. package/dist/tests/units/security/verifier.test.d.ts +2 -0
  719. package/dist/tests/units/security/verifier.test.d.ts.map +1 -0
  720. package/dist/tests/units/security/verifier.test.js +200 -0
  721. package/dist/tests/units/security/verifier.test.js.map +1 -0
  722. package/dist/tests/units/services/contextActionsExecutor.test.d.ts +2 -0
  723. package/dist/tests/units/services/contextActionsExecutor.test.d.ts.map +1 -0
  724. package/dist/tests/units/services/contextActionsExecutor.test.js +112 -0
  725. package/dist/tests/units/services/contextActionsExecutor.test.js.map +1 -0
  726. package/dist/tests/units/services/mrTrackingRemoveMr.test.d.ts +2 -0
  727. package/dist/tests/units/services/mrTrackingRemoveMr.test.d.ts.map +1 -0
  728. package/dist/tests/units/services/mrTrackingRemoveMr.test.js +155 -0
  729. package/dist/tests/units/services/mrTrackingRemoveMr.test.js.map +1 -0
  730. package/dist/tests/units/services/mrTrackingService.autoFollowup.test.d.ts +2 -0
  731. package/dist/tests/units/services/mrTrackingService.autoFollowup.test.d.ts.map +1 -0
  732. package/dist/tests/units/services/mrTrackingService.autoFollowup.test.js +82 -0
  733. package/dist/tests/units/services/mrTrackingService.autoFollowup.test.js.map +1 -0
  734. package/dist/tests/units/services/reviewContextWatcher.service.test.d.ts +2 -0
  735. package/dist/tests/units/services/reviewContextWatcher.service.test.d.ts.map +1 -0
  736. package/dist/tests/units/services/reviewContextWatcher.service.test.js +112 -0
  737. package/dist/tests/units/services/reviewContextWatcher.service.test.js.map +1 -0
  738. package/dist/tests/units/services/threadActionsExecutor.test.d.ts +2 -0
  739. package/dist/tests/units/services/threadActionsExecutor.test.d.ts.map +1 -0
  740. package/dist/tests/units/services/threadActionsExecutor.test.js +206 -0
  741. package/dist/tests/units/services/threadActionsExecutor.test.js.map +1 -0
  742. package/dist/tests/units/services/threadActionsParser.test.d.ts +2 -0
  743. package/dist/tests/units/services/threadActionsParser.test.d.ts.map +1 -0
  744. package/dist/tests/units/services/threadActionsParser.test.js +148 -0
  745. package/dist/tests/units/services/threadActionsParser.test.js.map +1 -0
  746. package/dist/tests/units/shared/foundation/foundation.contracts.test.d.ts +2 -0
  747. package/dist/tests/units/shared/foundation/foundation.contracts.test.d.ts.map +1 -0
  748. package/dist/tests/units/shared/foundation/foundation.contracts.test.js +46 -0
  749. package/dist/tests/units/shared/foundation/foundation.contracts.test.js.map +1 -0
  750. package/dist/tests/units/shared/foundation/guard.base.test.d.ts +2 -0
  751. package/dist/tests/units/shared/foundation/guard.base.test.d.ts.map +1 -0
  752. package/dist/tests/units/shared/foundation/guard.base.test.js +40 -0
  753. package/dist/tests/units/shared/foundation/guard.base.test.js.map +1 -0
  754. package/dist/tests/units/shared/services/claudePathResolver.test.d.ts +2 -0
  755. package/dist/tests/units/shared/services/claudePathResolver.test.d.ts.map +1 -0
  756. package/dist/tests/units/shared/services/claudePathResolver.test.js +61 -0
  757. package/dist/tests/units/shared/services/claudePathResolver.test.js.map +1 -0
  758. package/dist/tests/units/shared/services/dependencyChecker.test.d.ts +2 -0
  759. package/dist/tests/units/shared/services/dependencyChecker.test.d.ts.map +1 -0
  760. package/dist/tests/units/shared/services/dependencyChecker.test.js +35 -0
  761. package/dist/tests/units/shared/services/dependencyChecker.test.js.map +1 -0
  762. package/dist/tests/units/shared/services/mcpJobContext.test.d.ts +2 -0
  763. package/dist/tests/units/shared/services/mcpJobContext.test.d.ts.map +1 -0
  764. package/dist/tests/units/shared/services/mcpJobContext.test.js +38 -0
  765. package/dist/tests/units/shared/services/mcpJobContext.test.js.map +1 -0
  766. package/dist/tests/units/types/progress.test.d.ts +2 -0
  767. package/dist/tests/units/types/progress.test.d.ts.map +1 -0
  768. package/dist/tests/units/types/progress.test.js +135 -0
  769. package/dist/tests/units/types/progress.test.js.map +1 -0
  770. package/dist/tests/units/usecases/cancelReview.usecase.test.d.ts +2 -0
  771. package/dist/tests/units/usecases/cancelReview.usecase.test.d.ts.map +1 -0
  772. package/dist/tests/units/usecases/cancelReview.usecase.test.js +57 -0
  773. package/dist/tests/units/usecases/cancelReview.usecase.test.js.map +1 -0
  774. package/dist/tests/units/usecases/handleReviewRequestPush.usecase.test.d.ts +2 -0
  775. package/dist/tests/units/usecases/handleReviewRequestPush.usecase.test.d.ts.map +1 -0
  776. package/dist/tests/units/usecases/handleReviewRequestPush.usecase.test.js +124 -0
  777. package/dist/tests/units/usecases/handleReviewRequestPush.usecase.test.js.map +1 -0
  778. package/dist/tests/units/usecases/mcp/addAction.usecase.test.d.ts +2 -0
  779. package/dist/tests/units/usecases/mcp/addAction.usecase.test.d.ts.map +1 -0
  780. package/dist/tests/units/usecases/mcp/addAction.usecase.test.js +123 -0
  781. package/dist/tests/units/usecases/mcp/addAction.usecase.test.js.map +1 -0
  782. package/dist/tests/units/usecases/mcp/completeAgent.usecase.test.d.ts +2 -0
  783. package/dist/tests/units/usecases/mcp/completeAgent.usecase.test.d.ts.map +1 -0
  784. package/dist/tests/units/usecases/mcp/completeAgent.usecase.test.js +67 -0
  785. package/dist/tests/units/usecases/mcp/completeAgent.usecase.test.js.map +1 -0
  786. package/dist/tests/units/usecases/mcp/getThreads.usecase.test.d.ts +2 -0
  787. package/dist/tests/units/usecases/mcp/getThreads.usecase.test.d.ts.map +1 -0
  788. package/dist/tests/units/usecases/mcp/getThreads.usecase.test.js +77 -0
  789. package/dist/tests/units/usecases/mcp/getThreads.usecase.test.js.map +1 -0
  790. package/dist/tests/units/usecases/mcp/getWorkflow.usecase.test.d.ts +2 -0
  791. package/dist/tests/units/usecases/mcp/getWorkflow.usecase.test.d.ts.map +1 -0
  792. package/dist/tests/units/usecases/mcp/getWorkflow.usecase.test.js +55 -0
  793. package/dist/tests/units/usecases/mcp/getWorkflow.usecase.test.js.map +1 -0
  794. package/dist/tests/units/usecases/mcp/setPhase.usecase.test.d.ts +2 -0
  795. package/dist/tests/units/usecases/mcp/setPhase.usecase.test.d.ts.map +1 -0
  796. package/dist/tests/units/usecases/mcp/setPhase.usecase.test.js +41 -0
  797. package/dist/tests/units/usecases/mcp/setPhase.usecase.test.js.map +1 -0
  798. package/dist/tests/units/usecases/mcp/startAgent.usecase.test.d.ts +2 -0
  799. package/dist/tests/units/usecases/mcp/startAgent.usecase.test.d.ts.map +1 -0
  800. package/dist/tests/units/usecases/mcp/startAgent.usecase.test.js +42 -0
  801. package/dist/tests/units/usecases/mcp/startAgent.usecase.test.js.map +1 -0
  802. package/dist/tests/units/usecases/tracking/checkFollowupNeeded.usecase.test.d.ts +2 -0
  803. package/dist/tests/units/usecases/tracking/checkFollowupNeeded.usecase.test.d.ts.map +1 -0
  804. package/dist/tests/units/usecases/tracking/checkFollowupNeeded.usecase.test.js +71 -0
  805. package/dist/tests/units/usecases/tracking/checkFollowupNeeded.usecase.test.js.map +1 -0
  806. package/dist/tests/units/usecases/tracking/recordPush.usecase.test.d.ts +2 -0
  807. package/dist/tests/units/usecases/tracking/recordPush.usecase.test.d.ts.map +1 -0
  808. package/dist/tests/units/usecases/tracking/recordPush.usecase.test.js +22 -0
  809. package/dist/tests/units/usecases/tracking/recordPush.usecase.test.js.map +1 -0
  810. package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.d.ts +2 -0
  811. package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.d.ts.map +1 -0
  812. package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js +106 -0
  813. package/dist/tests/units/usecases/tracking/recordReviewCompletion.usecase.test.js.map +1 -0
  814. package/dist/tests/units/usecases/tracking/syncThreads.usecase.test.d.ts +2 -0
  815. package/dist/tests/units/usecases/tracking/syncThreads.usecase.test.d.ts.map +1 -0
  816. package/dist/tests/units/usecases/tracking/syncThreads.usecase.test.js +76 -0
  817. package/dist/tests/units/usecases/tracking/syncThreads.usecase.test.js.map +1 -0
  818. package/dist/tests/units/usecases/tracking/trackAssignment.usecase.test.d.ts +2 -0
  819. package/dist/tests/units/usecases/tracking/trackAssignment.usecase.test.d.ts.map +1 -0
  820. package/dist/tests/units/usecases/tracking/trackAssignment.usecase.test.js +70 -0
  821. package/dist/tests/units/usecases/tracking/trackAssignment.usecase.test.js.map +1 -0
  822. package/dist/tests/units/usecases/tracking/transitionState.usecase.test.d.ts +2 -0
  823. package/dist/tests/units/usecases/tracking/transitionState.usecase.test.d.ts.map +1 -0
  824. package/dist/tests/units/usecases/tracking/transitionState.usecase.test.js +48 -0
  825. package/dist/tests/units/usecases/tracking/transitionState.usecase.test.js.map +1 -0
  826. package/dist/tests/units/usecases/triggerReview.usecase.test.d.ts +2 -0
  827. package/dist/tests/units/usecases/triggerReview.usecase.test.d.ts.map +1 -0
  828. package/dist/tests/units/usecases/triggerReview.usecase.test.js +103 -0
  829. package/dist/tests/units/usecases/triggerReview.usecase.test.js.map +1 -0
  830. package/dist/types/progress.d.ts +55 -0
  831. package/dist/types/progress.d.ts.map +1 -0
  832. package/dist/types/progress.js +63 -0
  833. package/dist/types/progress.js.map +1 -0
  834. package/dist/usecases/cancelReview.usecase.d.ts +21 -0
  835. package/dist/usecases/cancelReview.usecase.d.ts.map +1 -0
  836. package/dist/usecases/cancelReview.usecase.js +19 -0
  837. package/dist/usecases/cancelReview.usecase.js.map +1 -0
  838. package/dist/usecases/handleReviewRequestPush.usecase.d.ts +26 -0
  839. package/dist/usecases/handleReviewRequestPush.usecase.d.ts.map +1 -0
  840. package/dist/usecases/handleReviewRequestPush.usecase.js +45 -0
  841. package/dist/usecases/handleReviewRequestPush.usecase.js.map +1 -0
  842. package/dist/usecases/mcp/addAction.usecase.d.ts +33 -0
  843. package/dist/usecases/mcp/addAction.usecase.d.ts.map +1 -0
  844. package/dist/usecases/mcp/addAction.usecase.js +94 -0
  845. package/dist/usecases/mcp/addAction.usecase.js.map +1 -0
  846. package/dist/usecases/mcp/completeAgent.usecase.d.ts +18 -0
  847. package/dist/usecases/mcp/completeAgent.usecase.d.ts.map +1 -0
  848. package/dist/usecases/mcp/completeAgent.usecase.js +20 -0
  849. package/dist/usecases/mcp/completeAgent.usecase.js.map +1 -0
  850. package/dist/usecases/mcp/getThreads.usecase.d.ts +16 -0
  851. package/dist/usecases/mcp/getThreads.usecase.d.ts.map +1 -0
  852. package/dist/usecases/mcp/getThreads.usecase.js +22 -0
  853. package/dist/usecases/mcp/getThreads.usecase.js.map +1 -0
  854. package/dist/usecases/mcp/getWorkflow.usecase.d.ts +28 -0
  855. package/dist/usecases/mcp/getWorkflow.usecase.d.ts.map +1 -0
  856. package/dist/usecases/mcp/getWorkflow.usecase.js +36 -0
  857. package/dist/usecases/mcp/getWorkflow.usecase.js.map +1 -0
  858. package/dist/usecases/mcp/setPhase.usecase.d.ts +15 -0
  859. package/dist/usecases/mcp/setPhase.usecase.d.ts.map +1 -0
  860. package/dist/usecases/mcp/setPhase.usecase.js +16 -0
  861. package/dist/usecases/mcp/setPhase.usecase.js.map +1 -0
  862. package/dist/usecases/mcp/startAgent.usecase.d.ts +15 -0
  863. package/dist/usecases/mcp/startAgent.usecase.d.ts.map +1 -0
  864. package/dist/usecases/mcp/startAgent.usecase.js +18 -0
  865. package/dist/usecases/mcp/startAgent.usecase.js.map +1 -0
  866. package/dist/usecases/tracking/checkFollowupNeeded.usecase.d.ts +14 -0
  867. package/dist/usecases/tracking/checkFollowupNeeded.usecase.d.ts.map +1 -0
  868. package/dist/usecases/tracking/checkFollowupNeeded.usecase.js +17 -0
  869. package/dist/usecases/tracking/checkFollowupNeeded.usecase.js.map +1 -0
  870. package/dist/usecases/tracking/recordPush.usecase.d.ts +15 -0
  871. package/dist/usecases/tracking/recordPush.usecase.d.ts.map +1 -0
  872. package/dist/usecases/tracking/recordPush.usecase.js +10 -0
  873. package/dist/usecases/tracking/recordPush.usecase.js.map +1 -0
  874. package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts +24 -0
  875. package/dist/usecases/tracking/recordReviewCompletion.usecase.d.ts.map +1 -0
  876. package/dist/usecases/tracking/recordReviewCompletion.usecase.js +52 -0
  877. package/dist/usecases/tracking/recordReviewCompletion.usecase.js.map +1 -0
  878. package/dist/usecases/tracking/syncThreads.usecase.d.ts +16 -0
  879. package/dist/usecases/tracking/syncThreads.usecase.d.ts.map +1 -0
  880. package/dist/usecases/tracking/syncThreads.usecase.js +26 -0
  881. package/dist/usecases/tracking/syncThreads.usecase.js.map +1 -0
  882. package/dist/usecases/tracking/trackAssignment.usecase.d.ts +28 -0
  883. package/dist/usecases/tracking/trackAssignment.usecase.d.ts.map +1 -0
  884. package/dist/usecases/tracking/trackAssignment.usecase.js +69 -0
  885. package/dist/usecases/tracking/trackAssignment.usecase.js.map +1 -0
  886. package/dist/usecases/tracking/transitionState.usecase.d.ts +14 -0
  887. package/dist/usecases/tracking/transitionState.usecase.d.ts.map +1 -0
  888. package/dist/usecases/tracking/transitionState.usecase.js +22 -0
  889. package/dist/usecases/tracking/transitionState.usecase.js.map +1 -0
  890. package/dist/usecases/triggerReview.usecase.d.ts +41 -0
  891. package/dist/usecases/triggerReview.usecase.d.ts.map +1 -0
  892. package/dist/usecases/triggerReview.usecase.js +34 -0
  893. package/dist/usecases/triggerReview.usecase.js.map +1 -0
  894. package/package.json +82 -0
  895. package/scripts/copyAssets.mjs +10 -0
  896. package/scripts/launcher.sh +35 -0
  897. package/templates/SETUP.md +183 -0
  898. package/templates/SKILL.md.template +207 -0
  899. package/templates/claude-mcp-config.example.json +12 -0
  900. package/templates/config.json.template +15 -0
  901. package/templates/en/followup-basic/README.md +66 -0
  902. package/templates/en/followup-basic/SKILL.md +317 -0
  903. package/templates/en/review-basic/README.md +75 -0
  904. package/templates/en/review-basic/SKILL.md +160 -0
  905. package/templates/en/review-with-agents/README.md +78 -0
  906. package/templates/en/review-with-agents/SKILL.md +225 -0
  907. package/templates/fr/followup-basic/README.md +66 -0
  908. package/templates/fr/followup-basic/SKILL.md +317 -0
  909. package/templates/fr/review-basic/README.md +59 -0
  910. package/templates/fr/review-basic/SKILL.md +160 -0
  911. package/templates/fr/review-with-agents/README.md +54 -0
  912. package/templates/fr/review-with-agents/SKILL.md +225 -0
  913. package/templates/skills/review-bootstrap/SKILL.md +119 -0
  914. package/templates/skills/review-with-mcp.md +133 -0
@@ -0,0 +1,540 @@
1
+ import { readFileSync, writeFileSync, existsSync, mkdirSync } from 'node:fs';
2
+ import { join, dirname } from 'node:path';
3
+ import { execSync } from 'node:child_process';
4
+ function getTrackingPath(projectPath) {
5
+ return join(projectPath, '.claude', 'reviews', 'mr-tracking.json');
6
+ }
7
+ function createEmptyStats() {
8
+ return {
9
+ totalMrs: 0,
10
+ totalReviews: 0,
11
+ totalFollowups: 0,
12
+ averageReviewsPerMr: 0,
13
+ averageTimeToApproval: null,
14
+ topAssigners: [],
15
+ };
16
+ }
17
+ function recalculateStats(data) {
18
+ const mrs = data.mrs;
19
+ data.stats.totalMrs = mrs.length;
20
+ data.stats.totalReviews = mrs.reduce((sum, mr) => sum + mr.totalReviews, 0);
21
+ data.stats.totalFollowups = mrs.reduce((sum, mr) => sum + mr.totalFollowups, 0);
22
+ if (mrs.length > 0) {
23
+ data.stats.averageReviewsPerMr = (data.stats.totalReviews + data.stats.totalFollowups) / mrs.length;
24
+ }
25
+ // Calculate average time to approval
26
+ const approvedMrs = mrs.filter((mr) => mr.approvedAt && mr.createdAt);
27
+ if (approvedMrs.length > 0) {
28
+ const totalTime = approvedMrs.reduce((sum, mr) => {
29
+ const created = new Date(mr.createdAt).getTime();
30
+ const approved = new Date(mr.approvedAt).getTime();
31
+ return sum + (approved - created);
32
+ }, 0);
33
+ data.stats.averageTimeToApproval = totalTime / approvedMrs.length;
34
+ }
35
+ // Top assigners
36
+ const assignerCounts = new Map();
37
+ for (const mr of mrs) {
38
+ const username = mr.assignment.username;
39
+ assignerCounts.set(username, (assignerCounts.get(username) || 0) + 1);
40
+ }
41
+ data.stats.topAssigners = Array.from(assignerCounts.entries())
42
+ .map(([username, count]) => ({ username, count }))
43
+ .sort((a, b) => b.count - a.count)
44
+ .slice(0, 10);
45
+ }
46
+ export function loadMrTracking(projectPath) {
47
+ const trackingPath = getTrackingPath(projectPath);
48
+ if (!existsSync(trackingPath)) {
49
+ return { mrs: [], lastUpdated: new Date().toISOString(), stats: createEmptyStats() };
50
+ }
51
+ try {
52
+ const content = readFileSync(trackingPath, 'utf-8');
53
+ const data = JSON.parse(content);
54
+ // Ensure arrays and stats exist
55
+ if (!Array.isArray(data.mrs)) {
56
+ data.mrs = [];
57
+ }
58
+ if (!data.stats) {
59
+ data.stats = createEmptyStats();
60
+ }
61
+ for (const mr of data.mrs) {
62
+ if (mr.autoFollowup === undefined) {
63
+ mr.autoFollowup = true;
64
+ }
65
+ }
66
+ return data;
67
+ }
68
+ catch {
69
+ return { mrs: [], lastUpdated: new Date().toISOString(), stats: createEmptyStats() };
70
+ }
71
+ }
72
+ export function saveMrTracking(projectPath, data) {
73
+ const trackingPath = getTrackingPath(projectPath);
74
+ const dir = dirname(trackingPath);
75
+ if (!existsSync(dir)) {
76
+ mkdirSync(dir, { recursive: true });
77
+ }
78
+ // Recalculate stats before saving
79
+ recalculateStats(data);
80
+ data.lastUpdated = new Date().toISOString();
81
+ writeFileSync(trackingPath, JSON.stringify(data, null, 2), 'utf-8');
82
+ }
83
+ /**
84
+ * Create or update a tracked MR when assigned for review
85
+ */
86
+ export function trackMrAssignment(projectPath, mrInfo, assignedBy) {
87
+ const data = loadMrTracking(projectPath);
88
+ const mrId = `${mrInfo.platform}-${mrInfo.project}-${mrInfo.mrNumber}`;
89
+ const existingIndex = data.mrs.findIndex((mr) => mr.id === mrId);
90
+ if (existingIndex >= 0) {
91
+ // MR already tracked, update assignment info but KEEP existing state
92
+ // Don't reset state - the MR might be in pending-fix waiting for followup
93
+ const existing = data.mrs[existingIndex];
94
+ existing.title = mrInfo.title;
95
+ existing.assignment = {
96
+ username: assignedBy.username,
97
+ displayName: assignedBy.displayName,
98
+ assignedAt: new Date().toISOString(),
99
+ };
100
+ // Only set to pending-review if it's a new MR or was merged/closed
101
+ if (['merged', 'closed'].includes(existing.state)) {
102
+ existing.state = 'pending-review';
103
+ }
104
+ saveMrTracking(projectPath, data);
105
+ return existing;
106
+ }
107
+ // Create new tracked MR
108
+ const now = new Date().toISOString();
109
+ const trackedMr = {
110
+ id: mrId,
111
+ mrNumber: mrInfo.mrNumber,
112
+ title: mrInfo.title,
113
+ url: mrInfo.url,
114
+ project: mrInfo.project,
115
+ platform: mrInfo.platform,
116
+ sourceBranch: mrInfo.sourceBranch,
117
+ targetBranch: mrInfo.targetBranch,
118
+ assignment: {
119
+ username: assignedBy.username,
120
+ displayName: assignedBy.displayName,
121
+ assignedAt: now,
122
+ },
123
+ state: 'pending-review',
124
+ openThreads: 0,
125
+ totalThreads: 0,
126
+ createdAt: now,
127
+ lastReviewAt: null,
128
+ lastPushAt: null,
129
+ approvedAt: null,
130
+ mergedAt: null,
131
+ reviews: [],
132
+ totalReviews: 0,
133
+ totalFollowups: 0,
134
+ totalBlocking: 0,
135
+ totalWarnings: 0,
136
+ totalSuggestions: 0,
137
+ totalDurationMs: 0,
138
+ averageScore: null,
139
+ latestScore: null,
140
+ autoFollowup: true,
141
+ };
142
+ data.mrs.push(trackedMr);
143
+ saveMrTracking(projectPath, data);
144
+ return trackedMr;
145
+ }
146
+ /**
147
+ * Record a review completion on a MR
148
+ */
149
+ export function recordReviewCompletion(projectPath, mrId, reviewData) {
150
+ const data = loadMrTracking(projectPath);
151
+ const mr = data.mrs.find((m) => m.id === mrId);
152
+ if (!mr)
153
+ return undefined;
154
+ const now = new Date().toISOString();
155
+ // Add review event
156
+ const event = {
157
+ type: reviewData.type,
158
+ timestamp: now,
159
+ durationMs: reviewData.durationMs,
160
+ score: reviewData.score,
161
+ blocking: reviewData.blocking,
162
+ warnings: reviewData.warnings,
163
+ suggestions: reviewData.suggestions ?? 0,
164
+ threadsOpened: reviewData.threadsOpened ?? 0,
165
+ threadsClosed: reviewData.threadsClosed ?? 0,
166
+ };
167
+ mr.reviews.push(event);
168
+ // Update aggregates
169
+ mr.lastReviewAt = now;
170
+ if (reviewData.type === 'review') {
171
+ mr.totalReviews++;
172
+ }
173
+ else {
174
+ mr.totalFollowups++;
175
+ }
176
+ mr.totalBlocking += reviewData.blocking;
177
+ mr.totalWarnings += reviewData.warnings;
178
+ mr.totalSuggestions += reviewData.suggestions ?? 0;
179
+ mr.totalDurationMs += reviewData.durationMs;
180
+ // Update thread counts
181
+ mr.openThreads = Math.max(0, mr.openThreads + (reviewData.threadsOpened ?? 0) - (reviewData.threadsClosed ?? 0));
182
+ mr.totalThreads += reviewData.threadsOpened ?? 0;
183
+ // Update latest score (current state of the MR)
184
+ if (reviewData.score !== null) {
185
+ mr.latestScore = reviewData.score;
186
+ }
187
+ // Recalculate average score (historical metric)
188
+ const reviewsWithScore = mr.reviews.filter((r) => r.score !== null);
189
+ if (reviewsWithScore.length > 0) {
190
+ mr.averageScore = reviewsWithScore.reduce((sum, r) => sum + (r.score ?? 0), 0) / reviewsWithScore.length;
191
+ }
192
+ // Update state based on blocking issues
193
+ if (reviewData.blocking > 0 || mr.openThreads > 0) {
194
+ mr.state = 'pending-fix';
195
+ }
196
+ else {
197
+ mr.state = 'pending-approval';
198
+ }
199
+ saveMrTracking(projectPath, data);
200
+ return mr;
201
+ }
202
+ /**
203
+ * Record a push event on a MR
204
+ */
205
+ export function recordMrPush(projectPath, mrNumber, platform) {
206
+ const data = loadMrTracking(projectPath);
207
+ const mr = data.mrs.find((m) => m.mrNumber === mrNumber && m.platform === platform);
208
+ if (!mr)
209
+ return undefined;
210
+ mr.lastPushAt = new Date().toISOString();
211
+ saveMrTracking(projectPath, data);
212
+ return mr;
213
+ }
214
+ /**
215
+ * Update thread counts for a MR (from GitLab/GitHub API)
216
+ */
217
+ export function updateMrThreads(projectPath, mrId, openThreads, totalThreads) {
218
+ const data = loadMrTracking(projectPath);
219
+ const mr = data.mrs.find((m) => m.id === mrId);
220
+ if (!mr)
221
+ return undefined;
222
+ mr.openThreads = openThreads;
223
+ mr.totalThreads = totalThreads;
224
+ // Update state based on threads
225
+ if (openThreads > 0) {
226
+ mr.state = 'pending-fix';
227
+ }
228
+ else if (mr.state === 'pending-fix') {
229
+ mr.state = 'pending-approval';
230
+ }
231
+ saveMrTracking(projectPath, data);
232
+ return mr;
233
+ }
234
+ /**
235
+ * Mark MR as approved
236
+ */
237
+ export function approveMr(projectPath, mrId) {
238
+ const data = loadMrTracking(projectPath);
239
+ const mr = data.mrs.find((m) => m.id === mrId);
240
+ if (!mr)
241
+ return false;
242
+ mr.state = 'approved';
243
+ mr.approvedAt = new Date().toISOString();
244
+ saveMrTracking(projectPath, data);
245
+ return true;
246
+ }
247
+ /**
248
+ * Mark MR as merged and archive it
249
+ */
250
+ export function markMrMerged(projectPath, mrId) {
251
+ const data = loadMrTracking(projectPath);
252
+ const mr = data.mrs.find((m) => m.id === mrId);
253
+ if (!mr)
254
+ return false;
255
+ mr.state = 'merged';
256
+ mr.mergedAt = new Date().toISOString();
257
+ saveMrTracking(projectPath, data);
258
+ return true;
259
+ }
260
+ /**
261
+ * Mark MR as closed (abandoned)
262
+ */
263
+ export function markMrClosed(projectPath, mrId) {
264
+ const data = loadMrTracking(projectPath);
265
+ const mr = data.mrs.find((m) => m.id === mrId);
266
+ if (!mr)
267
+ return false;
268
+ mr.state = 'closed';
269
+ saveMrTracking(projectPath, data);
270
+ return true;
271
+ }
272
+ /**
273
+ * Remove MR from tracking completely (no history kept)
274
+ */
275
+ export function removeMrFromTracking(projectPath, mrId) {
276
+ const data = loadMrTracking(projectPath);
277
+ if (data.mrs.length === 0)
278
+ return false;
279
+ const index = data.mrs.findIndex((mr) => mr.id === mrId);
280
+ if (index < 0)
281
+ return false;
282
+ data.mrs.splice(index, 1);
283
+ saveMrTracking(projectPath, data);
284
+ return true;
285
+ }
286
+ /**
287
+ * Recompute project stats from current MR data
288
+ */
289
+ export function recomputeProjectStats(projectPath) {
290
+ const data = loadMrTracking(projectPath);
291
+ recalculateStats(data);
292
+ data.lastUpdated = new Date().toISOString();
293
+ const trackingPath = getTrackingPath(projectPath);
294
+ const dir = dirname(trackingPath);
295
+ if (!existsSync(dir)) {
296
+ mkdirSync(dir, { recursive: true });
297
+ }
298
+ writeFileSync(trackingPath, JSON.stringify(data, null, 2), 'utf-8');
299
+ }
300
+ /**
301
+ * Remove MR from active tracking (keeps in history)
302
+ */
303
+ export function archiveMr(projectPath, mrId) {
304
+ const data = loadMrTracking(projectPath);
305
+ const index = data.mrs.findIndex((m) => m.id === mrId);
306
+ if (index < 0)
307
+ return false;
308
+ data.mrs.splice(index, 1);
309
+ saveMrTracking(projectPath, data);
310
+ return true;
311
+ }
312
+ /**
313
+ * Toggle auto-followup for a specific MR
314
+ */
315
+ export function setAutoFollowup(projectPath, mrId, enabled) {
316
+ const data = loadMrTracking(projectPath);
317
+ const mr = data.mrs.find((m) => m.id === mrId);
318
+ if (!mr)
319
+ return null;
320
+ mr.autoFollowup = enabled;
321
+ saveMrTracking(projectPath, data);
322
+ return mr;
323
+ }
324
+ /**
325
+ * Get MRs pending fix (with open threads or blocking issues)
326
+ */
327
+ export function getPendingFixMrs(projectPath) {
328
+ const data = loadMrTracking(projectPath);
329
+ return data.mrs.filter((mr) => mr.state === 'pending-fix');
330
+ }
331
+ /**
332
+ * Get MRs pending approval (all threads resolved)
333
+ */
334
+ export function getPendingApprovalMrs(projectPath) {
335
+ const data = loadMrTracking(projectPath);
336
+ return data.mrs.filter((mr) => mr.state === 'pending-approval');
337
+ }
338
+ /**
339
+ * Get MRs pending initial review
340
+ */
341
+ export function getPendingReviewMrs(projectPath) {
342
+ const data = loadMrTracking(projectPath);
343
+ return data.mrs.filter((mr) => mr.state === 'pending-review');
344
+ }
345
+ /**
346
+ * Check if a MR needs a followup review
347
+ */
348
+ export function needsFollowupReview(projectPath, mrNumber, platform) {
349
+ const data = loadMrTracking(projectPath);
350
+ const mr = data.mrs.find((m) => m.mrNumber === mrNumber && m.platform === platform);
351
+ if (!mr)
352
+ return false;
353
+ if (mr.state !== 'pending-fix')
354
+ return false;
355
+ if (!mr.lastPushAt || !mr.lastReviewAt)
356
+ return false;
357
+ const pushTime = new Date(mr.lastPushAt).getTime();
358
+ const reviewTime = new Date(mr.lastReviewAt).getTime();
359
+ return pushTime > reviewTime;
360
+ }
361
+ /**
362
+ * Get tracking stats for a project
363
+ */
364
+ export function getTrackingStats(projectPath) {
365
+ const data = loadMrTracking(projectPath);
366
+ return data.stats;
367
+ }
368
+ /**
369
+ * Get detailed stats for a specific MR
370
+ */
371
+ export function getMrDetails(projectPath, mrId) {
372
+ const data = loadMrTracking(projectPath);
373
+ return data.mrs.find((m) => m.id === mrId);
374
+ }
375
+ /**
376
+ * Get all active MRs (not merged/closed)
377
+ */
378
+ export function getActiveMrs(projectPath) {
379
+ const data = loadMrTracking(projectPath);
380
+ return data.mrs.filter((mr) => !['merged', 'closed'].includes(mr.state));
381
+ }
382
+ /**
383
+ * Legacy compatibility - track MR after review (calls new functions)
384
+ */
385
+ export function trackMrAfterReview(projectPath, mrInfo, threadCount) {
386
+ const mrId = `${mrInfo.platform}-${mrInfo.project}-${mrInfo.mrNumber}`;
387
+ const data = loadMrTracking(projectPath);
388
+ let mr = data.mrs.find((m) => m.id === mrId);
389
+ if (!mr) {
390
+ // Create with minimal info if not exists
391
+ mr = trackMrAssignment(projectPath, {
392
+ ...mrInfo,
393
+ sourceBranch: 'unknown',
394
+ targetBranch: 'unknown',
395
+ }, { username: 'unknown' });
396
+ }
397
+ // Update thread counts
398
+ updateMrThreads(projectPath, mrId, threadCount.open, threadCount.total);
399
+ return loadMrTracking(projectPath).mrs.find((m) => m.id === mrId);
400
+ }
401
+ /**
402
+ * Sync thread counts from GitLab API for all active MRs
403
+ */
404
+ export async function syncGitLabThreads(projectPath) {
405
+ const data = loadMrTracking(projectPath);
406
+ const gitlabMrs = data.mrs.filter((mr) => mr.platform === 'gitlab' && !['merged', 'closed'].includes(mr.state));
407
+ for (const mr of gitlabMrs) {
408
+ try {
409
+ const threads = fetchGitLabThreads(mr.project, mr.mrNumber);
410
+ if (threads) {
411
+ updateMrThreads(projectPath, mr.id, threads.open, threads.total);
412
+ }
413
+ }
414
+ catch {
415
+ // Silently ignore individual MR sync failures
416
+ }
417
+ }
418
+ }
419
+ /**
420
+ * Fetch thread counts from GitLab API using glab CLI
421
+ */
422
+ function fetchGitLabThreads(project, mrNumber) {
423
+ try {
424
+ // URL-encode the project path
425
+ const encodedProject = encodeURIComponent(project);
426
+ // Fetch discussions from GitLab API
427
+ const result = execSync(`glab api "projects/${encodedProject}/merge_requests/${mrNumber}/discussions"`, { encoding: 'utf-8', timeout: 10000 });
428
+ const discussions = JSON.parse(result);
429
+ let total = 0;
430
+ let open = 0;
431
+ let resolvable = 0;
432
+ for (const discussion of discussions) {
433
+ // Skip system notes (not real discussions)
434
+ if (discussion.individual_note)
435
+ continue;
436
+ // Count resolvable threads (code review comments)
437
+ const notes = discussion.notes || [];
438
+ const firstNote = notes[0];
439
+ if (firstNote?.resolvable) {
440
+ resolvable++;
441
+ total++;
442
+ // Check if thread is unresolved
443
+ if (!firstNote.resolved) {
444
+ open++;
445
+ }
446
+ }
447
+ }
448
+ return { open, total, resolvable };
449
+ }
450
+ catch {
451
+ return null;
452
+ }
453
+ }
454
+ /**
455
+ * Sync a single MR's threads from GitLab or GitHub
456
+ */
457
+ export function syncSingleMrThreads(projectPath, mrId) {
458
+ const data = loadMrTracking(projectPath);
459
+ const mr = data.mrs.find((m) => m.id === mrId);
460
+ if (!mr) {
461
+ return null;
462
+ }
463
+ let threads = null;
464
+ if (mr.platform === 'gitlab') {
465
+ threads = fetchGitLabThreads(mr.project, mr.mrNumber);
466
+ }
467
+ else if (mr.platform === 'github') {
468
+ threads = fetchGitHubThreads(mr.project, mr.mrNumber);
469
+ }
470
+ if (threads) {
471
+ return updateMrThreads(projectPath, mr.id, threads.open, threads.total) || null;
472
+ }
473
+ return null;
474
+ }
475
+ /**
476
+ * Sync thread counts from GitHub API for all active PRs
477
+ */
478
+ export async function syncGitHubThreads(projectPath) {
479
+ const data = loadMrTracking(projectPath);
480
+ const githubPrs = data.mrs.filter((mr) => mr.platform === 'github' && !['merged', 'closed'].includes(mr.state));
481
+ for (const pr of githubPrs) {
482
+ try {
483
+ const threads = fetchGitHubThreads(pr.project, pr.mrNumber);
484
+ if (threads) {
485
+ updateMrThreads(projectPath, pr.id, threads.open, threads.total);
486
+ }
487
+ }
488
+ catch {
489
+ // Silently ignore individual PR sync failures
490
+ }
491
+ }
492
+ }
493
+ /**
494
+ * Fetch thread counts from GitHub API using gh CLI
495
+ */
496
+ function fetchGitHubThreads(repo, prNumber) {
497
+ try {
498
+ // Fetch review threads from GitHub API
499
+ const result = execSync(`gh api "repos/${repo}/pulls/${prNumber}/comments"`, { encoding: 'utf-8', timeout: 10000 });
500
+ const comments = JSON.parse(result);
501
+ // Group comments by thread (in_reply_to_id)
502
+ const threadIds = new Set();
503
+ const resolvedThreads = new Set();
504
+ for (const comment of comments) {
505
+ // Each top-level comment starts a thread
506
+ if (!comment.in_reply_to_id) {
507
+ threadIds.add(comment.id);
508
+ }
509
+ }
510
+ // Check review state (approved/changes_requested)
511
+ try {
512
+ const reviewsResult = execSync(`gh api "repos/${repo}/pulls/${prNumber}/reviews"`, { encoding: 'utf-8', timeout: 10000 });
513
+ const reviews = JSON.parse(reviewsResult);
514
+ // Count pending review threads (not approved yet)
515
+ let _pendingReviews = 0;
516
+ for (const review of reviews) {
517
+ if (review.state === 'CHANGES_REQUESTED' || review.state === 'COMMENTED') {
518
+ _pendingReviews++;
519
+ }
520
+ }
521
+ }
522
+ catch {
523
+ // Ignore review fetch errors
524
+ }
525
+ const total = threadIds.size;
526
+ const open = total - resolvedThreads.size;
527
+ return { open, total };
528
+ }
529
+ catch {
530
+ return null;
531
+ }
532
+ }
533
+ /**
534
+ * Sync all platforms' threads
535
+ */
536
+ export async function syncAllThreads(projectPath) {
537
+ await syncGitLabThreads(projectPath);
538
+ await syncGitHubThreads(projectPath);
539
+ }
540
+ //# sourceMappingURL=mrTrackingService.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mrTrackingService.js","sourceRoot":"","sources":["../../src/services/mrTrackingService.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ import type { ReviewContextGateway } from '../entities/reviewContext/reviewContext.gateway.js';
2
+ import type { ReviewContextProgress } from '../entities/reviewContext/reviewContext.js';
3
+ export type ProgressCallback = (progress: ReviewContextProgress) => void;
4
+ export declare class ReviewContextWatcherService {
5
+ private gateway;
6
+ private pollingIntervalMs;
7
+ private watchers;
8
+ private lastProgress;
9
+ constructor(gateway: ReviewContextGateway, pollingIntervalMs?: number);
10
+ start(localPath: string, mergeRequestId: string, callback: ProgressCallback): void;
11
+ isWatching(mergeRequestId: string): boolean;
12
+ stop(mergeRequestId: string): void;
13
+ stopAll(): void;
14
+ }
15
+ //# sourceMappingURL=reviewContextWatcher.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reviewContextWatcher.service.d.ts","sourceRoot":"","sources":["../../src/services/reviewContextWatcher.service.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,oDAAoD,CAAA;AAC9F,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,4CAA4C,CAAA;AAEvF,MAAM,MAAM,gBAAgB,GAAG,CAAC,QAAQ,EAAE,qBAAqB,KAAK,IAAI,CAAA;AAIxE,qBAAa,2BAA2B;IAKpC,OAAO,CAAC,OAAO;IACf,OAAO,CAAC,iBAAiB;IAL3B,OAAO,CAAC,QAAQ,CAAoC;IACpD,OAAO,CAAC,YAAY,CAA4B;gBAGtC,OAAO,EAAE,oBAAoB,EAC7B,iBAAiB,SAA8B;IAGzD,KAAK,CAAC,SAAS,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,EAAE,QAAQ,EAAE,gBAAgB,GAAG,IAAI;IAkBlF,UAAU,CAAC,cAAc,EAAE,MAAM,GAAG,OAAO;IAI3C,IAAI,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI;IASlC,OAAO,IAAI,IAAI;CAKhB"}
@@ -0,0 +1,44 @@
1
+ const DEFAULT_POLLING_INTERVAL_MS = 500;
2
+ export class ReviewContextWatcherService {
3
+ gateway;
4
+ pollingIntervalMs;
5
+ watchers = new Map();
6
+ lastProgress = new Map();
7
+ constructor(gateway, pollingIntervalMs = DEFAULT_POLLING_INTERVAL_MS) {
8
+ this.gateway = gateway;
9
+ this.pollingIntervalMs = pollingIntervalMs;
10
+ }
11
+ start(localPath, mergeRequestId, callback) {
12
+ const interval = setInterval(() => {
13
+ const context = this.gateway.read(localPath, mergeRequestId);
14
+ if (context) {
15
+ const progressKey = JSON.stringify(context.progress);
16
+ if (progressKey !== this.lastProgress.get(mergeRequestId)) {
17
+ this.lastProgress.set(mergeRequestId, progressKey);
18
+ callback(context.progress);
19
+ if (context.progress.phase === 'completed') {
20
+ this.stop(mergeRequestId);
21
+ }
22
+ }
23
+ }
24
+ }, this.pollingIntervalMs);
25
+ this.watchers.set(mergeRequestId, interval);
26
+ }
27
+ isWatching(mergeRequestId) {
28
+ return this.watchers.has(mergeRequestId);
29
+ }
30
+ stop(mergeRequestId) {
31
+ const interval = this.watchers.get(mergeRequestId);
32
+ if (interval) {
33
+ clearInterval(interval);
34
+ this.watchers.delete(mergeRequestId);
35
+ this.lastProgress.delete(mergeRequestId);
36
+ }
37
+ }
38
+ stopAll() {
39
+ for (const [mergeRequestId] of this.watchers) {
40
+ this.stop(mergeRequestId);
41
+ }
42
+ }
43
+ }
44
+ //# sourceMappingURL=reviewContextWatcher.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"reviewContextWatcher.service.js","sourceRoot":"","sources":["../../src/services/reviewContextWatcher.service.ts"],"names":[],"mappings":"AAKA,MAAM,2BAA2B,GAAG,GAAG,CAAA;AAEvC,MAAM,OAAO,2BAA2B;IAK5B;IACA;IALF,QAAQ,GAAG,IAAI,GAAG,EAA0B,CAAA;IAC5C,YAAY,GAAG,IAAI,GAAG,EAAkB,CAAA;IAEhD,YACU,OAA6B,EAC7B,oBAAoB,2BAA2B;QAD/C,YAAO,GAAP,OAAO,CAAsB;QAC7B,sBAAiB,GAAjB,iBAAiB,CAA8B;IACtD,CAAC;IAEJ,KAAK,CAAC,SAAiB,EAAE,cAAsB,EAAE,QAA0B;QACzE,MAAM,QAAQ,GAAG,WAAW,CAAC,GAAG,EAAE;YAChC,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,EAAE,cAAc,CAAC,CAAA;YAC5D,IAAI,OAAO,EAAE,CAAC;gBACZ,MAAM,WAAW,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;gBACpD,IAAI,WAAW,KAAK,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,cAAc,CAAC,EAAE,CAAC;oBAC1D,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,cAAc,EAAE,WAAW,CAAC,CAAA;oBAClD,QAAQ,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;oBAE1B,IAAI,OAAO,CAAC,QAAQ,CAAC,KAAK,KAAK,WAAW,EAAE,CAAC;wBAC3C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;oBAC3B,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAA;QAC1B,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAA;IAC7C,CAAC;IAED,UAAU,CAAC,cAAsB;QAC/B,OAAO,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;IAC1C,CAAC;IAED,IAAI,CAAC,cAAsB;QACzB,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC,CAAA;QAClD,IAAI,QAAQ,EAAE,CAAC;YACb,aAAa,CAAC,QAAQ,CAAC,CAAA;YACvB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;YACpC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;QAC1C,CAAC;IACH,CAAC;IAED,OAAO;QACL,KAAK,MAAM,CAAC,cAAc,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAC7C,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAA;QAC3B,CAAC;IACH,CAAC;CACF"}
@@ -0,0 +1,3 @@
1
+ export { getModel, setModel, getSettings, } from '../frameworks/settings/runtimeSettings.js';
2
+ export type { ClaudeModel } from '../frameworks/settings/runtimeSettings.js';
3
+ //# sourceMappingURL=runtimeSettings.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runtimeSettings.d.ts","sourceRoot":"","sources":["../../src/services/runtimeSettings.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,QAAQ,EACR,QAAQ,EACR,WAAW,GACZ,MAAM,2CAA2C,CAAC;AAEnD,YAAY,EAAE,WAAW,EAAE,MAAM,2CAA2C,CAAC"}
@@ -0,0 +1,4 @@
1
+ // Strangler Fig: Re-export from new location
2
+ // This file will be removed once all imports are updated
3
+ export { getModel, setModel, getSettings, } from '../frameworks/settings/runtimeSettings.js';
4
+ //# sourceMappingURL=runtimeSettings.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"runtimeSettings.js","sourceRoot":"","sources":["../../src/services/runtimeSettings.ts"],"names":[],"mappings":"AAAA,6CAA6C;AAC7C,yDAAyD;AACzD,OAAO,EACL,QAAQ,EACR,QAAQ,EACR,WAAW,GACZ,MAAM,2CAA2C,CAAC"}