@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/index.ts ADDED
@@ -0,0 +1,515 @@
1
+ /**
2
+ * @claude-flow/memory - V3 Unified Memory System
3
+ *
4
+ * Provides a unified memory interface backed by AgentDB with HNSW indexing
5
+ * for 150x-12,500x faster vector search compared to brute-force approaches.
6
+ *
7
+ * @module @claude-flow/memory
8
+ *
9
+ * @example
10
+ * ```typescript
11
+ * import { UnifiedMemoryService, query, QueryTemplates } from '@claude-flow/memory';
12
+ *
13
+ * // Initialize the memory service
14
+ * const memory = new UnifiedMemoryService({
15
+ * dimensions: 1536,
16
+ * cacheEnabled: true,
17
+ * embeddingGenerator: async (text) => embeddings.embed(text),
18
+ * });
19
+ *
20
+ * await memory.initialize();
21
+ *
22
+ * // Store entries
23
+ * await memory.store({
24
+ * key: 'auth-patterns',
25
+ * content: 'OAuth 2.0 implementation patterns for secure authentication',
26
+ * tags: ['auth', 'security', 'patterns'],
27
+ * });
28
+ *
29
+ * // Semantic search
30
+ * const results = await memory.semanticSearch('user authentication best practices', 5);
31
+ *
32
+ * // Query with fluent builder
33
+ * const entries = await memory.query(
34
+ * query()
35
+ * .semantic('security vulnerabilities')
36
+ * .inNamespace('security')
37
+ * .withTags(['critical'])
38
+ * .threshold(0.8)
39
+ * .limit(10)
40
+ * .build()
41
+ * );
42
+ * ```
43
+ */
44
+
45
+ // ===== Core Types =====
46
+ export type {
47
+ // Memory Entry Types
48
+ MemoryType,
49
+ AccessLevel,
50
+ ConsistencyLevel,
51
+ DistanceMetric,
52
+ MemoryEntry,
53
+ MemoryEntryInput,
54
+ MemoryEntryUpdate,
55
+
56
+ // Query Types
57
+ QueryType,
58
+ MemoryQuery,
59
+ SearchResult,
60
+ SearchOptions,
61
+
62
+ // HNSW Types
63
+ HNSWConfig,
64
+ HNSWStats,
65
+ QuantizationConfig,
66
+
67
+ // Backend Types
68
+ IMemoryBackend,
69
+ BackendStats,
70
+ HealthCheckResult,
71
+ ComponentHealth,
72
+
73
+ // Cache Types
74
+ CacheConfig,
75
+ CacheStats,
76
+ CachedEntry,
77
+
78
+ // Migration Types
79
+ MigrationSource,
80
+ MigrationConfig,
81
+ MigrationProgress,
82
+ MigrationResult,
83
+ MigrationError,
84
+
85
+ // Event Types
86
+ MemoryEventType,
87
+ MemoryEvent,
88
+ MemoryEventHandler,
89
+
90
+ // SONA Types
91
+ SONAMode,
92
+ LearningPattern,
93
+
94
+ // Utility Types
95
+ EmbeddingGenerator,
96
+ } from './types.js';
97
+
98
+ // Utility Functions and Constants (runtime values)
99
+ export {
100
+ generateMemoryId,
101
+ createDefaultEntry,
102
+ PERFORMANCE_TARGETS,
103
+ } from './types.js';
104
+
105
+ // ===== Core Components =====
106
+ export { AgentDBAdapter } from './agentdb-adapter.js';
107
+ export type { AgentDBAdapterConfig } from './agentdb-adapter.js';
108
+ export { AgentDBBackend } from './agentdb-backend.js';
109
+ export type { AgentDBBackendConfig } from './agentdb-backend.js';
110
+ export { SQLiteBackend } from './sqlite-backend.js';
111
+ export type { SQLiteBackendConfig } from './sqlite-backend.js';
112
+ export { SqlJsBackend } from './sqljs-backend.js';
113
+ export type { SqlJsBackendConfig } from './sqljs-backend.js';
114
+ export { HybridBackend } from './hybrid-backend.js';
115
+ export type {
116
+ HybridBackendConfig,
117
+ StructuredQuery,
118
+ SemanticQuery,
119
+ HybridQuery,
120
+ } from './hybrid-backend.js';
121
+ export { HNSWIndex } from './hnsw-index.js';
122
+ export { CacheManager, TieredCacheManager } from './cache-manager.js';
123
+ export { QueryBuilder, query, QueryTemplates } from './query-builder.js';
124
+ export type { SortDirection, SortField } from './query-builder.js';
125
+ export { MemoryMigrator, createMigrator, migrateMultipleSources } from './migration.js';
126
+ export { createDatabase, getPlatformInfo, getAvailableProviders } from './database-provider.js';
127
+ export type { DatabaseProvider, DatabaseOptions } from './database-provider.js';
128
+
129
+ // ===== Unified Memory Service =====
130
+ import { EventEmitter } from 'node:events';
131
+ import {
132
+ IMemoryBackend,
133
+ MemoryEntry,
134
+ MemoryEntryInput,
135
+ MemoryEntryUpdate,
136
+ MemoryQuery,
137
+ SearchResult,
138
+ SearchOptions,
139
+ BackendStats,
140
+ HealthCheckResult,
141
+ EmbeddingGenerator,
142
+ MigrationSource,
143
+ MigrationConfig,
144
+ MigrationResult,
145
+ } from './types.js';
146
+ import { AgentDBAdapter, AgentDBAdapterConfig } from './agentdb-adapter.js';
147
+ import { MemoryMigrator } from './migration.js';
148
+
149
+ /**
150
+ * Configuration for UnifiedMemoryService
151
+ */
152
+ export interface UnifiedMemoryServiceConfig extends Partial<AgentDBAdapterConfig> {
153
+ /** Enable automatic embedding generation */
154
+ autoEmbed?: boolean;
155
+
156
+ /** Default embedding dimensions */
157
+ dimensions?: number;
158
+
159
+ /** Embedding generator function */
160
+ embeddingGenerator?: EmbeddingGenerator;
161
+ }
162
+
163
+ /**
164
+ * Unified Memory Service
165
+ *
166
+ * High-level interface for the V3 memory system that provides:
167
+ * - Simple API for common operations
168
+ * - Automatic embedding generation
169
+ * - Cross-agent memory sharing
170
+ * - SONA integration for learning
171
+ * - Event-driven notifications
172
+ * - Performance monitoring
173
+ */
174
+ export class UnifiedMemoryService extends EventEmitter implements IMemoryBackend {
175
+ private adapter: AgentDBAdapter;
176
+ private config: UnifiedMemoryServiceConfig;
177
+ private initialized: boolean = false;
178
+
179
+ constructor(config: UnifiedMemoryServiceConfig = {}) {
180
+ super();
181
+ this.config = {
182
+ dimensions: 1536,
183
+ cacheEnabled: true,
184
+ autoEmbed: true,
185
+ ...config,
186
+ };
187
+
188
+ this.adapter = new AgentDBAdapter({
189
+ dimensions: this.config.dimensions,
190
+ cacheEnabled: this.config.cacheEnabled,
191
+ cacheSize: this.config.cacheSize,
192
+ cacheTtl: this.config.cacheTtl,
193
+ hnswM: this.config.hnswM,
194
+ hnswEfConstruction: this.config.hnswEfConstruction,
195
+ defaultNamespace: this.config.defaultNamespace,
196
+ embeddingGenerator: this.config.embeddingGenerator,
197
+ persistenceEnabled: this.config.persistenceEnabled,
198
+ persistencePath: this.config.persistencePath,
199
+ maxEntries: this.config.maxEntries,
200
+ });
201
+
202
+ // Forward adapter events
203
+ this.adapter.on('entry:stored', (data) => this.emit('entry:stored', data));
204
+ this.adapter.on('entry:updated', (data) => this.emit('entry:updated', data));
205
+ this.adapter.on('entry:deleted', (data) => this.emit('entry:deleted', data));
206
+ this.adapter.on('cache:hit', (data) => this.emit('cache:hit', data));
207
+ this.adapter.on('cache:miss', (data) => this.emit('cache:miss', data));
208
+ this.adapter.on('index:added', (data) => this.emit('index:added', data));
209
+ }
210
+
211
+ // ===== Lifecycle =====
212
+
213
+ async initialize(): Promise<void> {
214
+ if (this.initialized) return;
215
+ await this.adapter.initialize();
216
+ this.initialized = true;
217
+ this.emit('initialized');
218
+ }
219
+
220
+ async shutdown(): Promise<void> {
221
+ if (!this.initialized) return;
222
+ await this.adapter.shutdown();
223
+ this.initialized = false;
224
+ this.emit('shutdown');
225
+ }
226
+
227
+ // ===== IMemoryBackend Implementation =====
228
+
229
+ async store(entry: MemoryEntry): Promise<void> {
230
+ return this.adapter.store(entry);
231
+ }
232
+
233
+ async get(id: string): Promise<MemoryEntry | null> {
234
+ return this.adapter.get(id);
235
+ }
236
+
237
+ async getByKey(namespace: string, key: string): Promise<MemoryEntry | null> {
238
+ return this.adapter.getByKey(namespace, key);
239
+ }
240
+
241
+ async update(id: string, update: MemoryEntryUpdate): Promise<MemoryEntry | null> {
242
+ return this.adapter.update(id, update);
243
+ }
244
+
245
+ async delete(id: string): Promise<boolean> {
246
+ return this.adapter.delete(id);
247
+ }
248
+
249
+ async query(query: MemoryQuery): Promise<MemoryEntry[]> {
250
+ return this.adapter.query(query);
251
+ }
252
+
253
+ async search(embedding: Float32Array, options: SearchOptions): Promise<SearchResult[]> {
254
+ return this.adapter.search(embedding, options);
255
+ }
256
+
257
+ async bulkInsert(entries: MemoryEntry[]): Promise<void> {
258
+ return this.adapter.bulkInsert(entries);
259
+ }
260
+
261
+ async bulkDelete(ids: string[]): Promise<number> {
262
+ return this.adapter.bulkDelete(ids);
263
+ }
264
+
265
+ async count(namespace?: string): Promise<number> {
266
+ return this.adapter.count(namespace);
267
+ }
268
+
269
+ async listNamespaces(): Promise<string[]> {
270
+ return this.adapter.listNamespaces();
271
+ }
272
+
273
+ async clearNamespace(namespace: string): Promise<number> {
274
+ return this.adapter.clearNamespace(namespace);
275
+ }
276
+
277
+ async getStats(): Promise<BackendStats> {
278
+ return this.adapter.getStats();
279
+ }
280
+
281
+ async healthCheck(): Promise<HealthCheckResult> {
282
+ return this.adapter.healthCheck();
283
+ }
284
+
285
+ // ===== Convenience Methods =====
286
+
287
+ /**
288
+ * Store an entry from simple input
289
+ */
290
+ async storeEntry(input: MemoryEntryInput): Promise<MemoryEntry> {
291
+ return this.adapter.storeEntry(input);
292
+ }
293
+
294
+ /**
295
+ * Semantic search by content string
296
+ */
297
+ async semanticSearch(
298
+ content: string,
299
+ k: number = 10,
300
+ threshold?: number
301
+ ): Promise<SearchResult[]> {
302
+ return this.adapter.semanticSearch(content, k, threshold);
303
+ }
304
+
305
+ /**
306
+ * Find similar entries to a given entry
307
+ */
308
+ async findSimilar(id: string, k: number = 5): Promise<SearchResult[]> {
309
+ const entry = await this.get(id);
310
+ if (!entry || !entry.embedding) {
311
+ return [];
312
+ }
313
+
314
+ const results = await this.search(entry.embedding, { k: k + 1 });
315
+
316
+ // Filter out the source entry
317
+ return results.filter((r) => r.entry.id !== id).slice(0, k);
318
+ }
319
+
320
+ /**
321
+ * Get or create an entry
322
+ */
323
+ async getOrCreate(
324
+ namespace: string,
325
+ key: string,
326
+ creator: () => MemoryEntryInput | Promise<MemoryEntryInput>
327
+ ): Promise<MemoryEntry> {
328
+ const existing = await this.getByKey(namespace, key);
329
+ if (existing) return existing;
330
+
331
+ const input = await creator();
332
+ return this.storeEntry({ ...input, namespace, key });
333
+ }
334
+
335
+ /**
336
+ * Append content to an existing entry
337
+ */
338
+ async appendContent(id: string, content: string): Promise<MemoryEntry | null> {
339
+ const entry = await this.get(id);
340
+ if (!entry) return null;
341
+
342
+ return this.update(id, {
343
+ content: entry.content + '\n' + content,
344
+ });
345
+ }
346
+
347
+ /**
348
+ * Add tags to an existing entry
349
+ */
350
+ async addTags(id: string, tags: string[]): Promise<MemoryEntry | null> {
351
+ const entry = await this.get(id);
352
+ if (!entry) return null;
353
+
354
+ const newTags = [...new Set([...entry.tags, ...tags])];
355
+ return this.update(id, { tags: newTags });
356
+ }
357
+
358
+ /**
359
+ * Remove tags from an existing entry
360
+ */
361
+ async removeTags(id: string, tags: string[]): Promise<MemoryEntry | null> {
362
+ const entry = await this.get(id);
363
+ if (!entry) return null;
364
+
365
+ const newTags = entry.tags.filter((t) => !tags.includes(t));
366
+ return this.update(id, { tags: newTags });
367
+ }
368
+
369
+ // ===== Migration =====
370
+
371
+ /**
372
+ * Migrate from a legacy memory source
373
+ */
374
+ async migrateFrom(
375
+ source: MigrationSource,
376
+ sourcePath: string,
377
+ options: Partial<MigrationConfig> = {}
378
+ ): Promise<MigrationResult> {
379
+ const migrator = new MemoryMigrator(
380
+ this.adapter,
381
+ { source, sourcePath, ...options },
382
+ this.config.embeddingGenerator
383
+ );
384
+
385
+ // Forward migration events
386
+ migrator.on('migration:started', (data) => this.emit('migration:started', data));
387
+ migrator.on('migration:progress', (data) => this.emit('migration:progress', data));
388
+ migrator.on('migration:completed', (data) => this.emit('migration:completed', data));
389
+ migrator.on('migration:failed', (data) => this.emit('migration:failed', data));
390
+ migrator.on('migration:error', (data) => this.emit('migration:error', data));
391
+ migrator.on('migration:warning', (data) => this.emit('migration:warning', data));
392
+
393
+ return migrator.migrate();
394
+ }
395
+
396
+ // ===== Cross-Agent Memory Sharing =====
397
+
398
+ /**
399
+ * Share an entry with another agent
400
+ */
401
+ async shareWith(id: string, agentId: string): Promise<MemoryEntry | null> {
402
+ const entry = await this.get(id);
403
+ if (!entry) return null;
404
+
405
+ const sharedWith = (entry.metadata.sharedWith as string[]) || [];
406
+ if (!sharedWith.includes(agentId)) {
407
+ sharedWith.push(agentId);
408
+ }
409
+
410
+ return this.update(id, {
411
+ metadata: { ...entry.metadata, sharedWith },
412
+ });
413
+ }
414
+
415
+ /**
416
+ * Get entries shared with a specific agent
417
+ */
418
+ async getSharedWith(agentId: string): Promise<MemoryEntry[]> {
419
+ const all = await this.query({ type: 'hybrid', limit: 10000 });
420
+ return all.filter((entry) => {
421
+ const sharedWith = (entry.metadata.sharedWith as string[]) || [];
422
+ return sharedWith.includes(agentId);
423
+ });
424
+ }
425
+
426
+ // ===== Utility =====
427
+
428
+ /**
429
+ * Get the underlying adapter for advanced operations
430
+ */
431
+ getAdapter(): AgentDBAdapter {
432
+ return this.adapter;
433
+ }
434
+
435
+ /**
436
+ * Check if the service is initialized
437
+ */
438
+ isInitialized(): boolean {
439
+ return this.initialized;
440
+ }
441
+ }
442
+
443
+ // ===== Factory Functions =====
444
+
445
+ /**
446
+ * Create a simple in-memory service (for testing)
447
+ */
448
+ export function createInMemoryService(): UnifiedMemoryService {
449
+ return new UnifiedMemoryService({
450
+ persistenceEnabled: false,
451
+ cacheEnabled: true,
452
+ });
453
+ }
454
+
455
+ /**
456
+ * Create a persistent memory service
457
+ */
458
+ export function createPersistentService(path: string): UnifiedMemoryService {
459
+ return new UnifiedMemoryService({
460
+ persistenceEnabled: true,
461
+ persistencePath: path,
462
+ cacheEnabled: true,
463
+ });
464
+ }
465
+
466
+ /**
467
+ * Create a memory service with embedding support
468
+ */
469
+ export function createEmbeddingService(
470
+ embeddingGenerator: EmbeddingGenerator,
471
+ dimensions: number = 1536
472
+ ): UnifiedMemoryService {
473
+ return new UnifiedMemoryService({
474
+ embeddingGenerator,
475
+ dimensions,
476
+ autoEmbed: true,
477
+ cacheEnabled: true,
478
+ });
479
+ }
480
+
481
+ /**
482
+ * Create a hybrid memory service (SQLite + AgentDB)
483
+ * This is the DEFAULT recommended configuration per ADR-009
484
+ *
485
+ * @example
486
+ * ```typescript
487
+ * const memory = createHybridService('./data/memory.db', embeddingFn);
488
+ * await memory.initialize();
489
+ *
490
+ * // Structured queries go to SQLite
491
+ * const user = await memory.getByKey('users', 'john@example.com');
492
+ *
493
+ * // Semantic queries go to AgentDB
494
+ * const similar = await memory.semanticSearch('authentication patterns', 10);
495
+ * ```
496
+ */
497
+ export function createHybridService(
498
+ databasePath: string,
499
+ embeddingGenerator: EmbeddingGenerator,
500
+ dimensions: number = 1536
501
+ ): UnifiedMemoryService {
502
+ return new UnifiedMemoryService({
503
+ embeddingGenerator,
504
+ dimensions,
505
+ autoEmbed: true,
506
+ cacheEnabled: true,
507
+ // Note: This would require extending UnifiedMemoryService to support HybridBackend
508
+ // For now, this creates an AgentDB service with persistence
509
+ persistenceEnabled: true,
510
+ persistencePath: databasePath,
511
+ });
512
+ }
513
+
514
+ // Default export
515
+ export default UnifiedMemoryService;
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Memory Infrastructure Layer - Public Exports
3
+ *
4
+ * Exports all infrastructure implementations including repositories,
5
+ * adapters, and external service integrations.
6
+ *
7
+ * @module v3/memory/infrastructure
8
+ */
9
+
10
+ // Repositories
11
+ export {
12
+ HybridMemoryRepository,
13
+ type HybridRepositoryConfig,
14
+ } from './repositories/hybrid-memory-repository.js';
15
+
16
+ // Re-export existing adapters
17
+ export { AgentDBAdapter } from '../agentdb-adapter.js';
18
+ export type { AgentDBAdapterConfig } from '../agentdb-adapter.js';
19
+ export { HNSWIndex } from '../hnsw-index.js';
20
+ export type { HNSWConfig } from '../types.js';
21
+ export { CacheManager } from '../cache-manager.js';
22
+ export type { CacheConfig } from '../types.js';
23
+ export { MemoryMigrator } from '../migration.js';