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.
- package/dist/src/agent/agent.module.js +3 -1
- package/dist/src/agent/agent.module.js.map +1 -1
- package/dist/src/agent/agent.service.d.ts +11 -4
- package/dist/src/agent/agent.service.js +81 -13
- package/dist/src/agent/agent.service.js.map +1 -1
- package/dist/src/agent/agent.types.d.ts +41 -1
- package/dist/src/agent/agent.types.js.map +1 -1
- package/dist/src/collaboration/discussion-engine.d.ts +14 -0
- package/dist/src/collaboration/discussion-engine.js +49 -0
- package/dist/src/collaboration/discussion-engine.js.map +1 -0
- package/dist/src/collaboration/index.d.ts +5 -0
- package/dist/src/collaboration/index.js +22 -0
- package/dist/src/collaboration/index.js.map +1 -0
- package/dist/src/collaboration/opinion-adapter.d.ts +14 -0
- package/dist/src/collaboration/opinion-adapter.js +56 -0
- package/dist/src/collaboration/opinion-adapter.js.map +1 -0
- package/dist/src/collaboration/terminal-formatter.d.ts +5 -0
- package/dist/src/collaboration/terminal-formatter.js +57 -0
- package/dist/src/collaboration/terminal-formatter.js.map +1 -0
- package/dist/src/collaboration/types.d.ts +50 -0
- package/dist/src/collaboration/types.js +53 -0
- package/dist/src/collaboration/types.js.map +1 -0
- package/dist/src/config/config.schema.d.ts +14 -0
- package/dist/src/config/config.schema.js +7 -0
- package/dist/src/config/config.schema.js.map +1 -1
- package/dist/src/context/context-archive.service.d.ts +14 -0
- package/dist/src/context/context-archive.service.js +257 -0
- package/dist/src/context/context-archive.service.js.map +1 -0
- package/dist/src/context/context-archive.types.d.ts +37 -0
- package/dist/src/context/context-archive.types.js +47 -0
- package/dist/src/context/context-archive.types.js.map +1 -0
- package/dist/src/context/context-document.service.d.ts +4 -2
- package/dist/src/context/context-document.service.js +24 -4
- package/dist/src/context/context-document.service.js.map +1 -1
- package/dist/src/context/context-document.types.d.ts +18 -0
- package/dist/src/context/context-document.types.js +13 -1
- package/dist/src/context/context-document.types.js.map +1 -1
- package/dist/src/context/context-parser.utils.js +32 -0
- package/dist/src/context/context-parser.utils.js.map +1 -1
- package/dist/src/context/context-serializer.utils.d.ts +3 -2
- package/dist/src/context/context-serializer.utils.js +25 -1
- package/dist/src/context/context-serializer.utils.js.map +1 -1
- package/dist/src/context/context.module.js +3 -2
- package/dist/src/context/context.module.js.map +1 -1
- package/dist/src/context/index.d.ts +1 -0
- package/dist/src/context/index.js +1 -0
- package/dist/src/context/index.js.map +1 -1
- package/dist/src/impact/impact-event.service.d.ts +8 -0
- package/dist/src/impact/impact-event.service.js +53 -0
- package/dist/src/impact/impact-event.service.js.map +1 -0
- package/dist/src/impact/impact-report.service.d.ts +7 -0
- package/dist/src/impact/impact-report.service.js +92 -0
- package/dist/src/impact/impact-report.service.js.map +1 -0
- package/dist/src/impact/impact.module.d.ts +2 -0
- package/dist/src/impact/impact.module.js +22 -0
- package/dist/src/impact/impact.module.js.map +1 -0
- package/dist/src/impact/impact.types.d.ts +32 -0
- package/dist/src/impact/impact.types.js +5 -0
- package/dist/src/impact/impact.types.js.map +1 -0
- package/dist/src/impact/index.d.ts +4 -0
- package/dist/src/impact/index.js +25 -0
- package/dist/src/impact/index.js.map +1 -0
- package/dist/src/keyword/diff-analyzer.d.ts +19 -0
- package/dist/src/keyword/diff-analyzer.js +127 -0
- package/dist/src/keyword/diff-analyzer.js.map +1 -0
- package/dist/src/keyword/explicit-pattern-matcher.d.ts +3 -0
- package/dist/src/keyword/explicit-pattern-matcher.js +34 -0
- package/dist/src/keyword/explicit-pattern-matcher.js.map +1 -0
- package/dist/src/keyword/keyword.module.js +17 -1
- package/dist/src/keyword/keyword.module.js.map +1 -1
- package/dist/src/keyword/keyword.service.d.ts +3 -0
- package/dist/src/keyword/keyword.service.js +33 -3
- package/dist/src/keyword/keyword.service.js.map +1 -1
- package/dist/src/keyword/keyword.types.d.ts +29 -1
- package/dist/src/keyword/keyword.types.js +34 -1
- package/dist/src/keyword/keyword.types.js.map +1 -1
- package/dist/src/keyword/primary-agent-resolver.d.ts +7 -3
- package/dist/src/keyword/primary-agent-resolver.js +24 -2
- package/dist/src/keyword/primary-agent-resolver.js.map +1 -1
- package/dist/src/keyword/strategies/act-agent.strategy.js +16 -0
- package/dist/src/keyword/strategies/act-agent.strategy.js.map +1 -1
- package/dist/src/keyword/strategies/index.d.ts +1 -1
- package/dist/src/keyword/strategies/index.js.map +1 -1
- package/dist/src/keyword/strategies/resolution-strategy.interface.d.ts +5 -0
- package/dist/src/keyword/visual-data.builder.d.ts +10 -0
- package/dist/src/keyword/visual-data.builder.js +62 -0
- package/dist/src/keyword/visual-data.builder.js.map +1 -0
- package/dist/src/mcp/handlers/agent.handler.d.ts +4 -1
- package/dist/src/mcp/handlers/agent.handler.js +59 -6
- package/dist/src/mcp/handlers/agent.handler.js.map +1 -1
- package/dist/src/mcp/handlers/checklist-context.handler.d.ts +3 -1
- package/dist/src/mcp/handlers/checklist-context.handler.js +13 -2
- package/dist/src/mcp/handlers/checklist-context.handler.js.map +1 -1
- package/dist/src/mcp/handlers/context-archive.handler.d.ts +14 -0
- package/dist/src/mcp/handlers/context-archive.handler.js +136 -0
- package/dist/src/mcp/handlers/context-archive.handler.js.map +1 -0
- package/dist/src/mcp/handlers/context-document.handler.d.ts +6 -1
- package/dist/src/mcp/handlers/context-document.handler.js +113 -12
- package/dist/src/mcp/handlers/context-document.handler.js.map +1 -1
- package/dist/src/mcp/handlers/discussion.handler.d.ts +14 -0
- package/dist/src/mcp/handlers/discussion.handler.js +168 -0
- package/dist/src/mcp/handlers/discussion.handler.js.map +1 -0
- package/dist/src/mcp/handlers/discussion.types.d.ts +18 -0
- package/dist/src/mcp/handlers/discussion.types.js +11 -0
- package/dist/src/mcp/handlers/discussion.types.js.map +1 -0
- package/dist/src/mcp/handlers/impact.handler.d.ts +11 -0
- package/dist/src/mcp/handlers/impact.handler.js +53 -0
- package/dist/src/mcp/handlers/impact.handler.js.map +1 -0
- package/dist/src/mcp/handlers/index.d.ts +6 -0
- package/dist/src/mcp/handlers/index.js +13 -1
- package/dist/src/mcp/handlers/index.js.map +1 -1
- package/dist/src/mcp/handlers/mode.handler.d.ts +7 -1
- package/dist/src/mcp/handlers/mode.handler.js +109 -3
- package/dist/src/mcp/handlers/mode.handler.js.map +1 -1
- package/dist/src/mcp/handlers/pipeline.handler.d.ts +14 -0
- package/dist/src/mcp/handlers/pipeline.handler.js +137 -0
- package/dist/src/mcp/handlers/pipeline.handler.js.map +1 -0
- package/dist/src/mcp/handlers/rule-insights.handler.d.ts +14 -0
- package/dist/src/mcp/handlers/rule-insights.handler.js +78 -0
- package/dist/src/mcp/handlers/rule-insights.handler.js.map +1 -0
- package/dist/src/mcp/handlers/rules.handler.d.ts +3 -1
- package/dist/src/mcp/handlers/rules.handler.js +14 -2
- package/dist/src/mcp/handlers/rules.handler.js.map +1 -1
- package/dist/src/mcp/mcp.module.js +10 -0
- package/dist/src/mcp/mcp.module.js.map +1 -1
- package/dist/src/parallel-validation/extract-file-paths.d.ts +1 -0
- package/dist/src/parallel-validation/extract-file-paths.js +19 -0
- package/dist/src/parallel-validation/extract-file-paths.js.map +1 -0
- package/dist/src/parallel-validation/index.d.ts +5 -0
- package/dist/src/parallel-validation/index.js +12 -0
- package/dist/src/parallel-validation/index.js.map +1 -0
- package/dist/src/parallel-validation/overlap-matrix.d.ts +10 -0
- package/dist/src/parallel-validation/overlap-matrix.js +23 -0
- package/dist/src/parallel-validation/overlap-matrix.js.map +1 -0
- package/dist/src/parallel-validation/parallel-validation.handler.d.ts +8 -0
- package/dist/src/parallel-validation/parallel-validation.handler.js +84 -0
- package/dist/src/parallel-validation/parallel-validation.handler.js.map +1 -0
- package/dist/src/parallel-validation/parallel-validation.types.d.ts +12 -0
- package/dist/src/parallel-validation/parallel-validation.types.js +3 -0
- package/dist/src/parallel-validation/parallel-validation.types.js.map +1 -0
- package/dist/src/parallel-validation/wave-splitter.d.ts +2 -0
- package/dist/src/parallel-validation/wave-splitter.js +39 -0
- package/dist/src/parallel-validation/wave-splitter.js.map +1 -0
- package/dist/src/pipeline/index.d.ts +5 -0
- package/dist/src/pipeline/index.js +14 -0
- package/dist/src/pipeline/index.js.map +1 -0
- package/dist/src/pipeline/pipeline.executors.d.ts +2 -0
- package/dist/src/pipeline/pipeline.executors.js +79 -0
- package/dist/src/pipeline/pipeline.executors.js.map +1 -0
- package/dist/src/pipeline/pipeline.module.d.ts +2 -0
- package/dist/src/pipeline/pipeline.module.js +21 -0
- package/dist/src/pipeline/pipeline.module.js.map +1 -0
- package/dist/src/pipeline/pipeline.service.d.ts +8 -0
- package/dist/src/pipeline/pipeline.service.js +89 -0
- package/dist/src/pipeline/pipeline.service.js.map +1 -0
- package/dist/src/pipeline/pipeline.types.d.ts +47 -0
- package/dist/src/pipeline/pipeline.types.js +33 -0
- package/dist/src/pipeline/pipeline.types.js.map +1 -0
- package/dist/src/rules/rule-insights.service.d.ts +31 -0
- package/dist/src/rules/rule-insights.service.js +102 -0
- package/dist/src/rules/rule-insights.service.js.map +1 -0
- package/dist/src/rules/rule-tracker.d.ts +24 -0
- package/dist/src/rules/rule-tracker.js +74 -0
- package/dist/src/rules/rule-tracker.js.map +1 -0
- package/dist/src/rules/rules.module.js +3 -2
- package/dist/src/rules/rules.module.js.map +1 -1
- package/dist/src/shared/event-bridge-reader.d.ts +17 -0
- package/dist/src/shared/event-bridge-reader.js +56 -0
- package/dist/src/shared/event-bridge-reader.js.map +1 -0
- package/dist/src/shared/version.d.ts +1 -1
- package/dist/src/shared/version.js +1 -1
- package/dist/src/skill/i18n/keywords.types.d.ts +4 -2
- package/dist/src/skill/i18n/keywords.types.js +3 -0
- package/dist/src/skill/i18n/keywords.types.js.map +1 -1
- package/dist/src/tui/components/ActModeScreen.d.ts +10 -0
- package/dist/src/tui/components/ActModeScreen.js +25 -0
- package/dist/src/tui/components/ActModeScreen.js.map +1 -0
- package/dist/src/tui/components/AgentDiscussionPanel.d.ts +8 -0
- package/dist/src/tui/components/AgentDiscussionPanel.js +115 -0
- package/dist/src/tui/components/AgentDiscussionPanel.js.map +1 -0
- package/dist/src/tui/components/AgentDiscussionPanel.spec.d.ts +1 -0
- package/dist/src/tui/components/AgentDiscussionPanel.spec.js +229 -0
- package/dist/src/tui/components/AgentDiscussionPanel.spec.js.map +1 -0
- package/dist/src/tui/components/EvalModeScreen.d.ts +8 -0
- package/dist/src/tui/components/EvalModeScreen.js +21 -0
- package/dist/src/tui/components/EvalModeScreen.js.map +1 -0
- package/dist/src/tui/components/FlowMap.spec.js.map +1 -1
- package/dist/src/tui/components/FocusedAgentPanel.js +1 -1
- package/dist/src/tui/components/FocusedAgentPanel.js.map +1 -1
- package/dist/src/tui/components/FocusedAgentPanel.spec.js +1 -3
- package/dist/src/tui/components/FocusedAgentPanel.spec.js.map +1 -1
- package/dist/src/tui/components/HeaderBar.js +3 -3
- package/dist/src/tui/components/HeaderBar.js.map +1 -1
- package/dist/src/tui/components/ModeScreenRouter.d.ts +13 -0
- package/dist/src/tui/components/ModeScreenRouter.js +51 -0
- package/dist/src/tui/components/ModeScreenRouter.js.map +1 -0
- package/dist/src/tui/components/PlanModeScreen.d.ts +10 -0
- package/dist/src/tui/components/PlanModeScreen.js +24 -0
- package/dist/src/tui/components/PlanModeScreen.js.map +1 -0
- package/dist/src/tui/components/SessionDashboard.d.ts +17 -0
- package/dist/src/tui/components/SessionDashboard.js +58 -0
- package/dist/src/tui/components/SessionDashboard.js.map +1 -0
- package/dist/src/tui/components/act-screen.pure.d.ts +12 -0
- package/dist/src/tui/components/act-screen.pure.js +93 -0
- package/dist/src/tui/components/act-screen.pure.js.map +1 -0
- package/dist/src/tui/components/agent-discussion-panel.pure.d.ts +55 -0
- package/dist/src/tui/components/agent-discussion-panel.pure.js +201 -0
- package/dist/src/tui/components/agent-discussion-panel.pure.js.map +1 -0
- package/dist/src/tui/components/eval-screen.pure.d.ts +13 -0
- package/dist/src/tui/components/eval-screen.pure.js +76 -0
- package/dist/src/tui/components/eval-screen.pure.js.map +1 -0
- package/dist/src/tui/components/index.d.ts +16 -0
- package/dist/src/tui/components/index.js +48 -1
- package/dist/src/tui/components/index.js.map +1 -1
- package/dist/src/tui/components/plan-screen.pure.d.ts +9 -0
- package/dist/src/tui/components/plan-screen.pure.js +61 -0
- package/dist/src/tui/components/plan-screen.pure.js.map +1 -0
- package/dist/src/tui/components/session-dashboard.pure.d.ts +43 -0
- package/dist/src/tui/components/session-dashboard.pure.js +182 -0
- package/dist/src/tui/components/session-dashboard.pure.js.map +1 -0
- package/dist/src/tui/dashboard-app.js +3 -3
- package/dist/src/tui/dashboard-app.js.map +1 -1
- package/dist/src/tui/dashboard-types.d.ts +49 -0
- package/dist/src/tui/dashboard-types.js +20 -1
- package/dist/src/tui/dashboard-types.js.map +1 -1
- package/dist/src/tui/events/index.d.ts +1 -1
- package/dist/src/tui/events/index.js.map +1 -1
- package/dist/src/tui/events/types.d.ts +29 -1
- package/dist/src/tui/events/types.js +5 -0
- package/dist/src/tui/events/types.js.map +1 -1
- package/dist/src/tui/hooks/use-dashboard-state.d.ts +16 -1
- package/dist/src/tui/hooks/use-dashboard-state.js +70 -1
- package/dist/src/tui/hooks/use-dashboard-state.js.map +1 -1
- package/dist/src/tui-bundle.mjs +1023 -125
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- 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
|
-
|
|
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;
|
|
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,
|
|
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,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 @@
|
|
|
1
|
+
{"version":3,"file":"parallel-validation.types.js","sourceRoot":"","sources":["../../../src/parallel-validation/parallel-validation.types.ts"],"names":[],"mappings":""}
|
|
@@ -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,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,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
|
+
}
|