agentdb 1.6.1 → 2.0.0-alpha.2

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 (918) hide show
  1. package/README.md +1098 -350
  2. package/dist/agentdb-advanced.js +2110 -0
  3. package/dist/agentdb-advanced.min.js +1 -0
  4. package/dist/agentdb.min.js +4 -4
  5. package/dist/backends/GraphBackend.d.ts +196 -0
  6. package/dist/backends/GraphBackend.d.ts.map +1 -0
  7. package/dist/backends/GraphBackend.js +33 -0
  8. package/dist/backends/GraphBackend.js.map +1 -0
  9. package/dist/backends/LearningBackend.d.ts +148 -0
  10. package/dist/backends/LearningBackend.d.ts.map +1 -0
  11. package/dist/backends/LearningBackend.js +27 -0
  12. package/dist/backends/LearningBackend.js.map +1 -0
  13. package/dist/backends/VectorBackend.d.ts +119 -0
  14. package/dist/backends/VectorBackend.d.ts.map +1 -0
  15. package/dist/backends/VectorBackend.js +14 -0
  16. package/dist/backends/VectorBackend.js.map +1 -0
  17. package/dist/backends/detector.d.ts +81 -0
  18. package/dist/backends/detector.d.ts.map +1 -0
  19. package/dist/backends/detector.js +192 -0
  20. package/dist/backends/detector.js.map +1 -0
  21. package/dist/backends/factory.d.ts +50 -0
  22. package/dist/backends/factory.d.ts.map +1 -0
  23. package/dist/backends/factory.js +161 -0
  24. package/dist/backends/factory.js.map +1 -0
  25. package/dist/backends/graph/GraphDatabaseAdapter.d.ts +139 -0
  26. package/dist/backends/graph/GraphDatabaseAdapter.d.ts.map +1 -0
  27. package/dist/backends/graph/GraphDatabaseAdapter.js +194 -0
  28. package/dist/backends/graph/GraphDatabaseAdapter.js.map +1 -0
  29. package/dist/backends/hnswlib/HNSWLibBackend.d.ts +92 -0
  30. package/dist/backends/hnswlib/HNSWLibBackend.d.ts.map +1 -0
  31. package/dist/backends/hnswlib/HNSWLibBackend.js +316 -0
  32. package/dist/backends/hnswlib/HNSWLibBackend.js.map +1 -0
  33. package/dist/backends/hnswlib/index.d.ts +7 -0
  34. package/dist/backends/hnswlib/index.d.ts.map +1 -0
  35. package/dist/backends/hnswlib/index.js +7 -0
  36. package/dist/backends/hnswlib/index.js.map +1 -0
  37. package/dist/backends/index.d.ts +14 -0
  38. package/dist/backends/index.d.ts.map +1 -0
  39. package/dist/backends/index.js +13 -0
  40. package/dist/backends/index.js.map +1 -0
  41. package/dist/backends/ruvector/RuVectorBackend.d.ts +75 -0
  42. package/dist/backends/ruvector/RuVectorBackend.d.ts.map +1 -0
  43. package/dist/backends/ruvector/RuVectorBackend.js +198 -0
  44. package/dist/backends/ruvector/RuVectorBackend.js.map +1 -0
  45. package/dist/backends/ruvector/RuVectorLearning.d.ts +104 -0
  46. package/dist/backends/ruvector/RuVectorLearning.d.ts.map +1 -0
  47. package/dist/backends/ruvector/RuVectorLearning.js +177 -0
  48. package/dist/backends/ruvector/RuVectorLearning.js.map +1 -0
  49. package/dist/backends/ruvector/index.d.ts +9 -0
  50. package/dist/backends/ruvector/index.d.ts.map +1 -0
  51. package/dist/backends/ruvector/index.js +8 -0
  52. package/dist/backends/ruvector/index.js.map +1 -0
  53. package/dist/browser/AdvancedFeatures.d.ts +144 -0
  54. package/dist/browser/AdvancedFeatures.d.ts.map +1 -0
  55. package/dist/browser/AdvancedFeatures.js +430 -0
  56. package/dist/browser/AdvancedFeatures.js.map +1 -0
  57. package/dist/browser/HNSWIndex.d.ts +117 -0
  58. package/dist/browser/HNSWIndex.d.ts.map +1 -0
  59. package/dist/browser/HNSWIndex.js +402 -0
  60. package/dist/browser/HNSWIndex.js.map +1 -0
  61. package/dist/browser/ProductQuantization.d.ts +107 -0
  62. package/dist/browser/ProductQuantization.d.ts.map +1 -0
  63. package/dist/browser/ProductQuantization.js +337 -0
  64. package/dist/browser/ProductQuantization.js.map +1 -0
  65. package/dist/browser/browser/AdvancedFeatures.d.ts +144 -0
  66. package/dist/browser/browser/AdvancedFeatures.d.ts.map +1 -0
  67. package/dist/browser/browser/AdvancedFeatures.js +427 -0
  68. package/dist/browser/browser/HNSWIndex.d.ts +117 -0
  69. package/dist/browser/browser/HNSWIndex.d.ts.map +1 -0
  70. package/dist/browser/browser/HNSWIndex.js +402 -0
  71. package/dist/browser/browser/ProductQuantization.d.ts +107 -0
  72. package/dist/browser/browser/ProductQuantization.d.ts.map +1 -0
  73. package/dist/browser/browser/ProductQuantization.js +348 -0
  74. package/dist/browser/browser/index.d.ts +223 -0
  75. package/dist/browser/browser/index.d.ts.map +1 -0
  76. package/dist/browser/browser/index.js +233 -0
  77. package/dist/browser/index.d.ts +223 -0
  78. package/dist/browser/index.d.ts.map +1 -0
  79. package/dist/browser/index.js +225 -0
  80. package/dist/browser/index.js.map +1 -0
  81. package/dist/cli/agentdb-cli.d.ts.map +1 -1
  82. package/dist/cli/agentdb-cli.js +130 -8
  83. package/dist/cli/agentdb-cli.js.map +1 -1
  84. package/dist/cli/agentdb.db +0 -0
  85. package/dist/cli/commands/init.d.ts +12 -0
  86. package/dist/cli/commands/init.d.ts.map +1 -0
  87. package/dist/cli/commands/init.js +115 -0
  88. package/dist/cli/commands/init.js.map +1 -0
  89. package/dist/cli/commands/install-embeddings.d.ts +10 -0
  90. package/dist/cli/commands/install-embeddings.d.ts.map +1 -0
  91. package/dist/cli/commands/install-embeddings.js +68 -0
  92. package/dist/cli/commands/install-embeddings.js.map +1 -0
  93. package/dist/cli/commands/migrate.d.ts +15 -0
  94. package/dist/cli/commands/migrate.d.ts.map +1 -0
  95. package/dist/cli/commands/migrate.js +425 -0
  96. package/dist/cli/commands/migrate.js.map +1 -0
  97. package/dist/cli/commands/status.d.ts +10 -0
  98. package/dist/cli/commands/status.d.ts.map +1 -0
  99. package/dist/cli/commands/status.js +129 -0
  100. package/dist/cli/commands/status.js.map +1 -0
  101. package/dist/controllers/CausalRecall.d.ts +3 -1
  102. package/dist/controllers/CausalRecall.d.ts.map +1 -1
  103. package/dist/controllers/CausalRecall.js +35 -4
  104. package/dist/controllers/CausalRecall.js.map +1 -1
  105. package/dist/controllers/ExplainableRecall.d.ts +24 -0
  106. package/dist/controllers/ExplainableRecall.d.ts.map +1 -1
  107. package/dist/controllers/ExplainableRecall.js +102 -5
  108. package/dist/controllers/ExplainableRecall.js.map +1 -1
  109. package/dist/controllers/NightlyLearner.d.ts.map +1 -1
  110. package/dist/controllers/NightlyLearner.js +7 -4
  111. package/dist/controllers/NightlyLearner.js.map +1 -1
  112. package/dist/controllers/ReasoningBank.d.ts +101 -2
  113. package/dist/controllers/ReasoningBank.d.ts.map +1 -1
  114. package/dist/controllers/ReasoningBank.js +196 -4
  115. package/dist/controllers/ReasoningBank.js.map +1 -1
  116. package/dist/controllers/ReflexionMemory.d.ts +41 -1
  117. package/dist/controllers/ReflexionMemory.d.ts.map +1 -1
  118. package/dist/controllers/ReflexionMemory.js +282 -5
  119. package/dist/controllers/ReflexionMemory.js.map +1 -1
  120. package/dist/controllers/SkillLibrary.d.ts +27 -9
  121. package/dist/controllers/SkillLibrary.d.ts.map +1 -1
  122. package/dist/controllers/SkillLibrary.js +136 -47
  123. package/dist/controllers/SkillLibrary.js.map +1 -1
  124. package/dist/db-fallback.d.ts.map +1 -1
  125. package/dist/db-fallback.js +100 -29
  126. package/dist/db-fallback.js.map +1 -1
  127. package/dist/db-test.d.ts +13 -0
  128. package/dist/db-test.d.ts.map +1 -0
  129. package/dist/db-test.js +55 -0
  130. package/dist/db-test.js.map +1 -0
  131. package/dist/db-unified.d.ts +76 -0
  132. package/dist/db-unified.d.ts.map +1 -0
  133. package/dist/db-unified.js +278 -0
  134. package/dist/db-unified.js.map +1 -0
  135. package/dist/malp/core/ccc.d.ts +99 -0
  136. package/dist/malp/core/ccc.d.ts.map +1 -0
  137. package/dist/malp/core/ccc.js +181 -0
  138. package/dist/malp/core/ccc.js.map +1 -0
  139. package/dist/malp/core/index.d.ts +9 -0
  140. package/dist/malp/core/index.d.ts.map +1 -0
  141. package/dist/malp/core/index.js +9 -0
  142. package/dist/malp/core/index.js.map +1 -0
  143. package/dist/malp/core/linalg.d.ts +101 -0
  144. package/dist/malp/core/linalg.d.ts.map +1 -0
  145. package/dist/malp/core/linalg.js +278 -0
  146. package/dist/malp/core/linalg.js.map +1 -0
  147. package/dist/malp/core/optimizer.d.ts +68 -0
  148. package/dist/malp/core/optimizer.d.ts.map +1 -0
  149. package/dist/malp/core/optimizer.js +160 -0
  150. package/dist/malp/core/optimizer.js.map +1 -0
  151. package/dist/malp/index.d.ts +33 -0
  152. package/dist/malp/index.d.ts.map +1 -0
  153. package/dist/malp/index.js +37 -0
  154. package/dist/malp/index.js.map +1 -0
  155. package/dist/malp/metrics/agreement.d.ts +106 -0
  156. package/dist/malp/metrics/agreement.d.ts.map +1 -0
  157. package/dist/malp/metrics/agreement.js +199 -0
  158. package/dist/malp/metrics/agreement.js.map +1 -0
  159. package/dist/malp/metrics/comparison.d.ts +93 -0
  160. package/dist/malp/metrics/comparison.d.ts.map +1 -0
  161. package/dist/malp/metrics/comparison.js +256 -0
  162. package/dist/malp/metrics/comparison.js.map +1 -0
  163. package/dist/malp/metrics/index.d.ts +8 -0
  164. package/dist/malp/metrics/index.d.ts.map +1 -0
  165. package/dist/malp/metrics/index.js +8 -0
  166. package/dist/malp/metrics/index.js.map +1 -0
  167. package/dist/malp/metrics/performance.d.ts +61 -0
  168. package/dist/malp/metrics/performance.d.ts.map +1 -0
  169. package/dist/malp/metrics/performance.js +190 -0
  170. package/dist/malp/metrics/performance.js.map +1 -0
  171. package/dist/malp/models/index.d.ts +7 -0
  172. package/dist/malp/models/index.d.ts.map +1 -0
  173. package/dist/malp/models/index.js +7 -0
  174. package/dist/malp/models/index.js.map +1 -0
  175. package/dist/malp/models/malp.d.ts +116 -0
  176. package/dist/malp/models/malp.d.ts.map +1 -0
  177. package/dist/malp/models/malp.js +206 -0
  178. package/dist/malp/models/malp.js.map +1 -0
  179. package/dist/malp/models/regressor.d.ts +80 -0
  180. package/dist/malp/models/regressor.d.ts.map +1 -0
  181. package/dist/malp/models/regressor.js +229 -0
  182. package/dist/malp/models/regressor.js.map +1 -0
  183. package/dist/malp/reasoningbank_validator.d.ts +187 -0
  184. package/dist/malp/reasoningbank_validator.d.ts.map +1 -0
  185. package/dist/malp/reasoningbank_validator.js +246 -0
  186. package/dist/malp/reasoningbank_validator.js.map +1 -0
  187. package/dist/malp/wasm_bindings.d.ts +344 -0
  188. package/dist/malp/wasm_bindings.d.ts.map +1 -0
  189. package/dist/malp/wasm_bindings.js +9 -0
  190. package/dist/malp/wasm_bindings.js.map +1 -0
  191. package/dist/mcp/agentdb-mcp-server.js +512 -33
  192. package/dist/mcp/agentdb-mcp-server.js.map +1 -1
  193. package/dist/optimizations/BatchOperations.d.ts +42 -0
  194. package/dist/optimizations/BatchOperations.d.ts.map +1 -1
  195. package/dist/optimizations/BatchOperations.js +181 -0
  196. package/dist/optimizations/BatchOperations.js.map +1 -1
  197. package/dist/optimizations/ToolCache.d.ts +137 -0
  198. package/dist/optimizations/ToolCache.d.ts.map +1 -0
  199. package/dist/optimizations/ToolCache.js +281 -0
  200. package/dist/optimizations/ToolCache.js.map +1 -0
  201. package/dist/security/input-validation.d.ts +24 -0
  202. package/dist/security/input-validation.d.ts.map +1 -1
  203. package/dist/security/input-validation.js +106 -0
  204. package/dist/security/input-validation.js.map +1 -1
  205. package/dist/security/limits.d.ts +150 -0
  206. package/dist/security/limits.d.ts.map +1 -0
  207. package/dist/security/limits.js +288 -0
  208. package/dist/security/limits.js.map +1 -0
  209. package/dist/security/path-security.d.ts +100 -0
  210. package/dist/security/path-security.d.ts.map +1 -0
  211. package/dist/security/path-security.js +337 -0
  212. package/dist/security/path-security.js.map +1 -0
  213. package/dist/security/validation.d.ts +95 -0
  214. package/dist/security/validation.d.ts.map +1 -0
  215. package/dist/security/validation.js +315 -0
  216. package/dist/security/validation.js.map +1 -0
  217. package/dist/simulation/cli.d.ts +9 -0
  218. package/dist/simulation/cli.d.ts.map +1 -0
  219. package/dist/simulation/cli.js +68 -0
  220. package/dist/simulation/cli.js.map +1 -0
  221. package/dist/simulation/runner.d.ts +21 -0
  222. package/dist/simulation/runner.d.ts.map +1 -0
  223. package/dist/simulation/runner.js +241 -0
  224. package/dist/simulation/runner.js.map +1 -0
  225. package/dist/simulation/scenarios/aidefence-integration.d.ts +24 -0
  226. package/dist/simulation/scenarios/aidefence-integration.d.ts.map +1 -0
  227. package/dist/simulation/scenarios/aidefence-integration.js +124 -0
  228. package/dist/simulation/scenarios/aidefence-integration.js.map +1 -0
  229. package/dist/simulation/scenarios/bmssp-integration.d.ts +23 -0
  230. package/dist/simulation/scenarios/bmssp-integration.d.ts.map +1 -0
  231. package/dist/simulation/scenarios/bmssp-integration.js +104 -0
  232. package/dist/simulation/scenarios/bmssp-integration.js.map +1 -0
  233. package/dist/simulation/scenarios/causal-reasoning.d.ts +16 -0
  234. package/dist/simulation/scenarios/causal-reasoning.d.ts.map +1 -0
  235. package/dist/simulation/scenarios/causal-reasoning.js +108 -0
  236. package/dist/simulation/scenarios/causal-reasoning.js.map +1 -0
  237. package/dist/simulation/scenarios/consciousness-explorer.d.ts +25 -0
  238. package/dist/simulation/scenarios/consciousness-explorer.d.ts.map +1 -0
  239. package/dist/simulation/scenarios/consciousness-explorer.js +108 -0
  240. package/dist/simulation/scenarios/consciousness-explorer.js.map +1 -0
  241. package/dist/simulation/scenarios/domain-examples/e-commerce-recommendations.d.ts +135 -0
  242. package/dist/simulation/scenarios/domain-examples/e-commerce-recommendations.d.ts.map +1 -0
  243. package/dist/simulation/scenarios/domain-examples/e-commerce-recommendations.js +158 -0
  244. package/dist/simulation/scenarios/domain-examples/e-commerce-recommendations.js.map +1 -0
  245. package/dist/simulation/scenarios/domain-examples/index.d.ts +14 -0
  246. package/dist/simulation/scenarios/domain-examples/index.d.ts.map +1 -0
  247. package/dist/simulation/scenarios/domain-examples/index.js +14 -0
  248. package/dist/simulation/scenarios/domain-examples/index.js.map +1 -0
  249. package/dist/simulation/scenarios/domain-examples/iot-sensor-networks.d.ts +178 -0
  250. package/dist/simulation/scenarios/domain-examples/iot-sensor-networks.d.ts.map +1 -0
  251. package/dist/simulation/scenarios/domain-examples/iot-sensor-networks.js +218 -0
  252. package/dist/simulation/scenarios/domain-examples/iot-sensor-networks.js.map +1 -0
  253. package/dist/simulation/scenarios/domain-examples/medical-imaging.d.ts +122 -0
  254. package/dist/simulation/scenarios/domain-examples/medical-imaging.d.ts.map +1 -0
  255. package/dist/simulation/scenarios/domain-examples/medical-imaging.js +129 -0
  256. package/dist/simulation/scenarios/domain-examples/medical-imaging.js.map +1 -0
  257. package/dist/simulation/scenarios/domain-examples/robotics-navigation.d.ts +166 -0
  258. package/dist/simulation/scenarios/domain-examples/robotics-navigation.d.ts.map +1 -0
  259. package/dist/simulation/scenarios/domain-examples/robotics-navigation.js +161 -0
  260. package/dist/simulation/scenarios/domain-examples/robotics-navigation.js.map +1 -0
  261. package/dist/simulation/scenarios/domain-examples/scientific-research.d.ts +151 -0
  262. package/dist/simulation/scenarios/domain-examples/scientific-research.d.ts.map +1 -0
  263. package/dist/simulation/scenarios/domain-examples/scientific-research.js +187 -0
  264. package/dist/simulation/scenarios/domain-examples/scientific-research.js.map +1 -0
  265. package/dist/simulation/scenarios/domain-examples/trading-systems.d.ts +102 -0
  266. package/dist/simulation/scenarios/domain-examples/trading-systems.d.ts.map +1 -0
  267. package/dist/simulation/scenarios/domain-examples/trading-systems.js +100 -0
  268. package/dist/simulation/scenarios/domain-examples/trading-systems.js.map +1 -0
  269. package/dist/simulation/scenarios/goalie-integration.d.ts +24 -0
  270. package/dist/simulation/scenarios/goalie-integration.d.ts.map +1 -0
  271. package/dist/simulation/scenarios/goalie-integration.js +121 -0
  272. package/dist/simulation/scenarios/goalie-integration.js.map +1 -0
  273. package/dist/simulation/scenarios/graph-traversal.d.ts +17 -0
  274. package/dist/simulation/scenarios/graph-traversal.d.ts.map +1 -0
  275. package/dist/simulation/scenarios/graph-traversal.js +101 -0
  276. package/dist/simulation/scenarios/graph-traversal.js.map +1 -0
  277. package/dist/simulation/scenarios/latent-space/attention-analysis.d.ts +45 -0
  278. package/dist/simulation/scenarios/latent-space/attention-analysis.d.ts.map +1 -0
  279. package/dist/simulation/scenarios/latent-space/attention-analysis.js +435 -0
  280. package/dist/simulation/scenarios/latent-space/attention-analysis.js.map +1 -0
  281. package/dist/simulation/scenarios/latent-space/clustering-analysis.d.ts +55 -0
  282. package/dist/simulation/scenarios/latent-space/clustering-analysis.d.ts.map +1 -0
  283. package/dist/simulation/scenarios/latent-space/clustering-analysis.js +606 -0
  284. package/dist/simulation/scenarios/latent-space/clustering-analysis.js.map +1 -0
  285. package/dist/simulation/scenarios/latent-space/hnsw-exploration.d.ts +74 -0
  286. package/dist/simulation/scenarios/latent-space/hnsw-exploration.d.ts.map +1 -0
  287. package/dist/simulation/scenarios/latent-space/hnsw-exploration.js +391 -0
  288. package/dist/simulation/scenarios/latent-space/hnsw-exploration.js.map +1 -0
  289. package/dist/simulation/scenarios/latent-space/hypergraph-exploration.d.ts +51 -0
  290. package/dist/simulation/scenarios/latent-space/hypergraph-exploration.d.ts.map +1 -0
  291. package/dist/simulation/scenarios/latent-space/hypergraph-exploration.js +536 -0
  292. package/dist/simulation/scenarios/latent-space/hypergraph-exploration.js.map +1 -0
  293. package/dist/simulation/scenarios/latent-space/index.d.ts +35 -0
  294. package/dist/simulation/scenarios/latent-space/index.d.ts.map +1 -0
  295. package/dist/simulation/scenarios/latent-space/index.js +35 -0
  296. package/dist/simulation/scenarios/latent-space/index.js.map +1 -0
  297. package/dist/simulation/scenarios/latent-space/neural-augmentation.d.ts +52 -0
  298. package/dist/simulation/scenarios/latent-space/neural-augmentation.d.ts.map +1 -0
  299. package/dist/simulation/scenarios/latent-space/neural-augmentation.js +472 -0
  300. package/dist/simulation/scenarios/latent-space/neural-augmentation.js.map +1 -0
  301. package/dist/simulation/scenarios/latent-space/quantum-hybrid.d.ts +53 -0
  302. package/dist/simulation/scenarios/latent-space/quantum-hybrid.d.ts.map +1 -0
  303. package/dist/simulation/scenarios/latent-space/quantum-hybrid.js +391 -0
  304. package/dist/simulation/scenarios/latent-space/quantum-hybrid.js.map +1 -0
  305. package/dist/simulation/scenarios/latent-space/self-organizing-hnsw.d.ts +52 -0
  306. package/dist/simulation/scenarios/latent-space/self-organizing-hnsw.d.ts.map +1 -0
  307. package/dist/simulation/scenarios/latent-space/self-organizing-hnsw.js +514 -0
  308. package/dist/simulation/scenarios/latent-space/self-organizing-hnsw.js.map +1 -0
  309. package/dist/simulation/scenarios/latent-space/traversal-optimization.d.ts +53 -0
  310. package/dist/simulation/scenarios/latent-space/traversal-optimization.d.ts.map +1 -0
  311. package/dist/simulation/scenarios/latent-space/traversal-optimization.js +595 -0
  312. package/dist/simulation/scenarios/latent-space/traversal-optimization.js.map +1 -0
  313. package/dist/simulation/scenarios/lean-agentic-swarm.d.ts +18 -0
  314. package/dist/simulation/scenarios/lean-agentic-swarm.d.ts.map +1 -0
  315. package/dist/simulation/scenarios/lean-agentic-swarm.js +132 -0
  316. package/dist/simulation/scenarios/lean-agentic-swarm.js.map +1 -0
  317. package/dist/simulation/scenarios/multi-agent-swarm.d.ts +17 -0
  318. package/dist/simulation/scenarios/multi-agent-swarm.d.ts.map +1 -0
  319. package/dist/simulation/scenarios/multi-agent-swarm.js +111 -0
  320. package/dist/simulation/scenarios/multi-agent-swarm.js.map +1 -0
  321. package/dist/simulation/scenarios/psycho-symbolic-reasoner.d.ts +23 -0
  322. package/dist/simulation/scenarios/psycho-symbolic-reasoner.d.ts.map +1 -0
  323. package/dist/simulation/scenarios/psycho-symbolic-reasoner.js +98 -0
  324. package/dist/simulation/scenarios/psycho-symbolic-reasoner.js.map +1 -0
  325. package/dist/simulation/scenarios/reflexion-learning.d.ts +16 -0
  326. package/dist/simulation/scenarios/reflexion-learning.d.ts.map +1 -0
  327. package/dist/simulation/scenarios/reflexion-learning.js +98 -0
  328. package/dist/simulation/scenarios/reflexion-learning.js.map +1 -0
  329. package/dist/simulation/scenarios/research-swarm.d.ts +24 -0
  330. package/dist/simulation/scenarios/research-swarm.d.ts.map +1 -0
  331. package/dist/simulation/scenarios/research-swarm.js +146 -0
  332. package/dist/simulation/scenarios/research-swarm.js.map +1 -0
  333. package/dist/simulation/scenarios/skill-evolution.d.ts +16 -0
  334. package/dist/simulation/scenarios/skill-evolution.d.ts.map +1 -0
  335. package/dist/simulation/scenarios/skill-evolution.js +109 -0
  336. package/dist/simulation/scenarios/skill-evolution.js.map +1 -0
  337. package/dist/simulation/scenarios/stock-market-emergence.d.ts +33 -0
  338. package/dist/simulation/scenarios/stock-market-emergence.d.ts.map +1 -0
  339. package/dist/simulation/scenarios/stock-market-emergence.js +246 -0
  340. package/dist/simulation/scenarios/stock-market-emergence.js.map +1 -0
  341. package/dist/simulation/scenarios/strange-loops.d.ts +18 -0
  342. package/dist/simulation/scenarios/strange-loops.d.ts.map +1 -0
  343. package/dist/simulation/scenarios/strange-loops.js +133 -0
  344. package/dist/simulation/scenarios/strange-loops.js.map +1 -0
  345. package/dist/simulation/scenarios/sublinear-solver.d.ts +22 -0
  346. package/dist/simulation/scenarios/sublinear-solver.d.ts.map +1 -0
  347. package/dist/simulation/scenarios/sublinear-solver.js +82 -0
  348. package/dist/simulation/scenarios/sublinear-solver.js.map +1 -0
  349. package/dist/simulation/scenarios/temporal-lead-solver.d.ts +23 -0
  350. package/dist/simulation/scenarios/temporal-lead-solver.d.ts.map +1 -0
  351. package/dist/simulation/scenarios/temporal-lead-solver.js +90 -0
  352. package/dist/simulation/scenarios/temporal-lead-solver.js.map +1 -0
  353. package/dist/simulation/scenarios/voting-system-consensus.d.ts +27 -0
  354. package/dist/simulation/scenarios/voting-system-consensus.d.ts.map +1 -0
  355. package/dist/simulation/scenarios/voting-system-consensus.js +175 -0
  356. package/dist/simulation/scenarios/voting-system-consensus.js.map +1 -0
  357. package/dist/simulation/types.d.ts +162 -0
  358. package/dist/simulation/types.d.ts.map +1 -0
  359. package/dist/simulation/types.js +5 -0
  360. package/dist/simulation/types.js.map +1 -0
  361. package/dist/simulation/utils/PerformanceOptimizer.d.ts +115 -0
  362. package/dist/simulation/utils/PerformanceOptimizer.d.ts.map +1 -0
  363. package/dist/simulation/utils/PerformanceOptimizer.js +223 -0
  364. package/dist/simulation/utils/PerformanceOptimizer.js.map +1 -0
  365. package/dist/src/backends/GraphBackend.d.ts +196 -0
  366. package/dist/src/backends/GraphBackend.d.ts.map +1 -0
  367. package/dist/src/backends/GraphBackend.js +33 -0
  368. package/dist/src/backends/GraphBackend.js.map +1 -0
  369. package/dist/src/backends/LearningBackend.d.ts +148 -0
  370. package/dist/src/backends/LearningBackend.d.ts.map +1 -0
  371. package/dist/src/backends/LearningBackend.js +27 -0
  372. package/dist/src/backends/LearningBackend.js.map +1 -0
  373. package/dist/src/backends/VectorBackend.d.ts +119 -0
  374. package/dist/src/backends/VectorBackend.d.ts.map +1 -0
  375. package/dist/src/backends/VectorBackend.js +14 -0
  376. package/dist/src/backends/VectorBackend.js.map +1 -0
  377. package/dist/src/backends/detector.d.ts +81 -0
  378. package/dist/src/backends/detector.d.ts.map +1 -0
  379. package/dist/src/backends/detector.js +192 -0
  380. package/dist/src/backends/detector.js.map +1 -0
  381. package/dist/src/backends/factory.d.ts +50 -0
  382. package/dist/src/backends/factory.d.ts.map +1 -0
  383. package/dist/src/backends/factory.js +161 -0
  384. package/dist/src/backends/factory.js.map +1 -0
  385. package/dist/src/backends/graph/GraphDatabaseAdapter.d.ts +151 -0
  386. package/dist/src/backends/graph/GraphDatabaseAdapter.d.ts.map +1 -0
  387. package/dist/src/backends/graph/GraphDatabaseAdapter.js +224 -0
  388. package/dist/src/backends/graph/GraphDatabaseAdapter.js.map +1 -0
  389. package/dist/src/backends/hnswlib/HNSWLibBackend.d.ts +92 -0
  390. package/dist/src/backends/hnswlib/HNSWLibBackend.d.ts.map +1 -0
  391. package/dist/src/backends/hnswlib/HNSWLibBackend.js +316 -0
  392. package/dist/src/backends/hnswlib/HNSWLibBackend.js.map +1 -0
  393. package/dist/src/backends/hnswlib/index.d.ts +7 -0
  394. package/dist/src/backends/hnswlib/index.d.ts.map +1 -0
  395. package/dist/src/backends/hnswlib/index.js +7 -0
  396. package/dist/src/backends/hnswlib/index.js.map +1 -0
  397. package/dist/src/backends/index.d.ts +14 -0
  398. package/dist/src/backends/index.d.ts.map +1 -0
  399. package/dist/src/backends/index.js +13 -0
  400. package/dist/src/backends/index.js.map +1 -0
  401. package/dist/src/backends/ruvector/RuVectorBackend.d.ts +75 -0
  402. package/dist/src/backends/ruvector/RuVectorBackend.d.ts.map +1 -0
  403. package/dist/src/backends/ruvector/RuVectorBackend.js +198 -0
  404. package/dist/src/backends/ruvector/RuVectorBackend.js.map +1 -0
  405. package/dist/src/backends/ruvector/RuVectorLearning.d.ts +104 -0
  406. package/dist/src/backends/ruvector/RuVectorLearning.d.ts.map +1 -0
  407. package/dist/src/backends/ruvector/RuVectorLearning.js +177 -0
  408. package/dist/src/backends/ruvector/RuVectorLearning.js.map +1 -0
  409. package/dist/src/backends/ruvector/index.d.ts +9 -0
  410. package/dist/src/backends/ruvector/index.d.ts.map +1 -0
  411. package/dist/src/backends/ruvector/index.js +8 -0
  412. package/dist/src/backends/ruvector/index.js.map +1 -0
  413. package/dist/src/benchmarks/wasm-vector-benchmark.d.ts +10 -0
  414. package/dist/src/benchmarks/wasm-vector-benchmark.d.ts.map +1 -0
  415. package/dist/src/benchmarks/wasm-vector-benchmark.js +196 -0
  416. package/dist/src/benchmarks/wasm-vector-benchmark.js.map +1 -0
  417. package/dist/src/browser/AdvancedFeatures.d.ts +144 -0
  418. package/dist/src/browser/AdvancedFeatures.d.ts.map +1 -0
  419. package/dist/src/browser/AdvancedFeatures.js +430 -0
  420. package/dist/src/browser/AdvancedFeatures.js.map +1 -0
  421. package/dist/src/browser/HNSWIndex.d.ts +117 -0
  422. package/dist/src/browser/HNSWIndex.d.ts.map +1 -0
  423. package/dist/src/browser/HNSWIndex.js +402 -0
  424. package/dist/src/browser/HNSWIndex.js.map +1 -0
  425. package/dist/src/browser/ProductQuantization.d.ts +107 -0
  426. package/dist/src/browser/ProductQuantization.d.ts.map +1 -0
  427. package/dist/src/browser/ProductQuantization.js +337 -0
  428. package/dist/src/browser/ProductQuantization.js.map +1 -0
  429. package/dist/src/browser/index.d.ts +223 -0
  430. package/dist/src/browser/index.d.ts.map +1 -0
  431. package/dist/src/browser/index.js +225 -0
  432. package/dist/src/browser/index.js.map +1 -0
  433. package/dist/src/cli/agentdb-cli.d.ts +154 -0
  434. package/dist/src/cli/agentdb-cli.d.ts.map +1 -0
  435. package/dist/src/cli/agentdb-cli.js +2273 -0
  436. package/dist/src/cli/agentdb-cli.js.map +1 -0
  437. package/dist/src/cli/commands/init.d.ts +12 -0
  438. package/dist/src/cli/commands/init.d.ts.map +1 -0
  439. package/dist/src/cli/commands/init.js +115 -0
  440. package/dist/src/cli/commands/init.js.map +1 -0
  441. package/dist/src/cli/commands/install-embeddings.d.ts +10 -0
  442. package/dist/src/cli/commands/install-embeddings.d.ts.map +1 -0
  443. package/dist/src/cli/commands/install-embeddings.js +68 -0
  444. package/dist/src/cli/commands/install-embeddings.js.map +1 -0
  445. package/dist/src/cli/commands/migrate.d.ts +15 -0
  446. package/dist/src/cli/commands/migrate.d.ts.map +1 -0
  447. package/dist/src/cli/commands/migrate.js +425 -0
  448. package/dist/src/cli/commands/migrate.js.map +1 -0
  449. package/dist/src/cli/commands/simulate-custom.d.ts +26 -0
  450. package/dist/src/cli/commands/simulate-custom.d.ts.map +1 -0
  451. package/dist/src/cli/commands/simulate-custom.js +207 -0
  452. package/dist/src/cli/commands/simulate-custom.js.map +1 -0
  453. package/dist/src/cli/commands/simulate-report.d.ts +15 -0
  454. package/dist/src/cli/commands/simulate-report.d.ts.map +1 -0
  455. package/dist/src/cli/commands/simulate-report.js +136 -0
  456. package/dist/src/cli/commands/simulate-report.js.map +1 -0
  457. package/dist/src/cli/commands/simulate-wizard.d.ts +6 -0
  458. package/dist/src/cli/commands/simulate-wizard.d.ts.map +1 -0
  459. package/dist/src/cli/commands/simulate-wizard.js +352 -0
  460. package/dist/src/cli/commands/simulate-wizard.js.map +1 -0
  461. package/dist/src/cli/commands/simulate.d.ts +7 -0
  462. package/dist/src/cli/commands/simulate.d.ts.map +1 -0
  463. package/dist/src/cli/commands/simulate.js +100 -0
  464. package/dist/src/cli/commands/simulate.js.map +1 -0
  465. package/dist/src/cli/commands/status.d.ts +10 -0
  466. package/dist/src/cli/commands/status.d.ts.map +1 -0
  467. package/dist/src/cli/commands/status.js +129 -0
  468. package/dist/src/cli/commands/status.js.map +1 -0
  469. package/dist/src/cli/lib/config-manager.d.ts +110 -0
  470. package/dist/src/cli/lib/config-manager.d.ts.map +1 -0
  471. package/dist/src/cli/lib/config-manager.js +512 -0
  472. package/dist/src/cli/lib/config-manager.js.map +1 -0
  473. package/dist/src/cli/lib/config-validator.d.ts +43 -0
  474. package/dist/src/cli/lib/config-validator.d.ts.map +1 -0
  475. package/dist/src/cli/lib/config-validator.js +217 -0
  476. package/dist/src/cli/lib/config-validator.js.map +1 -0
  477. package/dist/src/cli/lib/health-monitor.d.ts +149 -0
  478. package/dist/src/cli/lib/health-monitor.d.ts.map +1 -0
  479. package/dist/src/cli/lib/health-monitor.js +380 -0
  480. package/dist/src/cli/lib/health-monitor.js.map +1 -0
  481. package/dist/src/cli/lib/help-formatter.d.ts +38 -0
  482. package/dist/src/cli/lib/help-formatter.d.ts.map +1 -0
  483. package/dist/src/cli/lib/help-formatter.js +357 -0
  484. package/dist/src/cli/lib/help-formatter.js.map +1 -0
  485. package/dist/src/cli/lib/history-tracker.d.ts +103 -0
  486. package/dist/src/cli/lib/history-tracker.d.ts.map +1 -0
  487. package/dist/src/cli/lib/history-tracker.js +352 -0
  488. package/dist/src/cli/lib/history-tracker.js.map +1 -0
  489. package/dist/src/cli/lib/report-generator.d.ts +24 -0
  490. package/dist/src/cli/lib/report-generator.d.ts.map +1 -0
  491. package/dist/src/cli/lib/report-generator.js +417 -0
  492. package/dist/src/cli/lib/report-generator.js.map +1 -0
  493. package/dist/src/cli/lib/report-store.d.ts +116 -0
  494. package/dist/src/cli/lib/report-store.d.ts.map +1 -0
  495. package/dist/src/cli/lib/report-store.js +464 -0
  496. package/dist/src/cli/lib/report-store.js.map +1 -0
  497. package/dist/src/cli/lib/simulation-registry.d.ts +165 -0
  498. package/dist/src/cli/lib/simulation-registry.d.ts.map +1 -0
  499. package/dist/src/cli/lib/simulation-registry.js +332 -0
  500. package/dist/src/cli/lib/simulation-registry.js.map +1 -0
  501. package/dist/src/cli/lib/simulation-runner.d.ts +90 -0
  502. package/dist/src/cli/lib/simulation-runner.d.ts.map +1 -0
  503. package/dist/src/cli/lib/simulation-runner.js +211 -0
  504. package/dist/src/cli/lib/simulation-runner.js.map +1 -0
  505. package/dist/src/controllers/CausalMemoryGraph.d.ts +127 -0
  506. package/dist/src/controllers/CausalMemoryGraph.d.ts.map +1 -0
  507. package/dist/src/controllers/CausalMemoryGraph.js +354 -0
  508. package/dist/src/controllers/CausalMemoryGraph.js.map +1 -0
  509. package/dist/src/controllers/CausalRecall.d.ts +139 -0
  510. package/dist/src/controllers/CausalRecall.d.ts.map +1 -0
  511. package/dist/src/controllers/CausalRecall.js +356 -0
  512. package/dist/src/controllers/CausalRecall.js.map +1 -0
  513. package/dist/src/controllers/ContextSynthesizer.d.ts +65 -0
  514. package/dist/src/controllers/ContextSynthesizer.d.ts.map +1 -0
  515. package/dist/src/controllers/ContextSynthesizer.js +208 -0
  516. package/dist/src/controllers/ContextSynthesizer.js.map +1 -0
  517. package/dist/src/controllers/EmbeddingService.d.ts +37 -0
  518. package/dist/src/controllers/EmbeddingService.d.ts.map +1 -0
  519. package/dist/src/controllers/EmbeddingService.js +136 -0
  520. package/dist/src/controllers/EmbeddingService.js.map +1 -0
  521. package/dist/src/controllers/EnhancedEmbeddingService.d.ts +50 -0
  522. package/dist/src/controllers/EnhancedEmbeddingService.d.ts.map +1 -0
  523. package/dist/src/controllers/EnhancedEmbeddingService.js +119 -0
  524. package/dist/src/controllers/EnhancedEmbeddingService.js.map +1 -0
  525. package/dist/src/controllers/ExplainableRecall.d.ts +163 -0
  526. package/dist/src/controllers/ExplainableRecall.d.ts.map +1 -0
  527. package/dist/src/controllers/ExplainableRecall.js +485 -0
  528. package/dist/src/controllers/ExplainableRecall.js.map +1 -0
  529. package/dist/src/controllers/HNSWIndex.d.ts +128 -0
  530. package/dist/src/controllers/HNSWIndex.d.ts.map +1 -0
  531. package/dist/src/controllers/HNSWIndex.js +361 -0
  532. package/dist/src/controllers/HNSWIndex.js.map +1 -0
  533. package/dist/src/controllers/LearningSystem.d.ts +195 -0
  534. package/dist/src/controllers/LearningSystem.d.ts.map +1 -0
  535. package/dist/src/controllers/LearningSystem.js +929 -0
  536. package/dist/src/controllers/LearningSystem.js.map +1 -0
  537. package/dist/src/controllers/MMRDiversityRanker.d.ts +50 -0
  538. package/dist/src/controllers/MMRDiversityRanker.d.ts.map +1 -0
  539. package/dist/src/controllers/MMRDiversityRanker.js +130 -0
  540. package/dist/src/controllers/MMRDiversityRanker.js.map +1 -0
  541. package/dist/src/controllers/MetadataFilter.d.ts +70 -0
  542. package/dist/src/controllers/MetadataFilter.d.ts.map +1 -0
  543. package/dist/src/controllers/MetadataFilter.js +243 -0
  544. package/dist/src/controllers/MetadataFilter.js.map +1 -0
  545. package/dist/src/controllers/NightlyLearner.d.ts +114 -0
  546. package/dist/src/controllers/NightlyLearner.d.ts.map +1 -0
  547. package/dist/src/controllers/NightlyLearner.js +394 -0
  548. package/dist/src/controllers/NightlyLearner.js.map +1 -0
  549. package/dist/src/controllers/QUICClient.d.ts +109 -0
  550. package/dist/src/controllers/QUICClient.d.ts.map +1 -0
  551. package/dist/src/controllers/QUICClient.js +299 -0
  552. package/dist/src/controllers/QUICClient.js.map +1 -0
  553. package/dist/src/controllers/QUICServer.d.ts +121 -0
  554. package/dist/src/controllers/QUICServer.d.ts.map +1 -0
  555. package/dist/src/controllers/QUICServer.js +383 -0
  556. package/dist/src/controllers/QUICServer.js.map +1 -0
  557. package/dist/src/controllers/ReasoningBank.d.ts +196 -0
  558. package/dist/src/controllers/ReasoningBank.d.ts.map +1 -0
  559. package/dist/src/controllers/ReasoningBank.js +494 -0
  560. package/dist/src/controllers/ReasoningBank.js.map +1 -0
  561. package/dist/src/controllers/ReflexionMemory.d.ts +125 -0
  562. package/dist/src/controllers/ReflexionMemory.d.ts.map +1 -0
  563. package/dist/src/controllers/ReflexionMemory.js +654 -0
  564. package/dist/src/controllers/ReflexionMemory.js.map +1 -0
  565. package/dist/src/controllers/SkillLibrary.d.ts +150 -0
  566. package/dist/src/controllers/SkillLibrary.d.ts.map +1 -0
  567. package/dist/src/controllers/SkillLibrary.js +608 -0
  568. package/dist/src/controllers/SkillLibrary.js.map +1 -0
  569. package/dist/src/controllers/SyncCoordinator.d.ts +120 -0
  570. package/dist/src/controllers/SyncCoordinator.d.ts.map +1 -0
  571. package/dist/src/controllers/SyncCoordinator.js +441 -0
  572. package/dist/src/controllers/SyncCoordinator.js.map +1 -0
  573. package/dist/src/controllers/WASMVectorSearch.d.ts +89 -0
  574. package/dist/src/controllers/WASMVectorSearch.d.ts.map +1 -0
  575. package/dist/src/controllers/WASMVectorSearch.js +234 -0
  576. package/dist/src/controllers/WASMVectorSearch.js.map +1 -0
  577. package/dist/src/controllers/frontier-index.d.ts +14 -0
  578. package/dist/src/controllers/frontier-index.d.ts.map +1 -0
  579. package/dist/src/controllers/frontier-index.js +10 -0
  580. package/dist/src/controllers/frontier-index.js.map +1 -0
  581. package/dist/src/controllers/index.d.ts +30 -0
  582. package/dist/src/controllers/index.d.ts.map +1 -0
  583. package/dist/src/controllers/index.js +18 -0
  584. package/dist/src/controllers/index.js.map +1 -0
  585. package/dist/src/db-fallback.d.ts +26 -0
  586. package/dist/src/db-fallback.d.ts.map +1 -0
  587. package/dist/src/db-fallback.js +264 -0
  588. package/dist/src/db-fallback.js.map +1 -0
  589. package/dist/src/db-test.d.ts +13 -0
  590. package/dist/src/db-test.d.ts.map +1 -0
  591. package/dist/src/db-test.js +55 -0
  592. package/dist/src/db-test.js.map +1 -0
  593. package/dist/src/db-unified.d.ts +76 -0
  594. package/dist/src/db-unified.d.ts.map +1 -0
  595. package/dist/src/db-unified.js +279 -0
  596. package/dist/src/db-unified.js.map +1 -0
  597. package/dist/src/examples/quic-sync-example.d.ts +9 -0
  598. package/dist/src/examples/quic-sync-example.d.ts.map +1 -0
  599. package/dist/src/examples/quic-sync-example.js +169 -0
  600. package/dist/src/examples/quic-sync-example.js.map +1 -0
  601. package/dist/src/examples/wasm-vector-usage.d.ts +12 -0
  602. package/dist/src/examples/wasm-vector-usage.d.ts.map +1 -0
  603. package/dist/src/examples/wasm-vector-usage.js +190 -0
  604. package/dist/src/examples/wasm-vector-usage.js.map +1 -0
  605. package/dist/src/index.d.ts +28 -0
  606. package/dist/src/index.d.ts.map +1 -0
  607. package/dist/src/index.js +35 -0
  608. package/dist/src/index.js.map +1 -0
  609. package/dist/src/mcp/agentdb-mcp-server.d.ts +8 -0
  610. package/dist/src/mcp/agentdb-mcp-server.d.ts.map +1 -0
  611. package/dist/src/mcp/agentdb-mcp-server.js +2116 -0
  612. package/dist/src/mcp/agentdb-mcp-server.js.map +1 -0
  613. package/dist/src/mcp/learning-tools-handlers.d.ts +16 -0
  614. package/dist/src/mcp/learning-tools-handlers.d.ts.map +1 -0
  615. package/dist/src/mcp/learning-tools-handlers.js +105 -0
  616. package/dist/src/mcp/learning-tools-handlers.js.map +1 -0
  617. package/dist/src/optimizations/BatchOperations.d.ts +109 -0
  618. package/dist/src/optimizations/BatchOperations.d.ts.map +1 -0
  619. package/dist/src/optimizations/BatchOperations.js +407 -0
  620. package/dist/src/optimizations/BatchOperations.js.map +1 -0
  621. package/dist/src/optimizations/QueryOptimizer.d.ts +83 -0
  622. package/dist/src/optimizations/QueryOptimizer.d.ts.map +1 -0
  623. package/dist/src/optimizations/QueryOptimizer.js +228 -0
  624. package/dist/src/optimizations/QueryOptimizer.js.map +1 -0
  625. package/dist/src/optimizations/ToolCache.d.ts +137 -0
  626. package/dist/src/optimizations/ToolCache.d.ts.map +1 -0
  627. package/dist/src/optimizations/ToolCache.js +281 -0
  628. package/dist/src/optimizations/ToolCache.js.map +1 -0
  629. package/dist/src/optimizations/index.d.ts +10 -0
  630. package/dist/src/optimizations/index.d.ts.map +1 -0
  631. package/dist/src/optimizations/index.js +8 -0
  632. package/dist/src/optimizations/index.js.map +1 -0
  633. package/dist/src/security/input-validation.d.ts +109 -0
  634. package/dist/src/security/input-validation.d.ts.map +1 -0
  635. package/dist/src/security/input-validation.js +398 -0
  636. package/dist/src/security/input-validation.js.map +1 -0
  637. package/dist/src/security/limits.d.ts +150 -0
  638. package/dist/src/security/limits.d.ts.map +1 -0
  639. package/dist/src/security/limits.js +288 -0
  640. package/dist/src/security/limits.js.map +1 -0
  641. package/dist/src/security/path-security.d.ts +100 -0
  642. package/dist/src/security/path-security.d.ts.map +1 -0
  643. package/dist/src/security/path-security.js +337 -0
  644. package/dist/src/security/path-security.js.map +1 -0
  645. package/dist/src/security/validation.d.ts +95 -0
  646. package/dist/src/security/validation.d.ts.map +1 -0
  647. package/dist/src/security/validation.js +315 -0
  648. package/dist/src/security/validation.js.map +1 -0
  649. package/dist/src/services/LLMRouter.d.ts +84 -0
  650. package/dist/src/services/LLMRouter.d.ts.map +1 -0
  651. package/dist/src/services/LLMRouter.js +329 -0
  652. package/dist/src/services/LLMRouter.js.map +1 -0
  653. package/dist/src/types/quic.d.ts +518 -0
  654. package/dist/src/types/quic.d.ts.map +1 -0
  655. package/dist/src/types/quic.js +272 -0
  656. package/dist/src/types/quic.js.map +1 -0
  657. package/dist/src/utils/NodeIdMapper.d.ts +38 -0
  658. package/dist/src/utils/NodeIdMapper.d.ts.map +1 -0
  659. package/dist/src/utils/NodeIdMapper.js +57 -0
  660. package/dist/src/utils/NodeIdMapper.js.map +1 -0
  661. package/examples/README.md +105 -0
  662. package/examples/quickstart.js +43 -0
  663. package/package.json +17 -3
  664. package/scripts/README.md +314 -0
  665. package/simulation/.claude-flow/metrics/agent-metrics.json +1 -0
  666. package/simulation/.claude-flow/metrics/performance.json +87 -0
  667. package/simulation/.claude-flow/metrics/task-metrics.json +10 -0
  668. package/simulation/COMPLETION-STATUS.md +139 -0
  669. package/simulation/FINAL-RESULTS.md +414 -0
  670. package/simulation/FINAL-STATUS.md +281 -0
  671. package/simulation/INTEGRATION-COMPLETE.md +452 -0
  672. package/simulation/MIGRATION-STATUS.md +231 -0
  673. package/simulation/OPTIMIZATION-RESULTS.md +397 -0
  674. package/simulation/PHASE1-COMPLETE.md +163 -0
  675. package/simulation/README.md +848 -0
  676. package/simulation/SIMULATION-RESULTS.md +239 -0
  677. package/simulation/cli.ts +78 -0
  678. package/simulation/configs/default.json +37 -0
  679. package/simulation/data/advanced/aidefence.graph +0 -0
  680. package/simulation/data/advanced/bmssp.graph +0 -0
  681. package/simulation/data/advanced/consciousness.graph +0 -0
  682. package/simulation/data/advanced/goalie.graph +0 -0
  683. package/simulation/data/advanced/psycho-symbolic.graph +0 -0
  684. package/simulation/data/advanced/research-swarm.graph +0 -0
  685. package/simulation/data/advanced/sublinear.graph +0 -0
  686. package/simulation/data/advanced/temporal.graph +0 -0
  687. package/simulation/data/causal.graph +0 -0
  688. package/simulation/data/graph-traversal.graph +0 -0
  689. package/simulation/data/lean-agentic.graph +0 -0
  690. package/simulation/data/reflexion.graph +0 -0
  691. package/simulation/data/skills.graph +0 -0
  692. package/simulation/data/stock-market.graph +0 -0
  693. package/simulation/data/strange-loops.graph +0 -0
  694. package/simulation/data/swarm.graph +0 -0
  695. package/simulation/data/voting-consensus.graph +0 -0
  696. package/simulation/docs/CLI-INTEGRATION-PLAN.md +1038 -0
  697. package/simulation/docs/COMPREHENSIVE-LATENT-SPACE-COMPLETION.md +354 -0
  698. package/simulation/docs/DOCUMENTATION-INDEX.md +226 -0
  699. package/simulation/docs/IMPLEMENTATION-COMPLETE.md +521 -0
  700. package/simulation/docs/OPTIMIZATION-SUMMARY.md +279 -0
  701. package/simulation/docs/README.md +229 -0
  702. package/simulation/docs/SWARM-5-INTEGRATION-SUMMARY.md +528 -0
  703. package/simulation/docs/TESTING-SUMMARY.md +304 -0
  704. package/simulation/docs/architecture/EXTENSION-API.md +868 -0
  705. package/simulation/docs/architecture/INTEGRATION-ARCHITECTURE.md +1138 -0
  706. package/simulation/docs/architecture/OPTIMIZATION-STRATEGY.md +778 -0
  707. package/simulation/docs/architecture/SIMULATION-ARCHITECTURE.md +892 -0
  708. package/simulation/docs/guides/CLI-REFERENCE.md +896 -0
  709. package/simulation/docs/guides/CUSTOM-SIMULATIONS.md +931 -0
  710. package/simulation/docs/guides/DEPLOYMENT.md +832 -0
  711. package/simulation/docs/guides/IMPLEMENTATION-SUMMARY.md +544 -0
  712. package/simulation/docs/guides/MIGRATION-GUIDE.md +591 -0
  713. package/simulation/docs/guides/QUICK-START.md +361 -0
  714. package/simulation/docs/guides/README.md +736 -0
  715. package/simulation/docs/guides/TROUBLESHOOTING.md +817 -0
  716. package/simulation/docs/guides/WIZARD-GUIDE.md +869 -0
  717. package/simulation/docs/reports/latent-space/MASTER-SYNTHESIS.md +345 -0
  718. package/simulation/docs/reports/latent-space/README.md +132 -0
  719. package/simulation/docs/reports/latent-space/attention-analysis-RESULTS.md +238 -0
  720. package/simulation/docs/reports/latent-space/clustering-analysis-RESULTS.md +210 -0
  721. package/simulation/docs/reports/latent-space/hnsw-exploration-RESULTS.md +332 -0
  722. package/simulation/docs/reports/latent-space/hypergraph-exploration-RESULTS.md +37 -0
  723. package/simulation/docs/reports/latent-space/neural-augmentation-RESULTS.md +69 -0
  724. package/simulation/docs/reports/latent-space/quantum-hybrid-RESULTS.md +91 -0
  725. package/simulation/docs/reports/latent-space/self-organizing-hnsw-RESULTS.md +51 -0
  726. package/simulation/docs/reports/latent-space/traversal-optimization-RESULTS.md +238 -0
  727. package/simulation/reports/README.md +397 -0
  728. package/simulation/reports/advanced-simulations-performance.md +1241 -0
  729. package/simulation/reports/aidefence-integration-2025-11-30T01-36-53-486Z.json +30 -0
  730. package/simulation/reports/architecture-analysis.md +1396 -0
  731. package/simulation/reports/basic-scenarios-performance.md +1840 -0
  732. package/simulation/reports/bmssp-integration-2025-11-30T01-36-27-193Z.json +30 -0
  733. package/simulation/reports/bmssp-integration-2025-11-30T03-38-12-887Z.json +30 -0
  734. package/simulation/reports/causal-reasoning-2025-11-29T23-35-21-795Z.json +36 -0
  735. package/simulation/reports/causal-reasoning-2025-11-30T00-58-42-862Z.json +30 -0
  736. package/simulation/reports/causal-reasoning-2025-11-30T00-59-12-546Z.json +40 -0
  737. package/simulation/reports/consciousness-explorer-2025-11-30T01-36-51-269Z.json +31 -0
  738. package/simulation/reports/core-benchmarks.md +727 -0
  739. package/simulation/reports/goalie-integration-2025-11-30T01-36-52-377Z.json +30 -0
  740. package/simulation/reports/graph-traversal-2025-11-29T23-35-35-279Z.json +78 -0
  741. package/simulation/reports/graph-traversal-2025-11-29T23-37-36-697Z.json +30 -0
  742. package/simulation/reports/graph-traversal-2025-11-30T01-03-59-716Z.json +30 -0
  743. package/simulation/reports/graph-traversal-2025-11-30T01-05-10-984Z.json +30 -0
  744. package/simulation/reports/graph-traversal-2025-11-30T01-06-16-334Z.json +30 -0
  745. package/simulation/reports/graph-traversal-2025-11-30T01-06-53-312Z.json +30 -0
  746. package/simulation/reports/graph-traversal-2025-11-30T01-07-51-075Z.json +24 -0
  747. package/simulation/reports/graph-traversal-2025-11-30T01-08-22-179Z.json +42 -0
  748. package/simulation/reports/lean-agentic-swarm-2025-11-29T23-37-23-804Z.json +148 -0
  749. package/simulation/reports/lean-agentic-swarm-2025-11-30T01-31-24-401Z.json +31 -0
  750. package/simulation/reports/lean-agentic-swarm-2025-11-30T03-38-01-470Z.json +31 -0
  751. package/simulation/reports/multi-agent-swarm-2025-11-29T23-35-28-093Z.json +78 -0
  752. package/simulation/reports/multi-agent-swarm-2025-11-30T01-03-54-062Z.json +42 -0
  753. package/simulation/reports/multi-agent-swarm-2025-11-30T01-05-06-092Z.json +42 -0
  754. package/simulation/reports/psycho-symbolic-reasoner-2025-11-30T01-36-50-180Z.json +30 -0
  755. package/simulation/reports/quality-metrics.md +727 -0
  756. package/simulation/reports/reflexion-learning-2025-11-29T23-35-09-774Z.json +48 -0
  757. package/simulation/reports/reflexion-learning-2025-11-29T23-37-16-934Z.json +36 -0
  758. package/simulation/reports/reflexion-learning-2025-11-30T00-07-49-259Z.json +30 -0
  759. package/simulation/reports/reflexion-learning-2025-11-30T00-09-29-319Z.json +51 -0
  760. package/simulation/reports/reflexion-learning-2025-11-30T00-28-37-659Z.json +51 -0
  761. package/simulation/reports/reflexion-learning-2025-11-30T01-31-30-690Z.json +29 -0
  762. package/simulation/reports/reflexion-learning-2025-11-30T03-38-06-937Z.json +29 -0
  763. package/simulation/reports/research-foundations.md +2004 -0
  764. package/simulation/reports/research-swarm-2025-11-30T01-36-54-647Z.json +30 -0
  765. package/simulation/reports/scalability-deployment.md +2404 -0
  766. package/simulation/reports/skill-evolution-2025-11-29T23-35-15-945Z.json +36 -0
  767. package/simulation/reports/skill-evolution-2025-11-30T01-03-17-995Z.json +30 -0
  768. package/simulation/reports/skill-evolution-2025-11-30T01-03-48-441Z.json +30 -0
  769. package/simulation/reports/skill-evolution-2025-11-30T01-05-00-554Z.json +30 -0
  770. package/simulation/reports/skill-evolution-2025-11-30T01-06-11-436Z.json +30 -0
  771. package/simulation/reports/skill-evolution-2025-11-30T01-06-51-979Z.json +30 -0
  772. package/simulation/reports/skill-evolution-2025-11-30T01-07-32-695Z.json +40 -0
  773. package/simulation/reports/stock-market-emergence-2025-11-30T00-11-43-865Z.json +56 -0
  774. package/simulation/reports/stock-market-emergence-2025-11-30T00-28-57-495Z.json +56 -0
  775. package/simulation/reports/strange-loops-2025-11-29T23-37-30-621Z.json +78 -0
  776. package/simulation/reports/strange-loops-2025-11-30T00-07-55-415Z.json +30 -0
  777. package/simulation/reports/strange-loops-2025-11-30T00-09-35-133Z.json +30 -0
  778. package/simulation/reports/strange-loops-2025-11-30T00-48-50-744Z.json +24 -0
  779. package/simulation/reports/strange-loops-2025-11-30T00-54-48-044Z.json +24 -0
  780. package/simulation/reports/strange-loops-2025-11-30T00-57-27-633Z.json +24 -0
  781. package/simulation/reports/strange-loops-2025-11-30T00-57-59-135Z.json +42 -0
  782. package/simulation/reports/sublinear-solver-2025-11-30T01-36-33-134Z.json +30 -0
  783. package/simulation/reports/temporal-lead-solver-2025-11-30T01-36-38-628Z.json +30 -0
  784. package/simulation/reports/use-cases-applications.md +2212 -0
  785. package/simulation/reports/voting-system-consensus-2025-11-30T00-11-37-199Z.json +58 -0
  786. package/simulation/reports/voting-system-consensus-2025-11-30T00-28-47-735Z.json +58 -0
  787. package/simulation/runner.ts +300 -0
  788. package/simulation/scenarios/README-advanced/aidefence-integration.md +63 -0
  789. package/simulation/scenarios/README-advanced/bmssp-integration.md +58 -0
  790. package/simulation/scenarios/README-advanced/consciousness-explorer.md +53 -0
  791. package/simulation/scenarios/README-advanced/goalie-integration.md +61 -0
  792. package/simulation/scenarios/README-advanced/psycho-symbolic-reasoner.md +55 -0
  793. package/simulation/scenarios/README-advanced/research-swarm.md +63 -0
  794. package/simulation/scenarios/README-advanced/sublinear-solver.md +58 -0
  795. package/simulation/scenarios/README-advanced/temporal-lead-solver.md +55 -0
  796. package/simulation/scenarios/README-basic/causal-reasoning.md +39 -0
  797. package/simulation/scenarios/README-basic/graph-traversal.md +41 -0
  798. package/simulation/scenarios/README-basic/lean-agentic-swarm.md +122 -0
  799. package/simulation/scenarios/README-basic/multi-agent-swarm.md +34 -0
  800. package/simulation/scenarios/README-basic/reflexion-learning.md +41 -0
  801. package/simulation/scenarios/README-basic/skill-evolution.md +38 -0
  802. package/simulation/scenarios/README-basic/stock-market-emergence.md +28 -0
  803. package/simulation/scenarios/README-basic/strange-loops.md +36 -0
  804. package/simulation/scenarios/README-basic/voting-system-consensus.md +28 -0
  805. package/simulation/scenarios/README.md +438 -0
  806. package/simulation/scenarios/aidefence-integration.ts +165 -0
  807. package/simulation/scenarios/bmssp-integration.ts +137 -0
  808. package/simulation/scenarios/causal-reasoning.ts +143 -0
  809. package/simulation/scenarios/consciousness-explorer.ts +139 -0
  810. package/simulation/scenarios/domain-examples/.claude-flow/metrics/agent-metrics.json +1 -0
  811. package/simulation/scenarios/domain-examples/.claude-flow/metrics/performance.json +87 -0
  812. package/simulation/scenarios/domain-examples/.claude-flow/metrics/task-metrics.json +10 -0
  813. package/simulation/scenarios/domain-examples/README.md +525 -0
  814. package/simulation/scenarios/domain-examples/e-commerce-recommendations.ts +220 -0
  815. package/simulation/scenarios/domain-examples/index.ts +81 -0
  816. package/simulation/scenarios/domain-examples/iot-sensor-networks.ts +290 -0
  817. package/simulation/scenarios/domain-examples/medical-imaging.ts +181 -0
  818. package/simulation/scenarios/domain-examples/robotics-navigation.ts +214 -0
  819. package/simulation/scenarios/domain-examples/scientific-research.ts +250 -0
  820. package/simulation/scenarios/domain-examples/trading-systems.ts +138 -0
  821. package/simulation/scenarios/goalie-integration.ts +161 -0
  822. package/simulation/scenarios/graph-traversal.ts +129 -0
  823. package/simulation/scenarios/latent-space/OPTIMIZATION-COMPLETE.md +287 -0
  824. package/simulation/scenarios/latent-space/README-attention-analysis.md +170 -0
  825. package/simulation/scenarios/latent-space/README-clustering-analysis.md +239 -0
  826. package/simulation/scenarios/latent-space/README-hnsw-exploration.md +199 -0
  827. package/simulation/scenarios/latent-space/README-hypergraph-exploration.md +279 -0
  828. package/simulation/scenarios/latent-space/README-neural-augmentation.md +267 -0
  829. package/simulation/scenarios/latent-space/README-quantum-hybrid.md +276 -0
  830. package/simulation/scenarios/latent-space/README-self-organizing-hnsw.md +244 -0
  831. package/simulation/scenarios/latent-space/README-traversal-optimization.md +212 -0
  832. package/simulation/scenarios/latent-space/attention-analysis.ts +598 -0
  833. package/simulation/scenarios/latent-space/clustering-analysis.ts +796 -0
  834. package/simulation/scenarios/latent-space/hnsw-exploration.ts +526 -0
  835. package/simulation/scenarios/latent-space/hypergraph-exploration.ts +706 -0
  836. package/simulation/scenarios/latent-space/index.ts +47 -0
  837. package/simulation/scenarios/latent-space/neural-augmentation.ts +604 -0
  838. package/simulation/scenarios/latent-space/quantum-hybrid.ts +508 -0
  839. package/simulation/scenarios/latent-space/self-organizing-hnsw.ts +680 -0
  840. package/simulation/scenarios/latent-space/traversal-optimization.ts +782 -0
  841. package/simulation/scenarios/lean-agentic-swarm.ts +182 -0
  842. package/simulation/scenarios/multi-agent-swarm.ts +146 -0
  843. package/simulation/scenarios/psycho-symbolic-reasoner.ts +136 -0
  844. package/simulation/scenarios/reflexion-learning.ts +132 -0
  845. package/simulation/scenarios/research-swarm.ts +187 -0
  846. package/simulation/scenarios/skill-evolution.ts +135 -0
  847. package/simulation/scenarios/stock-market-emergence.ts +323 -0
  848. package/simulation/scenarios/strange-loops.ts +175 -0
  849. package/simulation/scenarios/sublinear-solver.ts +108 -0
  850. package/simulation/scenarios/temporal-lead-solver.ts +121 -0
  851. package/simulation/scenarios/voting-system-consensus.ts +251 -0
  852. package/simulation/tests/latent-space/attention-analysis.test.ts +204 -0
  853. package/simulation/tests/latent-space/clustering-analysis.test.ts +281 -0
  854. package/simulation/tests/latent-space/hnsw-exploration.test.ts +253 -0
  855. package/simulation/tests/latent-space/hypergraph-exploration.test.ts +295 -0
  856. package/simulation/tests/latent-space/neural-augmentation.test.ts +326 -0
  857. package/simulation/tests/latent-space/quantum-hybrid.test.ts +307 -0
  858. package/simulation/tests/latent-space/self-organizing-hnsw.test.ts +291 -0
  859. package/simulation/tests/latent-space/traversal-optimization.test.ts +261 -0
  860. package/simulation/types.ts +177 -0
  861. package/simulation/utils/PerformanceOptimizer.ts +269 -0
  862. package/src/backends/GraphBackend.ts +290 -0
  863. package/src/backends/LearningBackend.ts +210 -0
  864. package/src/backends/README.md +389 -0
  865. package/src/backends/VectorBackend.ts +145 -0
  866. package/src/backends/detector.ts +283 -0
  867. package/src/backends/factory.ts +193 -0
  868. package/src/backends/graph/GraphDatabaseAdapter.ts +334 -0
  869. package/src/backends/hnswlib/HNSWLibBackend.ts +413 -0
  870. package/src/backends/hnswlib/index.ts +7 -0
  871. package/src/backends/index.ts +32 -0
  872. package/src/backends/ruvector/RuVectorBackend.ts +232 -0
  873. package/src/backends/ruvector/RuVectorLearning.ts +242 -0
  874. package/src/backends/ruvector/index.ts +9 -0
  875. package/src/backends/ruvector/types.d.ts +64 -0
  876. package/src/browser/AdvancedFeatures.ts +565 -0
  877. package/src/browser/HNSWIndex.ts +494 -0
  878. package/src/browser/ProductQuantization.ts +419 -0
  879. package/src/browser/index.ts +301 -0
  880. package/src/cli/agentdb-cli.ts +131 -8
  881. package/src/cli/commands/init.ts +148 -0
  882. package/src/cli/commands/install-embeddings.ts +81 -0
  883. package/src/cli/commands/migrate.ts +545 -0
  884. package/src/cli/commands/simulate-custom.ts +232 -0
  885. package/src/cli/commands/simulate-report.ts +171 -0
  886. package/src/cli/commands/simulate-wizard.ts +379 -0
  887. package/src/cli/commands/simulate.ts +115 -0
  888. package/src/cli/commands/status.ts +156 -0
  889. package/src/cli/lib/config-manager.ts +627 -0
  890. package/src/cli/lib/config-validator.ts +261 -0
  891. package/src/cli/lib/health-monitor.ts +513 -0
  892. package/src/cli/lib/help-formatter.ts +406 -0
  893. package/src/cli/lib/history-tracker.ts +503 -0
  894. package/src/cli/lib/report-generator.ts +455 -0
  895. package/src/cli/lib/report-store.ts +582 -0
  896. package/src/cli/lib/simulation-registry.ts +502 -0
  897. package/src/cli/lib/simulation-runner.ts +291 -0
  898. package/src/cli/tests/agentdb-cli.test.ts +58 -0
  899. package/src/controllers/CausalMemoryGraph.ts +42 -2
  900. package/src/controllers/CausalRecall.ts +41 -4
  901. package/src/controllers/ExplainableRecall.ts +123 -5
  902. package/src/controllers/NightlyLearner.ts +8 -4
  903. package/src/controllers/ReasoningBank.ts +268 -5
  904. package/src/controllers/ReflexionMemory.ts +531 -6
  905. package/src/controllers/SkillLibrary.ts +234 -60
  906. package/src/db-fallback.ts +103 -35
  907. package/src/db-test.ts +59 -0
  908. package/src/db-unified.ts +327 -0
  909. package/src/mcp/agentdb-mcp-server.ts +544 -38
  910. package/src/optimizations/BatchOperations.ts +270 -0
  911. package/src/optimizations/ToolCache.ts +355 -0
  912. package/src/security/input-validation.ts +166 -0
  913. package/src/security/limits.ts +375 -0
  914. package/src/security/path-security.ts +436 -0
  915. package/src/security/validation.ts +556 -0
  916. package/src/services/LLMRouter.ts +406 -0
  917. package/src/types/xenova-transformers.d.ts +26 -0
  918. package/src/utils/NodeIdMapper.ts +64 -0
@@ -0,0 +1,337 @@
1
+ /**
2
+ * AgentDB v2 Path Security Utilities
3
+ *
4
+ * Prevents path traversal attacks and ensures safe file operations:
5
+ * - Path validation and canonicalization
6
+ * - Symlink detection and handling
7
+ * - Safe file read/write operations
8
+ * - Temporary file cleanup
9
+ */
10
+ import * as path from 'path';
11
+ import * as fs from 'fs';
12
+ import { SecurityError } from './limits.js';
13
+ /**
14
+ * Validate and sanitize file path
15
+ * Prevents path traversal attacks
16
+ */
17
+ export function validatePath(filePath, baseDir) {
18
+ if (!filePath || typeof filePath !== 'string') {
19
+ throw new SecurityError('File path must be a non-empty string', 'INVALID_PATH');
20
+ }
21
+ if (!baseDir || typeof baseDir !== 'string') {
22
+ throw new SecurityError('Base directory must be a non-empty string', 'INVALID_BASE_DIR');
23
+ }
24
+ // Resolve to absolute paths
25
+ const resolvedBase = path.resolve(baseDir);
26
+ const resolvedPath = path.resolve(baseDir, filePath);
27
+ // Calculate relative path
28
+ const relativePath = path.relative(resolvedBase, resolvedPath);
29
+ // Check for path traversal attempts
30
+ if (relativePath.startsWith('..') || path.isAbsolute(relativePath)) {
31
+ throw new SecurityError(`Path traversal attempt detected: ${filePath}`, 'PATH_TRAVERSAL');
32
+ }
33
+ // Additional security checks
34
+ if (filePath.includes('\x00')) {
35
+ throw new SecurityError('Path contains null bytes', 'NULL_BYTE_IN_PATH');
36
+ }
37
+ return resolvedPath;
38
+ }
39
+ /**
40
+ * Check if path is a symbolic link
41
+ */
42
+ export async function isSymbolicLink(filePath) {
43
+ try {
44
+ const stats = await fs.promises.lstat(filePath);
45
+ return stats.isSymbolicLink();
46
+ }
47
+ catch (error) {
48
+ // File doesn't exist
49
+ if (error.code === 'ENOENT') {
50
+ return false;
51
+ }
52
+ throw error;
53
+ }
54
+ }
55
+ /**
56
+ * Secure file write operation
57
+ * Prevents writing to symbolic links and validates paths
58
+ */
59
+ export async function secureWrite(filePath, data, baseDir, options) {
60
+ const safePath = validatePath(filePath, baseDir);
61
+ // Check if file exists and is a symlink
62
+ if (await isSymbolicLink(safePath)) {
63
+ throw new SecurityError('Cannot write to symbolic link', 'SYMLINK_WRITE_DENIED');
64
+ }
65
+ // Check if file exists and overwrite is not allowed
66
+ if (!options?.overwrite) {
67
+ try {
68
+ await fs.promises.access(safePath, fs.constants.F_OK);
69
+ throw new SecurityError('File already exists and overwrite is not allowed', 'FILE_EXISTS');
70
+ }
71
+ catch (error) {
72
+ // File doesn't exist, which is what we want
73
+ if (error.code !== 'ENOENT') {
74
+ throw error;
75
+ }
76
+ }
77
+ }
78
+ // Ensure directory exists
79
+ const dir = path.dirname(safePath);
80
+ await fs.promises.mkdir(dir, { recursive: true });
81
+ // Write file with atomic operation (write to temp, then rename)
82
+ const tempPath = `${safePath}.tmp.${Date.now()}`;
83
+ try {
84
+ if (options?.encoding && typeof data === 'string') {
85
+ await fs.promises.writeFile(tempPath, data, { encoding: options.encoding });
86
+ }
87
+ else {
88
+ await fs.promises.writeFile(tempPath, data);
89
+ }
90
+ // Atomic rename
91
+ await fs.promises.rename(tempPath, safePath);
92
+ }
93
+ catch (error) {
94
+ // Clean up temp file on error
95
+ try {
96
+ await fs.promises.unlink(tempPath);
97
+ }
98
+ catch {
99
+ // Ignore cleanup errors
100
+ }
101
+ throw error;
102
+ }
103
+ }
104
+ /**
105
+ * Secure file read operation
106
+ * Validates paths and prevents symlink attacks
107
+ */
108
+ export async function secureRead(filePath, baseDir, options) {
109
+ const safePath = validatePath(filePath, baseDir);
110
+ // Check for symlinks if not allowed
111
+ if (!options?.followSymlinks && await isSymbolicLink(safePath)) {
112
+ throw new SecurityError('Cannot read symbolic link', 'SYMLINK_READ_DENIED');
113
+ }
114
+ // Verify file exists and is readable
115
+ try {
116
+ await fs.promises.access(safePath, fs.constants.R_OK);
117
+ }
118
+ catch (error) {
119
+ throw new SecurityError(`File not found or not readable: ${path.basename(filePath)}`, 'FILE_NOT_READABLE');
120
+ }
121
+ // Read file
122
+ if (options?.encoding) {
123
+ return await fs.promises.readFile(safePath, { encoding: options.encoding });
124
+ }
125
+ else {
126
+ return await fs.promises.readFile(safePath);
127
+ }
128
+ }
129
+ /**
130
+ * Secure directory listing
131
+ * Prevents path traversal and filters out sensitive files
132
+ */
133
+ export async function secureListDir(dirPath, baseDir, options) {
134
+ const safeDir = validatePath(dirPath, baseDir);
135
+ // Verify directory exists
136
+ try {
137
+ const stats = await fs.promises.stat(safeDir);
138
+ if (!stats.isDirectory()) {
139
+ throw new SecurityError('Path is not a directory', 'NOT_A_DIRECTORY');
140
+ }
141
+ }
142
+ catch (error) {
143
+ if (error.code === 'ENOENT') {
144
+ throw new SecurityError('Directory not found', 'DIRECTORY_NOT_FOUND');
145
+ }
146
+ throw error;
147
+ }
148
+ const entries = await fs.promises.readdir(safeDir, { withFileTypes: true });
149
+ const files = [];
150
+ for (const entry of entries) {
151
+ // Skip dot files unless explicitly included
152
+ if (!options?.includeDotFiles && entry.name.startsWith('.')) {
153
+ continue;
154
+ }
155
+ const fullPath = path.join(dirPath, entry.name);
156
+ if (entry.isFile()) {
157
+ files.push(fullPath);
158
+ }
159
+ else if (entry.isDirectory() && options?.recursive) {
160
+ const subFiles = await secureListDir(fullPath, baseDir, options);
161
+ files.push(...subFiles);
162
+ }
163
+ }
164
+ return files;
165
+ }
166
+ /**
167
+ * Secure file deletion
168
+ * Validates paths and prevents symlink attacks
169
+ */
170
+ export async function secureDelete(filePath, baseDir, options) {
171
+ const safePath = validatePath(filePath, baseDir);
172
+ // Check if file is a symlink
173
+ if (await isSymbolicLink(safePath)) {
174
+ if (!options?.force) {
175
+ throw new SecurityError('Cannot delete symbolic link without force option', 'SYMLINK_DELETE_DENIED');
176
+ }
177
+ // Delete the symlink itself, not the target
178
+ await fs.promises.unlink(safePath);
179
+ return;
180
+ }
181
+ // Delete file
182
+ try {
183
+ await fs.promises.unlink(safePath);
184
+ }
185
+ catch (error) {
186
+ if (error.code === 'ENOENT') {
187
+ // File doesn't exist, which is fine
188
+ return;
189
+ }
190
+ throw error;
191
+ }
192
+ }
193
+ /**
194
+ * Temporary file manager with automatic cleanup
195
+ */
196
+ export class TempFileManager {
197
+ tempFiles = new Set();
198
+ tempDir;
199
+ cleanupScheduled = false;
200
+ constructor(baseDir) {
201
+ this.tempDir = path.join(baseDir, '.tmp');
202
+ }
203
+ /**
204
+ * Initialize temp directory
205
+ */
206
+ async init() {
207
+ await fs.promises.mkdir(this.tempDir, { recursive: true });
208
+ // Schedule cleanup on process exit
209
+ if (!this.cleanupScheduled) {
210
+ process.on('exit', () => this.cleanupSync());
211
+ process.on('SIGINT', () => {
212
+ this.cleanupSync();
213
+ process.exit(0);
214
+ });
215
+ process.on('SIGTERM', () => {
216
+ this.cleanupSync();
217
+ process.exit(0);
218
+ });
219
+ this.cleanupScheduled = true;
220
+ }
221
+ }
222
+ /**
223
+ * Create a temporary file
224
+ */
225
+ async createTempFile(prefix = 'agentdb') {
226
+ await this.init();
227
+ const filename = `${prefix}-${Date.now()}-${Math.random().toString(36).substring(7)}`;
228
+ const tempPath = path.join(this.tempDir, filename);
229
+ this.tempFiles.add(tempPath);
230
+ return tempPath;
231
+ }
232
+ /**
233
+ * Write to temporary file
234
+ */
235
+ async writeTempFile(data, prefix = 'agentdb') {
236
+ const tempPath = await this.createTempFile(prefix);
237
+ await fs.promises.writeFile(tempPath, data);
238
+ return tempPath;
239
+ }
240
+ /**
241
+ * Delete a specific temp file
242
+ */
243
+ async deleteTempFile(tempPath) {
244
+ if (!this.tempFiles.has(tempPath)) {
245
+ throw new SecurityError('File is not managed by this temp file manager', 'NOT_TEMP_FILE');
246
+ }
247
+ try {
248
+ await fs.promises.unlink(tempPath);
249
+ this.tempFiles.delete(tempPath);
250
+ }
251
+ catch (error) {
252
+ if (error.code !== 'ENOENT') {
253
+ throw error;
254
+ }
255
+ }
256
+ }
257
+ /**
258
+ * Clean up all temporary files
259
+ */
260
+ async cleanup() {
261
+ const deletePromises = Array.from(this.tempFiles).map(async (tempPath) => {
262
+ try {
263
+ await fs.promises.unlink(tempPath);
264
+ }
265
+ catch (error) {
266
+ // Ignore errors during cleanup
267
+ console.warn(`Failed to delete temp file: ${tempPath}`, error);
268
+ }
269
+ });
270
+ await Promise.all(deletePromises);
271
+ this.tempFiles.clear();
272
+ // Try to remove temp directory if empty
273
+ try {
274
+ await fs.promises.rmdir(this.tempDir);
275
+ }
276
+ catch {
277
+ // Directory not empty or doesn't exist, which is fine
278
+ }
279
+ }
280
+ /**
281
+ * Synchronous cleanup for process exit
282
+ */
283
+ cleanupSync() {
284
+ for (const tempPath of this.tempFiles) {
285
+ try {
286
+ fs.unlinkSync(tempPath);
287
+ }
288
+ catch {
289
+ // Ignore errors during cleanup
290
+ }
291
+ }
292
+ try {
293
+ fs.rmdirSync(this.tempDir);
294
+ }
295
+ catch {
296
+ // Directory not empty or doesn't exist
297
+ }
298
+ }
299
+ /**
300
+ * Get list of managed temp files
301
+ */
302
+ getTempFiles() {
303
+ return Array.from(this.tempFiles);
304
+ }
305
+ }
306
+ /**
307
+ * Ensure directory exists with safe permissions
308
+ */
309
+ export async function ensureDir(dirPath, baseDir) {
310
+ const safeDir = validatePath(dirPath, baseDir);
311
+ await fs.promises.mkdir(safeDir, {
312
+ recursive: true,
313
+ mode: 0o755, // rwxr-xr-x
314
+ });
315
+ return safeDir;
316
+ }
317
+ /**
318
+ * Get safe file stats without following symlinks
319
+ */
320
+ export async function safeStats(filePath, baseDir) {
321
+ const safePath = validatePath(filePath, baseDir);
322
+ return await fs.promises.lstat(safePath);
323
+ }
324
+ /**
325
+ * Check if path exists within base directory
326
+ */
327
+ export async function pathExists(filePath, baseDir) {
328
+ try {
329
+ const safePath = validatePath(filePath, baseDir);
330
+ await fs.promises.access(safePath, fs.constants.F_OK);
331
+ return true;
332
+ }
333
+ catch {
334
+ return false;
335
+ }
336
+ }
337
+ //# sourceMappingURL=path-security.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"path-security.js","sourceRoot":"","sources":["../../../src/security/path-security.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,95 @@
1
+ /**
2
+ * AgentDB v2 Security Validation
3
+ *
4
+ * Comprehensive input validation for RuVector integration:
5
+ * - Vector dimension and value validation (NaN/Infinity prevention)
6
+ * - ID sanitization (path traversal prevention)
7
+ * - Search options validation (bounds checking)
8
+ * - Cypher query parameter validation (injection prevention)
9
+ * - Metadata sanitization (sensitive data protection)
10
+ */
11
+ /**
12
+ * Security limits for AgentDB v2
13
+ */
14
+ export declare const SECURITY_LIMITS: {
15
+ readonly MAX_VECTORS: 10000000;
16
+ readonly MAX_DIMENSION: 4096;
17
+ readonly MAX_BATCH_SIZE: 10000;
18
+ readonly MAX_K: 10000;
19
+ readonly QUERY_TIMEOUT_MS: 30000;
20
+ readonly MAX_MEMORY_MB: 16384;
21
+ readonly MAX_ID_LENGTH: 256;
22
+ readonly MAX_METADATA_SIZE: 65536;
23
+ readonly MAX_LABEL_LENGTH: 128;
24
+ readonly MAX_PROPERTY_KEY_LENGTH: 128;
25
+ readonly MAX_CYPHER_PARAMS: 100;
26
+ readonly MIN_DIMENSION: 1;
27
+ readonly MIN_K: 1;
28
+ readonly MIN_THRESHOLD: 0;
29
+ readonly MAX_THRESHOLD: 1;
30
+ readonly MIN_EF_SEARCH: 1;
31
+ readonly MAX_EF_SEARCH: 1000;
32
+ readonly MIN_EF_CONSTRUCTION: 4;
33
+ readonly MAX_EF_CONSTRUCTION: 500;
34
+ readonly MAX_M: 64;
35
+ readonly MIN_M: 2;
36
+ };
37
+ /**
38
+ * Validate vector embedding data
39
+ * Prevents NaN, Infinity, and dimension mismatches
40
+ */
41
+ export declare function validateVector(embedding: Float32Array | number[], expectedDim: number, fieldName?: string): void;
42
+ /**
43
+ * Validate vector ID
44
+ * Prevents path traversal, excessive length, and malicious characters
45
+ */
46
+ export declare function validateVectorId(id: string, fieldName?: string): string;
47
+ /**
48
+ * Validate search options
49
+ * Ensures k, threshold, and other parameters are within safe bounds
50
+ */
51
+ export interface SearchOptions {
52
+ k?: number;
53
+ threshold?: number;
54
+ efSearch?: number;
55
+ filter?: Record<string, any>;
56
+ includeMetadata?: boolean;
57
+ includeVectors?: boolean;
58
+ }
59
+ export declare function validateSearchOptions(options: SearchOptions): SearchOptions;
60
+ /**
61
+ * Validate HNSW index parameters
62
+ */
63
+ export interface HNSWParams {
64
+ M?: number;
65
+ efConstruction?: number;
66
+ efSearch?: number;
67
+ }
68
+ export declare function validateHNSWParams(params: HNSWParams): HNSWParams;
69
+ /**
70
+ * Sanitize metadata to prevent sensitive data exposure
71
+ * Removes fields that commonly contain secrets or PII
72
+ */
73
+ export declare function sanitizeMetadata(metadata: Record<string, any>): Record<string, any>;
74
+ /**
75
+ * Validate Cypher query parameters for graph operations
76
+ * Prevents Cypher injection attacks
77
+ */
78
+ export declare function validateCypherParams(params: Record<string, any>): Record<string, any>;
79
+ /**
80
+ * Validate graph node label
81
+ */
82
+ export declare function validateLabel(label: string): string;
83
+ /**
84
+ * Validate batch size for bulk operations
85
+ */
86
+ export declare function validateBatchSize(batchSize: number): number;
87
+ /**
88
+ * Validate vector count doesn't exceed limits
89
+ */
90
+ export declare function validateVectorCount(count: number): void;
91
+ /**
92
+ * Safe logging that doesn't expose vectors or sensitive data
93
+ */
94
+ export declare function safeLog(message: string, data?: any): void;
95
+ //# sourceMappingURL=validation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../../src/security/validation.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAIH;;GAEG;AACH,eAAO,MAAM,eAAe;;;;;;;;;;;;;;;;;;;;;;CAsBlB,CAAC;AAEX;;;GAGG;AACH,wBAAgB,cAAc,CAC5B,SAAS,EAAE,YAAY,GAAG,MAAM,EAAE,EAClC,WAAW,EAAE,MAAM,EACnB,SAAS,GAAE,MAAiB,GAC3B,IAAI,CAiDN;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAAC,EAAE,EAAE,MAAM,EAAE,SAAS,GAAE,MAAa,GAAG,MAAM,CAsD7E;AAED;;;GAGG;AACH,MAAM,WAAW,aAAa;IAC5B,CAAC,CAAC,EAAE,MAAM,CAAC;IACX,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAC7B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,cAAc,CAAC,EAAE,OAAO,CAAC;CAC1B;AAED,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,aAAa,GAAG,aAAa,CAmG3E;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,CAAC,CAAC,EAAE,MAAM,CAAC;IACX,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,wBAAgB,kBAAkB,CAAC,MAAM,EAAE,UAAU,GAAG,UAAU,CAkDjE;AAED;;;GAGG;AACH,wBAAgB,gBAAgB,CAC9B,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAC5B,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAqDrB;AAED;;;GAGG;AACH,wBAAgB,oBAAoB,CAClC,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAC1B,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CA+CrB;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,CAmCnD;AAED;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,MAAM,CAkB3D;AAED;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAQvD;AAED;;GAEG;AACH,wBAAgB,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI,CA0BzD"}