moflo 4.8.19 → 4.8.20
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/guidance/shipped/moflo.md +45 -0
- package/.claude/helpers/statusline.cjs +1 -1
- package/.claude/workflow-state.json +9 -0
- package/package.json +2 -2
- package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +1 -1
- package/src/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +5 -3
- package/src/@claude-flow/cli/package.json +1 -1
- package/src/@claude-flow/memory/dist/agent-memory-scope.d.ts +131 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.js +223 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.test.js +466 -0
- package/src/@claude-flow/memory/dist/agentdb-adapter.d.ts +165 -0
- package/src/@claude-flow/memory/dist/agentdb-adapter.js +806 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.d.ts +212 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.js +842 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.test.d.ts +7 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.test.js +258 -0
- package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.d.ts +65 -0
- package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.js +129 -0
- package/src/@claude-flow/memory/dist/application/commands/store-memory.command.d.ts +48 -0
- package/src/@claude-flow/memory/dist/application/commands/store-memory.command.js +72 -0
- package/src/@claude-flow/memory/dist/application/index.d.ts +12 -0
- package/src/@claude-flow/memory/dist/application/index.js +15 -0
- package/src/@claude-flow/memory/dist/application/queries/search-memory.query.d.ts +72 -0
- package/src/@claude-flow/memory/dist/application/queries/search-memory.query.js +143 -0
- package/src/@claude-flow/memory/dist/application/services/memory-application-service.d.ts +121 -0
- package/src/@claude-flow/memory/dist/application/services/memory-application-service.js +190 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.d.ts +226 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.js +709 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +757 -0
- package/src/@claude-flow/memory/dist/benchmark.test.d.ts +2 -0
- package/src/@claude-flow/memory/dist/benchmark.test.js +277 -0
- package/src/@claude-flow/memory/dist/cache-manager.d.ts +134 -0
- package/src/@claude-flow/memory/dist/cache-manager.js +407 -0
- package/src/@claude-flow/memory/dist/controller-registry.d.ts +216 -0
- package/src/@claude-flow/memory/dist/controller-registry.js +893 -0
- package/src/@claude-flow/memory/dist/controller-registry.test.d.ts +14 -0
- package/src/@claude-flow/memory/dist/controller-registry.test.js +593 -0
- package/src/@claude-flow/memory/dist/database-provider.d.ts +87 -0
- package/src/@claude-flow/memory/dist/database-provider.js +372 -0
- package/src/@claude-flow/memory/dist/database-provider.test.d.ts +7 -0
- package/src/@claude-flow/memory/dist/database-provider.test.js +287 -0
- package/src/@claude-flow/memory/dist/domain/entities/memory-entry.d.ts +143 -0
- package/src/@claude-flow/memory/dist/domain/entities/memory-entry.js +226 -0
- package/src/@claude-flow/memory/dist/domain/index.d.ts +11 -0
- package/src/@claude-flow/memory/dist/domain/index.js +12 -0
- package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.d.ts +102 -0
- package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.js +11 -0
- package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.d.ts +105 -0
- package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.js +297 -0
- package/src/@claude-flow/memory/dist/hnsw-index.d.ts +111 -0
- package/src/@claude-flow/memory/dist/hnsw-index.js +781 -0
- package/src/@claude-flow/memory/dist/hnsw-lite.d.ts +23 -0
- package/src/@claude-flow/memory/dist/hnsw-lite.js +168 -0
- package/src/@claude-flow/memory/dist/index.d.ts +204 -0
- package/src/@claude-flow/memory/dist/index.js +358 -0
- package/src/@claude-flow/memory/dist/infrastructure/index.d.ts +17 -0
- package/src/@claude-flow/memory/dist/infrastructure/index.js +16 -0
- package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.d.ts +66 -0
- package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.js +409 -0
- package/src/@claude-flow/memory/dist/learning-bridge.d.ts +137 -0
- package/src/@claude-flow/memory/dist/learning-bridge.js +335 -0
- package/src/@claude-flow/memory/dist/learning-bridge.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/learning-bridge.test.js +578 -0
- package/src/@claude-flow/memory/dist/memory-graph.d.ts +100 -0
- package/src/@claude-flow/memory/dist/memory-graph.js +333 -0
- package/src/@claude-flow/memory/dist/memory-graph.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/memory-graph.test.js +609 -0
- package/src/@claude-flow/memory/dist/migration.d.ts +68 -0
- package/src/@claude-flow/memory/dist/migration.js +513 -0
- package/src/@claude-flow/memory/dist/persistent-sona.d.ts +144 -0
- package/src/@claude-flow/memory/dist/persistent-sona.js +332 -0
- package/src/@claude-flow/memory/dist/query-builder.d.ts +211 -0
- package/src/@claude-flow/memory/dist/query-builder.js +438 -0
- package/src/@claude-flow/memory/dist/rvf-backend.d.ts +51 -0
- package/src/@claude-flow/memory/dist/rvf-backend.js +481 -0
- package/src/@claude-flow/memory/dist/rvf-learning-store.d.ts +139 -0
- package/src/@claude-flow/memory/dist/rvf-learning-store.js +295 -0
- package/src/@claude-flow/memory/dist/rvf-migration.d.ts +45 -0
- package/src/@claude-flow/memory/dist/rvf-migration.js +234 -0
- package/src/@claude-flow/memory/dist/sqljs-backend.d.ts +127 -0
- package/src/@claude-flow/memory/dist/sqljs-backend.js +600 -0
- package/src/@claude-flow/memory/dist/types.d.ts +484 -0
- package/src/@claude-flow/memory/dist/types.js +58 -0
- package/src/@claude-flow/shared/dist/core/config/defaults.d.ts +41 -0
- package/src/@claude-flow/shared/dist/core/config/defaults.js +186 -0
- package/src/@claude-flow/shared/dist/core/config/index.d.ts +8 -0
- package/src/@claude-flow/shared/dist/core/config/index.js +12 -0
- package/src/@claude-flow/shared/dist/core/config/loader.d.ts +45 -0
- package/src/@claude-flow/shared/dist/core/config/loader.js +222 -0
- package/src/@claude-flow/shared/dist/core/config/schema.d.ts +1134 -0
- package/src/@claude-flow/shared/dist/core/config/schema.js +158 -0
- package/src/@claude-flow/shared/dist/core/config/validator.d.ts +92 -0
- package/src/@claude-flow/shared/dist/core/config/validator.js +147 -0
- package/src/@claude-flow/shared/dist/core/event-bus.d.ts +31 -0
- package/src/@claude-flow/shared/dist/core/event-bus.js +197 -0
- package/src/@claude-flow/shared/dist/core/index.d.ts +15 -0
- package/src/@claude-flow/shared/dist/core/index.js +19 -0
- package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +200 -0
- package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.js +6 -0
- package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +310 -0
- package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +7 -0
- package/src/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +224 -0
- package/src/@claude-flow/shared/dist/core/interfaces/event.interface.js +46 -0
- package/src/@claude-flow/shared/dist/core/interfaces/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/core/interfaces/index.js +15 -0
- package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +298 -0
- package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.js +7 -0
- package/src/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +185 -0
- package/src/@claude-flow/shared/dist/core/interfaces/task.interface.js +6 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +35 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +101 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +60 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +166 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/index.d.ts +46 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/index.js +64 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +195 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +83 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.js +193 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +49 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.js +253 -0
- package/src/@claude-flow/shared/dist/events/domain-events.d.ts +282 -0
- package/src/@claude-flow/shared/dist/events/domain-events.js +165 -0
- package/src/@claude-flow/shared/dist/events/event-store.d.ts +126 -0
- package/src/@claude-flow/shared/dist/events/event-store.js +432 -0
- package/src/@claude-flow/shared/dist/events/event-store.test.d.ts +8 -0
- package/src/@claude-flow/shared/dist/events/event-store.test.js +297 -0
- package/src/@claude-flow/shared/dist/events/example-usage.d.ts +10 -0
- package/src/@claude-flow/shared/dist/events/example-usage.js +193 -0
- package/src/@claude-flow/shared/dist/events/index.d.ts +21 -0
- package/src/@claude-flow/shared/dist/events/index.js +22 -0
- package/src/@claude-flow/shared/dist/events/projections.d.ts +177 -0
- package/src/@claude-flow/shared/dist/events/projections.js +421 -0
- package/src/@claude-flow/shared/dist/events/rvf-event-log.d.ts +82 -0
- package/src/@claude-flow/shared/dist/events/rvf-event-log.js +340 -0
- package/src/@claude-flow/shared/dist/events/state-reconstructor.d.ts +101 -0
- package/src/@claude-flow/shared/dist/events/state-reconstructor.js +263 -0
- package/src/@claude-flow/shared/dist/events.d.ts +80 -0
- package/src/@claude-flow/shared/dist/events.js +249 -0
- package/src/@claude-flow/shared/dist/hooks/example-usage.d.ts +42 -0
- package/src/@claude-flow/shared/dist/hooks/example-usage.js +351 -0
- package/src/@claude-flow/shared/dist/hooks/executor.d.ts +100 -0
- package/src/@claude-flow/shared/dist/hooks/executor.js +267 -0
- package/src/@claude-flow/shared/dist/hooks/hooks.test.d.ts +9 -0
- package/src/@claude-flow/shared/dist/hooks/hooks.test.js +322 -0
- package/src/@claude-flow/shared/dist/hooks/index.d.ts +52 -0
- package/src/@claude-flow/shared/dist/hooks/index.js +51 -0
- package/src/@claude-flow/shared/dist/hooks/registry.d.ts +133 -0
- package/src/@claude-flow/shared/dist/hooks/registry.js +277 -0
- package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +105 -0
- package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.js +481 -0
- package/src/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +144 -0
- package/src/@claude-flow/shared/dist/hooks/safety/file-organization.js +328 -0
- package/src/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +158 -0
- package/src/@claude-flow/shared/dist/hooks/safety/git-commit.js +450 -0
- package/src/@claude-flow/shared/dist/hooks/safety/index.d.ts +17 -0
- package/src/@claude-flow/shared/dist/hooks/safety/index.js +17 -0
- package/src/@claude-flow/shared/dist/hooks/session-hooks.d.ts +234 -0
- package/src/@claude-flow/shared/dist/hooks/session-hooks.js +334 -0
- package/src/@claude-flow/shared/dist/hooks/task-hooks.d.ts +163 -0
- package/src/@claude-flow/shared/dist/hooks/task-hooks.js +326 -0
- package/src/@claude-flow/shared/dist/hooks/types.d.ts +267 -0
- package/src/@claude-flow/shared/dist/hooks/types.js +62 -0
- package/src/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +9 -0
- package/src/@claude-flow/shared/dist/hooks/verify-exports.test.js +93 -0
- package/src/@claude-flow/shared/dist/index.d.ts +20 -0
- package/src/@claude-flow/shared/dist/index.js +50 -0
- package/src/@claude-flow/shared/dist/mcp/connection-pool.d.ts +98 -0
- package/src/@claude-flow/shared/dist/mcp/connection-pool.js +364 -0
- package/src/@claude-flow/shared/dist/mcp/index.d.ts +69 -0
- package/src/@claude-flow/shared/dist/mcp/index.js +84 -0
- package/src/@claude-flow/shared/dist/mcp/server.d.ts +166 -0
- package/src/@claude-flow/shared/dist/mcp/server.js +593 -0
- package/src/@claude-flow/shared/dist/mcp/session-manager.d.ts +136 -0
- package/src/@claude-flow/shared/dist/mcp/session-manager.js +335 -0
- package/src/@claude-flow/shared/dist/mcp/tool-registry.d.ts +178 -0
- package/src/@claude-flow/shared/dist/mcp/tool-registry.js +439 -0
- package/src/@claude-flow/shared/dist/mcp/transport/http.d.ts +104 -0
- package/src/@claude-flow/shared/dist/mcp/transport/http.js +476 -0
- package/src/@claude-flow/shared/dist/mcp/transport/index.d.ts +102 -0
- package/src/@claude-flow/shared/dist/mcp/transport/index.js +238 -0
- package/src/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +104 -0
- package/src/@claude-flow/shared/dist/mcp/transport/stdio.js +263 -0
- package/src/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +133 -0
- package/src/@claude-flow/shared/dist/mcp/transport/websocket.js +396 -0
- package/src/@claude-flow/shared/dist/mcp/types.d.ts +438 -0
- package/src/@claude-flow/shared/dist/mcp/types.js +54 -0
- package/src/@claude-flow/shared/dist/plugin-interface.d.ts +544 -0
- package/src/@claude-flow/shared/dist/plugin-interface.js +23 -0
- package/src/@claude-flow/shared/dist/plugin-loader.d.ts +139 -0
- package/src/@claude-flow/shared/dist/plugin-loader.js +434 -0
- package/src/@claude-flow/shared/dist/plugin-registry.d.ts +183 -0
- package/src/@claude-flow/shared/dist/plugin-registry.js +457 -0
- package/src/@claude-flow/shared/dist/plugins/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/plugins/index.js +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
- package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +241 -0
- package/src/@claude-flow/shared/dist/plugins/official/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/index.js +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +121 -0
- package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +355 -0
- package/src/@claude-flow/shared/dist/plugins/types.d.ts +93 -0
- package/src/@claude-flow/shared/dist/plugins/types.js +9 -0
- package/src/@claude-flow/shared/dist/resilience/bulkhead.d.ts +105 -0
- package/src/@claude-flow/shared/dist/resilience/bulkhead.js +206 -0
- package/src/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +132 -0
- package/src/@claude-flow/shared/dist/resilience/circuit-breaker.js +233 -0
- package/src/@claude-flow/shared/dist/resilience/index.d.ts +19 -0
- package/src/@claude-flow/shared/dist/resilience/index.js +19 -0
- package/src/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +168 -0
- package/src/@claude-flow/shared/dist/resilience/rate-limiter.js +314 -0
- package/src/@claude-flow/shared/dist/resilience/retry.d.ts +91 -0
- package/src/@claude-flow/shared/dist/resilience/retry.js +159 -0
- package/src/@claude-flow/shared/dist/security/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/security/index.js +12 -0
- package/src/@claude-flow/shared/dist/security/input-validation.d.ts +73 -0
- package/src/@claude-flow/shared/dist/security/input-validation.js +201 -0
- package/src/@claude-flow/shared/dist/security/secure-random.d.ts +92 -0
- package/src/@claude-flow/shared/dist/security/secure-random.js +142 -0
- package/src/@claude-flow/shared/dist/services/index.d.ts +7 -0
- package/src/@claude-flow/shared/dist/services/index.js +7 -0
- package/src/@claude-flow/shared/dist/services/v3-progress.service.d.ts +124 -0
- package/src/@claude-flow/shared/dist/services/v3-progress.service.js +402 -0
- package/src/@claude-flow/shared/dist/types/agent.types.d.ts +137 -0
- package/src/@claude-flow/shared/dist/types/agent.types.js +6 -0
- package/src/@claude-flow/shared/dist/types/index.d.ts +11 -0
- package/src/@claude-flow/shared/dist/types/index.js +17 -0
- package/src/@claude-flow/shared/dist/types/mcp.types.d.ts +266 -0
- package/src/@claude-flow/shared/dist/types/mcp.types.js +7 -0
- package/src/@claude-flow/shared/dist/types/memory.types.d.ts +236 -0
- package/src/@claude-flow/shared/dist/types/memory.types.js +7 -0
- package/src/@claude-flow/shared/dist/types/swarm.types.d.ts +186 -0
- package/src/@claude-flow/shared/dist/types/swarm.types.js +65 -0
- package/src/@claude-flow/shared/dist/types/task.types.d.ts +178 -0
- package/src/@claude-flow/shared/dist/types/task.types.js +32 -0
- package/src/@claude-flow/shared/dist/types.d.ts +197 -0
- package/src/@claude-flow/shared/dist/types.js +21 -0
- package/src/@claude-flow/shared/dist/utils/secure-logger.d.ts +69 -0
- package/src/@claude-flow/shared/dist/utils/secure-logger.js +208 -0
|
@@ -0,0 +1,297 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Memory Domain Service - Domain Layer
|
|
3
|
+
*
|
|
4
|
+
* Contains domain logic that doesn't naturally fit within a single entity.
|
|
5
|
+
* Coordinates between multiple memory entries and enforces domain rules.
|
|
6
|
+
*
|
|
7
|
+
* @module v3/memory/domain/services
|
|
8
|
+
*/
|
|
9
|
+
import { MemoryEntry } from '../entities/memory-entry.js';
|
|
10
|
+
/**
|
|
11
|
+
* Memory Domain Service
|
|
12
|
+
*
|
|
13
|
+
* Provides domain-level operations that span multiple entities.
|
|
14
|
+
* Implements business rules for memory management.
|
|
15
|
+
*/
|
|
16
|
+
export class MemoryDomainService {
|
|
17
|
+
repository;
|
|
18
|
+
constructor(repository) {
|
|
19
|
+
this.repository = repository;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Store a new memory with automatic type detection
|
|
23
|
+
*/
|
|
24
|
+
async storeWithTypeDetection(namespace, key, value, vector) {
|
|
25
|
+
const type = this.detectMemoryType(value);
|
|
26
|
+
const entry = MemoryEntry.create({
|
|
27
|
+
namespace,
|
|
28
|
+
key,
|
|
29
|
+
value,
|
|
30
|
+
type,
|
|
31
|
+
vector,
|
|
32
|
+
});
|
|
33
|
+
await this.repository.save(entry);
|
|
34
|
+
return entry;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Retrieve and record access
|
|
38
|
+
*/
|
|
39
|
+
async retrieveWithAccessTracking(namespace, key) {
|
|
40
|
+
const entry = await this.repository.findByKey(namespace, key);
|
|
41
|
+
if (entry && entry.isAccessible()) {
|
|
42
|
+
entry.recordAccess();
|
|
43
|
+
await this.repository.save(entry);
|
|
44
|
+
}
|
|
45
|
+
return entry;
|
|
46
|
+
}
|
|
47
|
+
/**
|
|
48
|
+
* Search for similar memories and record access
|
|
49
|
+
*/
|
|
50
|
+
async searchSimilarWithTracking(vector, namespace, limit = 10) {
|
|
51
|
+
const results = await this.repository.searchByVector({
|
|
52
|
+
vector,
|
|
53
|
+
namespace,
|
|
54
|
+
limit,
|
|
55
|
+
});
|
|
56
|
+
// Record access for all returned entries
|
|
57
|
+
await Promise.all(results.map(async (result) => {
|
|
58
|
+
result.entry.recordAccess();
|
|
59
|
+
await this.repository.save(result.entry);
|
|
60
|
+
}));
|
|
61
|
+
return results;
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Consolidate memories based on strategy
|
|
65
|
+
*/
|
|
66
|
+
async consolidate(options) {
|
|
67
|
+
const entries = await this.repository.findByNamespace(options.namespace ?? 'default', { status: 'active' });
|
|
68
|
+
let result = {
|
|
69
|
+
processed: entries.length,
|
|
70
|
+
consolidated: 0,
|
|
71
|
+
removed: 0,
|
|
72
|
+
newEntries: [],
|
|
73
|
+
};
|
|
74
|
+
switch (options.strategy) {
|
|
75
|
+
case 'prune':
|
|
76
|
+
result = await this.pruneOldMemories(entries, options);
|
|
77
|
+
break;
|
|
78
|
+
case 'dedupe':
|
|
79
|
+
const dedupeResult = await this.deduplicateMemories(entries, options);
|
|
80
|
+
result.removed = dedupeResult.duplicatesRemoved;
|
|
81
|
+
break;
|
|
82
|
+
case 'merge':
|
|
83
|
+
result = await this.mergeRelatedMemories(entries, options);
|
|
84
|
+
break;
|
|
85
|
+
default:
|
|
86
|
+
// No-op for unknown strategies
|
|
87
|
+
}
|
|
88
|
+
return result;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Detect memory type based on value structure
|
|
92
|
+
*/
|
|
93
|
+
detectMemoryType(value) {
|
|
94
|
+
if (typeof value === 'string') {
|
|
95
|
+
// Long text is likely semantic
|
|
96
|
+
if (value.length > 500)
|
|
97
|
+
return 'semantic';
|
|
98
|
+
// Short instructions are procedural
|
|
99
|
+
if (value.includes('->') || value.includes('then'))
|
|
100
|
+
return 'procedural';
|
|
101
|
+
}
|
|
102
|
+
if (typeof value === 'object' && value !== null) {
|
|
103
|
+
const obj = value;
|
|
104
|
+
// Objects with timestamps are episodic
|
|
105
|
+
if ('timestamp' in obj || 'when' in obj || 'date' in obj)
|
|
106
|
+
return 'episodic';
|
|
107
|
+
// Objects with steps are procedural
|
|
108
|
+
if ('steps' in obj || 'actions' in obj)
|
|
109
|
+
return 'procedural';
|
|
110
|
+
}
|
|
111
|
+
// Default to working memory for short-term storage
|
|
112
|
+
return 'working';
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Prune old, rarely accessed memories
|
|
116
|
+
*/
|
|
117
|
+
async pruneOldMemories(entries, options) {
|
|
118
|
+
const maxAge = options.maxAge ?? 7 * 24 * 60 * 60 * 1000; // 7 days default
|
|
119
|
+
const threshold = options.threshold ?? 5; // Minimum access count to keep
|
|
120
|
+
const now = Date.now();
|
|
121
|
+
const toRemove = [];
|
|
122
|
+
for (const entry of entries) {
|
|
123
|
+
const age = now - entry.createdAt.getTime();
|
|
124
|
+
const isOld = age > maxAge;
|
|
125
|
+
const isRarelyAccessed = entry.accessCount < threshold;
|
|
126
|
+
// Keep hot memories if requested
|
|
127
|
+
if (options.keepHot && entry.isHot())
|
|
128
|
+
continue;
|
|
129
|
+
if (isOld && isRarelyAccessed) {
|
|
130
|
+
entry.archive();
|
|
131
|
+
toRemove.push(entry.id);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
if (toRemove.length > 0) {
|
|
135
|
+
await this.repository.deleteMany(toRemove);
|
|
136
|
+
}
|
|
137
|
+
return {
|
|
138
|
+
processed: entries.length,
|
|
139
|
+
consolidated: 0,
|
|
140
|
+
removed: toRemove.length,
|
|
141
|
+
newEntries: [],
|
|
142
|
+
};
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Find and remove duplicate memories
|
|
146
|
+
*/
|
|
147
|
+
async deduplicateMemories(entries, options) {
|
|
148
|
+
const threshold = options.threshold ?? 0.95; // Similarity threshold
|
|
149
|
+
const duplicates = [];
|
|
150
|
+
const processed = new Set();
|
|
151
|
+
for (let i = 0; i < entries.length; i++) {
|
|
152
|
+
if (processed.has(entries[i].id))
|
|
153
|
+
continue;
|
|
154
|
+
const entry = entries[i];
|
|
155
|
+
if (!entry.vector)
|
|
156
|
+
continue;
|
|
157
|
+
// Find similar entries
|
|
158
|
+
const similar = await this.repository.searchByVector({
|
|
159
|
+
vector: entry.vector,
|
|
160
|
+
namespace: entry.namespace,
|
|
161
|
+
limit: 10,
|
|
162
|
+
threshold,
|
|
163
|
+
});
|
|
164
|
+
// Mark duplicates (keep the one with highest access count)
|
|
165
|
+
const group = similar
|
|
166
|
+
.filter((s) => s.entry.id !== entry.id && s.similarity >= threshold)
|
|
167
|
+
.sort((a, b) => b.entry.accessCount - a.entry.accessCount);
|
|
168
|
+
for (const dup of group.slice(1)) {
|
|
169
|
+
duplicates.push(dup.entry.id);
|
|
170
|
+
processed.add(dup.entry.id);
|
|
171
|
+
}
|
|
172
|
+
processed.add(entry.id);
|
|
173
|
+
}
|
|
174
|
+
if (duplicates.length > 0) {
|
|
175
|
+
await this.repository.deleteMany(duplicates);
|
|
176
|
+
}
|
|
177
|
+
return {
|
|
178
|
+
duplicatesFound: duplicates.length,
|
|
179
|
+
duplicatesRemoved: duplicates.length,
|
|
180
|
+
groupsProcessed: processed.size,
|
|
181
|
+
};
|
|
182
|
+
}
|
|
183
|
+
/**
|
|
184
|
+
* Merge related memories into consolidated entries
|
|
185
|
+
*/
|
|
186
|
+
async mergeRelatedMemories(entries, options) {
|
|
187
|
+
const threshold = options.threshold ?? 0.8;
|
|
188
|
+
const newEntries = [];
|
|
189
|
+
const toRemove = [];
|
|
190
|
+
const processed = new Set();
|
|
191
|
+
for (const entry of entries) {
|
|
192
|
+
if (processed.has(entry.id))
|
|
193
|
+
continue;
|
|
194
|
+
if (!entry.vector) {
|
|
195
|
+
processed.add(entry.id);
|
|
196
|
+
continue;
|
|
197
|
+
}
|
|
198
|
+
// Find related entries
|
|
199
|
+
const related = await this.repository.searchByVector({
|
|
200
|
+
vector: entry.vector,
|
|
201
|
+
namespace: entry.namespace,
|
|
202
|
+
limit: 5,
|
|
203
|
+
threshold,
|
|
204
|
+
});
|
|
205
|
+
if (related.length > 1) {
|
|
206
|
+
// Merge related entries
|
|
207
|
+
const merged = this.mergeEntries(related.map((r) => r.entry));
|
|
208
|
+
newEntries.push(merged);
|
|
209
|
+
for (const r of related) {
|
|
210
|
+
toRemove.push(r.entry.id);
|
|
211
|
+
processed.add(r.entry.id);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
else {
|
|
215
|
+
processed.add(entry.id);
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
// Remove old entries and save merged ones
|
|
219
|
+
if (toRemove.length > 0) {
|
|
220
|
+
await this.repository.deleteMany(toRemove);
|
|
221
|
+
}
|
|
222
|
+
if (newEntries.length > 0) {
|
|
223
|
+
await this.repository.saveMany(newEntries);
|
|
224
|
+
}
|
|
225
|
+
return {
|
|
226
|
+
processed: entries.length,
|
|
227
|
+
consolidated: newEntries.length,
|
|
228
|
+
removed: toRemove.length,
|
|
229
|
+
newEntries,
|
|
230
|
+
};
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* Merge multiple entries into one
|
|
234
|
+
*/
|
|
235
|
+
mergeEntries(entries) {
|
|
236
|
+
// Sort by access count to prioritize most accessed
|
|
237
|
+
const sorted = [...entries].sort((a, b) => b.accessCount - a.accessCount);
|
|
238
|
+
const primary = sorted[0];
|
|
239
|
+
// Combine metadata
|
|
240
|
+
const combinedMetadata = {};
|
|
241
|
+
for (const entry of entries) {
|
|
242
|
+
Object.assign(combinedMetadata, entry.metadata);
|
|
243
|
+
}
|
|
244
|
+
combinedMetadata.mergedFrom = entries.map((e) => e.id);
|
|
245
|
+
combinedMetadata.mergedAt = new Date().toISOString();
|
|
246
|
+
// Create merged entry
|
|
247
|
+
return MemoryEntry.create({
|
|
248
|
+
namespace: primary.namespace,
|
|
249
|
+
key: `merged_${Date.now()}`,
|
|
250
|
+
value: {
|
|
251
|
+
primary: primary.value,
|
|
252
|
+
related: sorted.slice(1).map((e) => e.value),
|
|
253
|
+
},
|
|
254
|
+
type: primary.type,
|
|
255
|
+
vector: primary.vector,
|
|
256
|
+
metadata: combinedMetadata,
|
|
257
|
+
accessCount: entries.reduce((sum, e) => sum + e.accessCount, 0),
|
|
258
|
+
});
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* Analyze a namespace
|
|
262
|
+
*/
|
|
263
|
+
async analyzeNamespace(namespace) {
|
|
264
|
+
const entries = await this.repository.findByNamespace(namespace);
|
|
265
|
+
const active = entries.filter((e) => e.status === 'active');
|
|
266
|
+
const typeDistribution = {
|
|
267
|
+
semantic: 0,
|
|
268
|
+
episodic: 0,
|
|
269
|
+
procedural: 0,
|
|
270
|
+
working: 0,
|
|
271
|
+
};
|
|
272
|
+
let totalAccessCount = 0;
|
|
273
|
+
let totalSize = 0;
|
|
274
|
+
let oldestDate = new Date();
|
|
275
|
+
let newestDate = new Date(0);
|
|
276
|
+
for (const entry of entries) {
|
|
277
|
+
typeDistribution[entry.type]++;
|
|
278
|
+
totalAccessCount += entry.accessCount;
|
|
279
|
+
totalSize += JSON.stringify(entry.value).length;
|
|
280
|
+
if (entry.createdAt < oldestDate)
|
|
281
|
+
oldestDate = entry.createdAt;
|
|
282
|
+
if (entry.createdAt > newestDate)
|
|
283
|
+
newestDate = entry.createdAt;
|
|
284
|
+
}
|
|
285
|
+
return {
|
|
286
|
+
namespace,
|
|
287
|
+
totalEntries: entries.length,
|
|
288
|
+
activeEntries: active.length,
|
|
289
|
+
totalSize,
|
|
290
|
+
averageAccessCount: entries.length > 0 ? totalAccessCount / entries.length : 0,
|
|
291
|
+
oldestEntry: oldestDate,
|
|
292
|
+
newestEntry: newestDate,
|
|
293
|
+
typeDistribution,
|
|
294
|
+
};
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
//# sourceMappingURL=memory-domain-service.js.map
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* V3 HNSW Vector Index
|
|
3
|
+
*
|
|
4
|
+
* High-performance Hierarchical Navigable Small World (HNSW) index for
|
|
5
|
+
* 150x-12,500x faster vector similarity search compared to brute force.
|
|
6
|
+
*
|
|
7
|
+
* OPTIMIZATIONS:
|
|
8
|
+
* - BinaryMinHeap/BinaryMaxHeap for O(log n) operations (vs O(n log n) Array.sort)
|
|
9
|
+
* - Pre-normalized vectors for O(1) cosine similarity (no sqrt needed)
|
|
10
|
+
* - Bounded max-heap for efficient top-k tracking
|
|
11
|
+
*
|
|
12
|
+
* @module v3/memory/hnsw-index
|
|
13
|
+
*/
|
|
14
|
+
import { EventEmitter } from 'node:events';
|
|
15
|
+
import { HNSWConfig, HNSWStats } from './types.js';
|
|
16
|
+
/**
|
|
17
|
+
* HNSW Index implementation for ultra-fast vector similarity search
|
|
18
|
+
*
|
|
19
|
+
* Performance characteristics:
|
|
20
|
+
* - Search: O(log n) approximate nearest neighbor
|
|
21
|
+
* - Insert: O(log n) amortized
|
|
22
|
+
* - Memory: O(n * M * L) where M is max connections, L is layers
|
|
23
|
+
*/
|
|
24
|
+
export declare class HNSWIndex extends EventEmitter {
|
|
25
|
+
private config;
|
|
26
|
+
private nodes;
|
|
27
|
+
private entryPoint;
|
|
28
|
+
private maxLevel;
|
|
29
|
+
private levelMult;
|
|
30
|
+
private stats;
|
|
31
|
+
private quantizer;
|
|
32
|
+
constructor(config?: Partial<HNSWConfig>);
|
|
33
|
+
/**
|
|
34
|
+
* Add a vector to the index
|
|
35
|
+
*/
|
|
36
|
+
addPoint(id: string, vector: Float32Array): Promise<void>;
|
|
37
|
+
/**
|
|
38
|
+
* Search for k nearest neighbors
|
|
39
|
+
*/
|
|
40
|
+
search(query: Float32Array, k: number, ef?: number): Promise<Array<{
|
|
41
|
+
id: string;
|
|
42
|
+
distance: number;
|
|
43
|
+
}>>;
|
|
44
|
+
/**
|
|
45
|
+
* Search with filters applied post-retrieval
|
|
46
|
+
*/
|
|
47
|
+
searchWithFilters(query: Float32Array, k: number, filter: (id: string) => boolean, ef?: number): Promise<Array<{
|
|
48
|
+
id: string;
|
|
49
|
+
distance: number;
|
|
50
|
+
}>>;
|
|
51
|
+
/**
|
|
52
|
+
* Remove a point from the index
|
|
53
|
+
*/
|
|
54
|
+
removePoint(id: string): Promise<boolean>;
|
|
55
|
+
/**
|
|
56
|
+
* Rebuild the index from scratch
|
|
57
|
+
*/
|
|
58
|
+
rebuild(entries: Array<{
|
|
59
|
+
id: string;
|
|
60
|
+
vector: Float32Array;
|
|
61
|
+
}>): Promise<void>;
|
|
62
|
+
/**
|
|
63
|
+
* Get index statistics
|
|
64
|
+
*/
|
|
65
|
+
getStats(): HNSWStats;
|
|
66
|
+
/**
|
|
67
|
+
* Clear the index
|
|
68
|
+
*/
|
|
69
|
+
clear(): void;
|
|
70
|
+
/**
|
|
71
|
+
* Check if an ID exists in the index
|
|
72
|
+
*/
|
|
73
|
+
has(id: string): boolean;
|
|
74
|
+
/**
|
|
75
|
+
* Get the number of vectors in the index
|
|
76
|
+
*/
|
|
77
|
+
get size(): number;
|
|
78
|
+
private mergeConfig;
|
|
79
|
+
private getRandomLevel;
|
|
80
|
+
private insertNode;
|
|
81
|
+
private searchLayer;
|
|
82
|
+
/**
|
|
83
|
+
* OPTIMIZED searchLayer using heap-based priority queues
|
|
84
|
+
* Performance: O(log n) per operation vs O(n log n) for Array.sort()
|
|
85
|
+
* Expected speedup: 3-5x for large result sets
|
|
86
|
+
*/
|
|
87
|
+
private searchLayerOptimized;
|
|
88
|
+
private selectNeighbors;
|
|
89
|
+
private pruneConnections;
|
|
90
|
+
private distance;
|
|
91
|
+
private cosineDistance;
|
|
92
|
+
/**
|
|
93
|
+
* OPTIMIZED: Cosine distance using pre-normalized vectors
|
|
94
|
+
* Only requires dot product (no sqrt operations)
|
|
95
|
+
* Performance: O(n) with ~2x speedup over standard cosine
|
|
96
|
+
*/
|
|
97
|
+
private cosineDistanceNormalized;
|
|
98
|
+
/**
|
|
99
|
+
* Normalize a vector to unit length for O(1) cosine similarity
|
|
100
|
+
*/
|
|
101
|
+
private normalizeVector;
|
|
102
|
+
/**
|
|
103
|
+
* OPTIMIZED distance calculation that uses pre-normalized vectors when available
|
|
104
|
+
*/
|
|
105
|
+
private distanceOptimized;
|
|
106
|
+
private euclideanDistance;
|
|
107
|
+
private dotProductDistance;
|
|
108
|
+
private manhattanDistance;
|
|
109
|
+
}
|
|
110
|
+
export default HNSWIndex;
|
|
111
|
+
//# sourceMappingURL=hnsw-index.d.ts.map
|