@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.
Files changed (73) hide show
  1. package/dist/ai-gateway/index.d.ts.map +1 -1
  2. package/dist/ai-gateway/index.js +8 -1
  3. package/dist/ai-gateway/index.js.map +1 -1
  4. package/dist/daemon/handlers/context-builder.d.ts +7 -5
  5. package/dist/daemon/handlers/context-builder.d.ts.map +1 -1
  6. package/dist/daemon/handlers/context-builder.js +29 -26
  7. package/dist/daemon/handlers/context-builder.js.map +1 -1
  8. package/dist/daemon/handlers/orchestration-context.d.ts +3 -0
  9. package/dist/daemon/handlers/orchestration-context.d.ts.map +1 -1
  10. package/dist/daemon/handlers/stages/01-failure-signal.d.ts.map +1 -1
  11. package/dist/daemon/handlers/stages/01-failure-signal.js +1 -0
  12. package/dist/daemon/handlers/stages/01-failure-signal.js.map +1 -1
  13. package/dist/daemon/handlers/stages/04-skill-suggestions.js +1 -1
  14. package/dist/daemon/handlers/stages/04-skill-suggestions.js.map +1 -1
  15. package/dist/daemon/handlers/stages/07-pipeline-reply.d.ts.map +1 -1
  16. package/dist/daemon/handlers/stages/07-pipeline-reply.js +2 -0
  17. package/dist/daemon/handlers/stages/07-pipeline-reply.js.map +1 -1
  18. package/dist/daemon/handlers/stages/10-cooldown.d.ts.map +1 -1
  19. package/dist/daemon/handlers/stages/10-cooldown.js +21 -0
  20. package/dist/daemon/handlers/stages/10-cooldown.js.map +1 -1
  21. package/dist/daemon/handlers/stages/11-intent-analysis.d.ts +2 -0
  22. package/dist/daemon/handlers/stages/11-intent-analysis.d.ts.map +1 -1
  23. package/dist/daemon/handlers/stages/11-intent-analysis.js +21 -3
  24. package/dist/daemon/handlers/stages/11-intent-analysis.js.map +1 -1
  25. package/dist/daemon/handlers/stages/17-simple-task.js +1 -1
  26. package/dist/daemon/handlers/stages/17-simple-task.js.map +1 -1
  27. package/dist/daemon/handlers/stages/18-complex-task.d.ts +2 -0
  28. package/dist/daemon/handlers/stages/18-complex-task.d.ts.map +1 -1
  29. package/dist/daemon/handlers/stages/18-complex-task.js +24 -2
  30. package/dist/daemon/handlers/stages/18-complex-task.js.map +1 -1
  31. package/dist/daemon/handlers/stages/19-moderate-task.d.ts +2 -0
  32. package/dist/daemon/handlers/stages/19-moderate-task.d.ts.map +1 -1
  33. package/dist/daemon/handlers/stages/19-moderate-task.js +22 -2
  34. package/dist/daemon/handlers/stages/19-moderate-task.js.map +1 -1
  35. package/dist/daemon/handlers/stages/stage-interface.d.ts +4 -1
  36. package/dist/daemon/handlers/stages/stage-interface.d.ts.map +1 -1
  37. package/dist/daemon/handlers/user-prompt-handler.d.ts +9 -0
  38. package/dist/daemon/handlers/user-prompt-handler.d.ts.map +1 -1
  39. package/dist/daemon/handlers/user-prompt-handler.js +77 -0
  40. package/dist/daemon/handlers/user-prompt-handler.js.map +1 -1
  41. package/dist/storage/repositories/base-repository.d.ts +6 -0
  42. package/dist/storage/repositories/base-repository.d.ts.map +1 -1
  43. package/dist/storage/repositories/base-repository.js +23 -0
  44. package/dist/storage/repositories/base-repository.js.map +1 -1
  45. package/dist/storage/repositories/event-repository.d.ts.map +1 -1
  46. package/dist/storage/repositories/event-repository.js +96 -87
  47. package/dist/storage/repositories/event-repository.js.map +1 -1
  48. package/dist/storage/repositories/graph-traversal.d.ts +37 -0
  49. package/dist/storage/repositories/graph-traversal.d.ts.map +1 -0
  50. package/dist/storage/repositories/graph-traversal.js +157 -0
  51. package/dist/storage/repositories/graph-traversal.js.map +1 -0
  52. package/dist/storage/repositories/knowledge-repository.d.ts +14 -0
  53. package/dist/storage/repositories/knowledge-repository.d.ts.map +1 -1
  54. package/dist/storage/repositories/knowledge-repository.js +22 -0
  55. package/dist/storage/repositories/knowledge-repository.js.map +1 -1
  56. package/dist/storage/repositories/latency-repository.d.ts.map +1 -1
  57. package/dist/storage/repositories/latency-repository.js +2 -5
  58. package/dist/storage/repositories/latency-repository.js.map +1 -1
  59. package/dist/storage/repositories/maintenance-repository.d.ts +3 -0
  60. package/dist/storage/repositories/maintenance-repository.d.ts.map +1 -1
  61. package/dist/storage/repositories/maintenance-repository.js +12 -3
  62. package/dist/storage/repositories/maintenance-repository.js.map +1 -1
  63. package/dist/storage/repositories/task-repository.d.ts.map +1 -1
  64. package/dist/storage/repositories/task-repository.js +16 -11
  65. package/dist/storage/repositories/task-repository.js.map +1 -1
  66. package/dist/storage/sqlite.d.ts.map +1 -1
  67. package/dist/storage/sqlite.js +16 -1
  68. package/dist/storage/sqlite.js.map +1 -1
  69. package/dist/utils/error-handler.d.ts +39 -0
  70. package/dist/utils/error-handler.d.ts.map +1 -0
  71. package/dist/utils/error-handler.js +155 -0
  72. package/dist/utils/error-handler.js.map +1 -0
  73. 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
- const tx = this.db.transaction((ev) => {
14
- const toolInputStr = ev.tool_input ? JSON.stringify(ev.tool_input) : null;
15
- const changes = this.db.prepare(`
16
- INSERT OR IGNORE INTO events (
17
- event_id, session_id, project_path, timestamp,
18
- hook_type, tool_name, tool_input, tool_output,
19
- user_prompt, ai_response, distilled
20
- ) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
21
- `).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);
22
- if (changes.changes > 0) {
23
- try {
24
- const row = this.db.prepare('SELECT rowid FROM events WHERE event_id = ?')
25
- .get(ev.event_id);
26
- if (row) {
27
- this.db.prepare(`
28
- INSERT OR IGNORE INTO events_fts(rowid, event_id, session_id, project_path, tool_name, tool_input, user_prompt)
29
- VALUES (?, ?, ?, ?, ?, ?, ?)
30
- `).run(row.rowid, ev.event_id, ev.session_id, ev.project_path, ev.tool_name || null, toolInputStr, ev.user_prompt || null);
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
- catch { /* FTS5 表可能尚未创建,静默忽略 */ }
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
- const existing = this.db.prepare('SELECT session_id FROM sessions WHERE session_id = ? AND project_path = ?').get(ev.session_id, ev.project_path);
37
- if (!existing) {
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
- else {
48
- this.db.prepare(`
49
- UPDATE sessions SET last_event_time = ?, event_count = event_count + 1, updated_at = datetime('now')
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 (ev.hook_type === 'Stop') {
54
- this.db.prepare(`
55
- UPDATE sessions SET status = 'completed', end_time = ?, updated_at = datetime('now')
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
- tx(event);
61
- }
62
- queryEvents(filters) {
63
- let sql = 'SELECT * FROM events WHERE 1=1';
64
- const params = [];
65
- if (filters.session_id) {
66
- sql += ' AND session_id = ?';
67
- params.push(filters.session_id);
68
- }
69
- if (filters.project_path) {
70
- sql += ' AND project_path = ?';
71
- params.push(filters.project_path);
72
- }
73
- if (filters.start_time) {
74
- sql += ' AND timestamp >= ?';
75
- params.push(filters.start_time);
76
- }
77
- if (filters.end_time) {
78
- sql += ' AND timestamp <= ?';
79
- params.push(filters.end_time);
80
- }
81
- if (filters.tool_name) {
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
- if (filters.offset) {
99
- sql += ' OFFSET ?';
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
- const stmt = this.db.prepare('UPDATE events SET distilled = 1 WHERE event_id = ?');
125
- const tx = this.db.transaction((ids) => { for (const id of ids)
126
- stmt.run(id); });
127
- tx(eventIds);
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;YAChD,MAAM,YAAY,GAAG,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YAC1E,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;;;;OAM/B,CAAC,CAAC,GAAG,CACJ,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,SAAS,EACzD,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,IAAI,IAAI,EAAE,YAAY,EAChD,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,EACtD,EAAE,CAAC,WAAW,IAAI,IAAI,EAAE,EAAE,CAAC,WAAW,IAAI,IAAI,EAAE,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CACrE,CAAC;YAEF,IAAI,OAAO,CAAC,OAAO,GAAG,CAAC,EAAE,CAAC;gBACxB,IAAI,CAAC;oBACH,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,6CAA6C,CAAC;yBACvE,GAAG,CAAC,EAAE,CAAC,QAAQ,CAAkC,CAAC;oBACrD,IAAI,GAAG,EAAE,CAAC;wBACR,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;aAGf,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,YAAY,EAC3D,EAAE,CAAC,SAAS,IAAI,IAAI,EAAE,YAAY,EAAE,EAAE,CAAC,WAAW,IAAI,IAAI,CAAC,CAAC;oBAChE,CAAC;gBACH,CAAC;gBAAC,MAAM,CAAC,CAAC,uBAAuB,CAAC,CAAC;YACrC,CAAC;YAED,SAAS;YACT,MAAM,QAAQ,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAC9B,2EAA2E,CAC5E,CAAC,GAAG,CAAC,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC;YACtC,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;;;;;SAOf,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,YAAY,EAAE,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,SAAS,CAAC,CAAC;YACrE,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;SAGf,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC;YACvD,CAAC;YACD,IAAI,EAAE,CAAC,SAAS,KAAK,MAAM,EAAE,CAAC;gBAC5B,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;SAGf,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,SAAS,EAAE,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,YAAY,CAAC,CAAC;YACvD,CAAC;QACH,CAAC,CAAC,CAAC;QACH,EAAE,CAAC,KAAK,CAAC,CAAC;IACZ,CAAC;IAED,WAAW,CAAC,OAAmB;QAC7B,IAAI,GAAG,GAAG,gCAAgC,CAAC;QAC3C,MAAM,MAAM,GAAc,EAAE,CAAC;QAC7B,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;YAAC,GAAG,IAAI,qBAAqB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAAC,CAAC;QAC1F,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;YAAC,GAAG,IAAI,uBAAuB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QAAC,CAAC;QAChG,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;YAAC,GAAG,IAAI,qBAAqB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAAC,CAAC;QAC1F,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YAAC,GAAG,IAAI,qBAAqB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QAAC,CAAC;QACtF,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YAAC,GAAG,IAAI,oBAAoB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAAC,CAAC;QACvF,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YAAC,GAAG,IAAI,oBAAoB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QAAC,CAAC;QACvF,IAAI,OAAO,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YAAC,GAAG,IAAI,oBAAoB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAAC,CAAC;QAC7G,GAAG,IAAI,0BAA0B,CAAC;QAClC,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;YAAC,GAAG,IAAI,UAAU,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAAC,CAAC;QACrE,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YAAC,GAAG,IAAI,WAAW,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QAAC,CAAC;QACxE,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAA8B,CAAC;QAC9E,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACnC,CAAC;IAED,WAAW,CAAC,OAAmB;QAC7B,IAAI,GAAG,GAAG,gDAAgD,CAAC;QAC3D,MAAM,MAAM,GAAc,EAAE,CAAC;QAC7B,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;YAAC,GAAG,IAAI,qBAAqB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QAAC,CAAC;QAC1F,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;YAAC,GAAG,IAAI,uBAAuB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC;QAAC,CAAC;QAChG,IAAI,OAAO,CAAC,SAAS,KAAK,SAAS,EAAE,CAAC;YAAC,GAAG,IAAI,oBAAoB,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAAC,CAAC;QAC7G,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAsB,CAAC;QACrE,OAAO,GAAG,CAAC,KAAK,CAAC;IACnB,CAAC;IAED,mBAAmB,CAAC,QAAkB;QACpC,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,oDAAoD,CAAC,CAAC;QACnF,MAAM,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC,GAAa,EAAE,EAAE,GAAG,KAAK,MAAM,EAAE,IAAI,GAAG;YAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3F,EAAE,CAAC,QAAQ,CAAC,CAAC;IACf,CAAC;IAED,oBAAoB,CAAC,SAAiB,EAAE,WAAoB;QAC1D,OAAO,IAAI,CAAC,WAAW,CAAC,EAAE,UAAU,EAAE,SAAS,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC9H,CAAC;IAED,gBAAgB,CAAC,QAAkB,EAAE,WAAmB,EAAE,KAAK,GAAG,EAAE;QAClE,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC;YAAE,OAAO,EAAE,CAAC;QACrC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,QAAQ;iBACrB,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,gBAAgB,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;iBAClD,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,MAAM,IAAI,CAAC,CAAC;iBAC5B,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,CAAC;iBACpG,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACf,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO,EAAE,CAAC;YACpC,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;;;OAK5B,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,WAAW,EAAE,KAAK,CAA8B,CAAC;YAC9E,OAAO,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACnC,CAAC;QAAC,MAAM,CAAC;YAAC,OAAO,EAAE,CAAC;QAAC,CAAC;IACxB,CAAC;IAEO,UAAU,CAAC,GAA4B;QAC7C,OAAO;YACL,QAAQ,EAAE,GAAG,CAAC,QAAkB;YAChC,UAAU,EAAE,GAAG,CAAC,UAAoB;YACpC,YAAY,EAAE,GAAG,CAAC,YAAsB;YACxC,SAAS,EAAE,GAAG,CAAC,SAAmB;YAClC,SAAS,EAAE,GAAG,CAAC,SAAoC;YACnD,SAAS,EAAE,GAAG,CAAC,SAA+B;YAC9C,UAAU,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,UAAoB,CAAC,CAAC,CAAC,CAAC,SAAS;YAC7E,WAAW,EAAE,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,WAAqB,CAAC,CAAC,CAAC,CAAC,SAAS;YAChF,WAAW,EAAE,GAAG,CAAC,WAAiC;YAClD,WAAW,EAAE,GAAG,CAAC,WAAiC;YAClD,SAAS,EAAG,GAAG,CAAC,SAAoB,KAAK,CAAC;SAC3C,CAAC;IACJ,CAAC"}
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;AAEtD,qBAAa,mBAAoB,SAAQ,cAAc;IACrD,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;CAcH"}
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":"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"}
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;IAWR,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;CAwBH"}
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
- try {
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;YACH,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;OAGf,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,CAAC;QAC9D,CAAC;QAAC,MAAM,CAAC,CAAC,kBAAkB,CAAC,CAAC;IAChC,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;YAAC,OAAO,EAAE,CAAC;QAAC,CAAC;IACxB,CAAC;CACF"}
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;IAazH,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI;IAO1C,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;CAQjD"}
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"}