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,89 @@
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.PipelineService = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const crypto_1 = require("crypto");
12
+ const pipeline_executors_1 = require("./pipeline.executors");
13
+ let PipelineService = class PipelineService {
14
+ constructor() {
15
+ this.executions = new Map();
16
+ }
17
+ async runPipeline(definition) {
18
+ const executionId = (0, crypto_1.randomUUID)();
19
+ const startedAt = new Date().toISOString();
20
+ const execution = await this.executeFromStage(executionId, definition, 0, [], startedAt);
21
+ this.executions.set(executionId, execution);
22
+ return execution;
23
+ }
24
+ getStatus(executionId) {
25
+ return this.executions.get(executionId);
26
+ }
27
+ async resumePipeline(executionId, updatedDefinition) {
28
+ const existing = this.executions.get(executionId);
29
+ if (!existing) {
30
+ throw new Error('Execution not found');
31
+ }
32
+ if (existing.status !== 'failed') {
33
+ throw new Error('Pipeline is not in a failed state');
34
+ }
35
+ const failedIndex = existing.stageResults.findIndex(r => r.status === 'failed');
36
+ const preservedResults = existing.stageResults.slice(0, failedIndex);
37
+ const execution = await this.executeFromStage(executionId, updatedDefinition, failedIndex, [...preservedResults], existing.startedAt);
38
+ this.executions.set(executionId, execution);
39
+ return execution;
40
+ }
41
+ async executeFromStage(executionId, definition, startIndex, previousResults, startedAt) {
42
+ const stageResults = [...previousResults];
43
+ let lastOutput;
44
+ if (previousResults.length > 0) {
45
+ const lastResult = previousResults[previousResults.length - 1];
46
+ lastOutput = lastResult.output?.trim();
47
+ }
48
+ for (let i = startIndex; i < definition.stages.length; i++) {
49
+ const stage = definition.stages[i];
50
+ const inProgress = {
51
+ id: executionId,
52
+ pipelineId: definition.id,
53
+ status: 'running',
54
+ currentStageIndex: i,
55
+ stageResults: [...stageResults],
56
+ startedAt,
57
+ };
58
+ this.executions.set(executionId, inProgress);
59
+ const result = await (0, pipeline_executors_1.executeStage)(stage, lastOutput);
60
+ stageResults.push(result);
61
+ if (result.status === 'failed') {
62
+ return {
63
+ id: executionId,
64
+ pipelineId: definition.id,
65
+ status: 'failed',
66
+ currentStageIndex: i,
67
+ stageResults,
68
+ startedAt,
69
+ completedAt: new Date().toISOString(),
70
+ };
71
+ }
72
+ lastOutput = result.output?.trim();
73
+ }
74
+ return {
75
+ id: executionId,
76
+ pipelineId: definition.id,
77
+ status: 'completed',
78
+ currentStageIndex: definition.stages.length - 1,
79
+ stageResults,
80
+ startedAt,
81
+ completedAt: new Date().toISOString(),
82
+ };
83
+ }
84
+ };
85
+ exports.PipelineService = PipelineService;
86
+ exports.PipelineService = PipelineService = __decorate([
87
+ (0, common_1.Injectable)()
88
+ ], PipelineService);
89
+ //# sourceMappingURL=pipeline.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.service.js","sourceRoot":"","sources":["../../../src/pipeline/pipeline.service.ts"],"names":[],"mappings":";;;;;;;;;AAOA,2CAA4C;AAC5C,mCAAoC;AAEpC,6DAAoD;AAG7C,IAAM,eAAe,GAArB,MAAM,eAAe;IAArB;QACY,eAAU,GAAG,IAAI,GAAG,EAA6B,CAAC;IAsHrE,CAAC;IA/GC,KAAK,CAAC,WAAW,CAAC,UAA8B;QAC9C,MAAM,WAAW,GAAG,IAAA,mBAAU,GAAE,CAAC;QACjC,MAAM,SAAS,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;QAE3C,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC,EAAE,EAAE,EAAE,SAAS,CAAC,CAAC;QACzF,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;QAC5C,OAAO,SAAS,CAAC;IACnB,CAAC;IAKD,SAAS,CAAC,WAAmB;QAC3B,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IAC1C,CAAC;IASD,KAAK,CAAC,cAAc,CAClB,WAAmB,EACnB,iBAAqC;QAErC,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;QAClD,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QACzC,CAAC;QACD,IAAI,QAAQ,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;YACjC,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAC;QACvD,CAAC;QAGD,MAAM,WAAW,GAAG,QAAQ,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC;QAChF,MAAM,gBAAgB,GAAG,QAAQ,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC;QAErE,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAC3C,WAAW,EACX,iBAAiB,EACjB,WAAW,EACX,CAAC,GAAG,gBAAgB,CAAC,EACrB,QAAQ,CAAC,SAAS,CACnB,CAAC;QACF,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,WAAW,EAAE,SAAS,CAAC,CAAC;QAC5C,OAAO,SAAS,CAAC;IACnB,CAAC;IAKO,KAAK,CAAC,gBAAgB,CAC5B,WAAmB,EACnB,UAA8B,EAC9B,UAAkB,EAClB,eAAsC,EACtC,SAAiB;QAEjB,MAAM,YAAY,GAA0B,CAAC,GAAG,eAAe,CAAC,CAAC;QAGjE,IAAI,UAA8B,CAAC;QACnC,IAAI,eAAe,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC/B,MAAM,UAAU,GAAG,eAAe,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAC/D,UAAU,GAAG,UAAU,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC;QACzC,CAAC;QAED,KAAK,IAAI,CAAC,GAAG,UAAU,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC3D,MAAM,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;YAGnC,MAAM,UAAU,GAAsB;gBACpC,EAAE,EAAE,WAAW;gBACf,UAAU,EAAE,UAAU,CAAC,EAAE;gBACzB,MAAM,EAAE,SAAS;gBACjB,iBAAiB,EAAE,CAAC;gBACpB,YAAY,EAAE,CAAC,GAAG,YAAY,CAAC;gBAC/B,SAAS;aACV,CAAC;YACF,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,WAAW,EAAE,UAAU,CAAC,CAAC;YAE7C,MAAM,MAAM,GAAG,MAAM,IAAA,iCAAY,EAAC,KAAK,EAAE,UAAU,CAAC,CAAC;YACrD,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAE1B,IAAI,MAAM,CAAC,MAAM,KAAK,QAAQ,EAAE,CAAC;gBAC/B,OAAO;oBACL,EAAE,EAAE,WAAW;oBACf,UAAU,EAAE,UAAU,CAAC,EAAE;oBACzB,MAAM,EAAE,QAAQ;oBAChB,iBAAiB,EAAE,CAAC;oBACpB,YAAY;oBACZ,SAAS;oBACT,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;iBACtC,CAAC;YACJ,CAAC;YAED,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC;QACrC,CAAC;QAED,OAAO;YACL,EAAE,EAAE,WAAW;YACf,UAAU,EAAE,UAAU,CAAC,EAAE;YACzB,MAAM,EAAE,WAAW;YACnB,iBAAiB,EAAE,UAAU,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC;YAC/C,YAAY;YACZ,SAAS;YACT,WAAW,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;SACtC,CAAC;IACJ,CAAC;CACF,CAAA;AAvHY,0CAAe;0BAAf,eAAe;IAD3B,IAAA,mBAAU,GAAE;GACA,eAAe,CAuH3B"}
@@ -0,0 +1,47 @@
1
+ export type PipelineStageType = 'command' | 'agent' | 'skill';
2
+ export interface CommandStageConfig {
3
+ readonly command: string;
4
+ }
5
+ export interface AgentStageConfig {
6
+ readonly agentName: string;
7
+ readonly prompt: string;
8
+ }
9
+ export interface SkillStageConfig {
10
+ readonly skillName: string;
11
+ readonly args?: string;
12
+ }
13
+ export type PipelineStageConfig = CommandStageConfig | AgentStageConfig | SkillStageConfig;
14
+ export interface PipelineStage {
15
+ readonly id: string;
16
+ readonly name: string;
17
+ readonly type: PipelineStageType;
18
+ readonly config: PipelineStageConfig;
19
+ }
20
+ export interface PipelineDefinition {
21
+ readonly id: string;
22
+ readonly name: string;
23
+ readonly stages: readonly PipelineStage[];
24
+ }
25
+ export type PipelineStageStatus = 'pending' | 'running' | 'completed' | 'failed' | 'skipped';
26
+ export interface PipelineStageResult {
27
+ readonly stageId: string;
28
+ readonly status: PipelineStageStatus;
29
+ readonly output?: string;
30
+ readonly error?: string;
31
+ readonly startedAt: string;
32
+ readonly completedAt?: string;
33
+ readonly durationMs?: number;
34
+ }
35
+ export type PipelineExecutionStatus = 'running' | 'completed' | 'failed' | 'paused';
36
+ export interface PipelineExecution {
37
+ readonly id: string;
38
+ readonly pipelineId: string;
39
+ readonly status: PipelineExecutionStatus;
40
+ readonly currentStageIndex: number;
41
+ readonly stageResults: readonly PipelineStageResult[];
42
+ readonly startedAt: string;
43
+ readonly completedAt?: string;
44
+ }
45
+ export declare function isValidStageType(value: unknown): value is PipelineStageType;
46
+ export declare function isValidPipelineStage(value: unknown): value is PipelineStage;
47
+ export declare function isValidPipelineDefinition(value: unknown): value is PipelineDefinition;
@@ -0,0 +1,33 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isValidStageType = isValidStageType;
4
+ exports.isValidPipelineStage = isValidPipelineStage;
5
+ exports.isValidPipelineDefinition = isValidPipelineDefinition;
6
+ const VALID_STAGE_TYPES = ['command', 'agent', 'skill'];
7
+ function isValidStageType(value) {
8
+ return typeof value === 'string' && VALID_STAGE_TYPES.includes(value);
9
+ }
10
+ function isValidPipelineStage(value) {
11
+ if (typeof value !== 'object' || value === null)
12
+ return false;
13
+ const obj = value;
14
+ return (typeof obj.id === 'string' &&
15
+ obj.id.length > 0 &&
16
+ typeof obj.name === 'string' &&
17
+ obj.name.length > 0 &&
18
+ isValidStageType(obj.type) &&
19
+ typeof obj.config === 'object' &&
20
+ obj.config !== null);
21
+ }
22
+ function isValidPipelineDefinition(value) {
23
+ if (typeof value !== 'object' || value === null)
24
+ return false;
25
+ const obj = value;
26
+ return (typeof obj.id === 'string' &&
27
+ obj.id.length > 0 &&
28
+ typeof obj.name === 'string' &&
29
+ obj.name.length > 0 &&
30
+ Array.isArray(obj.stages) &&
31
+ obj.stages.every((stage) => isValidPipelineStage(stage)));
32
+ }
33
+ //# sourceMappingURL=pipeline.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.types.js","sourceRoot":"","sources":["../../../src/pipeline/pipeline.types.ts"],"names":[],"mappings":";;AA0HA,4CAEC;AAKD,oDAYC;AAKD,8DAWC;AAxCD,MAAM,iBAAiB,GAAiC,CAAC,SAAS,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC;AAKtF,SAAgB,gBAAgB,CAAC,KAAc;IAC7C,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,iBAAiB,CAAC,QAAQ,CAAC,KAA0B,CAAC,CAAC;AAC7F,CAAC;AAKD,SAAgB,oBAAoB,CAAC,KAAc;IACjD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAC9D,MAAM,GAAG,GAAG,KAAgC,CAAC;IAC7C,OAAO,CACL,OAAO,GAAG,CAAC,EAAE,KAAK,QAAQ;QAC1B,GAAG,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC;QACjB,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;QACnB,gBAAgB,CAAC,GAAG,CAAC,IAAI,CAAC;QAC1B,OAAO,GAAG,CAAC,MAAM,KAAK,QAAQ;QAC9B,GAAG,CAAC,MAAM,KAAK,IAAI,CACpB,CAAC;AACJ,CAAC;AAKD,SAAgB,yBAAyB,CAAC,KAAc;IACtD,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI;QAAE,OAAO,KAAK,CAAC;IAC9D,MAAM,GAAG,GAAG,KAAgC,CAAC;IAC7C,OAAO,CACL,OAAO,GAAG,CAAC,EAAE,KAAK,QAAQ;QAC1B,GAAG,CAAC,EAAE,CAAC,MAAM,GAAG,CAAC;QACjB,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,GAAG,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;QACnB,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC;QACzB,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAc,EAAE,EAAE,CAAC,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAClE,CAAC;AACJ,CAAC"}
@@ -0,0 +1,31 @@
1
+ import type { RuleStats } from './rule-tracker';
2
+ export interface RuleInsight {
3
+ generatedAt: number;
4
+ summary: {
5
+ totalRulesTracked: number;
6
+ totalUsageCount: number;
7
+ activeRules: number;
8
+ staleRules: number;
9
+ };
10
+ topRules: Array<{
11
+ name: string;
12
+ count: number;
13
+ lastUsed: number;
14
+ classification: 'high' | 'medium' | 'low';
15
+ }>;
16
+ unusedRules: string[];
17
+ trends: {
18
+ recentlyActive: string[];
19
+ declining: string[];
20
+ emerging: string[];
21
+ };
22
+ suggestions: string[];
23
+ }
24
+ export declare class RuleInsightsService {
25
+ generateInsights(stats: Record<string, RuleStats>, allRuleNames: string[], now?: number): RuleInsight;
26
+ private buildTopRules;
27
+ private classifyFrequency;
28
+ private findUnusedRules;
29
+ private analyzeTrends;
30
+ private generateSuggestions;
31
+ }
@@ -0,0 +1,102 @@
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.RuleInsightsService = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const WEEK_MS = 7 * 24 * 60 * 60 * 1000;
12
+ const MONTH_MS = 30 * 24 * 60 * 60 * 1000;
13
+ const TOP_RULES_LIMIT = 10;
14
+ const EMERGING_THRESHOLD = 3;
15
+ const SUGGESTION_UNUSED_PREVIEW = 5;
16
+ let RuleInsightsService = class RuleInsightsService {
17
+ generateInsights(stats, allRuleNames, now = Date.now()) {
18
+ const entries = Object.entries(stats);
19
+ const totalUsageCount = entries.reduce((sum, [, s]) => sum + s.count, 0);
20
+ const avgCount = entries.length > 0 ? totalUsageCount / entries.length : 0;
21
+ const topRules = this.buildTopRules(entries, avgCount);
22
+ const unusedRules = this.findUnusedRules(stats, allRuleNames, now);
23
+ const activeRules = entries.filter(([, s]) => now - s.lastUsed <= WEEK_MS).length;
24
+ const staleRules = entries.filter(([, s]) => now - s.lastUsed > MONTH_MS).length;
25
+ const trends = this.analyzeTrends(entries, avgCount, now);
26
+ const suggestions = this.generateSuggestions(topRules, unusedRules, trends.declining, entries.length);
27
+ return {
28
+ generatedAt: now,
29
+ summary: {
30
+ totalRulesTracked: entries.length,
31
+ totalUsageCount,
32
+ activeRules,
33
+ staleRules,
34
+ },
35
+ topRules: topRules.slice(0, TOP_RULES_LIMIT),
36
+ unusedRules,
37
+ trends,
38
+ suggestions,
39
+ };
40
+ }
41
+ buildTopRules(entries, avgCount) {
42
+ return entries
43
+ .map(([name, s]) => ({
44
+ name,
45
+ count: s.count,
46
+ lastUsed: s.lastUsed,
47
+ classification: this.classifyFrequency(s.count, avgCount),
48
+ }))
49
+ .sort((a, b) => b.count - a.count);
50
+ }
51
+ classifyFrequency(count, avgCount) {
52
+ if (avgCount === 0)
53
+ return 'low';
54
+ if (count > avgCount * 2)
55
+ return 'high';
56
+ if (count > avgCount)
57
+ return 'medium';
58
+ return 'low';
59
+ }
60
+ findUnusedRules(stats, allRuleNames, now) {
61
+ return allRuleNames.filter(name => {
62
+ const s = stats[name];
63
+ return !s || now - s.lastUsed > MONTH_MS;
64
+ });
65
+ }
66
+ analyzeTrends(entries, avgCount, now) {
67
+ const recentlyActive = entries
68
+ .filter(([, s]) => now - s.lastUsed <= WEEK_MS)
69
+ .map(([name]) => name);
70
+ const declining = entries
71
+ .filter(([, s]) => now - s.lastUsed > MONTH_MS && s.count > avgCount)
72
+ .map(([name]) => name);
73
+ const emerging = entries
74
+ .filter(([, s]) => now - s.lastUsed <= WEEK_MS && s.count <= EMERGING_THRESHOLD)
75
+ .map(([name]) => name);
76
+ return { recentlyActive, declining, emerging };
77
+ }
78
+ generateSuggestions(topRules, unusedRules, declining, totalTracked) {
79
+ const suggestions = [];
80
+ if (totalTracked === 0) {
81
+ suggestions.push('No tracking data available yet — use parse_mode to start collecting rule usage data');
82
+ return suggestions;
83
+ }
84
+ const highFreq = topRules.filter(r => r.classification === 'high');
85
+ if (highFreq.length > 0) {
86
+ suggestions.push(`High-frequency rules [${highFreq.map(r => r.name).join(', ')}] may need stricter enforcement or developer education`);
87
+ }
88
+ if (unusedRules.length > 0) {
89
+ const preview = unusedRules.slice(0, SUGGESTION_UNUSED_PREVIEW).join(', ');
90
+ suggestions.push(`${unusedRules.length} unused/stale rules detected — consider removing or updating: ${preview}`);
91
+ }
92
+ if (declining.length > 0) {
93
+ suggestions.push(`Rules [${declining.join(', ')}] were once active but have declined — verify they are still relevant`);
94
+ }
95
+ return suggestions;
96
+ }
97
+ };
98
+ exports.RuleInsightsService = RuleInsightsService;
99
+ exports.RuleInsightsService = RuleInsightsService = __decorate([
100
+ (0, common_1.Injectable)()
101
+ ], RuleInsightsService);
102
+ //# sourceMappingURL=rule-insights.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rule-insights.service.js","sourceRoot":"","sources":["../../../src/rules/rule-insights.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ export interface RuleStats {
2
+ count: number;
3
+ lastUsed: number;
4
+ }
5
+ export interface RuleEffectivenessReport {
6
+ totalRulesTracked: number;
7
+ generatedAt: number;
8
+ entries: Array<{
9
+ name: string;
10
+ count: number;
11
+ lastUsed: number;
12
+ }>;
13
+ }
14
+ export declare class RuleTracker {
15
+ private readonly statsPath;
16
+ private stats;
17
+ constructor(statsPath: string);
18
+ static fromFile(statsPath: string): Promise<RuleTracker>;
19
+ trackRuleUsage(ruleNames: string[]): void;
20
+ getStats(): Record<string, RuleStats>;
21
+ detectUnusedRules(allRuleNames: string[], thresholdDays: number): string[];
22
+ generateReport(): RuleEffectivenessReport;
23
+ save(): Promise<void>;
24
+ }
@@ -0,0 +1,74 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RuleTracker = void 0;
4
+ const promises_1 = require("fs/promises");
5
+ const fs_1 = require("fs");
6
+ const path_1 = require("path");
7
+ class RuleTracker {
8
+ constructor(statsPath) {
9
+ this.statsPath = statsPath;
10
+ this.stats = {};
11
+ }
12
+ static async fromFile(statsPath) {
13
+ const tracker = new RuleTracker(statsPath);
14
+ try {
15
+ const raw = await (0, promises_1.readFile)(statsPath, 'utf-8');
16
+ tracker.stats = JSON.parse(raw);
17
+ }
18
+ catch {
19
+ }
20
+ return tracker;
21
+ }
22
+ trackRuleUsage(ruleNames) {
23
+ const now = Date.now();
24
+ for (const name of ruleNames) {
25
+ if (!name)
26
+ continue;
27
+ if (this.stats[name]) {
28
+ this.stats[name].count += 1;
29
+ this.stats[name].lastUsed = now;
30
+ }
31
+ else {
32
+ this.stats[name] = { count: 1, lastUsed: now };
33
+ }
34
+ }
35
+ }
36
+ getStats() {
37
+ return JSON.parse(JSON.stringify(this.stats));
38
+ }
39
+ detectUnusedRules(allRuleNames, thresholdDays) {
40
+ const thresholdMs = thresholdDays * 24 * 60 * 60 * 1000;
41
+ const now = Date.now();
42
+ const unused = [];
43
+ for (const name of allRuleNames) {
44
+ const stat = this.stats[name];
45
+ if (!stat || now - stat.lastUsed > thresholdMs) {
46
+ unused.push(name);
47
+ }
48
+ }
49
+ return unused;
50
+ }
51
+ generateReport() {
52
+ const entries = Object.entries(this.stats)
53
+ .map(([name, stat]) => ({
54
+ name,
55
+ count: stat.count,
56
+ lastUsed: stat.lastUsed,
57
+ }))
58
+ .sort((a, b) => b.count - a.count);
59
+ return {
60
+ totalRulesTracked: entries.length,
61
+ generatedAt: Date.now(),
62
+ entries,
63
+ };
64
+ }
65
+ async save() {
66
+ const dir = (0, path_1.dirname)(this.statsPath);
67
+ if (!(0, fs_1.existsSync)(dir)) {
68
+ (0, fs_1.mkdirSync)(dir, { recursive: true });
69
+ }
70
+ await (0, promises_1.writeFile)(this.statsPath, JSON.stringify(this.stats, null, 2), 'utf-8');
71
+ }
72
+ }
73
+ exports.RuleTracker = RuleTracker;
74
+ //# sourceMappingURL=rule-tracker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rule-tracker.js","sourceRoot":"","sources":["../../../src/rules/rule-tracker.ts"],"names":[],"mappings":"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"}
@@ -9,6 +9,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
9
9
  exports.RulesModule = void 0;
10
10
  const common_1 = require("@nestjs/common");
11
11
  const rules_service_1 = require("./rules.service");
12
+ const rule_insights_service_1 = require("./rule-insights.service");
12
13
  const custom_1 = require("../custom");
13
14
  const config_module_1 = require("../config/config.module");
14
15
  let RulesModule = class RulesModule {
@@ -17,8 +18,8 @@ exports.RulesModule = RulesModule;
17
18
  exports.RulesModule = RulesModule = __decorate([
18
19
  (0, common_1.Module)({
19
20
  imports: [custom_1.CustomModule, config_module_1.CodingBuddyConfigModule],
20
- providers: [rules_service_1.RulesService],
21
- exports: [rules_service_1.RulesService],
21
+ providers: [rules_service_1.RulesService, rule_insights_service_1.RuleInsightsService],
22
+ exports: [rules_service_1.RulesService, rule_insights_service_1.RuleInsightsService],
22
23
  })
23
24
  ], RulesModule);
24
25
  //# sourceMappingURL=rules.module.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"rules.module.js","sourceRoot":"","sources":["../../../src/rules/rules.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,mDAA+C;AAC/C,sCAAyC;AACzC,2DAAkE;AAO3D,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IALvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,qBAAY,EAAE,uCAAuB,CAAC;QAChD,SAAS,EAAE,CAAC,4BAAY,CAAC;QACzB,OAAO,EAAE,CAAC,4BAAY,CAAC;KACxB,CAAC;GACW,WAAW,CAAG"}
1
+ {"version":3,"file":"rules.module.js","sourceRoot":"","sources":["../../../src/rules/rules.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,mDAA+C;AAC/C,mEAA8D;AAC9D,sCAAyC;AACzC,2DAAkE;AAO3D,IAAM,WAAW,GAAjB,MAAM,WAAW;CAAG,CAAA;AAAd,kCAAW;sBAAX,WAAW;IALvB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,qBAAY,EAAE,uCAAuB,CAAC;QAChD,SAAS,EAAE,CAAC,4BAAY,EAAE,2CAAmB,CAAC;QAC9C,OAAO,EAAE,CAAC,4BAAY,EAAE,2CAAmB,CAAC;KAC7C,CAAC;GACW,WAAW,CAAG"}
@@ -0,0 +1,17 @@
1
+ export declare const EVENT_TYPES: readonly ["tool_call", "session_start", "session_end", "pattern_detected", "rule_suggested"];
2
+ export type EventType = (typeof EVENT_TYPES)[number];
3
+ export interface BridgeEvent {
4
+ ts: string;
5
+ type: EventType;
6
+ session_id: string;
7
+ payload: Record<string, unknown>;
8
+ }
9
+ export declare class EventBridgeReader {
10
+ readonly eventsDir: string;
11
+ private readonly sessionId;
12
+ private offset;
13
+ constructor(sessionId: string, eventsDir?: string);
14
+ private get filePath();
15
+ readNewEvents(): Promise<BridgeEvent[]>;
16
+ cleanup(): Promise<void>;
17
+ }
@@ -0,0 +1,56 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.EventBridgeReader = exports.EVENT_TYPES = void 0;
4
+ const fs_1 = require("fs");
5
+ const path_1 = require("path");
6
+ const os_1 = require("os");
7
+ exports.EVENT_TYPES = [
8
+ 'tool_call',
9
+ 'session_start',
10
+ 'session_end',
11
+ 'pattern_detected',
12
+ 'rule_suggested',
13
+ ];
14
+ class EventBridgeReader {
15
+ constructor(sessionId, eventsDir) {
16
+ this.offset = 0;
17
+ this.sessionId = sessionId;
18
+ this.eventsDir = eventsDir ?? (0, path_1.join)((0, os_1.homedir)(), '.codingbuddy', 'events');
19
+ }
20
+ get filePath() {
21
+ return (0, path_1.join)(this.eventsDir, `${this.sessionId}.jsonl`);
22
+ }
23
+ async readNewEvents() {
24
+ let content;
25
+ try {
26
+ const buffer = await fs_1.promises.readFile(this.filePath, 'utf-8');
27
+ content = buffer.slice(this.offset);
28
+ this.offset = buffer.length;
29
+ }
30
+ catch {
31
+ return [];
32
+ }
33
+ if (!content) {
34
+ return [];
35
+ }
36
+ const events = [];
37
+ const lines = content.split('\n').filter(line => line.trim().length > 0);
38
+ for (const line of lines) {
39
+ try {
40
+ events.push(JSON.parse(line));
41
+ }
42
+ catch {
43
+ }
44
+ }
45
+ return events;
46
+ }
47
+ async cleanup() {
48
+ try {
49
+ await fs_1.promises.unlink(this.filePath);
50
+ }
51
+ catch {
52
+ }
53
+ }
54
+ }
55
+ exports.EventBridgeReader = EventBridgeReader;
56
+ //# sourceMappingURL=event-bridge-reader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-bridge-reader.js","sourceRoot":"","sources":["../../../src/shared/event-bridge-reader.ts"],"names":[],"mappings":";;;AAMA,2BAAoC;AACpC,+BAA4B;AAC5B,2BAA6B;AAGhB,QAAA,WAAW,GAAG;IACzB,WAAW;IACX,eAAe;IACf,aAAa;IACb,kBAAkB;IAClB,gBAAgB;CACR,CAAC;AAgBX,MAAa,iBAAiB;IAK5B,YAAY,SAAiB,EAAE,SAAkB;QAFzC,WAAM,GAAG,CAAC,CAAC;QAGjB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,SAAS,GAAG,SAAS,IAAI,IAAA,WAAI,EAAC,IAAA,YAAO,GAAE,EAAE,cAAc,EAAE,QAAQ,CAAC,CAAC;IAC1E,CAAC;IAED,IAAY,QAAQ;QAClB,OAAO,IAAA,WAAI,EAAC,IAAI,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC,SAAS,QAAQ,CAAC,CAAC;IACzD,CAAC;IAOD,KAAK,CAAC,aAAa;QACjB,IAAI,OAAe,CAAC;QACpB,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,aAAE,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;YACzD,OAAO,GAAG,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACpC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,CAAC;QAC9B,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,EAAE,CAAC;QACZ,CAAC;QAED,MAAM,MAAM,GAAkB,EAAE,CAAC;QACjC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAEzE,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,IAAI,CAAC;gBACH,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAgB,CAAC,CAAC;YAC/C,CAAC;YAAC,MAAM,CAAC;YAET,CAAC;QACH,CAAC;QAED,OAAO,MAAM,CAAC;IAChB,CAAC;IAGD,KAAK,CAAC,OAAO;QACX,IAAI,CAAC;YACH,MAAM,aAAE,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;QAAC,MAAM,CAAC;QAET,CAAC;IACH,CAAC;CACF;AAvDD,8CAuDC"}
@@ -1 +1 @@
1
- export declare const VERSION = "4.5.0";
1
+ export declare const VERSION = "5.1.0";
@@ -1,5 +1,5 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.VERSION = void 0;
4
- exports.VERSION = '4.5.0';
4
+ exports.VERSION = '5.1.0';
5
5
  //# sourceMappingURL=version.js.map
@@ -1,6 +1,8 @@
1
- export type SupportedLanguage = 'en' | 'ko' | 'ja' | 'zh' | 'es';
1
+ export type SupportedLanguage = 'en' | 'ko' | 'ja' | 'zh' | 'es' | 'pt' | 'de' | 'fr';
2
2
  export type ConceptKeywords = {
3
- [lang in SupportedLanguage]: string[];
3
+ [lang in SupportedLanguage]?: string[];
4
+ } & {
5
+ en: string[];
4
6
  };
5
7
  export interface SkillKeywordConfig {
6
8
  skillName: string;
@@ -7,5 +7,8 @@ exports.LANGUAGE_OPTIONS = {
7
7
  ja: { useWordBoundary: false },
8
8
  zh: { useWordBoundary: false },
9
9
  es: { useWordBoundary: true },
10
+ pt: { useWordBoundary: true },
11
+ de: { useWordBoundary: true },
12
+ fr: { useWordBoundary: true },
10
13
  };
11
14
  //# sourceMappingURL=keywords.types.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"keywords.types.js","sourceRoot":"","sources":["../../../../src/skill/i18n/keywords.types.ts"],"names":[],"mappings":";;;AA2Ba,QAAA,gBAAgB,GAA4D;IACvF,EAAE,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE;IAC7B,EAAE,EAAE,EAAE,eAAe,EAAE,KAAK,EAAE;IAC9B,EAAE,EAAE,EAAE,eAAe,EAAE,KAAK,EAAE;IAC9B,EAAE,EAAE,EAAE,eAAe,EAAE,KAAK,EAAE;IAC9B,EAAE,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE;CAC9B,CAAC"}
1
+ {"version":3,"file":"keywords.types.js","sourceRoot":"","sources":["../../../../src/skill/i18n/keywords.types.ts"],"names":[],"mappings":";;;AA2Ba,QAAA,gBAAgB,GAA4D;IACvF,EAAE,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE;IAC7B,EAAE,EAAE,EAAE,eAAe,EAAE,KAAK,EAAE;IAC9B,EAAE,EAAE,EAAE,eAAe,EAAE,KAAK,EAAE;IAC9B,EAAE,EAAE,EAAE,eAAe,EAAE,KAAK,EAAE;IAC9B,EAAE,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE;IAC7B,EAAE,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE;IAC7B,EAAE,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE;IAC7B,EAAE,EAAE,EAAE,eAAe,EAAE,IAAI,EAAE;CAC9B,CAAC"}
@@ -0,0 +1,10 @@
1
+ import React from 'react';
2
+ import type { TddPhase, TddStep, DashboardNode } from '../dashboard-types';
3
+ export interface ActModeScreenProps {
4
+ currentPhase: TddPhase | null;
5
+ steps: readonly TddStep[];
6
+ agents: ReadonlyMap<string, DashboardNode>;
7
+ width: number;
8
+ height: number;
9
+ }
10
+ export declare function ActModeScreen({ currentPhase, steps, agents, width, height, }: ActModeScreenProps): React.ReactElement;
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ActModeScreen = ActModeScreen;
4
+ const react_1 = require("react");
5
+ const ink_1 = require("ink");
6
+ const theme_1 = require("../utils/theme");
7
+ const act_screen_pure_1 = require("./act-screen.pure");
8
+ function getLineColor(line, currentPhase) {
9
+ if (line.type === 'header')
10
+ return 'magenta';
11
+ if (line.type === 'phase-bar' && currentPhase)
12
+ return act_screen_pure_1.PHASE_COLORS[currentPhase];
13
+ if (line.type === 'progress')
14
+ return 'cyan';
15
+ if (line.type === 'empty')
16
+ return 'gray';
17
+ return 'white';
18
+ }
19
+ function ActModeScreen({ currentPhase, steps, agents, width, height, }) {
20
+ const lines = (0, react_1.useMemo)(() => (0, act_screen_pure_1.renderActScreen)(currentPhase, steps, agents, width - 2), [currentPhase, steps, agents, width]);
21
+ const maxLines = Math.max(0, height - 2);
22
+ const visibleLines = lines.slice(0, maxLines);
23
+ return (react_1.default.createElement(ink_1.Box, { flexDirection: "column", width: width, height: height, borderStyle: "round", borderColor: theme_1.BORDER_COLORS.panel }, visibleLines.map((line, i) => (react_1.default.createElement(ink_1.Text, { key: i, color: getLineColor(line, currentPhase), bold: line.type === 'header' || line.type === 'phase-bar', dimColor: line.type === 'empty', wrap: "truncate" }, line.text)))));
24
+ }
25
+ //# sourceMappingURL=ActModeScreen.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ActModeScreen.js","sourceRoot":"","sources":["../../../../src/tui/components/ActModeScreen.tsx"],"names":[],"mappings":";;AA2BA,sCAoCC;AA1DD,iCAAuC;AACvC,6BAAgC;AAEhC,0CAA+C;AAC/C,uDAAsF;AAUtF,SAAS,YAAY,CAAC,IAAmB,EAAE,YAA6B;IACtE,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ;QAAE,OAAO,SAAS,CAAC;IAC7C,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,IAAI,YAAY;QAAE,OAAO,8BAAY,CAAC,YAAY,CAAC,CAAC;IACjF,IAAI,IAAI,CAAC,IAAI,KAAK,UAAU;QAAE,OAAO,MAAM,CAAC;IAC5C,IAAI,IAAI,CAAC,IAAI,KAAK,OAAO;QAAE,OAAO,MAAM,CAAC;IACzC,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAgB,aAAa,CAAC,EAC5B,YAAY,EACZ,KAAK,EACL,MAAM,EACN,KAAK,EACL,MAAM,GACa;IACnB,MAAM,KAAK,GAAG,IAAA,eAAO,EACnB,GAAG,EAAE,CAAC,IAAA,iCAAe,EAAC,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,GAAG,CAAC,CAAC,EAC7D,CAAC,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,CACrC,CAAC;IAEF,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;IACzC,MAAM,YAAY,GAAG,KAAK,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC;IAE9C,OAAO,CACL,8BAAC,SAAG,IACF,aAAa,EAAC,QAAQ,EACtB,KAAK,EAAE,KAAK,EACZ,MAAM,EAAE,MAAM,EACd,WAAW,EAAC,OAAO,EACnB,WAAW,EAAE,qBAAa,CAAC,KAAK,IAE/B,YAAY,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAC7B,8BAAC,UAAI,IACH,GAAG,EAAE,CAAC,EACN,KAAK,EAAE,YAAY,CAAC,IAAI,EAAE,YAAY,CAAC,EACvC,IAAI,EAAE,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,KAAK,WAAW,EACzD,QAAQ,EAAE,IAAI,CAAC,IAAI,KAAK,OAAO,EAC/B,IAAI,EAAC,UAAU,IAEd,IAAI,CAAC,IAAI,CACL,CACR,CAAC,CACE,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,8 @@
1
+ import React from 'react';
2
+ import type { DiscussionRound } from '../../collaboration/types';
3
+ export interface AgentDiscussionPanelProps {
4
+ rounds: readonly DiscussionRound[];
5
+ width: number;
6
+ height: number;
7
+ }
8
+ export declare function AgentDiscussionPanel({ rounds, width, height, }: AgentDiscussionPanelProps): React.ReactElement;