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.
Files changed (192) hide show
  1. package/CHANGELOG.md +68 -0
  2. package/README.md +58 -2
  3. package/config/plugin-manifest.json +152 -0
  4. package/config/plugin-manifest.schema.json +244 -0
  5. package/dist/algorithms/{merge/analytics → analytics}/token-estimator.d.ts +1 -1
  6. package/dist/algorithms/analytics/token-estimator.d.ts.map +1 -0
  7. package/dist/algorithms/{merge/analytics → analytics}/token-estimator.js +3 -3
  8. package/dist/algorithms/analytics/token-estimator.js.map +1 -0
  9. package/dist/algorithms/detection/hash-filters.d.ts.map +1 -0
  10. package/dist/algorithms/detection/hash-filters.js.map +1 -0
  11. package/dist/algorithms/{merge/detection → detection}/semantic-ranker.d.ts +1 -1
  12. package/dist/algorithms/detection/semantic-ranker.d.ts.map +1 -0
  13. package/dist/algorithms/{merge/detection → detection}/semantic-ranker.js +1 -1
  14. package/dist/algorithms/detection/semantic-ranker.js.map +1 -0
  15. package/dist/algorithms/{merge/detection → detection}/two-stage-detector.d.ts +1 -1
  16. package/dist/algorithms/detection/two-stage-detector.d.ts.map +1 -0
  17. package/dist/algorithms/{merge/detection → detection}/two-stage-detector.js +4 -4
  18. package/dist/algorithms/detection/two-stage-detector.js.map +1 -0
  19. package/dist/algorithms/handlers/approve-merge.d.ts.map +1 -0
  20. package/dist/algorithms/{merge/handlers → handlers}/approve-merge.js +4 -4
  21. package/dist/algorithms/handlers/approve-merge.js.map +1 -0
  22. package/dist/algorithms/{merge/handlers → handlers}/detect-duplicates.d.ts +1 -1
  23. package/dist/algorithms/handlers/detect-duplicates.d.ts.map +1 -0
  24. package/dist/algorithms/{merge/handlers → handlers}/detect-duplicates.js +55 -75
  25. package/dist/algorithms/handlers/detect-duplicates.js.map +1 -0
  26. package/dist/algorithms/handlers/get-stats.d.ts.map +1 -0
  27. package/dist/algorithms/{merge/handlers → handlers}/get-stats.js +3 -3
  28. package/dist/algorithms/handlers/get-stats.js.map +1 -0
  29. package/dist/algorithms/handlers/list-proposals.d.ts.map +1 -0
  30. package/dist/algorithms/{merge/handlers → handlers}/list-proposals.js +3 -3
  31. package/dist/algorithms/handlers/list-proposals.js.map +1 -0
  32. package/dist/algorithms/handlers/preview-merge.d.ts.map +1 -0
  33. package/dist/algorithms/{merge/handlers → handlers}/preview-merge.js +3 -3
  34. package/dist/algorithms/handlers/preview-merge.js.map +1 -0
  35. package/dist/algorithms/handlers/reject-merge.d.ts.map +1 -0
  36. package/dist/algorithms/{merge/handlers → handlers}/reject-merge.js +3 -3
  37. package/dist/algorithms/handlers/reject-merge.js.map +1 -0
  38. package/dist/algorithms/handlers/reverse-merge.d.ts.map +1 -0
  39. package/dist/algorithms/{merge/handlers → handlers}/reverse-merge.js +3 -3
  40. package/dist/algorithms/handlers/reverse-merge.js.map +1 -0
  41. package/dist/algorithms/{merge/safety → safety}/safety-checks.d.ts +1 -1
  42. package/dist/algorithms/safety/safety-checks.d.ts.map +1 -0
  43. package/dist/algorithms/safety/safety-checks.js +179 -0
  44. package/dist/algorithms/safety/safety-checks.js.map +1 -0
  45. package/dist/algorithms/{merge/strategies → strategies}/merge-strategies.d.ts +1 -1
  46. package/dist/algorithms/strategies/merge-strategies.d.ts.map +1 -0
  47. package/dist/algorithms/strategies/merge-strategies.js.map +1 -0
  48. package/dist/algorithms/utils/response-builder.d.ts +28 -0
  49. package/dist/algorithms/utils/response-builder.d.ts.map +1 -0
  50. package/dist/algorithms/utils/response-builder.js +37 -0
  51. package/dist/algorithms/utils/response-builder.js.map +1 -0
  52. package/dist/api/web/web.d.ts.map +1 -1
  53. package/dist/api/web/web.js +0 -21
  54. package/dist/api/web/web.js.map +1 -1
  55. package/dist/commands/mcp-server.js +1 -1
  56. package/dist/config.d.ts +1 -1
  57. package/dist/config.d.ts.map +1 -1
  58. package/dist/config.js +30 -38
  59. package/dist/config.js.map +1 -1
  60. package/dist/core/associations.js +2 -2
  61. package/dist/core/associations.js.map +1 -1
  62. package/dist/core/layers/generator.d.ts +25 -0
  63. package/dist/core/layers/generator.d.ts.map +1 -0
  64. package/dist/core/layers/generator.js +76 -0
  65. package/dist/core/layers/generator.js.map +1 -0
  66. package/dist/core/mcp/tools.d.ts.map +1 -1
  67. package/dist/core/mcp/tools.js +71 -0
  68. package/dist/core/mcp/tools.js.map +1 -1
  69. package/dist/core/memory/hybrid-retrieval.d.ts.map +1 -1
  70. package/dist/core/memory/hybrid-retrieval.js +49 -1
  71. package/dist/core/memory/hybrid-retrieval.js.map +1 -1
  72. package/dist/core/memory/hybrid-search.d.ts.map +1 -1
  73. package/dist/core/memory/hybrid-search.js +0 -7
  74. package/dist/core/memory/hybrid-search.js.map +1 -1
  75. package/dist/core/memory/memories.d.ts.map +1 -1
  76. package/dist/core/memory/memories.js +47 -53
  77. package/dist/core/memory/memories.js.map +1 -1
  78. package/dist/core/memory/progressive-disclosure.d.ts.map +1 -1
  79. package/dist/core/memory/progressive-disclosure.js.map +1 -1
  80. package/dist/core/namespaces/index.d.ts +71 -0
  81. package/dist/core/namespaces/index.d.ts.map +1 -0
  82. package/dist/core/namespaces/index.js +296 -0
  83. package/dist/core/namespaces/index.js.map +1 -0
  84. package/dist/core/namespaces/uri-parser.d.ts +31 -0
  85. package/dist/core/namespaces/uri-parser.d.ts.map +1 -0
  86. package/dist/core/namespaces/uri-parser.js +74 -0
  87. package/dist/core/namespaces/uri-parser.js.map +1 -0
  88. package/dist/core/observations.d.ts.map +1 -1
  89. package/dist/core/observations.js +3 -12
  90. package/dist/core/observations.js.map +1 -1
  91. package/dist/core/projects.d.ts.map +1 -1
  92. package/dist/core/projects.js +0 -12
  93. package/dist/core/projects.js.map +1 -1
  94. package/dist/core/scheduler/cron-scheduler.d.ts.map +1 -1
  95. package/dist/core/scheduler/cron-scheduler.js +14 -0
  96. package/dist/core/scheduler/cron-scheduler.js.map +1 -1
  97. package/dist/core/session-hooks/self-iteration-job.d.ts +20 -0
  98. package/dist/core/session-hooks/self-iteration-job.d.ts.map +1 -0
  99. package/dist/core/session-hooks/self-iteration-job.js +278 -0
  100. package/dist/core/session-hooks/self-iteration-job.js.map +1 -0
  101. package/dist/core/session-hooks/session-hooks.d.ts +18 -0
  102. package/dist/core/session-hooks/session-hooks.d.ts.map +1 -0
  103. package/dist/core/session-hooks/session-hooks.js +55 -0
  104. package/dist/core/session-hooks/session-hooks.js.map +1 -0
  105. package/dist/core/tracing/collector.d.ts +111 -0
  106. package/dist/core/tracing/collector.d.ts.map +1 -0
  107. package/dist/core/tracing/collector.js +338 -0
  108. package/dist/core/tracing/collector.js.map +1 -0
  109. package/dist/core/tracing/visualizer.d.ts +32 -0
  110. package/dist/core/tracing/visualizer.d.ts.map +1 -0
  111. package/dist/core/tracing/visualizer.js +165 -0
  112. package/dist/core/tracing/visualizer.js.map +1 -0
  113. package/dist/drizzle/schema-sqlite.d.ts +384 -0
  114. package/dist/drizzle/schema-sqlite.d.ts.map +1 -1
  115. package/dist/drizzle/schema-sqlite.js +65 -0
  116. package/dist/drizzle/schema-sqlite.js.map +1 -1
  117. package/dist/drizzle/schema.d.ts +368 -0
  118. package/dist/drizzle/schema.d.ts.map +1 -1
  119. package/dist/drizzle/schema.js +63 -0
  120. package/dist/drizzle/schema.js.map +1 -1
  121. package/dist/index.d.ts +4 -4
  122. package/dist/index.js +101 -62
  123. package/dist/index.js.map +1 -1
  124. package/generated/mcp/manifest.json +23 -0
  125. package/generated/mcp/mcp-servers.json +25 -0
  126. package/generated/mcp/mcporter.json +34 -0
  127. package/generated/mcp/openclaw-memory-qmd.json +17 -0
  128. package/generated/mcp/runtime.json +12 -0
  129. package/package.json +50 -9
  130. package/packages/plugin-claude-code/README.md +73 -0
  131. package/packages/plugin-claude-code/dist/plugin-wrapper.d.ts +35 -0
  132. package/packages/plugin-claude-code/dist/plugin-wrapper.d.ts.map +1 -0
  133. package/packages/plugin-claude-code/dist/plugin-wrapper.js +191 -0
  134. package/packages/plugin-claude-code/dist/plugin-wrapper.js.map +1 -0
  135. package/packages/plugin-claude-code/package.json +31 -0
  136. package/packages/plugin-openclaw/README.md +70 -0
  137. package/packages/plugin-openclaw/dist/index.d.ts +49 -0
  138. package/packages/plugin-openclaw/dist/index.d.ts.map +1 -0
  139. package/packages/plugin-openclaw/dist/index.js +262 -0
  140. package/packages/plugin-openclaw/dist/index.js.map +1 -0
  141. package/packages/plugin-openclaw/openclaw.plugin.json +94 -0
  142. package/packages/plugin-openclaw/package.json +31 -0
  143. package/packages/plugin-opencode/install.mjs +217 -0
  144. package/packages/plugin-opencode/package.json +21 -0
  145. package/scripts/dependency-manager.mjs +217 -0
  146. package/scripts/detect-clients.mjs +78 -0
  147. package/scripts/install-interactive.mjs +674 -0
  148. package/scripts/install-plugin.mjs +415 -0
  149. package/scripts/test-interactive.mjs +131 -0
  150. package/commands/managed-sync.ts +0 -69
  151. package/commands/mcp-server.ts +0 -519
  152. package/dist/algorithms/merge/analytics/token-estimator.d.ts.map +0 -1
  153. package/dist/algorithms/merge/analytics/token-estimator.js.map +0 -1
  154. package/dist/algorithms/merge/detection/hash-filters.d.ts.map +0 -1
  155. package/dist/algorithms/merge/detection/hash-filters.js.map +0 -1
  156. package/dist/algorithms/merge/detection/semantic-ranker.d.ts.map +0 -1
  157. package/dist/algorithms/merge/detection/semantic-ranker.js.map +0 -1
  158. package/dist/algorithms/merge/detection/two-stage-detector.d.ts.map +0 -1
  159. package/dist/algorithms/merge/detection/two-stage-detector.js.map +0 -1
  160. package/dist/algorithms/merge/handlers/approve-merge.d.ts.map +0 -1
  161. package/dist/algorithms/merge/handlers/approve-merge.js.map +0 -1
  162. package/dist/algorithms/merge/handlers/detect-duplicates.d.ts.map +0 -1
  163. package/dist/algorithms/merge/handlers/detect-duplicates.js.map +0 -1
  164. package/dist/algorithms/merge/handlers/get-stats.d.ts.map +0 -1
  165. package/dist/algorithms/merge/handlers/get-stats.js.map +0 -1
  166. package/dist/algorithms/merge/handlers/list-proposals.d.ts.map +0 -1
  167. package/dist/algorithms/merge/handlers/list-proposals.js.map +0 -1
  168. package/dist/algorithms/merge/handlers/preview-merge.d.ts.map +0 -1
  169. package/dist/algorithms/merge/handlers/preview-merge.js.map +0 -1
  170. package/dist/algorithms/merge/handlers/reject-merge.d.ts.map +0 -1
  171. package/dist/algorithms/merge/handlers/reject-merge.js.map +0 -1
  172. package/dist/algorithms/merge/handlers/reverse-merge.d.ts.map +0 -1
  173. package/dist/algorithms/merge/handlers/reverse-merge.js.map +0 -1
  174. package/dist/algorithms/merge/safety/safety-checks.d.ts.map +0 -1
  175. package/dist/algorithms/merge/safety/safety-checks.js +0 -215
  176. package/dist/algorithms/merge/safety/safety-checks.js.map +0 -1
  177. package/dist/algorithms/merge/strategies/merge-strategies.d.ts.map +0 -1
  178. package/dist/algorithms/merge/strategies/merge-strategies.js.map +0 -1
  179. package/dist/core/embeddings/qmd-provider.d.ts +0 -65
  180. package/dist/core/embeddings/qmd-provider.d.ts.map +0 -1
  181. package/dist/core/embeddings/qmd-provider.js +0 -133
  182. package/dist/core/embeddings/qmd-provider.js.map +0 -1
  183. package/scripts/init-dirs.ts +0 -15
  184. /package/dist/algorithms/{merge/detection → detection}/hash-filters.d.ts +0 -0
  185. /package/dist/algorithms/{merge/detection → detection}/hash-filters.js +0 -0
  186. /package/dist/algorithms/{merge/handlers → handlers}/approve-merge.d.ts +0 -0
  187. /package/dist/algorithms/{merge/handlers → handlers}/get-stats.d.ts +0 -0
  188. /package/dist/algorithms/{merge/handlers → handlers}/list-proposals.d.ts +0 -0
  189. /package/dist/algorithms/{merge/handlers → handlers}/preview-merge.d.ts +0 -0
  190. /package/dist/algorithms/{merge/handlers → handlers}/reject-merge.d.ts +0 -0
  191. /package/dist/algorithms/{merge/handlers → handlers}/reverse-merge.d.ts +0 -0
  192. /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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"}