@winspan/claude-forge 0.6.8 → 0.6.9
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/ai-gateway/index.d.ts.map +1 -1
- package/dist/ai-gateway/index.js +8 -1
- package/dist/ai-gateway/index.js.map +1 -1
- package/dist/daemon/handlers/context-builder.d.ts +7 -5
- package/dist/daemon/handlers/context-builder.d.ts.map +1 -1
- package/dist/daemon/handlers/context-builder.js +29 -26
- package/dist/daemon/handlers/context-builder.js.map +1 -1
- package/dist/daemon/handlers/orchestration-context.d.ts +3 -0
- package/dist/daemon/handlers/orchestration-context.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/01-failure-signal.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/01-failure-signal.js +1 -0
- package/dist/daemon/handlers/stages/01-failure-signal.js.map +1 -1
- package/dist/daemon/handlers/stages/04-skill-suggestions.js +1 -1
- package/dist/daemon/handlers/stages/04-skill-suggestions.js.map +1 -1
- package/dist/daemon/handlers/stages/07-pipeline-reply.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/07-pipeline-reply.js +2 -0
- package/dist/daemon/handlers/stages/07-pipeline-reply.js.map +1 -1
- package/dist/daemon/handlers/stages/10-cooldown.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/10-cooldown.js +21 -0
- package/dist/daemon/handlers/stages/10-cooldown.js.map +1 -1
- package/dist/daemon/handlers/stages/11-intent-analysis.d.ts +2 -0
- package/dist/daemon/handlers/stages/11-intent-analysis.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/11-intent-analysis.js +21 -3
- package/dist/daemon/handlers/stages/11-intent-analysis.js.map +1 -1
- package/dist/daemon/handlers/stages/17-simple-task.js +1 -1
- package/dist/daemon/handlers/stages/17-simple-task.js.map +1 -1
- package/dist/daemon/handlers/stages/18-complex-task.d.ts +2 -0
- package/dist/daemon/handlers/stages/18-complex-task.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/18-complex-task.js +24 -2
- package/dist/daemon/handlers/stages/18-complex-task.js.map +1 -1
- package/dist/daemon/handlers/stages/19-moderate-task.d.ts +2 -0
- package/dist/daemon/handlers/stages/19-moderate-task.d.ts.map +1 -1
- package/dist/daemon/handlers/stages/19-moderate-task.js +22 -2
- package/dist/daemon/handlers/stages/19-moderate-task.js.map +1 -1
- package/dist/daemon/handlers/stages/stage-interface.d.ts +4 -1
- package/dist/daemon/handlers/stages/stage-interface.d.ts.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.d.ts +9 -0
- package/dist/daemon/handlers/user-prompt-handler.d.ts.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.js +77 -0
- package/dist/daemon/handlers/user-prompt-handler.js.map +1 -1
- package/dist/storage/repositories/base-repository.d.ts +6 -0
- package/dist/storage/repositories/base-repository.d.ts.map +1 -1
- package/dist/storage/repositories/base-repository.js +23 -0
- package/dist/storage/repositories/base-repository.js.map +1 -1
- package/dist/storage/repositories/event-repository.d.ts.map +1 -1
- package/dist/storage/repositories/event-repository.js +96 -87
- package/dist/storage/repositories/event-repository.js.map +1 -1
- package/dist/storage/repositories/graph-traversal.d.ts +37 -0
- package/dist/storage/repositories/graph-traversal.d.ts.map +1 -0
- package/dist/storage/repositories/graph-traversal.js +157 -0
- package/dist/storage/repositories/graph-traversal.js.map +1 -0
- package/dist/storage/repositories/knowledge-repository.d.ts +14 -0
- package/dist/storage/repositories/knowledge-repository.d.ts.map +1 -1
- package/dist/storage/repositories/knowledge-repository.js +22 -0
- package/dist/storage/repositories/knowledge-repository.js.map +1 -1
- package/dist/storage/repositories/latency-repository.d.ts.map +1 -1
- package/dist/storage/repositories/latency-repository.js +2 -5
- package/dist/storage/repositories/latency-repository.js.map +1 -1
- package/dist/storage/repositories/maintenance-repository.d.ts +3 -0
- package/dist/storage/repositories/maintenance-repository.d.ts.map +1 -1
- package/dist/storage/repositories/maintenance-repository.js +12 -3
- package/dist/storage/repositories/maintenance-repository.js.map +1 -1
- package/dist/storage/repositories/task-repository.d.ts.map +1 -1
- package/dist/storage/repositories/task-repository.js +16 -11
- package/dist/storage/repositories/task-repository.js.map +1 -1
- package/dist/storage/sqlite.d.ts.map +1 -1
- package/dist/storage/sqlite.js +16 -1
- package/dist/storage/sqlite.js.map +1 -1
- package/dist/utils/error-handler.d.ts +39 -0
- package/dist/utils/error-handler.d.ts.map +1 -0
- package/dist/utils/error-handler.js +155 -0
- package/dist/utils/error-handler.js.map +1 -0
- package/package.json +1 -1
|
@@ -10,97 +10,104 @@ export class EventRepository extends BaseRepository {
|
|
|
10
10
|
'and', 'or', 'but', 'not', 'it', 'this', 'that',
|
|
11
11
|
]);
|
|
12
12
|
writeEvent(event) {
|
|
13
|
-
|
|
14
|
-
const
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
.
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
13
|
+
this.writeWithRetry(() => {
|
|
14
|
+
const tx = this.db.transaction((ev) => {
|
|
15
|
+
const toolInputStr = ev.tool_input ? JSON.stringify(ev.tool_input) : null;
|
|
16
|
+
const changes = this.db.prepare(`
|
|
17
|
+
INSERT OR IGNORE INTO events (
|
|
18
|
+
event_id, session_id, project_path, timestamp,
|
|
19
|
+
hook_type, tool_name, tool_input, tool_output,
|
|
20
|
+
user_prompt, ai_response, distilled
|
|
21
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
22
|
+
`).run(ev.event_id, ev.session_id, ev.project_path, ev.timestamp, ev.hook_type, ev.tool_name || null, toolInputStr, ev.tool_output ? JSON.stringify(ev.tool_output) : null, ev.user_prompt || null, ev.ai_response || null, ev.distilled ? 1 : 0);
|
|
23
|
+
if (changes.changes > 0) {
|
|
24
|
+
try {
|
|
25
|
+
const row = this.db.prepare('SELECT rowid FROM events WHERE event_id = ?')
|
|
26
|
+
.get(ev.event_id);
|
|
27
|
+
if (row) {
|
|
28
|
+
this.db.prepare(`
|
|
29
|
+
INSERT OR IGNORE INTO events_fts(rowid, event_id, session_id, project_path, tool_name, tool_input, user_prompt)
|
|
30
|
+
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
31
|
+
`).run(row.rowid, ev.event_id, ev.session_id, ev.project_path, ev.tool_name || null, toolInputStr, ev.user_prompt || null);
|
|
32
|
+
}
|
|
31
33
|
}
|
|
34
|
+
catch { /* FTS5 表可能尚未创建,静默忽略 */ }
|
|
32
35
|
}
|
|
33
|
-
|
|
36
|
+
// 同步更新会话
|
|
37
|
+
const existing = this.db.prepare('SELECT session_id FROM sessions WHERE session_id = ? AND project_path = ?').get(ev.session_id, ev.project_path);
|
|
38
|
+
if (!existing) {
|
|
39
|
+
this.db.prepare(`
|
|
40
|
+
INSERT INTO sessions (session_id, project_path, status, start_time, last_event_time, event_count)
|
|
41
|
+
VALUES (?, ?, 'active', ?, ?, 1)
|
|
42
|
+
ON CONFLICT(session_id) DO UPDATE SET
|
|
43
|
+
project_path = excluded.project_path,
|
|
44
|
+
last_event_time = excluded.last_event_time,
|
|
45
|
+
event_count = event_count + 1, updated_at = datetime('now')
|
|
46
|
+
`).run(ev.session_id, ev.project_path, ev.timestamp, ev.timestamp);
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
this.db.prepare(`
|
|
50
|
+
UPDATE sessions SET last_event_time = ?, event_count = event_count + 1, updated_at = datetime('now')
|
|
51
|
+
WHERE session_id = ? AND project_path = ?
|
|
52
|
+
`).run(ev.timestamp, ev.session_id, ev.project_path);
|
|
53
|
+
}
|
|
54
|
+
if (ev.hook_type === 'Stop') {
|
|
55
|
+
this.db.prepare(`
|
|
56
|
+
UPDATE sessions SET status = 'completed', end_time = ?, updated_at = datetime('now')
|
|
57
|
+
WHERE session_id = ? AND project_path = ?
|
|
58
|
+
`).run(ev.timestamp, ev.session_id, ev.project_path);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
tx(event);
|
|
62
|
+
}, '写入事件');
|
|
63
|
+
}
|
|
64
|
+
queryEvents(filters) {
|
|
65
|
+
try {
|
|
66
|
+
let sql = 'SELECT * FROM events WHERE 1=1';
|
|
67
|
+
const params = [];
|
|
68
|
+
if (filters.session_id) {
|
|
69
|
+
sql += ' AND session_id = ?';
|
|
70
|
+
params.push(filters.session_id);
|
|
34
71
|
}
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
this.db.prepare(`
|
|
39
|
-
INSERT INTO sessions (session_id, project_path, status, start_time, last_event_time, event_count)
|
|
40
|
-
VALUES (?, ?, 'active', ?, ?, 1)
|
|
41
|
-
ON CONFLICT(session_id) DO UPDATE SET
|
|
42
|
-
project_path = excluded.project_path,
|
|
43
|
-
last_event_time = excluded.last_event_time,
|
|
44
|
-
event_count = event_count + 1, updated_at = datetime('now')
|
|
45
|
-
`).run(ev.session_id, ev.project_path, ev.timestamp, ev.timestamp);
|
|
72
|
+
if (filters.project_path) {
|
|
73
|
+
sql += ' AND project_path = ?';
|
|
74
|
+
params.push(filters.project_path);
|
|
46
75
|
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
WHERE session_id = ? AND project_path = ?
|
|
51
|
-
`).run(ev.timestamp, ev.session_id, ev.project_path);
|
|
76
|
+
if (filters.start_time) {
|
|
77
|
+
sql += ' AND timestamp >= ?';
|
|
78
|
+
params.push(filters.start_time);
|
|
52
79
|
}
|
|
53
|
-
if (
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
WHERE session_id = ? AND project_path = ?
|
|
57
|
-
`).run(ev.timestamp, ev.session_id, ev.project_path);
|
|
80
|
+
if (filters.end_time) {
|
|
81
|
+
sql += ' AND timestamp <= ?';
|
|
82
|
+
params.push(filters.end_time);
|
|
58
83
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
sql += ' AND tool_name = ?';
|
|
83
|
-
params.push(filters.tool_name);
|
|
84
|
-
}
|
|
85
|
-
if (filters.hook_type) {
|
|
86
|
-
sql += ' AND hook_type = ?';
|
|
87
|
-
params.push(filters.hook_type);
|
|
88
|
-
}
|
|
89
|
-
if (filters.distilled !== undefined) {
|
|
90
|
-
sql += ' AND distilled = ?';
|
|
91
|
-
params.push(filters.distilled ? 1 : 0);
|
|
92
|
-
}
|
|
93
|
-
sql += ' ORDER BY timestamp DESC';
|
|
94
|
-
if (filters.limit) {
|
|
95
|
-
sql += ' LIMIT ?';
|
|
96
|
-
params.push(filters.limit);
|
|
84
|
+
if (filters.tool_name) {
|
|
85
|
+
sql += ' AND tool_name = ?';
|
|
86
|
+
params.push(filters.tool_name);
|
|
87
|
+
}
|
|
88
|
+
if (filters.hook_type) {
|
|
89
|
+
sql += ' AND hook_type = ?';
|
|
90
|
+
params.push(filters.hook_type);
|
|
91
|
+
}
|
|
92
|
+
if (filters.distilled !== undefined) {
|
|
93
|
+
sql += ' AND distilled = ?';
|
|
94
|
+
params.push(filters.distilled ? 1 : 0);
|
|
95
|
+
}
|
|
96
|
+
sql += ' ORDER BY timestamp DESC';
|
|
97
|
+
if (filters.limit) {
|
|
98
|
+
sql += ' LIMIT ?';
|
|
99
|
+
params.push(filters.limit);
|
|
100
|
+
}
|
|
101
|
+
if (filters.offset) {
|
|
102
|
+
sql += ' OFFSET ?';
|
|
103
|
+
params.push(filters.offset);
|
|
104
|
+
}
|
|
105
|
+
const rows = this.db.prepare(sql).all(...params);
|
|
106
|
+
return rows.map(this.rowToEvent);
|
|
97
107
|
}
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
params.push(filters.offset);
|
|
108
|
+
catch {
|
|
109
|
+
return [];
|
|
101
110
|
}
|
|
102
|
-
const rows = this.db.prepare(sql).all(...params);
|
|
103
|
-
return rows.map(this.rowToEvent);
|
|
104
111
|
}
|
|
105
112
|
countEvents(filters) {
|
|
106
113
|
let sql = 'SELECT COUNT(*) as count FROM events WHERE 1=1';
|
|
@@ -121,10 +128,12 @@ export class EventRepository extends BaseRepository {
|
|
|
121
128
|
return row.count;
|
|
122
129
|
}
|
|
123
130
|
markEventsDistilled(eventIds) {
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
131
|
+
this.writeWithRetry(() => {
|
|
132
|
+
const stmt = this.db.prepare('UPDATE events SET distilled = 1 WHERE event_id = ?');
|
|
133
|
+
const tx = this.db.transaction((ids) => { for (const id of ids)
|
|
134
|
+
stmt.run(id); });
|
|
135
|
+
tx(eventIds);
|
|
136
|
+
}, '标记事件已蒸馏');
|
|
128
137
|
}
|
|
129
138
|
getUndistilledEvents(sessionId, projectPath) {
|
|
130
139
|
return this.queryEvents({ session_id: sessionId, distilled: false, ...(projectPath ? { project_path: projectPath } : {}) });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/event-repository.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,OAAO,eAAgB,SAAQ,cAAc;IACzC,MAAM,CAAU,SAAS,GAAG,IAAI,GAAG,CAAC;QAC1C,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;QAChD,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;QAChD,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;QAChD,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG;QAChD,KAAK,EAAE,GAAG,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK;QACzD,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM;QACzD,KAAK,EAAE,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM;KAChD,CAAC,CAAC;IAEH,UAAU,CAAC,KAAiB;QAC1B,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,EAAc,EAAE,EAAE;
|
|
1
|
+
{"version":3,"file":"event-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/event-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type Database from 'better-sqlite3';
|
|
2
|
+
/** 图遍历结果:路径 + 总权重 */
|
|
3
|
+
export interface GraphPath {
|
|
4
|
+
nodes: string[];
|
|
5
|
+
edges: Array<{
|
|
6
|
+
from: string;
|
|
7
|
+
to: string;
|
|
8
|
+
type: string;
|
|
9
|
+
weight: number;
|
|
10
|
+
}>;
|
|
11
|
+
totalWeight: number;
|
|
12
|
+
}
|
|
13
|
+
/** 知识图谱遍历算法(BFS/DFS + 缓存) */
|
|
14
|
+
export declare class GraphTraversal {
|
|
15
|
+
private db;
|
|
16
|
+
private cache;
|
|
17
|
+
private readonly CACHE_TTL;
|
|
18
|
+
constructor(db: Database.Database);
|
|
19
|
+
/** BFS 查找最短路径(按边数) */
|
|
20
|
+
findShortestPath(fromNodeId: string, toNodeId: string, maxDepth?: number): GraphPath | null;
|
|
21
|
+
/** DFS 查找所有路径(按权重排序,返回 Top-K) */
|
|
22
|
+
findAllPaths(fromNodeId: string, toNodeId: string, maxDepth?: number, topK?: number): GraphPath[];
|
|
23
|
+
/** 查找 K 跳邻居(广度优先,按权重排序) */
|
|
24
|
+
findKHopNeighbors(nodeId: string, k: number, limit?: number): Array<{
|
|
25
|
+
nodeId: string;
|
|
26
|
+
distance: number;
|
|
27
|
+
totalWeight: number;
|
|
28
|
+
}>;
|
|
29
|
+
/** 清理过期缓存 */
|
|
30
|
+
cleanExpiredCache(): number;
|
|
31
|
+
/** 清空所有缓存 */
|
|
32
|
+
clearCache(): void;
|
|
33
|
+
private getOutgoingEdges;
|
|
34
|
+
private getFromCache;
|
|
35
|
+
private setCache;
|
|
36
|
+
}
|
|
37
|
+
//# sourceMappingURL=graph-traversal.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph-traversal.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/graph-traversal.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,QAAQ,MAAM,gBAAgB,CAAC;AAE3C,qBAAqB;AACrB,MAAM,WAAW,SAAS;IACxB,KAAK,EAAE,MAAM,EAAE,CAAC;IAChB,KAAK,EAAE,KAAK,CAAC;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,EAAE,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC;IACzE,WAAW,EAAE,MAAM,CAAC;CACrB;AAQD,6BAA6B;AAC7B,qBAAa,cAAc;IAIb,OAAO,CAAC,EAAE;IAHtB,OAAO,CAAC,KAAK,CAAiC;IAC9C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAiB;gBAEvB,EAAE,EAAE,QAAQ,CAAC,QAAQ;IAEzC,sBAAsB;IACtB,gBAAgB,CACd,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,MAAM,EAChB,QAAQ,SAAI,GACX,SAAS,GAAG,IAAI;IAsCnB,iCAAiC;IACjC,YAAY,CACV,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,MAAM,EAChB,QAAQ,SAAI,EACZ,IAAI,SAAI,GACP,SAAS,EAAE;IAuCd,2BAA2B;IAC3B,iBAAiB,CACf,MAAM,EAAE,MAAM,EACd,CAAC,EAAE,MAAM,EACT,KAAK,SAAK,GACT,KAAK,CAAC;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE,CAAC;IAsCnE,aAAa;IACb,iBAAiB,IAAI,MAAM;IAY3B,aAAa;IACb,UAAU,IAAI,IAAI;IAIlB,OAAO,CAAC,gBAAgB;IAexB,OAAO,CAAC,YAAY;IAUpB,OAAO,CAAC,QAAQ;CAGjB"}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
/** 知识图谱遍历算法(BFS/DFS + 缓存) */
|
|
2
|
+
export class GraphTraversal {
|
|
3
|
+
db;
|
|
4
|
+
cache = new Map();
|
|
5
|
+
CACHE_TTL = 5 * 60 * 1000; // 5分钟
|
|
6
|
+
constructor(db) {
|
|
7
|
+
this.db = db;
|
|
8
|
+
}
|
|
9
|
+
/** BFS 查找最短路径(按边数) */
|
|
10
|
+
findShortestPath(fromNodeId, toNodeId, maxDepth = 5) {
|
|
11
|
+
const cacheKey = `bfs:${fromNodeId}:${toNodeId}:${maxDepth}`;
|
|
12
|
+
const cached = this.getFromCache(cacheKey);
|
|
13
|
+
if (cached?.[0])
|
|
14
|
+
return cached[0];
|
|
15
|
+
const visited = new Set();
|
|
16
|
+
const queue = [
|
|
17
|
+
{ nodeId: fromNodeId, path: { nodes: [fromNodeId], edges: [], totalWeight: 0 } },
|
|
18
|
+
];
|
|
19
|
+
while (queue.length > 0) {
|
|
20
|
+
const { nodeId, path } = queue.shift();
|
|
21
|
+
if (nodeId === toNodeId) {
|
|
22
|
+
this.setCache(cacheKey, [path]);
|
|
23
|
+
return path;
|
|
24
|
+
}
|
|
25
|
+
if (path.nodes.length >= maxDepth || visited.has(nodeId))
|
|
26
|
+
continue;
|
|
27
|
+
visited.add(nodeId);
|
|
28
|
+
const edges = this.getOutgoingEdges(nodeId);
|
|
29
|
+
for (const edge of edges) {
|
|
30
|
+
if (!visited.has(edge.to_node_id)) {
|
|
31
|
+
queue.push({
|
|
32
|
+
nodeId: edge.to_node_id,
|
|
33
|
+
path: {
|
|
34
|
+
nodes: [...path.nodes, edge.to_node_id],
|
|
35
|
+
edges: [...path.edges, { from: edge.from_node_id, to: edge.to_node_id, type: edge.edge_type, weight: edge.weight }],
|
|
36
|
+
totalWeight: path.totalWeight + edge.weight,
|
|
37
|
+
},
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
/** DFS 查找所有路径(按权重排序,返回 Top-K) */
|
|
45
|
+
findAllPaths(fromNodeId, toNodeId, maxDepth = 5, topK = 3) {
|
|
46
|
+
const cacheKey = `dfs:${fromNodeId}:${toNodeId}:${maxDepth}:${topK}`;
|
|
47
|
+
const cached = this.getFromCache(cacheKey);
|
|
48
|
+
if (cached)
|
|
49
|
+
return cached;
|
|
50
|
+
const allPaths = [];
|
|
51
|
+
const visited = new Set();
|
|
52
|
+
const dfs = (nodeId, path) => {
|
|
53
|
+
if (nodeId === toNodeId) {
|
|
54
|
+
allPaths.push({ ...path });
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
if (path.nodes.length >= maxDepth || visited.has(nodeId))
|
|
58
|
+
return;
|
|
59
|
+
visited.add(nodeId);
|
|
60
|
+
const edges = this.getOutgoingEdges(nodeId);
|
|
61
|
+
for (const edge of edges) {
|
|
62
|
+
if (!visited.has(edge.to_node_id)) {
|
|
63
|
+
dfs(edge.to_node_id, {
|
|
64
|
+
nodes: [...path.nodes, edge.to_node_id],
|
|
65
|
+
edges: [...path.edges, { from: edge.from_node_id, to: edge.to_node_id, type: edge.edge_type, weight: edge.weight }],
|
|
66
|
+
totalWeight: path.totalWeight + edge.weight,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
visited.delete(nodeId);
|
|
71
|
+
};
|
|
72
|
+
dfs(fromNodeId, { nodes: [fromNodeId], edges: [], totalWeight: 0 });
|
|
73
|
+
// 按总权重降序排序,取 Top-K
|
|
74
|
+
const topPaths = allPaths.sort((a, b) => b.totalWeight - a.totalWeight).slice(0, topK);
|
|
75
|
+
this.setCache(cacheKey, topPaths);
|
|
76
|
+
return topPaths;
|
|
77
|
+
}
|
|
78
|
+
/** 查找 K 跳邻居(广度优先,按权重排序) */
|
|
79
|
+
findKHopNeighbors(nodeId, k, limit = 20) {
|
|
80
|
+
const cacheKey = `khop:${nodeId}:${k}:${limit}`;
|
|
81
|
+
const cached = this.getFromCache(cacheKey);
|
|
82
|
+
if (cached)
|
|
83
|
+
return cached;
|
|
84
|
+
const visited = new Map();
|
|
85
|
+
const queue = [
|
|
86
|
+
{ nodeId, distance: 0, totalWeight: 0 },
|
|
87
|
+
];
|
|
88
|
+
while (queue.length > 0) {
|
|
89
|
+
const current = queue.shift();
|
|
90
|
+
if (current.distance > k)
|
|
91
|
+
break;
|
|
92
|
+
if (visited.has(current.nodeId))
|
|
93
|
+
continue;
|
|
94
|
+
visited.set(current.nodeId, { distance: current.distance, totalWeight: current.totalWeight });
|
|
95
|
+
const edges = this.getOutgoingEdges(current.nodeId);
|
|
96
|
+
for (const edge of edges) {
|
|
97
|
+
if (!visited.has(edge.to_node_id)) {
|
|
98
|
+
queue.push({
|
|
99
|
+
nodeId: edge.to_node_id,
|
|
100
|
+
distance: current.distance + 1,
|
|
101
|
+
totalWeight: current.totalWeight + edge.weight,
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
visited.delete(nodeId); // 排除起点
|
|
107
|
+
const result = Array.from(visited.entries())
|
|
108
|
+
.map(([nodeId, info]) => ({ nodeId, ...info }))
|
|
109
|
+
.sort((a, b) => b.totalWeight - a.totalWeight)
|
|
110
|
+
.slice(0, limit);
|
|
111
|
+
this.setCache(cacheKey, result);
|
|
112
|
+
return result;
|
|
113
|
+
}
|
|
114
|
+
/** 清理过期缓存 */
|
|
115
|
+
cleanExpiredCache() {
|
|
116
|
+
const now = Date.now();
|
|
117
|
+
let cleaned = 0;
|
|
118
|
+
for (const [key, entry] of this.cache.entries()) {
|
|
119
|
+
if (now - entry.timestamp > this.CACHE_TTL) {
|
|
120
|
+
this.cache.delete(key);
|
|
121
|
+
cleaned++;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
return cleaned;
|
|
125
|
+
}
|
|
126
|
+
/** 清空所有缓存 */
|
|
127
|
+
clearCache() {
|
|
128
|
+
this.cache.clear();
|
|
129
|
+
}
|
|
130
|
+
getOutgoingEdges(nodeId) {
|
|
131
|
+
try {
|
|
132
|
+
return this.db.prepare(`
|
|
133
|
+
SELECT from_node_id, to_node_id, edge_type, weight
|
|
134
|
+
FROM knowledge_edges
|
|
135
|
+
WHERE from_node_id = ?
|
|
136
|
+
ORDER BY weight DESC
|
|
137
|
+
`).all(nodeId);
|
|
138
|
+
}
|
|
139
|
+
catch {
|
|
140
|
+
return [];
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
getFromCache(key) {
|
|
144
|
+
const entry = this.cache.get(key);
|
|
145
|
+
if (!entry)
|
|
146
|
+
return null;
|
|
147
|
+
if (Date.now() - entry.timestamp > this.CACHE_TTL) {
|
|
148
|
+
this.cache.delete(key);
|
|
149
|
+
return null;
|
|
150
|
+
}
|
|
151
|
+
return entry.paths;
|
|
152
|
+
}
|
|
153
|
+
setCache(key, paths) {
|
|
154
|
+
this.cache.set(key, { paths, timestamp: Date.now() });
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
//# sourceMappingURL=graph-traversal.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"graph-traversal.js","sourceRoot":"","sources":["../../../src/storage/repositories/graph-traversal.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { BaseRepository } from './base-repository.js';
|
|
2
2
|
export declare class KnowledgeRepository extends BaseRepository {
|
|
3
|
+
private graphTraversal;
|
|
4
|
+
constructor(db: import('better-sqlite3').Database);
|
|
3
5
|
insertKnowledgeNode(node: {
|
|
4
6
|
id: string;
|
|
5
7
|
project_path: string;
|
|
@@ -42,5 +44,17 @@ export declare class KnowledgeRepository extends BaseRepository {
|
|
|
42
44
|
edge_type: string;
|
|
43
45
|
weight: number;
|
|
44
46
|
}>;
|
|
47
|
+
/** 查找两节点间最短路径(BFS) */
|
|
48
|
+
findShortestPath(fromNodeId: string, toNodeId: string, maxDepth?: number): import("./graph-traversal.js").GraphPath | null;
|
|
49
|
+
/** 查找两节点间所有路径(DFS,按权重排序) */
|
|
50
|
+
findAllPaths(fromNodeId: string, toNodeId: string, maxDepth?: number, topK?: number): import("./graph-traversal.js").GraphPath[];
|
|
51
|
+
/** 查找 K 跳邻居节点 */
|
|
52
|
+
findKHopNeighbors(nodeId: string, k: number, limit?: number): {
|
|
53
|
+
nodeId: string;
|
|
54
|
+
distance: number;
|
|
55
|
+
totalWeight: number;
|
|
56
|
+
}[];
|
|
57
|
+
/** 清理图遍历缓存 */
|
|
58
|
+
clearGraphCache(): void;
|
|
45
59
|
}
|
|
46
60
|
//# sourceMappingURL=knowledge-repository.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"knowledge-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/knowledge-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"knowledge-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/knowledge-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAGtD,qBAAa,mBAAoB,SAAQ,cAAc;IACrD,OAAO,CAAC,cAAc,CAAiB;gBAE3B,EAAE,EAAE,OAAO,gBAAgB,EAAE,QAAQ;IAKjD,mBAAmB,CAAC,IAAI,EAAE;QACxB,EAAE,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QACpD,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;QAAC,cAAc,CAAC,EAAE,MAAM,CAAC;KAC1E,GAAG,IAAI;IAQR,mBAAmB,CAAC,IAAI,EAAE;QACxB,EAAE,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QACrD,SAAS,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;KACxE,GAAG,IAAI;IAQR,oBAAoB,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,SAAK,GAAG,KAAK,CAAC;QAC1E,EAAE,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;KACpF,CAAC;IAcF,wBAAwB,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,QAAQ,CAAC,EAAE,MAAM,GAAG;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;IAUtG,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,SAAS,GAAE,KAAK,GAAG,IAAI,GAAG,MAAe,GAAG,KAAK,CAAC;QAClF,EAAE,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;KACzF,CAAC;IAWF,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,SAAK,GAAG,KAAK,CAAC;QACvE,EAAE,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;KAClG,CAAC;IAeF,sBAAsB;IACtB,gBAAgB,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,SAAI;IAInE,4BAA4B;IAC5B,YAAY,CAAC,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,SAAI,EAAE,IAAI,SAAI;IAIzE,iBAAiB;IACjB,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,EAAE,MAAM,EAAE,KAAK,SAAK;;;;;IAIvD,cAAc;IACd,eAAe,IAAI,IAAI;CAGxB"}
|
|
@@ -1,5 +1,11 @@
|
|
|
1
1
|
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
import { GraphTraversal } from './graph-traversal.js';
|
|
2
3
|
export class KnowledgeRepository extends BaseRepository {
|
|
4
|
+
graphTraversal;
|
|
5
|
+
constructor(db) {
|
|
6
|
+
super(db);
|
|
7
|
+
this.graphTraversal = new GraphTraversal(db);
|
|
8
|
+
}
|
|
3
9
|
insertKnowledgeNode(node) {
|
|
4
10
|
this.db.prepare(`
|
|
5
11
|
INSERT OR REPLACE INTO knowledge_nodes (id, project_path, node_type, title, content, tags, embedding_hint, last_accessed_at)
|
|
@@ -80,5 +86,21 @@ export class KnowledgeRepository extends BaseRepository {
|
|
|
80
86
|
return [];
|
|
81
87
|
}
|
|
82
88
|
}
|
|
89
|
+
/** 查找两节点间最短路径(BFS) */
|
|
90
|
+
findShortestPath(fromNodeId, toNodeId, maxDepth = 5) {
|
|
91
|
+
return this.graphTraversal.findShortestPath(fromNodeId, toNodeId, maxDepth);
|
|
92
|
+
}
|
|
93
|
+
/** 查找两节点间所有路径(DFS,按权重排序) */
|
|
94
|
+
findAllPaths(fromNodeId, toNodeId, maxDepth = 5, topK = 3) {
|
|
95
|
+
return this.graphTraversal.findAllPaths(fromNodeId, toNodeId, maxDepth, topK);
|
|
96
|
+
}
|
|
97
|
+
/** 查找 K 跳邻居节点 */
|
|
98
|
+
findKHopNeighbors(nodeId, k, limit = 20) {
|
|
99
|
+
return this.graphTraversal.findKHopNeighbors(nodeId, k, limit);
|
|
100
|
+
}
|
|
101
|
+
/** 清理图遍历缓存 */
|
|
102
|
+
clearGraphCache() {
|
|
103
|
+
this.graphTraversal.clearCache();
|
|
104
|
+
}
|
|
83
105
|
}
|
|
84
106
|
//# sourceMappingURL=knowledge-repository.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"knowledge-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/knowledge-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,OAAO,mBAAoB,SAAQ,cAAc;
|
|
1
|
+
{"version":3,"file":"knowledge-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/knowledge-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"latency-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/latency-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,qBAAa,iBAAkB,SAAQ,cAAc;IACnD,kBAAkB,CAAC,MAAM,EAAE;QACzB,EAAE,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QACrD,UAAU,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAC7D,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;KAC3C,GAAG,IAAI;
|
|
1
|
+
{"version":3,"file":"latency-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/latency-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,qBAAa,iBAAkB,SAAQ,cAAc;IACnD,kBAAkB,CAAC,MAAM,EAAE;QACzB,EAAE,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QACrD,UAAU,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAC7D,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;KAC3C,GAAG,IAAI;IAaR,eAAe,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,IAAI,SAAI,GAAG,KAAK,CAAC;QACnD,WAAW,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAC;QAAC,GAAG,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;KAC/F,CAAC;CA0BH"}
|
|
@@ -1,13 +1,10 @@
|
|
|
1
1
|
import { BaseRepository } from './base-repository.js';
|
|
2
2
|
export class LatencyRepository extends BaseRepository {
|
|
3
3
|
insertLatencyTrace(record) {
|
|
4
|
-
|
|
5
|
-
this.db.prepare(`
|
|
4
|
+
this.withSilent(() => this.db.prepare(`
|
|
6
5
|
INSERT OR IGNORE INTO latency_traces (id, session_id, project_path, trace_type, engine_name, duration_ms, metadata)
|
|
7
6
|
VALUES (?, ?, ?, ?, ?, ?, ?)
|
|
8
|
-
`).run(record.id, record.session_id, record.project_path, record.trace_type, record.engine_name, record.duration_ms, record.metadata ? JSON.stringify(record.metadata) : null);
|
|
9
|
-
}
|
|
10
|
-
catch { /* 延迟追踪失败不影响主流程 */ }
|
|
7
|
+
`).run(record.id, record.session_id, record.project_path, record.trace_type, record.engine_name, record.duration_ms, record.metadata ? JSON.stringify(record.metadata) : null), '插入延迟追踪记录', undefined);
|
|
11
8
|
}
|
|
12
9
|
getLatencyStats(traceType, days = 7) {
|
|
13
10
|
try {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"latency-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/latency-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,OAAO,iBAAkB,SAAQ,cAAc;IACnD,kBAAkB,CAAC,MAIlB;QACC,IAAI,CAAC
|
|
1
|
+
{"version":3,"file":"latency-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/latency-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,OAAO,iBAAkB,SAAQ,cAAc;IACnD,kBAAkB,CAAC,MAIlB;QACC,IAAI,CAAC,UAAU,CACb,GAAG,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;OAGrB,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,EAAE,EAAE,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,YAAY,EACtD,MAAM,CAAC,UAAU,EAAE,MAAM,CAAC,WAAW,EAAE,MAAM,CAAC,WAAW,EACzD,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAC3D,UAAU,EACV,SAAS,CACV,CAAC;IACJ,CAAC;IAED,eAAe,CAAC,SAAkB,EAAE,IAAI,GAAG,CAAC;QAG1C,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,GAAG,SAAS,CAAC,CAAC,WAAW,EAAE,CAAC;YACpE,MAAM,KAAK,GAAG,SAAS,CAAC,CAAC,CAAC,qBAAqB,SAAS,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC;YACjE,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;mDAEgB,KAAK;;OAEjD,CAAC,CAAC,GAAG,CAAC,KAAK,CAA4E,CAAC;YAEzF,MAAM,MAAM,GAAG,IAAI,GAAG,EAAoB,CAAC;YAC3C,MAAM,IAAI,GAAG,IAAI,GAAG,EAAuD,CAAC;YAC5E,KAAK,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;gBACrB,MAAM,GAAG,GAAG,GAAG,CAAC,CAAC,WAAW,KAAK,CAAC,CAAC,UAAU,EAAE,CAAC;gBAChD,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;oBAAC,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;oBAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC,WAAW,EAAE,UAAU,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC;gBAAC,CAAC;gBACvH,MAAM,CAAC,GAAG,CAAC,GAAG,CAAE,CAAC,IAAI,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC;YACvC,CAAC;YACD,OAAO,CAAC,GAAG,MAAM,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,EAAE,IAAI,CAAC,EAAE,EAAE;gBAC/C,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC3B,MAAM,CAAC,GAAG,CAAC,GAAW,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC;gBACpE,OAAO,EAAE,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,CAAE,EAAE,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC;YAC/G,CAAC,CAAC,CAAC;QACL,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;CACF"}
|
|
@@ -6,10 +6,13 @@ export declare class MaintenanceRepository extends BaseRepository {
|
|
|
6
6
|
getStorageSize(): number;
|
|
7
7
|
purgeDistilledEvents(retentionDays?: number): number;
|
|
8
8
|
purgeOldSessions(retentionDays?: number): number;
|
|
9
|
+
truncateToolOutputs(maxLength?: number): number;
|
|
9
10
|
runMaintenance(maxSizeMb?: number): {
|
|
10
11
|
purgedEvents: number;
|
|
11
12
|
purgedSessions: number;
|
|
12
13
|
purgedQueue: number;
|
|
14
|
+
purgedTraces: number;
|
|
15
|
+
truncatedOutputs: number;
|
|
13
16
|
dbSizeMb: number;
|
|
14
17
|
};
|
|
15
18
|
getDaemonState(key: string): string | null;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"maintenance-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/maintenance-repository.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,qBAAa,qBAAsB,SAAQ,cAAc;IACJ,OAAO,CAAC,MAAM;gBAArD,EAAE,EAAE,OAAO,gBAAgB,EAAE,QAAQ,EAAU,MAAM,EAAE,MAAM;IAIzE,WAAW,IAAI,MAAM;IAIrB,cAAc,IAAI,MAAM;IAKxB,oBAAoB,CAAC,aAAa,SAAI,GAAG,MAAM;IAK/C,gBAAgB,CAAC,aAAa,SAAK,GAAG,MAAM;IAK5C,cAAc,CAAC,SAAS,SAAO,GAAG;QAAE,YAAY,EAAE,MAAM,CAAC;QAAC,cAAc,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE;
|
|
1
|
+
{"version":3,"file":"maintenance-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/maintenance-repository.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,qBAAa,qBAAsB,SAAQ,cAAc;IACJ,OAAO,CAAC,MAAM;gBAArD,EAAE,EAAE,OAAO,gBAAgB,EAAE,QAAQ,EAAU,MAAM,EAAE,MAAM;IAIzE,WAAW,IAAI,MAAM;IAIrB,cAAc,IAAI,MAAM;IAKxB,oBAAoB,CAAC,aAAa,SAAI,GAAG,MAAM;IAK/C,gBAAgB,CAAC,aAAa,SAAK,GAAG,MAAM;IAK5C,mBAAmB,CAAC,SAAS,SAAQ,GAAG,MAAM;IAQ9C,cAAc,CAAC,SAAS,SAAO,GAAG;QAAE,YAAY,EAAE,MAAM,CAAC;QAAC,cAAc,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,gBAAgB,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE;IAezK,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAO1C,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;CAQjD"}
|