@winspan/claude-forge 0.5.3 → 0.6.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/README.md +3 -3
- package/dist/ai-gateway/index.d.ts +26 -0
- package/dist/ai-gateway/index.d.ts.map +1 -0
- package/dist/ai-gateway/index.js +67 -0
- package/dist/ai-gateway/index.js.map +1 -0
- package/dist/ai-gateway/model-selector.d.ts +6 -0
- package/dist/ai-gateway/model-selector.d.ts.map +1 -0
- package/dist/ai-gateway/model-selector.js +36 -0
- package/dist/ai-gateway/model-selector.js.map +1 -0
- package/dist/ai-gateway/rate-limiter.d.ts +20 -0
- package/dist/ai-gateway/rate-limiter.d.ts.map +1 -0
- package/dist/ai-gateway/rate-limiter.js +45 -0
- package/dist/ai-gateway/rate-limiter.js.map +1 -0
- package/dist/ai-gateway/response-cache.d.ts +17 -0
- package/dist/ai-gateway/response-cache.d.ts.map +1 -0
- package/dist/ai-gateway/response-cache.js +44 -0
- package/dist/ai-gateway/response-cache.js.map +1 -0
- package/dist/ai-provider/types.d.ts +2 -0
- package/dist/ai-provider/types.d.ts.map +1 -1
- package/dist/ai-provider/types.js.map +1 -1
- package/dist/daemon/handlers/context-builder.d.ts +55 -0
- package/dist/daemon/handlers/context-builder.d.ts.map +1 -0
- package/dist/daemon/handlers/context-builder.js +429 -0
- package/dist/daemon/handlers/context-builder.js.map +1 -0
- package/dist/daemon/handlers/orchestration-context.d.ts +37 -0
- package/dist/daemon/handlers/orchestration-context.d.ts.map +1 -0
- package/dist/daemon/handlers/orchestration-context.js +2 -0
- package/dist/daemon/handlers/orchestration-context.js.map +1 -0
- package/dist/daemon/handlers/session-cleanup.js +5 -5
- package/dist/daemon/handlers/session-cleanup.js.map +1 -1
- package/dist/daemon/handlers/stages/01-failure-signal.d.ts +8 -0
- package/dist/daemon/handlers/stages/01-failure-signal.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/01-failure-signal.js +39 -0
- package/dist/daemon/handlers/stages/01-failure-signal.js.map +1 -0
- package/dist/daemon/handlers/stages/02-active-intervention.d.ts +8 -0
- package/dist/daemon/handlers/stages/02-active-intervention.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/02-active-intervention.js +27 -0
- package/dist/daemon/handlers/stages/02-active-intervention.js.map +1 -0
- package/dist/daemon/handlers/stages/03-init-prompt.d.ts +8 -0
- package/dist/daemon/handlers/stages/03-init-prompt.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/03-init-prompt.js +24 -0
- package/dist/daemon/handlers/stages/03-init-prompt.js.map +1 -0
- package/dist/daemon/handlers/stages/04-skill-suggestions.d.ts +8 -0
- package/dist/daemon/handlers/stages/04-skill-suggestions.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/04-skill-suggestions.js +23 -0
- package/dist/daemon/handlers/stages/04-skill-suggestions.js.map +1 -0
- package/dist/daemon/handlers/stages/05-conv-config.d.ts +10 -0
- package/dist/daemon/handlers/stages/05-conv-config.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/05-conv-config.js +23 -0
- package/dist/daemon/handlers/stages/05-conv-config.js.map +1 -0
- package/dist/daemon/handlers/stages/06-engine-check.d.ts +8 -0
- package/dist/daemon/handlers/stages/06-engine-check.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/06-engine-check.js +13 -0
- package/dist/daemon/handlers/stages/06-engine-check.js.map +1 -0
- package/dist/daemon/handlers/stages/07-pipeline-reply.d.ts +9 -0
- package/dist/daemon/handlers/stages/07-pipeline-reply.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/07-pipeline-reply.js +44 -0
- package/dist/daemon/handlers/stages/07-pipeline-reply.js.map +1 -0
- package/dist/daemon/handlers/stages/08-esc-interrupt.d.ts +9 -0
- package/dist/daemon/handlers/stages/08-esc-interrupt.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/08-esc-interrupt.js +52 -0
- package/dist/daemon/handlers/stages/08-esc-interrupt.js.map +1 -0
- package/dist/daemon/handlers/stages/09-pipeline-active.d.ts +8 -0
- package/dist/daemon/handlers/stages/09-pipeline-active.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/09-pipeline-active.js +20 -0
- package/dist/daemon/handlers/stages/09-pipeline-active.js.map +1 -0
- package/dist/daemon/handlers/stages/10-cooldown.d.ts +9 -0
- package/dist/daemon/handlers/stages/10-cooldown.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/10-cooldown.js +44 -0
- package/dist/daemon/handlers/stages/10-cooldown.js.map +1 -0
- package/dist/daemon/handlers/stages/11-intent-analysis.d.ts +8 -0
- package/dist/daemon/handlers/stages/11-intent-analysis.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/11-intent-analysis.js +38 -0
- package/dist/daemon/handlers/stages/11-intent-analysis.js.map +1 -0
- package/dist/daemon/handlers/stages/12-strategy-advice.d.ts +8 -0
- package/dist/daemon/handlers/stages/12-strategy-advice.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/12-strategy-advice.js +20 -0
- package/dist/daemon/handlers/stages/12-strategy-advice.js.map +1 -0
- package/dist/daemon/handlers/stages/13-template-route.d.ts +8 -0
- package/dist/daemon/handlers/stages/13-template-route.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/13-template-route.js +49 -0
- package/dist/daemon/handlers/stages/13-template-route.js.map +1 -0
- package/dist/daemon/handlers/stages/14-plan-resume.d.ts +8 -0
- package/dist/daemon/handlers/stages/14-plan-resume.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/14-plan-resume.js +51 -0
- package/dist/daemon/handlers/stages/14-plan-resume.js.map +1 -0
- package/dist/daemon/handlers/stages/15-plan-enforcement.d.ts +8 -0
- package/dist/daemon/handlers/stages/15-plan-enforcement.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/15-plan-enforcement.js +41 -0
- package/dist/daemon/handlers/stages/15-plan-enforcement.js.map +1 -0
- package/dist/daemon/handlers/stages/16-intervention-level.d.ts +8 -0
- package/dist/daemon/handlers/stages/16-intervention-level.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/16-intervention-level.js +24 -0
- package/dist/daemon/handlers/stages/16-intervention-level.js.map +1 -0
- package/dist/daemon/handlers/stages/17-simple-task.d.ts +8 -0
- package/dist/daemon/handlers/stages/17-simple-task.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/17-simple-task.js +47 -0
- package/dist/daemon/handlers/stages/17-simple-task.js.map +1 -0
- package/dist/daemon/handlers/stages/18-complex-task.d.ts +11 -0
- package/dist/daemon/handlers/stages/18-complex-task.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/18-complex-task.js +84 -0
- package/dist/daemon/handlers/stages/18-complex-task.js.map +1 -0
- package/dist/daemon/handlers/stages/19-moderate-task.d.ts +8 -0
- package/dist/daemon/handlers/stages/19-moderate-task.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/19-moderate-task.js +62 -0
- package/dist/daemon/handlers/stages/19-moderate-task.js.map +1 -0
- package/dist/daemon/handlers/stages/stage-interface.d.ts +24 -0
- package/dist/daemon/handlers/stages/stage-interface.d.ts.map +1 -0
- package/dist/daemon/handlers/stages/stage-interface.js +2 -0
- package/dist/daemon/handlers/stages/stage-interface.js.map +1 -0
- package/dist/daemon/handlers/stop-handler.js +2 -2
- package/dist/daemon/handlers/stop-handler.js.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.d.ts +1 -115
- package/dist/daemon/handlers/user-prompt-handler.d.ts.map +1 -1
- package/dist/daemon/handlers/user-prompt-handler.js +76 -1089
- package/dist/daemon/handlers/user-prompt-handler.js.map +1 -1
- package/dist/daemon/index.d.ts.map +1 -1
- package/dist/daemon/index.js +3 -1
- package/dist/daemon/index.js.map +1 -1
- package/dist/storage/repositories/api-usage-repository.d.ts +28 -0
- package/dist/storage/repositories/api-usage-repository.d.ts.map +1 -0
- package/dist/storage/repositories/api-usage-repository.js +59 -0
- package/dist/storage/repositories/api-usage-repository.js.map +1 -0
- package/dist/storage/repositories/base-repository.d.ts +6 -0
- package/dist/storage/repositories/base-repository.d.ts.map +1 -0
- package/dist/storage/repositories/base-repository.js +7 -0
- package/dist/storage/repositories/base-repository.js.map +1 -0
- package/dist/storage/repositories/distill-repository.d.ts +36 -0
- package/dist/storage/repositories/distill-repository.d.ts.map +1 -0
- package/dist/storage/repositories/distill-repository.js +85 -0
- package/dist/storage/repositories/distill-repository.js.map +1 -0
- package/dist/storage/repositories/event-repository.d.ts +14 -0
- package/dist/storage/repositories/event-repository.d.ts.map +1 -0
- package/dist/storage/repositories/event-repository.js +171 -0
- package/dist/storage/repositories/event-repository.js.map +1 -0
- package/dist/storage/repositories/failure-repository.d.ts +22 -0
- package/dist/storage/repositories/failure-repository.d.ts.map +1 -0
- package/dist/storage/repositories/failure-repository.js +26 -0
- package/dist/storage/repositories/failure-repository.js.map +1 -0
- package/dist/storage/repositories/intent-rule-repository.d.ts +20 -0
- package/dist/storage/repositories/intent-rule-repository.d.ts.map +1 -0
- package/dist/storage/repositories/intent-rule-repository.js +38 -0
- package/dist/storage/repositories/intent-rule-repository.js.map +1 -0
- package/dist/storage/repositories/knowledge-repository.d.ts +46 -0
- package/dist/storage/repositories/knowledge-repository.d.ts.map +1 -0
- package/dist/storage/repositories/knowledge-repository.js +84 -0
- package/dist/storage/repositories/knowledge-repository.js.map +1 -0
- package/dist/storage/repositories/latency-repository.d.ts +21 -0
- package/dist/storage/repositories/latency-repository.d.ts.map +1 -0
- package/dist/storage/repositories/latency-repository.js +42 -0
- package/dist/storage/repositories/latency-repository.js.map +1 -0
- package/dist/storage/repositories/maintenance-repository.d.ts +18 -0
- package/dist/storage/repositories/maintenance-repository.d.ts.map +1 -0
- package/dist/storage/repositories/maintenance-repository.js +61 -0
- package/dist/storage/repositories/maintenance-repository.js.map +1 -0
- package/dist/storage/repositories/satisfaction-repository.d.ts +21 -0
- package/dist/storage/repositories/satisfaction-repository.d.ts.map +1 -0
- package/dist/storage/repositories/satisfaction-repository.js +26 -0
- package/dist/storage/repositories/satisfaction-repository.js.map +1 -0
- package/dist/storage/repositories/session-repository.d.ts +16 -0
- package/dist/storage/repositories/session-repository.d.ts.map +1 -0
- package/dist/storage/repositories/session-repository.js +69 -0
- package/dist/storage/repositories/session-repository.js.map +1 -0
- package/dist/storage/repositories/task-repository.d.ts +82 -0
- package/dist/storage/repositories/task-repository.d.ts.map +1 -0
- package/dist/storage/repositories/task-repository.js +198 -0
- package/dist/storage/repositories/task-repository.js.map +1 -0
- package/dist/storage/sqlite.d.ts +25 -0
- package/dist/storage/sqlite.d.ts.map +1 -1
- package/dist/storage/sqlite.js +27 -0
- package/dist/storage/sqlite.js.map +1 -1
- package/dist/utils/claude-api.d.ts.map +1 -1
- package/dist/utils/claude-api.js +3 -1
- package/dist/utils/claude-api.js.map +1 -1
- package/dist/utils/logger.d.ts +7 -0
- package/dist/utils/logger.d.ts.map +1 -1
- package/dist/utils/logger.js +22 -0
- package/dist/utils/logger.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export class EventRepository extends BaseRepository {
|
|
3
|
+
static STOPWORDS = new Set([
|
|
4
|
+
'的', '了', '是', '在', '和', '我', '你', '它', '他', '她',
|
|
5
|
+
'这', '那', '有', '不', '也', '都', '就', '但', '而', '与',
|
|
6
|
+
'或', '及', '对', '为', '以', '从', '到', '把', '被', '让',
|
|
7
|
+
'使', '将', '已', '还', '又', '再', '很', '太', '更', '最',
|
|
8
|
+
'the', 'a', 'an', 'is', 'are', 'was', 'be', 'have', 'has',
|
|
9
|
+
'do', 'does', 'in', 'on', 'at', 'to', 'for', 'of', 'with',
|
|
10
|
+
'and', 'or', 'but', 'not', 'it', 'this', 'that',
|
|
11
|
+
]);
|
|
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);
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
catch { /* FTS5 表可能尚未创建,静默忽略 */ }
|
|
34
|
+
}
|
|
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);
|
|
46
|
+
}
|
|
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);
|
|
52
|
+
}
|
|
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);
|
|
58
|
+
}
|
|
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);
|
|
97
|
+
}
|
|
98
|
+
if (filters.offset) {
|
|
99
|
+
sql += ' OFFSET ?';
|
|
100
|
+
params.push(filters.offset);
|
|
101
|
+
}
|
|
102
|
+
const rows = this.db.prepare(sql).all(...params);
|
|
103
|
+
return rows.map(this.rowToEvent);
|
|
104
|
+
}
|
|
105
|
+
countEvents(filters) {
|
|
106
|
+
let sql = 'SELECT COUNT(*) as count FROM events WHERE 1=1';
|
|
107
|
+
const params = [];
|
|
108
|
+
if (filters.session_id) {
|
|
109
|
+
sql += ' AND session_id = ?';
|
|
110
|
+
params.push(filters.session_id);
|
|
111
|
+
}
|
|
112
|
+
if (filters.project_path) {
|
|
113
|
+
sql += ' AND project_path = ?';
|
|
114
|
+
params.push(filters.project_path);
|
|
115
|
+
}
|
|
116
|
+
if (filters.distilled !== undefined) {
|
|
117
|
+
sql += ' AND distilled = ?';
|
|
118
|
+
params.push(filters.distilled ? 1 : 0);
|
|
119
|
+
}
|
|
120
|
+
const row = this.db.prepare(sql).get(...params);
|
|
121
|
+
return row.count;
|
|
122
|
+
}
|
|
123
|
+
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);
|
|
128
|
+
}
|
|
129
|
+
getUndistilledEvents(sessionId, projectPath) {
|
|
130
|
+
return this.queryEvents({ session_id: sessionId, distilled: false, ...(projectPath ? { project_path: projectPath } : {}) });
|
|
131
|
+
}
|
|
132
|
+
searchByKeywords(keywords, projectPath, limit = 20) {
|
|
133
|
+
if (keywords.length === 0)
|
|
134
|
+
return [];
|
|
135
|
+
try {
|
|
136
|
+
const cleaned = keywords
|
|
137
|
+
.map(kw => kw.replace(/['"*\[\](){}]/g, '').trim())
|
|
138
|
+
.filter(kw => kw.length >= 2)
|
|
139
|
+
.filter(kw => !EventRepository.STOPWORDS.has(kw) && !EventRepository.STOPWORDS.has(kw.toLowerCase()))
|
|
140
|
+
.slice(0, 5);
|
|
141
|
+
if (cleaned.length === 0)
|
|
142
|
+
return [];
|
|
143
|
+
const rows = this.db.prepare(`
|
|
144
|
+
SELECT e.* FROM events e
|
|
145
|
+
INNER JOIN events_fts fts ON e.rowid = fts.rowid
|
|
146
|
+
WHERE events_fts MATCH ? AND e.project_path = ?
|
|
147
|
+
ORDER BY e.timestamp DESC LIMIT ?
|
|
148
|
+
`).all(cleaned.join(' OR '), projectPath, limit);
|
|
149
|
+
return rows.map(this.rowToEvent);
|
|
150
|
+
}
|
|
151
|
+
catch {
|
|
152
|
+
return [];
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
rowToEvent(row) {
|
|
156
|
+
return {
|
|
157
|
+
event_id: row.event_id,
|
|
158
|
+
session_id: row.session_id,
|
|
159
|
+
project_path: row.project_path,
|
|
160
|
+
timestamp: row.timestamp,
|
|
161
|
+
hook_type: row.hook_type,
|
|
162
|
+
tool_name: row.tool_name,
|
|
163
|
+
tool_input: row.tool_input ? JSON.parse(row.tool_input) : undefined,
|
|
164
|
+
tool_output: row.tool_output ? JSON.parse(row.tool_output) : undefined,
|
|
165
|
+
user_prompt: row.user_prompt,
|
|
166
|
+
ai_response: row.ai_response,
|
|
167
|
+
distilled: row.distilled === 1,
|
|
168
|
+
};
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
//# sourceMappingURL=event-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/event-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export declare class FailureRepository extends BaseRepository {
|
|
3
|
+
insertFailureSignal(data: {
|
|
4
|
+
id: string;
|
|
5
|
+
session_id: string;
|
|
6
|
+
project_path: string;
|
|
7
|
+
task_session_id?: string;
|
|
8
|
+
signal_type: string;
|
|
9
|
+
raw_prompt: string;
|
|
10
|
+
matched_pattern?: string;
|
|
11
|
+
context_phase?: string;
|
|
12
|
+
is_iteration: number;
|
|
13
|
+
preceding_tool_count: number;
|
|
14
|
+
timestamp: string;
|
|
15
|
+
}): void;
|
|
16
|
+
getFailureSignals(query: {
|
|
17
|
+
session_id?: string;
|
|
18
|
+
project_path?: string;
|
|
19
|
+
limit?: number;
|
|
20
|
+
}): Record<string, unknown>[];
|
|
21
|
+
}
|
|
22
|
+
//# sourceMappingURL=failure-repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"failure-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/failure-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,qBAAa,iBAAkB,SAAQ,cAAc;IACnD,mBAAmB,CAAC,IAAI,EAAE;QACxB,EAAE,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,eAAe,CAAC,EAAE,MAAM,CAAC;QAC/E,WAAW,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,eAAe,CAAC,EAAE,MAAM,CAAC;QAClE,aAAa,CAAC,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAC;QAAC,oBAAoB,EAAE,MAAM,CAAC;QAC3E,SAAS,EAAE,MAAM,CAAC;KACnB,GAAG,IAAI;IAaR,iBAAiB,CAAC,KAAK,EAAE;QAAE,UAAU,CAAC,EAAE,MAAM,CAAC;QAAC,YAAY,CAAC,EAAE,MAAM,CAAC;QAAC,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE;CAUpH"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export class FailureRepository extends BaseRepository {
|
|
3
|
+
insertFailureSignal(data) {
|
|
4
|
+
this.db.prepare(`
|
|
5
|
+
INSERT INTO failure_signals (
|
|
6
|
+
id, session_id, project_path, task_session_id, signal_type, raw_prompt,
|
|
7
|
+
matched_pattern, context_phase, is_iteration, preceding_tool_count, timestamp
|
|
8
|
+
) VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
|
|
9
|
+
`).run(data.id, data.session_id, data.project_path, data.task_session_id ?? null, data.signal_type, data.raw_prompt, data.matched_pattern ?? null, data.context_phase ?? null, data.is_iteration, data.preceding_tool_count, data.timestamp);
|
|
10
|
+
}
|
|
11
|
+
getFailureSignals(query) {
|
|
12
|
+
const conditions = ['1=1'];
|
|
13
|
+
const params = [];
|
|
14
|
+
if (query.session_id) {
|
|
15
|
+
conditions.push('session_id = ?');
|
|
16
|
+
params.push(query.session_id);
|
|
17
|
+
}
|
|
18
|
+
if (query.project_path) {
|
|
19
|
+
conditions.push('project_path = ?');
|
|
20
|
+
params.push(query.project_path);
|
|
21
|
+
}
|
|
22
|
+
params.push(query.limit ?? 100);
|
|
23
|
+
return this.db.prepare(`SELECT * FROM failure_signals WHERE ${conditions.join(' AND ')} ORDER BY timestamp ASC LIMIT ?`).all(...params);
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=failure-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"failure-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/failure-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,OAAO,iBAAkB,SAAQ,cAAc;IACnD,mBAAmB,CAAC,IAKnB;QACC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;;;KAKf,CAAC,CAAC,GAAG,CACJ,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,eAAe,IAAI,IAAI,EACzE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,eAAe,IAAI,IAAI,EAC/D,IAAI,CAAC,aAAa,IAAI,IAAI,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,oBAAoB,EAAE,IAAI,CAAC,SAAS,CACzF,CAAC;IACJ,CAAC;IAED,iBAAiB,CAAC,KAAqE;QACrF,MAAM,UAAU,GAAa,CAAC,KAAK,CAAC,CAAC;QACrC,MAAM,MAAM,GAAc,EAAE,CAAC;QAC7B,IAAI,KAAK,CAAC,UAAU,EAAE,CAAC;YAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;QAAC,CAAC;QAC3F,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;YAAC,UAAU,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;YAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC;QAAC,CAAC;QACjG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,IAAI,GAAG,CAAC,CAAC;QAChC,OAAO,IAAI,CAAC,EAAE,CAAC,OAAO,CACpB,uCAAuC,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,iCAAiC,CACjG,CAAC,GAAG,CAAC,GAAG,MAAM,CAA8B,CAAC;IAChD,CAAC;CACF"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export declare class IntentRuleRepository extends BaseRepository {
|
|
3
|
+
upsertIntentRule(rule: {
|
|
4
|
+
id: string;
|
|
5
|
+
rule_type: string;
|
|
6
|
+
pattern: string;
|
|
7
|
+
confidence?: number;
|
|
8
|
+
source?: string;
|
|
9
|
+
}): void;
|
|
10
|
+
getIntentRules(ruleType?: string): Array<{
|
|
11
|
+
id: string;
|
|
12
|
+
rule_type: string;
|
|
13
|
+
pattern: string;
|
|
14
|
+
confidence: number;
|
|
15
|
+
hit_count: number;
|
|
16
|
+
miss_count: number;
|
|
17
|
+
}>;
|
|
18
|
+
recordIntentRuleHit(ruleId: string, hit: boolean): void;
|
|
19
|
+
}
|
|
20
|
+
//# sourceMappingURL=intent-rule-repository.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"intent-rule-repository.d.ts","sourceRoot":"","sources":["../../../src/storage/repositories/intent-rule-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,qBAAa,oBAAqB,SAAQ,cAAc;IACtD,gBAAgB,CAAC,IAAI,EAAE;QACrB,EAAE,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAC/C,UAAU,CAAC,EAAE,MAAM,CAAC;QAAC,MAAM,CAAC,EAAE,MAAM,CAAC;KACtC,GAAG,IAAI;IAWR,cAAc,CAAC,QAAQ,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC;QACvC,EAAE,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;KAC3G,CAAC;IAWF,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,OAAO,GAAG,IAAI;CASxD"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export class IntentRuleRepository extends BaseRepository {
|
|
3
|
+
upsertIntentRule(rule) {
|
|
4
|
+
this.db.prepare(`
|
|
5
|
+
INSERT INTO intent_rules (id, rule_type, pattern, confidence, source)
|
|
6
|
+
VALUES (?, ?, ?, ?, ?)
|
|
7
|
+
ON CONFLICT(id) DO UPDATE SET
|
|
8
|
+
pattern = excluded.pattern,
|
|
9
|
+
confidence = excluded.confidence,
|
|
10
|
+
updated_at = datetime('now')
|
|
11
|
+
`).run(rule.id, rule.rule_type, rule.pattern, rule.confidence ?? 0.8, rule.source ?? 'distilled');
|
|
12
|
+
}
|
|
13
|
+
getIntentRules(ruleType) {
|
|
14
|
+
try {
|
|
15
|
+
const where = ruleType ? `WHERE rule_type = ? AND confidence >= 0.5` : `WHERE confidence >= 0.5`;
|
|
16
|
+
const args = ruleType ? [ruleType] : [];
|
|
17
|
+
return this.db.prepare(`
|
|
18
|
+
SELECT id, rule_type, pattern, confidence, hit_count, miss_count
|
|
19
|
+
FROM intent_rules ${where} ORDER BY confidence DESC
|
|
20
|
+
`).all(...args);
|
|
21
|
+
}
|
|
22
|
+
catch {
|
|
23
|
+
return [];
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
recordIntentRuleHit(ruleId, hit) {
|
|
27
|
+
try {
|
|
28
|
+
if (hit) {
|
|
29
|
+
this.db.prepare(`UPDATE intent_rules SET hit_count = hit_count + 1, last_hit_at = datetime('now') WHERE id = ?`).run(ruleId);
|
|
30
|
+
}
|
|
31
|
+
else {
|
|
32
|
+
this.db.prepare(`UPDATE intent_rules SET miss_count = miss_count + 1 WHERE id = ?`).run(ruleId);
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
catch { /* 忽略 */ }
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
//# sourceMappingURL=intent-rule-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"intent-rule-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/intent-rule-repository.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAEtD,MAAM,OAAO,oBAAqB,SAAQ,cAAc;IACtD,gBAAgB,CAAC,IAGhB;QACC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;;;;;;KAOf,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,IAAI,GAAG,EAAE,IAAI,CAAC,MAAM,IAAI,WAAW,CAAC,CAAC;IACpG,CAAC;IAED,cAAc,CAAC,QAAiB;QAG9B,IAAI,CAAC;YACH,MAAM,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,2CAA2C,CAAC,CAAC,CAAC,yBAAyB,CAAC;YACjG,MAAM,IAAI,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACxC,OAAO,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC;;4BAED,KAAK;OAC1B,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAyH,CAAC;QAC1I,CAAC;QAAC,MAAM,CAAC;YAAC,OAAO,EAAE,CAAC;QAAC,CAAC;IACxB,CAAC;IAED,mBAAmB,CAAC,MAAc,EAAE,GAAY;QAC9C,IAAI,CAAC;YACH,IAAI,GAAG,EAAE,CAAC;gBACR,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,+FAA+F,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAC/H,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,kEAAkE,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAClG,CAAC;QACH,CAAC;QAAC,MAAM,CAAC,CAAC,QAAQ,CAAC,CAAC;IACtB,CAAC;CACF"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export declare class KnowledgeRepository extends BaseRepository {
|
|
3
|
+
insertKnowledgeNode(node: {
|
|
4
|
+
id: string;
|
|
5
|
+
project_path: string;
|
|
6
|
+
node_type: string;
|
|
7
|
+
title: string;
|
|
8
|
+
content: string;
|
|
9
|
+
tags?: string[];
|
|
10
|
+
embedding_hint?: string;
|
|
11
|
+
}): void;
|
|
12
|
+
insertKnowledgeEdge(edge: {
|
|
13
|
+
id: string;
|
|
14
|
+
from_node_id: string;
|
|
15
|
+
to_node_id: string;
|
|
16
|
+
edge_type: string;
|
|
17
|
+
weight?: number;
|
|
18
|
+
metadata?: Record<string, unknown>;
|
|
19
|
+
}): void;
|
|
20
|
+
searchKnowledgeNodes(query: string, projectPath: string, limit?: number): Array<{
|
|
21
|
+
id: string;
|
|
22
|
+
node_type: string;
|
|
23
|
+
title: string;
|
|
24
|
+
content: string;
|
|
25
|
+
tags: string | null;
|
|
26
|
+
}>;
|
|
27
|
+
findKnowledgeNodeByTitle(title: string, projectPath: string, nodeType?: string): {
|
|
28
|
+
id: string;
|
|
29
|
+
} | null;
|
|
30
|
+
getKnowledgeEdges(nodeId: string, direction?: 'out' | 'in' | 'both'): Array<{
|
|
31
|
+
id: string;
|
|
32
|
+
from_node_id: string;
|
|
33
|
+
to_node_id: string;
|
|
34
|
+
edge_type: string;
|
|
35
|
+
weight: number;
|
|
36
|
+
}>;
|
|
37
|
+
getNeighborNodes(nodeId: string, projectPath: string, limit?: number): Array<{
|
|
38
|
+
id: string;
|
|
39
|
+
node_type: string;
|
|
40
|
+
title: string;
|
|
41
|
+
content: string;
|
|
42
|
+
edge_type: string;
|
|
43
|
+
weight: number;
|
|
44
|
+
}>;
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=knowledge-repository.d.ts.map
|
|
@@ -0,0 +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"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export class KnowledgeRepository extends BaseRepository {
|
|
3
|
+
insertKnowledgeNode(node) {
|
|
4
|
+
this.db.prepare(`
|
|
5
|
+
INSERT OR REPLACE INTO knowledge_nodes (id, project_path, node_type, title, content, tags, embedding_hint, last_accessed_at)
|
|
6
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, datetime('now'))
|
|
7
|
+
`).run(node.id, node.project_path, node.node_type, node.title, node.content, node.tags ? JSON.stringify(node.tags) : null, node.embedding_hint ?? null);
|
|
8
|
+
}
|
|
9
|
+
insertKnowledgeEdge(edge) {
|
|
10
|
+
this.db.prepare(`
|
|
11
|
+
INSERT OR IGNORE INTO knowledge_edges (id, from_node_id, to_node_id, edge_type, weight, metadata)
|
|
12
|
+
VALUES (?, ?, ?, ?, ?, ?)
|
|
13
|
+
`).run(edge.id, edge.from_node_id, edge.to_node_id, edge.edge_type, edge.weight ?? 1.0, edge.metadata ? JSON.stringify(edge.metadata) : null);
|
|
14
|
+
}
|
|
15
|
+
searchKnowledgeNodes(query, projectPath, limit = 10) {
|
|
16
|
+
try {
|
|
17
|
+
const terms = query.trim().split(/\s+/).filter(Boolean).map(t => `"${t}"`).join(' OR ');
|
|
18
|
+
if (!terms)
|
|
19
|
+
return [];
|
|
20
|
+
return this.db.prepare(`
|
|
21
|
+
SELECT kn.id, kn.node_type, kn.title, kn.content, kn.tags
|
|
22
|
+
FROM knowledge_nodes_fts fts
|
|
23
|
+
JOIN knowledge_nodes kn ON kn.id = fts.id
|
|
24
|
+
WHERE fts.knowledge_nodes_fts MATCH ? AND kn.project_path = ? AND kn.archived = 0
|
|
25
|
+
ORDER BY rank LIMIT ?
|
|
26
|
+
`).all(terms, projectPath, limit);
|
|
27
|
+
}
|
|
28
|
+
catch {
|
|
29
|
+
return [];
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
findKnowledgeNodeByTitle(title, projectPath, nodeType) {
|
|
33
|
+
try {
|
|
34
|
+
const sql = nodeType
|
|
35
|
+
? `SELECT id FROM knowledge_nodes WHERE title = ? AND project_path = ? AND node_type = ? AND archived = 0 LIMIT 1`
|
|
36
|
+
: `SELECT id FROM knowledge_nodes WHERE title = ? AND project_path = ? AND archived = 0 LIMIT 1`;
|
|
37
|
+
const params = nodeType ? [title, projectPath, nodeType] : [title, projectPath];
|
|
38
|
+
return this.db.prepare(sql).get(...params);
|
|
39
|
+
}
|
|
40
|
+
catch {
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
getKnowledgeEdges(nodeId, direction = 'both') {
|
|
45
|
+
try {
|
|
46
|
+
let sql;
|
|
47
|
+
let params;
|
|
48
|
+
if (direction === 'out') {
|
|
49
|
+
sql = `SELECT id, from_node_id, to_node_id, edge_type, weight FROM knowledge_edges WHERE from_node_id = ?`;
|
|
50
|
+
params = [nodeId];
|
|
51
|
+
}
|
|
52
|
+
else if (direction === 'in') {
|
|
53
|
+
sql = `SELECT id, from_node_id, to_node_id, edge_type, weight FROM knowledge_edges WHERE to_node_id = ?`;
|
|
54
|
+
params = [nodeId];
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
sql = `SELECT id, from_node_id, to_node_id, edge_type, weight FROM knowledge_edges WHERE from_node_id = ? OR to_node_id = ?`;
|
|
58
|
+
params = [nodeId, nodeId];
|
|
59
|
+
}
|
|
60
|
+
return this.db.prepare(sql).all(...params);
|
|
61
|
+
}
|
|
62
|
+
catch {
|
|
63
|
+
return [];
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
getNeighborNodes(nodeId, projectPath, limit = 10) {
|
|
67
|
+
try {
|
|
68
|
+
return this.db.prepare(`
|
|
69
|
+
SELECT kn.id, kn.node_type, kn.title, kn.content, ke.edge_type, ke.weight
|
|
70
|
+
FROM knowledge_edges ke
|
|
71
|
+
JOIN knowledge_nodes kn ON (
|
|
72
|
+
CASE WHEN ke.from_node_id = ? THEN ke.to_node_id ELSE ke.from_node_id END = kn.id
|
|
73
|
+
)
|
|
74
|
+
WHERE (ke.from_node_id = ? OR ke.to_node_id = ?)
|
|
75
|
+
AND kn.project_path = ? AND kn.archived = 0
|
|
76
|
+
ORDER BY ke.weight DESC LIMIT ?
|
|
77
|
+
`).all(nodeId, nodeId, nodeId, projectPath, limit);
|
|
78
|
+
}
|
|
79
|
+
catch {
|
|
80
|
+
return [];
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=knowledge-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"knowledge-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/knowledge-repository.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export declare class LatencyRepository extends BaseRepository {
|
|
3
|
+
insertLatencyTrace(record: {
|
|
4
|
+
id: string;
|
|
5
|
+
session_id: string;
|
|
6
|
+
project_path: string;
|
|
7
|
+
trace_type: string;
|
|
8
|
+
engine_name: string;
|
|
9
|
+
duration_ms: number;
|
|
10
|
+
metadata?: Record<string, unknown> | null;
|
|
11
|
+
}): void;
|
|
12
|
+
getLatencyStats(traceType?: string, days?: number): Array<{
|
|
13
|
+
engine_name: string;
|
|
14
|
+
trace_type: string;
|
|
15
|
+
p50: number;
|
|
16
|
+
p95: number;
|
|
17
|
+
max: number;
|
|
18
|
+
count: number;
|
|
19
|
+
}>;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=latency-repository.d.ts.map
|
|
@@ -0,0 +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"}
|
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export class LatencyRepository extends BaseRepository {
|
|
3
|
+
insertLatencyTrace(record) {
|
|
4
|
+
try {
|
|
5
|
+
this.db.prepare(`
|
|
6
|
+
INSERT OR IGNORE INTO latency_traces (id, session_id, project_path, trace_type, engine_name, duration_ms, metadata)
|
|
7
|
+
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 { /* 延迟追踪失败不影响主流程 */ }
|
|
11
|
+
}
|
|
12
|
+
getLatencyStats(traceType, days = 7) {
|
|
13
|
+
try {
|
|
14
|
+
const since = new Date(Date.now() - days * 86400_000).toISOString();
|
|
15
|
+
const where = traceType ? `AND trace_type = '${traceType}'` : '';
|
|
16
|
+
const rows = this.db.prepare(`
|
|
17
|
+
SELECT engine_name, trace_type, duration_ms
|
|
18
|
+
FROM latency_traces WHERE timestamp >= ? ${where}
|
|
19
|
+
ORDER BY engine_name, trace_type, duration_ms
|
|
20
|
+
`).all(since);
|
|
21
|
+
const groups = new Map();
|
|
22
|
+
const meta = new Map();
|
|
23
|
+
for (const r of rows) {
|
|
24
|
+
const key = `${r.engine_name}::${r.trace_type}`;
|
|
25
|
+
if (!groups.has(key)) {
|
|
26
|
+
groups.set(key, []);
|
|
27
|
+
meta.set(key, { engine_name: r.engine_name, trace_type: r.trace_type });
|
|
28
|
+
}
|
|
29
|
+
groups.get(key).push(r.duration_ms);
|
|
30
|
+
}
|
|
31
|
+
return [...groups.entries()].map(([key, vals]) => {
|
|
32
|
+
vals.sort((a, b) => a - b);
|
|
33
|
+
const p = (pct) => vals[Math.floor(vals.length * pct)] ?? 0;
|
|
34
|
+
return { ...meta.get(key), p50: p(0.5), p95: p(0.95), max: vals[vals.length - 1] ?? 0, count: vals.length };
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
catch {
|
|
38
|
+
return [];
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
//# sourceMappingURL=latency-repository.js.map
|
|
@@ -0,0 +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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { BaseRepository } from './base-repository.js';
|
|
2
|
+
export declare class MaintenanceRepository extends BaseRepository {
|
|
3
|
+
private dbPath;
|
|
4
|
+
constructor(db: import('better-sqlite3').Database, dbPath: string);
|
|
5
|
+
getDbSizeMb(): number;
|
|
6
|
+
getStorageSize(): number;
|
|
7
|
+
purgeDistilledEvents(retentionDays?: number): number;
|
|
8
|
+
purgeOldSessions(retentionDays?: number): number;
|
|
9
|
+
runMaintenance(maxSizeMb?: number): {
|
|
10
|
+
purgedEvents: number;
|
|
11
|
+
purgedSessions: number;
|
|
12
|
+
purgedQueue: number;
|
|
13
|
+
dbSizeMb: number;
|
|
14
|
+
};
|
|
15
|
+
getDaemonState(key: string): string | null;
|
|
16
|
+
setDaemonState(key: string, value: string): void;
|
|
17
|
+
}
|
|
18
|
+
//# sourceMappingURL=maintenance-repository.d.ts.map
|
|
@@ -0,0 +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"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import fs from 'fs';
|
|
2
|
+
import { logger } from '../../utils/logger.js';
|
|
3
|
+
import { BaseRepository } from './base-repository.js';
|
|
4
|
+
export class MaintenanceRepository extends BaseRepository {
|
|
5
|
+
dbPath;
|
|
6
|
+
constructor(db, dbPath) {
|
|
7
|
+
super(db);
|
|
8
|
+
this.dbPath = dbPath;
|
|
9
|
+
}
|
|
10
|
+
getDbSizeMb() {
|
|
11
|
+
try {
|
|
12
|
+
return fs.statSync(this.dbPath).size / (1024 * 1024);
|
|
13
|
+
}
|
|
14
|
+
catch {
|
|
15
|
+
return 0;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
getStorageSize() {
|
|
19
|
+
const row = this.db.prepare("SELECT page_count * page_size as size FROM pragma_page_count(), pragma_page_size()").get();
|
|
20
|
+
return row.size;
|
|
21
|
+
}
|
|
22
|
+
purgeDistilledEvents(retentionDays = 7) {
|
|
23
|
+
const cutoff = new Date(Date.now() - retentionDays * 86400000).toISOString();
|
|
24
|
+
return this.db.prepare('DELETE FROM events WHERE distilled = 1 AND timestamp < ?').run(cutoff).changes;
|
|
25
|
+
}
|
|
26
|
+
purgeOldSessions(retentionDays = 30) {
|
|
27
|
+
const cutoff = new Date(Date.now() - retentionDays * 86400000).toISOString();
|
|
28
|
+
return this.db.prepare("DELETE FROM sessions WHERE status IN ('completed', 'abandoned') AND updated_at < ?").run(cutoff).changes;
|
|
29
|
+
}
|
|
30
|
+
runMaintenance(maxSizeMb = 1024) {
|
|
31
|
+
const purgedEvents = this.purgeDistilledEvents(30);
|
|
32
|
+
const purgedSessions = this.purgeOldSessions(30);
|
|
33
|
+
const purgedQueue = this.db.prepare("DELETE FROM distill_queue WHERE status = 'processed' AND processed_at < datetime('now', '-7 days')").run().changes;
|
|
34
|
+
this.db.exec('VACUUM');
|
|
35
|
+
const dbSizeMb = this.getDbSizeMb();
|
|
36
|
+
if (dbSizeMb > maxSizeMb) {
|
|
37
|
+
logger.warn(`[存储] 数据库大小 ${dbSizeMb.toFixed(1)}MB 超过上限 ${maxSizeMb}MB,建议检查数据增长`);
|
|
38
|
+
}
|
|
39
|
+
logger.info(`[存储] 维护完成:清理事件 ${purgedEvents} 条,会话 ${purgedSessions} 条,队列 ${purgedQueue} 条,当前大小 ${dbSizeMb.toFixed(1)}MB`);
|
|
40
|
+
return { purgedEvents, purgedSessions, purgedQueue, dbSizeMb };
|
|
41
|
+
}
|
|
42
|
+
getDaemonState(key) {
|
|
43
|
+
try {
|
|
44
|
+
const row = this.db.prepare(`SELECT value FROM daemon_state WHERE key = ?`).get(key);
|
|
45
|
+
return row?.value ?? null;
|
|
46
|
+
}
|
|
47
|
+
catch {
|
|
48
|
+
return null;
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
setDaemonState(key, value) {
|
|
52
|
+
try {
|
|
53
|
+
this.db.prepare(`
|
|
54
|
+
INSERT INTO daemon_state (key, value, updated_at) VALUES (?, ?, datetime('now'))
|
|
55
|
+
ON CONFLICT(key) DO UPDATE SET value = excluded.value, updated_at = datetime('now')
|
|
56
|
+
`).run(key, value);
|
|
57
|
+
}
|
|
58
|
+
catch { /* 忽略 */ }
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
//# sourceMappingURL=maintenance-repository.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"maintenance-repository.js","sourceRoot":"","sources":["../../../src/storage/repositories/maintenance-repository.ts"],"names":[],"mappings":"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"}
|