@claude-flow/memory 3.0.0-alpha.1

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 (214) hide show
  1. package/.agentic-flow/intelligence.json +16 -0
  2. package/README.md +249 -0
  3. package/__tests__/coverage/base.css +224 -0
  4. package/__tests__/coverage/block-navigation.js +87 -0
  5. package/__tests__/coverage/coverage-final.json +19 -0
  6. package/__tests__/coverage/favicon.png +0 -0
  7. package/__tests__/coverage/index.html +206 -0
  8. package/__tests__/coverage/lcov-report/base.css +224 -0
  9. package/__tests__/coverage/lcov-report/block-navigation.js +87 -0
  10. package/__tests__/coverage/lcov-report/favicon.png +0 -0
  11. package/__tests__/coverage/lcov-report/index.html +206 -0
  12. package/__tests__/coverage/lcov-report/prettify.css +1 -0
  13. package/__tests__/coverage/lcov-report/prettify.js +2 -0
  14. package/__tests__/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  15. package/__tests__/coverage/lcov-report/sorter.js +210 -0
  16. package/__tests__/coverage/lcov-report/src/agentdb-adapter.ts.html +2737 -0
  17. package/__tests__/coverage/lcov-report/src/agentdb-backend.ts.html +3130 -0
  18. package/__tests__/coverage/lcov-report/src/application/commands/delete-memory.command.ts.html +601 -0
  19. package/__tests__/coverage/lcov-report/src/application/commands/index.html +131 -0
  20. package/__tests__/coverage/lcov-report/src/application/commands/store-memory.command.ts.html +394 -0
  21. package/__tests__/coverage/lcov-report/src/application/queries/index.html +116 -0
  22. package/__tests__/coverage/lcov-report/src/application/queries/search-memory.query.ts.html +796 -0
  23. package/__tests__/coverage/lcov-report/src/application/services/index.html +116 -0
  24. package/__tests__/coverage/lcov-report/src/application/services/memory-application-service.ts.html +793 -0
  25. package/__tests__/coverage/lcov-report/src/cache-manager.ts.html +1633 -0
  26. package/__tests__/coverage/lcov-report/src/database-provider.ts.html +1618 -0
  27. package/__tests__/coverage/lcov-report/src/domain/entities/index.html +116 -0
  28. package/__tests__/coverage/lcov-report/src/domain/entities/memory-entry.ts.html +952 -0
  29. package/__tests__/coverage/lcov-report/src/domain/services/index.html +116 -0
  30. package/__tests__/coverage/lcov-report/src/domain/services/memory-domain-service.ts.html +1294 -0
  31. package/__tests__/coverage/lcov-report/src/hnsw-index.ts.html +3124 -0
  32. package/__tests__/coverage/lcov-report/src/hybrid-backend.ts.html +2167 -0
  33. package/__tests__/coverage/lcov-report/src/index.html +266 -0
  34. package/__tests__/coverage/lcov-report/src/infrastructure/repositories/hybrid-memory-repository.ts.html +1633 -0
  35. package/__tests__/coverage/lcov-report/src/infrastructure/repositories/index.html +116 -0
  36. package/__tests__/coverage/lcov-report/src/migration.ts.html +2092 -0
  37. package/__tests__/coverage/lcov-report/src/query-builder.ts.html +1711 -0
  38. package/__tests__/coverage/lcov-report/src/sqlite-backend.ts.html +2281 -0
  39. package/__tests__/coverage/lcov-report/src/sqljs-backend.ts.html +2374 -0
  40. package/__tests__/coverage/lcov-report/src/types.ts.html +2266 -0
  41. package/__tests__/coverage/lcov.info +10238 -0
  42. package/__tests__/coverage/prettify.css +1 -0
  43. package/__tests__/coverage/prettify.js +2 -0
  44. package/__tests__/coverage/sort-arrow-sprite.png +0 -0
  45. package/__tests__/coverage/sorter.js +210 -0
  46. package/__tests__/coverage/src/agentdb-adapter.ts.html +2737 -0
  47. package/__tests__/coverage/src/agentdb-backend.ts.html +3130 -0
  48. package/__tests__/coverage/src/application/commands/delete-memory.command.ts.html +601 -0
  49. package/__tests__/coverage/src/application/commands/index.html +131 -0
  50. package/__tests__/coverage/src/application/commands/store-memory.command.ts.html +394 -0
  51. package/__tests__/coverage/src/application/queries/index.html +116 -0
  52. package/__tests__/coverage/src/application/queries/search-memory.query.ts.html +796 -0
  53. package/__tests__/coverage/src/application/services/index.html +116 -0
  54. package/__tests__/coverage/src/application/services/memory-application-service.ts.html +793 -0
  55. package/__tests__/coverage/src/cache-manager.ts.html +1633 -0
  56. package/__tests__/coverage/src/database-provider.ts.html +1618 -0
  57. package/__tests__/coverage/src/domain/entities/index.html +116 -0
  58. package/__tests__/coverage/src/domain/entities/memory-entry.ts.html +952 -0
  59. package/__tests__/coverage/src/domain/services/index.html +116 -0
  60. package/__tests__/coverage/src/domain/services/memory-domain-service.ts.html +1294 -0
  61. package/__tests__/coverage/src/hnsw-index.ts.html +3124 -0
  62. package/__tests__/coverage/src/hybrid-backend.ts.html +2167 -0
  63. package/__tests__/coverage/src/index.html +266 -0
  64. package/__tests__/coverage/src/infrastructure/repositories/hybrid-memory-repository.ts.html +1633 -0
  65. package/__tests__/coverage/src/infrastructure/repositories/index.html +116 -0
  66. package/__tests__/coverage/src/migration.ts.html +2092 -0
  67. package/__tests__/coverage/src/query-builder.ts.html +1711 -0
  68. package/__tests__/coverage/src/sqlite-backend.ts.html +2281 -0
  69. package/__tests__/coverage/src/sqljs-backend.ts.html +2374 -0
  70. package/__tests__/coverage/src/types.ts.html +2266 -0
  71. package/benchmarks/cache-hit-rate.bench.ts +535 -0
  72. package/benchmarks/hnsw-indexing.bench.ts +552 -0
  73. package/benchmarks/memory-write.bench.ts +469 -0
  74. package/benchmarks/vector-search.bench.ts +449 -0
  75. package/dist/agentdb-adapter.d.ts +146 -0
  76. package/dist/agentdb-adapter.d.ts.map +1 -0
  77. package/dist/agentdb-adapter.js +679 -0
  78. package/dist/agentdb-adapter.js.map +1 -0
  79. package/dist/agentdb-backend.d.ts +214 -0
  80. package/dist/agentdb-backend.d.ts.map +1 -0
  81. package/dist/agentdb-backend.js +827 -0
  82. package/dist/agentdb-backend.js.map +1 -0
  83. package/dist/agentdb-backend.test.d.ts +7 -0
  84. package/dist/agentdb-backend.test.d.ts.map +1 -0
  85. package/dist/agentdb-backend.test.js +258 -0
  86. package/dist/agentdb-backend.test.js.map +1 -0
  87. package/dist/application/commands/delete-memory.command.d.ts +65 -0
  88. package/dist/application/commands/delete-memory.command.d.ts.map +1 -0
  89. package/dist/application/commands/delete-memory.command.js +129 -0
  90. package/dist/application/commands/delete-memory.command.js.map +1 -0
  91. package/dist/application/commands/store-memory.command.d.ts +48 -0
  92. package/dist/application/commands/store-memory.command.d.ts.map +1 -0
  93. package/dist/application/commands/store-memory.command.js +72 -0
  94. package/dist/application/commands/store-memory.command.js.map +1 -0
  95. package/dist/application/index.d.ts +12 -0
  96. package/dist/application/index.d.ts.map +1 -0
  97. package/dist/application/index.js +15 -0
  98. package/dist/application/index.js.map +1 -0
  99. package/dist/application/queries/search-memory.query.d.ts +72 -0
  100. package/dist/application/queries/search-memory.query.d.ts.map +1 -0
  101. package/dist/application/queries/search-memory.query.js +143 -0
  102. package/dist/application/queries/search-memory.query.js.map +1 -0
  103. package/dist/application/services/memory-application-service.d.ts +121 -0
  104. package/dist/application/services/memory-application-service.d.ts.map +1 -0
  105. package/dist/application/services/memory-application-service.js +190 -0
  106. package/dist/application/services/memory-application-service.js.map +1 -0
  107. package/dist/cache-manager.d.ts +134 -0
  108. package/dist/cache-manager.d.ts.map +1 -0
  109. package/dist/cache-manager.js +407 -0
  110. package/dist/cache-manager.js.map +1 -0
  111. package/dist/database-provider.d.ts +86 -0
  112. package/dist/database-provider.d.ts.map +1 -0
  113. package/dist/database-provider.js +385 -0
  114. package/dist/database-provider.js.map +1 -0
  115. package/dist/database-provider.test.d.ts +7 -0
  116. package/dist/database-provider.test.d.ts.map +1 -0
  117. package/dist/database-provider.test.js +285 -0
  118. package/dist/database-provider.test.js.map +1 -0
  119. package/dist/domain/entities/memory-entry.d.ts +143 -0
  120. package/dist/domain/entities/memory-entry.d.ts.map +1 -0
  121. package/dist/domain/entities/memory-entry.js +226 -0
  122. package/dist/domain/entities/memory-entry.js.map +1 -0
  123. package/dist/domain/index.d.ts +11 -0
  124. package/dist/domain/index.d.ts.map +1 -0
  125. package/dist/domain/index.js +12 -0
  126. package/dist/domain/index.js.map +1 -0
  127. package/dist/domain/repositories/memory-repository.interface.d.ts +102 -0
  128. package/dist/domain/repositories/memory-repository.interface.d.ts.map +1 -0
  129. package/dist/domain/repositories/memory-repository.interface.js +11 -0
  130. package/dist/domain/repositories/memory-repository.interface.js.map +1 -0
  131. package/dist/domain/services/memory-domain-service.d.ts +105 -0
  132. package/dist/domain/services/memory-domain-service.d.ts.map +1 -0
  133. package/dist/domain/services/memory-domain-service.js +297 -0
  134. package/dist/domain/services/memory-domain-service.js.map +1 -0
  135. package/dist/hnsw-index.d.ts +111 -0
  136. package/dist/hnsw-index.d.ts.map +1 -0
  137. package/dist/hnsw-index.js +781 -0
  138. package/dist/hnsw-index.js.map +1 -0
  139. package/dist/hybrid-backend.d.ts +217 -0
  140. package/dist/hybrid-backend.d.ts.map +1 -0
  141. package/dist/hybrid-backend.js +491 -0
  142. package/dist/hybrid-backend.js.map +1 -0
  143. package/dist/hybrid-backend.test.d.ts +8 -0
  144. package/dist/hybrid-backend.test.d.ts.map +1 -0
  145. package/dist/hybrid-backend.test.js +320 -0
  146. package/dist/hybrid-backend.test.js.map +1 -0
  147. package/dist/index.d.ts +188 -0
  148. package/dist/index.d.ts.map +1 -0
  149. package/dist/index.js +345 -0
  150. package/dist/index.js.map +1 -0
  151. package/dist/infrastructure/index.d.ts +17 -0
  152. package/dist/infrastructure/index.d.ts.map +1 -0
  153. package/dist/infrastructure/index.js +16 -0
  154. package/dist/infrastructure/index.js.map +1 -0
  155. package/dist/infrastructure/repositories/hybrid-memory-repository.d.ts +66 -0
  156. package/dist/infrastructure/repositories/hybrid-memory-repository.d.ts.map +1 -0
  157. package/dist/infrastructure/repositories/hybrid-memory-repository.js +409 -0
  158. package/dist/infrastructure/repositories/hybrid-memory-repository.js.map +1 -0
  159. package/dist/migration.d.ts +68 -0
  160. package/dist/migration.d.ts.map +1 -0
  161. package/dist/migration.js +513 -0
  162. package/dist/migration.js.map +1 -0
  163. package/dist/query-builder.d.ts +211 -0
  164. package/dist/query-builder.d.ts.map +1 -0
  165. package/dist/query-builder.js +438 -0
  166. package/dist/query-builder.js.map +1 -0
  167. package/dist/sqlite-backend.d.ts +121 -0
  168. package/dist/sqlite-backend.d.ts.map +1 -0
  169. package/dist/sqlite-backend.js +564 -0
  170. package/dist/sqlite-backend.js.map +1 -0
  171. package/dist/sqljs-backend.d.ts +128 -0
  172. package/dist/sqljs-backend.d.ts.map +1 -0
  173. package/dist/sqljs-backend.js +598 -0
  174. package/dist/sqljs-backend.js.map +1 -0
  175. package/dist/types.d.ts +481 -0
  176. package/dist/types.d.ts.map +1 -0
  177. package/dist/types.js +58 -0
  178. package/dist/types.js.map +1 -0
  179. package/docs/AGENTDB-INTEGRATION.md +388 -0
  180. package/docs/CROSS_PLATFORM.md +505 -0
  181. package/docs/WINDOWS_SUPPORT.md +422 -0
  182. package/examples/agentdb-example.ts +345 -0
  183. package/examples/cross-platform-usage.ts +326 -0
  184. package/framework/benchmark.ts +112 -0
  185. package/package.json +31 -0
  186. package/src/agentdb-adapter.ts +884 -0
  187. package/src/agentdb-backend.test.ts +339 -0
  188. package/src/agentdb-backend.ts +1016 -0
  189. package/src/application/commands/delete-memory.command.ts +172 -0
  190. package/src/application/commands/store-memory.command.ts +103 -0
  191. package/src/application/index.ts +36 -0
  192. package/src/application/queries/search-memory.query.ts +237 -0
  193. package/src/application/services/memory-application-service.ts +236 -0
  194. package/src/cache-manager.ts +516 -0
  195. package/src/database-provider.test.ts +364 -0
  196. package/src/database-provider.ts +511 -0
  197. package/src/domain/entities/memory-entry.ts +289 -0
  198. package/src/domain/index.ts +35 -0
  199. package/src/domain/repositories/memory-repository.interface.ts +120 -0
  200. package/src/domain/services/memory-domain-service.ts +403 -0
  201. package/src/hnsw-index.ts +1013 -0
  202. package/src/hybrid-backend.test.ts +399 -0
  203. package/src/hybrid-backend.ts +694 -0
  204. package/src/index.ts +515 -0
  205. package/src/infrastructure/index.ts +23 -0
  206. package/src/infrastructure/repositories/hybrid-memory-repository.ts +516 -0
  207. package/src/migration.ts +669 -0
  208. package/src/query-builder.ts +542 -0
  209. package/src/sqlite-backend.ts +732 -0
  210. package/src/sqljs-backend.ts +763 -0
  211. package/src/types.ts +727 -0
  212. package/tsconfig.json +9 -0
  213. package/tsconfig.tsbuildinfo +1 -0
  214. package/verify-cross-platform.ts +170 -0
package/src/types.ts ADDED
@@ -0,0 +1,727 @@
1
+ /**
2
+ * V3 Unified Memory Types
3
+ *
4
+ * Type definitions for the unified memory system based on AgentDB with HNSW indexing.
5
+ * Supports 150x-12,500x faster vector search compared to brute-force approaches.
6
+ *
7
+ * @module v3/memory/types
8
+ */
9
+
10
+ // ===== Core Memory Entry Types =====
11
+
12
+ /**
13
+ * Memory entry type classification
14
+ */
15
+ export type MemoryType =
16
+ | 'episodic' // Time-based experiences and events
17
+ | 'semantic' // Facts, concepts, and knowledge
18
+ | 'procedural' // How-to knowledge and skills
19
+ | 'working' // Short-term operational memory
20
+ | 'cache'; // Temporary cached data
21
+
22
+ /**
23
+ * Access level for memory entries
24
+ */
25
+ export type AccessLevel =
26
+ | 'private' // Only owner can access
27
+ | 'team' // Team members can access
28
+ | 'swarm' // All swarm agents can access
29
+ | 'public' // Publicly accessible
30
+ | 'system'; // System-level access
31
+
32
+ /**
33
+ * Consistency level for distributed memory operations
34
+ */
35
+ export type ConsistencyLevel =
36
+ | 'strong' // Strong consistency (all nodes agree)
37
+ | 'eventual' // Eventual consistency (propagates over time)
38
+ | 'session' // Session-scoped consistency
39
+ | 'weak'; // Weak consistency (best effort)
40
+
41
+ /**
42
+ * Distance metrics for vector similarity search
43
+ */
44
+ export type DistanceMetric =
45
+ | 'cosine' // Cosine similarity (default)
46
+ | 'euclidean' // Euclidean distance (L2)
47
+ | 'dot' // Dot product
48
+ | 'manhattan'; // Manhattan distance (L1)
49
+
50
+ // ===== Memory Entry =====
51
+
52
+ /**
53
+ * Core memory entry structure with vector embedding support
54
+ */
55
+ export interface MemoryEntry {
56
+ /** Unique identifier */
57
+ id: string;
58
+
59
+ /** Human-readable key for retrieval */
60
+ key: string;
61
+
62
+ /** Actual content of the memory */
63
+ content: string;
64
+
65
+ /** Vector embedding for semantic search (Float32Array for efficiency) */
66
+ embedding?: Float32Array;
67
+
68
+ /** Type of memory */
69
+ type: MemoryType;
70
+
71
+ /** Namespace for organization */
72
+ namespace: string;
73
+
74
+ /** Tags for categorization and filtering */
75
+ tags: string[];
76
+
77
+ /** Additional metadata */
78
+ metadata: Record<string, unknown>;
79
+
80
+ /** Owner agent ID */
81
+ ownerId?: string;
82
+
83
+ /** Access level */
84
+ accessLevel: AccessLevel;
85
+
86
+ /** Creation timestamp */
87
+ createdAt: number;
88
+
89
+ /** Last update timestamp */
90
+ updatedAt: number;
91
+
92
+ /** Expiration timestamp (optional) */
93
+ expiresAt?: number;
94
+
95
+ /** Version number for optimistic locking */
96
+ version: number;
97
+
98
+ /** References to other memory entries */
99
+ references: string[];
100
+
101
+ /** Access count for usage tracking */
102
+ accessCount: number;
103
+
104
+ /** Last access timestamp */
105
+ lastAccessedAt: number;
106
+ }
107
+
108
+ /**
109
+ * Input for creating a new memory entry
110
+ */
111
+ export interface MemoryEntryInput {
112
+ key: string;
113
+ content: string;
114
+ type?: MemoryType;
115
+ namespace?: string;
116
+ tags?: string[];
117
+ metadata?: Record<string, unknown>;
118
+ ownerId?: string;
119
+ accessLevel?: AccessLevel;
120
+ expiresAt?: number;
121
+ references?: string[];
122
+ }
123
+
124
+ /**
125
+ * Partial update for a memory entry
126
+ */
127
+ export interface MemoryEntryUpdate {
128
+ content?: string;
129
+ tags?: string[];
130
+ metadata?: Record<string, unknown>;
131
+ accessLevel?: AccessLevel;
132
+ expiresAt?: number;
133
+ references?: string[];
134
+ }
135
+
136
+ // ===== Query Types =====
137
+
138
+ /**
139
+ * Query type for memory retrieval
140
+ */
141
+ export type QueryType =
142
+ | 'semantic' // Vector similarity search
143
+ | 'exact' // Exact key match
144
+ | 'prefix' // Key prefix match
145
+ | 'tag' // Tag-based search
146
+ | 'hybrid'; // Combined semantic + filters
147
+
148
+ /**
149
+ * Memory query specification
150
+ */
151
+ export interface MemoryQuery {
152
+ /** Type of query to perform */
153
+ type: QueryType;
154
+
155
+ /** Content for semantic search (will be embedded) */
156
+ content?: string;
157
+
158
+ /** Pre-computed embedding for semantic search */
159
+ embedding?: Float32Array;
160
+
161
+ /** Exact key to match */
162
+ key?: string;
163
+
164
+ /** Key prefix to match */
165
+ keyPrefix?: string;
166
+
167
+ /** Namespace filter */
168
+ namespace?: string;
169
+
170
+ /** Tag filters (entries must have all specified tags) */
171
+ tags?: string[];
172
+
173
+ /** Memory type filter */
174
+ memoryType?: MemoryType;
175
+
176
+ /** Access level filter */
177
+ accessLevel?: AccessLevel;
178
+
179
+ /** Owner filter */
180
+ ownerId?: string;
181
+
182
+ /** Metadata filters */
183
+ metadata?: Record<string, unknown>;
184
+
185
+ /** Time range filters */
186
+ createdAfter?: number;
187
+ createdBefore?: number;
188
+ updatedAfter?: number;
189
+ updatedBefore?: number;
190
+
191
+ /** Maximum number of results */
192
+ limit: number;
193
+
194
+ /** Offset for pagination */
195
+ offset?: number;
196
+
197
+ /** Minimum similarity threshold (0-1) for semantic search */
198
+ threshold?: number;
199
+
200
+ /** Include expired entries */
201
+ includeExpired?: boolean;
202
+
203
+ /** Distance metric for semantic search */
204
+ distanceMetric?: DistanceMetric;
205
+ }
206
+
207
+ /**
208
+ * Search result with similarity score
209
+ */
210
+ export interface SearchResult {
211
+ /** The memory entry */
212
+ entry: MemoryEntry;
213
+
214
+ /** Similarity score (0-1, higher is better) */
215
+ score: number;
216
+
217
+ /** Distance from query vector */
218
+ distance: number;
219
+ }
220
+
221
+ /**
222
+ * Search options for HNSW vector search
223
+ */
224
+ export interface SearchOptions {
225
+ /** Number of results to return */
226
+ k: number;
227
+
228
+ /** Search expansion factor (higher = more accurate, slower) */
229
+ ef?: number;
230
+
231
+ /** Minimum similarity threshold (0-1) */
232
+ threshold?: number;
233
+
234
+ /** Distance metric */
235
+ metric?: DistanceMetric;
236
+
237
+ /** Additional filters to apply post-search */
238
+ filters?: MemoryQuery;
239
+ }
240
+
241
+ // ===== HNSW Index Types =====
242
+
243
+ /**
244
+ * HNSW index configuration
245
+ */
246
+ export interface HNSWConfig {
247
+ /** Vector dimensions (e.g., 1536 for OpenAI embeddings) */
248
+ dimensions: number;
249
+
250
+ /** Maximum number of connections per layer (default: 16) */
251
+ M: number;
252
+
253
+ /** Size of the dynamic candidate list during construction (default: 200) */
254
+ efConstruction: number;
255
+
256
+ /** Maximum elements the index can hold */
257
+ maxElements: number;
258
+
259
+ /** Distance metric */
260
+ metric: DistanceMetric;
261
+
262
+ /** Enable quantization for memory efficiency */
263
+ quantization?: QuantizationConfig;
264
+ }
265
+
266
+ /**
267
+ * Quantization configuration for memory reduction
268
+ */
269
+ export interface QuantizationConfig {
270
+ /** Quantization type */
271
+ type: 'binary' | 'scalar' | 'product';
272
+
273
+ /** Number of bits for scalar quantization */
274
+ bits?: 4 | 8 | 16;
275
+
276
+ /** Number of subquantizers for product quantization */
277
+ subquantizers?: number;
278
+
279
+ /** Codebook size for product quantization */
280
+ codebookSize?: number;
281
+ }
282
+
283
+ /**
284
+ * HNSW index statistics
285
+ */
286
+ export interface HNSWStats {
287
+ /** Total number of vectors in the index */
288
+ vectorCount: number;
289
+
290
+ /** Memory usage in bytes */
291
+ memoryUsage: number;
292
+
293
+ /** Average search time in milliseconds */
294
+ avgSearchTime: number;
295
+
296
+ /** Index build time in milliseconds */
297
+ buildTime: number;
298
+
299
+ /** Compression ratio if quantization is enabled */
300
+ compressionRatio?: number;
301
+ }
302
+
303
+ // ===== Backend Interface =====
304
+
305
+ /**
306
+ * Memory backend interface for storage and retrieval
307
+ */
308
+ export interface IMemoryBackend {
309
+ /** Initialize the backend */
310
+ initialize(): Promise<void>;
311
+
312
+ /** Shutdown the backend */
313
+ shutdown(): Promise<void>;
314
+
315
+ /** Store a memory entry */
316
+ store(entry: MemoryEntry): Promise<void>;
317
+
318
+ /** Retrieve a memory entry by ID */
319
+ get(id: string): Promise<MemoryEntry | null>;
320
+
321
+ /** Retrieve a memory entry by key within a namespace */
322
+ getByKey(namespace: string, key: string): Promise<MemoryEntry | null>;
323
+
324
+ /** Update a memory entry */
325
+ update(id: string, update: MemoryEntryUpdate): Promise<MemoryEntry | null>;
326
+
327
+ /** Delete a memory entry */
328
+ delete(id: string): Promise<boolean>;
329
+
330
+ /** Query memory entries */
331
+ query(query: MemoryQuery): Promise<MemoryEntry[]>;
332
+
333
+ /** Semantic vector search */
334
+ search(embedding: Float32Array, options: SearchOptions): Promise<SearchResult[]>;
335
+
336
+ /** Bulk insert entries */
337
+ bulkInsert(entries: MemoryEntry[]): Promise<void>;
338
+
339
+ /** Bulk delete entries */
340
+ bulkDelete(ids: string[]): Promise<number>;
341
+
342
+ /** Get entry count */
343
+ count(namespace?: string): Promise<number>;
344
+
345
+ /** List all namespaces */
346
+ listNamespaces(): Promise<string[]>;
347
+
348
+ /** Clear all entries in a namespace */
349
+ clearNamespace(namespace: string): Promise<number>;
350
+
351
+ /** Get backend statistics */
352
+ getStats(): Promise<BackendStats>;
353
+
354
+ /** Perform health check */
355
+ healthCheck(): Promise<HealthCheckResult>;
356
+ }
357
+
358
+ /**
359
+ * Backend statistics
360
+ */
361
+ export interface BackendStats {
362
+ /** Total number of entries */
363
+ totalEntries: number;
364
+
365
+ /** Entries by namespace */
366
+ entriesByNamespace: Record<string, number>;
367
+
368
+ /** Entries by type */
369
+ entriesByType: Record<MemoryType, number>;
370
+
371
+ /** Total memory usage in bytes */
372
+ memoryUsage: number;
373
+
374
+ /** HNSW index statistics */
375
+ hnswStats?: HNSWStats;
376
+
377
+ /** Cache statistics */
378
+ cacheStats?: CacheStats;
379
+
380
+ /** Average query time in milliseconds */
381
+ avgQueryTime: number;
382
+
383
+ /** Average search time in milliseconds */
384
+ avgSearchTime: number;
385
+ }
386
+
387
+ /**
388
+ * Health check result
389
+ */
390
+ export interface HealthCheckResult {
391
+ /** Overall health status */
392
+ status: 'healthy' | 'degraded' | 'unhealthy';
393
+
394
+ /** Individual component health */
395
+ components: {
396
+ storage: ComponentHealth;
397
+ index: ComponentHealth;
398
+ cache: ComponentHealth;
399
+ };
400
+
401
+ /** Health check timestamp */
402
+ timestamp: number;
403
+
404
+ /** Any issues detected */
405
+ issues: string[];
406
+
407
+ /** Recommendations for improvement */
408
+ recommendations: string[];
409
+ }
410
+
411
+ /**
412
+ * Individual component health status
413
+ */
414
+ export interface ComponentHealth {
415
+ status: 'healthy' | 'degraded' | 'unhealthy';
416
+ latency: number;
417
+ message?: string;
418
+ }
419
+
420
+ // ===== Cache Types =====
421
+
422
+ /**
423
+ * Cache configuration
424
+ */
425
+ export interface CacheConfig {
426
+ /** Maximum number of entries in the cache */
427
+ maxSize: number;
428
+
429
+ /** Default TTL in milliseconds */
430
+ ttl: number;
431
+
432
+ /** Enable LRU eviction */
433
+ lruEnabled: boolean;
434
+
435
+ /** Maximum memory usage in bytes */
436
+ maxMemory?: number;
437
+
438
+ /** Enable write-through caching */
439
+ writeThrough: boolean;
440
+ }
441
+
442
+ /**
443
+ * Cache statistics
444
+ */
445
+ export interface CacheStats {
446
+ /** Number of entries in cache */
447
+ size: number;
448
+
449
+ /** Cache hit rate (0-1) */
450
+ hitRate: number;
451
+
452
+ /** Total cache hits */
453
+ hits: number;
454
+
455
+ /** Total cache misses */
456
+ misses: number;
457
+
458
+ /** Total evictions */
459
+ evictions: number;
460
+
461
+ /** Memory usage in bytes */
462
+ memoryUsage: number;
463
+ }
464
+
465
+ /**
466
+ * Cached entry wrapper
467
+ */
468
+ export interface CachedEntry<T> {
469
+ /** The cached data */
470
+ data: T;
471
+
472
+ /** When the entry was cached */
473
+ cachedAt: number;
474
+
475
+ /** When the entry expires */
476
+ expiresAt: number;
477
+
478
+ /** Last access timestamp */
479
+ lastAccessedAt: number;
480
+
481
+ /** Access count */
482
+ accessCount: number;
483
+ }
484
+
485
+ // ===== Migration Types =====
486
+
487
+ /**
488
+ * Migration source type
489
+ */
490
+ export type MigrationSource =
491
+ | 'sqlite'
492
+ | 'markdown'
493
+ | 'json'
494
+ | 'memory-manager'
495
+ | 'swarm-memory'
496
+ | 'distributed-memory';
497
+
498
+ /**
499
+ * Migration configuration
500
+ */
501
+ export interface MigrationConfig {
502
+ /** Source backend type */
503
+ source: MigrationSource;
504
+
505
+ /** Source path or connection string */
506
+ sourcePath: string;
507
+
508
+ /** Batch size for migration */
509
+ batchSize: number;
510
+
511
+ /** Generate embeddings during migration */
512
+ generateEmbeddings: boolean;
513
+
514
+ /** Validate data during migration */
515
+ validateData: boolean;
516
+
517
+ /** Continue on error */
518
+ continueOnError: boolean;
519
+
520
+ /** Namespace mapping */
521
+ namespaceMapping?: Record<string, string>;
522
+
523
+ /** Type mapping */
524
+ typeMapping?: Record<string, MemoryType>;
525
+ }
526
+
527
+ /**
528
+ * Migration progress
529
+ */
530
+ export interface MigrationProgress {
531
+ /** Total entries to migrate */
532
+ total: number;
533
+
534
+ /** Entries migrated so far */
535
+ migrated: number;
536
+
537
+ /** Entries failed */
538
+ failed: number;
539
+
540
+ /** Entries skipped */
541
+ skipped: number;
542
+
543
+ /** Current batch number */
544
+ currentBatch: number;
545
+
546
+ /** Total batches */
547
+ totalBatches: number;
548
+
549
+ /** Progress percentage (0-100) */
550
+ percentage: number;
551
+
552
+ /** Estimated time remaining in milliseconds */
553
+ estimatedTimeRemaining: number;
554
+
555
+ /** Errors encountered */
556
+ errors: MigrationError[];
557
+ }
558
+
559
+ /**
560
+ * Migration error
561
+ */
562
+ export interface MigrationError {
563
+ /** Entry ID or key that failed */
564
+ entryId: string;
565
+
566
+ /** Error message */
567
+ message: string;
568
+
569
+ /** Error code */
570
+ code: string;
571
+
572
+ /** Whether the error is recoverable */
573
+ recoverable: boolean;
574
+ }
575
+
576
+ /**
577
+ * Migration result
578
+ */
579
+ export interface MigrationResult {
580
+ /** Whether migration completed successfully */
581
+ success: boolean;
582
+
583
+ /** Final progress state */
584
+ progress: MigrationProgress;
585
+
586
+ /** Total time taken in milliseconds */
587
+ duration: number;
588
+
589
+ /** Summary message */
590
+ summary: string;
591
+ }
592
+
593
+ // ===== Event Types =====
594
+
595
+ /**
596
+ * Memory event types
597
+ */
598
+ export type MemoryEventType =
599
+ | 'entry:created'
600
+ | 'entry:updated'
601
+ | 'entry:deleted'
602
+ | 'entry:accessed'
603
+ | 'entry:expired'
604
+ | 'cache:hit'
605
+ | 'cache:miss'
606
+ | 'cache:eviction'
607
+ | 'index:rebuilt'
608
+ | 'migration:started'
609
+ | 'migration:progress'
610
+ | 'migration:completed'
611
+ | 'migration:failed';
612
+
613
+ /**
614
+ * Memory event payload
615
+ */
616
+ export interface MemoryEvent {
617
+ type: MemoryEventType;
618
+ timestamp: number;
619
+ data: Record<string, unknown>;
620
+ }
621
+
622
+ /**
623
+ * Memory event handler
624
+ */
625
+ export type MemoryEventHandler = (event: MemoryEvent) => void | Promise<void>;
626
+
627
+ // ===== SONA Integration Types =====
628
+
629
+ /**
630
+ * SONA learning mode for adaptive memory
631
+ */
632
+ export type SONAMode =
633
+ | 'real-time' // <0.05ms adaptation
634
+ | 'balanced' // Balance between speed and accuracy
635
+ | 'research' // Maximum accuracy, slower
636
+ | 'edge' // Optimized for edge devices
637
+ | 'batch'; // Batch processing mode
638
+
639
+ /**
640
+ * Learning pattern from SONA integration
641
+ */
642
+ export interface LearningPattern {
643
+ /** Pattern ID */
644
+ id: string;
645
+
646
+ /** Pattern data */
647
+ data: Record<string, unknown>;
648
+
649
+ /** SONA mode used */
650
+ mode: SONAMode;
651
+
652
+ /** Reward signal */
653
+ reward: number;
654
+
655
+ /** Trajectory data */
656
+ trajectory: unknown[];
657
+
658
+ /** Adaptation time in milliseconds */
659
+ adaptationTime: number;
660
+
661
+ /** Creation timestamp */
662
+ createdAt: number;
663
+ }
664
+
665
+ // ===== Utility Types =====
666
+
667
+ /**
668
+ * Embedding generator function type
669
+ */
670
+ export type EmbeddingGenerator = (content: string) => Promise<Float32Array>;
671
+
672
+ /**
673
+ * Generates a unique memory ID
674
+ */
675
+ export function generateMemoryId(): string {
676
+ const timestamp = Date.now().toString(36);
677
+ const random = Math.random().toString(36).substring(2, 10);
678
+ return `mem_${timestamp}_${random}`;
679
+ }
680
+
681
+ /**
682
+ * Creates a default memory entry
683
+ */
684
+ export function createDefaultEntry(input: MemoryEntryInput): MemoryEntry {
685
+ const now = Date.now();
686
+ return {
687
+ id: generateMemoryId(),
688
+ key: input.key,
689
+ content: input.content,
690
+ type: input.type || 'semantic',
691
+ namespace: input.namespace || 'default',
692
+ tags: input.tags || [],
693
+ metadata: input.metadata || {},
694
+ ownerId: input.ownerId,
695
+ accessLevel: input.accessLevel || 'private',
696
+ createdAt: now,
697
+ updatedAt: now,
698
+ expiresAt: input.expiresAt,
699
+ version: 1,
700
+ references: input.references || [],
701
+ accessCount: 0,
702
+ lastAccessedAt: now,
703
+ };
704
+ }
705
+
706
+ /**
707
+ * Performance targets for V3 memory system
708
+ */
709
+ export const PERFORMANCE_TARGETS = {
710
+ /** Maximum vector search time for 100k vectors */
711
+ MAX_SEARCH_TIME_100K: 1, // ms
712
+
713
+ /** Maximum write time per entry */
714
+ MAX_WRITE_TIME: 5, // ms
715
+
716
+ /** Maximum batch insert time per entry */
717
+ MAX_BATCH_INSERT_TIME: 1, // ms
718
+
719
+ /** Target memory reduction from legacy systems */
720
+ MEMORY_REDUCTION_TARGET: 0.5, // 50%
721
+
722
+ /** Minimum search improvement over brute force */
723
+ MIN_SEARCH_IMPROVEMENT: 150, // 150x
724
+
725
+ /** Maximum search improvement over brute force */
726
+ MAX_SEARCH_IMPROVEMENT: 12500, // 12,500x
727
+ } as const;