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 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 */
@@ -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 if path provided, otherwise in-memory
57
- const storage = opts.sqlitePath
58
- ? new SqliteStorage({ path: opts.sqlitePath })
59
- : new InMemoryStorage();
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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"}
@@ -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: string;
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":"AACA,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,IAAI,EAAE,MAAM,CAAC;CACd;AAED,qBAAa,aAAc,YAAW,OAAO;IAC3C,OAAO,CAAC,EAAE,CAAoB;gBAElB,IAAI,EAAE,oBAAoB;IAOtC,OAAO,CAAC,OAAO;IAsIf,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;IAyBvD,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;IA+BxD,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;CAGd"}
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"}
@@ -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
- this.db = new Database(opts.path);
6
- this.db.pragma("journal_mode = WAL");
7
- this.db.pragma("foreign_keys = ON");
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 idx_messages_scope ON messages(scope);
93
- CREATE INDEX IF NOT EXISTS idx_messages_sender ON messages(sender_id);
94
- CREATE INDEX IF NOT EXISTS idx_messages_thread_tag ON messages(thread_tag, scope);
95
- CREATE INDEX IF NOT EXISTS idx_messages_conversation ON messages(conversation_id);
96
- CREATE INDEX IF NOT EXISTS idx_messages_created ON messages(created_at);
97
- CREATE INDEX IF NOT EXISTS idx_recipients_agent ON recipients(agent_id);
98
- CREATE INDEX IF NOT EXISTS idx_turns_conversation ON turns(conversation_id);
99
- CREATE INDEX IF NOT EXISTS idx_agents_scope ON agents(scope);
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("SELECT * FROM agents WHERE agent_id = ?")
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("SELECT * FROM agents WHERE scope = ?").all(scope).map(rowToAgent);
171
+ return this.db.prepare(`SELECT * FROM ${this.p("agents")} WHERE scope = ?`).all(scope).map(rowToAgent);
158
172
  }
159
- return this.db.prepare("SELECT * FROM agents").all().map(rowToAgent);
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("DELETE FROM agents WHERE agent_id = ?")
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("SELECT * FROM messages WHERE id = ?")
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("DELETE FROM recipients WHERE message_id = ?")
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 messages m
198
- JOIN recipients r ON r.message_id = m.id
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("SELECT * FROM messages WHERE thread_tag = ? AND scope = ? ORDER BY created_at ASC")
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 = "SELECT * FROM messages WHERE sender_id = ? ORDER BY created_at ASC";
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 messages m
239
- JOIN messages_fts fts ON fts.id = m.id
240
- WHERE messages_fts MATCH ? AND m.scope = ?
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 messages m
248
- JOIN messages_fts fts ON fts.id = m.id
249
- WHERE messages_fts MATCH ?
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("SELECT * FROM conversations WHERE id = ?")
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("DELETE FROM participants WHERE conversation_id = ?")
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("SELECT * FROM conversations WHERE scope = ? ORDER BY updated_at DESC")
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("SELECT * FROM conversations ORDER BY updated_at DESC")
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("SELECT * FROM turns WHERE conversation_id = ? ORDER BY created_at ASC")
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("SELECT * FROM threads WHERE id = ?")
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("SELECT * FROM threads WHERE conversation_id = ?")
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("SELECT * FROM recipients WHERE message_id = ?")
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("SELECT * FROM participants WHERE conversation_id = ?")
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.db.close();
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":"AAAA,OAAO,QAAQ,MAAM,gBAAgB,CAAC;AAiBtC,MAAM,OAAO,aAAa;IAChB,EAAE,CAAoB;IAE9B,YAAY,IAA0B;QACpC,IAAI,CAAC,EAAE,GAAG,IAAI,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,oBAAoB,CAAC,CAAC;QACrC,IAAI,CAAC,EAAE,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;QACpC,IAAI,CAAC,OAAO,EAAE,CAAC;IACjB,CAAC;IAEO,OAAO;QACb,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAgIZ,CAAC,CAAC;IACL,CAAC;IAED,iBAAiB;IAEjB,QAAQ,CAAC,OAAe;QACtB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CAAC,yCAAyC,CAAC;aAClD,GAAG,CAAC,OAAO,CAAyB,CAAC;QACxC,OAAO,GAAG,CAAC,CAAC,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC3C,CAAC;IAED,QAAQ,CAAC,KAAY;QACnB,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;4CAEoC,CACrC;aACA,GAAG,CACF,KAAK,CAAC,QAAQ,EACd,KAAK,CAAC,YAAY,IAAI,IAAI,EAC1B,KAAK,CAAC,OAAO,IAAI,IAAI,EACrB,KAAK,CAAC,KAAK,IAAI,IAAI,EACnB,KAAK,CAAC,KAAK,EACX,KAAK,CAAC,MAAM,EACZ,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,CAAC,EAC9B,KAAK,CAAC,aAAa,EACnB,KAAK,CAAC,cAAc,CACrB,CAAC;IACN,CAAC;IAED,UAAU,CAAC,KAAc;QACvB,IAAI,KAAK,EAAE,CAAC;YACV,OACE,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,sCAAsC,CAAC,CAAC,GAAG,CAAC,KAAK,CAClE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACpB,CAAC;QACD,OAAQ,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC,GAAG,EAAiB,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACvF,CAAC;IAED,WAAW,CAAC,OAAe;QACzB,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE;aACnB,OAAO,CAAC,uCAAuC,CAAC;aAChD,GAAG,CAAC,OAAO,CAAC,CAAC;QAChB,OAAO,MAAM,CAAC,OAAO,GAAG,CAAC,CAAC;IAC5B,CAAC;IAED,mBAAmB;IAEnB,UAAU,CAAC,EAAU;QACnB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CAAC,qCAAqC,CAAC;aAC9C,GAAG,CAAC,EAAE,CAA2B,CAAC;QACrC,IAAI,CAAC,GAAG;YAAE,OAAO,SAAS,CAAC;QAC3B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;IAChC,CAAC;IAED,UAAU,CAAC,OAAgB;QACzB,MAAM,SAAS,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAC/B;;gDAE0C,CAC3C,CAAC;QACF,MAAM,eAAe,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CACrC;;iCAE2B,CAC5B,CAAC;QAEF,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE;YACvB,SAAS,CAAC,GAAG,CACX,OAAO,CAAC,EAAE,EACV,OAAO,CAAC,KAAK,EACb,OAAO,CAAC,SAAS,EACjB,OAAO,CAAC,OAAO,IAAI,IAAI,EACvB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,EAC/B,OAAO,CAAC,UAAU,IAAI,IAAI,EAC1B,OAAO,CAAC,WAAW,IAAI,IAAI,EAC3B,OAAO,CAAC,eAAe,IAAI,IAAI,EAC/B,OAAO,CAAC,UAAU,EAClB,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAChC,OAAO,CAAC,UAAU,CACnB,CAAC;YACF,sCAAsC;YACtC,IAAI,CAAC,EAAE;iBACJ,OAAO,CAAC,6CAA6C,CAAC;iBACtD,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;YACnB,KAAK,MAAM,CAAC,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;gBACnC,eAAe,CAAC,GAAG,CACjB,OAAO,CAAC,EAAE,EACV,CAAC,CAAC,QAAQ,EACV,CAAC,CAAC,IAAI,EACN,CAAC,CAAC,YAAY,IAAI,IAAI,EACtB,CAAC,CAAC,OAAO,IAAI,IAAI,EACjB,CAAC,CAAC,MAAM,IAAI,IAAI,CACjB,CAAC;YACJ,CAAC;QACH,CAAC,CAAC,EAAE,CAAC;QAEL,OAAO,OAAO,CAAC;IACjB,CAAC;IAED,QAAQ,CAAC,OAAe,EAAE,IAAiB;QACzC,IAAI,GAAG,GAAG;;;;KAIT,CAAC;QACF,MAAM,MAAM,GAAc,CAAC,OAAO,CAAC,CAAC;QAEpC,IAAI,IAAI,EAAE,UAAU,EAAE,CAAC;YACrB,GAAG,IAAI,wBAAwB,CAAC;QAClC,CAAC;QACD,IAAI,IAAI,EAAE,KAAK,EAAE,CAAC;YAChB,GAAG,IAAI,wBAAwB,CAAC;YAChC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;QACD,GAAG,IAAI,4BAA4B,CAAC;QACpC,IAAI,IAAI,EAAE,KAAK,EAAE,CAAC;YAChB,GAAG,IAAI,UAAU,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1B,CAAC;QAED,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAiB,CAAC;QACjE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;IACnD,CAAC;IAED,SAAS,CAAC,KAAkB;QAC1B,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE;aACjB,OAAO,CACN,mFAAmF,CACpF;aACA,GAAG,CAAC,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC,KAAK,CAAiB,CAAC;QACrD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;IACnD,CAAC;IAED,eAAe,CAAC,OAAe,EAAE,KAAc;QAC7C,IAAI,GAAG,GAAG,oEAAoE,CAAC;QAC/E,MAAM,MAAM,GAAc,CAAC,OAAO,CAAC,CAAC;QACpC,IAAI,KAAK,EAAE,CAAC;YACV,GAAG,IAAI,UAAU,CAAC;YAClB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAiB,CAAC;QACjE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;IACnD,CAAC;IAED,cAAc,CAAC,KAAa,EAAE,KAAc;QAC1C,IAAI,GAAW,CAAC;QAChB,IAAI,MAAiB,CAAC;QAEtB,IAAI,KAAK,EAAE,CAAC;YACV,GAAG,GAAG;;;;;OAKL,CAAC;YACF,MAAM,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC1B,CAAC;aAAM,CAAC;YACN,GAAG,GAAG;;;;;OAKL,CAAC;YACF,MAAM,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,CAAC;QAED,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAiB,CAAC;YACjE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;QACnD,CAAC;QAAC,MAAM,CAAC;YACP,6CAA6C;YAC7C,OAAO,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC;IAEO,kBAAkB,CAAC,KAAa,EAAE,KAAc;QACtD,MAAM,OAAO,GAAG,IAAI,KAAK,GAAG,CAAC;QAC7B,IAAI,GAAG,GAAG;;;KAGT,CAAC;QACF,MAAM,MAAM,GAAc,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAC7C,IAAI,KAAK,EAAE,CAAC;YACV,GAAG,IAAI,gBAAgB,CAAC;YACxB,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC;QACD,GAAG,IAAI,0BAA0B,CAAC;QAClC,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,MAAM,CAAiB,CAAC;QACjE,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC;IACnD,CAAC;IAED,wBAAwB;IAExB,eAAe,CAAC,EAAU;QACxB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CAAC,0CAA0C,CAAC;aACnD,GAAG,CAAC,EAAE,CAAgC,CAAC;QAC1C,IAAI,CAAC,GAAG;YAAE,OAAO,SAAS,CAAC;QAC3B,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAED,eAAe,CAAC,YAA0B;QACxC,IAAI,CAAC,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE;YACvB,IAAI,CAAC,EAAE;iBACJ,OAAO,CACN;;wCAE8B,CAC/B;iBACA,GAAG,CACF,YAAY,CAAC,EAAE,EACf,YAAY,CAAC,KAAK,EAClB,YAAY,CAAC,OAAO,IAAI,IAAI,EAC5B,YAAY,CAAC,MAAM,EACnB,IAAI,CAAC,SAAS,CAAC,YAAY,CAAC,QAAQ,CAAC,EACrC,YAAY,CAAC,UAAU,EACvB,YAAY,CAAC,UAAU,CACxB,CAAC;YACJ,uBAAuB;YACvB,IAAI,CAAC,EAAE;iBACJ,OAAO,CAAC,oDAAoD,CAAC;iBAC7D,GAAG,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;YACxB,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,OAAO,CAC7B,2FAA2F,CAC5F,CAAC;YACF,KAAK,MAAM,CAAC,IAAI,YAAY,CAAC,YAAY,EAAE,CAAC;gBAC1C,OAAO,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC;YACxE,CAAC;QACH,CAAC,CAAC,EAAE,CAAC;QACL,OAAO,YAAY,CAAC;IACtB,CAAC;IAED,iBAAiB,CAAC,KAAc;QAC9B,IAAI,IAAuB,CAAC;QAC5B,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,GAAG,IAAI,CAAC,EAAE;iBACX,OAAO,CAAC,sEAAsE,CAAC;iBAC/E,GAAG,CAAC,KAAK,CAAsB,CAAC;QACrC,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,IAAI,CAAC,EAAE;iBACX,OAAO,CAAC,sDAAsD,CAAC;iBAC/D,GAAG,EAAuB,CAAC;QAChC,CAAC;QACD,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC,CAAC;IACxD,CAAC;IAED,gBAAgB;IAEhB,OAAO,CAAC,IAAU;QAChB,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;4CAEoC,CACrC;aACA,GAAG,CACF,IAAI,CAAC,EAAE,EACP,IAAI,CAAC,eAAe,EACpB,IAAI,CAAC,cAAc,EACnB,IAAI,CAAC,iBAAiB,IAAI,IAAI,EAC9B,IAAI,CAAC,YAAY,EACjB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,EAC5B,IAAI,CAAC,SAAS,IAAI,IAAI,EACtB,IAAI,CAAC,WAAW,IAAI,IAAI,EACxB,IAAI,CAAC,UAAU,CAChB,CAAC;IACN,CAAC;IAED,QAAQ,CAAC,cAAsB;QAC7B,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE;aACjB,OAAO,CACN,uEAAuE,CACxE;aACA,GAAG,CAAC,cAAc,CAAc,CAAC;QACpC,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IAC7B,CAAC;IAED,kBAAkB;IAElB,UAAU,CAAC,EAAU;QACnB,MAAM,GAAG,GAAG,IAAI,CAAC,EAAE;aAChB,OAAO,CAAC,oCAAoC,CAAC;aAC7C,GAAG,CAAC,EAAE,CAA0B,CAAC;QACpC,OAAO,GAAG,CAAC,CAAC,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;IAC5C,CAAC;IAED,SAAS,CAAC,MAAc;QACtB,IAAI,CAAC,EAAE;aACJ,OAAO,CACN;;mCAE2B,CAC5B;aACA,GAAG,CACF,MAAM,CAAC,EAAE,EACT,MAAM,CAAC,eAAe,EACtB,MAAM,CAAC,YAAY,EACnB,MAAM,CAAC,gBAAgB,IAAI,IAAI,EAC/B,MAAM,CAAC,OAAO,IAAI,IAAI,EACtB,MAAM,CAAC,UAAU,CAClB,CAAC;QACJ,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,wBAAwB,CAAC,cAAsB;QAC7C,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE;aACjB,OAAO,CAAC,iDAAiD,CAAC;aAC1D,GAAG,CAAC,cAAc,CAAgB,CAAC;QACtC,OAAO,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC;IAC/B,CAAC;IAED,kBAAkB;IAEV,aAAa,CAAC,SAAiB;QACrC,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE;aACjB,OAAO,CAAC,+CAA+C,CAAC;aACxD,GAAG,CAAC,SAAS,CAAmB,CAAC;QACpC,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACtB,QAAQ,EAAE,CAAC,CAAC,QAAQ;YACpB,IAAI,EAAE,CAAC,CAAC,IAAyB;YACjC,YAAY,EAAE,CAAC,CAAC,YAAY,IAAI,SAAS;YACzC,OAAO,EAAE,CAAC,CAAC,OAAO,IAAI,SAAS;YAC/B,MAAM,EAAE,CAAC,CAAC,MAAM,IAAI,SAAS;SAC9B,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,eAAe,CAAC,cAAsB;QAC5C,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE;aACjB,OAAO,CAAC,sDAAsD,CAAC;aAC/D,GAAG,CAAC,cAAc,CAAqB,CAAC;QAC3C,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;YACtB,QAAQ,EAAE,CAAC,CAAC,QAAQ;YACpB,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,SAAS;YACzB,SAAS,EAAE,CAAC,CAAC,SAAS;SACvB,CAAC,CAAC,CAAC;IACN,CAAC;IAEO,YAAY,CAAC,GAAe;QAClC,OAAO;YACL,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,KAAK,EAAE,GAAG,CAAC,KAAK;YAChB,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,UAAU,EAAE,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC;YACtC,OAAO,EAAE,GAAG,CAAC,OAAO,IAAI,SAAS;YACjC,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAmB;YAClD,UAAU,EAAE,GAAG,CAAC,UAAU,IAAI,SAAS;YACvC,WAAW,EAAE,GAAG,CAAC,WAAW,IAAI,SAAS;YACzC,eAAe,EAAE,GAAG,CAAC,eAAe,IAAI,SAAS;YACjD,UAAU,EAAE,GAAG,CAAC,UAAmC;YACnD,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC;YAClC,UAAU,EAAE,GAAG,CAAC,UAAU;SAC3B,CAAC;IACJ,CAAC;IAEO,iBAAiB,CAAC,GAAoB;QAC5C,OAAO;YACL,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,KAAK,EAAE,GAAG,CAAC,KAAK;YAChB,OAAO,EAAE,GAAG,CAAC,OAAO,IAAI,SAAS;YACjC,MAAM,EAAE,GAAG,CAAC,MAAgC;YAC5C,YAAY,EAAE,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1C,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC;YAClC,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,UAAU,EAAE,GAAG,CAAC,UAAU;SAC3B,CAAC;IACJ,CAAC;IAED,KAAK;QACH,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC;IAClB,CAAC;CACF;AA6ED,SAAS,UAAU,CAAC,GAAa;IAC/B,OAAO;QACL,QAAQ,EAAE,GAAG,CAAC,QAAQ;QACtB,YAAY,EAAE,GAAG,CAAC,YAAY,IAAI,SAAS;QAC3C,OAAO,EAAE,GAAG,CAAC,OAAO,IAAI,SAAS;QACjC,KAAK,EAAE,GAAG,CAAC,KAAK,IAAI,SAAS;QAC7B,KAAK,EAAE,GAAG,CAAC,KAAK;QAChB,MAAM,EAAE,GAAG,CAAC,MAAyB;QACrC,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC;QAClC,aAAa,EAAE,GAAG,CAAC,aAAa;QAChC,cAAc,EAAE,GAAG,CAAC,cAAc;KACnC,CAAC;AACJ,CAAC;AAED,SAAS,SAAS,CAAC,GAAY;IAC7B,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,eAAe,EAAE,GAAG,CAAC,eAAe;QACpC,cAAc,EAAE,GAAG,CAAC,cAAc;QAClC,iBAAiB,EAAE,GAAG,CAAC,iBAAiB,IAAI,SAAS;QACrD,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAmB;QAClD,SAAS,EAAE,GAAG,CAAC,SAAS,IAAI,SAAS;QACrC,WAAW,EAAE,GAAG,CAAC,WAAW,IAAI,SAAS;QACzC,UAAU,EAAE,GAAG,CAAC,UAAU;KAC3B,CAAC;AACJ,CAAC;AAED,SAAS,WAAW,CAAC,GAAc;IACjC,OAAO;QACL,EAAE,EAAE,GAAG,CAAC,EAAE;QACV,eAAe,EAAE,GAAG,CAAC,eAAe;QACpC,YAAY,EAAE,GAAG,CAAC,YAAY;QAC9B,gBAAgB,EAAE,GAAG,CAAC,gBAAgB,IAAI,SAAS;QACnD,OAAO,EAAE,GAAG,CAAC,OAAO,IAAI,SAAS;QACjC,UAAU,EAAE,GAAG,CAAC,UAAU;KAC3B,CAAC;AACJ,CAAC"}
1
+ {"version":3,"file":"sqlite.js","sourceRoot":"","sources":["../../src/storage/sqlite.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "agent-inbox",
3
- "version": "0.1.3",
3
+ "version": "0.1.4",
4
4
  "description": "Agent Inbox — message routing, traceability, and MCP tools for multi-agent systems",
5
5
  "type": "module",
6
6
  "main": "dist/index.js",
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 if path provided, otherwise in-memory
107
- const storage: Storage = opts.sqlitePath
108
- ? new SqliteStorage({ path: opts.sqlitePath })
109
- : new InMemoryStorage();
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();
@@ -12,22 +12,42 @@ import type {
12
12
  import type { Storage, InboxQuery, ThreadQuery } from "./interface.js";
13
13
 
14
14
  export interface SqliteStorageOptions {
15
- path: string; // ":memory:" for in-memory, or file path
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
- this.db = new Database(opts.path);
23
- this.db.pragma("journal_mode = WAL");
24
- this.db.pragma("foreign_keys = ON");
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 idx_messages_scope ON messages(scope);
111
- CREATE INDEX IF NOT EXISTS idx_messages_sender ON messages(sender_id);
112
- CREATE INDEX IF NOT EXISTS idx_messages_thread_tag ON messages(thread_tag, scope);
113
- CREATE INDEX IF NOT EXISTS idx_messages_conversation ON messages(conversation_id);
114
- CREATE INDEX IF NOT EXISTS idx_messages_created ON messages(created_at);
115
- CREATE INDEX IF NOT EXISTS idx_recipients_agent ON recipients(agent_id);
116
- CREATE INDEX IF NOT EXISTS idx_turns_conversation ON turns(conversation_id);
117
- CREATE INDEX IF NOT EXISTS idx_agents_scope ON agents(scope);
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("SELECT * FROM agents WHERE agent_id = ?")
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("SELECT * FROM agents WHERE scope = ?").all(scope) as AgentRow[]
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("SELECT * FROM agents").all() as AgentRow[]).map(rowToAgent);
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("DELETE FROM agents WHERE agent_id = ?")
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("SELECT * FROM messages WHERE id = ?")
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("DELETE FROM recipients WHERE message_id = ?")
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 messages m
263
- JOIN recipients r ON r.message_id = m.id
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
- "SELECT * FROM messages WHERE thread_tag = ? AND scope = ? ORDER BY created_at ASC"
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 = "SELECT * FROM messages WHERE sender_id = ? ORDER BY created_at ASC";
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 messages m
312
- JOIN messages_fts fts ON fts.id = m.id
313
- WHERE messages_fts MATCH ? AND m.scope = ?
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 messages m
320
- JOIN messages_fts fts ON fts.id = m.id
321
- WHERE messages_fts MATCH ?
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("SELECT * FROM conversations WHERE id = ?")
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("DELETE FROM participants WHERE conversation_id = ?")
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("SELECT * FROM conversations WHERE scope = ? ORDER BY updated_at DESC")
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("SELECT * FROM conversations ORDER BY updated_at DESC")
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
- "SELECT * FROM turns WHERE conversation_id = ? ORDER BY created_at ASC"
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("SELECT * FROM threads WHERE id = ?")
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("SELECT * FROM threads WHERE conversation_id = ?")
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("SELECT * FROM recipients WHERE message_id = ?")
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("SELECT * FROM participants WHERE conversation_id = ?")
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.db.close();
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
+ });