@falai/agent 0.3.12 → 0.3.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/README.md +74 -0
  2. package/dist/adapters/MemoryAdapter.d.ts +47 -0
  3. package/dist/adapters/MemoryAdapter.d.ts.map +1 -0
  4. package/dist/adapters/MemoryAdapter.js +178 -0
  5. package/dist/adapters/MemoryAdapter.js.map +1 -0
  6. package/dist/adapters/MongoAdapter.d.ts +97 -0
  7. package/dist/adapters/MongoAdapter.d.ts.map +1 -0
  8. package/dist/adapters/MongoAdapter.js +163 -0
  9. package/dist/adapters/MongoAdapter.js.map +1 -0
  10. package/dist/adapters/PostgreSQLAdapter.d.ts +71 -0
  11. package/dist/adapters/PostgreSQLAdapter.d.ts.map +1 -0
  12. package/dist/adapters/PostgreSQLAdapter.js +256 -0
  13. package/dist/adapters/PostgreSQLAdapter.js.map +1 -0
  14. package/dist/adapters/RedisAdapter.d.ts +71 -0
  15. package/dist/adapters/RedisAdapter.d.ts.map +1 -0
  16. package/dist/adapters/RedisAdapter.js +226 -0
  17. package/dist/adapters/RedisAdapter.js.map +1 -0
  18. package/dist/adapters/SQLiteAdapter.d.ts +69 -0
  19. package/dist/adapters/SQLiteAdapter.d.ts.map +1 -0
  20. package/dist/adapters/SQLiteAdapter.js +307 -0
  21. package/dist/adapters/SQLiteAdapter.js.map +1 -0
  22. package/dist/adapters/index.d.ts +9 -0
  23. package/dist/adapters/index.d.ts.map +1 -1
  24. package/dist/adapters/index.js +5 -0
  25. package/dist/adapters/index.js.map +1 -1
  26. package/dist/cjs/adapters/MemoryAdapter.d.ts +47 -0
  27. package/dist/cjs/adapters/MemoryAdapter.d.ts.map +1 -0
  28. package/dist/cjs/adapters/MemoryAdapter.js +182 -0
  29. package/dist/cjs/adapters/MemoryAdapter.js.map +1 -0
  30. package/dist/cjs/adapters/MongoAdapter.d.ts +97 -0
  31. package/dist/cjs/adapters/MongoAdapter.d.ts.map +1 -0
  32. package/dist/cjs/adapters/MongoAdapter.js +167 -0
  33. package/dist/cjs/adapters/MongoAdapter.js.map +1 -0
  34. package/dist/cjs/adapters/PostgreSQLAdapter.d.ts +71 -0
  35. package/dist/cjs/adapters/PostgreSQLAdapter.d.ts.map +1 -0
  36. package/dist/cjs/adapters/PostgreSQLAdapter.js +260 -0
  37. package/dist/cjs/adapters/PostgreSQLAdapter.js.map +1 -0
  38. package/dist/cjs/adapters/RedisAdapter.d.ts +71 -0
  39. package/dist/cjs/adapters/RedisAdapter.d.ts.map +1 -0
  40. package/dist/cjs/adapters/RedisAdapter.js +230 -0
  41. package/dist/cjs/adapters/RedisAdapter.js.map +1 -0
  42. package/dist/cjs/adapters/SQLiteAdapter.d.ts +69 -0
  43. package/dist/cjs/adapters/SQLiteAdapter.d.ts.map +1 -0
  44. package/dist/cjs/adapters/SQLiteAdapter.js +311 -0
  45. package/dist/cjs/adapters/SQLiteAdapter.js.map +1 -0
  46. package/dist/cjs/adapters/index.d.ts +9 -0
  47. package/dist/cjs/adapters/index.d.ts.map +1 -1
  48. package/dist/cjs/adapters/index.js +11 -1
  49. package/dist/cjs/adapters/index.js.map +1 -1
  50. package/dist/cjs/index.d.ts +9 -0
  51. package/dist/cjs/index.d.ts.map +1 -1
  52. package/dist/cjs/index.js +11 -1
  53. package/dist/cjs/index.js.map +1 -1
  54. package/dist/index.d.ts +9 -0
  55. package/dist/index.d.ts.map +1 -1
  56. package/dist/index.js +5 -0
  57. package/dist/index.js.map +1 -1
  58. package/docs/ADAPTERS.md +151 -0
  59. package/docs/API_REFERENCE.md +448 -0
  60. package/docs/PERSISTENCE.md +176 -6
  61. package/examples/redis-persistence.ts +89 -0
  62. package/package.json +26 -2
  63. package/src/adapters/MemoryAdapter.ts +245 -0
  64. package/src/adapters/MongoAdapter.ts +295 -0
  65. package/src/adapters/PostgreSQLAdapter.ts +417 -0
  66. package/src/adapters/RedisAdapter.ts +365 -0
  67. package/src/adapters/SQLiteAdapter.ts +449 -0
  68. package/src/adapters/index.ts +27 -0
  69. package/src/index.ts +22 -0
@@ -0,0 +1,307 @@
1
+ /**
2
+ * SQLite adapter for persistence
3
+ * Lightweight, file-based database perfect for local development
4
+ */
5
+ /**
6
+ * SQLite Adapter - Provider-style API for SQLite persistence
7
+ *
8
+ * @example
9
+ * ```typescript
10
+ * import Database from 'better-sqlite3';
11
+ * import { Agent, SQLiteAdapter } from '@falai/agent';
12
+ *
13
+ * const db = new Database('agent.db');
14
+ *
15
+ * const agent = new Agent({
16
+ * name: "My Agent",
17
+ * ai: provider,
18
+ * persistence: {
19
+ * adapter: new SQLiteAdapter({ db }),
20
+ * userId: "user_123",
21
+ * },
22
+ * });
23
+ * ```
24
+ */
25
+ export class SQLiteAdapter {
26
+ constructor(options) {
27
+ this.db = options.db;
28
+ const sessionTable = options.tables?.sessions || "agent_sessions";
29
+ const messageTable = options.tables?.messages || "agent_messages";
30
+ this.sessionRepository = new SQLiteSessionRepository(this.db, sessionTable);
31
+ this.messageRepository = new SQLiteMessageRepository(this.db, messageTable);
32
+ }
33
+ async initialize() {
34
+ const sessionTable = "agent_sessions";
35
+ const messageTable = "agent_messages";
36
+ // Create sessions table
37
+ this.db.exec(`
38
+ CREATE TABLE IF NOT EXISTS ${sessionTable} (
39
+ id TEXT PRIMARY KEY,
40
+ user_id TEXT,
41
+ agent_name TEXT,
42
+ status TEXT DEFAULT 'active',
43
+ current_route TEXT,
44
+ current_state TEXT,
45
+ collected_data TEXT,
46
+ message_count INTEGER DEFAULT 0,
47
+ last_message_at TEXT,
48
+ completed_at TEXT,
49
+ created_at TEXT NOT NULL,
50
+ updated_at TEXT NOT NULL
51
+ )
52
+ `);
53
+ // Create indexes for sessions
54
+ this.db.exec(`
55
+ CREATE INDEX IF NOT EXISTS idx_sessions_user_id ON ${sessionTable}(user_id);
56
+ CREATE INDEX IF NOT EXISTS idx_sessions_status ON ${sessionTable}(status);
57
+ `);
58
+ // Create messages table
59
+ this.db.exec(`
60
+ CREATE TABLE IF NOT EXISTS ${messageTable} (
61
+ id TEXT PRIMARY KEY,
62
+ session_id TEXT NOT NULL,
63
+ user_id TEXT,
64
+ role TEXT NOT NULL,
65
+ content TEXT NOT NULL,
66
+ route TEXT,
67
+ state TEXT,
68
+ tool_calls TEXT,
69
+ event TEXT,
70
+ created_at TEXT NOT NULL,
71
+ FOREIGN KEY (session_id) REFERENCES ${sessionTable}(id) ON DELETE CASCADE
72
+ )
73
+ `);
74
+ // Create indexes for messages
75
+ this.db.exec(`
76
+ CREATE INDEX IF NOT EXISTS idx_messages_session_id ON ${messageTable}(session_id);
77
+ CREATE INDEX IF NOT EXISTS idx_messages_user_id ON ${messageTable}(user_id);
78
+ `);
79
+ await Promise.resolve();
80
+ }
81
+ async disconnect() {
82
+ this.db.close();
83
+ await Promise.resolve();
84
+ }
85
+ }
86
+ /**
87
+ * SQLite Session Repository
88
+ */
89
+ class SQLiteSessionRepository {
90
+ constructor(db, tableName) {
91
+ this.db = db;
92
+ this.tableName = tableName;
93
+ }
94
+ create(data) {
95
+ const id = `session_${Date.now()}_${Math.random().toString(36).slice(2)}`;
96
+ const now = new Date();
97
+ const session = {
98
+ ...data,
99
+ id,
100
+ status: data.status || "active",
101
+ messageCount: data.messageCount || 0,
102
+ createdAt: now,
103
+ updatedAt: now,
104
+ };
105
+ const stmt = this.db.prepare(`
106
+ INSERT INTO ${this.tableName}
107
+ (id, user_id, agent_name, status, collected_data, message_count, created_at, updated_at)
108
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?)
109
+ `);
110
+ stmt.run(id, data.userId || null, data.agentName || null, session.status, JSON.stringify(data.collectedData || {}), session.messageCount, now.toISOString(), now.toISOString());
111
+ return Promise.resolve(session);
112
+ }
113
+ findById(id) {
114
+ const stmt = this.db.prepare(`SELECT * FROM ${this.tableName} WHERE id = ?`);
115
+ const row = stmt.get(id);
116
+ return Promise.resolve(row ? this.deserializeSession(row) : null);
117
+ }
118
+ findActiveByUserId(userId) {
119
+ const stmt = this.db.prepare(`SELECT * FROM ${this.tableName}
120
+ WHERE user_id = ? AND status = 'active'
121
+ ORDER BY created_at DESC
122
+ LIMIT 1`);
123
+ const row = stmt.get(userId);
124
+ return Promise.resolve(row ? this.deserializeSession(row) : null);
125
+ }
126
+ findByUserId(userId, limit = 100) {
127
+ const stmt = this.db.prepare(`SELECT * FROM ${this.tableName}
128
+ WHERE user_id = ?
129
+ ORDER BY created_at DESC
130
+ LIMIT ?`);
131
+ const rows = stmt.all(userId, limit);
132
+ return Promise.resolve(rows.map((row) => this.deserializeSession(row)));
133
+ }
134
+ async update(id, data) {
135
+ const fields = [];
136
+ const values = [];
137
+ if (data.status !== undefined) {
138
+ fields.push("status = ?");
139
+ values.push(data.status);
140
+ }
141
+ if (data.collectedData !== undefined) {
142
+ fields.push("collected_data = ?");
143
+ values.push(JSON.stringify(data.collectedData));
144
+ }
145
+ if (data.currentRoute !== undefined) {
146
+ fields.push("current_route = ?");
147
+ values.push(data.currentRoute);
148
+ }
149
+ if (data.currentState !== undefined) {
150
+ fields.push("current_state = ?");
151
+ values.push(data.currentState);
152
+ }
153
+ if (data.messageCount !== undefined) {
154
+ fields.push("message_count = ?");
155
+ values.push(data.messageCount);
156
+ }
157
+ if (data.lastMessageAt !== undefined) {
158
+ fields.push("last_message_at = ?");
159
+ values.push(data.lastMessageAt.toISOString());
160
+ }
161
+ if (data.completedAt !== undefined) {
162
+ fields.push("completed_at = ?");
163
+ values.push(data.completedAt.toISOString());
164
+ }
165
+ fields.push("updated_at = ?");
166
+ values.push(new Date().toISOString());
167
+ values.push(id);
168
+ const stmt = this.db.prepare(`UPDATE ${this.tableName}
169
+ SET ${fields.join(", ")}
170
+ WHERE id = ?`);
171
+ const result = stmt.run(...values);
172
+ if (result.changes === 0)
173
+ return null;
174
+ return await this.findById(id);
175
+ }
176
+ async updateStatus(id, status, completedAt) {
177
+ return await this.update(id, { status, completedAt });
178
+ }
179
+ async updateCollectedData(id, collectedData) {
180
+ return await this.update(id, { collectedData });
181
+ }
182
+ async updateRouteState(id, route, state) {
183
+ return await this.update(id, {
184
+ currentRoute: route,
185
+ currentState: state,
186
+ });
187
+ }
188
+ async incrementMessageCount(id) {
189
+ const stmt = this.db.prepare(`UPDATE ${this.tableName}
190
+ SET message_count = message_count + 1,
191
+ last_message_at = ?,
192
+ updated_at = ?
193
+ WHERE id = ?`);
194
+ const now = new Date();
195
+ const result = stmt.run(now.toISOString(), now.toISOString(), id);
196
+ if (result.changes === 0)
197
+ return null;
198
+ return await this.findById(id);
199
+ }
200
+ delete(id) {
201
+ const stmt = this.db.prepare(`DELETE FROM ${this.tableName} WHERE id = ?`);
202
+ const result = stmt.run(id);
203
+ return Promise.resolve(result.changes > 0);
204
+ }
205
+ deserializeSession(row) {
206
+ return {
207
+ id: row.id,
208
+ userId: row.user_id || undefined,
209
+ agentName: row.agent_name || undefined,
210
+ status: row.status,
211
+ currentRoute: row.current_route || undefined,
212
+ currentState: row.current_state || undefined,
213
+ collectedData: row.collected_data
214
+ ? JSON.parse(row.collected_data)
215
+ : undefined,
216
+ messageCount: row.message_count || 0,
217
+ lastMessageAt: row.last_message_at
218
+ ? new Date(row.last_message_at)
219
+ : undefined,
220
+ completedAt: row.completed_at
221
+ ? new Date(row.completed_at)
222
+ : undefined,
223
+ createdAt: new Date(row.created_at),
224
+ updatedAt: new Date(row.updated_at),
225
+ };
226
+ }
227
+ }
228
+ /**
229
+ * SQLite Message Repository
230
+ */
231
+ class SQLiteMessageRepository {
232
+ constructor(db, tableName) {
233
+ this.db = db;
234
+ this.tableName = tableName;
235
+ }
236
+ create(data) {
237
+ const id = `msg_${Date.now()}_${Math.random().toString(36).slice(2)}`;
238
+ const now = new Date();
239
+ const message = {
240
+ ...data,
241
+ id,
242
+ createdAt: now,
243
+ };
244
+ const stmt = this.db.prepare(`
245
+ INSERT INTO ${this.tableName}
246
+ (id, session_id, user_id, role, content, route, state, tool_calls, event, created_at)
247
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
248
+ `);
249
+ stmt.run(id, data.sessionId, data.userId || null, data.role, data.content, data.route || null, data.state || null, JSON.stringify(data.toolCalls || null), JSON.stringify(data.event || null), now.toISOString());
250
+ return Promise.resolve(message);
251
+ }
252
+ findById(id) {
253
+ const stmt = this.db.prepare(`SELECT * FROM ${this.tableName} WHERE id = ?`);
254
+ const row = stmt.get(id);
255
+ return Promise.resolve(row ? this.deserializeMessage(row) : null);
256
+ }
257
+ findBySessionId(sessionId, limit = 1000) {
258
+ const stmt = this.db.prepare(`SELECT * FROM ${this.tableName}
259
+ WHERE session_id = ?
260
+ ORDER BY created_at ASC
261
+ LIMIT ?`);
262
+ const rows = stmt.all(sessionId, limit);
263
+ return Promise.resolve(rows.map((row) => this.deserializeMessage(row)));
264
+ }
265
+ findByUserId(userId, limit = 100) {
266
+ const stmt = this.db.prepare(`SELECT * FROM ${this.tableName}
267
+ WHERE user_id = ?
268
+ ORDER BY created_at DESC
269
+ LIMIT ?`);
270
+ const rows = stmt.all(userId, limit);
271
+ return Promise.resolve(rows.map((row) => this.deserializeMessage(row)));
272
+ }
273
+ delete(id) {
274
+ const stmt = this.db.prepare(`DELETE FROM ${this.tableName} WHERE id = ?`);
275
+ const result = stmt.run(id);
276
+ return Promise.resolve(result.changes > 0);
277
+ }
278
+ deleteBySessionId(sessionId) {
279
+ const stmt = this.db.prepare(`DELETE FROM ${this.tableName} WHERE session_id = ?`);
280
+ const result = stmt.run(sessionId);
281
+ return Promise.resolve(result.changes);
282
+ }
283
+ deleteByUserId(userId) {
284
+ const stmt = this.db.prepare(`DELETE FROM ${this.tableName} WHERE user_id = ?`);
285
+ const result = stmt.run(userId);
286
+ return Promise.resolve(result.changes);
287
+ }
288
+ deserializeMessage(row) {
289
+ return {
290
+ id: row.id,
291
+ sessionId: row.session_id,
292
+ userId: row.user_id || undefined,
293
+ role: row.role,
294
+ content: row.content,
295
+ route: row.route || undefined,
296
+ state: row.state || undefined,
297
+ toolCalls: row.tool_calls
298
+ ? JSON.parse(row.tool_calls)
299
+ : undefined,
300
+ event: row.event
301
+ ? JSON.parse(row.event)
302
+ : undefined,
303
+ createdAt: new Date(row.created_at),
304
+ };
305
+ }
306
+ }
307
+ //# sourceMappingURL=SQLiteAdapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SQLiteAdapter.js","sourceRoot":"","sources":["../../src/adapters/SQLiteAdapter.ts"],"names":[],"mappings":"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"}
@@ -3,4 +3,13 @@
3
3
  */
4
4
  export { PrismaAdapter } from "./PrismaAdapter";
5
5
  export type { PrismaClient, FieldMappings, PrismaAdapterOptions, } from "./PrismaAdapter";
6
+ export { RedisAdapter } from "./RedisAdapter";
7
+ export type { RedisClient, RedisAdapterOptions } from "./RedisAdapter";
8
+ export { MongoAdapter } from "./MongoAdapter";
9
+ export type { MongoClient, MongoDatabase, MongoCollection, MongoAdapterOptions, } from "./MongoAdapter";
10
+ export { PostgreSQLAdapter } from "./PostgreSQLAdapter";
11
+ export type { PgClient, PgQueryResult, PostgreSQLAdapterOptions, } from "./PostgreSQLAdapter";
12
+ export { SQLiteAdapter } from "./SQLiteAdapter";
13
+ export type { SqliteDatabase, SqliteStatement, SQLiteAdapterOptions, } from "./SQLiteAdapter";
14
+ export { MemoryAdapter } from "./MemoryAdapter";
6
15
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/adapters/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,YAAY,EACV,YAAY,EACZ,aAAa,EACb,oBAAoB,GACrB,MAAM,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/adapters/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,YAAY,EACV,YAAY,EACZ,aAAa,EACb,oBAAoB,GACrB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,YAAY,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAEvE,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,YAAY,EACV,WAAW,EACX,aAAa,EACb,eAAe,EACf,mBAAmB,GACpB,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,YAAY,EACV,QAAQ,EACR,aAAa,EACb,wBAAwB,GACzB,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,YAAY,EACV,cAAc,EACd,eAAe,EACf,oBAAoB,GACrB,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
@@ -2,4 +2,9 @@
2
2
  * Database adapters for persistence
3
3
  */
4
4
  export { PrismaAdapter } from "./PrismaAdapter";
5
+ export { RedisAdapter } from "./RedisAdapter";
6
+ export { MongoAdapter } from "./MongoAdapter";
7
+ export { PostgreSQLAdapter } from "./PostgreSQLAdapter";
8
+ export { SQLiteAdapter } from "./SQLiteAdapter";
9
+ export { MemoryAdapter } from "./MemoryAdapter";
5
10
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/adapters/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/adapters/index.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAOhD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAG9C,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAQ9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAOxD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAOhD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC"}
@@ -0,0 +1,47 @@
1
+ /**
2
+ * Memory adapter for persistence
3
+ * In-memory storage for testing and development (no database required)
4
+ */
5
+ import type { SessionRepository, MessageRepository, SessionData, MessageData, PersistenceAdapter } from "../types/persistence";
6
+ /**
7
+ * Memory Adapter - Provider-style API for in-memory persistence
8
+ *
9
+ * Perfect for:
10
+ * - Testing
11
+ * - Development
12
+ * - Prototyping
13
+ * - No database setup required
14
+ *
15
+ * @example
16
+ * ```typescript
17
+ * import { Agent, MemoryAdapter } from '@falai/agent';
18
+ *
19
+ * const agent = new Agent({
20
+ * name: "My Agent",
21
+ * ai: provider,
22
+ * persistence: {
23
+ * adapter: new MemoryAdapter(),
24
+ * userId: "user_123",
25
+ * },
26
+ * });
27
+ * ```
28
+ */
29
+ export declare class MemoryAdapter implements PersistenceAdapter {
30
+ readonly sessionRepository: SessionRepository;
31
+ readonly messageRepository: MessageRepository;
32
+ private sessions;
33
+ private messages;
34
+ constructor();
35
+ /**
36
+ * Clear all data (useful for testing)
37
+ */
38
+ clear(): void;
39
+ /**
40
+ * Get data snapshot (useful for debugging)
41
+ */
42
+ getSnapshot(): {
43
+ sessions: SessionData[];
44
+ messages: MessageData[];
45
+ };
46
+ }
47
+ //# sourceMappingURL=MemoryAdapter.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MemoryAdapter.d.ts","sourceRoot":"","sources":["../../../src/adapters/MemoryAdapter.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EACV,iBAAiB,EACjB,iBAAiB,EACjB,WAAW,EACX,WAAW,EAEX,kBAAkB,EACnB,MAAM,sBAAsB,CAAC;AAE9B;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,qBAAa,aAAc,YAAW,kBAAkB;IACtD,SAAgB,iBAAiB,EAAE,iBAAiB,CAAC;IACrD,SAAgB,iBAAiB,EAAE,iBAAiB,CAAC;IACrD,OAAO,CAAC,QAAQ,CAA2B;IAC3C,OAAO,CAAC,QAAQ,CAA2B;;IAU3C;;OAEG;IACH,KAAK,IAAI,IAAI;IAKb;;OAEG;IACH,WAAW,IAAI;QACb,QAAQ,EAAE,WAAW,EAAE,CAAC;QACxB,QAAQ,EAAE,WAAW,EAAE,CAAC;KACzB;CAMF"}
@@ -0,0 +1,182 @@
1
+ "use strict";
2
+ /**
3
+ * Memory adapter for persistence
4
+ * In-memory storage for testing and development (no database required)
5
+ */
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.MemoryAdapter = void 0;
8
+ /**
9
+ * Memory Adapter - Provider-style API for in-memory persistence
10
+ *
11
+ * Perfect for:
12
+ * - Testing
13
+ * - Development
14
+ * - Prototyping
15
+ * - No database setup required
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * import { Agent, MemoryAdapter } from '@falai/agent';
20
+ *
21
+ * const agent = new Agent({
22
+ * name: "My Agent",
23
+ * ai: provider,
24
+ * persistence: {
25
+ * adapter: new MemoryAdapter(),
26
+ * userId: "user_123",
27
+ * },
28
+ * });
29
+ * ```
30
+ */
31
+ class MemoryAdapter {
32
+ constructor() {
33
+ this.sessions = new Map();
34
+ this.messages = new Map();
35
+ this.sessionRepository = new MemorySessionRepository(this.sessions);
36
+ this.messageRepository = new MemoryMessageRepository(this.messages);
37
+ }
38
+ /**
39
+ * Clear all data (useful for testing)
40
+ */
41
+ clear() {
42
+ this.sessions.clear();
43
+ this.messages.clear();
44
+ }
45
+ /**
46
+ * Get data snapshot (useful for debugging)
47
+ */
48
+ getSnapshot() {
49
+ return {
50
+ sessions: Array.from(this.sessions.values()),
51
+ messages: Array.from(this.messages.values()),
52
+ };
53
+ }
54
+ }
55
+ exports.MemoryAdapter = MemoryAdapter;
56
+ /**
57
+ * Memory Session Repository
58
+ */
59
+ class MemorySessionRepository {
60
+ constructor(sessions) {
61
+ this.sessions = sessions;
62
+ }
63
+ async create(data) {
64
+ const id = `session_${Date.now()}_${Math.random().toString(36).slice(2)}`;
65
+ const now = new Date();
66
+ const session = {
67
+ ...data,
68
+ id,
69
+ status: data.status || "active",
70
+ messageCount: data.messageCount || 0,
71
+ createdAt: now,
72
+ updatedAt: now,
73
+ };
74
+ this.sessions.set(id, session);
75
+ return Promise.resolve(session);
76
+ }
77
+ async findById(id) {
78
+ const session = this.sessions.get(id) || null;
79
+ return Promise.resolve(session);
80
+ }
81
+ async findActiveByUserId(userId) {
82
+ const sessions = Array.from(this.sessions.values())
83
+ .filter((s) => s.userId === userId && s.status === "active")
84
+ .sort((a, b) => b.createdAt.getTime() - a.createdAt.getTime());
85
+ return Promise.resolve(sessions[0] || null);
86
+ }
87
+ async findByUserId(userId, limit = 100) {
88
+ const sessions = Array.from(this.sessions.values())
89
+ .filter((s) => s.userId === userId)
90
+ .sort((a, b) => b.createdAt.getTime() - a.createdAt.getTime())
91
+ .slice(0, limit);
92
+ return Promise.resolve(sessions);
93
+ }
94
+ async update(id, data) {
95
+ const existing = this.sessions.get(id);
96
+ if (!existing)
97
+ return null;
98
+ const updated = {
99
+ ...existing,
100
+ ...data,
101
+ updatedAt: new Date(),
102
+ };
103
+ this.sessions.set(id, updated);
104
+ return Promise.resolve(updated);
105
+ }
106
+ async updateStatus(id, status, completedAt) {
107
+ return await this.update(id, { status, completedAt });
108
+ }
109
+ async updateCollectedData(id, collectedData) {
110
+ return await this.update(id, { collectedData });
111
+ }
112
+ async updateRouteState(id, route, state) {
113
+ return await this.update(id, {
114
+ currentRoute: route,
115
+ currentState: state,
116
+ });
117
+ }
118
+ async incrementMessageCount(id) {
119
+ const session = this.sessions.get(id);
120
+ if (!session)
121
+ return null;
122
+ return await this.update(id, {
123
+ messageCount: (session.messageCount || 0) + 1,
124
+ lastMessageAt: new Date(),
125
+ });
126
+ }
127
+ async delete(id) {
128
+ const result = this.sessions.delete(id);
129
+ return Promise.resolve(result);
130
+ }
131
+ }
132
+ /**
133
+ * Memory Message Repository
134
+ */
135
+ class MemoryMessageRepository {
136
+ constructor(messages) {
137
+ this.messages = messages;
138
+ }
139
+ async create(data) {
140
+ const id = `msg_${Date.now()}_${Math.random().toString(36).slice(2)}`;
141
+ const message = {
142
+ ...data,
143
+ id,
144
+ createdAt: new Date(),
145
+ };
146
+ this.messages.set(id, message);
147
+ return Promise.resolve(message);
148
+ }
149
+ async findById(id) {
150
+ const message = this.messages.get(id) || null;
151
+ return Promise.resolve(message);
152
+ }
153
+ async findBySessionId(sessionId, limit = 1000) {
154
+ const messages = Array.from(this.messages.values())
155
+ .filter((m) => m.sessionId === sessionId)
156
+ .sort((a, b) => a.createdAt.getTime() - b.createdAt.getTime())
157
+ .slice(0, limit);
158
+ return Promise.resolve(messages);
159
+ }
160
+ async findByUserId(userId, limit = 100) {
161
+ const messages = Array.from(this.messages.values())
162
+ .filter((m) => m.userId === userId)
163
+ .sort((a, b) => b.createdAt.getTime() - a.createdAt.getTime())
164
+ .slice(0, limit);
165
+ return Promise.resolve(messages);
166
+ }
167
+ async delete(id) {
168
+ const result = this.messages.delete(id);
169
+ return Promise.resolve(result);
170
+ }
171
+ async deleteBySessionId(sessionId) {
172
+ const toDelete = Array.from(this.messages.values()).filter((m) => m.sessionId === sessionId);
173
+ toDelete.forEach((m) => this.messages.delete(m.id));
174
+ return Promise.resolve(toDelete.length);
175
+ }
176
+ async deleteByUserId(userId) {
177
+ const toDelete = Array.from(this.messages.values()).filter((m) => m.userId === userId);
178
+ toDelete.forEach((m) => this.messages.delete(m.id));
179
+ return Promise.resolve(toDelete.length);
180
+ }
181
+ }
182
+ //# sourceMappingURL=MemoryAdapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MemoryAdapter.js","sourceRoot":"","sources":["../../../src/adapters/MemoryAdapter.ts"],"names":[],"mappings":"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"}