@claude-flow/memory 3.0.0-alpha.1 → 3.0.0-alpha.7

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 (156) hide show
  1. package/README.md +356 -18
  2. package/dist/agent-memory-scope.d.ts +131 -0
  3. package/dist/agent-memory-scope.d.ts.map +1 -0
  4. package/dist/agent-memory-scope.js +215 -0
  5. package/dist/agent-memory-scope.js.map +1 -0
  6. package/dist/agent-memory-scope.test.d.ts +8 -0
  7. package/dist/agent-memory-scope.test.d.ts.map +1 -0
  8. package/dist/agent-memory-scope.test.js +463 -0
  9. package/dist/agent-memory-scope.test.js.map +1 -0
  10. package/dist/agentdb-adapter.d.ts +22 -3
  11. package/dist/agentdb-adapter.d.ts.map +1 -1
  12. package/dist/agentdb-adapter.js +135 -8
  13. package/dist/agentdb-adapter.js.map +1 -1
  14. package/dist/auto-memory-bridge.d.ts +226 -0
  15. package/dist/auto-memory-bridge.d.ts.map +1 -0
  16. package/dist/auto-memory-bridge.js +709 -0
  17. package/dist/auto-memory-bridge.js.map +1 -0
  18. package/dist/auto-memory-bridge.test.d.ts +8 -0
  19. package/dist/auto-memory-bridge.test.d.ts.map +1 -0
  20. package/dist/auto-memory-bridge.test.js +754 -0
  21. package/dist/auto-memory-bridge.test.js.map +1 -0
  22. package/dist/benchmark.test.d.ts +2 -0
  23. package/dist/benchmark.test.d.ts.map +1 -0
  24. package/dist/benchmark.test.js +277 -0
  25. package/dist/benchmark.test.js.map +1 -0
  26. package/dist/index.d.ts +8 -0
  27. package/dist/index.d.ts.map +1 -1
  28. package/dist/index.js +8 -0
  29. package/dist/index.js.map +1 -1
  30. package/dist/learning-bridge.d.ts +137 -0
  31. package/dist/learning-bridge.d.ts.map +1 -0
  32. package/dist/learning-bridge.js +335 -0
  33. package/dist/learning-bridge.js.map +1 -0
  34. package/dist/learning-bridge.test.d.ts +8 -0
  35. package/dist/learning-bridge.test.d.ts.map +1 -0
  36. package/dist/learning-bridge.test.js +578 -0
  37. package/dist/learning-bridge.test.js.map +1 -0
  38. package/dist/memory-graph.d.ts +100 -0
  39. package/dist/memory-graph.d.ts.map +1 -0
  40. package/dist/memory-graph.js +333 -0
  41. package/dist/memory-graph.js.map +1 -0
  42. package/dist/memory-graph.test.d.ts +8 -0
  43. package/dist/memory-graph.test.d.ts.map +1 -0
  44. package/dist/memory-graph.test.js +609 -0
  45. package/dist/memory-graph.test.js.map +1 -0
  46. package/dist/types.d.ts +3 -0
  47. package/dist/types.d.ts.map +1 -1
  48. package/package.json +19 -4
  49. package/.agentic-flow/intelligence.json +0 -16
  50. package/__tests__/coverage/base.css +0 -224
  51. package/__tests__/coverage/block-navigation.js +0 -87
  52. package/__tests__/coverage/coverage-final.json +0 -19
  53. package/__tests__/coverage/favicon.png +0 -0
  54. package/__tests__/coverage/index.html +0 -206
  55. package/__tests__/coverage/lcov-report/base.css +0 -224
  56. package/__tests__/coverage/lcov-report/block-navigation.js +0 -87
  57. package/__tests__/coverage/lcov-report/favicon.png +0 -0
  58. package/__tests__/coverage/lcov-report/index.html +0 -206
  59. package/__tests__/coverage/lcov-report/prettify.css +0 -1
  60. package/__tests__/coverage/lcov-report/prettify.js +0 -2
  61. package/__tests__/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  62. package/__tests__/coverage/lcov-report/sorter.js +0 -210
  63. package/__tests__/coverage/lcov-report/src/agentdb-adapter.ts.html +0 -2737
  64. package/__tests__/coverage/lcov-report/src/agentdb-backend.ts.html +0 -3130
  65. package/__tests__/coverage/lcov-report/src/application/commands/delete-memory.command.ts.html +0 -601
  66. package/__tests__/coverage/lcov-report/src/application/commands/index.html +0 -131
  67. package/__tests__/coverage/lcov-report/src/application/commands/store-memory.command.ts.html +0 -394
  68. package/__tests__/coverage/lcov-report/src/application/queries/index.html +0 -116
  69. package/__tests__/coverage/lcov-report/src/application/queries/search-memory.query.ts.html +0 -796
  70. package/__tests__/coverage/lcov-report/src/application/services/index.html +0 -116
  71. package/__tests__/coverage/lcov-report/src/application/services/memory-application-service.ts.html +0 -793
  72. package/__tests__/coverage/lcov-report/src/cache-manager.ts.html +0 -1633
  73. package/__tests__/coverage/lcov-report/src/database-provider.ts.html +0 -1618
  74. package/__tests__/coverage/lcov-report/src/domain/entities/index.html +0 -116
  75. package/__tests__/coverage/lcov-report/src/domain/entities/memory-entry.ts.html +0 -952
  76. package/__tests__/coverage/lcov-report/src/domain/services/index.html +0 -116
  77. package/__tests__/coverage/lcov-report/src/domain/services/memory-domain-service.ts.html +0 -1294
  78. package/__tests__/coverage/lcov-report/src/hnsw-index.ts.html +0 -3124
  79. package/__tests__/coverage/lcov-report/src/hybrid-backend.ts.html +0 -2167
  80. package/__tests__/coverage/lcov-report/src/index.html +0 -266
  81. package/__tests__/coverage/lcov-report/src/infrastructure/repositories/hybrid-memory-repository.ts.html +0 -1633
  82. package/__tests__/coverage/lcov-report/src/infrastructure/repositories/index.html +0 -116
  83. package/__tests__/coverage/lcov-report/src/migration.ts.html +0 -2092
  84. package/__tests__/coverage/lcov-report/src/query-builder.ts.html +0 -1711
  85. package/__tests__/coverage/lcov-report/src/sqlite-backend.ts.html +0 -2281
  86. package/__tests__/coverage/lcov-report/src/sqljs-backend.ts.html +0 -2374
  87. package/__tests__/coverage/lcov-report/src/types.ts.html +0 -2266
  88. package/__tests__/coverage/lcov.info +0 -10238
  89. package/__tests__/coverage/prettify.css +0 -1
  90. package/__tests__/coverage/prettify.js +0 -2
  91. package/__tests__/coverage/sort-arrow-sprite.png +0 -0
  92. package/__tests__/coverage/sorter.js +0 -210
  93. package/__tests__/coverage/src/agentdb-adapter.ts.html +0 -2737
  94. package/__tests__/coverage/src/agentdb-backend.ts.html +0 -3130
  95. package/__tests__/coverage/src/application/commands/delete-memory.command.ts.html +0 -601
  96. package/__tests__/coverage/src/application/commands/index.html +0 -131
  97. package/__tests__/coverage/src/application/commands/store-memory.command.ts.html +0 -394
  98. package/__tests__/coverage/src/application/queries/index.html +0 -116
  99. package/__tests__/coverage/src/application/queries/search-memory.query.ts.html +0 -796
  100. package/__tests__/coverage/src/application/services/index.html +0 -116
  101. package/__tests__/coverage/src/application/services/memory-application-service.ts.html +0 -793
  102. package/__tests__/coverage/src/cache-manager.ts.html +0 -1633
  103. package/__tests__/coverage/src/database-provider.ts.html +0 -1618
  104. package/__tests__/coverage/src/domain/entities/index.html +0 -116
  105. package/__tests__/coverage/src/domain/entities/memory-entry.ts.html +0 -952
  106. package/__tests__/coverage/src/domain/services/index.html +0 -116
  107. package/__tests__/coverage/src/domain/services/memory-domain-service.ts.html +0 -1294
  108. package/__tests__/coverage/src/hnsw-index.ts.html +0 -3124
  109. package/__tests__/coverage/src/hybrid-backend.ts.html +0 -2167
  110. package/__tests__/coverage/src/index.html +0 -266
  111. package/__tests__/coverage/src/infrastructure/repositories/hybrid-memory-repository.ts.html +0 -1633
  112. package/__tests__/coverage/src/infrastructure/repositories/index.html +0 -116
  113. package/__tests__/coverage/src/migration.ts.html +0 -2092
  114. package/__tests__/coverage/src/query-builder.ts.html +0 -1711
  115. package/__tests__/coverage/src/sqlite-backend.ts.html +0 -2281
  116. package/__tests__/coverage/src/sqljs-backend.ts.html +0 -2374
  117. package/__tests__/coverage/src/types.ts.html +0 -2266
  118. package/benchmarks/cache-hit-rate.bench.ts +0 -535
  119. package/benchmarks/hnsw-indexing.bench.ts +0 -552
  120. package/benchmarks/memory-write.bench.ts +0 -469
  121. package/benchmarks/vector-search.bench.ts +0 -449
  122. package/docs/AGENTDB-INTEGRATION.md +0 -388
  123. package/docs/CROSS_PLATFORM.md +0 -505
  124. package/docs/WINDOWS_SUPPORT.md +0 -422
  125. package/examples/agentdb-example.ts +0 -345
  126. package/examples/cross-platform-usage.ts +0 -326
  127. package/framework/benchmark.ts +0 -112
  128. package/src/agentdb-adapter.ts +0 -884
  129. package/src/agentdb-backend.test.ts +0 -339
  130. package/src/agentdb-backend.ts +0 -1016
  131. package/src/application/commands/delete-memory.command.ts +0 -172
  132. package/src/application/commands/store-memory.command.ts +0 -103
  133. package/src/application/index.ts +0 -36
  134. package/src/application/queries/search-memory.query.ts +0 -237
  135. package/src/application/services/memory-application-service.ts +0 -236
  136. package/src/cache-manager.ts +0 -516
  137. package/src/database-provider.test.ts +0 -364
  138. package/src/database-provider.ts +0 -511
  139. package/src/domain/entities/memory-entry.ts +0 -289
  140. package/src/domain/index.ts +0 -35
  141. package/src/domain/repositories/memory-repository.interface.ts +0 -120
  142. package/src/domain/services/memory-domain-service.ts +0 -403
  143. package/src/hnsw-index.ts +0 -1013
  144. package/src/hybrid-backend.test.ts +0 -399
  145. package/src/hybrid-backend.ts +0 -694
  146. package/src/index.ts +0 -515
  147. package/src/infrastructure/index.ts +0 -23
  148. package/src/infrastructure/repositories/hybrid-memory-repository.ts +0 -516
  149. package/src/migration.ts +0 -669
  150. package/src/query-builder.ts +0 -542
  151. package/src/sqlite-backend.ts +0 -732
  152. package/src/sqljs-backend.ts +0 -763
  153. package/src/types.ts +0 -727
  154. package/tsconfig.json +0 -9
  155. package/tsconfig.tsbuildinfo +0 -1
  156. package/verify-cross-platform.ts +0 -170
package/src/index.ts DELETED
@@ -1,515 +0,0 @@
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;
@@ -1,23 +0,0 @@
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';