agent-inbox 0.1.3 → 0.1.4
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/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +17 -4
- package/dist/index.js.map +1 -1
- package/dist/storage/sqlite.d.ts +11 -1
- package/dist/storage/sqlite.d.ts.map +1 -1
- package/dist/storage/sqlite.js +85 -65
- package/dist/storage/sqlite.js.map +1 -1
- package/package.json +1 -1
- package/src/index.ts +19 -4
- package/src/storage/sqlite.ts +92 -66
- package/test/sqlite-prefix.test.ts +192 -0
package/dist/index.d.ts
CHANGED
|
@@ -45,6 +45,10 @@ export interface CreateOptions {
|
|
|
45
45
|
config?: Partial<InboxConfig>;
|
|
46
46
|
/** Use SQLite storage at this path (":memory:" for in-memory SQLite) */
|
|
47
47
|
sqlitePath?: string;
|
|
48
|
+
/** Use an external better-sqlite3 Database handle (co-locate tables in another DB) */
|
|
49
|
+
sqliteDb?: import("better-sqlite3").Database;
|
|
50
|
+
/** Table name prefix when co-locating in an external DB (e.g. "inbox_") */
|
|
51
|
+
sqlitePrefix?: string;
|
|
48
52
|
/** HTTP port for JSON-RPC endpoint (0 = disabled) */
|
|
49
53
|
httpPort?: number;
|
|
50
54
|
/** Webhook URLs for push notifications */
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/index.js
CHANGED
|
@@ -53,10 +53,23 @@ function loadConfig() {
|
|
|
53
53
|
}
|
|
54
54
|
export async function createAgentInbox(opts = {}) {
|
|
55
55
|
const config = { ...loadConfig(), ...opts.config };
|
|
56
|
-
// 1. Storage — SQLite
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
56
|
+
// 1. Storage — SQLite (own file, external DB, or in-memory fallback)
|
|
57
|
+
let storage;
|
|
58
|
+
if (opts.sqliteDb) {
|
|
59
|
+
storage = new SqliteStorage({
|
|
60
|
+
db: opts.sqliteDb,
|
|
61
|
+
prefix: opts.sqlitePrefix,
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
else if (opts.sqlitePath) {
|
|
65
|
+
storage = new SqliteStorage({
|
|
66
|
+
path: opts.sqlitePath,
|
|
67
|
+
prefix: opts.sqlitePrefix,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
else {
|
|
71
|
+
storage = new InMemoryStorage();
|
|
72
|
+
}
|
|
60
73
|
// 2. Event bus (internal)
|
|
61
74
|
const events = new EventEmitter();
|
|
62
75
|
// 3. Message router
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"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"}
|
package/dist/storage/sqlite.d.ts
CHANGED
|
@@ -1,10 +1,20 @@
|
|
|
1
|
+
import Database from "better-sqlite3";
|
|
1
2
|
import type { Agent, Message, Conversation, Turn, Thread } from "../types.js";
|
|
2
3
|
import type { Storage, InboxQuery, ThreadQuery } from "./interface.js";
|
|
3
4
|
export interface SqliteStorageOptions {
|
|
4
|
-
path:
|
|
5
|
+
/** Open a new database at this path (":memory:" for in-memory). Ignored if `db` is provided. */
|
|
6
|
+
path?: string;
|
|
7
|
+
/** Use an externally-managed database handle. When provided, the handle is borrowed —
|
|
8
|
+
* close() will NOT close it (the caller owns its lifecycle). */
|
|
9
|
+
db?: Database.Database;
|
|
10
|
+
/** Table name prefix (e.g. "inbox_"). Defaults to "" (no prefix). */
|
|
11
|
+
prefix?: string;
|
|
5
12
|
}
|
|
6
13
|
export declare class SqliteStorage implements Storage {
|
|
7
14
|
private db;
|
|
15
|
+
private externalDb;
|
|
16
|
+
/** Prefixed table name helper */
|
|
17
|
+
private p;
|
|
8
18
|
constructor(opts: SqliteStorageOptions);
|
|
9
19
|
private migrate;
|
|
10
20
|
getAgent(agentId: string): Agent | undefined;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sqlite.d.ts","sourceRoot":"","sources":["../../src/storage/sqlite.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"sqlite.d.ts","sourceRoot":"","sources":["../../src/storage/sqlite.ts"],"names":[],"mappings":"AAAA,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AACtC,OAAO,KAAK,EACV,KAAK,EACL,OAAO,EACP,YAAY,EACZ,IAAI,EACJ,MAAM,EAIP,MAAM,aAAa,CAAC;AACrB,OAAO,KAAK,EAAE,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAEvE,MAAM,WAAW,oBAAoB;IACnC,gGAAgG;IAChG,IAAI,CAAC,EAAE,MAAM,CAAC;IACd;qEACiE;IACjE,EAAE,CAAC,EAAE,QAAQ,CAAC,QAAQ,CAAC;IACvB,qEAAqE;IACrE,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,aAAc,YAAW,OAAO;IAC3C,OAAO,CAAC,EAAE,CAAoB;IAC9B,OAAO,CAAC,UAAU,CAAU;IAC5B,iCAAiC;IACjC,OAAO,CAAC,CAAC,CAA4B;gBAEzB,IAAI,EAAE,oBAAoB;IAiBtC,OAAO,CAAC,OAAO;IAuIf,QAAQ,CAAC,OAAO,EAAE,MAAM,GAAG,KAAK,GAAG,SAAS;IAO5C,QAAQ,CAAC,KAAK,EAAE,KAAK,GAAG,IAAI;IAoB5B,UAAU,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,KAAK,EAAE;IASnC,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO;IASrC,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS;IAQ3C,UAAU,CAAC,OAAO,EAAE,OAAO,GAAG,OAAO;IA6CrC,QAAQ,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,UAAU,GAAG,OAAO,EAAE;IA2BvD,SAAS,CAAC,KAAK,EAAE,WAAW,GAAG,OAAO,EAAE;IASxC,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,EAAE;IAW3D,cAAc,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,EAAE;IAiCxD,OAAO,CAAC,kBAAkB;IAkB1B,eAAe,CAAC,EAAE,EAAE,MAAM,GAAG,YAAY,GAAG,SAAS;IAQrD,eAAe,CAAC,YAAY,EAAE,YAAY,GAAG,YAAY;IA+BzD,iBAAiB,CAAC,KAAK,CAAC,EAAE,MAAM,GAAG,YAAY,EAAE;IAgBjD,OAAO,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI;IAoBzB,QAAQ,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI,EAAE;IAWxC,UAAU,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS;IAO1C,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM;IAkBjC,wBAAwB,CAAC,cAAc,EAAE,MAAM,GAAG,MAAM,EAAE;IAS1D,OAAO,CAAC,aAAa;IAarB,OAAO,CAAC,eAAe;IAWvB,OAAO,CAAC,YAAY;IAiBpB,OAAO,CAAC,iBAAiB;IAazB,KAAK,IAAI,IAAI;CAKd"}
|
package/dist/storage/sqlite.js
CHANGED
|
@@ -1,15 +1,29 @@
|
|
|
1
1
|
import Database from "better-sqlite3";
|
|
2
2
|
export class SqliteStorage {
|
|
3
3
|
db;
|
|
4
|
+
externalDb;
|
|
5
|
+
/** Prefixed table name helper */
|
|
6
|
+
p;
|
|
4
7
|
constructor(opts) {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
+
if (opts.db) {
|
|
9
|
+
this.db = opts.db;
|
|
10
|
+
this.externalDb = true;
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
const path = opts.path ?? ":memory:";
|
|
14
|
+
this.db = new Database(path);
|
|
15
|
+
this.db.pragma("journal_mode = WAL");
|
|
16
|
+
this.db.pragma("foreign_keys = ON");
|
|
17
|
+
this.externalDb = false;
|
|
18
|
+
}
|
|
19
|
+
const prefix = opts.prefix ?? "";
|
|
20
|
+
this.p = (table) => `${prefix}${table}`;
|
|
8
21
|
this.migrate();
|
|
9
22
|
}
|
|
10
23
|
migrate() {
|
|
24
|
+
const t = this.p;
|
|
11
25
|
this.db.exec(`
|
|
12
|
-
CREATE TABLE IF NOT EXISTS agents (
|
|
26
|
+
CREATE TABLE IF NOT EXISTS ${t("agents")} (
|
|
13
27
|
agent_id TEXT PRIMARY KEY,
|
|
14
28
|
display_name TEXT,
|
|
15
29
|
program TEXT,
|
|
@@ -21,7 +35,7 @@ export class SqliteStorage {
|
|
|
21
35
|
last_active_at TEXT NOT NULL
|
|
22
36
|
);
|
|
23
37
|
|
|
24
|
-
CREATE TABLE IF NOT EXISTS messages (
|
|
38
|
+
CREATE TABLE IF NOT EXISTS ${t("messages")} (
|
|
25
39
|
id TEXT PRIMARY KEY,
|
|
26
40
|
scope TEXT NOT NULL DEFAULT 'default',
|
|
27
41
|
sender_id TEXT NOT NULL,
|
|
@@ -35,7 +49,7 @@ export class SqliteStorage {
|
|
|
35
49
|
created_at TEXT NOT NULL
|
|
36
50
|
);
|
|
37
51
|
|
|
38
|
-
CREATE TABLE IF NOT EXISTS recipients (
|
|
52
|
+
CREATE TABLE IF NOT EXISTS ${t("recipients")} (
|
|
39
53
|
message_id TEXT NOT NULL,
|
|
40
54
|
agent_id TEXT NOT NULL,
|
|
41
55
|
kind TEXT NOT NULL DEFAULT 'to',
|
|
@@ -43,10 +57,10 @@ export class SqliteStorage {
|
|
|
43
57
|
read_at TEXT,
|
|
44
58
|
ack_at TEXT,
|
|
45
59
|
PRIMARY KEY (message_id, agent_id),
|
|
46
|
-
FOREIGN KEY (message_id) REFERENCES messages(id)
|
|
60
|
+
FOREIGN KEY (message_id) REFERENCES ${t("messages")}(id)
|
|
47
61
|
);
|
|
48
62
|
|
|
49
|
-
CREATE TABLE IF NOT EXISTS conversations (
|
|
63
|
+
CREATE TABLE IF NOT EXISTS ${t("conversations")} (
|
|
50
64
|
id TEXT PRIMARY KEY,
|
|
51
65
|
scope TEXT NOT NULL DEFAULT 'default',
|
|
52
66
|
subject TEXT,
|
|
@@ -56,16 +70,16 @@ export class SqliteStorage {
|
|
|
56
70
|
updated_at TEXT NOT NULL
|
|
57
71
|
);
|
|
58
72
|
|
|
59
|
-
CREATE TABLE IF NOT EXISTS participants (
|
|
73
|
+
CREATE TABLE IF NOT EXISTS ${t("participants")} (
|
|
60
74
|
conversation_id TEXT NOT NULL,
|
|
61
75
|
agent_id TEXT NOT NULL,
|
|
62
76
|
role TEXT,
|
|
63
77
|
joined_at TEXT NOT NULL,
|
|
64
78
|
PRIMARY KEY (conversation_id, agent_id),
|
|
65
|
-
FOREIGN KEY (conversation_id) REFERENCES conversations(id)
|
|
79
|
+
FOREIGN KEY (conversation_id) REFERENCES ${t("conversations")}(id)
|
|
66
80
|
);
|
|
67
81
|
|
|
68
|
-
CREATE TABLE IF NOT EXISTS turns (
|
|
82
|
+
CREATE TABLE IF NOT EXISTS ${t("turns")} (
|
|
69
83
|
id TEXT PRIMARY KEY,
|
|
70
84
|
conversation_id TEXT NOT NULL,
|
|
71
85
|
participant_id TEXT NOT NULL,
|
|
@@ -75,62 +89,62 @@ export class SqliteStorage {
|
|
|
75
89
|
thread_id TEXT,
|
|
76
90
|
in_reply_to TEXT,
|
|
77
91
|
created_at TEXT NOT NULL,
|
|
78
|
-
FOREIGN KEY (conversation_id) REFERENCES conversations(id)
|
|
92
|
+
FOREIGN KEY (conversation_id) REFERENCES ${t("conversations")}(id)
|
|
79
93
|
);
|
|
80
94
|
|
|
81
|
-
CREATE TABLE IF NOT EXISTS threads (
|
|
95
|
+
CREATE TABLE IF NOT EXISTS ${t("threads")} (
|
|
82
96
|
id TEXT PRIMARY KEY,
|
|
83
97
|
conversation_id TEXT NOT NULL,
|
|
84
98
|
root_turn_id TEXT NOT NULL,
|
|
85
99
|
parent_thread_id TEXT,
|
|
86
100
|
subject TEXT,
|
|
87
101
|
created_at TEXT NOT NULL,
|
|
88
|
-
FOREIGN KEY (conversation_id) REFERENCES conversations(id)
|
|
102
|
+
FOREIGN KEY (conversation_id) REFERENCES ${t("conversations")}(id)
|
|
89
103
|
);
|
|
90
104
|
|
|
91
105
|
-- Indexes for common queries
|
|
92
|
-
CREATE INDEX IF NOT EXISTS
|
|
93
|
-
CREATE INDEX IF NOT EXISTS
|
|
94
|
-
CREATE INDEX IF NOT EXISTS
|
|
95
|
-
CREATE INDEX IF NOT EXISTS
|
|
96
|
-
CREATE INDEX IF NOT EXISTS
|
|
97
|
-
CREATE INDEX IF NOT EXISTS
|
|
98
|
-
CREATE INDEX IF NOT EXISTS
|
|
99
|
-
CREATE INDEX IF NOT EXISTS
|
|
106
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_scope ON ${t("messages")}(scope);
|
|
107
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_sender ON ${t("messages")}(sender_id);
|
|
108
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_thread_tag ON ${t("messages")}(thread_tag, scope);
|
|
109
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_conversation ON ${t("messages")}(conversation_id);
|
|
110
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_created ON ${t("messages")}(created_at);
|
|
111
|
+
CREATE INDEX IF NOT EXISTS idx_${t("recipients")}_agent ON ${t("recipients")}(agent_id);
|
|
112
|
+
CREATE INDEX IF NOT EXISTS idx_${t("turns")}_conversation ON ${t("turns")}(conversation_id);
|
|
113
|
+
CREATE INDEX IF NOT EXISTS idx_${t("agents")}_scope ON ${t("agents")}(scope);
|
|
100
114
|
|
|
101
115
|
-- FTS5 virtual table for full-text search
|
|
102
|
-
CREATE VIRTUAL TABLE IF NOT EXISTS messages_fts USING fts5(
|
|
116
|
+
CREATE VIRTUAL TABLE IF NOT EXISTS ${t("messages_fts")} USING fts5(
|
|
103
117
|
id UNINDEXED,
|
|
104
118
|
subject,
|
|
105
119
|
text_content,
|
|
106
|
-
content='messages',
|
|
120
|
+
content='${t("messages")}',
|
|
107
121
|
content_rowid='rowid'
|
|
108
122
|
);
|
|
109
123
|
|
|
110
124
|
-- Triggers to keep FTS in sync
|
|
111
|
-
CREATE TRIGGER IF NOT EXISTS messages_ai AFTER INSERT ON messages BEGIN
|
|
112
|
-
INSERT INTO messages_fts(rowid, id, subject, text_content)
|
|
125
|
+
CREATE TRIGGER IF NOT EXISTS ${t("messages_ai")} AFTER INSERT ON ${t("messages")} BEGIN
|
|
126
|
+
INSERT INTO ${t("messages_fts")}(rowid, id, subject, text_content)
|
|
113
127
|
VALUES (NEW.rowid, NEW.id, NEW.subject,
|
|
114
128
|
CASE WHEN json_extract(NEW.content, '$.type') = 'text'
|
|
115
129
|
THEN json_extract(NEW.content, '$.text')
|
|
116
130
|
ELSE '' END);
|
|
117
131
|
END;
|
|
118
132
|
|
|
119
|
-
CREATE TRIGGER IF NOT EXISTS messages_ad AFTER DELETE ON messages BEGIN
|
|
120
|
-
INSERT INTO messages_fts(messages_fts, rowid, id, subject, text_content)
|
|
133
|
+
CREATE TRIGGER IF NOT EXISTS ${t("messages_ad")} AFTER DELETE ON ${t("messages")} BEGIN
|
|
134
|
+
INSERT INTO ${t("messages_fts")}(${t("messages_fts")}, rowid, id, subject, text_content)
|
|
121
135
|
VALUES ('delete', OLD.rowid, OLD.id, OLD.subject,
|
|
122
136
|
CASE WHEN json_extract(OLD.content, '$.type') = 'text'
|
|
123
137
|
THEN json_extract(OLD.content, '$.text')
|
|
124
138
|
ELSE '' END);
|
|
125
139
|
END;
|
|
126
140
|
|
|
127
|
-
CREATE TRIGGER IF NOT EXISTS messages_au AFTER UPDATE ON messages BEGIN
|
|
128
|
-
INSERT INTO messages_fts(messages_fts, rowid, id, subject, text_content)
|
|
141
|
+
CREATE TRIGGER IF NOT EXISTS ${t("messages_au")} AFTER UPDATE ON ${t("messages")} BEGIN
|
|
142
|
+
INSERT INTO ${t("messages_fts")}(${t("messages_fts")}, rowid, id, subject, text_content)
|
|
129
143
|
VALUES ('delete', OLD.rowid, OLD.id, OLD.subject,
|
|
130
144
|
CASE WHEN json_extract(OLD.content, '$.type') = 'text'
|
|
131
145
|
THEN json_extract(OLD.content, '$.text')
|
|
132
146
|
ELSE '' END);
|
|
133
|
-
INSERT INTO messages_fts(rowid, id, subject, text_content)
|
|
147
|
+
INSERT INTO ${t("messages_fts")}(rowid, id, subject, text_content)
|
|
134
148
|
VALUES (NEW.rowid, NEW.id, NEW.subject,
|
|
135
149
|
CASE WHEN json_extract(NEW.content, '$.type') = 'text'
|
|
136
150
|
THEN json_extract(NEW.content, '$.text')
|
|
@@ -141,50 +155,50 @@ export class SqliteStorage {
|
|
|
141
155
|
// --- Agents ---
|
|
142
156
|
getAgent(agentId) {
|
|
143
157
|
const row = this.db
|
|
144
|
-
.prepare(
|
|
158
|
+
.prepare(`SELECT * FROM ${this.p("agents")} WHERE agent_id = ?`)
|
|
145
159
|
.get(agentId);
|
|
146
160
|
return row ? rowToAgent(row) : undefined;
|
|
147
161
|
}
|
|
148
162
|
putAgent(agent) {
|
|
149
163
|
this.db
|
|
150
|
-
.prepare(`INSERT OR REPLACE INTO agents
|
|
164
|
+
.prepare(`INSERT OR REPLACE INTO ${this.p("agents")}
|
|
151
165
|
(agent_id, display_name, program, model, scope, status, metadata, registered_at, last_active_at)
|
|
152
166
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
153
167
|
.run(agent.agent_id, agent.display_name ?? null, agent.program ?? null, agent.model ?? null, agent.scope, agent.status, JSON.stringify(agent.metadata), agent.registered_at, agent.last_active_at);
|
|
154
168
|
}
|
|
155
169
|
listAgents(scope) {
|
|
156
170
|
if (scope) {
|
|
157
|
-
return this.db.prepare(
|
|
171
|
+
return this.db.prepare(`SELECT * FROM ${this.p("agents")} WHERE scope = ?`).all(scope).map(rowToAgent);
|
|
158
172
|
}
|
|
159
|
-
return this.db.prepare(
|
|
173
|
+
return this.db.prepare(`SELECT * FROM ${this.p("agents")}`).all().map(rowToAgent);
|
|
160
174
|
}
|
|
161
175
|
removeAgent(agentId) {
|
|
162
176
|
const result = this.db
|
|
163
|
-
.prepare(
|
|
177
|
+
.prepare(`DELETE FROM ${this.p("agents")} WHERE agent_id = ?`)
|
|
164
178
|
.run(agentId);
|
|
165
179
|
return result.changes > 0;
|
|
166
180
|
}
|
|
167
181
|
// --- Messages ---
|
|
168
182
|
getMessage(id) {
|
|
169
183
|
const row = this.db
|
|
170
|
-
.prepare(
|
|
184
|
+
.prepare(`SELECT * FROM ${this.p("messages")} WHERE id = ?`)
|
|
171
185
|
.get(id);
|
|
172
186
|
if (!row)
|
|
173
187
|
return undefined;
|
|
174
188
|
return this.rowToMessage(row);
|
|
175
189
|
}
|
|
176
190
|
putMessage(message) {
|
|
177
|
-
const upsertMsg = this.db.prepare(`INSERT OR REPLACE INTO messages
|
|
191
|
+
const upsertMsg = this.db.prepare(`INSERT OR REPLACE INTO ${this.p("messages")}
|
|
178
192
|
(id, scope, sender_id, subject, content, thread_tag, in_reply_to, conversation_id, importance, metadata, created_at)
|
|
179
193
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`);
|
|
180
|
-
const upsertRecipient = this.db.prepare(`INSERT OR REPLACE INTO recipients
|
|
194
|
+
const upsertRecipient = this.db.prepare(`INSERT OR REPLACE INTO ${this.p("recipients")}
|
|
181
195
|
(message_id, agent_id, kind, delivered_at, read_at, ack_at)
|
|
182
196
|
VALUES (?, ?, ?, ?, ?, ?)`);
|
|
183
197
|
this.db.transaction(() => {
|
|
184
198
|
upsertMsg.run(message.id, message.scope, message.sender_id, message.subject ?? null, JSON.stringify(message.content), message.thread_tag ?? null, message.in_reply_to ?? null, message.conversation_id ?? null, message.importance, JSON.stringify(message.metadata), message.created_at);
|
|
185
199
|
// Delete old recipients and re-insert
|
|
186
200
|
this.db
|
|
187
|
-
.prepare(
|
|
201
|
+
.prepare(`DELETE FROM ${this.p("recipients")} WHERE message_id = ?`)
|
|
188
202
|
.run(message.id);
|
|
189
203
|
for (const r of message.recipients) {
|
|
190
204
|
upsertRecipient.run(message.id, r.agent_id, r.kind, r.delivered_at ?? null, r.read_at ?? null, r.ack_at ?? null);
|
|
@@ -193,9 +207,11 @@ export class SqliteStorage {
|
|
|
193
207
|
return message;
|
|
194
208
|
}
|
|
195
209
|
getInbox(agentId, opts) {
|
|
210
|
+
const m = this.p("messages");
|
|
211
|
+
const r = this.p("recipients");
|
|
196
212
|
let sql = `
|
|
197
|
-
SELECT m.* FROM
|
|
198
|
-
JOIN
|
|
213
|
+
SELECT m.* FROM ${m} m
|
|
214
|
+
JOIN ${r} r ON r.message_id = m.id
|
|
199
215
|
WHERE r.agent_id = ?
|
|
200
216
|
`;
|
|
201
217
|
const params = [agentId];
|
|
@@ -216,12 +232,12 @@ export class SqliteStorage {
|
|
|
216
232
|
}
|
|
217
233
|
getThread(query) {
|
|
218
234
|
const rows = this.db
|
|
219
|
-
.prepare(
|
|
235
|
+
.prepare(`SELECT * FROM ${this.p("messages")} WHERE thread_tag = ? AND scope = ? ORDER BY created_at ASC`)
|
|
220
236
|
.all(query.threadTag, query.scope);
|
|
221
237
|
return rows.map((row) => this.rowToMessage(row));
|
|
222
238
|
}
|
|
223
239
|
getSentMessages(agentId, limit) {
|
|
224
|
-
let sql =
|
|
240
|
+
let sql = `SELECT * FROM ${this.p("messages")} WHERE sender_id = ? ORDER BY created_at ASC`;
|
|
225
241
|
const params = [agentId];
|
|
226
242
|
if (limit) {
|
|
227
243
|
sql += " LIMIT ?";
|
|
@@ -231,22 +247,24 @@ export class SqliteStorage {
|
|
|
231
247
|
return rows.map((row) => this.rowToMessage(row));
|
|
232
248
|
}
|
|
233
249
|
searchMessages(query, scope) {
|
|
250
|
+
const m = this.p("messages");
|
|
251
|
+
const fts = this.p("messages_fts");
|
|
234
252
|
let sql;
|
|
235
253
|
let params;
|
|
236
254
|
if (scope) {
|
|
237
255
|
sql = `
|
|
238
|
-
SELECT m.* FROM
|
|
239
|
-
JOIN
|
|
240
|
-
WHERE
|
|
256
|
+
SELECT m.* FROM ${m} m
|
|
257
|
+
JOIN ${fts} fts ON fts.id = m.id
|
|
258
|
+
WHERE ${fts} MATCH ? AND m.scope = ?
|
|
241
259
|
ORDER BY m.created_at ASC
|
|
242
260
|
`;
|
|
243
261
|
params = [query, scope];
|
|
244
262
|
}
|
|
245
263
|
else {
|
|
246
264
|
sql = `
|
|
247
|
-
SELECT m.* FROM
|
|
248
|
-
JOIN
|
|
249
|
-
WHERE
|
|
265
|
+
SELECT m.* FROM ${m} m
|
|
266
|
+
JOIN ${fts} fts ON fts.id = m.id
|
|
267
|
+
WHERE ${fts} MATCH ?
|
|
250
268
|
ORDER BY m.created_at ASC
|
|
251
269
|
`;
|
|
252
270
|
params = [query];
|
|
@@ -263,7 +281,7 @@ export class SqliteStorage {
|
|
|
263
281
|
searchMessagesLike(query, scope) {
|
|
264
282
|
const pattern = `%${query}%`;
|
|
265
283
|
let sql = `
|
|
266
|
-
SELECT * FROM messages
|
|
284
|
+
SELECT * FROM ${this.p("messages")}
|
|
267
285
|
WHERE (subject LIKE ? OR content LIKE ?)
|
|
268
286
|
`;
|
|
269
287
|
const params = [pattern, pattern];
|
|
@@ -278,7 +296,7 @@ export class SqliteStorage {
|
|
|
278
296
|
// --- Conversations ---
|
|
279
297
|
getConversation(id) {
|
|
280
298
|
const row = this.db
|
|
281
|
-
.prepare(
|
|
299
|
+
.prepare(`SELECT * FROM ${this.p("conversations")} WHERE id = ?`)
|
|
282
300
|
.get(id);
|
|
283
301
|
if (!row)
|
|
284
302
|
return undefined;
|
|
@@ -287,15 +305,15 @@ export class SqliteStorage {
|
|
|
287
305
|
putConversation(conversation) {
|
|
288
306
|
this.db.transaction(() => {
|
|
289
307
|
this.db
|
|
290
|
-
.prepare(`INSERT OR REPLACE INTO conversations
|
|
308
|
+
.prepare(`INSERT OR REPLACE INTO ${this.p("conversations")}
|
|
291
309
|
(id, scope, subject, status, metadata, created_at, updated_at)
|
|
292
310
|
VALUES (?, ?, ?, ?, ?, ?, ?)`)
|
|
293
311
|
.run(conversation.id, conversation.scope, conversation.subject ?? null, conversation.status, JSON.stringify(conversation.metadata), conversation.created_at, conversation.updated_at);
|
|
294
312
|
// Re-sync participants
|
|
295
313
|
this.db
|
|
296
|
-
.prepare(
|
|
314
|
+
.prepare(`DELETE FROM ${this.p("participants")} WHERE conversation_id = ?`)
|
|
297
315
|
.run(conversation.id);
|
|
298
|
-
const insertP = this.db.prepare(`INSERT INTO participants (conversation_id, agent_id, role, joined_at) VALUES (?, ?, ?, ?)`);
|
|
316
|
+
const insertP = this.db.prepare(`INSERT INTO ${this.p("participants")} (conversation_id, agent_id, role, joined_at) VALUES (?, ?, ?, ?)`);
|
|
299
317
|
for (const p of conversation.participants) {
|
|
300
318
|
insertP.run(conversation.id, p.agent_id, p.role ?? null, p.joined_at);
|
|
301
319
|
}
|
|
@@ -306,12 +324,12 @@ export class SqliteStorage {
|
|
|
306
324
|
let rows;
|
|
307
325
|
if (scope) {
|
|
308
326
|
rows = this.db
|
|
309
|
-
.prepare(
|
|
327
|
+
.prepare(`SELECT * FROM ${this.p("conversations")} WHERE scope = ? ORDER BY updated_at DESC`)
|
|
310
328
|
.all(scope);
|
|
311
329
|
}
|
|
312
330
|
else {
|
|
313
331
|
rows = this.db
|
|
314
|
-
.prepare(
|
|
332
|
+
.prepare(`SELECT * FROM ${this.p("conversations")} ORDER BY updated_at DESC`)
|
|
315
333
|
.all();
|
|
316
334
|
}
|
|
317
335
|
return rows.map((row) => this.rowToConversation(row));
|
|
@@ -319,27 +337,27 @@ export class SqliteStorage {
|
|
|
319
337
|
// --- Turns ---
|
|
320
338
|
addTurn(turn) {
|
|
321
339
|
this.db
|
|
322
|
-
.prepare(`INSERT INTO turns
|
|
340
|
+
.prepare(`INSERT INTO ${this.p("turns")}
|
|
323
341
|
(id, conversation_id, participant_id, source_message_id, content_type, content, thread_id, in_reply_to, created_at)
|
|
324
342
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`)
|
|
325
343
|
.run(turn.id, turn.conversation_id, turn.participant_id, turn.source_message_id ?? null, turn.content_type, JSON.stringify(turn.content), turn.thread_id ?? null, turn.in_reply_to ?? null, turn.created_at);
|
|
326
344
|
}
|
|
327
345
|
getTurns(conversationId) {
|
|
328
346
|
const rows = this.db
|
|
329
|
-
.prepare(
|
|
347
|
+
.prepare(`SELECT * FROM ${this.p("turns")} WHERE conversation_id = ? ORDER BY created_at ASC`)
|
|
330
348
|
.all(conversationId);
|
|
331
349
|
return rows.map(rowToTurn);
|
|
332
350
|
}
|
|
333
351
|
// --- Threads ---
|
|
334
352
|
getThread2(id) {
|
|
335
353
|
const row = this.db
|
|
336
|
-
.prepare(
|
|
354
|
+
.prepare(`SELECT * FROM ${this.p("threads")} WHERE id = ?`)
|
|
337
355
|
.get(id);
|
|
338
356
|
return row ? rowToThread(row) : undefined;
|
|
339
357
|
}
|
|
340
358
|
putThread(thread) {
|
|
341
359
|
this.db
|
|
342
|
-
.prepare(`INSERT OR REPLACE INTO threads
|
|
360
|
+
.prepare(`INSERT OR REPLACE INTO ${this.p("threads")}
|
|
343
361
|
(id, conversation_id, root_turn_id, parent_thread_id, subject, created_at)
|
|
344
362
|
VALUES (?, ?, ?, ?, ?, ?)`)
|
|
345
363
|
.run(thread.id, thread.conversation_id, thread.root_turn_id, thread.parent_thread_id ?? null, thread.subject ?? null, thread.created_at);
|
|
@@ -347,14 +365,14 @@ export class SqliteStorage {
|
|
|
347
365
|
}
|
|
348
366
|
getThreadsByConversation(conversationId) {
|
|
349
367
|
const rows = this.db
|
|
350
|
-
.prepare(
|
|
368
|
+
.prepare(`SELECT * FROM ${this.p("threads")} WHERE conversation_id = ?`)
|
|
351
369
|
.all(conversationId);
|
|
352
370
|
return rows.map(rowToThread);
|
|
353
371
|
}
|
|
354
372
|
// --- Helpers ---
|
|
355
373
|
getRecipients(messageId) {
|
|
356
374
|
const rows = this.db
|
|
357
|
-
.prepare(
|
|
375
|
+
.prepare(`SELECT * FROM ${this.p("recipients")} WHERE message_id = ?`)
|
|
358
376
|
.all(messageId);
|
|
359
377
|
return rows.map((r) => ({
|
|
360
378
|
agent_id: r.agent_id,
|
|
@@ -366,7 +384,7 @@ export class SqliteStorage {
|
|
|
366
384
|
}
|
|
367
385
|
getParticipants(conversationId) {
|
|
368
386
|
const rows = this.db
|
|
369
|
-
.prepare(
|
|
387
|
+
.prepare(`SELECT * FROM ${this.p("participants")} WHERE conversation_id = ?`)
|
|
370
388
|
.all(conversationId);
|
|
371
389
|
return rows.map((r) => ({
|
|
372
390
|
agent_id: r.agent_id,
|
|
@@ -403,7 +421,9 @@ export class SqliteStorage {
|
|
|
403
421
|
};
|
|
404
422
|
}
|
|
405
423
|
close() {
|
|
406
|
-
this.
|
|
424
|
+
if (!this.externalDb) {
|
|
425
|
+
this.db.close();
|
|
426
|
+
}
|
|
407
427
|
}
|
|
408
428
|
}
|
|
409
429
|
function rowToAgent(row) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sqlite.js","sourceRoot":"","sources":["../../src/storage/sqlite.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"sqlite.js","sourceRoot":"","sources":["../../src/storage/sqlite.ts"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
package/src/index.ts
CHANGED
|
@@ -86,6 +86,10 @@ export interface CreateOptions {
|
|
|
86
86
|
config?: Partial<InboxConfig>;
|
|
87
87
|
/** Use SQLite storage at this path (":memory:" for in-memory SQLite) */
|
|
88
88
|
sqlitePath?: string;
|
|
89
|
+
/** Use an external better-sqlite3 Database handle (co-locate tables in another DB) */
|
|
90
|
+
sqliteDb?: import("better-sqlite3").Database;
|
|
91
|
+
/** Table name prefix when co-locating in an external DB (e.g. "inbox_") */
|
|
92
|
+
sqlitePrefix?: string;
|
|
89
93
|
/** HTTP port for JSON-RPC endpoint (0 = disabled) */
|
|
90
94
|
httpPort?: number;
|
|
91
95
|
/** Webhook URLs for push notifications */
|
|
@@ -103,10 +107,21 @@ export async function createAgentInbox(
|
|
|
103
107
|
): Promise<AgentInbox> {
|
|
104
108
|
const config = { ...loadConfig(), ...opts.config };
|
|
105
109
|
|
|
106
|
-
// 1. Storage — SQLite
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
+
// 1. Storage — SQLite (own file, external DB, or in-memory fallback)
|
|
111
|
+
let storage: Storage;
|
|
112
|
+
if (opts.sqliteDb) {
|
|
113
|
+
storage = new SqliteStorage({
|
|
114
|
+
db: opts.sqliteDb,
|
|
115
|
+
prefix: opts.sqlitePrefix,
|
|
116
|
+
});
|
|
117
|
+
} else if (opts.sqlitePath) {
|
|
118
|
+
storage = new SqliteStorage({
|
|
119
|
+
path: opts.sqlitePath,
|
|
120
|
+
prefix: opts.sqlitePrefix,
|
|
121
|
+
});
|
|
122
|
+
} else {
|
|
123
|
+
storage = new InMemoryStorage();
|
|
124
|
+
}
|
|
110
125
|
|
|
111
126
|
// 2. Event bus (internal)
|
|
112
127
|
const events = new EventEmitter();
|
package/src/storage/sqlite.ts
CHANGED
|
@@ -12,22 +12,42 @@ import type {
|
|
|
12
12
|
import type { Storage, InboxQuery, ThreadQuery } from "./interface.js";
|
|
13
13
|
|
|
14
14
|
export interface SqliteStorageOptions {
|
|
15
|
-
|
|
15
|
+
/** Open a new database at this path (":memory:" for in-memory). Ignored if `db` is provided. */
|
|
16
|
+
path?: string;
|
|
17
|
+
/** Use an externally-managed database handle. When provided, the handle is borrowed —
|
|
18
|
+
* close() will NOT close it (the caller owns its lifecycle). */
|
|
19
|
+
db?: Database.Database;
|
|
20
|
+
/** Table name prefix (e.g. "inbox_"). Defaults to "" (no prefix). */
|
|
21
|
+
prefix?: string;
|
|
16
22
|
}
|
|
17
23
|
|
|
18
24
|
export class SqliteStorage implements Storage {
|
|
19
25
|
private db: Database.Database;
|
|
26
|
+
private externalDb: boolean;
|
|
27
|
+
/** Prefixed table name helper */
|
|
28
|
+
private p: (table: string) => string;
|
|
20
29
|
|
|
21
30
|
constructor(opts: SqliteStorageOptions) {
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
31
|
+
if (opts.db) {
|
|
32
|
+
this.db = opts.db;
|
|
33
|
+
this.externalDb = true;
|
|
34
|
+
} else {
|
|
35
|
+
const path = opts.path ?? ":memory:";
|
|
36
|
+
this.db = new Database(path);
|
|
37
|
+
this.db.pragma("journal_mode = WAL");
|
|
38
|
+
this.db.pragma("foreign_keys = ON");
|
|
39
|
+
this.externalDb = false;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
const prefix = opts.prefix ?? "";
|
|
43
|
+
this.p = (table: string) => `${prefix}${table}`;
|
|
25
44
|
this.migrate();
|
|
26
45
|
}
|
|
27
46
|
|
|
28
47
|
private migrate(): void {
|
|
48
|
+
const t = this.p;
|
|
29
49
|
this.db.exec(`
|
|
30
|
-
CREATE TABLE IF NOT EXISTS agents (
|
|
50
|
+
CREATE TABLE IF NOT EXISTS ${t("agents")} (
|
|
31
51
|
agent_id TEXT PRIMARY KEY,
|
|
32
52
|
display_name TEXT,
|
|
33
53
|
program TEXT,
|
|
@@ -39,7 +59,7 @@ export class SqliteStorage implements Storage {
|
|
|
39
59
|
last_active_at TEXT NOT NULL
|
|
40
60
|
);
|
|
41
61
|
|
|
42
|
-
CREATE TABLE IF NOT EXISTS messages (
|
|
62
|
+
CREATE TABLE IF NOT EXISTS ${t("messages")} (
|
|
43
63
|
id TEXT PRIMARY KEY,
|
|
44
64
|
scope TEXT NOT NULL DEFAULT 'default',
|
|
45
65
|
sender_id TEXT NOT NULL,
|
|
@@ -53,7 +73,7 @@ export class SqliteStorage implements Storage {
|
|
|
53
73
|
created_at TEXT NOT NULL
|
|
54
74
|
);
|
|
55
75
|
|
|
56
|
-
CREATE TABLE IF NOT EXISTS recipients (
|
|
76
|
+
CREATE TABLE IF NOT EXISTS ${t("recipients")} (
|
|
57
77
|
message_id TEXT NOT NULL,
|
|
58
78
|
agent_id TEXT NOT NULL,
|
|
59
79
|
kind TEXT NOT NULL DEFAULT 'to',
|
|
@@ -61,10 +81,10 @@ export class SqliteStorage implements Storage {
|
|
|
61
81
|
read_at TEXT,
|
|
62
82
|
ack_at TEXT,
|
|
63
83
|
PRIMARY KEY (message_id, agent_id),
|
|
64
|
-
FOREIGN KEY (message_id) REFERENCES messages(id)
|
|
84
|
+
FOREIGN KEY (message_id) REFERENCES ${t("messages")}(id)
|
|
65
85
|
);
|
|
66
86
|
|
|
67
|
-
CREATE TABLE IF NOT EXISTS conversations (
|
|
87
|
+
CREATE TABLE IF NOT EXISTS ${t("conversations")} (
|
|
68
88
|
id TEXT PRIMARY KEY,
|
|
69
89
|
scope TEXT NOT NULL DEFAULT 'default',
|
|
70
90
|
subject TEXT,
|
|
@@ -74,16 +94,16 @@ export class SqliteStorage implements Storage {
|
|
|
74
94
|
updated_at TEXT NOT NULL
|
|
75
95
|
);
|
|
76
96
|
|
|
77
|
-
CREATE TABLE IF NOT EXISTS participants (
|
|
97
|
+
CREATE TABLE IF NOT EXISTS ${t("participants")} (
|
|
78
98
|
conversation_id TEXT NOT NULL,
|
|
79
99
|
agent_id TEXT NOT NULL,
|
|
80
100
|
role TEXT,
|
|
81
101
|
joined_at TEXT NOT NULL,
|
|
82
102
|
PRIMARY KEY (conversation_id, agent_id),
|
|
83
|
-
FOREIGN KEY (conversation_id) REFERENCES conversations(id)
|
|
103
|
+
FOREIGN KEY (conversation_id) REFERENCES ${t("conversations")}(id)
|
|
84
104
|
);
|
|
85
105
|
|
|
86
|
-
CREATE TABLE IF NOT EXISTS turns (
|
|
106
|
+
CREATE TABLE IF NOT EXISTS ${t("turns")} (
|
|
87
107
|
id TEXT PRIMARY KEY,
|
|
88
108
|
conversation_id TEXT NOT NULL,
|
|
89
109
|
participant_id TEXT NOT NULL,
|
|
@@ -93,62 +113,62 @@ export class SqliteStorage implements Storage {
|
|
|
93
113
|
thread_id TEXT,
|
|
94
114
|
in_reply_to TEXT,
|
|
95
115
|
created_at TEXT NOT NULL,
|
|
96
|
-
FOREIGN KEY (conversation_id) REFERENCES conversations(id)
|
|
116
|
+
FOREIGN KEY (conversation_id) REFERENCES ${t("conversations")}(id)
|
|
97
117
|
);
|
|
98
118
|
|
|
99
|
-
CREATE TABLE IF NOT EXISTS threads (
|
|
119
|
+
CREATE TABLE IF NOT EXISTS ${t("threads")} (
|
|
100
120
|
id TEXT PRIMARY KEY,
|
|
101
121
|
conversation_id TEXT NOT NULL,
|
|
102
122
|
root_turn_id TEXT NOT NULL,
|
|
103
123
|
parent_thread_id TEXT,
|
|
104
124
|
subject TEXT,
|
|
105
125
|
created_at TEXT NOT NULL,
|
|
106
|
-
FOREIGN KEY (conversation_id) REFERENCES conversations(id)
|
|
126
|
+
FOREIGN KEY (conversation_id) REFERENCES ${t("conversations")}(id)
|
|
107
127
|
);
|
|
108
128
|
|
|
109
129
|
-- Indexes for common queries
|
|
110
|
-
CREATE INDEX IF NOT EXISTS
|
|
111
|
-
CREATE INDEX IF NOT EXISTS
|
|
112
|
-
CREATE INDEX IF NOT EXISTS
|
|
113
|
-
CREATE INDEX IF NOT EXISTS
|
|
114
|
-
CREATE INDEX IF NOT EXISTS
|
|
115
|
-
CREATE INDEX IF NOT EXISTS
|
|
116
|
-
CREATE INDEX IF NOT EXISTS
|
|
117
|
-
CREATE INDEX IF NOT EXISTS
|
|
130
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_scope ON ${t("messages")}(scope);
|
|
131
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_sender ON ${t("messages")}(sender_id);
|
|
132
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_thread_tag ON ${t("messages")}(thread_tag, scope);
|
|
133
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_conversation ON ${t("messages")}(conversation_id);
|
|
134
|
+
CREATE INDEX IF NOT EXISTS idx_${t("messages")}_created ON ${t("messages")}(created_at);
|
|
135
|
+
CREATE INDEX IF NOT EXISTS idx_${t("recipients")}_agent ON ${t("recipients")}(agent_id);
|
|
136
|
+
CREATE INDEX IF NOT EXISTS idx_${t("turns")}_conversation ON ${t("turns")}(conversation_id);
|
|
137
|
+
CREATE INDEX IF NOT EXISTS idx_${t("agents")}_scope ON ${t("agents")}(scope);
|
|
118
138
|
|
|
119
139
|
-- FTS5 virtual table for full-text search
|
|
120
|
-
CREATE VIRTUAL TABLE IF NOT EXISTS messages_fts USING fts5(
|
|
140
|
+
CREATE VIRTUAL TABLE IF NOT EXISTS ${t("messages_fts")} USING fts5(
|
|
121
141
|
id UNINDEXED,
|
|
122
142
|
subject,
|
|
123
143
|
text_content,
|
|
124
|
-
content='messages',
|
|
144
|
+
content='${t("messages")}',
|
|
125
145
|
content_rowid='rowid'
|
|
126
146
|
);
|
|
127
147
|
|
|
128
148
|
-- Triggers to keep FTS in sync
|
|
129
|
-
CREATE TRIGGER IF NOT EXISTS messages_ai AFTER INSERT ON messages BEGIN
|
|
130
|
-
INSERT INTO messages_fts(rowid, id, subject, text_content)
|
|
149
|
+
CREATE TRIGGER IF NOT EXISTS ${t("messages_ai")} AFTER INSERT ON ${t("messages")} BEGIN
|
|
150
|
+
INSERT INTO ${t("messages_fts")}(rowid, id, subject, text_content)
|
|
131
151
|
VALUES (NEW.rowid, NEW.id, NEW.subject,
|
|
132
152
|
CASE WHEN json_extract(NEW.content, '$.type') = 'text'
|
|
133
153
|
THEN json_extract(NEW.content, '$.text')
|
|
134
154
|
ELSE '' END);
|
|
135
155
|
END;
|
|
136
156
|
|
|
137
|
-
CREATE TRIGGER IF NOT EXISTS messages_ad AFTER DELETE ON messages BEGIN
|
|
138
|
-
INSERT INTO messages_fts(messages_fts, rowid, id, subject, text_content)
|
|
157
|
+
CREATE TRIGGER IF NOT EXISTS ${t("messages_ad")} AFTER DELETE ON ${t("messages")} BEGIN
|
|
158
|
+
INSERT INTO ${t("messages_fts")}(${t("messages_fts")}, rowid, id, subject, text_content)
|
|
139
159
|
VALUES ('delete', OLD.rowid, OLD.id, OLD.subject,
|
|
140
160
|
CASE WHEN json_extract(OLD.content, '$.type') = 'text'
|
|
141
161
|
THEN json_extract(OLD.content, '$.text')
|
|
142
162
|
ELSE '' END);
|
|
143
163
|
END;
|
|
144
164
|
|
|
145
|
-
CREATE TRIGGER IF NOT EXISTS messages_au AFTER UPDATE ON messages BEGIN
|
|
146
|
-
INSERT INTO messages_fts(messages_fts, rowid, id, subject, text_content)
|
|
165
|
+
CREATE TRIGGER IF NOT EXISTS ${t("messages_au")} AFTER UPDATE ON ${t("messages")} BEGIN
|
|
166
|
+
INSERT INTO ${t("messages_fts")}(${t("messages_fts")}, rowid, id, subject, text_content)
|
|
147
167
|
VALUES ('delete', OLD.rowid, OLD.id, OLD.subject,
|
|
148
168
|
CASE WHEN json_extract(OLD.content, '$.type') = 'text'
|
|
149
169
|
THEN json_extract(OLD.content, '$.text')
|
|
150
170
|
ELSE '' END);
|
|
151
|
-
INSERT INTO messages_fts(rowid, id, subject, text_content)
|
|
171
|
+
INSERT INTO ${t("messages_fts")}(rowid, id, subject, text_content)
|
|
152
172
|
VALUES (NEW.rowid, NEW.id, NEW.subject,
|
|
153
173
|
CASE WHEN json_extract(NEW.content, '$.type') = 'text'
|
|
154
174
|
THEN json_extract(NEW.content, '$.text')
|
|
@@ -161,7 +181,7 @@ export class SqliteStorage implements Storage {
|
|
|
161
181
|
|
|
162
182
|
getAgent(agentId: string): Agent | undefined {
|
|
163
183
|
const row = this.db
|
|
164
|
-
.prepare(
|
|
184
|
+
.prepare(`SELECT * FROM ${this.p("agents")} WHERE agent_id = ?`)
|
|
165
185
|
.get(agentId) as AgentRow | undefined;
|
|
166
186
|
return row ? rowToAgent(row) : undefined;
|
|
167
187
|
}
|
|
@@ -169,7 +189,7 @@ export class SqliteStorage implements Storage {
|
|
|
169
189
|
putAgent(agent: Agent): void {
|
|
170
190
|
this.db
|
|
171
191
|
.prepare(
|
|
172
|
-
`INSERT OR REPLACE INTO agents
|
|
192
|
+
`INSERT OR REPLACE INTO ${this.p("agents")}
|
|
173
193
|
(agent_id, display_name, program, model, scope, status, metadata, registered_at, last_active_at)
|
|
174
194
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`
|
|
175
195
|
)
|
|
@@ -189,15 +209,15 @@ export class SqliteStorage implements Storage {
|
|
|
189
209
|
listAgents(scope?: string): Agent[] {
|
|
190
210
|
if (scope) {
|
|
191
211
|
return (
|
|
192
|
-
this.db.prepare(
|
|
212
|
+
this.db.prepare(`SELECT * FROM ${this.p("agents")} WHERE scope = ?`).all(scope) as AgentRow[]
|
|
193
213
|
).map(rowToAgent);
|
|
194
214
|
}
|
|
195
|
-
return (this.db.prepare(
|
|
215
|
+
return (this.db.prepare(`SELECT * FROM ${this.p("agents")}`).all() as AgentRow[]).map(rowToAgent);
|
|
196
216
|
}
|
|
197
217
|
|
|
198
218
|
removeAgent(agentId: string): boolean {
|
|
199
219
|
const result = this.db
|
|
200
|
-
.prepare(
|
|
220
|
+
.prepare(`DELETE FROM ${this.p("agents")} WHERE agent_id = ?`)
|
|
201
221
|
.run(agentId);
|
|
202
222
|
return result.changes > 0;
|
|
203
223
|
}
|
|
@@ -206,7 +226,7 @@ export class SqliteStorage implements Storage {
|
|
|
206
226
|
|
|
207
227
|
getMessage(id: string): Message | undefined {
|
|
208
228
|
const row = this.db
|
|
209
|
-
.prepare(
|
|
229
|
+
.prepare(`SELECT * FROM ${this.p("messages")} WHERE id = ?`)
|
|
210
230
|
.get(id) as MessageRow | undefined;
|
|
211
231
|
if (!row) return undefined;
|
|
212
232
|
return this.rowToMessage(row);
|
|
@@ -214,12 +234,12 @@ export class SqliteStorage implements Storage {
|
|
|
214
234
|
|
|
215
235
|
putMessage(message: Message): Message {
|
|
216
236
|
const upsertMsg = this.db.prepare(
|
|
217
|
-
`INSERT OR REPLACE INTO messages
|
|
237
|
+
`INSERT OR REPLACE INTO ${this.p("messages")}
|
|
218
238
|
(id, scope, sender_id, subject, content, thread_tag, in_reply_to, conversation_id, importance, metadata, created_at)
|
|
219
239
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)`
|
|
220
240
|
);
|
|
221
241
|
const upsertRecipient = this.db.prepare(
|
|
222
|
-
`INSERT OR REPLACE INTO recipients
|
|
242
|
+
`INSERT OR REPLACE INTO ${this.p("recipients")}
|
|
223
243
|
(message_id, agent_id, kind, delivered_at, read_at, ack_at)
|
|
224
244
|
VALUES (?, ?, ?, ?, ?, ?)`
|
|
225
245
|
);
|
|
@@ -240,7 +260,7 @@ export class SqliteStorage implements Storage {
|
|
|
240
260
|
);
|
|
241
261
|
// Delete old recipients and re-insert
|
|
242
262
|
this.db
|
|
243
|
-
.prepare(
|
|
263
|
+
.prepare(`DELETE FROM ${this.p("recipients")} WHERE message_id = ?`)
|
|
244
264
|
.run(message.id);
|
|
245
265
|
for (const r of message.recipients) {
|
|
246
266
|
upsertRecipient.run(
|
|
@@ -258,9 +278,11 @@ export class SqliteStorage implements Storage {
|
|
|
258
278
|
}
|
|
259
279
|
|
|
260
280
|
getInbox(agentId: string, opts?: InboxQuery): Message[] {
|
|
281
|
+
const m = this.p("messages");
|
|
282
|
+
const r = this.p("recipients");
|
|
261
283
|
let sql = `
|
|
262
|
-
SELECT m.* FROM
|
|
263
|
-
JOIN
|
|
284
|
+
SELECT m.* FROM ${m} m
|
|
285
|
+
JOIN ${r} r ON r.message_id = m.id
|
|
264
286
|
WHERE r.agent_id = ?
|
|
265
287
|
`;
|
|
266
288
|
const params: unknown[] = [agentId];
|
|
@@ -285,14 +307,14 @@ export class SqliteStorage implements Storage {
|
|
|
285
307
|
getThread(query: ThreadQuery): Message[] {
|
|
286
308
|
const rows = this.db
|
|
287
309
|
.prepare(
|
|
288
|
-
|
|
310
|
+
`SELECT * FROM ${this.p("messages")} WHERE thread_tag = ? AND scope = ? ORDER BY created_at ASC`
|
|
289
311
|
)
|
|
290
312
|
.all(query.threadTag, query.scope) as MessageRow[];
|
|
291
313
|
return rows.map((row) => this.rowToMessage(row));
|
|
292
314
|
}
|
|
293
315
|
|
|
294
316
|
getSentMessages(agentId: string, limit?: number): Message[] {
|
|
295
|
-
let sql =
|
|
317
|
+
let sql = `SELECT * FROM ${this.p("messages")} WHERE sender_id = ? ORDER BY created_at ASC`;
|
|
296
318
|
const params: unknown[] = [agentId];
|
|
297
319
|
if (limit) {
|
|
298
320
|
sql += " LIMIT ?";
|
|
@@ -303,22 +325,24 @@ export class SqliteStorage implements Storage {
|
|
|
303
325
|
}
|
|
304
326
|
|
|
305
327
|
searchMessages(query: string, scope?: string): Message[] {
|
|
328
|
+
const m = this.p("messages");
|
|
329
|
+
const fts = this.p("messages_fts");
|
|
306
330
|
let sql: string;
|
|
307
331
|
let params: unknown[];
|
|
308
332
|
|
|
309
333
|
if (scope) {
|
|
310
334
|
sql = `
|
|
311
|
-
SELECT m.* FROM
|
|
312
|
-
JOIN
|
|
313
|
-
WHERE
|
|
335
|
+
SELECT m.* FROM ${m} m
|
|
336
|
+
JOIN ${fts} fts ON fts.id = m.id
|
|
337
|
+
WHERE ${fts} MATCH ? AND m.scope = ?
|
|
314
338
|
ORDER BY m.created_at ASC
|
|
315
339
|
`;
|
|
316
340
|
params = [query, scope];
|
|
317
341
|
} else {
|
|
318
342
|
sql = `
|
|
319
|
-
SELECT m.* FROM
|
|
320
|
-
JOIN
|
|
321
|
-
WHERE
|
|
343
|
+
SELECT m.* FROM ${m} m
|
|
344
|
+
JOIN ${fts} fts ON fts.id = m.id
|
|
345
|
+
WHERE ${fts} MATCH ?
|
|
322
346
|
ORDER BY m.created_at ASC
|
|
323
347
|
`;
|
|
324
348
|
params = [query];
|
|
@@ -336,7 +360,7 @@ export class SqliteStorage implements Storage {
|
|
|
336
360
|
private searchMessagesLike(query: string, scope?: string): Message[] {
|
|
337
361
|
const pattern = `%${query}%`;
|
|
338
362
|
let sql = `
|
|
339
|
-
SELECT * FROM messages
|
|
363
|
+
SELECT * FROM ${this.p("messages")}
|
|
340
364
|
WHERE (subject LIKE ? OR content LIKE ?)
|
|
341
365
|
`;
|
|
342
366
|
const params: unknown[] = [pattern, pattern];
|
|
@@ -353,7 +377,7 @@ export class SqliteStorage implements Storage {
|
|
|
353
377
|
|
|
354
378
|
getConversation(id: string): Conversation | undefined {
|
|
355
379
|
const row = this.db
|
|
356
|
-
.prepare(
|
|
380
|
+
.prepare(`SELECT * FROM ${this.p("conversations")} WHERE id = ?`)
|
|
357
381
|
.get(id) as ConversationRow | undefined;
|
|
358
382
|
if (!row) return undefined;
|
|
359
383
|
return this.rowToConversation(row);
|
|
@@ -363,7 +387,7 @@ export class SqliteStorage implements Storage {
|
|
|
363
387
|
this.db.transaction(() => {
|
|
364
388
|
this.db
|
|
365
389
|
.prepare(
|
|
366
|
-
`INSERT OR REPLACE INTO conversations
|
|
390
|
+
`INSERT OR REPLACE INTO ${this.p("conversations")}
|
|
367
391
|
(id, scope, subject, status, metadata, created_at, updated_at)
|
|
368
392
|
VALUES (?, ?, ?, ?, ?, ?, ?)`
|
|
369
393
|
)
|
|
@@ -378,10 +402,10 @@ export class SqliteStorage implements Storage {
|
|
|
378
402
|
);
|
|
379
403
|
// Re-sync participants
|
|
380
404
|
this.db
|
|
381
|
-
.prepare(
|
|
405
|
+
.prepare(`DELETE FROM ${this.p("participants")} WHERE conversation_id = ?`)
|
|
382
406
|
.run(conversation.id);
|
|
383
407
|
const insertP = this.db.prepare(
|
|
384
|
-
`INSERT INTO participants (conversation_id, agent_id, role, joined_at) VALUES (?, ?, ?, ?)`
|
|
408
|
+
`INSERT INTO ${this.p("participants")} (conversation_id, agent_id, role, joined_at) VALUES (?, ?, ?, ?)`
|
|
385
409
|
);
|
|
386
410
|
for (const p of conversation.participants) {
|
|
387
411
|
insertP.run(conversation.id, p.agent_id, p.role ?? null, p.joined_at);
|
|
@@ -394,11 +418,11 @@ export class SqliteStorage implements Storage {
|
|
|
394
418
|
let rows: ConversationRow[];
|
|
395
419
|
if (scope) {
|
|
396
420
|
rows = this.db
|
|
397
|
-
.prepare(
|
|
421
|
+
.prepare(`SELECT * FROM ${this.p("conversations")} WHERE scope = ? ORDER BY updated_at DESC`)
|
|
398
422
|
.all(scope) as ConversationRow[];
|
|
399
423
|
} else {
|
|
400
424
|
rows = this.db
|
|
401
|
-
.prepare(
|
|
425
|
+
.prepare(`SELECT * FROM ${this.p("conversations")} ORDER BY updated_at DESC`)
|
|
402
426
|
.all() as ConversationRow[];
|
|
403
427
|
}
|
|
404
428
|
return rows.map((row) => this.rowToConversation(row));
|
|
@@ -409,7 +433,7 @@ export class SqliteStorage implements Storage {
|
|
|
409
433
|
addTurn(turn: Turn): void {
|
|
410
434
|
this.db
|
|
411
435
|
.prepare(
|
|
412
|
-
`INSERT INTO turns
|
|
436
|
+
`INSERT INTO ${this.p("turns")}
|
|
413
437
|
(id, conversation_id, participant_id, source_message_id, content_type, content, thread_id, in_reply_to, created_at)
|
|
414
438
|
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`
|
|
415
439
|
)
|
|
@@ -429,7 +453,7 @@ export class SqliteStorage implements Storage {
|
|
|
429
453
|
getTurns(conversationId: string): Turn[] {
|
|
430
454
|
const rows = this.db
|
|
431
455
|
.prepare(
|
|
432
|
-
|
|
456
|
+
`SELECT * FROM ${this.p("turns")} WHERE conversation_id = ? ORDER BY created_at ASC`
|
|
433
457
|
)
|
|
434
458
|
.all(conversationId) as TurnRow[];
|
|
435
459
|
return rows.map(rowToTurn);
|
|
@@ -439,7 +463,7 @@ export class SqliteStorage implements Storage {
|
|
|
439
463
|
|
|
440
464
|
getThread2(id: string): Thread | undefined {
|
|
441
465
|
const row = this.db
|
|
442
|
-
.prepare(
|
|
466
|
+
.prepare(`SELECT * FROM ${this.p("threads")} WHERE id = ?`)
|
|
443
467
|
.get(id) as ThreadRow | undefined;
|
|
444
468
|
return row ? rowToThread(row) : undefined;
|
|
445
469
|
}
|
|
@@ -447,7 +471,7 @@ export class SqliteStorage implements Storage {
|
|
|
447
471
|
putThread(thread: Thread): Thread {
|
|
448
472
|
this.db
|
|
449
473
|
.prepare(
|
|
450
|
-
`INSERT OR REPLACE INTO threads
|
|
474
|
+
`INSERT OR REPLACE INTO ${this.p("threads")}
|
|
451
475
|
(id, conversation_id, root_turn_id, parent_thread_id, subject, created_at)
|
|
452
476
|
VALUES (?, ?, ?, ?, ?, ?)`
|
|
453
477
|
)
|
|
@@ -464,7 +488,7 @@ export class SqliteStorage implements Storage {
|
|
|
464
488
|
|
|
465
489
|
getThreadsByConversation(conversationId: string): Thread[] {
|
|
466
490
|
const rows = this.db
|
|
467
|
-
.prepare(
|
|
491
|
+
.prepare(`SELECT * FROM ${this.p("threads")} WHERE conversation_id = ?`)
|
|
468
492
|
.all(conversationId) as ThreadRow[];
|
|
469
493
|
return rows.map(rowToThread);
|
|
470
494
|
}
|
|
@@ -473,7 +497,7 @@ export class SqliteStorage implements Storage {
|
|
|
473
497
|
|
|
474
498
|
private getRecipients(messageId: string): Recipient[] {
|
|
475
499
|
const rows = this.db
|
|
476
|
-
.prepare(
|
|
500
|
+
.prepare(`SELECT * FROM ${this.p("recipients")} WHERE message_id = ?`)
|
|
477
501
|
.all(messageId) as RecipientRow[];
|
|
478
502
|
return rows.map((r) => ({
|
|
479
503
|
agent_id: r.agent_id,
|
|
@@ -486,7 +510,7 @@ export class SqliteStorage implements Storage {
|
|
|
486
510
|
|
|
487
511
|
private getParticipants(conversationId: string): Participant[] {
|
|
488
512
|
const rows = this.db
|
|
489
|
-
.prepare(
|
|
513
|
+
.prepare(`SELECT * FROM ${this.p("participants")} WHERE conversation_id = ?`)
|
|
490
514
|
.all(conversationId) as ParticipantRow[];
|
|
491
515
|
return rows.map((r) => ({
|
|
492
516
|
agent_id: r.agent_id,
|
|
@@ -526,7 +550,9 @@ export class SqliteStorage implements Storage {
|
|
|
526
550
|
}
|
|
527
551
|
|
|
528
552
|
close(): void {
|
|
529
|
-
this.
|
|
553
|
+
if (!this.externalDb) {
|
|
554
|
+
this.db.close();
|
|
555
|
+
}
|
|
530
556
|
}
|
|
531
557
|
}
|
|
532
558
|
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
import { describe, it, expect, beforeEach, afterEach } from "vitest";
|
|
2
|
+
import Database from "better-sqlite3";
|
|
3
|
+
import { SqliteStorage } from "../src/storage/sqlite.js";
|
|
4
|
+
import type { Agent, Message } from "../src/types.js";
|
|
5
|
+
|
|
6
|
+
function makeAgent(overrides: Partial<Agent> = {}): Agent {
|
|
7
|
+
return {
|
|
8
|
+
agent_id: "agent-1",
|
|
9
|
+
scope: "default",
|
|
10
|
+
status: "active",
|
|
11
|
+
metadata: {},
|
|
12
|
+
registered_at: "2025-01-01T00:00:00Z",
|
|
13
|
+
last_active_at: "2025-01-01T00:00:00Z",
|
|
14
|
+
...overrides,
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function makeMessage(overrides: Partial<Message> = {}): Message {
|
|
19
|
+
return {
|
|
20
|
+
id: "msg-1",
|
|
21
|
+
scope: "default",
|
|
22
|
+
sender_id: "agent-1",
|
|
23
|
+
recipients: [{ agent_id: "agent-2", kind: "to" }],
|
|
24
|
+
content: { type: "text", text: "hello" },
|
|
25
|
+
importance: "normal",
|
|
26
|
+
metadata: {},
|
|
27
|
+
created_at: "2025-01-01T00:00:00Z",
|
|
28
|
+
...overrides,
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
describe("SqliteStorage with prefix", () => {
|
|
33
|
+
let storage: SqliteStorage;
|
|
34
|
+
|
|
35
|
+
beforeEach(() => {
|
|
36
|
+
storage = new SqliteStorage({ path: ":memory:", prefix: "inbox_" });
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
afterEach(() => {
|
|
40
|
+
storage.close();
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
it("should create prefixed tables", () => {
|
|
44
|
+
storage.putAgent(makeAgent());
|
|
45
|
+
const agent = storage.getAgent("agent-1");
|
|
46
|
+
expect(agent).toBeDefined();
|
|
47
|
+
expect(agent!.agent_id).toBe("agent-1");
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
it("should store and retrieve messages with prefix", () => {
|
|
51
|
+
storage.putMessage(makeMessage());
|
|
52
|
+
const msg = storage.getMessage("msg-1");
|
|
53
|
+
expect(msg).toBeDefined();
|
|
54
|
+
expect(msg!.recipients).toHaveLength(1);
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
it("should support full-text search with prefix", () => {
|
|
58
|
+
storage.putMessage(
|
|
59
|
+
makeMessage({ id: "m1", content: { type: "text", text: "fix the auth bug" } })
|
|
60
|
+
);
|
|
61
|
+
storage.putMessage(
|
|
62
|
+
makeMessage({ id: "m2", content: { type: "text", text: "deploy the app" } })
|
|
63
|
+
);
|
|
64
|
+
const results = storage.searchMessages("auth");
|
|
65
|
+
expect(results).toHaveLength(1);
|
|
66
|
+
expect(results[0].id).toBe("m1");
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
it("should support conversations and turns with prefix", () => {
|
|
70
|
+
storage.putConversation({
|
|
71
|
+
id: "conv-1",
|
|
72
|
+
scope: "default",
|
|
73
|
+
status: "active",
|
|
74
|
+
participants: [{ agent_id: "alice", joined_at: "2025-01-01T00:00:00Z" }],
|
|
75
|
+
metadata: {},
|
|
76
|
+
created_at: "2025-01-01T00:00:00Z",
|
|
77
|
+
updated_at: "2025-01-01T00:00:00Z",
|
|
78
|
+
});
|
|
79
|
+
storage.addTurn({
|
|
80
|
+
id: "turn-1",
|
|
81
|
+
conversation_id: "conv-1",
|
|
82
|
+
participant_id: "alice",
|
|
83
|
+
content_type: "text",
|
|
84
|
+
content: { type: "text", text: "hello" },
|
|
85
|
+
created_at: "2025-01-01T00:00:00Z",
|
|
86
|
+
});
|
|
87
|
+
const turns = storage.getTurns("conv-1");
|
|
88
|
+
expect(turns).toHaveLength(1);
|
|
89
|
+
});
|
|
90
|
+
});
|
|
91
|
+
|
|
92
|
+
describe("SqliteStorage with external DB handle", () => {
|
|
93
|
+
let externalDb: Database.Database;
|
|
94
|
+
let storage: SqliteStorage;
|
|
95
|
+
|
|
96
|
+
beforeEach(() => {
|
|
97
|
+
externalDb = new Database(":memory:");
|
|
98
|
+
externalDb.pragma("journal_mode = WAL");
|
|
99
|
+
externalDb.pragma("foreign_keys = ON");
|
|
100
|
+
storage = new SqliteStorage({ db: externalDb, prefix: "inbox_" });
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
afterEach(() => {
|
|
104
|
+
storage.close(); // should NOT close the external DB
|
|
105
|
+
// Verify external DB is still usable
|
|
106
|
+
expect(() => externalDb.pragma("journal_mode")).not.toThrow();
|
|
107
|
+
externalDb.close();
|
|
108
|
+
});
|
|
109
|
+
|
|
110
|
+
it("should use the external DB handle", () => {
|
|
111
|
+
storage.putAgent(makeAgent());
|
|
112
|
+
const agent = storage.getAgent("agent-1");
|
|
113
|
+
expect(agent).toBeDefined();
|
|
114
|
+
});
|
|
115
|
+
|
|
116
|
+
it("should create prefixed tables in external DB", () => {
|
|
117
|
+
storage.putAgent(makeAgent());
|
|
118
|
+
// Query the external DB directly to verify prefixed table exists
|
|
119
|
+
const rows = externalDb
|
|
120
|
+
.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name LIKE 'inbox_%'")
|
|
121
|
+
.all() as { name: string }[];
|
|
122
|
+
const tableNames = rows.map((r) => r.name);
|
|
123
|
+
expect(tableNames).toContain("inbox_agents");
|
|
124
|
+
expect(tableNames).toContain("inbox_messages");
|
|
125
|
+
expect(tableNames).toContain("inbox_recipients");
|
|
126
|
+
});
|
|
127
|
+
|
|
128
|
+
it("should not close external DB on storage.close()", () => {
|
|
129
|
+
storage.close();
|
|
130
|
+
// External DB should still work
|
|
131
|
+
const result = externalDb.prepare("SELECT 1 as val").get() as { val: number };
|
|
132
|
+
expect(result.val).toBe(1);
|
|
133
|
+
});
|
|
134
|
+
|
|
135
|
+
it("should coexist with other tables in the same DB", () => {
|
|
136
|
+
// Create a non-inbox table in the same DB
|
|
137
|
+
externalDb.exec("CREATE TABLE IF NOT EXISTS hive_posts (id TEXT PRIMARY KEY, title TEXT)");
|
|
138
|
+
externalDb.prepare("INSERT INTO hive_posts (id, title) VALUES (?, ?)").run("p1", "Hello World");
|
|
139
|
+
|
|
140
|
+
// Inbox operations should work independently
|
|
141
|
+
storage.putAgent(makeAgent());
|
|
142
|
+
storage.putMessage(makeMessage());
|
|
143
|
+
|
|
144
|
+
// Both should be accessible
|
|
145
|
+
const agent = storage.getAgent("agent-1");
|
|
146
|
+
expect(agent).toBeDefined();
|
|
147
|
+
const post = externalDb.prepare("SELECT title FROM hive_posts WHERE id = ?").get("p1") as { title: string };
|
|
148
|
+
expect(post.title).toBe("Hello World");
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
describe("Two SqliteStorage instances sharing one DB", () => {
|
|
153
|
+
let sharedDb: Database.Database;
|
|
154
|
+
let storageA: SqliteStorage;
|
|
155
|
+
let storageB: SqliteStorage;
|
|
156
|
+
|
|
157
|
+
beforeEach(() => {
|
|
158
|
+
sharedDb = new Database(":memory:");
|
|
159
|
+
sharedDb.pragma("journal_mode = WAL");
|
|
160
|
+
sharedDb.pragma("foreign_keys = ON");
|
|
161
|
+
storageA = new SqliteStorage({ db: sharedDb, prefix: "inbox_a_" });
|
|
162
|
+
storageB = new SqliteStorage({ db: sharedDb, prefix: "inbox_b_" });
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
afterEach(() => {
|
|
166
|
+
storageA.close();
|
|
167
|
+
storageB.close();
|
|
168
|
+
sharedDb.close();
|
|
169
|
+
});
|
|
170
|
+
|
|
171
|
+
it("should isolate data between prefixes", () => {
|
|
172
|
+
storageA.putAgent(makeAgent({ agent_id: "alice" }));
|
|
173
|
+
storageB.putAgent(makeAgent({ agent_id: "bob" }));
|
|
174
|
+
|
|
175
|
+
expect(storageA.getAgent("alice")).toBeDefined();
|
|
176
|
+
expect(storageA.getAgent("bob")).toBeUndefined();
|
|
177
|
+
|
|
178
|
+
expect(storageB.getAgent("bob")).toBeDefined();
|
|
179
|
+
expect(storageB.getAgent("alice")).toBeUndefined();
|
|
180
|
+
});
|
|
181
|
+
|
|
182
|
+
it("should isolate messages between prefixes", () => {
|
|
183
|
+
storageA.putMessage(makeMessage({ id: "m1", sender_id: "alice" }));
|
|
184
|
+
storageB.putMessage(makeMessage({ id: "m2", sender_id: "bob" }));
|
|
185
|
+
|
|
186
|
+
expect(storageA.getMessage("m1")).toBeDefined();
|
|
187
|
+
expect(storageA.getMessage("m2")).toBeUndefined();
|
|
188
|
+
|
|
189
|
+
expect(storageB.getMessage("m2")).toBeDefined();
|
|
190
|
+
expect(storageB.getMessage("m1")).toBeUndefined();
|
|
191
|
+
});
|
|
192
|
+
});
|