codingbuddy 4.5.0 → 5.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (236) hide show
  1. package/dist/src/agent/agent.module.js +3 -1
  2. package/dist/src/agent/agent.module.js.map +1 -1
  3. package/dist/src/agent/agent.service.d.ts +11 -4
  4. package/dist/src/agent/agent.service.js +81 -13
  5. package/dist/src/agent/agent.service.js.map +1 -1
  6. package/dist/src/agent/agent.types.d.ts +41 -1
  7. package/dist/src/agent/agent.types.js.map +1 -1
  8. package/dist/src/collaboration/discussion-engine.d.ts +14 -0
  9. package/dist/src/collaboration/discussion-engine.js +49 -0
  10. package/dist/src/collaboration/discussion-engine.js.map +1 -0
  11. package/dist/src/collaboration/index.d.ts +5 -0
  12. package/dist/src/collaboration/index.js +22 -0
  13. package/dist/src/collaboration/index.js.map +1 -0
  14. package/dist/src/collaboration/opinion-adapter.d.ts +14 -0
  15. package/dist/src/collaboration/opinion-adapter.js +56 -0
  16. package/dist/src/collaboration/opinion-adapter.js.map +1 -0
  17. package/dist/src/collaboration/terminal-formatter.d.ts +5 -0
  18. package/dist/src/collaboration/terminal-formatter.js +57 -0
  19. package/dist/src/collaboration/terminal-formatter.js.map +1 -0
  20. package/dist/src/collaboration/types.d.ts +50 -0
  21. package/dist/src/collaboration/types.js +53 -0
  22. package/dist/src/collaboration/types.js.map +1 -0
  23. package/dist/src/config/config.schema.d.ts +14 -0
  24. package/dist/src/config/config.schema.js +7 -0
  25. package/dist/src/config/config.schema.js.map +1 -1
  26. package/dist/src/context/context-archive.service.d.ts +14 -0
  27. package/dist/src/context/context-archive.service.js +257 -0
  28. package/dist/src/context/context-archive.service.js.map +1 -0
  29. package/dist/src/context/context-archive.types.d.ts +37 -0
  30. package/dist/src/context/context-archive.types.js +47 -0
  31. package/dist/src/context/context-archive.types.js.map +1 -0
  32. package/dist/src/context/context-document.service.d.ts +4 -2
  33. package/dist/src/context/context-document.service.js +24 -4
  34. package/dist/src/context/context-document.service.js.map +1 -1
  35. package/dist/src/context/context-document.types.d.ts +18 -0
  36. package/dist/src/context/context-document.types.js +13 -1
  37. package/dist/src/context/context-document.types.js.map +1 -1
  38. package/dist/src/context/context-parser.utils.js +32 -0
  39. package/dist/src/context/context-parser.utils.js.map +1 -1
  40. package/dist/src/context/context-serializer.utils.d.ts +3 -2
  41. package/dist/src/context/context-serializer.utils.js +25 -1
  42. package/dist/src/context/context-serializer.utils.js.map +1 -1
  43. package/dist/src/context/context.module.js +3 -2
  44. package/dist/src/context/context.module.js.map +1 -1
  45. package/dist/src/context/index.d.ts +1 -0
  46. package/dist/src/context/index.js +1 -0
  47. package/dist/src/context/index.js.map +1 -1
  48. package/dist/src/impact/impact-event.service.d.ts +8 -0
  49. package/dist/src/impact/impact-event.service.js +53 -0
  50. package/dist/src/impact/impact-event.service.js.map +1 -0
  51. package/dist/src/impact/impact-report.service.d.ts +7 -0
  52. package/dist/src/impact/impact-report.service.js +92 -0
  53. package/dist/src/impact/impact-report.service.js.map +1 -0
  54. package/dist/src/impact/impact.module.d.ts +2 -0
  55. package/dist/src/impact/impact.module.js +22 -0
  56. package/dist/src/impact/impact.module.js.map +1 -0
  57. package/dist/src/impact/impact.types.d.ts +32 -0
  58. package/dist/src/impact/impact.types.js +5 -0
  59. package/dist/src/impact/impact.types.js.map +1 -0
  60. package/dist/src/impact/index.d.ts +4 -0
  61. package/dist/src/impact/index.js +25 -0
  62. package/dist/src/impact/index.js.map +1 -0
  63. package/dist/src/keyword/diff-analyzer.d.ts +19 -0
  64. package/dist/src/keyword/diff-analyzer.js +127 -0
  65. package/dist/src/keyword/diff-analyzer.js.map +1 -0
  66. package/dist/src/keyword/explicit-pattern-matcher.d.ts +3 -0
  67. package/dist/src/keyword/explicit-pattern-matcher.js +34 -0
  68. package/dist/src/keyword/explicit-pattern-matcher.js.map +1 -0
  69. package/dist/src/keyword/keyword.module.js +17 -1
  70. package/dist/src/keyword/keyword.module.js.map +1 -1
  71. package/dist/src/keyword/keyword.service.d.ts +3 -0
  72. package/dist/src/keyword/keyword.service.js +33 -3
  73. package/dist/src/keyword/keyword.service.js.map +1 -1
  74. package/dist/src/keyword/keyword.types.d.ts +29 -1
  75. package/dist/src/keyword/keyword.types.js +34 -1
  76. package/dist/src/keyword/keyword.types.js.map +1 -1
  77. package/dist/src/keyword/primary-agent-resolver.d.ts +7 -3
  78. package/dist/src/keyword/primary-agent-resolver.js +24 -2
  79. package/dist/src/keyword/primary-agent-resolver.js.map +1 -1
  80. package/dist/src/keyword/strategies/act-agent.strategy.js +16 -0
  81. package/dist/src/keyword/strategies/act-agent.strategy.js.map +1 -1
  82. package/dist/src/keyword/strategies/index.d.ts +1 -1
  83. package/dist/src/keyword/strategies/index.js.map +1 -1
  84. package/dist/src/keyword/strategies/resolution-strategy.interface.d.ts +5 -0
  85. package/dist/src/keyword/visual-data.builder.d.ts +10 -0
  86. package/dist/src/keyword/visual-data.builder.js +62 -0
  87. package/dist/src/keyword/visual-data.builder.js.map +1 -0
  88. package/dist/src/mcp/handlers/agent.handler.d.ts +4 -1
  89. package/dist/src/mcp/handlers/agent.handler.js +59 -6
  90. package/dist/src/mcp/handlers/agent.handler.js.map +1 -1
  91. package/dist/src/mcp/handlers/checklist-context.handler.d.ts +3 -1
  92. package/dist/src/mcp/handlers/checklist-context.handler.js +13 -2
  93. package/dist/src/mcp/handlers/checklist-context.handler.js.map +1 -1
  94. package/dist/src/mcp/handlers/context-archive.handler.d.ts +14 -0
  95. package/dist/src/mcp/handlers/context-archive.handler.js +136 -0
  96. package/dist/src/mcp/handlers/context-archive.handler.js.map +1 -0
  97. package/dist/src/mcp/handlers/context-document.handler.d.ts +6 -1
  98. package/dist/src/mcp/handlers/context-document.handler.js +113 -12
  99. package/dist/src/mcp/handlers/context-document.handler.js.map +1 -1
  100. package/dist/src/mcp/handlers/discussion.handler.d.ts +14 -0
  101. package/dist/src/mcp/handlers/discussion.handler.js +168 -0
  102. package/dist/src/mcp/handlers/discussion.handler.js.map +1 -0
  103. package/dist/src/mcp/handlers/discussion.types.d.ts +18 -0
  104. package/dist/src/mcp/handlers/discussion.types.js +11 -0
  105. package/dist/src/mcp/handlers/discussion.types.js.map +1 -0
  106. package/dist/src/mcp/handlers/impact.handler.d.ts +11 -0
  107. package/dist/src/mcp/handlers/impact.handler.js +53 -0
  108. package/dist/src/mcp/handlers/impact.handler.js.map +1 -0
  109. package/dist/src/mcp/handlers/index.d.ts +6 -0
  110. package/dist/src/mcp/handlers/index.js +13 -1
  111. package/dist/src/mcp/handlers/index.js.map +1 -1
  112. package/dist/src/mcp/handlers/mode.handler.d.ts +7 -1
  113. package/dist/src/mcp/handlers/mode.handler.js +109 -3
  114. package/dist/src/mcp/handlers/mode.handler.js.map +1 -1
  115. package/dist/src/mcp/handlers/pipeline.handler.d.ts +14 -0
  116. package/dist/src/mcp/handlers/pipeline.handler.js +137 -0
  117. package/dist/src/mcp/handlers/pipeline.handler.js.map +1 -0
  118. package/dist/src/mcp/handlers/rule-insights.handler.d.ts +14 -0
  119. package/dist/src/mcp/handlers/rule-insights.handler.js +78 -0
  120. package/dist/src/mcp/handlers/rule-insights.handler.js.map +1 -0
  121. package/dist/src/mcp/handlers/rules.handler.d.ts +3 -1
  122. package/dist/src/mcp/handlers/rules.handler.js +14 -2
  123. package/dist/src/mcp/handlers/rules.handler.js.map +1 -1
  124. package/dist/src/mcp/mcp.module.js +10 -0
  125. package/dist/src/mcp/mcp.module.js.map +1 -1
  126. package/dist/src/parallel-validation/extract-file-paths.d.ts +1 -0
  127. package/dist/src/parallel-validation/extract-file-paths.js +19 -0
  128. package/dist/src/parallel-validation/extract-file-paths.js.map +1 -0
  129. package/dist/src/parallel-validation/index.d.ts +5 -0
  130. package/dist/src/parallel-validation/index.js +12 -0
  131. package/dist/src/parallel-validation/index.js.map +1 -0
  132. package/dist/src/parallel-validation/overlap-matrix.d.ts +10 -0
  133. package/dist/src/parallel-validation/overlap-matrix.js +23 -0
  134. package/dist/src/parallel-validation/overlap-matrix.js.map +1 -0
  135. package/dist/src/parallel-validation/parallel-validation.handler.d.ts +8 -0
  136. package/dist/src/parallel-validation/parallel-validation.handler.js +84 -0
  137. package/dist/src/parallel-validation/parallel-validation.handler.js.map +1 -0
  138. package/dist/src/parallel-validation/parallel-validation.types.d.ts +12 -0
  139. package/dist/src/parallel-validation/parallel-validation.types.js +3 -0
  140. package/dist/src/parallel-validation/parallel-validation.types.js.map +1 -0
  141. package/dist/src/parallel-validation/wave-splitter.d.ts +2 -0
  142. package/dist/src/parallel-validation/wave-splitter.js +39 -0
  143. package/dist/src/parallel-validation/wave-splitter.js.map +1 -0
  144. package/dist/src/pipeline/index.d.ts +5 -0
  145. package/dist/src/pipeline/index.js +14 -0
  146. package/dist/src/pipeline/index.js.map +1 -0
  147. package/dist/src/pipeline/pipeline.executors.d.ts +2 -0
  148. package/dist/src/pipeline/pipeline.executors.js +79 -0
  149. package/dist/src/pipeline/pipeline.executors.js.map +1 -0
  150. package/dist/src/pipeline/pipeline.module.d.ts +2 -0
  151. package/dist/src/pipeline/pipeline.module.js +21 -0
  152. package/dist/src/pipeline/pipeline.module.js.map +1 -0
  153. package/dist/src/pipeline/pipeline.service.d.ts +8 -0
  154. package/dist/src/pipeline/pipeline.service.js +89 -0
  155. package/dist/src/pipeline/pipeline.service.js.map +1 -0
  156. package/dist/src/pipeline/pipeline.types.d.ts +47 -0
  157. package/dist/src/pipeline/pipeline.types.js +33 -0
  158. package/dist/src/pipeline/pipeline.types.js.map +1 -0
  159. package/dist/src/rules/rule-insights.service.d.ts +31 -0
  160. package/dist/src/rules/rule-insights.service.js +102 -0
  161. package/dist/src/rules/rule-insights.service.js.map +1 -0
  162. package/dist/src/rules/rule-tracker.d.ts +24 -0
  163. package/dist/src/rules/rule-tracker.js +74 -0
  164. package/dist/src/rules/rule-tracker.js.map +1 -0
  165. package/dist/src/rules/rules.module.js +3 -2
  166. package/dist/src/rules/rules.module.js.map +1 -1
  167. package/dist/src/shared/event-bridge-reader.d.ts +17 -0
  168. package/dist/src/shared/event-bridge-reader.js +56 -0
  169. package/dist/src/shared/event-bridge-reader.js.map +1 -0
  170. package/dist/src/shared/version.d.ts +1 -1
  171. package/dist/src/shared/version.js +1 -1
  172. package/dist/src/skill/i18n/keywords.types.d.ts +4 -2
  173. package/dist/src/skill/i18n/keywords.types.js +3 -0
  174. package/dist/src/skill/i18n/keywords.types.js.map +1 -1
  175. package/dist/src/tui/components/ActModeScreen.d.ts +10 -0
  176. package/dist/src/tui/components/ActModeScreen.js +25 -0
  177. package/dist/src/tui/components/ActModeScreen.js.map +1 -0
  178. package/dist/src/tui/components/AgentDiscussionPanel.d.ts +8 -0
  179. package/dist/src/tui/components/AgentDiscussionPanel.js +115 -0
  180. package/dist/src/tui/components/AgentDiscussionPanel.js.map +1 -0
  181. package/dist/src/tui/components/AgentDiscussionPanel.spec.d.ts +1 -0
  182. package/dist/src/tui/components/AgentDiscussionPanel.spec.js +229 -0
  183. package/dist/src/tui/components/AgentDiscussionPanel.spec.js.map +1 -0
  184. package/dist/src/tui/components/EvalModeScreen.d.ts +8 -0
  185. package/dist/src/tui/components/EvalModeScreen.js +21 -0
  186. package/dist/src/tui/components/EvalModeScreen.js.map +1 -0
  187. package/dist/src/tui/components/FlowMap.spec.js.map +1 -1
  188. package/dist/src/tui/components/FocusedAgentPanel.js +1 -1
  189. package/dist/src/tui/components/FocusedAgentPanel.js.map +1 -1
  190. package/dist/src/tui/components/FocusedAgentPanel.spec.js +1 -3
  191. package/dist/src/tui/components/FocusedAgentPanel.spec.js.map +1 -1
  192. package/dist/src/tui/components/HeaderBar.js +3 -3
  193. package/dist/src/tui/components/HeaderBar.js.map +1 -1
  194. package/dist/src/tui/components/ModeScreenRouter.d.ts +13 -0
  195. package/dist/src/tui/components/ModeScreenRouter.js +51 -0
  196. package/dist/src/tui/components/ModeScreenRouter.js.map +1 -0
  197. package/dist/src/tui/components/PlanModeScreen.d.ts +10 -0
  198. package/dist/src/tui/components/PlanModeScreen.js +24 -0
  199. package/dist/src/tui/components/PlanModeScreen.js.map +1 -0
  200. package/dist/src/tui/components/SessionDashboard.d.ts +17 -0
  201. package/dist/src/tui/components/SessionDashboard.js +58 -0
  202. package/dist/src/tui/components/SessionDashboard.js.map +1 -0
  203. package/dist/src/tui/components/act-screen.pure.d.ts +12 -0
  204. package/dist/src/tui/components/act-screen.pure.js +93 -0
  205. package/dist/src/tui/components/act-screen.pure.js.map +1 -0
  206. package/dist/src/tui/components/agent-discussion-panel.pure.d.ts +55 -0
  207. package/dist/src/tui/components/agent-discussion-panel.pure.js +201 -0
  208. package/dist/src/tui/components/agent-discussion-panel.pure.js.map +1 -0
  209. package/dist/src/tui/components/eval-screen.pure.d.ts +13 -0
  210. package/dist/src/tui/components/eval-screen.pure.js +76 -0
  211. package/dist/src/tui/components/eval-screen.pure.js.map +1 -0
  212. package/dist/src/tui/components/index.d.ts +16 -0
  213. package/dist/src/tui/components/index.js +48 -1
  214. package/dist/src/tui/components/index.js.map +1 -1
  215. package/dist/src/tui/components/plan-screen.pure.d.ts +9 -0
  216. package/dist/src/tui/components/plan-screen.pure.js +61 -0
  217. package/dist/src/tui/components/plan-screen.pure.js.map +1 -0
  218. package/dist/src/tui/components/session-dashboard.pure.d.ts +43 -0
  219. package/dist/src/tui/components/session-dashboard.pure.js +182 -0
  220. package/dist/src/tui/components/session-dashboard.pure.js.map +1 -0
  221. package/dist/src/tui/dashboard-app.js +3 -3
  222. package/dist/src/tui/dashboard-app.js.map +1 -1
  223. package/dist/src/tui/dashboard-types.d.ts +49 -0
  224. package/dist/src/tui/dashboard-types.js +20 -1
  225. package/dist/src/tui/dashboard-types.js.map +1 -1
  226. package/dist/src/tui/events/index.d.ts +1 -1
  227. package/dist/src/tui/events/index.js.map +1 -1
  228. package/dist/src/tui/events/types.d.ts +29 -1
  229. package/dist/src/tui/events/types.js +5 -0
  230. package/dist/src/tui/events/types.js.map +1 -1
  231. package/dist/src/tui/hooks/use-dashboard-state.d.ts +16 -1
  232. package/dist/src/tui/hooks/use-dashboard-state.js +70 -1
  233. package/dist/src/tui/hooks/use-dashboard-state.js.map +1 -1
  234. package/dist/src/tui-bundle.mjs +1023 -125
  235. package/dist/tsconfig.build.tsbuildinfo +1 -1
  236. package/package.json +14 -14
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.RuleInsightsHandler = void 0;
13
+ const common_1 = require("@nestjs/common");
14
+ const path_1 = require("path");
15
+ const abstract_handler_1 = require("./abstract-handler");
16
+ const response_utils_1 = require("../response.utils");
17
+ const rule_insights_service_1 = require("../../rules/rule-insights.service");
18
+ const rule_tracker_1 = require("../../rules/rule-tracker");
19
+ const rules_service_1 = require("../../rules/rules.service");
20
+ const validation_constants_1 = require("../../shared/validation.constants");
21
+ const DEFAULT_STATS_PATH = (0, path_1.join)(process.cwd(), 'docs', 'codingbuddy', 'rule-stats.json');
22
+ let RuleInsightsHandler = class RuleInsightsHandler extends abstract_handler_1.AbstractHandler {
23
+ constructor(insightsService, rulesService) {
24
+ super();
25
+ this.insightsService = insightsService;
26
+ this.rulesService = rulesService;
27
+ }
28
+ getHandledTools() {
29
+ return ['get_rule_insights'];
30
+ }
31
+ async handleTool(toolName, args) {
32
+ const statsPath = (0, validation_constants_1.extractOptionalString)(args, 'statsPath') ?? DEFAULT_STATS_PATH;
33
+ let stats = {};
34
+ try {
35
+ const tracker = await rule_tracker_1.RuleTracker.fromFile(statsPath);
36
+ stats = tracker.getStats();
37
+ }
38
+ catch {
39
+ }
40
+ const allRuleNames = await this.getAllRuleNames();
41
+ const insights = this.insightsService.generateInsights(stats, allRuleNames);
42
+ return (0, response_utils_1.createJsonResponse)(insights);
43
+ }
44
+ getToolDefinitions() {
45
+ return [
46
+ {
47
+ name: 'get_rule_insights',
48
+ description: 'Analyze accumulated rule tracking data to provide effectiveness insights: violation frequency, unused/redundant rules, trend analysis, and improvement suggestions',
49
+ inputSchema: {
50
+ type: 'object',
51
+ properties: {
52
+ statsPath: {
53
+ type: 'string',
54
+ description: 'Path to rule-stats.json file. Defaults to docs/codingbuddy/rule-stats.json',
55
+ },
56
+ },
57
+ required: [],
58
+ },
59
+ },
60
+ ];
61
+ }
62
+ async getAllRuleNames() {
63
+ try {
64
+ const results = await this.rulesService.searchRules('*');
65
+ return results.map(r => r.file.replace(/^rules\//, '').replace(/\.md$/, ''));
66
+ }
67
+ catch {
68
+ return [];
69
+ }
70
+ }
71
+ };
72
+ exports.RuleInsightsHandler = RuleInsightsHandler;
73
+ exports.RuleInsightsHandler = RuleInsightsHandler = __decorate([
74
+ (0, common_1.Injectable)(),
75
+ __metadata("design:paramtypes", [rule_insights_service_1.RuleInsightsService,
76
+ rules_service_1.RulesService])
77
+ ], RuleInsightsHandler);
78
+ //# sourceMappingURL=rule-insights.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rule-insights.handler.js","sourceRoot":"","sources":["../../../../src/mcp/handlers/rule-insights.handler.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,+BAA4B;AAC5B,yDAAqD;AAGrD,sDAAuD;AACvD,6EAAwE;AACxE,2DAAuD;AACvD,6DAAyD;AACzD,4EAA0E;AAE1E,MAAM,kBAAkB,GAAG,IAAA,WAAI,EAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,iBAAiB,CAAC,CAAC;AAGlF,IAAM,mBAAmB,GAAzB,MAAM,mBAAoB,SAAQ,kCAAe;IACtD,YACmB,eAAoC,EACpC,YAA0B;QAE3C,KAAK,EAAE,CAAC;QAHS,oBAAe,GAAf,eAAe,CAAqB;QACpC,iBAAY,GAAZ,YAAY,CAAc;IAG7C,CAAC;IAES,eAAe;QACvB,OAAO,CAAC,mBAAmB,CAAC,CAAC;IAC/B,CAAC;IAES,KAAK,CAAC,UAAU,CACxB,QAAgB,EAChB,IAAyC;QAEzC,MAAM,SAAS,GAAG,IAAA,4CAAqB,EAAC,IAAI,EAAE,WAAW,CAAC,IAAI,kBAAkB,CAAC;QAEjF,IAAI,KAAK,GAAwD,EAAE,CAAC;QACpE,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,0BAAW,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YACtD,KAAK,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;QAC7B,CAAC;QAAC,MAAM,CAAC;QAET,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,IAAI,CAAC,eAAe,EAAE,CAAC;QAClD,MAAM,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,gBAAgB,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;QAE5E,OAAO,IAAA,mCAAkB,EAAC,QAAQ,CAAC,CAAC;IACtC,CAAC;IAED,kBAAkB;QAChB,OAAO;YACL;gBACE,IAAI,EAAE,mBAAmB;gBACzB,WAAW,EACT,oKAAoK;gBACtK,WAAW,EAAE;oBACX,IAAI,EAAE,QAAiB;oBACvB,UAAU,EAAE;wBACV,SAAS,EAAE;4BACT,IAAI,EAAE,QAAQ;4BACd,WAAW,EACT,4EAA4E;yBAC/E;qBACF;oBACD,QAAQ,EAAE,EAAE;iBACb;aACF;SACF,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,eAAe;QAC3B,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;YACzD,OAAO,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,EAAE,CAAC,CAAC,CAAC;QAC/E,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;CACF,CAAA;AA7DY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,mBAAU,GAAE;qCAGyB,2CAAmB;QACtB,4BAAY;GAHlC,mBAAmB,CA6D/B"}
@@ -3,10 +3,12 @@ import type { ToolResponse } from '../response.utils';
3
3
  import { AbstractHandler } from './abstract-handler';
4
4
  import { RulesService } from '../../rules/rules.service';
5
5
  import { ModelResolverService } from '../../model';
6
+ import { ImpactEventService } from '../../impact';
6
7
  export declare class RulesHandler extends AbstractHandler {
7
8
  private readonly rulesService;
8
9
  private readonly modelResolverService;
9
- constructor(rulesService: RulesService, modelResolverService: ModelResolverService);
10
+ private readonly impactEventService;
11
+ constructor(rulesService: RulesService, modelResolverService: ModelResolverService, impactEventService: ImpactEventService);
10
12
  protected getHandledTools(): string[];
11
13
  protected handleTool(toolName: string, args: Record<string, unknown> | undefined): Promise<ToolResponse>;
12
14
  getToolDefinitions(): ToolDefinition[];
@@ -16,11 +16,13 @@ const rules_service_1 = require("../../rules/rules.service");
16
16
  const response_utils_1 = require("../response.utils");
17
17
  const model_1 = require("../../model");
18
18
  const validation_constants_1 = require("../../shared/validation.constants");
19
+ const impact_1 = require("../../impact");
19
20
  let RulesHandler = class RulesHandler extends abstract_handler_1.AbstractHandler {
20
- constructor(rulesService, modelResolverService) {
21
+ constructor(rulesService, modelResolverService, impactEventService) {
21
22
  super();
22
23
  this.rulesService = rulesService;
23
24
  this.modelResolverService = modelResolverService;
25
+ this.impactEventService = impactEventService;
24
26
  }
25
27
  getHandledTools() {
26
28
  return ['search_rules', 'get_agent_details'];
@@ -67,6 +69,15 @@ let RulesHandler = class RulesHandler extends abstract_handler_1.AbstractHandler
67
69
  return (0, response_utils_1.createErrorResponse)('Missing required parameter: query');
68
70
  }
69
71
  const results = await this.rulesService.searchRules(query);
72
+ try {
73
+ const count = Array.isArray(results) ? results.length : 0;
74
+ this.impactEventService.logEvent('default', 'rule_matched', {
75
+ count,
76
+ detail: query,
77
+ });
78
+ }
79
+ catch {
80
+ }
70
81
  return (0, response_utils_1.createJsonResponse)(results);
71
82
  }
72
83
  async handleGetAgentDetails(args) {
@@ -91,6 +102,7 @@ exports.RulesHandler = RulesHandler;
91
102
  exports.RulesHandler = RulesHandler = __decorate([
92
103
  (0, common_1.Injectable)(),
93
104
  __metadata("design:paramtypes", [rules_service_1.RulesService,
94
- model_1.ModelResolverService])
105
+ model_1.ModelResolverService,
106
+ impact_1.ImpactEventService])
95
107
  ], RulesHandler);
96
108
  //# sourceMappingURL=rules.handler.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"rules.handler.js","sourceRoot":"","sources":["../../../../src/mcp/handlers/rules.handler.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAG5C,yDAAqD;AACrD,6DAAyD;AACzD,sDAA4E;AAC5E,uCAAmD;AACnD,4EAA0E;AAQnE,IAAM,YAAY,GAAlB,MAAM,YAAa,SAAQ,kCAAe;IAC/C,YACmB,YAA0B,EAC1B,oBAA0C;QAE3D,KAAK,EAAE,CAAC;QAHS,iBAAY,GAAZ,YAAY,CAAc;QAC1B,yBAAoB,GAApB,oBAAoB,CAAsB;IAG7D,CAAC;IAES,eAAe;QACvB,OAAO,CAAC,cAAc,EAAE,mBAAmB,CAAC,CAAC;IAC/C,CAAC;IAES,KAAK,CAAC,UAAU,CACxB,QAAgB,EAChB,IAAyC;QAEzC,QAAQ,QAAQ,EAAE,CAAC;YACjB,KAAK,cAAc;gBACjB,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;YACtC,KAAK,mBAAmB;gBACtB,OAAO,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC;YAC1C;gBACE,OAAO,IAAA,oCAAmB,EAAC,iBAAiB,QAAQ,EAAE,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;IAED,kBAAkB;QAChB,OAAO;YACL;gBACE,IAAI,EAAE,cAAc;gBACpB,WAAW,EAAE,iCAAiC;gBAC9C,WAAW,EAAE;oBACX,IAAI,EAAE,QAAQ;oBACd,UAAU,EAAE;wBACV,KAAK,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,cAAc,EAAE;qBACvD;oBACD,QAAQ,EAAE,CAAC,OAAO,CAAC;iBACpB;aACF;YACD;gBACE,IAAI,EAAE,mBAAmB;gBACzB,WAAW,EAAE,6CAA6C;gBAC1D,WAAW,EAAE;oBACX,IAAI,EAAE,QAAQ;oBACd,UAAU,EAAE;wBACV,SAAS,EAAE,EAAE,IAAI,EAAE,QAAQ,EAAE,WAAW,EAAE,mBAAmB,EAAE;qBAChE;oBACD,QAAQ,EAAE,CAAC,WAAW,CAAC;iBACxB;aACF;SACF,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,iBAAiB,CAC7B,IAAyC;QAEzC,MAAM,KAAK,GAAG,IAAA,4CAAqB,EAAC,IAAI,EAAE,OAAO,CAAC,CAAC;QACnD,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAA,oCAAmB,EAAC,mCAAmC,CAAC,CAAC;QAClE,CAAC;QACD,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAC3D,OAAO,IAAA,mCAAkB,EAAC,OAAO,CAAC,CAAC;IACrC,CAAC;IAEO,KAAK,CAAC,qBAAqB,CACjC,IAAyC;QAEzC,MAAM,SAAS,GAAG,IAAA,4CAAqB,EAAC,IAAI,EAAE,WAAW,CAAC,CAAC;QAC3D,IAAI,SAAS,KAAK,IAAI,EAAE,CAAC;YACvB,OAAO,IAAA,oCAAmB,EAAC,uCAAuC,CAAC,CAAC;QACtE,CAAC;QACD,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YAI1D,MAAM,aAAa,GAAG,MAAM,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,CAAC;YAEhE,OAAO,IAAA,mCAAkB,EAAC;gBACxB,GAAG,KAAK;gBACR,aAAa;aACd,CAAC,CAAC;QACL,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,IAAA,oCAAmB,EAAC,UAAU,SAAS,cAAc,CAAC,CAAC;QAChE,CAAC;IACH,CAAC;CACF,CAAA;AAtFY,oCAAY;uBAAZ,YAAY;IADxB,IAAA,mBAAU,GAAE;qCAGsB,4BAAY;QACJ,4BAAoB;GAHlD,YAAY,CAsFxB"}
1
+ {"version":3,"file":"rules.handler.js","sourceRoot":"","sources":["../../../../src/mcp/handlers/rules.handler.ts"],"names":[],"mappings":"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"}
@@ -20,6 +20,8 @@ const context_module_1 = require("../context/context.module");
20
20
  const state_module_1 = require("../state/state.module");
21
21
  const diagnostic_module_1 = require("../diagnostic/diagnostic.module");
22
22
  const events_1 = require("../tui/events");
23
+ const pipeline_module_1 = require("../pipeline/pipeline.module");
24
+ const impact_1 = require("../impact");
23
25
  const skill_recommendation_service_1 = require("../skill/skill-recommendation.service");
24
26
  const language_service_1 = require("../shared/language.service");
25
27
  const model_1 = require("../model");
@@ -33,7 +35,13 @@ const handlers = [
33
35
  handlers_1.ChecklistContextHandler,
34
36
  handlers_1.ConventionsHandler,
35
37
  handlers_1.ContextDocumentHandler,
38
+ handlers_1.ContextArchiveHandler,
39
+ handlers_1.RuleInsightsHandler,
36
40
  handlers_1.TuiHandler,
41
+ handlers_1.DiscussionHandler,
42
+ handlers_1.ParallelValidationHandler,
43
+ handlers_1.PipelineHandler,
44
+ handlers_1.ImpactHandler,
37
45
  ];
38
46
  let McpModule = class McpModule {
39
47
  };
@@ -51,6 +59,8 @@ exports.McpModule = McpModule = __decorate([
51
59
  state_module_1.StateModule,
52
60
  diagnostic_module_1.DiagnosticModule,
53
61
  events_1.TuiEventsModule,
62
+ pipeline_module_1.PipelineModule,
63
+ impact_1.ImpactModule,
54
64
  ],
55
65
  controllers: [mcp_controller_1.McpController],
56
66
  providers: [
@@ -1 +1 @@
1
- {"version":3,"file":"mcp.module.js","sourceRoot":"","sources":["../../../src/mcp/mcp.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,+CAA2C;AAC3C,qDAAiD;AACjD,wDAAoD;AACpD,8DAA0D;AAC1D,2DAAkE;AAClE,iEAA6D;AAC7D,wDAAoD;AACpD,oEAAgE;AAChE,8DAA0D;AAC1D,wDAAoD;AACpD,uEAAmE;AACnE,0CAAgD;AAChD,wFAAmF;AACnF,iEAA6D;AAC7D,oCAAgD;AAGhD,yCAWoB;AAEpB,MAAM,QAAQ,GAAG;IACf,uBAAY;IACZ,wBAAa;IACb,uBAAY;IACZ,uBAAY;IACZ,sBAAW;IACX,kCAAuB;IACvB,6BAAkB;IAClB,iCAAsB;IACtB,qBAAU;CACX,CAAC;AA+BK,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IA7BrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,0BAAW;YACX,8BAAa;YACb,uCAAuB;YACvB,gCAAc;YACd,0BAAW;YACX,kCAAe;YACf,8BAAa;YACb,0BAAW;YACX,oCAAgB;YAChB,wBAAe;SAChB;QACD,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE;YACT,wBAAU;YACV,yDAA0B;YAC1B,kCAAe;YACf,4BAAoB;YACpB,GAAG,QAAQ;YACX;gBACE,OAAO,EAAE,wBAAa;gBACtB,UAAU,EAAE,CAAC,GAAG,gBAA2D,EAAE,EAAE,CAC7E,gBAAgB;gBAClB,MAAM,EAAE,QAAQ;aACjB;SACF;QACD,OAAO,EAAE,CAAC,wBAAU,CAAC;KACtB,CAAC;GACW,SAAS,CAAG"}
1
+ {"version":3,"file":"mcp.module.js","sourceRoot":"","sources":["../../../src/mcp/mcp.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,+CAA2C;AAC3C,qDAAiD;AACjD,wDAAoD;AACpD,8DAA0D;AAC1D,2DAAkE;AAClE,iEAA6D;AAC7D,wDAAoD;AACpD,oEAAgE;AAChE,8DAA0D;AAC1D,wDAAoD;AACpD,uEAAmE;AACnE,0CAAgD;AAChD,iEAA6D;AAC7D,sCAAyC;AACzC,wFAAmF;AACnF,iEAA6D;AAC7D,oCAAgD;AAGhD,yCAiBoB;AAEpB,MAAM,QAAQ,GAAG;IACf,uBAAY;IACZ,wBAAa;IACb,uBAAY;IACZ,uBAAY;IACZ,sBAAW;IACX,kCAAuB;IACvB,6BAAkB;IAClB,iCAAsB;IACtB,gCAAqB;IACrB,8BAAmB;IACnB,qBAAU;IACV,4BAAiB;IACjB,oCAAyB;IACzB,0BAAe;IACf,wBAAa;CACd,CAAC;AAiCK,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IA/BrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,0BAAW;YACX,8BAAa;YACb,uCAAuB;YACvB,gCAAc;YACd,0BAAW;YACX,kCAAe;YACf,8BAAa;YACb,0BAAW;YACX,oCAAgB;YAChB,wBAAe;YACf,gCAAc;YACd,qBAAY;SACb;QACD,WAAW,EAAE,CAAC,8BAAa,CAAC;QAC5B,SAAS,EAAE;YACT,wBAAU;YACV,yDAA0B;YAC1B,kCAAe;YACf,4BAAoB;YACpB,GAAG,QAAQ;YACX;gBACE,OAAO,EAAE,wBAAa;gBACtB,UAAU,EAAE,CAAC,GAAG,gBAA2D,EAAE,EAAE,CAC7E,gBAAgB;gBAClB,MAAM,EAAE,QAAQ;aACjB;SACF;QACD,OAAO,EAAE,CAAC,wBAAU,CAAC;KACtB,CAAC;GACW,SAAS,CAAG"}
@@ -0,0 +1 @@
1
+ export declare function extractFilePaths(issueBody: string): string[];
@@ -0,0 +1,19 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.extractFilePaths = extractFilePaths;
4
+ const FILE_PATH_PATTERN = /(?<![/\w])(?:(?:packages|src|apps|\.claude|\.cursor|\.kiro|\.q|\.antigravity|\.codex)\/[\w./@-]+\.\w+)/g;
5
+ const URL_PATTERN = /https?:\/\/\S+/g;
6
+ function extractFilePaths(issueBody) {
7
+ if (!issueBody.trim()) {
8
+ return [];
9
+ }
10
+ const withoutUrls = issueBody.replace(URL_PATTERN, '');
11
+ const paths = new Set();
12
+ const matches = withoutUrls.matchAll(FILE_PATH_PATTERN);
13
+ for (const match of matches) {
14
+ const path = match[0].replace(/[,;:)}\]]+$/, '');
15
+ paths.add(path);
16
+ }
17
+ return [...paths];
18
+ }
19
+ //# sourceMappingURL=extract-file-paths.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extract-file-paths.js","sourceRoot":"","sources":["../../../src/parallel-validation/extract-file-paths.ts"],"names":[],"mappings":";;AAoBA,4CAkBC;AAlCD,MAAM,iBAAiB,GACrB,yGAAyG,CAAC;AAK5G,MAAM,WAAW,GAAG,iBAAiB,CAAC;AAUtC,SAAgB,gBAAgB,CAAC,SAAiB;IAChD,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,CAAC;QACtB,OAAO,EAAE,CAAC;IACZ,CAAC;IAGD,MAAM,WAAW,GAAG,SAAS,CAAC,OAAO,CAAC,WAAW,EAAE,EAAE,CAAC,CAAC;IAEvD,MAAM,KAAK,GAAG,IAAI,GAAG,EAAU,CAAC;IAGhC,MAAM,OAAO,GAAG,WAAW,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;IACxD,KAAK,MAAM,KAAK,IAAI,OAAO,EAAE,CAAC;QAC5B,MAAM,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;QACjD,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IAClB,CAAC;IAED,OAAO,CAAC,GAAG,KAAK,CAAC,CAAC;AACpB,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { extractFilePaths } from './extract-file-paths';
2
+ export { buildOverlapMatrix, type IssueFiles, type OverlapEntry } from './overlap-matrix';
3
+ export { splitIntoWaves } from './wave-splitter';
4
+ export { ParallelValidationHandler } from './parallel-validation.handler';
5
+ export type { ValidationResult } from './parallel-validation.types';
@@ -0,0 +1,12 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ParallelValidationHandler = exports.splitIntoWaves = exports.buildOverlapMatrix = exports.extractFilePaths = void 0;
4
+ var extract_file_paths_1 = require("./extract-file-paths");
5
+ Object.defineProperty(exports, "extractFilePaths", { enumerable: true, get: function () { return extract_file_paths_1.extractFilePaths; } });
6
+ var overlap_matrix_1 = require("./overlap-matrix");
7
+ Object.defineProperty(exports, "buildOverlapMatrix", { enumerable: true, get: function () { return overlap_matrix_1.buildOverlapMatrix; } });
8
+ var wave_splitter_1 = require("./wave-splitter");
9
+ Object.defineProperty(exports, "splitIntoWaves", { enumerable: true, get: function () { return wave_splitter_1.splitIntoWaves; } });
10
+ var parallel_validation_handler_1 = require("./parallel-validation.handler");
11
+ Object.defineProperty(exports, "ParallelValidationHandler", { enumerable: true, get: function () { return parallel_validation_handler_1.ParallelValidationHandler; } });
12
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/parallel-validation/index.ts"],"names":[],"mappings":";;;AAAA,2DAAwD;AAA/C,sHAAA,gBAAgB,OAAA;AACzB,mDAA0F;AAAjF,oHAAA,kBAAkB,OAAA;AAC3B,iDAAiD;AAAxC,+GAAA,cAAc,OAAA;AACvB,6EAA0E;AAAjE,wIAAA,yBAAyB,OAAA"}
@@ -0,0 +1,10 @@
1
+ export interface IssueFiles {
2
+ issue: number;
3
+ files: string[];
4
+ }
5
+ export interface OverlapEntry {
6
+ issueA: number;
7
+ issueB: number;
8
+ overlappingFiles: string[];
9
+ }
10
+ export declare function buildOverlapMatrix(issues: IssueFiles[]): OverlapEntry[];
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.buildOverlapMatrix = buildOverlapMatrix;
4
+ function buildOverlapMatrix(issues) {
5
+ if (issues.length < 2) {
6
+ return [];
7
+ }
8
+ const entries = [];
9
+ for (let i = 0; i < issues.length; i++) {
10
+ const filesA = new Set(issues[i].files);
11
+ for (let j = i + 1; j < issues.length; j++) {
12
+ const overlapping = issues[j].files.filter(f => filesA.has(f)).sort();
13
+ if (overlapping.length > 0) {
14
+ const [issueA, issueB] = issues[i].issue < issues[j].issue
15
+ ? [issues[i].issue, issues[j].issue]
16
+ : [issues[j].issue, issues[i].issue];
17
+ entries.push({ issueA, issueB, overlappingFiles: overlapping });
18
+ }
19
+ }
20
+ }
21
+ return entries;
22
+ }
23
+ //# sourceMappingURL=overlap-matrix.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"overlap-matrix.js","sourceRoot":"","sources":["../../../src/parallel-validation/overlap-matrix.ts"],"names":[],"mappings":";;AAiBA,gDAwBC;AAxBD,SAAgB,kBAAkB,CAAC,MAAoB;IACrD,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACtB,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,MAAM,OAAO,GAAmB,EAAE,CAAC;IAEnC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACvC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QACxC,KAAK,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3C,MAAM,WAAW,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;YAEtE,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBAC3B,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GACpB,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK;oBAC/B,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;oBACpC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBAEzC,OAAO,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,gBAAgB,EAAE,WAAW,EAAE,CAAC,CAAC;YAClE,CAAC;QACH,CAAC;IACH,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { ToolDefinition } from '../mcp/handlers/base.handler';
2
+ import type { ToolResponse } from '../mcp/response.utils';
3
+ import { AbstractHandler } from '../mcp/handlers/abstract-handler';
4
+ export declare class ParallelValidationHandler extends AbstractHandler {
5
+ protected getHandledTools(): string[];
6
+ getToolDefinitions(): ToolDefinition[];
7
+ protected handleTool(_toolName: string, args: Record<string, unknown> | undefined): Promise<ToolResponse>;
8
+ }
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.ParallelValidationHandler = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const abstract_handler_1 = require("../mcp/handlers/abstract-handler");
12
+ const response_utils_1 = require("../mcp/response.utils");
13
+ const extract_file_paths_1 = require("./extract-file-paths");
14
+ const overlap_matrix_1 = require("./overlap-matrix");
15
+ const wave_splitter_1 = require("./wave-splitter");
16
+ let ParallelValidationHandler = class ParallelValidationHandler extends abstract_handler_1.AbstractHandler {
17
+ getHandledTools() {
18
+ return ['validate_parallel_issues'];
19
+ }
20
+ getToolDefinitions() {
21
+ return [
22
+ {
23
+ name: 'validate_parallel_issues',
24
+ description: 'Validate whether GitHub issues can be safely executed in parallel by checking file overlap. ' +
25
+ 'Returns overlap matrix, severity (OK/WARNING), and zero-conflict wave suggestions. ' +
26
+ 'Iron Rule: Issues modifying the same file MUST NOT run in the same wave.',
27
+ inputSchema: {
28
+ type: 'object',
29
+ properties: {
30
+ issues: {
31
+ type: 'array',
32
+ items: { type: 'number' },
33
+ description: 'List of GitHub issue numbers to validate for parallel execution',
34
+ },
35
+ issueContents: {
36
+ type: 'object',
37
+ additionalProperties: { type: 'string' },
38
+ description: 'Map of issue number to issue body content. Key is issue number as string, value is the issue body markdown text.',
39
+ },
40
+ },
41
+ required: ['issues'],
42
+ },
43
+ },
44
+ ];
45
+ }
46
+ async handleTool(_toolName, args) {
47
+ const rawIssues = args?.issues;
48
+ if (!Array.isArray(rawIssues)) {
49
+ return (0, response_utils_1.createErrorResponse)('Missing or invalid required parameter: issues (must be an array of numbers)');
50
+ }
51
+ const issueNumbers = rawIssues.map(Number).filter(n => !isNaN(n));
52
+ const issueContents = (args?.issueContents ?? {});
53
+ const issueFiles = issueNumbers.map(issue => ({
54
+ issue,
55
+ files: (0, extract_file_paths_1.extractFilePaths)(issueContents[String(issue)] ?? ''),
56
+ }));
57
+ const overlapMatrix = (0, overlap_matrix_1.buildOverlapMatrix)(issueFiles);
58
+ const hasOverlap = overlapMatrix.length > 0;
59
+ const suggestedWaves = (0, wave_splitter_1.splitIntoWaves)(issueFiles);
60
+ const overlappingPairs = overlapMatrix
61
+ .map(e => `#${e.issueA} ↔ #${e.issueB}: ${e.overlappingFiles.join(', ')}`)
62
+ .join('\n');
63
+ const message = hasOverlap
64
+ ? `⚠️ WARNING: File overlap detected! ${overlapMatrix.length} conflicting pair(s) found.\n` +
65
+ `Iron Rule: Issues modifying the same file MUST NOT run in the same Wave.\n\n` +
66
+ `Conflicts:\n${overlappingPairs}\n\n` +
67
+ `Suggested waves: ${suggestedWaves.map((w, i) => `Wave ${i + 1}: [${w.map(n => '#' + n).join(', ')}]`).join(' → ')}`
68
+ : `✅ OK: No file overlap detected. All ${issueNumbers.length} issues can run in parallel.`;
69
+ const result = {
70
+ issues: issueFiles,
71
+ overlapMatrix,
72
+ hasOverlap,
73
+ severity: hasOverlap ? 'WARNING' : 'OK',
74
+ suggestedWaves,
75
+ message,
76
+ };
77
+ return (0, response_utils_1.createJsonResponse)(result);
78
+ }
79
+ };
80
+ exports.ParallelValidationHandler = ParallelValidationHandler;
81
+ exports.ParallelValidationHandler = ParallelValidationHandler = __decorate([
82
+ (0, common_1.Injectable)()
83
+ ], ParallelValidationHandler);
84
+ //# sourceMappingURL=parallel-validation.handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parallel-validation.handler.js","sourceRoot":"","sources":["../../../src/parallel-validation/parallel-validation.handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import type { OverlapEntry } from './overlap-matrix';
2
+ export interface ValidationResult {
3
+ issues: Array<{
4
+ issue: number;
5
+ files: string[];
6
+ }>;
7
+ overlapMatrix: OverlapEntry[];
8
+ hasOverlap: boolean;
9
+ severity: 'OK' | 'WARNING';
10
+ suggestedWaves: number[][];
11
+ message: string;
12
+ }
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=parallel-validation.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parallel-validation.types.js","sourceRoot":"","sources":["../../../src/parallel-validation/parallel-validation.types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ import type { IssueFiles } from './overlap-matrix';
2
+ export declare function splitIntoWaves(issues: IssueFiles[]): number[][];
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.splitIntoWaves = splitIntoWaves;
4
+ function splitIntoWaves(issues) {
5
+ if (issues.length === 0) {
6
+ return [];
7
+ }
8
+ const conflicts = new Map();
9
+ for (const issue of issues) {
10
+ conflicts.set(issue.issue, new Set());
11
+ }
12
+ for (let i = 0; i < issues.length; i++) {
13
+ const filesA = new Set(issues[i].files);
14
+ for (let j = i + 1; j < issues.length; j++) {
15
+ const hasOverlap = issues[j].files.some(f => filesA.has(f));
16
+ if (hasOverlap) {
17
+ conflicts.get(issues[i].issue).add(issues[j].issue);
18
+ conflicts.get(issues[j].issue).add(issues[i].issue);
19
+ }
20
+ }
21
+ }
22
+ const waves = [];
23
+ for (const issue of issues) {
24
+ let assigned = false;
25
+ for (const wave of waves) {
26
+ const hasConflict = wave.some(id => conflicts.get(issue.issue).has(id));
27
+ if (!hasConflict) {
28
+ wave.push(issue.issue);
29
+ assigned = true;
30
+ break;
31
+ }
32
+ }
33
+ if (!assigned) {
34
+ waves.push([issue.issue]);
35
+ }
36
+ }
37
+ return waves;
38
+ }
39
+ //# sourceMappingURL=wave-splitter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"wave-splitter.js","sourceRoot":"","sources":["../../../src/parallel-validation/wave-splitter.ts"],"names":[],"mappings":";;AAOA,wCAyCC;AAzCD,SAAgB,cAAc,CAAC,MAAoB;IACjD,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACxB,OAAO,EAAE,CAAC;IACZ,CAAC;IAGD,MAAM,SAAS,GAAG,IAAI,GAAG,EAAuB,CAAC;IACjD,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QACvC,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QACxC,KAAK,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3C,MAAM,UAAU,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YAC5D,IAAI,UAAU,EAAE,CAAC;gBACf,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBACrD,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YACvD,CAAC;QACH,CAAC;IACH,CAAC;IAGD,MAAM,KAAK,GAAe,EAAE,CAAC;IAE7B,KAAK,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;QAC3B,IAAI,QAAQ,GAAG,KAAK,CAAC;QACrB,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,MAAM,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC;YACzE,IAAI,CAAC,WAAW,EAAE,CAAC;gBACjB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;gBACvB,QAAQ,GAAG,IAAI,CAAC;gBAChB,MAAM;YACR,CAAC;QACH,CAAC;QACD,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,KAAK,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC;QAC5B,CAAC;IACH,CAAC;IAED,OAAO,KAAK,CAAC;AACf,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { PipelineModule } from './pipeline.module';
2
+ export { PipelineService } from './pipeline.service';
3
+ export { executeStage } from './pipeline.executors';
4
+ export type { PipelineStageType, PipelineStageConfig, CommandStageConfig, AgentStageConfig, SkillStageConfig, PipelineStage, PipelineDefinition, PipelineStageStatus, PipelineStageResult, PipelineExecutionStatus, PipelineExecution, } from './pipeline.types';
5
+ export { isValidStageType, isValidPipelineStage, isValidPipelineDefinition, } from './pipeline.types';
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isValidPipelineDefinition = exports.isValidPipelineStage = exports.isValidStageType = exports.executeStage = exports.PipelineService = exports.PipelineModule = void 0;
4
+ var pipeline_module_1 = require("./pipeline.module");
5
+ Object.defineProperty(exports, "PipelineModule", { enumerable: true, get: function () { return pipeline_module_1.PipelineModule; } });
6
+ var pipeline_service_1 = require("./pipeline.service");
7
+ Object.defineProperty(exports, "PipelineService", { enumerable: true, get: function () { return pipeline_service_1.PipelineService; } });
8
+ var pipeline_executors_1 = require("./pipeline.executors");
9
+ Object.defineProperty(exports, "executeStage", { enumerable: true, get: function () { return pipeline_executors_1.executeStage; } });
10
+ var pipeline_types_1 = require("./pipeline.types");
11
+ Object.defineProperty(exports, "isValidStageType", { enumerable: true, get: function () { return pipeline_types_1.isValidStageType; } });
12
+ Object.defineProperty(exports, "isValidPipelineStage", { enumerable: true, get: function () { return pipeline_types_1.isValidPipelineStage; } });
13
+ Object.defineProperty(exports, "isValidPipelineDefinition", { enumerable: true, get: function () { return pipeline_types_1.isValidPipelineDefinition; } });
14
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/pipeline/index.ts"],"names":[],"mappings":";;;AAAA,qDAAmD;AAA1C,iHAAA,cAAc,OAAA;AACvB,uDAAqD;AAA5C,mHAAA,eAAe,OAAA;AACxB,2DAAoD;AAA3C,kHAAA,YAAY,OAAA;AAcrB,mDAI0B;AAHxB,kHAAA,gBAAgB,OAAA;AAChB,sHAAA,oBAAoB,OAAA;AACpB,2HAAA,yBAAyB,OAAA"}
@@ -0,0 +1,2 @@
1
+ import type { PipelineStage, PipelineStageResult } from './pipeline.types';
2
+ export declare function executeStage(stage: PipelineStage, input?: string): Promise<PipelineStageResult>;
@@ -0,0 +1,79 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.executeStage = executeStage;
4
+ const child_process_1 = require("child_process");
5
+ async function executeStage(stage, input) {
6
+ const startedAt = new Date().toISOString();
7
+ const startTime = Date.now();
8
+ try {
9
+ let output;
10
+ switch (stage.type) {
11
+ case 'command':
12
+ output = executeCommandStage(stage.config, input);
13
+ break;
14
+ case 'agent':
15
+ output = executeAgentStage(stage.config, input);
16
+ break;
17
+ case 'skill':
18
+ output = executeSkillStage(stage.config, input);
19
+ break;
20
+ default:
21
+ return {
22
+ stageId: stage.id,
23
+ status: 'failed',
24
+ error: `Unknown stage type: ${stage.type}`,
25
+ startedAt,
26
+ completedAt: new Date().toISOString(),
27
+ durationMs: Date.now() - startTime,
28
+ };
29
+ }
30
+ return {
31
+ stageId: stage.id,
32
+ status: 'completed',
33
+ output,
34
+ startedAt,
35
+ completedAt: new Date().toISOString(),
36
+ durationMs: Date.now() - startTime,
37
+ };
38
+ }
39
+ catch (error) {
40
+ return {
41
+ stageId: stage.id,
42
+ status: 'failed',
43
+ error: error instanceof Error ? error.message : String(error),
44
+ startedAt,
45
+ completedAt: new Date().toISOString(),
46
+ durationMs: Date.now() - startTime,
47
+ };
48
+ }
49
+ }
50
+ function executeCommandStage(config, input) {
51
+ const env = { ...process.env };
52
+ if (input !== undefined) {
53
+ env.PIPELINE_INPUT = input;
54
+ }
55
+ const result = (0, child_process_1.execSync)(config.command, {
56
+ encoding: 'utf-8',
57
+ env,
58
+ timeout: 60_000,
59
+ });
60
+ return result;
61
+ }
62
+ function executeAgentStage(config, input) {
63
+ const parts = [`[Agent: ${config.agentName}]`, `[Prompt: ${config.prompt}]`];
64
+ if (input !== undefined) {
65
+ parts.push(`[Input: ${input}]`);
66
+ }
67
+ return parts.join('\n');
68
+ }
69
+ function executeSkillStage(config, input) {
70
+ const parts = [`[Skill: ${config.skillName}]`];
71
+ if (config.args) {
72
+ parts.push(`[Args: ${config.args}]`);
73
+ }
74
+ if (input !== undefined) {
75
+ parts.push(`[Input: ${input}]`);
76
+ }
77
+ return parts.join('\n');
78
+ }
79
+ //# sourceMappingURL=pipeline.executors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.executors.js","sourceRoot":"","sources":["../../../src/pipeline/pipeline.executors.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare class PipelineModule {
2
+ }
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ Object.defineProperty(exports, "__esModule", { value: true });
9
+ exports.PipelineModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const pipeline_service_1 = require("./pipeline.service");
12
+ let PipelineModule = class PipelineModule {
13
+ };
14
+ exports.PipelineModule = PipelineModule;
15
+ exports.PipelineModule = PipelineModule = __decorate([
16
+ (0, common_1.Module)({
17
+ providers: [pipeline_service_1.PipelineService],
18
+ exports: [pipeline_service_1.PipelineService],
19
+ })
20
+ ], PipelineModule);
21
+ //# sourceMappingURL=pipeline.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.module.js","sourceRoot":"","sources":["../../../src/pipeline/pipeline.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,yDAAqD;AAM9C,IAAM,cAAc,GAApB,MAAM,cAAc;CAAG,CAAA;AAAjB,wCAAc;yBAAd,cAAc;IAJ1B,IAAA,eAAM,EAAC;QACN,SAAS,EAAE,CAAC,kCAAe,CAAC;QAC5B,OAAO,EAAE,CAAC,kCAAe,CAAC;KAC3B,CAAC;GACW,cAAc,CAAG"}
@@ -0,0 +1,8 @@
1
+ import type { PipelineDefinition, PipelineExecution } from './pipeline.types';
2
+ export declare class PipelineService {
3
+ private readonly executions;
4
+ runPipeline(definition: PipelineDefinition): Promise<PipelineExecution>;
5
+ getStatus(executionId: string): PipelineExecution | undefined;
6
+ resumePipeline(executionId: string, updatedDefinition: PipelineDefinition): Promise<PipelineExecution>;
7
+ private executeFromStage;
8
+ }