opcode-pg-memory 2.3.2 → 2.3.3
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/hooks/session-created.d.ts +1 -1
- package/dist/src/hooks/session-created.js +5 -5
- package/dist/src/services/opencode-schema-adapter.d.ts +4 -0
- package/dist/src/services/opencode-schema-adapter.d.ts.map +1 -1
- package/dist/src/services/opencode-schema-adapter.js +52 -24
- package/dist/src/services/opencode-schema-adapter.js.map +1 -1
- package/package.json +11 -10
|
@@ -15,7 +15,7 @@ const DEFAULT_CONFIG = {
|
|
|
15
15
|
* 处理 session.created 事件
|
|
16
16
|
*
|
|
17
17
|
* 功能:
|
|
18
|
-
* 1. 创建或更新
|
|
18
|
+
* 1. 创建或更新 session_map 表记录
|
|
19
19
|
* 2. 基于 Token 预算检索 entities 和 reflections
|
|
20
20
|
* 3. 优先注入 permanent 级别事实,其次 project,最后 session
|
|
21
21
|
*
|
|
@@ -55,14 +55,14 @@ pool, config = {}) {
|
|
|
55
55
|
*/
|
|
56
56
|
async function upsertSession(session, pool) {
|
|
57
57
|
const query = `
|
|
58
|
-
INSERT INTO
|
|
58
|
+
INSERT INTO session_map (opencode_session_id, project_id, model_context_limit, metadata)
|
|
59
59
|
VALUES ($1, $2, $3, $4)
|
|
60
|
-
ON CONFLICT (
|
|
60
|
+
ON CONFLICT (opencode_session_id)
|
|
61
61
|
DO UPDATE SET
|
|
62
62
|
project_id = EXCLUDED.project_id,
|
|
63
63
|
model_context_limit = EXCLUDED.model_context_limit,
|
|
64
|
-
|
|
65
|
-
metadata =
|
|
64
|
+
last_active_at = NOW(),
|
|
65
|
+
metadata = session_map.metadata || EXCLUDED.metadata
|
|
66
66
|
`;
|
|
67
67
|
await pool.query(query, [
|
|
68
68
|
session.id,
|
|
@@ -56,6 +56,10 @@ export declare class OpenCodeSchemaAdapter {
|
|
|
56
56
|
constructor(customPath?: string);
|
|
57
57
|
connect(): boolean;
|
|
58
58
|
private detectDrizzleVersion;
|
|
59
|
+
/** Unified query helper — supports both bun:sqlite and better-sqlite3 APIs */
|
|
60
|
+
private queryAll;
|
|
61
|
+
/** Unified single-row query helper */
|
|
62
|
+
private queryGet;
|
|
59
63
|
isConnected(): boolean;
|
|
60
64
|
getDrizzleVersion(): number;
|
|
61
65
|
getRecentSessions(): SQLiteSession[];
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"opencode-schema-adapter.d.ts","sourceRoot":"","sources":["../../../src/services/opencode-schema-adapter.ts"],"names":[],"mappings":"AAiBA,MAAM,WAAW,aAAa;IAC5B,EAAE,EAAE,MAAM,CAAC;IACX,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,qCAAqC;AACrC,MAAM,WAAW,iBAAiB;IAChC,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,MAAM,CAAC,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE;YAAE,IAAI,EAAE,MAAM,CAAC;YAAC,KAAK,EAAE,MAAM,CAAA;SAAE,CAAA;KAAE,CAAC;IACrH,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IAC/C,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,6BAA6B;AAC7B,MAAM,WAAW,UAAU;IACzB,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,OAAO,GAAG,WAAW,CAAC;IACxD,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE;QACN,MAAM,EAAE,MAAM,CAAC;QACf,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC5B,MAAM,CAAC,EAAE,GAAG,CAAC;QACb,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,IAAI,CAAC,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,GAAG,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;CACxC;AAED,qBAAa,qBAAqB;IAChC,OAAO,CAAC,EAAE,CAAa;IACvB,OAAO,CAAC,IAAI,CAAS;IACrB,OAAO,CAAC,cAAc,CAAa;gBAEvB,UAAU,CAAC,EAAE,MAAM;IAI/B,OAAO,IAAI,OAAO;
|
|
1
|
+
{"version":3,"file":"opencode-schema-adapter.d.ts","sourceRoot":"","sources":["../../../src/services/opencode-schema-adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -27,36 +27,72 @@ class OpenCodeSchemaAdapter {
|
|
|
27
27
|
if (this.db)
|
|
28
28
|
return true;
|
|
29
29
|
try {
|
|
30
|
+
// Try bun:sqlite first (faster, native)
|
|
30
31
|
const { Database } = require('bun:sqlite');
|
|
31
32
|
this.db = new Database(this.path);
|
|
32
33
|
this.detectDrizzleVersion();
|
|
33
34
|
return true;
|
|
34
35
|
}
|
|
35
|
-
catch
|
|
36
|
-
|
|
37
|
-
|
|
36
|
+
catch {
|
|
37
|
+
try {
|
|
38
|
+
// Fall back to better-sqlite3 (Node.js compatible)
|
|
39
|
+
const Database = require('better-sqlite3');
|
|
40
|
+
this.db = new Database(this.path);
|
|
41
|
+
this.detectDrizzleVersion();
|
|
42
|
+
return true;
|
|
43
|
+
}
|
|
44
|
+
catch (err) {
|
|
45
|
+
logger.warn('No SQLite driver available', { path: this.path, error: err.message });
|
|
46
|
+
return false;
|
|
47
|
+
}
|
|
38
48
|
}
|
|
39
49
|
}
|
|
40
50
|
detectDrizzleVersion() {
|
|
41
51
|
try {
|
|
42
|
-
const rows = this.
|
|
52
|
+
const rows = this.queryAll('SELECT count(*) as cnt FROM __drizzle_migrations');
|
|
43
53
|
this.drizzleVersion = rows.length > 0 ? rows[0].cnt || 0 : 0;
|
|
44
54
|
}
|
|
45
55
|
catch {
|
|
46
56
|
this.drizzleVersion = 0;
|
|
47
57
|
}
|
|
48
58
|
}
|
|
59
|
+
/** Unified query helper — supports both bun:sqlite and better-sqlite3 APIs */
|
|
60
|
+
queryAll(sql, ...params) {
|
|
61
|
+
if (!this.db)
|
|
62
|
+
return [];
|
|
63
|
+
try {
|
|
64
|
+
if (typeof this.db.query === 'function') {
|
|
65
|
+
return this.db.query(sql).all(...params);
|
|
66
|
+
}
|
|
67
|
+
return this.db.prepare(sql).all(...params);
|
|
68
|
+
}
|
|
69
|
+
catch {
|
|
70
|
+
return [];
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
/** Unified single-row query helper */
|
|
74
|
+
queryGet(sql, ...params) {
|
|
75
|
+
if (!this.db)
|
|
76
|
+
return null;
|
|
77
|
+
try {
|
|
78
|
+
if (typeof this.db.query === 'function') {
|
|
79
|
+
return this.db.query(sql).get(...params);
|
|
80
|
+
}
|
|
81
|
+
return this.db.prepare(sql).get(...params);
|
|
82
|
+
}
|
|
83
|
+
catch {
|
|
84
|
+
return null;
|
|
85
|
+
}
|
|
86
|
+
}
|
|
49
87
|
isConnected() { return this.db !== null; }
|
|
50
88
|
getDrizzleVersion() { return this.drizzleVersion; }
|
|
51
89
|
// ── 会话 ─────────────────────────────────────────
|
|
52
90
|
getRecentSessions() {
|
|
53
|
-
if (!this.db)
|
|
54
|
-
return [];
|
|
55
91
|
try {
|
|
56
|
-
return this.
|
|
92
|
+
return this.queryAll(`
|
|
57
93
|
SELECT id, title, time_created, agent, model
|
|
58
94
|
FROM session ORDER BY time_created ASC
|
|
59
|
-
`)
|
|
95
|
+
`);
|
|
60
96
|
}
|
|
61
97
|
catch (err) {
|
|
62
98
|
logger.warn('Failed to query sessions', { error: err.message });
|
|
@@ -64,10 +100,8 @@ class OpenCodeSchemaAdapter {
|
|
|
64
100
|
}
|
|
65
101
|
}
|
|
66
102
|
getSessionById(id) {
|
|
67
|
-
if (!this.db)
|
|
68
|
-
return null;
|
|
69
103
|
try {
|
|
70
|
-
return this.
|
|
104
|
+
return this.queryGet('SELECT id, title, time_created, agent FROM session WHERE id = ?', id) || null;
|
|
71
105
|
}
|
|
72
106
|
catch {
|
|
73
107
|
return null;
|
|
@@ -85,12 +119,10 @@ class OpenCodeSchemaAdapter {
|
|
|
85
119
|
}
|
|
86
120
|
/** 获取指定会话的全部消息(含 JSON 解析) */
|
|
87
121
|
getMessagesBySession(sessionId) {
|
|
88
|
-
if (!this.db)
|
|
89
|
-
return [];
|
|
90
122
|
try {
|
|
91
|
-
const rows = this.
|
|
123
|
+
const rows = this.queryAll(`
|
|
92
124
|
SELECT id, data FROM message WHERE session_id = ? ORDER BY time_created ASC
|
|
93
|
-
|
|
125
|
+
`, sessionId);
|
|
94
126
|
return rows.map(r => ({ id: r.id, meta: this.parseMessageMeta(r.data) }));
|
|
95
127
|
}
|
|
96
128
|
catch (err) {
|
|
@@ -100,8 +132,6 @@ class OpenCodeSchemaAdapter {
|
|
|
100
132
|
}
|
|
101
133
|
/** 获取增量消息(time_created > sinceTime) */
|
|
102
134
|
getRecentMessages(sinceTime) {
|
|
103
|
-
if (!this.db)
|
|
104
|
-
return [];
|
|
105
135
|
try {
|
|
106
136
|
let sql = 'SELECT id, session_id, data, time_created FROM message';
|
|
107
137
|
const params = [];
|
|
@@ -110,7 +140,7 @@ class OpenCodeSchemaAdapter {
|
|
|
110
140
|
params.push(sinceTime);
|
|
111
141
|
}
|
|
112
142
|
sql += ' ORDER BY time_created ASC';
|
|
113
|
-
const rows = this.
|
|
143
|
+
const rows = this.queryAll(sql, ...params);
|
|
114
144
|
return rows.map(r => ({ id: r.id, session_id: r.session_id, meta: this.parseMessageMeta(r.data) }));
|
|
115
145
|
}
|
|
116
146
|
catch (err) {
|
|
@@ -130,10 +160,8 @@ class OpenCodeSchemaAdapter {
|
|
|
130
160
|
}
|
|
131
161
|
/** 获取指定消息的全部部件 */
|
|
132
162
|
getPartsByMessage(messageId) {
|
|
133
|
-
if (!this.db)
|
|
134
|
-
return [];
|
|
135
163
|
try {
|
|
136
|
-
const rows = this.
|
|
164
|
+
const rows = this.queryAll('SELECT data FROM part WHERE message_id = ? ORDER BY time_created ASC', messageId);
|
|
137
165
|
return rows.map(r => this.parsePart(r.data)).filter(Boolean);
|
|
138
166
|
}
|
|
139
167
|
catch (err) {
|
|
@@ -149,7 +177,7 @@ class OpenCodeSchemaAdapter {
|
|
|
149
177
|
/** 获取指定会话的全部工具调用(两段式:message → part) */
|
|
150
178
|
getToolCallsBySession(sessionId) {
|
|
151
179
|
const results = [];
|
|
152
|
-
const msgs = this.
|
|
180
|
+
const msgs = this.queryAll('SELECT id FROM message WHERE session_id = ? ORDER BY time_created ASC', sessionId);
|
|
153
181
|
for (const msg of msgs) {
|
|
154
182
|
const tools = this.getToolCallsByMessage(msg.id);
|
|
155
183
|
for (const t of tools) {
|
|
@@ -170,8 +198,8 @@ class OpenCodeSchemaAdapter {
|
|
|
170
198
|
try {
|
|
171
199
|
if (!this.db)
|
|
172
200
|
return { ok: false, drizzleVersion: 0, sessionCount: 0, messageCount: 0 };
|
|
173
|
-
const sc = this.
|
|
174
|
-
const mc = this.
|
|
201
|
+
const sc = this.queryGet('SELECT count(*) as c FROM session')?.c || 0;
|
|
202
|
+
const mc = this.queryGet('SELECT count(*) as c FROM message')?.c || 0;
|
|
175
203
|
return { ok: true, drizzleVersion: this.drizzleVersion, sessionCount: sc, messageCount: mc };
|
|
176
204
|
}
|
|
177
205
|
catch {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"opencode-schema-adapter.js","sourceRoot":"","sources":["../../../src/services/opencode-schema-adapter.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;;GAUG;AACH,qCAAwC;AACxC,+BAA4B;AAC5B,2BAA6B;AAE7B,MAAM,MAAM,GAAG,IAAA,qBAAY,EAAC,gBAAgB,CAAC,CAAC;AAyC9C,MAAa,qBAAqB;IACxB,EAAE,GAAQ,IAAI,CAAC;IACf,IAAI,CAAS;IACb,cAAc,GAAW,CAAC,CAAC;IAEnC,YAAY,UAAmB;QAC7B,IAAI,CAAC,IAAI,GAAG,UAAU,IAAI,IAAA,WAAI,EAAC,IAAA,YAAO,GAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC;IAC1F,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,EAAE;YAAE,OAAO,IAAI,CAAC;QACzB,IAAI,CAAC;YACH,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,YAAY,CAAQ,CAAC;YAClD,IAAI,CAAC,EAAE,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"opencode-schema-adapter.js","sourceRoot":"","sources":["../../../src/services/opencode-schema-adapter.ts"],"names":[],"mappings":";;;AAAA;;;;;;;;;;GAUG;AACH,qCAAwC;AACxC,+BAA4B;AAC5B,2BAA6B;AAE7B,MAAM,MAAM,GAAG,IAAA,qBAAY,EAAC,gBAAgB,CAAC,CAAC;AAyC9C,MAAa,qBAAqB;IACxB,EAAE,GAAQ,IAAI,CAAC;IACf,IAAI,CAAS;IACb,cAAc,GAAW,CAAC,CAAC;IAEnC,YAAY,UAAmB;QAC7B,IAAI,CAAC,IAAI,GAAG,UAAU,IAAI,IAAA,WAAI,EAAC,IAAA,YAAO,GAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,UAAU,EAAE,aAAa,CAAC,CAAC;IAC1F,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,EAAE;YAAE,OAAO,IAAI,CAAC;QACzB,IAAI,CAAC;YACH,wCAAwC;YACxC,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC,YAAY,CAAQ,CAAC;YAClD,IAAI,CAAC,EAAE,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,MAAM,CAAC;YACP,IAAI,CAAC;gBACH,mDAAmD;gBACnD,MAAM,QAAQ,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAAC;gBAC3C,IAAI,CAAC,EAAE,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClC,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,OAAO,IAAI,CAAC;YACd,CAAC;YAAC,OAAO,GAAQ,EAAE,CAAC;gBAClB,MAAM,CAAC,IAAI,CAAC,4BAA4B,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;gBACnF,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;IACH,CAAC;IAEO,oBAAoB;QAC1B,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,kDAAkD,CAAC,CAAC;YAC/E,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAE,IAAI,CAAC,CAAC,CAAS,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACxE,CAAC;QAAC,MAAM,CAAC;YAAC,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;QAAC,CAAC;IACtC,CAAC;IAED,8EAA8E;IACtE,QAAQ,CAAC,GAAW,EAAE,GAAG,MAAa;QAC5C,IAAI,CAAC,IAAI,CAAC,EAAE;YAAE,OAAO,EAAE,CAAC;QACxB,IAAI,CAAC;YACH,IAAI,OAAO,IAAI,CAAC,EAAE,CAAC,KAAK,KAAK,UAAU,EAAE,CAAC;gBACxC,OAAO,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;YAC3C,CAAC;YACD,OAAO,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;QAC7C,CAAC;QAAC,MAAM,CAAC;YAAC,OAAO,EAAE,CAAC;QAAC,CAAC;IACxB,CAAC;IAED,sCAAsC;IAC9B,QAAQ,CAAC,GAAW,EAAE,GAAG,MAAa;QAC5C,IAAI,CAAC,IAAI,CAAC,EAAE;YAAE,OAAO,IAAI,CAAC;QAC1B,IAAI,CAAC;YACH,IAAI,OAAO,IAAI,CAAC,EAAE,CAAC,KAAK,KAAK,UAAU,EAAE,CAAC;gBACxC,OAAO,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;YAC3C,CAAC;YACD,OAAO,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;QAC7C,CAAC;QAAC,MAAM,CAAC;YAAC,OAAO,IAAI,CAAC;QAAC,CAAC;IAC1B,CAAC;IAED,WAAW,KAAc,OAAO,IAAI,CAAC,EAAE,KAAK,IAAI,CAAC,CAAC,CAAC;IACnD,iBAAiB,KAAa,OAAO,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC;IAE3D,kDAAkD;IAElD,iBAAiB;QACf,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,QAAQ,CAAC;;;OAGpB,CAAoB,CAAC;QACxB,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;YAChE,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;IAED,cAAc,CAAC,EAAU;QACvB,IAAI,CAAC;YACH,OAAO,IAAI,CAAC,QAAQ,CAAC,iEAAiE,EAAE,EAAE,CAAkB,IAAI,IAAI,CAAC;QACvH,CAAC;QAAC,MAAM,CAAC;YAAC,OAAO,IAAI,CAAC;QAAC,CAAC;IAC1B,CAAC;IAED,kDAAkD;IAElD,iCAAiC;IACjC,gBAAgB,CAAC,GAAW;QAC1B,IAAI,CAAC;YAAC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAsB,CAAC;QAAC,CAAC;QAAC,MAAM,CAAC;YAAC,OAAO,IAAI,CAAC;QAAC,CAAC;IAC7E,CAAC;IAED,6BAA6B;IAC7B,oBAAoB,CAAC,SAAiB;QACpC,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC;;OAE1B,EAAE,SAAS,CAAwC,CAAC;YACrD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5E,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,0BAA0B,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;YAC3E,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;IAED,uCAAuC;IACvC,iBAAiB,CAAC,SAAkB;QAClC,IAAI,CAAC;YACH,IAAI,GAAG,GAAG,wDAAwD,CAAC;YACnE,MAAM,MAAM,GAAU,EAAE,CAAC;YACzB,IAAI,SAAS,EAAE,CAAC;gBAAC,GAAG,IAAI,yBAAyB,CAAC;gBAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAAC,CAAC;YAC5E,GAAG,IAAI,4BAA4B,CAAC;YACpC,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,EAAE,GAAG,MAAM,CAAkF,CAAC;YAC5H,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,EAAE,UAAU,EAAE,CAAC,CAAC,UAAU,EAAE,IAAI,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;QACtG,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,iCAAiC,EAAE,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;YACvE,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;IAED,gDAAgD;IAEhD,gCAAgC;IAChC,SAAS,CAAC,GAAW;QACnB,IAAI,CAAC;YAAC,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAe,CAAC;QAAC,CAAC;QAAC,MAAM,CAAC;YAAC,OAAO,IAAI,CAAC;QAAC,CAAC;IACtE,CAAC;IAED,kBAAkB;IAClB,iBAAiB,CAAC,SAAiB;QACjC,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,sEAAsE,EAAE,SAAS,CAA4B,CAAC;YACzI,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAiB,CAAC;QAC/E,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,uBAAuB,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;YACxE,OAAO,EAAE,CAAC;QACZ,CAAC;IACH,CAAC;IAED,qBAAqB;IACrB,qBAAqB,CAAC,SAAiB;QACrC,OAAO,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,CAAC,IAAI,CAAC,CAAC;IACpF,CAAC;IAED,+CAA+C;IAE/C,wCAAwC;IACxC,qBAAqB,CAAC,SAAiB;QACrC,MAAM,OAAO,GAAe,EAAE,CAAC;QAC/B,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,uEAAuE,EAAE,SAAS,CAA0B,CAAC;QACxI,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,KAAK,GAAG,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACjD,KAAK,MAAM,CAAC,IAAI,KAAK,EAAE,CAAC;gBACtB,OAAO,CAAC,IAAI,CAAC;oBACX,SAAS,EAAE,GAAG,CAAC,EAAE;oBACjB,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,SAAS;oBACzB,MAAM,EAAE,CAAC,CAAC,MAAM;oBAChB,KAAK,EAAE,CAAC,CAAC,KAAK,EAAE,KAAK;oBACrB,MAAM,EAAE,CAAC,CAAC,KAAK,EAAE,MAAM;oBACvB,MAAM,EAAE,CAAC,CAAC,KAAK,EAAE,MAAM;iBACxB,CAAC,CAAC;YACL,CAAC;QACH,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,iBAAiB;IACjB,WAAW;QACT,IAAI,CAAC;YACH,IAAI,CAAC,IAAI,CAAC,EAAE;gBAAE,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC;YACxF,MAAM,EAAE,GAAI,IAAI,CAAC,QAAQ,CAAC,mCAAmC,CAAS,EAAE,CAAC,IAAI,CAAC,CAAC;YAC/E,MAAM,EAAE,GAAI,IAAI,CAAC,QAAQ,CAAC,mCAAmC,CAAS,EAAE,CAAC,IAAI,CAAC,CAAC;YAC/E,OAAO,EAAE,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,IAAI,CAAC,cAAc,EAAE,YAAY,EAAE,EAAE,EAAE,YAAY,EAAE,EAAE,EAAE,CAAC;QAC/F,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,EAAE,EAAE,EAAE,KAAK,EAAE,cAAc,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,YAAY,EAAE,CAAC,EAAE,CAAC;QAC5E,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC;YACZ,IAAI,CAAC;gBAAC,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;YAAC,CAAC;YAAC,MAAM,CAAC,CAAA,CAAC;YACjC,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC;QACjB,CAAC;IACH,CAAC;CACF;AArLD,sDAqLC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "opcode-pg-memory",
|
|
3
|
-
"version": "2.3.
|
|
3
|
+
"version": "2.3.3",
|
|
4
4
|
"main": "dist/index.js",
|
|
5
5
|
"types": "dist/index.d.ts",
|
|
6
6
|
"bin": {
|
|
@@ -45,26 +45,27 @@
|
|
|
45
45
|
"README.md"
|
|
46
46
|
],
|
|
47
47
|
"dependencies": {
|
|
48
|
-
"pg": "^8.11.3",
|
|
49
|
-
"pgvector": "^0.1.8",
|
|
50
48
|
"@modelcontextprotocol/sdk": "^0.5.0",
|
|
51
|
-
"
|
|
49
|
+
"better-sqlite3": "^12.9.0",
|
|
50
|
+
"dotenv": "^16.3.1",
|
|
52
51
|
"openai": "^4.20.0",
|
|
53
|
-
"
|
|
52
|
+
"pg": "^8.11.3",
|
|
53
|
+
"pgvector": "^0.1.8",
|
|
54
|
+
"uuid": "^9.0.1"
|
|
54
55
|
},
|
|
55
56
|
"devDependencies": {
|
|
57
|
+
"@types/better-sqlite3": "^7.6.13",
|
|
58
|
+
"@types/jest": "^29.5.10",
|
|
56
59
|
"@types/node": "^20.10.0",
|
|
57
60
|
"@types/pg": "^8.10.9",
|
|
58
61
|
"@types/uuid": "^9.0.7",
|
|
59
|
-
"
|
|
60
|
-
"rimraf": "^5.0.5",
|
|
62
|
+
"bun-types": "latest",
|
|
61
63
|
"jest": "^29.7.0",
|
|
64
|
+
"rimraf": "^5.0.5",
|
|
62
65
|
"ts-jest": "^29.1.1",
|
|
63
|
-
"
|
|
64
|
-
"bun-types": "latest"
|
|
66
|
+
"typescript": "^5.3.2"
|
|
65
67
|
},
|
|
66
68
|
"engines": {
|
|
67
69
|
"node": ">=18.0.0"
|
|
68
70
|
}
|
|
69
71
|
}
|
|
70
|
-
|