@stackmemoryai/stackmemory 0.2.8 → 0.2.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/src/core/context/compaction-handler.d.ts.map +1 -1
- package/dist/src/core/context/compaction-handler.js +1 -1
- package/dist/src/core/context/compaction-handler.js.map +1 -1
- package/dist/src/core/digest/hybrid-digest-generator.d.ts +76 -0
- package/dist/src/core/digest/hybrid-digest-generator.d.ts.map +1 -0
- package/dist/src/core/digest/hybrid-digest-generator.js +629 -0
- package/dist/src/core/digest/hybrid-digest-generator.js.map +1 -0
- package/dist/src/core/digest/index.d.ts +7 -0
- package/dist/src/core/digest/index.d.ts.map +1 -0
- package/dist/src/core/digest/index.js +7 -0
- package/dist/src/core/digest/index.js.map +1 -0
- package/dist/src/core/digest/types.d.ts +154 -0
- package/dist/src/core/digest/types.d.ts.map +1 -0
- package/dist/src/core/digest/types.js +18 -0
- package/dist/src/core/digest/types.js.map +1 -0
- package/dist/src/core/monitoring/logger.d.ts +2 -2
- package/dist/src/core/monitoring/logger.d.ts.map +1 -1
- package/dist/src/core/monitoring/logger.js +10 -5
- package/dist/src/core/monitoring/logger.js.map +1 -1
- package/dist/src/core/monitoring/metrics.d.ts +3 -0
- package/dist/src/core/monitoring/metrics.d.ts.map +1 -1
- package/dist/src/core/monitoring/metrics.js +142 -3
- package/dist/src/core/monitoring/metrics.js.map +1 -1
- package/dist/src/core/persistence/postgres-adapter.d.ts +31 -0
- package/dist/src/core/persistence/postgres-adapter.d.ts.map +1 -0
- package/dist/src/core/persistence/postgres-adapter.js +316 -0
- package/dist/src/core/persistence/postgres-adapter.js.map +1 -0
- package/dist/src/core/trace/trace-detector.demo.js +5 -5
- package/dist/src/core/trace/trace-detector.demo.js.map +1 -1
- package/dist/src/core/types.d.ts +35 -0
- package/dist/src/core/types.d.ts.map +1 -0
- package/dist/src/core/types.js +2 -0
- package/dist/src/core/types.js.map +1 -0
- package/dist/src/integrations/mcp/server.js +2 -2
- package/dist/src/integrations/mcp/server.js.map +1 -1
- package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts +48 -0
- package/dist/src/integrations/pg-aiguide/embedding-provider.d.ts.map +1 -0
- package/dist/src/integrations/pg-aiguide/embedding-provider.js +190 -0
- package/dist/src/integrations/pg-aiguide/embedding-provider.js.map +1 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts +34 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.d.ts.map +1 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.js +154 -0
- package/dist/src/integrations/pg-aiguide/semantic-search.js.map +1 -0
- package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts +44 -0
- package/dist/src/integrations/pg-aiguide/timescale-analytics.d.ts.map +1 -0
- package/dist/src/integrations/pg-aiguide/timescale-analytics.js +215 -0
- package/dist/src/integrations/pg-aiguide/timescale-analytics.js.map +1 -0
- package/dist/src/models/user.model.d.ts +55 -0
- package/dist/src/models/user.model.d.ts.map +1 -0
- package/dist/src/models/user.model.js +263 -0
- package/dist/src/models/user.model.js.map +1 -0
- package/dist/src/servers/production/auth-middleware.d.ts +7 -0
- package/dist/src/servers/production/auth-middleware.d.ts.map +1 -1
- package/dist/src/servers/production/auth-middleware.js +201 -26
- package/dist/src/servers/production/auth-middleware.js.map +1 -1
- package/dist/src/servers/railway/index.js.map +1 -1
- package/package.json +6 -1
|
@@ -0,0 +1,316 @@
|
|
|
1
|
+
import { Pool } from 'pg';
|
|
2
|
+
import { logger } from '../monitoring/logger.js';
|
|
3
|
+
export class PostgresAdapter {
|
|
4
|
+
pool;
|
|
5
|
+
config;
|
|
6
|
+
isInitialized = false;
|
|
7
|
+
constructor(config) {
|
|
8
|
+
this.config = {
|
|
9
|
+
...config,
|
|
10
|
+
vectorDimensions: config.vectorDimensions || 1536, // OpenAI ada-002 dimensions
|
|
11
|
+
};
|
|
12
|
+
this.pool = new Pool(this.config);
|
|
13
|
+
}
|
|
14
|
+
async connect() {
|
|
15
|
+
try {
|
|
16
|
+
await this.pool.connect();
|
|
17
|
+
await this.initialize();
|
|
18
|
+
this.isInitialized = true;
|
|
19
|
+
logger.info('PostgreSQL connected successfully');
|
|
20
|
+
}
|
|
21
|
+
catch (error) {
|
|
22
|
+
logger.error('Failed to connect to PostgreSQL', error instanceof Error ? error : undefined);
|
|
23
|
+
throw error;
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
async disconnect() {
|
|
27
|
+
await this.pool.end();
|
|
28
|
+
this.isInitialized = false;
|
|
29
|
+
logger.info('PostgreSQL disconnected');
|
|
30
|
+
}
|
|
31
|
+
async execute(query, params) {
|
|
32
|
+
try {
|
|
33
|
+
const result = await this.pool.query(query, params);
|
|
34
|
+
return {
|
|
35
|
+
rows: result.rows,
|
|
36
|
+
rowCount: result.rowCount || 0,
|
|
37
|
+
fields: result.fields?.map((f) => ({
|
|
38
|
+
name: f.name,
|
|
39
|
+
type: f.dataTypeID.toString(),
|
|
40
|
+
})),
|
|
41
|
+
};
|
|
42
|
+
}
|
|
43
|
+
catch (error) {
|
|
44
|
+
logger.error('Query execution failed', error instanceof Error ? error : new Error(String(error)), { query });
|
|
45
|
+
throw error;
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
async beginTransaction() {
|
|
49
|
+
await this.execute('BEGIN');
|
|
50
|
+
}
|
|
51
|
+
async commit() {
|
|
52
|
+
await this.execute('COMMIT');
|
|
53
|
+
}
|
|
54
|
+
async rollback() {
|
|
55
|
+
await this.execute('ROLLBACK');
|
|
56
|
+
}
|
|
57
|
+
isConnected() {
|
|
58
|
+
return this.isInitialized;
|
|
59
|
+
}
|
|
60
|
+
async initialize() {
|
|
61
|
+
// Create base schema
|
|
62
|
+
await this.createBaseSchema();
|
|
63
|
+
// Enable extensions if configured
|
|
64
|
+
if (this.config.enableTimescale) {
|
|
65
|
+
await this.enableTimescale();
|
|
66
|
+
}
|
|
67
|
+
if (this.config.enablePgvector) {
|
|
68
|
+
await this.enablePgvector();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
async createBaseSchema() {
|
|
72
|
+
const queries = [
|
|
73
|
+
// Projects table
|
|
74
|
+
`CREATE TABLE IF NOT EXISTS projects (
|
|
75
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
76
|
+
name VARCHAR(255) NOT NULL,
|
|
77
|
+
path TEXT NOT NULL,
|
|
78
|
+
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
79
|
+
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
80
|
+
metadata JSONB
|
|
81
|
+
)`,
|
|
82
|
+
// Sessions table
|
|
83
|
+
`CREATE TABLE IF NOT EXISTS sessions (
|
|
84
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
85
|
+
project_id UUID REFERENCES projects(id) ON DELETE CASCADE,
|
|
86
|
+
branch VARCHAR(255),
|
|
87
|
+
started_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
88
|
+
ended_at TIMESTAMP,
|
|
89
|
+
metadata JSONB
|
|
90
|
+
)`,
|
|
91
|
+
// Traces table
|
|
92
|
+
`CREATE TABLE IF NOT EXISTS traces (
|
|
93
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
94
|
+
session_id UUID REFERENCES sessions(id) ON DELETE CASCADE,
|
|
95
|
+
timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
96
|
+
type VARCHAR(100) NOT NULL,
|
|
97
|
+
data JSONB NOT NULL,
|
|
98
|
+
metadata JSONB,
|
|
99
|
+
INDEX idx_traces_session_timestamp (session_id, timestamp)
|
|
100
|
+
)`,
|
|
101
|
+
// Context frames table
|
|
102
|
+
`CREATE TABLE IF NOT EXISTS context_frames (
|
|
103
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
104
|
+
project_id UUID REFERENCES projects(id) ON DELETE CASCADE,
|
|
105
|
+
branch VARCHAR(255),
|
|
106
|
+
content TEXT NOT NULL,
|
|
107
|
+
summary TEXT,
|
|
108
|
+
timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
109
|
+
type VARCHAR(100) NOT NULL,
|
|
110
|
+
metadata JSONB,
|
|
111
|
+
INDEX idx_context_project_branch (project_id, branch)
|
|
112
|
+
)`,
|
|
113
|
+
// Decisions table
|
|
114
|
+
`CREATE TABLE IF NOT EXISTS decisions (
|
|
115
|
+
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
|
|
116
|
+
project_id UUID REFERENCES projects(id) ON DELETE CASCADE,
|
|
117
|
+
session_id UUID REFERENCES sessions(id) ON DELETE CASCADE,
|
|
118
|
+
decision TEXT NOT NULL,
|
|
119
|
+
rationale TEXT,
|
|
120
|
+
timestamp TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
|
|
121
|
+
metadata JSONB
|
|
122
|
+
)`,
|
|
123
|
+
];
|
|
124
|
+
for (const query of queries) {
|
|
125
|
+
await this.execute(query);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
async enableTimescale() {
|
|
129
|
+
try {
|
|
130
|
+
await this.execute('CREATE EXTENSION IF NOT EXISTS timescaledb');
|
|
131
|
+
// Convert traces to hypertable
|
|
132
|
+
await this.execute(`
|
|
133
|
+
SELECT create_hypertable('traces', 'timestamp',
|
|
134
|
+
if_not_exists => TRUE,
|
|
135
|
+
chunk_time_interval => INTERVAL '1 day'
|
|
136
|
+
)
|
|
137
|
+
`);
|
|
138
|
+
// Convert context_frames to hypertable
|
|
139
|
+
await this.execute(`
|
|
140
|
+
SELECT create_hypertable('context_frames', 'timestamp',
|
|
141
|
+
if_not_exists => TRUE,
|
|
142
|
+
chunk_time_interval => INTERVAL '7 days'
|
|
143
|
+
)
|
|
144
|
+
`);
|
|
145
|
+
logger.info('TimescaleDB extension enabled');
|
|
146
|
+
}
|
|
147
|
+
catch (error) {
|
|
148
|
+
logger.warn('Failed to enable TimescaleDB', error instanceof Error ? error : undefined);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
async enablePgvector() {
|
|
152
|
+
try {
|
|
153
|
+
await this.execute('CREATE EXTENSION IF NOT EXISTS vector');
|
|
154
|
+
// Add embedding columns
|
|
155
|
+
await this.execute(`
|
|
156
|
+
ALTER TABLE context_frames
|
|
157
|
+
ADD COLUMN IF NOT EXISTS embedding vector(${this.config.vectorDimensions})
|
|
158
|
+
`);
|
|
159
|
+
await this.execute(`
|
|
160
|
+
ALTER TABLE traces
|
|
161
|
+
ADD COLUMN IF NOT EXISTS embedding vector(${this.config.vectorDimensions})
|
|
162
|
+
`);
|
|
163
|
+
// Create vector indexes
|
|
164
|
+
await this.execute(`
|
|
165
|
+
CREATE INDEX IF NOT EXISTS idx_context_embedding
|
|
166
|
+
ON context_frames
|
|
167
|
+
USING ivfflat (embedding vector_cosine_ops)
|
|
168
|
+
WITH (lists = 100)
|
|
169
|
+
`);
|
|
170
|
+
logger.info('pgvector extension enabled');
|
|
171
|
+
}
|
|
172
|
+
catch (error) {
|
|
173
|
+
logger.warn('Failed to enable pgvector', error instanceof Error ? error : undefined);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
// Data access methods
|
|
177
|
+
async saveTrace(trace) {
|
|
178
|
+
await this.execute(`INSERT INTO traces (id, session_id, timestamp, type, data, metadata)
|
|
179
|
+
VALUES ($1, $2, $3, $4, $5, $6)`, [
|
|
180
|
+
trace.id,
|
|
181
|
+
trace.sessionId,
|
|
182
|
+
trace.timestamp,
|
|
183
|
+
trace.type,
|
|
184
|
+
JSON.stringify(trace.data),
|
|
185
|
+
trace.metadata ? JSON.stringify(trace.metadata) : null,
|
|
186
|
+
]);
|
|
187
|
+
}
|
|
188
|
+
async saveContext(context) {
|
|
189
|
+
await this.execute(`INSERT INTO context_frames (id, project_id, branch, content, timestamp, type, metadata)
|
|
190
|
+
VALUES ($1, $2, $3, $4, $5, $6, $7)`, [
|
|
191
|
+
context.id,
|
|
192
|
+
context.projectId,
|
|
193
|
+
context.branch || null,
|
|
194
|
+
context.content,
|
|
195
|
+
context.timestamp,
|
|
196
|
+
context.type,
|
|
197
|
+
context.metadata ? JSON.stringify(context.metadata) : null,
|
|
198
|
+
]);
|
|
199
|
+
}
|
|
200
|
+
async getRecentTraces(sessionId, limit = 100) {
|
|
201
|
+
const result = await this.execute(`SELECT * FROM traces
|
|
202
|
+
WHERE session_id = $1
|
|
203
|
+
ORDER BY timestamp DESC
|
|
204
|
+
LIMIT $2`, [sessionId, limit]);
|
|
205
|
+
return result.rows.map((row) => ({
|
|
206
|
+
id: row.id,
|
|
207
|
+
sessionId: row.session_id,
|
|
208
|
+
timestamp: row.timestamp,
|
|
209
|
+
type: row.type,
|
|
210
|
+
data: row.data,
|
|
211
|
+
metadata: row.metadata,
|
|
212
|
+
}));
|
|
213
|
+
}
|
|
214
|
+
async getRecentContext(projectId, branch, limit = 50) {
|
|
215
|
+
const query = branch
|
|
216
|
+
? `SELECT * FROM context_frames
|
|
217
|
+
WHERE project_id = $1 AND branch = $2
|
|
218
|
+
ORDER BY timestamp DESC
|
|
219
|
+
LIMIT $3`
|
|
220
|
+
: `SELECT * FROM context_frames
|
|
221
|
+
WHERE project_id = $1
|
|
222
|
+
ORDER BY timestamp DESC
|
|
223
|
+
LIMIT $2`;
|
|
224
|
+
const params = branch ? [projectId, branch, limit] : [projectId, limit];
|
|
225
|
+
const result = await this.execute(query, params);
|
|
226
|
+
return result.rows.map((row) => ({
|
|
227
|
+
id: row.id,
|
|
228
|
+
projectId: row.project_id,
|
|
229
|
+
branch: row.branch,
|
|
230
|
+
content: row.content,
|
|
231
|
+
timestamp: row.timestamp,
|
|
232
|
+
type: row.type,
|
|
233
|
+
metadata: row.metadata,
|
|
234
|
+
}));
|
|
235
|
+
}
|
|
236
|
+
// Hybrid SQLite/PostgreSQL migration helper
|
|
237
|
+
async migrateFromSQLite(sqliteDb) {
|
|
238
|
+
logger.info('Starting migration from SQLite to PostgreSQL');
|
|
239
|
+
try {
|
|
240
|
+
await this.beginTransaction();
|
|
241
|
+
// Migrate projects
|
|
242
|
+
const projects = sqliteDb
|
|
243
|
+
.prepare('SELECT * FROM projects')
|
|
244
|
+
.all();
|
|
245
|
+
for (const project of projects) {
|
|
246
|
+
await this.execute('INSERT INTO projects (id, name, path, created_at, updated_at, metadata) VALUES ($1, $2, $3, $4, $5, $6)', [
|
|
247
|
+
project.id,
|
|
248
|
+
project.name,
|
|
249
|
+
project.path,
|
|
250
|
+
project.created_at,
|
|
251
|
+
project.updated_at,
|
|
252
|
+
project.metadata,
|
|
253
|
+
]);
|
|
254
|
+
}
|
|
255
|
+
// Migrate sessions
|
|
256
|
+
const sessions = sqliteDb
|
|
257
|
+
.prepare('SELECT * FROM sessions')
|
|
258
|
+
.all();
|
|
259
|
+
for (const session of sessions) {
|
|
260
|
+
await this.execute('INSERT INTO sessions (id, project_id, branch, started_at, ended_at, metadata) VALUES ($1, $2, $3, $4, $5, $6)', [
|
|
261
|
+
session.id,
|
|
262
|
+
session.project_id,
|
|
263
|
+
session.branch,
|
|
264
|
+
session.started_at,
|
|
265
|
+
session.ended_at,
|
|
266
|
+
session.metadata,
|
|
267
|
+
]);
|
|
268
|
+
}
|
|
269
|
+
// Migrate traces in batches
|
|
270
|
+
const traceCount = sqliteDb
|
|
271
|
+
.prepare('SELECT COUNT(*) as count FROM traces')
|
|
272
|
+
.get();
|
|
273
|
+
const batchSize = 1000;
|
|
274
|
+
for (let offset = 0; offset < traceCount.count; offset += batchSize) {
|
|
275
|
+
const traces = sqliteDb
|
|
276
|
+
.prepare('SELECT * FROM traces LIMIT ? OFFSET ?')
|
|
277
|
+
.all(batchSize, offset);
|
|
278
|
+
for (const trace of traces) {
|
|
279
|
+
await this.execute('INSERT INTO traces (id, session_id, timestamp, type, data, metadata) VALUES ($1, $2, $3, $4, $5, $6)', [
|
|
280
|
+
trace.id,
|
|
281
|
+
trace.session_id,
|
|
282
|
+
trace.timestamp,
|
|
283
|
+
trace.type,
|
|
284
|
+
trace.data,
|
|
285
|
+
trace.metadata,
|
|
286
|
+
]);
|
|
287
|
+
}
|
|
288
|
+
logger.info(`Migrated ${offset + traces.length}/${traceCount.count} traces`);
|
|
289
|
+
}
|
|
290
|
+
// Migrate context frames
|
|
291
|
+
const contexts = sqliteDb
|
|
292
|
+
.prepare('SELECT * FROM context_frames')
|
|
293
|
+
.all();
|
|
294
|
+
for (const context of contexts) {
|
|
295
|
+
await this.execute('INSERT INTO context_frames (id, project_id, branch, content, summary, timestamp, type, metadata) VALUES ($1, $2, $3, $4, $5, $6, $7, $8)', [
|
|
296
|
+
context.id,
|
|
297
|
+
context.project_id,
|
|
298
|
+
context.branch,
|
|
299
|
+
context.content,
|
|
300
|
+
context.summary,
|
|
301
|
+
context.timestamp,
|
|
302
|
+
context.type,
|
|
303
|
+
context.metadata,
|
|
304
|
+
]);
|
|
305
|
+
}
|
|
306
|
+
await this.commit();
|
|
307
|
+
logger.info('Migration completed successfully');
|
|
308
|
+
}
|
|
309
|
+
catch (error) {
|
|
310
|
+
await this.rollback();
|
|
311
|
+
logger.error('Migration failed', error instanceof Error ? error : undefined);
|
|
312
|
+
throw error;
|
|
313
|
+
}
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
//# sourceMappingURL=postgres-adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"postgres-adapter.js","sourceRoot":"","sources":["../../../../src/core/persistence/postgres-adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -36,7 +36,7 @@ const searchDrivenTools = [
|
|
|
36
36
|
filesAffected: ['/src/auth/login.ts'],
|
|
37
37
|
},
|
|
38
38
|
];
|
|
39
|
-
searchDrivenTools.forEach(tool => {
|
|
39
|
+
searchDrivenTools.forEach((tool) => {
|
|
40
40
|
detector.addToolCall(tool);
|
|
41
41
|
console.log(` Added: ${tool.tool}`);
|
|
42
42
|
});
|
|
@@ -65,7 +65,7 @@ const errorRecoveryTools = [
|
|
|
65
65
|
result: 'All tests passing',
|
|
66
66
|
},
|
|
67
67
|
];
|
|
68
|
-
errorRecoveryTools.forEach(tool => {
|
|
68
|
+
errorRecoveryTools.forEach((tool) => {
|
|
69
69
|
detector.addToolCall(tool);
|
|
70
70
|
console.log(` Added: ${tool.tool}${tool.error ? ' (with error)' : ''}`);
|
|
71
71
|
});
|
|
@@ -92,7 +92,7 @@ const featureTools = [
|
|
|
92
92
|
arguments: { file: 'Dashboard.test.tsx' },
|
|
93
93
|
},
|
|
94
94
|
];
|
|
95
|
-
featureTools.forEach(tool => {
|
|
95
|
+
featureTools.forEach((tool) => {
|
|
96
96
|
detector.addToolCall(tool);
|
|
97
97
|
console.log(` Added: ${tool.tool}`);
|
|
98
98
|
});
|
|
@@ -118,7 +118,7 @@ traces.forEach((trace, index) => {
|
|
|
118
118
|
console.log(`\nTrace ${index + 1}:`);
|
|
119
119
|
console.log(` Type: ${trace.type}`);
|
|
120
120
|
console.log(` Score: ${trace.score.toFixed(2)}`);
|
|
121
|
-
console.log(` Tools: ${trace.tools.map(t => t.tool).join(' → ')}`);
|
|
121
|
+
console.log(` Tools: ${trace.tools.map((t) => t.tool).join(' → ')}`);
|
|
122
122
|
console.log(` Summary: ${trace.summary}`);
|
|
123
123
|
console.log(` Duration: ${((trace.metadata.endTime - trace.metadata.startTime) / 1000).toFixed(1)}s`);
|
|
124
124
|
if (trace.metadata.filesModified.length > 0) {
|
|
@@ -134,7 +134,7 @@ traces.forEach((trace, index) => {
|
|
|
134
134
|
// Test high-importance trace filtering
|
|
135
135
|
console.log('\n⭐ High Importance Traces (score > 0.3):');
|
|
136
136
|
const highImportance = detector.getHighImportanceTraces(0.3);
|
|
137
|
-
highImportance.forEach(trace => {
|
|
137
|
+
highImportance.forEach((trace) => {
|
|
138
138
|
console.log(` [${trace.type}] Score: ${trace.score.toFixed(2)} - ${trace.summary}`);
|
|
139
139
|
});
|
|
140
140
|
// Export traces as JSON
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"trace-detector.demo.js","sourceRoot":"","sources":["../../../../src/core/trace/trace-detector.demo.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,OAAO,EAAE,EAAE,IAAI,MAAM,EAAE,MAAM,MAAM,CAAC;AAEpC,8BAA8B;AAC9B,MAAM,QAAQ,GAAG,IAAI,aAAa,EAAE,CAAC;AAErC,OAAO,CAAC,GAAG,CAAC,2BAA2B,CAAC,CAAC;AACzC,OAAO,CAAC,GAAG,CAAC,GAAG,
|
|
1
|
+
{"version":3,"file":"trace-detector.demo.js","sourceRoot":"","sources":["../../../../src/core/trace/trace-detector.demo.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
export interface PersistenceAdapter {
|
|
2
|
+
connect(): Promise<void>;
|
|
3
|
+
disconnect(): Promise<void>;
|
|
4
|
+
execute(query: string, params?: any[]): Promise<QueryResult>;
|
|
5
|
+
beginTransaction(): Promise<void>;
|
|
6
|
+
commit(): Promise<void>;
|
|
7
|
+
rollback(): Promise<void>;
|
|
8
|
+
isConnected(): boolean;
|
|
9
|
+
}
|
|
10
|
+
export interface QueryResult {
|
|
11
|
+
rows: any[];
|
|
12
|
+
rowCount: number;
|
|
13
|
+
fields?: Array<{
|
|
14
|
+
name: string;
|
|
15
|
+
type: string;
|
|
16
|
+
}>;
|
|
17
|
+
}
|
|
18
|
+
export interface TraceData {
|
|
19
|
+
id: string;
|
|
20
|
+
sessionId: string;
|
|
21
|
+
timestamp: Date;
|
|
22
|
+
type: string;
|
|
23
|
+
data: any;
|
|
24
|
+
metadata?: Record<string, any>;
|
|
25
|
+
}
|
|
26
|
+
export interface ContextData {
|
|
27
|
+
id: string;
|
|
28
|
+
projectId: string;
|
|
29
|
+
branch?: string;
|
|
30
|
+
content: string;
|
|
31
|
+
timestamp: Date;
|
|
32
|
+
type: string;
|
|
33
|
+
metadata?: Record<string, any>;
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/core/types.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,kBAAkB;IACjC,OAAO,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACzB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,CAAC,EAAE,GAAG,EAAE,GAAG,OAAO,CAAC,WAAW,CAAC,CAAC;IAC7D,gBAAgB,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAClC,MAAM,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IACxB,QAAQ,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAC1B,WAAW,IAAI,OAAO,CAAC;CACxB;AAED,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,GAAG,EAAE,CAAC;IACZ,QAAQ,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE,KAAK,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;KACd,CAAC,CAAC;CACJ;AAED,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,SAAS,EAAE,IAAI,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,GAAG,CAAC;IACV,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC;AAED,MAAM,WAAW,WAAW;IAC1B,EAAE,EAAE,MAAM,CAAC;IACX,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,OAAO,EAAE,MAAM,CAAC;IAChB,SAAS,EAAE,IAAI,CAAC;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAChC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/core/types.ts"],"names":[],"mappings":""}
|
|
@@ -718,8 +718,8 @@ class LocalStackMemoryMCP {
|
|
|
718
718
|
}
|
|
719
719
|
}
|
|
720
720
|
catch (err) {
|
|
721
|
-
error = err;
|
|
722
|
-
toolCall.error =
|
|
721
|
+
error = err instanceof Error ? err : new Error(String(err));
|
|
722
|
+
toolCall.error = error.message;
|
|
723
723
|
throw err;
|
|
724
724
|
}
|
|
725
725
|
finally {
|