squish-memory 0.9.3 → 1.0.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/CHANGELOG.md +68 -0
- package/README.md +58 -2
- package/config/plugin-manifest.json +152 -0
- package/config/plugin-manifest.schema.json +244 -0
- package/dist/algorithms/{merge/analytics → analytics}/token-estimator.d.ts +1 -1
- package/dist/algorithms/analytics/token-estimator.d.ts.map +1 -0
- package/dist/algorithms/{merge/analytics → analytics}/token-estimator.js +3 -3
- package/dist/algorithms/analytics/token-estimator.js.map +1 -0
- package/dist/algorithms/detection/hash-filters.d.ts.map +1 -0
- package/dist/algorithms/detection/hash-filters.js.map +1 -0
- package/dist/algorithms/{merge/detection → detection}/semantic-ranker.d.ts +1 -1
- package/dist/algorithms/detection/semantic-ranker.d.ts.map +1 -0
- package/dist/algorithms/{merge/detection → detection}/semantic-ranker.js +1 -1
- package/dist/algorithms/detection/semantic-ranker.js.map +1 -0
- package/dist/algorithms/{merge/detection → detection}/two-stage-detector.d.ts +1 -1
- package/dist/algorithms/detection/two-stage-detector.d.ts.map +1 -0
- package/dist/algorithms/{merge/detection → detection}/two-stage-detector.js +4 -4
- package/dist/algorithms/detection/two-stage-detector.js.map +1 -0
- package/dist/algorithms/handlers/approve-merge.d.ts.map +1 -0
- package/dist/algorithms/{merge/handlers → handlers}/approve-merge.js +4 -4
- package/dist/algorithms/handlers/approve-merge.js.map +1 -0
- package/dist/algorithms/{merge/handlers → handlers}/detect-duplicates.d.ts +1 -1
- package/dist/algorithms/handlers/detect-duplicates.d.ts.map +1 -0
- package/dist/algorithms/{merge/handlers → handlers}/detect-duplicates.js +55 -75
- package/dist/algorithms/handlers/detect-duplicates.js.map +1 -0
- package/dist/algorithms/handlers/get-stats.d.ts.map +1 -0
- package/dist/algorithms/{merge/handlers → handlers}/get-stats.js +3 -3
- package/dist/algorithms/handlers/get-stats.js.map +1 -0
- package/dist/algorithms/handlers/list-proposals.d.ts.map +1 -0
- package/dist/algorithms/{merge/handlers → handlers}/list-proposals.js +3 -3
- package/dist/algorithms/handlers/list-proposals.js.map +1 -0
- package/dist/algorithms/handlers/preview-merge.d.ts.map +1 -0
- package/dist/algorithms/{merge/handlers → handlers}/preview-merge.js +3 -3
- package/dist/algorithms/handlers/preview-merge.js.map +1 -0
- package/dist/algorithms/handlers/reject-merge.d.ts.map +1 -0
- package/dist/algorithms/{merge/handlers → handlers}/reject-merge.js +3 -3
- package/dist/algorithms/handlers/reject-merge.js.map +1 -0
- package/dist/algorithms/handlers/reverse-merge.d.ts.map +1 -0
- package/dist/algorithms/{merge/handlers → handlers}/reverse-merge.js +3 -3
- package/dist/algorithms/handlers/reverse-merge.js.map +1 -0
- package/dist/algorithms/{merge/safety → safety}/safety-checks.d.ts +1 -1
- package/dist/algorithms/safety/safety-checks.d.ts.map +1 -0
- package/dist/algorithms/safety/safety-checks.js +179 -0
- package/dist/algorithms/safety/safety-checks.js.map +1 -0
- package/dist/algorithms/{merge/strategies → strategies}/merge-strategies.d.ts +1 -1
- package/dist/algorithms/strategies/merge-strategies.d.ts.map +1 -0
- package/dist/algorithms/strategies/merge-strategies.js.map +1 -0
- package/dist/algorithms/utils/response-builder.d.ts +28 -0
- package/dist/algorithms/utils/response-builder.d.ts.map +1 -0
- package/dist/algorithms/utils/response-builder.js +37 -0
- package/dist/algorithms/utils/response-builder.js.map +1 -0
- package/dist/api/web/web.d.ts.map +1 -1
- package/dist/api/web/web.js +0 -21
- package/dist/api/web/web.js.map +1 -1
- package/dist/commands/mcp-server.js +1 -1
- package/dist/config.d.ts +1 -1
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +30 -38
- package/dist/config.js.map +1 -1
- package/dist/core/associations.js +2 -2
- package/dist/core/associations.js.map +1 -1
- package/dist/core/layers/generator.d.ts +25 -0
- package/dist/core/layers/generator.d.ts.map +1 -0
- package/dist/core/layers/generator.js +76 -0
- package/dist/core/layers/generator.js.map +1 -0
- package/dist/core/mcp/tools.d.ts.map +1 -1
- package/dist/core/mcp/tools.js +71 -0
- package/dist/core/mcp/tools.js.map +1 -1
- package/dist/core/memory/hybrid-retrieval.d.ts.map +1 -1
- package/dist/core/memory/hybrid-retrieval.js +49 -1
- package/dist/core/memory/hybrid-retrieval.js.map +1 -1
- package/dist/core/memory/hybrid-search.d.ts.map +1 -1
- package/dist/core/memory/hybrid-search.js +0 -7
- package/dist/core/memory/hybrid-search.js.map +1 -1
- package/dist/core/memory/memories.d.ts.map +1 -1
- package/dist/core/memory/memories.js +47 -53
- package/dist/core/memory/memories.js.map +1 -1
- package/dist/core/memory/progressive-disclosure.d.ts.map +1 -1
- package/dist/core/memory/progressive-disclosure.js.map +1 -1
- package/dist/core/namespaces/index.d.ts +71 -0
- package/dist/core/namespaces/index.d.ts.map +1 -0
- package/dist/core/namespaces/index.js +296 -0
- package/dist/core/namespaces/index.js.map +1 -0
- package/dist/core/namespaces/uri-parser.d.ts +31 -0
- package/dist/core/namespaces/uri-parser.d.ts.map +1 -0
- package/dist/core/namespaces/uri-parser.js +74 -0
- package/dist/core/namespaces/uri-parser.js.map +1 -0
- package/dist/core/observations.d.ts.map +1 -1
- package/dist/core/observations.js +3 -12
- package/dist/core/observations.js.map +1 -1
- package/dist/core/projects.d.ts.map +1 -1
- package/dist/core/projects.js +0 -12
- package/dist/core/projects.js.map +1 -1
- package/dist/core/scheduler/cron-scheduler.d.ts.map +1 -1
- package/dist/core/scheduler/cron-scheduler.js +14 -0
- package/dist/core/scheduler/cron-scheduler.js.map +1 -1
- package/dist/core/session-hooks/self-iteration-job.d.ts +20 -0
- package/dist/core/session-hooks/self-iteration-job.d.ts.map +1 -0
- package/dist/core/session-hooks/self-iteration-job.js +278 -0
- package/dist/core/session-hooks/self-iteration-job.js.map +1 -0
- package/dist/core/session-hooks/session-hooks.d.ts +18 -0
- package/dist/core/session-hooks/session-hooks.d.ts.map +1 -0
- package/dist/core/session-hooks/session-hooks.js +55 -0
- package/dist/core/session-hooks/session-hooks.js.map +1 -0
- package/dist/core/tracing/collector.d.ts +111 -0
- package/dist/core/tracing/collector.d.ts.map +1 -0
- package/dist/core/tracing/collector.js +338 -0
- package/dist/core/tracing/collector.js.map +1 -0
- package/dist/core/tracing/visualizer.d.ts +32 -0
- package/dist/core/tracing/visualizer.d.ts.map +1 -0
- package/dist/core/tracing/visualizer.js +165 -0
- package/dist/core/tracing/visualizer.js.map +1 -0
- package/dist/drizzle/schema-sqlite.d.ts +384 -0
- package/dist/drizzle/schema-sqlite.d.ts.map +1 -1
- package/dist/drizzle/schema-sqlite.js +65 -0
- package/dist/drizzle/schema-sqlite.js.map +1 -1
- package/dist/drizzle/schema.d.ts +368 -0
- package/dist/drizzle/schema.d.ts.map +1 -1
- package/dist/drizzle/schema.js +63 -0
- package/dist/drizzle/schema.js.map +1 -1
- package/dist/index.d.ts +4 -4
- package/dist/index.js +101 -62
- package/dist/index.js.map +1 -1
- package/generated/mcp/manifest.json +23 -0
- package/generated/mcp/mcp-servers.json +25 -0
- package/generated/mcp/mcporter.json +34 -0
- package/generated/mcp/openclaw-memory-qmd.json +17 -0
- package/generated/mcp/runtime.json +12 -0
- package/package.json +50 -9
- package/packages/plugin-claude-code/README.md +73 -0
- package/packages/plugin-claude-code/dist/plugin-wrapper.d.ts +35 -0
- package/packages/plugin-claude-code/dist/plugin-wrapper.d.ts.map +1 -0
- package/packages/plugin-claude-code/dist/plugin-wrapper.js +191 -0
- package/packages/plugin-claude-code/dist/plugin-wrapper.js.map +1 -0
- package/packages/plugin-claude-code/package.json +31 -0
- package/packages/plugin-openclaw/README.md +70 -0
- package/packages/plugin-openclaw/dist/index.d.ts +49 -0
- package/packages/plugin-openclaw/dist/index.d.ts.map +1 -0
- package/packages/plugin-openclaw/dist/index.js +262 -0
- package/packages/plugin-openclaw/dist/index.js.map +1 -0
- package/packages/plugin-openclaw/openclaw.plugin.json +94 -0
- package/packages/plugin-openclaw/package.json +31 -0
- package/packages/plugin-opencode/install.mjs +217 -0
- package/packages/plugin-opencode/package.json +21 -0
- package/scripts/dependency-manager.mjs +217 -0
- package/scripts/detect-clients.mjs +78 -0
- package/scripts/install-interactive.mjs +674 -0
- package/scripts/install-plugin.mjs +415 -0
- package/scripts/test-interactive.mjs +131 -0
- package/commands/managed-sync.ts +0 -69
- package/commands/mcp-server.ts +0 -519
- package/dist/algorithms/merge/analytics/token-estimator.d.ts.map +0 -1
- package/dist/algorithms/merge/analytics/token-estimator.js.map +0 -1
- package/dist/algorithms/merge/detection/hash-filters.d.ts.map +0 -1
- package/dist/algorithms/merge/detection/hash-filters.js.map +0 -1
- package/dist/algorithms/merge/detection/semantic-ranker.d.ts.map +0 -1
- package/dist/algorithms/merge/detection/semantic-ranker.js.map +0 -1
- package/dist/algorithms/merge/detection/two-stage-detector.d.ts.map +0 -1
- package/dist/algorithms/merge/detection/two-stage-detector.js.map +0 -1
- package/dist/algorithms/merge/handlers/approve-merge.d.ts.map +0 -1
- package/dist/algorithms/merge/handlers/approve-merge.js.map +0 -1
- package/dist/algorithms/merge/handlers/detect-duplicates.d.ts.map +0 -1
- package/dist/algorithms/merge/handlers/detect-duplicates.js.map +0 -1
- package/dist/algorithms/merge/handlers/get-stats.d.ts.map +0 -1
- package/dist/algorithms/merge/handlers/get-stats.js.map +0 -1
- package/dist/algorithms/merge/handlers/list-proposals.d.ts.map +0 -1
- package/dist/algorithms/merge/handlers/list-proposals.js.map +0 -1
- package/dist/algorithms/merge/handlers/preview-merge.d.ts.map +0 -1
- package/dist/algorithms/merge/handlers/preview-merge.js.map +0 -1
- package/dist/algorithms/merge/handlers/reject-merge.d.ts.map +0 -1
- package/dist/algorithms/merge/handlers/reject-merge.js.map +0 -1
- package/dist/algorithms/merge/handlers/reverse-merge.d.ts.map +0 -1
- package/dist/algorithms/merge/handlers/reverse-merge.js.map +0 -1
- package/dist/algorithms/merge/safety/safety-checks.d.ts.map +0 -1
- package/dist/algorithms/merge/safety/safety-checks.js +0 -215
- package/dist/algorithms/merge/safety/safety-checks.js.map +0 -1
- package/dist/algorithms/merge/strategies/merge-strategies.d.ts.map +0 -1
- package/dist/algorithms/merge/strategies/merge-strategies.js.map +0 -1
- package/dist/core/embeddings/qmd-provider.d.ts +0 -65
- package/dist/core/embeddings/qmd-provider.d.ts.map +0 -1
- package/dist/core/embeddings/qmd-provider.js +0 -133
- package/dist/core/embeddings/qmd-provider.js.map +0 -1
- package/scripts/init-dirs.ts +0 -15
- /package/dist/algorithms/{merge/detection → detection}/hash-filters.d.ts +0 -0
- /package/dist/algorithms/{merge/detection → detection}/hash-filters.js +0 -0
- /package/dist/algorithms/{merge/handlers → handlers}/approve-merge.d.ts +0 -0
- /package/dist/algorithms/{merge/handlers → handlers}/get-stats.d.ts +0 -0
- /package/dist/algorithms/{merge/handlers → handlers}/list-proposals.d.ts +0 -0
- /package/dist/algorithms/{merge/handlers → handlers}/preview-merge.d.ts +0 -0
- /package/dist/algorithms/{merge/handlers → handlers}/reject-merge.d.ts +0 -0
- /package/dist/algorithms/{merge/handlers → handlers}/reverse-merge.d.ts +0 -0
- /package/dist/algorithms/{merge/strategies → strategies}/merge-strategies.js +0 -0
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
/** Self-Iteration Job - Auto-extract key facts from ended conversations
|
|
2
|
+
*
|
|
3
|
+
* Processes conversations to extract memories and generate summaries
|
|
4
|
+
*/
|
|
5
|
+
import { sql, eq } from 'drizzle-orm';
|
|
6
|
+
import { getDb } from '../../db/index.js';
|
|
7
|
+
import { getSchema } from '../../db/schema.js';
|
|
8
|
+
import { rememberMemory } from '../memory/memories.js';
|
|
9
|
+
import { logger } from '../logger.js';
|
|
10
|
+
const DEFAULT_CONFIG = {
|
|
11
|
+
enabled: true,
|
|
12
|
+
extractFacts: true,
|
|
13
|
+
generateSummaries: true,
|
|
14
|
+
consolidateMemories: true,
|
|
15
|
+
minMessageCount: 5,
|
|
16
|
+
maxMessagesToProcess: 50,
|
|
17
|
+
};
|
|
18
|
+
/**
|
|
19
|
+
* Build fact extraction prompt
|
|
20
|
+
*/
|
|
21
|
+
function buildFactExtractionPrompt(messages) {
|
|
22
|
+
const messagesText = messages.map(m => `[${m.role}]: ${m.content}`).join('\n\n');
|
|
23
|
+
return `Extract key facts, decisions, and user preferences from this conversation.
|
|
24
|
+
|
|
25
|
+
Format your response as JSON:
|
|
26
|
+
{
|
|
27
|
+
"extractedFacts": [
|
|
28
|
+
{
|
|
29
|
+
"content": "specific fact text",
|
|
30
|
+
"type": "fact|decision|preference|observation",
|
|
31
|
+
"confidence": 0-100
|
|
32
|
+
}
|
|
33
|
+
]
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
Only extract truly meaningful information that should be remembered:
|
|
37
|
+
- Facts that are useful for future work or decisions
|
|
38
|
+
- User preferences and choices
|
|
39
|
+
- Important decisions made
|
|
40
|
+
- Patterns or behaviors observed
|
|
41
|
+
|
|
42
|
+
Do NOT extract:
|
|
43
|
+
- Temporary conversational details
|
|
44
|
+
- Greetings or pleasantries
|
|
45
|
+
- Unless they indicate something significant
|
|
46
|
+
|
|
47
|
+
Conversation messages:
|
|
48
|
+
${messagesText}`;
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Build summary generation prompt
|
|
52
|
+
*/
|
|
53
|
+
function buildSummaryPrompt(messages) {
|
|
54
|
+
const messagesText = messages.map(m => `[${m.role}]: ${m.content}`).join('\n\n');
|
|
55
|
+
return `Generate a concise summary of this conversation (2-3 sentences, under 300 characters).
|
|
56
|
+
|
|
57
|
+
Focus on:
|
|
58
|
+
- What was accomplished
|
|
59
|
+
- Key decisions made
|
|
60
|
+
- Important context established
|
|
61
|
+
|
|
62
|
+
Conversation messages:
|
|
63
|
+
${messagesText}`;
|
|
64
|
+
}
|
|
65
|
+
/**
|
|
66
|
+
* Parse LLM fact extraction response
|
|
67
|
+
*/
|
|
68
|
+
function parseExtractedFacts(llmResponse) {
|
|
69
|
+
try {
|
|
70
|
+
const jsonMatch = llmResponse.match(/\{[\s\S]*\}/);
|
|
71
|
+
if (!jsonMatch)
|
|
72
|
+
return [];
|
|
73
|
+
const json = JSON.parse(jsonMatch[0]);
|
|
74
|
+
return json.extractedFacts || [];
|
|
75
|
+
}
|
|
76
|
+
catch {
|
|
77
|
+
logger.warn('[SelfIteration] Failed to parse fact extraction response');
|
|
78
|
+
return [];
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Get conversations ready for self-iteration
|
|
83
|
+
*/
|
|
84
|
+
async function getConversationsForIteration(maxMessages) {
|
|
85
|
+
const db = await getDb();
|
|
86
|
+
if (!db)
|
|
87
|
+
return [];
|
|
88
|
+
const schema = await getSchema();
|
|
89
|
+
// Get conversations that:
|
|
90
|
+
// 1. Have ended (endedAt is not null)
|
|
91
|
+
// 2. Haven't been processed yet (metadata.selfIterationProcessed is not set)
|
|
92
|
+
// 3. Have enough messages (messageCount >= minMessageCount)
|
|
93
|
+
const conversations = await db.select()
|
|
94
|
+
.from(schema.conversations)
|
|
95
|
+
.where(sql `${schema.conversations.endedAt} IS NOT NULL
|
|
96
|
+
AND (${schema.conversations.metadata}->>'selfIterationProcessed') IS NULL
|
|
97
|
+
AND ${schema.conversations.messageCount} >= ?`)
|
|
98
|
+
.limit(10);
|
|
99
|
+
return conversations;
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Get messages for a conversation
|
|
103
|
+
*/
|
|
104
|
+
async function getConversationMessages(conversationId) {
|
|
105
|
+
const db = await getDb();
|
|
106
|
+
if (!db)
|
|
107
|
+
return [];
|
|
108
|
+
const schema = await getSchema();
|
|
109
|
+
const messages = await db.select()
|
|
110
|
+
.from(schema.messages)
|
|
111
|
+
.where(eq(schema.messages.conversationId, conversationId))
|
|
112
|
+
.orderBy(schema.messages.createdAt);
|
|
113
|
+
return messages.map((m) => ({
|
|
114
|
+
id: m.id,
|
|
115
|
+
conversationId: m.conversation_id,
|
|
116
|
+
role: m.role,
|
|
117
|
+
content: m.content,
|
|
118
|
+
createdAt: new Date(m.createdAt),
|
|
119
|
+
}));
|
|
120
|
+
}
|
|
121
|
+
/**
|
|
122
|
+
* Mark conversation as processed
|
|
123
|
+
*/
|
|
124
|
+
async function markConversationProcessed(conversationId) {
|
|
125
|
+
const db = await getDb();
|
|
126
|
+
if (!db)
|
|
127
|
+
return;
|
|
128
|
+
const schema = await getSchema();
|
|
129
|
+
await db.update(schema.conversations)
|
|
130
|
+
.set({
|
|
131
|
+
metadata: sql `json_set(${schema.conversations.metadata}, 'selfIterationProcessed', true)`,
|
|
132
|
+
})
|
|
133
|
+
.where(eq(schema.conversations.id, conversationId));
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Process a single conversation
|
|
137
|
+
*/
|
|
138
|
+
async function processConversation(conversation, config) {
|
|
139
|
+
const messages = await getConversationMessages(conversation.id);
|
|
140
|
+
let memoriesCreated = 0;
|
|
141
|
+
let summariesCreated = 0;
|
|
142
|
+
// Limit messages if configured
|
|
143
|
+
const messagesToProcess = config.maxMessagesToProcess > 0
|
|
144
|
+
? messages.slice(-config.maxMessagesToProcess)
|
|
145
|
+
: messages;
|
|
146
|
+
if (messagesToProcess.length === 0) {
|
|
147
|
+
return { memoriesCreated, summariesCreated };
|
|
148
|
+
}
|
|
149
|
+
// Extract facts
|
|
150
|
+
if (config.extractFacts) {
|
|
151
|
+
const prompt = buildFactExtractionPrompt(messagesToProcess);
|
|
152
|
+
// Here we would call an LLM client to extract facts
|
|
153
|
+
// For now, we'll use a simple heuristic extraction
|
|
154
|
+
const extractedFacts = [];
|
|
155
|
+
for (const msg of messagesToProcess) {
|
|
156
|
+
if (msg.role === 'user') {
|
|
157
|
+
const content = msg.content.toLowerCase();
|
|
158
|
+
// Look for user preferences
|
|
159
|
+
if (content.includes('i want') || content.includes('i prefer') || content.includes('i like')) {
|
|
160
|
+
extractedFacts.push({
|
|
161
|
+
content: `User preference: ${msg.content}`,
|
|
162
|
+
type: 'preference',
|
|
163
|
+
confidence: 70,
|
|
164
|
+
});
|
|
165
|
+
}
|
|
166
|
+
// Look for decisions
|
|
167
|
+
if (content.includes('i will') || content.includes('i decide') || content.includes('let\'s')) {
|
|
168
|
+
extractedFacts.push({
|
|
169
|
+
content: `Decision: ${msg.content}`,
|
|
170
|
+
type: 'decision',
|
|
171
|
+
confidence: 80,
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
// Store extracted facts as memories
|
|
177
|
+
for (const fact of extractedFacts) {
|
|
178
|
+
if (fact.confidence >= 60) {
|
|
179
|
+
try {
|
|
180
|
+
await rememberMemory({
|
|
181
|
+
content: fact.content,
|
|
182
|
+
type: fact.type,
|
|
183
|
+
project: conversation.projectId,
|
|
184
|
+
metadata: {
|
|
185
|
+
extractionMethod: 'self-iteration',
|
|
186
|
+
confidence: fact.confidence,
|
|
187
|
+
conversationId: conversation.id,
|
|
188
|
+
sessionId: conversation.sessionId,
|
|
189
|
+
},
|
|
190
|
+
});
|
|
191
|
+
memoriesCreated++;
|
|
192
|
+
logger.info(`[SelfIteration] Extracted memory: ${fact.type} - ${fact.content.substring(0, 50)}...`);
|
|
193
|
+
}
|
|
194
|
+
catch (error) {
|
|
195
|
+
logger.error(`[SelfIteration] Failed to store memory:`, error);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
// Generate summary
|
|
201
|
+
if (config.generateSummaries && messagesToProcess.length > 0) {
|
|
202
|
+
const prompt = buildSummaryPrompt(messagesToProcess);
|
|
203
|
+
// Here we would call an LLM client to generate summary
|
|
204
|
+
// For now, use simple heuristic
|
|
205
|
+
const userMessages = messagesToProcess.filter(m => m.role === 'user');
|
|
206
|
+
const lastMessage = userMessages[userMessages.length - 1]?.content || '';
|
|
207
|
+
const summary = lastMessage.substring(0, Math.min(250, lastMessage.length));
|
|
208
|
+
// Update conversation with summary
|
|
209
|
+
const db = await getDb();
|
|
210
|
+
const schema = await getSchema();
|
|
211
|
+
await db.update(schema.conversations)
|
|
212
|
+
.set({ summary })
|
|
213
|
+
.where(eq(schema.conversations.id, conversation.id));
|
|
214
|
+
summariesCreated++;
|
|
215
|
+
logger.info(`[SelfIteration] Generated summary for conversation ${conversation.sessionId}`);
|
|
216
|
+
}
|
|
217
|
+
return { memoriesCreated, summariesCreated };
|
|
218
|
+
}
|
|
219
|
+
/**
|
|
220
|
+
* Register self-iteration job handler
|
|
221
|
+
*/
|
|
222
|
+
const selfIterationHandler = async (context) => {
|
|
223
|
+
logger.info('[SelfIteration] Starting job');
|
|
224
|
+
const config = {
|
|
225
|
+
...DEFAULT_CONFIG,
|
|
226
|
+
...context.config,
|
|
227
|
+
};
|
|
228
|
+
if (!config.enabled) {
|
|
229
|
+
logger.info('[SelfIteration] Job disabled, skipping');
|
|
230
|
+
return { recordsProcessed: 0, summary: { status: 'disabled' } };
|
|
231
|
+
}
|
|
232
|
+
try {
|
|
233
|
+
const conversations = await getConversationsForIteration(config.maxMessagesToProcess || DEFAULT_CONFIG.maxMessagesToProcess);
|
|
234
|
+
if (conversations.length === 0) {
|
|
235
|
+
logger.info('[SelfIteration] No conversations to process');
|
|
236
|
+
return { recordsProcessed: 0, summary: { status: 'no_conversations' } };
|
|
237
|
+
}
|
|
238
|
+
let totalMemoriesCreated = 0;
|
|
239
|
+
let totalSummariesGenerated = 0;
|
|
240
|
+
let processedCount = 0;
|
|
241
|
+
for (const conversation of conversations) {
|
|
242
|
+
// Skip if already processed
|
|
243
|
+
if (conversation.metadata?.selfIterationProcessed) {
|
|
244
|
+
continue;
|
|
245
|
+
}
|
|
246
|
+
try {
|
|
247
|
+
const result = await processConversation(conversation, config);
|
|
248
|
+
totalMemoriesCreated += result.memoriesCreated;
|
|
249
|
+
totalSummariesGenerated += result.summariesCreated;
|
|
250
|
+
await markConversationProcessed(conversation.id);
|
|
251
|
+
processedCount++;
|
|
252
|
+
}
|
|
253
|
+
catch (error) {
|
|
254
|
+
logger.error(`[SelfIteration] Failed to process conversation ${conversation.id}:`, error);
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
logger.info(`[SelfIteration] Processed ${processedCount}/${conversations.length} conversations`);
|
|
258
|
+
logger.info(`[SelfIteration] Created ${totalMemoriesCreated} memories`);
|
|
259
|
+
logger.info(`[SelfIteration] Generated ${totalSummariesGenerated} summaries`);
|
|
260
|
+
return {
|
|
261
|
+
recordsProcessed: processedCount,
|
|
262
|
+
summary: {
|
|
263
|
+
memoriesCreated: totalMemoriesCreated,
|
|
264
|
+
summariesGenerated: totalSummariesGenerated,
|
|
265
|
+
totalConversations: conversations.length,
|
|
266
|
+
},
|
|
267
|
+
};
|
|
268
|
+
}
|
|
269
|
+
catch (error) {
|
|
270
|
+
logger.error('[SelfIteration] Job failed:', error);
|
|
271
|
+
return {
|
|
272
|
+
recordsProcessed: 0,
|
|
273
|
+
summary: { error: error instanceof Error ? error.message : String(error) },
|
|
274
|
+
};
|
|
275
|
+
}
|
|
276
|
+
};
|
|
277
|
+
export { selfIterationHandler, DEFAULT_CONFIG };
|
|
278
|
+
//# sourceMappingURL=self-iteration-job.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"self-iteration-job.js","sourceRoot":"","sources":["../../../core/session-hooks/self-iteration-job.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/** Session Hooks - Lifecycle hooks for conversation management
|
|
2
|
+
*
|
|
3
|
+
* Provides functions to be called when sessions start/end
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Called when a session ends
|
|
7
|
+
* Marks the conversation as ended so self-iteration can process it
|
|
8
|
+
*/
|
|
9
|
+
export declare function onSessionEnd(sessionId: string): Promise<void>;
|
|
10
|
+
/**
|
|
11
|
+
* Get active sessions for a project
|
|
12
|
+
*/
|
|
13
|
+
export declare function getActiveSessions(projectId: string): Promise<string[]>;
|
|
14
|
+
/**
|
|
15
|
+
* End all sessions for a project
|
|
16
|
+
*/
|
|
17
|
+
export declare function endAllProjectSessions(projectId: string): Promise<number>;
|
|
18
|
+
//# sourceMappingURL=session-hooks.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-hooks.d.ts","sourceRoot":"","sources":["../../../core/session-hooks/session-hooks.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAOH;;;GAGG;AACH,wBAAsB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAiBnE;AAED;;GAEG;AACH,wBAAsB,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAY5E;AAED;;GAEG;AACH,wBAAsB,qBAAqB,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAY9E"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
/** Session Hooks - Lifecycle hooks for conversation management
|
|
2
|
+
*
|
|
3
|
+
* Provides functions to be called when sessions start/end
|
|
4
|
+
*/
|
|
5
|
+
import { sql, eq } from 'drizzle-orm';
|
|
6
|
+
import { getDb } from '../../db/index.js';
|
|
7
|
+
import { getSchema } from '../../db/schema.js';
|
|
8
|
+
import { logger } from '../logger.js';
|
|
9
|
+
/**
|
|
10
|
+
* Called when a session ends
|
|
11
|
+
* Marks the conversation as ended so self-iteration can process it
|
|
12
|
+
*/
|
|
13
|
+
export async function onSessionEnd(sessionId) {
|
|
14
|
+
logger.info(`[SessionHooks] Session ended: ${sessionId}`);
|
|
15
|
+
const db = await getDb();
|
|
16
|
+
if (!db) {
|
|
17
|
+
logger.warn('[SessionHooks] Database unavailable, cannot end session');
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const schema = await getSchema();
|
|
21
|
+
// Mark conversation as ended
|
|
22
|
+
await db.update(schema.conversations)
|
|
23
|
+
.set({ endedAt: new Date() })
|
|
24
|
+
.where(eq(schema.conversations.sessionId, sessionId));
|
|
25
|
+
logger.info(`[SessionHooks] Session ${sessionId} marked as ended`);
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Get active sessions for a project
|
|
29
|
+
*/
|
|
30
|
+
export async function getActiveSessions(projectId) {
|
|
31
|
+
const db = await getDb();
|
|
32
|
+
if (!db)
|
|
33
|
+
return [];
|
|
34
|
+
const schema = await getSchema();
|
|
35
|
+
const sessions = await db.select()
|
|
36
|
+
.from(schema.conversations)
|
|
37
|
+
.where(eq(schema.conversations.projectId, projectId))
|
|
38
|
+
.where(sql `${schema.conversations.endedAt} IS NULL`);
|
|
39
|
+
return sessions.map((s) => s.session_id);
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* End all sessions for a project
|
|
43
|
+
*/
|
|
44
|
+
export async function endAllProjectSessions(projectId) {
|
|
45
|
+
const db = await getDb();
|
|
46
|
+
if (!db)
|
|
47
|
+
return 0;
|
|
48
|
+
const schema = await getSchema();
|
|
49
|
+
const result = await db.update(schema.conversations)
|
|
50
|
+
.set({ endedAt: new Date() })
|
|
51
|
+
.where(eq(schema.conversations.projectId, projectId));
|
|
52
|
+
logger.info(`[SessionHooks] Ended ${result.rowCount} sessions for project ${projectId}`);
|
|
53
|
+
return result.rowCount || 0;
|
|
54
|
+
}
|
|
55
|
+
//# sourceMappingURL=session-hooks.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"session-hooks.js","sourceRoot":"","sources":["../../../core/session-hooks/session-hooks.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAEtC;;;GAGG;AACH,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,SAAiB;IAClD,MAAM,CAAC,IAAI,CAAC,iCAAiC,SAAS,EAAE,CAAC,CAAC;IAE1D,MAAM,EAAE,GAAG,MAAM,KAAK,EAAE,CAAC;IACzB,IAAI,CAAC,EAAE,EAAE,CAAC;QACR,MAAM,CAAC,IAAI,CAAC,yDAAyD,CAAC,CAAC;QACvE,OAAO;IACT,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;IAEjC,6BAA6B;IAC7B,MAAM,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC;SAClC,GAAG,CAAC,EAAE,OAAO,EAAE,IAAI,IAAI,EAAE,EAAE,CAAC;SAC5B,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC;IAExD,MAAM,CAAC,IAAI,CAAC,0BAA0B,SAAS,kBAAkB,CAAC,CAAC;AACrE,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,iBAAiB,CAAC,SAAiB;IACvD,MAAM,EAAE,GAAG,MAAM,KAAK,EAAE,CAAC;IACzB,IAAI,CAAC,EAAE;QAAE,OAAO,EAAE,CAAC;IAEnB,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;IAEjC,MAAM,QAAQ,GAAG,MAAM,EAAE,CAAC,MAAM,EAAE;SAC/B,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC;SAC1B,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;SACpD,KAAK,CAAC,GAAG,CAAA,GAAG,MAAM,CAAC,aAAa,CAAC,OAAO,UAAU,CAAC,CAAC;IAEvD,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;AAChD,CAAC;AAED;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAC,SAAiB;IAC3D,MAAM,EAAE,GAAG,MAAM,KAAK,EAAE,CAAC;IACzB,IAAI,CAAC,EAAE;QAAE,OAAO,CAAC,CAAC;IAElB,MAAM,MAAM,GAAG,MAAM,SAAS,EAAE,CAAC;IAEjC,MAAM,MAAM,GAAG,MAAM,EAAE,CAAC,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC;SACjD,GAAG,CAAC,EAAE,OAAO,EAAE,IAAI,IAAI,EAAE,EAAE,CAAC;SAC5B,KAAK,CAAC,EAAE,CAAC,MAAM,CAAC,aAAa,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC;IAExD,MAAM,CAAC,IAAI,CAAC,wBAAwB,MAAM,CAAC,QAAQ,yBAAyB,SAAS,EAAE,CAAC,CAAC;IACzF,OAAO,MAAM,CAAC,QAAQ,IAAI,CAAC,CAAC;AAC9B,CAAC"}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/** Trace Collector - Collects search pipeline traces for debugging and performance analysis
|
|
2
|
+
*
|
|
3
|
+
* Trace storage format - All search operations are logged with timing information
|
|
4
|
+
* Trace retrieval - Get traces by session or ID
|
|
5
|
+
*/
|
|
6
|
+
export interface SearchTrace {
|
|
7
|
+
id: string;
|
|
8
|
+
sessionId: string | null;
|
|
9
|
+
query: string;
|
|
10
|
+
timestamp: Date;
|
|
11
|
+
totalDurationMs: number;
|
|
12
|
+
metadata: Record<string, unknown>;
|
|
13
|
+
queryRewrite?: QueryRewriteStage;
|
|
14
|
+
candidateRetrieval?: RetrievalStage;
|
|
15
|
+
entityFiltering?: RetrievalStage;
|
|
16
|
+
hybridScoring?: ScoringStage;
|
|
17
|
+
reranking?: RerankingStage;
|
|
18
|
+
resultCount?: number;
|
|
19
|
+
topResults?: TopResult[];
|
|
20
|
+
}
|
|
21
|
+
export interface QueryRewriteStage {
|
|
22
|
+
original?: string;
|
|
23
|
+
rewritten?: string;
|
|
24
|
+
method?: string;
|
|
25
|
+
timeMs?: number;
|
|
26
|
+
}
|
|
27
|
+
export interface RetrievalStage {
|
|
28
|
+
candidates?: number;
|
|
29
|
+
results?: number;
|
|
30
|
+
timeMs?: number;
|
|
31
|
+
entities?: string[];
|
|
32
|
+
}
|
|
33
|
+
export interface ScoringStage {
|
|
34
|
+
results?: number;
|
|
35
|
+
timeMs?: number;
|
|
36
|
+
}
|
|
37
|
+
export interface RerankingStage {
|
|
38
|
+
results?: number;
|
|
39
|
+
timeMs?: number;
|
|
40
|
+
}
|
|
41
|
+
export interface TopResult {
|
|
42
|
+
type?: string;
|
|
43
|
+
content?: string;
|
|
44
|
+
hybridScore?: number;
|
|
45
|
+
}
|
|
46
|
+
export interface TraceOptions {
|
|
47
|
+
sessionId?: string;
|
|
48
|
+
limit?: number;
|
|
49
|
+
session?: string;
|
|
50
|
+
}
|
|
51
|
+
export interface TraceStats {
|
|
52
|
+
totalTraces: number;
|
|
53
|
+
totalDurationMs: number;
|
|
54
|
+
avgDurationMs: number;
|
|
55
|
+
recentSessions: number;
|
|
56
|
+
totalErrors: number;
|
|
57
|
+
errorRate: number;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Start a new search trace collection
|
|
61
|
+
*/
|
|
62
|
+
export declare function startTrace(sessionId: string, query: string): Promise<string>;
|
|
63
|
+
/**
|
|
64
|
+
* Add query rewrite stage data
|
|
65
|
+
*/
|
|
66
|
+
export declare function addQueryRewriteStage(traceId: string, stage: QueryRewriteStage): Promise<void>;
|
|
67
|
+
/**
|
|
68
|
+
* Add candidate retrieval stage data
|
|
69
|
+
*/
|
|
70
|
+
export declare function addCandidateRetrievalStage(traceId: string, stage: RetrievalStage): Promise<void>;
|
|
71
|
+
/**
|
|
72
|
+
* Add entity filtering stage data
|
|
73
|
+
*/
|
|
74
|
+
export declare function addEntityFilteringStage(traceId: string, stage: RetrievalStage): Promise<void>;
|
|
75
|
+
/**
|
|
76
|
+
* Add hybrid scoring stage data
|
|
77
|
+
*/
|
|
78
|
+
export declare function addHybridScoringStage(traceId: string, stage: ScoringStage): Promise<void>;
|
|
79
|
+
/**
|
|
80
|
+
* Add reranking stage data
|
|
81
|
+
*/
|
|
82
|
+
export declare function addRerankingStage(traceId: string, stage: RerankingStage): Promise<void>;
|
|
83
|
+
/**
|
|
84
|
+
* Complete current trace (all stages done)
|
|
85
|
+
*/
|
|
86
|
+
export declare function completeTrace(traceId: string, results: TopResult[]): Promise<void>;
|
|
87
|
+
/**
|
|
88
|
+
* Get traces for a session
|
|
89
|
+
*/
|
|
90
|
+
export declare function getTraces(options?: TraceOptions): Promise<SearchTrace[]>;
|
|
91
|
+
/**
|
|
92
|
+
* Get a specific trace by ID
|
|
93
|
+
*/
|
|
94
|
+
export declare function getTraceById(traceId: string): Promise<SearchTrace | null>;
|
|
95
|
+
/**
|
|
96
|
+
* Get recent traces (limited)
|
|
97
|
+
*/
|
|
98
|
+
export declare function getRecentTraces(limit?: number): Promise<SearchTrace[]>;
|
|
99
|
+
/**
|
|
100
|
+
* Get recent session summary traces (aggregated by session)
|
|
101
|
+
*/
|
|
102
|
+
export declare function getSessionTraces(sessionId: string): Promise<SearchTrace[]>;
|
|
103
|
+
/**
|
|
104
|
+
* Create visual ASCII visualization of a trace
|
|
105
|
+
*/
|
|
106
|
+
export declare function visualizeTrace(trace: SearchTrace): string;
|
|
107
|
+
/**
|
|
108
|
+
* Get trace statistics (performance metrics)
|
|
109
|
+
*/
|
|
110
|
+
export declare function getTraceStats(): Promise<TraceStats>;
|
|
111
|
+
//# sourceMappingURL=collector.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"collector.d.ts","sourceRoot":"","sources":["../../../core/tracing/collector.ts"],"names":[],"mappings":"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"}
|