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.
Files changed (241) hide show
  1. package/.claude/guidance/shipped/moflo.md +45 -0
  2. package/.claude/helpers/statusline.cjs +1 -1
  3. package/.claude/workflow-state.json +9 -0
  4. package/package.json +2 -2
  5. package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +1 -1
  6. package/src/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +5 -3
  7. package/src/@claude-flow/cli/package.json +1 -1
  8. package/src/@claude-flow/memory/dist/agent-memory-scope.d.ts +131 -0
  9. package/src/@claude-flow/memory/dist/agent-memory-scope.js +223 -0
  10. package/src/@claude-flow/memory/dist/agent-memory-scope.test.d.ts +8 -0
  11. package/src/@claude-flow/memory/dist/agent-memory-scope.test.js +466 -0
  12. package/src/@claude-flow/memory/dist/agentdb-adapter.d.ts +165 -0
  13. package/src/@claude-flow/memory/dist/agentdb-adapter.js +806 -0
  14. package/src/@claude-flow/memory/dist/agentdb-backend.d.ts +212 -0
  15. package/src/@claude-flow/memory/dist/agentdb-backend.js +842 -0
  16. package/src/@claude-flow/memory/dist/agentdb-backend.test.d.ts +7 -0
  17. package/src/@claude-flow/memory/dist/agentdb-backend.test.js +258 -0
  18. package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.d.ts +65 -0
  19. package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.js +129 -0
  20. package/src/@claude-flow/memory/dist/application/commands/store-memory.command.d.ts +48 -0
  21. package/src/@claude-flow/memory/dist/application/commands/store-memory.command.js +72 -0
  22. package/src/@claude-flow/memory/dist/application/index.d.ts +12 -0
  23. package/src/@claude-flow/memory/dist/application/index.js +15 -0
  24. package/src/@claude-flow/memory/dist/application/queries/search-memory.query.d.ts +72 -0
  25. package/src/@claude-flow/memory/dist/application/queries/search-memory.query.js +143 -0
  26. package/src/@claude-flow/memory/dist/application/services/memory-application-service.d.ts +121 -0
  27. package/src/@claude-flow/memory/dist/application/services/memory-application-service.js +190 -0
  28. package/src/@claude-flow/memory/dist/auto-memory-bridge.d.ts +226 -0
  29. package/src/@claude-flow/memory/dist/auto-memory-bridge.js +709 -0
  30. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.d.ts +8 -0
  31. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +757 -0
  32. package/src/@claude-flow/memory/dist/benchmark.test.d.ts +2 -0
  33. package/src/@claude-flow/memory/dist/benchmark.test.js +277 -0
  34. package/src/@claude-flow/memory/dist/cache-manager.d.ts +134 -0
  35. package/src/@claude-flow/memory/dist/cache-manager.js +407 -0
  36. package/src/@claude-flow/memory/dist/controller-registry.d.ts +216 -0
  37. package/src/@claude-flow/memory/dist/controller-registry.js +893 -0
  38. package/src/@claude-flow/memory/dist/controller-registry.test.d.ts +14 -0
  39. package/src/@claude-flow/memory/dist/controller-registry.test.js +593 -0
  40. package/src/@claude-flow/memory/dist/database-provider.d.ts +87 -0
  41. package/src/@claude-flow/memory/dist/database-provider.js +372 -0
  42. package/src/@claude-flow/memory/dist/database-provider.test.d.ts +7 -0
  43. package/src/@claude-flow/memory/dist/database-provider.test.js +287 -0
  44. package/src/@claude-flow/memory/dist/domain/entities/memory-entry.d.ts +143 -0
  45. package/src/@claude-flow/memory/dist/domain/entities/memory-entry.js +226 -0
  46. package/src/@claude-flow/memory/dist/domain/index.d.ts +11 -0
  47. package/src/@claude-flow/memory/dist/domain/index.js +12 -0
  48. package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.d.ts +102 -0
  49. package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.js +11 -0
  50. package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.d.ts +105 -0
  51. package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.js +297 -0
  52. package/src/@claude-flow/memory/dist/hnsw-index.d.ts +111 -0
  53. package/src/@claude-flow/memory/dist/hnsw-index.js +781 -0
  54. package/src/@claude-flow/memory/dist/hnsw-lite.d.ts +23 -0
  55. package/src/@claude-flow/memory/dist/hnsw-lite.js +168 -0
  56. package/src/@claude-flow/memory/dist/index.d.ts +204 -0
  57. package/src/@claude-flow/memory/dist/index.js +358 -0
  58. package/src/@claude-flow/memory/dist/infrastructure/index.d.ts +17 -0
  59. package/src/@claude-flow/memory/dist/infrastructure/index.js +16 -0
  60. package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.d.ts +66 -0
  61. package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.js +409 -0
  62. package/src/@claude-flow/memory/dist/learning-bridge.d.ts +137 -0
  63. package/src/@claude-flow/memory/dist/learning-bridge.js +335 -0
  64. package/src/@claude-flow/memory/dist/learning-bridge.test.d.ts +8 -0
  65. package/src/@claude-flow/memory/dist/learning-bridge.test.js +578 -0
  66. package/src/@claude-flow/memory/dist/memory-graph.d.ts +100 -0
  67. package/src/@claude-flow/memory/dist/memory-graph.js +333 -0
  68. package/src/@claude-flow/memory/dist/memory-graph.test.d.ts +8 -0
  69. package/src/@claude-flow/memory/dist/memory-graph.test.js +609 -0
  70. package/src/@claude-flow/memory/dist/migration.d.ts +68 -0
  71. package/src/@claude-flow/memory/dist/migration.js +513 -0
  72. package/src/@claude-flow/memory/dist/persistent-sona.d.ts +144 -0
  73. package/src/@claude-flow/memory/dist/persistent-sona.js +332 -0
  74. package/src/@claude-flow/memory/dist/query-builder.d.ts +211 -0
  75. package/src/@claude-flow/memory/dist/query-builder.js +438 -0
  76. package/src/@claude-flow/memory/dist/rvf-backend.d.ts +51 -0
  77. package/src/@claude-flow/memory/dist/rvf-backend.js +481 -0
  78. package/src/@claude-flow/memory/dist/rvf-learning-store.d.ts +139 -0
  79. package/src/@claude-flow/memory/dist/rvf-learning-store.js +295 -0
  80. package/src/@claude-flow/memory/dist/rvf-migration.d.ts +45 -0
  81. package/src/@claude-flow/memory/dist/rvf-migration.js +234 -0
  82. package/src/@claude-flow/memory/dist/sqljs-backend.d.ts +127 -0
  83. package/src/@claude-flow/memory/dist/sqljs-backend.js +600 -0
  84. package/src/@claude-flow/memory/dist/types.d.ts +484 -0
  85. package/src/@claude-flow/memory/dist/types.js +58 -0
  86. package/src/@claude-flow/shared/dist/core/config/defaults.d.ts +41 -0
  87. package/src/@claude-flow/shared/dist/core/config/defaults.js +186 -0
  88. package/src/@claude-flow/shared/dist/core/config/index.d.ts +8 -0
  89. package/src/@claude-flow/shared/dist/core/config/index.js +12 -0
  90. package/src/@claude-flow/shared/dist/core/config/loader.d.ts +45 -0
  91. package/src/@claude-flow/shared/dist/core/config/loader.js +222 -0
  92. package/src/@claude-flow/shared/dist/core/config/schema.d.ts +1134 -0
  93. package/src/@claude-flow/shared/dist/core/config/schema.js +158 -0
  94. package/src/@claude-flow/shared/dist/core/config/validator.d.ts +92 -0
  95. package/src/@claude-flow/shared/dist/core/config/validator.js +147 -0
  96. package/src/@claude-flow/shared/dist/core/event-bus.d.ts +31 -0
  97. package/src/@claude-flow/shared/dist/core/event-bus.js +197 -0
  98. package/src/@claude-flow/shared/dist/core/index.d.ts +15 -0
  99. package/src/@claude-flow/shared/dist/core/index.js +19 -0
  100. package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +200 -0
  101. package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.js +6 -0
  102. package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +310 -0
  103. package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +7 -0
  104. package/src/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +224 -0
  105. package/src/@claude-flow/shared/dist/core/interfaces/event.interface.js +46 -0
  106. package/src/@claude-flow/shared/dist/core/interfaces/index.d.ts +10 -0
  107. package/src/@claude-flow/shared/dist/core/interfaces/index.js +15 -0
  108. package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +298 -0
  109. package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.js +7 -0
  110. package/src/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +185 -0
  111. package/src/@claude-flow/shared/dist/core/interfaces/task.interface.js +6 -0
  112. package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +35 -0
  113. package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +101 -0
  114. package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +60 -0
  115. package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +166 -0
  116. package/src/@claude-flow/shared/dist/core/orchestrator/index.d.ts +46 -0
  117. package/src/@claude-flow/shared/dist/core/orchestrator/index.js +64 -0
  118. package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
  119. package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +195 -0
  120. package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +83 -0
  121. package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.js +193 -0
  122. package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +49 -0
  123. package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.js +253 -0
  124. package/src/@claude-flow/shared/dist/events/domain-events.d.ts +282 -0
  125. package/src/@claude-flow/shared/dist/events/domain-events.js +165 -0
  126. package/src/@claude-flow/shared/dist/events/event-store.d.ts +126 -0
  127. package/src/@claude-flow/shared/dist/events/event-store.js +432 -0
  128. package/src/@claude-flow/shared/dist/events/event-store.test.d.ts +8 -0
  129. package/src/@claude-flow/shared/dist/events/event-store.test.js +297 -0
  130. package/src/@claude-flow/shared/dist/events/example-usage.d.ts +10 -0
  131. package/src/@claude-flow/shared/dist/events/example-usage.js +193 -0
  132. package/src/@claude-flow/shared/dist/events/index.d.ts +21 -0
  133. package/src/@claude-flow/shared/dist/events/index.js +22 -0
  134. package/src/@claude-flow/shared/dist/events/projections.d.ts +177 -0
  135. package/src/@claude-flow/shared/dist/events/projections.js +421 -0
  136. package/src/@claude-flow/shared/dist/events/rvf-event-log.d.ts +82 -0
  137. package/src/@claude-flow/shared/dist/events/rvf-event-log.js +340 -0
  138. package/src/@claude-flow/shared/dist/events/state-reconstructor.d.ts +101 -0
  139. package/src/@claude-flow/shared/dist/events/state-reconstructor.js +263 -0
  140. package/src/@claude-flow/shared/dist/events.d.ts +80 -0
  141. package/src/@claude-flow/shared/dist/events.js +249 -0
  142. package/src/@claude-flow/shared/dist/hooks/example-usage.d.ts +42 -0
  143. package/src/@claude-flow/shared/dist/hooks/example-usage.js +351 -0
  144. package/src/@claude-flow/shared/dist/hooks/executor.d.ts +100 -0
  145. package/src/@claude-flow/shared/dist/hooks/executor.js +267 -0
  146. package/src/@claude-flow/shared/dist/hooks/hooks.test.d.ts +9 -0
  147. package/src/@claude-flow/shared/dist/hooks/hooks.test.js +322 -0
  148. package/src/@claude-flow/shared/dist/hooks/index.d.ts +52 -0
  149. package/src/@claude-flow/shared/dist/hooks/index.js +51 -0
  150. package/src/@claude-flow/shared/dist/hooks/registry.d.ts +133 -0
  151. package/src/@claude-flow/shared/dist/hooks/registry.js +277 -0
  152. package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +105 -0
  153. package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.js +481 -0
  154. package/src/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +144 -0
  155. package/src/@claude-flow/shared/dist/hooks/safety/file-organization.js +328 -0
  156. package/src/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +158 -0
  157. package/src/@claude-flow/shared/dist/hooks/safety/git-commit.js +450 -0
  158. package/src/@claude-flow/shared/dist/hooks/safety/index.d.ts +17 -0
  159. package/src/@claude-flow/shared/dist/hooks/safety/index.js +17 -0
  160. package/src/@claude-flow/shared/dist/hooks/session-hooks.d.ts +234 -0
  161. package/src/@claude-flow/shared/dist/hooks/session-hooks.js +334 -0
  162. package/src/@claude-flow/shared/dist/hooks/task-hooks.d.ts +163 -0
  163. package/src/@claude-flow/shared/dist/hooks/task-hooks.js +326 -0
  164. package/src/@claude-flow/shared/dist/hooks/types.d.ts +267 -0
  165. package/src/@claude-flow/shared/dist/hooks/types.js +62 -0
  166. package/src/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +9 -0
  167. package/src/@claude-flow/shared/dist/hooks/verify-exports.test.js +93 -0
  168. package/src/@claude-flow/shared/dist/index.d.ts +20 -0
  169. package/src/@claude-flow/shared/dist/index.js +50 -0
  170. package/src/@claude-flow/shared/dist/mcp/connection-pool.d.ts +98 -0
  171. package/src/@claude-flow/shared/dist/mcp/connection-pool.js +364 -0
  172. package/src/@claude-flow/shared/dist/mcp/index.d.ts +69 -0
  173. package/src/@claude-flow/shared/dist/mcp/index.js +84 -0
  174. package/src/@claude-flow/shared/dist/mcp/server.d.ts +166 -0
  175. package/src/@claude-flow/shared/dist/mcp/server.js +593 -0
  176. package/src/@claude-flow/shared/dist/mcp/session-manager.d.ts +136 -0
  177. package/src/@claude-flow/shared/dist/mcp/session-manager.js +335 -0
  178. package/src/@claude-flow/shared/dist/mcp/tool-registry.d.ts +178 -0
  179. package/src/@claude-flow/shared/dist/mcp/tool-registry.js +439 -0
  180. package/src/@claude-flow/shared/dist/mcp/transport/http.d.ts +104 -0
  181. package/src/@claude-flow/shared/dist/mcp/transport/http.js +476 -0
  182. package/src/@claude-flow/shared/dist/mcp/transport/index.d.ts +102 -0
  183. package/src/@claude-flow/shared/dist/mcp/transport/index.js +238 -0
  184. package/src/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +104 -0
  185. package/src/@claude-flow/shared/dist/mcp/transport/stdio.js +263 -0
  186. package/src/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +133 -0
  187. package/src/@claude-flow/shared/dist/mcp/transport/websocket.js +396 -0
  188. package/src/@claude-flow/shared/dist/mcp/types.d.ts +438 -0
  189. package/src/@claude-flow/shared/dist/mcp/types.js +54 -0
  190. package/src/@claude-flow/shared/dist/plugin-interface.d.ts +544 -0
  191. package/src/@claude-flow/shared/dist/plugin-interface.js +23 -0
  192. package/src/@claude-flow/shared/dist/plugin-loader.d.ts +139 -0
  193. package/src/@claude-flow/shared/dist/plugin-loader.js +434 -0
  194. package/src/@claude-flow/shared/dist/plugin-registry.d.ts +183 -0
  195. package/src/@claude-flow/shared/dist/plugin-registry.js +457 -0
  196. package/src/@claude-flow/shared/dist/plugins/index.d.ts +10 -0
  197. package/src/@claude-flow/shared/dist/plugins/index.js +10 -0
  198. package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
  199. package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +241 -0
  200. package/src/@claude-flow/shared/dist/plugins/official/index.d.ts +10 -0
  201. package/src/@claude-flow/shared/dist/plugins/official/index.js +10 -0
  202. package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +121 -0
  203. package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +355 -0
  204. package/src/@claude-flow/shared/dist/plugins/types.d.ts +93 -0
  205. package/src/@claude-flow/shared/dist/plugins/types.js +9 -0
  206. package/src/@claude-flow/shared/dist/resilience/bulkhead.d.ts +105 -0
  207. package/src/@claude-flow/shared/dist/resilience/bulkhead.js +206 -0
  208. package/src/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +132 -0
  209. package/src/@claude-flow/shared/dist/resilience/circuit-breaker.js +233 -0
  210. package/src/@claude-flow/shared/dist/resilience/index.d.ts +19 -0
  211. package/src/@claude-flow/shared/dist/resilience/index.js +19 -0
  212. package/src/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +168 -0
  213. package/src/@claude-flow/shared/dist/resilience/rate-limiter.js +314 -0
  214. package/src/@claude-flow/shared/dist/resilience/retry.d.ts +91 -0
  215. package/src/@claude-flow/shared/dist/resilience/retry.js +159 -0
  216. package/src/@claude-flow/shared/dist/security/index.d.ts +10 -0
  217. package/src/@claude-flow/shared/dist/security/index.js +12 -0
  218. package/src/@claude-flow/shared/dist/security/input-validation.d.ts +73 -0
  219. package/src/@claude-flow/shared/dist/security/input-validation.js +201 -0
  220. package/src/@claude-flow/shared/dist/security/secure-random.d.ts +92 -0
  221. package/src/@claude-flow/shared/dist/security/secure-random.js +142 -0
  222. package/src/@claude-flow/shared/dist/services/index.d.ts +7 -0
  223. package/src/@claude-flow/shared/dist/services/index.js +7 -0
  224. package/src/@claude-flow/shared/dist/services/v3-progress.service.d.ts +124 -0
  225. package/src/@claude-flow/shared/dist/services/v3-progress.service.js +402 -0
  226. package/src/@claude-flow/shared/dist/types/agent.types.d.ts +137 -0
  227. package/src/@claude-flow/shared/dist/types/agent.types.js +6 -0
  228. package/src/@claude-flow/shared/dist/types/index.d.ts +11 -0
  229. package/src/@claude-flow/shared/dist/types/index.js +17 -0
  230. package/src/@claude-flow/shared/dist/types/mcp.types.d.ts +266 -0
  231. package/src/@claude-flow/shared/dist/types/mcp.types.js +7 -0
  232. package/src/@claude-flow/shared/dist/types/memory.types.d.ts +236 -0
  233. package/src/@claude-flow/shared/dist/types/memory.types.js +7 -0
  234. package/src/@claude-flow/shared/dist/types/swarm.types.d.ts +186 -0
  235. package/src/@claude-flow/shared/dist/types/swarm.types.js +65 -0
  236. package/src/@claude-flow/shared/dist/types/task.types.d.ts +178 -0
  237. package/src/@claude-flow/shared/dist/types/task.types.js +32 -0
  238. package/src/@claude-flow/shared/dist/types.d.ts +197 -0
  239. package/src/@claude-flow/shared/dist/types.js +21 -0
  240. package/src/@claude-flow/shared/dist/utils/secure-logger.d.ts +69 -0
  241. package/src/@claude-flow/shared/dist/utils/secure-logger.js +208 -0
@@ -0,0 +1,143 @@
1
+ /**
2
+ * Memory Entry Entity - Domain Layer
3
+ *
4
+ * Core domain entity representing a stored memory item.
5
+ * Implements DDD principles with encapsulated business logic.
6
+ *
7
+ * @module v3/memory/domain/entities
8
+ */
9
+ /**
10
+ * Memory entry types
11
+ */
12
+ export type MemoryType = 'semantic' | 'episodic' | 'procedural' | 'working';
13
+ /**
14
+ * Memory entry status
15
+ */
16
+ export type MemoryStatus = 'active' | 'archived' | 'deleted';
17
+ /**
18
+ * Memory entry properties
19
+ */
20
+ export interface MemoryEntryProps {
21
+ id?: string;
22
+ namespace: string;
23
+ key: string;
24
+ value: unknown;
25
+ type: MemoryType;
26
+ vector?: Float32Array;
27
+ metadata?: Record<string, unknown>;
28
+ accessCount?: number;
29
+ lastAccessedAt?: Date;
30
+ createdAt?: Date;
31
+ updatedAt?: Date;
32
+ status?: MemoryStatus;
33
+ ttl?: number;
34
+ }
35
+ /**
36
+ * Memory Entry - Aggregate Root
37
+ *
38
+ * Represents a single memory entry with business logic
39
+ * for access tracking, expiration, and state management.
40
+ */
41
+ export declare class MemoryEntry {
42
+ private _id;
43
+ private _namespace;
44
+ private _key;
45
+ private _value;
46
+ private _type;
47
+ private _vector?;
48
+ private _metadata;
49
+ private _accessCount;
50
+ private _lastAccessedAt;
51
+ private _createdAt;
52
+ private _updatedAt;
53
+ private _status;
54
+ private _ttl?;
55
+ private constructor();
56
+ /**
57
+ * Factory method - Create new memory entry
58
+ */
59
+ static create(props: MemoryEntryProps): MemoryEntry;
60
+ /**
61
+ * Factory method - Reconstruct from persistence
62
+ */
63
+ static fromPersistence(props: MemoryEntryProps): MemoryEntry;
64
+ get id(): string;
65
+ get namespace(): string;
66
+ get key(): string;
67
+ get value(): unknown;
68
+ get type(): MemoryType;
69
+ get vector(): Float32Array | undefined;
70
+ get metadata(): Record<string, unknown>;
71
+ get accessCount(): number;
72
+ get lastAccessedAt(): Date;
73
+ get createdAt(): Date;
74
+ get updatedAt(): Date;
75
+ get status(): MemoryStatus;
76
+ get ttl(): number | undefined;
77
+ get compositeKey(): string;
78
+ /**
79
+ * Record an access to this memory entry
80
+ */
81
+ recordAccess(): void;
82
+ /**
83
+ * Update the value of this memory entry
84
+ */
85
+ updateValue(value: unknown): void;
86
+ /**
87
+ * Update the vector embedding
88
+ */
89
+ updateVector(vector: Float32Array): void;
90
+ /**
91
+ * Add or update metadata
92
+ */
93
+ setMetadata(key: string, value: unknown): void;
94
+ /**
95
+ * Remove metadata key
96
+ */
97
+ removeMetadata(key: string): void;
98
+ /**
99
+ * Archive this memory entry
100
+ */
101
+ archive(): void;
102
+ /**
103
+ * Restore archived memory entry
104
+ */
105
+ restore(): void;
106
+ /**
107
+ * Mark as deleted (soft delete)
108
+ */
109
+ delete(): void;
110
+ /**
111
+ * Check if memory has expired based on TTL
112
+ */
113
+ isExpired(): boolean;
114
+ /**
115
+ * Check if memory is accessible (active and not expired)
116
+ */
117
+ isAccessible(): boolean;
118
+ /**
119
+ * Calculate age in milliseconds
120
+ */
121
+ getAge(): number;
122
+ /**
123
+ * Calculate time since last access in milliseconds
124
+ */
125
+ getTimeSinceLastAccess(): number;
126
+ /**
127
+ * Check if memory is considered "hot" (frequently accessed)
128
+ */
129
+ isHot(threshold?: number): boolean;
130
+ /**
131
+ * Check if memory is considered "cold" (not accessed recently)
132
+ */
133
+ isCold(milliseconds?: number): boolean;
134
+ /**
135
+ * Convert to plain object for persistence
136
+ */
137
+ toPersistence(): Record<string, unknown>;
138
+ /**
139
+ * Convert to JSON-serializable object
140
+ */
141
+ toJSON(): Record<string, unknown>;
142
+ }
143
+ //# sourceMappingURL=memory-entry.d.ts.map
@@ -0,0 +1,226 @@
1
+ /**
2
+ * Memory Entry Entity - Domain Layer
3
+ *
4
+ * Core domain entity representing a stored memory item.
5
+ * Implements DDD principles with encapsulated business logic.
6
+ *
7
+ * @module v3/memory/domain/entities
8
+ */
9
+ import { randomUUID } from 'crypto';
10
+ /**
11
+ * Memory Entry - Aggregate Root
12
+ *
13
+ * Represents a single memory entry with business logic
14
+ * for access tracking, expiration, and state management.
15
+ */
16
+ export class MemoryEntry {
17
+ _id;
18
+ _namespace;
19
+ _key;
20
+ _value;
21
+ _type;
22
+ _vector;
23
+ _metadata;
24
+ _accessCount;
25
+ _lastAccessedAt;
26
+ _createdAt;
27
+ _updatedAt;
28
+ _status;
29
+ _ttl;
30
+ constructor(props) {
31
+ const now = new Date();
32
+ this._id = props.id ?? randomUUID();
33
+ this._namespace = props.namespace;
34
+ this._key = props.key;
35
+ this._value = props.value;
36
+ this._type = props.type;
37
+ this._vector = props.vector;
38
+ this._metadata = props.metadata ?? {};
39
+ this._accessCount = props.accessCount ?? 0;
40
+ this._lastAccessedAt = props.lastAccessedAt ?? now;
41
+ this._createdAt = props.createdAt ?? now;
42
+ this._updatedAt = props.updatedAt ?? now;
43
+ this._status = props.status ?? 'active';
44
+ this._ttl = props.ttl;
45
+ }
46
+ /**
47
+ * Factory method - Create new memory entry
48
+ */
49
+ static create(props) {
50
+ return new MemoryEntry(props);
51
+ }
52
+ /**
53
+ * Factory method - Reconstruct from persistence
54
+ */
55
+ static fromPersistence(props) {
56
+ return new MemoryEntry(props);
57
+ }
58
+ // Getters
59
+ get id() {
60
+ return this._id;
61
+ }
62
+ get namespace() {
63
+ return this._namespace;
64
+ }
65
+ get key() {
66
+ return this._key;
67
+ }
68
+ get value() {
69
+ return this._value;
70
+ }
71
+ get type() {
72
+ return this._type;
73
+ }
74
+ get vector() {
75
+ return this._vector;
76
+ }
77
+ get metadata() {
78
+ return { ...this._metadata };
79
+ }
80
+ get accessCount() {
81
+ return this._accessCount;
82
+ }
83
+ get lastAccessedAt() {
84
+ return new Date(this._lastAccessedAt);
85
+ }
86
+ get createdAt() {
87
+ return new Date(this._createdAt);
88
+ }
89
+ get updatedAt() {
90
+ return new Date(this._updatedAt);
91
+ }
92
+ get status() {
93
+ return this._status;
94
+ }
95
+ get ttl() {
96
+ return this._ttl;
97
+ }
98
+ get compositeKey() {
99
+ return `${this._namespace}:${this._key}`;
100
+ }
101
+ // Business Logic Methods
102
+ /**
103
+ * Record an access to this memory entry
104
+ */
105
+ recordAccess() {
106
+ this._accessCount++;
107
+ this._lastAccessedAt = new Date();
108
+ }
109
+ /**
110
+ * Update the value of this memory entry
111
+ */
112
+ updateValue(value) {
113
+ this._value = value;
114
+ this._updatedAt = new Date();
115
+ }
116
+ /**
117
+ * Update the vector embedding
118
+ */
119
+ updateVector(vector) {
120
+ this._vector = vector;
121
+ this._updatedAt = new Date();
122
+ }
123
+ /**
124
+ * Add or update metadata
125
+ */
126
+ setMetadata(key, value) {
127
+ this._metadata[key] = value;
128
+ this._updatedAt = new Date();
129
+ }
130
+ /**
131
+ * Remove metadata key
132
+ */
133
+ removeMetadata(key) {
134
+ delete this._metadata[key];
135
+ this._updatedAt = new Date();
136
+ }
137
+ /**
138
+ * Archive this memory entry
139
+ */
140
+ archive() {
141
+ this._status = 'archived';
142
+ this._updatedAt = new Date();
143
+ }
144
+ /**
145
+ * Restore archived memory entry
146
+ */
147
+ restore() {
148
+ if (this._status === 'archived') {
149
+ this._status = 'active';
150
+ this._updatedAt = new Date();
151
+ }
152
+ }
153
+ /**
154
+ * Mark as deleted (soft delete)
155
+ */
156
+ delete() {
157
+ this._status = 'deleted';
158
+ this._updatedAt = new Date();
159
+ }
160
+ /**
161
+ * Check if memory has expired based on TTL
162
+ */
163
+ isExpired() {
164
+ if (!this._ttl)
165
+ return false;
166
+ const expiresAt = this._createdAt.getTime() + this._ttl;
167
+ return Date.now() > expiresAt;
168
+ }
169
+ /**
170
+ * Check if memory is accessible (active and not expired)
171
+ */
172
+ isAccessible() {
173
+ return this._status === 'active' && !this.isExpired();
174
+ }
175
+ /**
176
+ * Calculate age in milliseconds
177
+ */
178
+ getAge() {
179
+ return Date.now() - this._createdAt.getTime();
180
+ }
181
+ /**
182
+ * Calculate time since last access in milliseconds
183
+ */
184
+ getTimeSinceLastAccess() {
185
+ return Date.now() - this._lastAccessedAt.getTime();
186
+ }
187
+ /**
188
+ * Check if memory is considered "hot" (frequently accessed)
189
+ */
190
+ isHot(threshold = 10) {
191
+ return this._accessCount >= threshold;
192
+ }
193
+ /**
194
+ * Check if memory is considered "cold" (not accessed recently)
195
+ */
196
+ isCold(milliseconds = 3600000) {
197
+ return this.getTimeSinceLastAccess() > milliseconds;
198
+ }
199
+ /**
200
+ * Convert to plain object for persistence
201
+ */
202
+ toPersistence() {
203
+ return {
204
+ id: this._id,
205
+ namespace: this._namespace,
206
+ key: this._key,
207
+ value: this._value,
208
+ type: this._type,
209
+ vector: this._vector ? Array.from(this._vector) : undefined,
210
+ metadata: this._metadata,
211
+ accessCount: this._accessCount,
212
+ lastAccessedAt: this._lastAccessedAt.toISOString(),
213
+ createdAt: this._createdAt.toISOString(),
214
+ updatedAt: this._updatedAt.toISOString(),
215
+ status: this._status,
216
+ ttl: this._ttl,
217
+ };
218
+ }
219
+ /**
220
+ * Convert to JSON-serializable object
221
+ */
222
+ toJSON() {
223
+ return this.toPersistence();
224
+ }
225
+ }
226
+ //# sourceMappingURL=memory-entry.js.map
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Memory Domain Layer - Public Exports
3
+ *
4
+ * Exports all domain entities, value objects, services, and interfaces.
5
+ *
6
+ * @module v3/memory/domain
7
+ */
8
+ export { MemoryEntry, type MemoryType, type MemoryStatus, type MemoryEntryProps, } from './entities/memory-entry.js';
9
+ export { type IMemoryRepository, type MemoryQueryOptions, type VectorSearchOptions, type VectorSearchResult, type BulkOperationResult, type MemoryStatistics, } from './repositories/memory-repository.interface.js';
10
+ export { MemoryDomainService, type ConsolidationStrategy, type ConsolidationOptions, type ConsolidationResult, type DeduplicationResult, type NamespaceAnalysis, } from './services/memory-domain-service.js';
11
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,12 @@
1
+ /**
2
+ * Memory Domain Layer - Public Exports
3
+ *
4
+ * Exports all domain entities, value objects, services, and interfaces.
5
+ *
6
+ * @module v3/memory/domain
7
+ */
8
+ // Entities
9
+ export { MemoryEntry, } from './entities/memory-entry.js';
10
+ // Domain Services
11
+ export { MemoryDomainService, } from './services/memory-domain-service.js';
12
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1,102 @@
1
+ /**
2
+ * Memory Repository Interface - Domain Layer
3
+ *
4
+ * Defines the contract for memory persistence.
5
+ * Following DDD, the interface belongs to the domain layer
6
+ * while implementations belong to infrastructure.
7
+ *
8
+ * @module v3/memory/domain/repositories
9
+ */
10
+ import { MemoryEntry, MemoryType, MemoryStatus } from '../entities/memory-entry.js';
11
+ /**
12
+ * Query options for memory retrieval
13
+ */
14
+ export interface MemoryQueryOptions {
15
+ namespace?: string;
16
+ type?: MemoryType;
17
+ status?: MemoryStatus;
18
+ limit?: number;
19
+ offset?: number;
20
+ orderBy?: 'createdAt' | 'updatedAt' | 'accessCount' | 'lastAccessedAt';
21
+ orderDirection?: 'asc' | 'desc';
22
+ }
23
+ /**
24
+ * Vector search options
25
+ */
26
+ export interface VectorSearchOptions {
27
+ vector: Float32Array;
28
+ namespace?: string;
29
+ limit?: number;
30
+ threshold?: number;
31
+ type?: MemoryType;
32
+ }
33
+ /**
34
+ * Vector search result
35
+ */
36
+ export interface VectorSearchResult {
37
+ entry: MemoryEntry;
38
+ similarity: number;
39
+ distance: number;
40
+ }
41
+ /**
42
+ * Bulk operation result
43
+ */
44
+ export interface BulkOperationResult {
45
+ success: number;
46
+ failed: number;
47
+ errors: Array<{
48
+ id: string;
49
+ error: string;
50
+ }>;
51
+ }
52
+ /**
53
+ * Memory statistics
54
+ */
55
+ export interface MemoryStatistics {
56
+ totalEntries: number;
57
+ activeEntries: number;
58
+ archivedEntries: number;
59
+ deletedEntries: number;
60
+ totalSize: number;
61
+ entriesByNamespace: Record<string, number>;
62
+ entriesByType: Record<MemoryType, number>;
63
+ averageAccessCount: number;
64
+ hottestEntries: string[];
65
+ coldestEntries: string[];
66
+ }
67
+ /**
68
+ * Memory Repository Interface
69
+ *
70
+ * Defines all operations for memory persistence.
71
+ * Implementations can use SQLite, AgentDB, or hybrid backends.
72
+ */
73
+ export interface IMemoryRepository {
74
+ save(entry: MemoryEntry): Promise<void>;
75
+ findById(id: string): Promise<MemoryEntry | null>;
76
+ findByKey(namespace: string, key: string): Promise<MemoryEntry | null>;
77
+ findByCompositeKey(compositeKey: string): Promise<MemoryEntry | null>;
78
+ delete(id: string): Promise<boolean>;
79
+ exists(id: string): Promise<boolean>;
80
+ saveMany(entries: MemoryEntry[]): Promise<BulkOperationResult>;
81
+ findByIds(ids: string[]): Promise<MemoryEntry[]>;
82
+ deleteMany(ids: string[]): Promise<BulkOperationResult>;
83
+ findAll(options?: MemoryQueryOptions): Promise<MemoryEntry[]>;
84
+ findByNamespace(namespace: string, options?: Omit<MemoryQueryOptions, 'namespace'>): Promise<MemoryEntry[]>;
85
+ findByType(type: MemoryType, options?: Omit<MemoryQueryOptions, 'type'>): Promise<MemoryEntry[]>;
86
+ findByStatus(status: MemoryStatus, options?: Omit<MemoryQueryOptions, 'status'>): Promise<MemoryEntry[]>;
87
+ searchByVector(options: VectorSearchOptions): Promise<VectorSearchResult[]>;
88
+ findSimilar(entryId: string, limit?: number): Promise<VectorSearchResult[]>;
89
+ findExpired(): Promise<MemoryEntry[]>;
90
+ deleteExpired(): Promise<number>;
91
+ findCold(milliseconds: number): Promise<MemoryEntry[]>;
92
+ archiveCold(milliseconds: number): Promise<number>;
93
+ getStatistics(): Promise<MemoryStatistics>;
94
+ count(options?: MemoryQueryOptions): Promise<number>;
95
+ listNamespaces(): Promise<string[]>;
96
+ deleteNamespace(namespace: string): Promise<number>;
97
+ getNamespaceSize(namespace: string): Promise<number>;
98
+ initialize(): Promise<void>;
99
+ shutdown(): Promise<void>;
100
+ clear(): Promise<void>;
101
+ }
102
+ //# sourceMappingURL=memory-repository.interface.d.ts.map
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Memory Repository Interface - Domain Layer
3
+ *
4
+ * Defines the contract for memory persistence.
5
+ * Following DDD, the interface belongs to the domain layer
6
+ * while implementations belong to infrastructure.
7
+ *
8
+ * @module v3/memory/domain/repositories
9
+ */
10
+ export {};
11
+ //# sourceMappingURL=memory-repository.interface.js.map
@@ -0,0 +1,105 @@
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, MemoryType } from '../entities/memory-entry.js';
10
+ import { IMemoryRepository, VectorSearchResult } from '../repositories/memory-repository.interface.js';
11
+ /**
12
+ * Memory consolidation strategy
13
+ */
14
+ export type ConsolidationStrategy = 'merge' | 'dedupe' | 'prune' | 'summarize';
15
+ /**
16
+ * Memory consolidation options
17
+ */
18
+ export interface ConsolidationOptions {
19
+ strategy: ConsolidationStrategy;
20
+ namespace?: string;
21
+ threshold?: number;
22
+ maxAge?: number;
23
+ keepHot?: boolean;
24
+ }
25
+ /**
26
+ * Consolidation result
27
+ */
28
+ export interface ConsolidationResult {
29
+ processed: number;
30
+ consolidated: number;
31
+ removed: number;
32
+ newEntries: MemoryEntry[];
33
+ }
34
+ /**
35
+ * Memory deduplication result
36
+ */
37
+ export interface DeduplicationResult {
38
+ duplicatesFound: number;
39
+ duplicatesRemoved: number;
40
+ groupsProcessed: number;
41
+ }
42
+ /**
43
+ * Memory namespace statistics
44
+ */
45
+ export interface NamespaceAnalysis {
46
+ namespace: string;
47
+ totalEntries: number;
48
+ activeEntries: number;
49
+ totalSize: number;
50
+ averageAccessCount: number;
51
+ oldestEntry: Date;
52
+ newestEntry: Date;
53
+ typeDistribution: Record<MemoryType, number>;
54
+ }
55
+ /**
56
+ * Memory Domain Service
57
+ *
58
+ * Provides domain-level operations that span multiple entities.
59
+ * Implements business rules for memory management.
60
+ */
61
+ export declare class MemoryDomainService {
62
+ private readonly repository;
63
+ constructor(repository: IMemoryRepository);
64
+ /**
65
+ * Store a new memory with automatic type detection
66
+ */
67
+ storeWithTypeDetection(namespace: string, key: string, value: unknown, vector?: Float32Array): Promise<MemoryEntry>;
68
+ /**
69
+ * Retrieve and record access
70
+ */
71
+ retrieveWithAccessTracking(namespace: string, key: string): Promise<MemoryEntry | null>;
72
+ /**
73
+ * Search for similar memories and record access
74
+ */
75
+ searchSimilarWithTracking(vector: Float32Array, namespace?: string, limit?: number): Promise<VectorSearchResult[]>;
76
+ /**
77
+ * Consolidate memories based on strategy
78
+ */
79
+ consolidate(options: ConsolidationOptions): Promise<ConsolidationResult>;
80
+ /**
81
+ * Detect memory type based on value structure
82
+ */
83
+ private detectMemoryType;
84
+ /**
85
+ * Prune old, rarely accessed memories
86
+ */
87
+ private pruneOldMemories;
88
+ /**
89
+ * Find and remove duplicate memories
90
+ */
91
+ private deduplicateMemories;
92
+ /**
93
+ * Merge related memories into consolidated entries
94
+ */
95
+ private mergeRelatedMemories;
96
+ /**
97
+ * Merge multiple entries into one
98
+ */
99
+ private mergeEntries;
100
+ /**
101
+ * Analyze a namespace
102
+ */
103
+ analyzeNamespace(namespace: string): Promise<NamespaceAnalysis>;
104
+ }
105
+ //# sourceMappingURL=memory-domain-service.d.ts.map