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,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":"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"}
|
|
@@ -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;
|
|
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 = "
|
|
1
|
+
export declare const VERSION = "5.1.0";
|
|
@@ -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]
|
|
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;
|