agentdb 1.0.0

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 (361) hide show
  1. package/LICENSE +38 -0
  2. package/LICENSE-APACHE +190 -0
  3. package/LICENSE-MIT +21 -0
  4. package/README.md +953 -0
  5. package/bin/agentdb.js +485 -0
  6. package/bin/plugin-cli-wrapper.mjs +21 -0
  7. package/dist/cache/query-cache.d.ts +105 -0
  8. package/dist/cache/query-cache.d.ts.map +1 -0
  9. package/dist/cache/query-cache.js +224 -0
  10. package/dist/cache/query-cache.js.map +1 -0
  11. package/dist/cache/query-cache.mjs +219 -0
  12. package/dist/cli/cache/query-cache.d.ts +104 -0
  13. package/dist/cli/cache/query-cache.js +244 -0
  14. package/dist/cli/cli/db-commands.d.ts +48 -0
  15. package/dist/cli/cli/db-commands.js +613 -0
  16. package/dist/cli/commands.d.ts +7 -0
  17. package/dist/cli/commands.d.ts.map +1 -0
  18. package/dist/cli/commands.js +113 -0
  19. package/dist/cli/commands.js.map +1 -0
  20. package/dist/cli/commands.mjs +104 -0
  21. package/dist/cli/core/backend-interface.d.ts +70 -0
  22. package/dist/cli/core/backend-interface.js +15 -0
  23. package/dist/cli/core/native-backend.d.ts +140 -0
  24. package/dist/cli/core/native-backend.js +432 -0
  25. package/dist/cli/core/vector-db.d.ts +126 -0
  26. package/dist/cli/core/vector-db.js +338 -0
  27. package/dist/cli/core/wasm-backend.d.ts +95 -0
  28. package/dist/cli/core/wasm-backend.js +418 -0
  29. package/dist/cli/db-commands.d.ts +49 -0
  30. package/dist/cli/db-commands.d.ts.map +1 -0
  31. package/dist/cli/db-commands.js +533 -0
  32. package/dist/cli/db-commands.js.map +1 -0
  33. package/dist/cli/db-commands.mjs +522 -0
  34. package/dist/cli/generator.d.ts +11 -0
  35. package/dist/cli/generator.d.ts.map +1 -0
  36. package/dist/cli/generator.js +567 -0
  37. package/dist/cli/generator.js.map +1 -0
  38. package/dist/cli/generator.mjs +527 -0
  39. package/dist/cli/help.d.ts +18 -0
  40. package/dist/cli/help.d.ts.map +1 -0
  41. package/dist/cli/help.js +676 -0
  42. package/dist/cli/help.js.map +1 -0
  43. package/dist/cli/help.mjs +667 -0
  44. package/dist/cli/index/hnsw.d.ts +164 -0
  45. package/dist/cli/index/hnsw.js +558 -0
  46. package/dist/cli/plugin-cli.d.ts +7 -0
  47. package/dist/cli/plugin-cli.d.ts.map +1 -0
  48. package/dist/cli/plugin-cli.js +295 -0
  49. package/dist/cli/plugin-cli.js.map +1 -0
  50. package/dist/cli/plugin-cli.mjs +289 -0
  51. package/dist/cli/quantization/product-quantization.d.ts +108 -0
  52. package/dist/cli/quantization/product-quantization.js +350 -0
  53. package/dist/cli/query/query-builder.d.ts +322 -0
  54. package/dist/cli/query/query-builder.js +600 -0
  55. package/dist/cli/templates.d.ts +14 -0
  56. package/dist/cli/templates.d.ts.map +1 -0
  57. package/dist/cli/templates.js +182 -0
  58. package/dist/cli/templates.js.map +1 -0
  59. package/dist/cli/templates.mjs +176 -0
  60. package/dist/cli/types/index.d.ts +116 -0
  61. package/dist/cli/types/index.js +5 -0
  62. package/dist/cli/types.d.ts +91 -0
  63. package/dist/cli/types.d.ts.map +1 -0
  64. package/dist/cli/types.js +6 -0
  65. package/dist/cli/types.js.map +1 -0
  66. package/dist/cli/types.mjs +4 -0
  67. package/dist/cli/wizard/index.d.ts +6 -0
  68. package/dist/cli/wizard/index.d.ts.map +1 -0
  69. package/dist/cli/wizard/index.js +138 -0
  70. package/dist/cli/wizard/index.js.map +1 -0
  71. package/dist/cli/wizard/index.mjs +131 -0
  72. package/dist/cli/wizard/prompts.d.ts +11 -0
  73. package/dist/cli/wizard/prompts.d.ts.map +1 -0
  74. package/dist/cli/wizard/prompts.js +482 -0
  75. package/dist/cli/wizard/prompts.js.map +1 -0
  76. package/dist/cli/wizard/prompts.mjs +470 -0
  77. package/dist/cli/wizard/validator.d.ts +13 -0
  78. package/dist/cli/wizard/validator.d.ts.map +1 -0
  79. package/dist/cli/wizard/validator.js +234 -0
  80. package/dist/cli/wizard/validator.js.map +1 -0
  81. package/dist/cli/wizard/validator.mjs +224 -0
  82. package/dist/core/backend-interface.d.ts +71 -0
  83. package/dist/core/backend-interface.d.ts.map +1 -0
  84. package/dist/core/backend-interface.js +16 -0
  85. package/dist/core/backend-interface.js.map +1 -0
  86. package/dist/core/backend-interface.mjs +12 -0
  87. package/dist/core/native-backend.d.ts +141 -0
  88. package/dist/core/native-backend.d.ts.map +1 -0
  89. package/dist/core/native-backend.js +457 -0
  90. package/dist/core/native-backend.js.map +1 -0
  91. package/dist/core/native-backend.mjs +449 -0
  92. package/dist/core/vector-db.d.ts +127 -0
  93. package/dist/core/vector-db.d.ts.map +1 -0
  94. package/dist/core/vector-db.js +266 -0
  95. package/dist/core/vector-db.js.map +1 -0
  96. package/dist/core/vector-db.mjs +261 -0
  97. package/dist/core/wasm-backend.d.ts +96 -0
  98. package/dist/core/wasm-backend.d.ts.map +1 -0
  99. package/dist/core/wasm-backend.js +393 -0
  100. package/dist/core/wasm-backend.js.map +1 -0
  101. package/dist/core/wasm-backend.mjs +385 -0
  102. package/dist/index/hnsw-optimized.d.ts +75 -0
  103. package/dist/index/hnsw-optimized.d.ts.map +1 -0
  104. package/dist/index/hnsw-optimized.js +412 -0
  105. package/dist/index/hnsw-optimized.js.map +1 -0
  106. package/dist/index/hnsw-optimized.mjs +407 -0
  107. package/dist/index/hnsw.d.ts +165 -0
  108. package/dist/index/hnsw.d.ts.map +1 -0
  109. package/dist/index/hnsw.js +521 -0
  110. package/dist/index/hnsw.js.map +1 -0
  111. package/dist/index/hnsw.mjs +516 -0
  112. package/dist/index.d.ts +57 -0
  113. package/dist/index.d.ts.map +1 -0
  114. package/dist/index.js +82 -0
  115. package/dist/index.js.map +1 -0
  116. package/dist/index.mjs +63 -0
  117. package/dist/mcp-server.d.ts +27 -0
  118. package/dist/mcp-server.d.ts.map +1 -0
  119. package/dist/mcp-server.js +789 -0
  120. package/dist/mcp-server.js.map +1 -0
  121. package/dist/mcp-server.mjs +784 -0
  122. package/dist/plugins/base-plugin.d.ts +114 -0
  123. package/dist/plugins/base-plugin.d.ts.map +1 -0
  124. package/dist/plugins/base-plugin.js +313 -0
  125. package/dist/plugins/base-plugin.js.map +1 -0
  126. package/dist/plugins/base-plugin.mjs +275 -0
  127. package/dist/plugins/implementations/active-learning.d.ts +135 -0
  128. package/dist/plugins/implementations/active-learning.d.ts.map +1 -0
  129. package/dist/plugins/implementations/active-learning.js +372 -0
  130. package/dist/plugins/implementations/active-learning.js.map +1 -0
  131. package/dist/plugins/implementations/active-learning.mjs +367 -0
  132. package/dist/plugins/implementations/actor-critic.d.ts +64 -0
  133. package/dist/plugins/implementations/actor-critic.d.ts.map +1 -0
  134. package/dist/plugins/implementations/actor-critic.js +363 -0
  135. package/dist/plugins/implementations/actor-critic.js.map +1 -0
  136. package/dist/plugins/implementations/actor-critic.mjs +358 -0
  137. package/dist/plugins/implementations/adversarial-training.d.ts +133 -0
  138. package/dist/plugins/implementations/adversarial-training.d.ts.map +1 -0
  139. package/dist/plugins/implementations/adversarial-training.js +409 -0
  140. package/dist/plugins/implementations/adversarial-training.js.map +1 -0
  141. package/dist/plugins/implementations/adversarial-training.mjs +404 -0
  142. package/dist/plugins/implementations/curriculum-learning.d.ts +132 -0
  143. package/dist/plugins/implementations/curriculum-learning.d.ts.map +1 -0
  144. package/dist/plugins/implementations/curriculum-learning.js +354 -0
  145. package/dist/plugins/implementations/curriculum-learning.js.map +1 -0
  146. package/dist/plugins/implementations/curriculum-learning.mjs +349 -0
  147. package/dist/plugins/implementations/decision-transformer.d.ts +77 -0
  148. package/dist/plugins/implementations/decision-transformer.d.ts.map +1 -0
  149. package/dist/plugins/implementations/decision-transformer.js +422 -0
  150. package/dist/plugins/implementations/decision-transformer.js.map +1 -0
  151. package/dist/plugins/implementations/decision-transformer.mjs +417 -0
  152. package/dist/plugins/implementations/federated-learning.d.ts +126 -0
  153. package/dist/plugins/implementations/federated-learning.d.ts.map +1 -0
  154. package/dist/plugins/implementations/federated-learning.js +436 -0
  155. package/dist/plugins/implementations/federated-learning.js.map +1 -0
  156. package/dist/plugins/implementations/federated-learning.mjs +431 -0
  157. package/dist/plugins/implementations/index.d.ts +30 -0
  158. package/dist/plugins/implementations/index.d.ts.map +1 -0
  159. package/dist/plugins/implementations/index.js +45 -0
  160. package/dist/plugins/implementations/index.js.map +1 -0
  161. package/dist/plugins/implementations/index.mjs +31 -0
  162. package/dist/plugins/implementations/multi-task-learning.d.ts +115 -0
  163. package/dist/plugins/implementations/multi-task-learning.d.ts.map +1 -0
  164. package/dist/plugins/implementations/multi-task-learning.js +369 -0
  165. package/dist/plugins/implementations/multi-task-learning.js.map +1 -0
  166. package/dist/plugins/implementations/multi-task-learning.mjs +364 -0
  167. package/dist/plugins/implementations/neural-architecture-search.d.ts +148 -0
  168. package/dist/plugins/implementations/neural-architecture-search.d.ts.map +1 -0
  169. package/dist/plugins/implementations/neural-architecture-search.js +379 -0
  170. package/dist/plugins/implementations/neural-architecture-search.js.map +1 -0
  171. package/dist/plugins/implementations/neural-architecture-search.mjs +374 -0
  172. package/dist/plugins/implementations/q-learning.d.ts +98 -0
  173. package/dist/plugins/implementations/q-learning.d.ts.map +1 -0
  174. package/dist/plugins/implementations/q-learning.js +435 -0
  175. package/dist/plugins/implementations/q-learning.js.map +1 -0
  176. package/dist/plugins/implementations/q-learning.mjs +430 -0
  177. package/dist/plugins/implementations/sarsa.d.ts +103 -0
  178. package/dist/plugins/implementations/sarsa.d.ts.map +1 -0
  179. package/dist/plugins/implementations/sarsa.js +347 -0
  180. package/dist/plugins/implementations/sarsa.js.map +1 -0
  181. package/dist/plugins/implementations/sarsa.mjs +342 -0
  182. package/dist/plugins/index.d.ts +107 -0
  183. package/dist/plugins/index.d.ts.map +1 -0
  184. package/dist/plugins/index.js +179 -0
  185. package/dist/plugins/index.js.map +1 -0
  186. package/dist/plugins/index.mjs +168 -0
  187. package/dist/plugins/interface.d.ts +439 -0
  188. package/dist/plugins/interface.d.ts.map +1 -0
  189. package/dist/plugins/interface.js +12 -0
  190. package/dist/plugins/interface.js.map +1 -0
  191. package/dist/plugins/interface.mjs +10 -0
  192. package/dist/plugins/learning-plugin.interface.d.ts +257 -0
  193. package/dist/plugins/learning-plugin.interface.d.ts.map +1 -0
  194. package/dist/plugins/learning-plugin.interface.js +7 -0
  195. package/dist/plugins/learning-plugin.interface.js.map +1 -0
  196. package/dist/plugins/learning-plugin.interface.mjs +5 -0
  197. package/dist/plugins/plugin-exports.d.ts +71 -0
  198. package/dist/plugins/plugin-exports.d.ts.map +1 -0
  199. package/dist/plugins/plugin-exports.js +78 -0
  200. package/dist/plugins/plugin-exports.js.map +1 -0
  201. package/dist/plugins/plugin-exports.mjs +69 -0
  202. package/dist/plugins/registry.d.ts +206 -0
  203. package/dist/plugins/registry.d.ts.map +1 -0
  204. package/dist/plugins/registry.js +365 -0
  205. package/dist/plugins/registry.js.map +1 -0
  206. package/dist/plugins/registry.mjs +356 -0
  207. package/dist/plugins/validator.d.ts +63 -0
  208. package/dist/plugins/validator.d.ts.map +1 -0
  209. package/dist/plugins/validator.js +464 -0
  210. package/dist/plugins/validator.js.map +1 -0
  211. package/dist/plugins/validator.mjs +458 -0
  212. package/dist/quantization/binary-quantization.d.ts +104 -0
  213. package/dist/quantization/binary-quantization.d.ts.map +1 -0
  214. package/dist/quantization/binary-quantization.js +246 -0
  215. package/dist/quantization/binary-quantization.js.map +1 -0
  216. package/dist/quantization/binary-quantization.mjs +240 -0
  217. package/dist/quantization/optimized-pq.d.ts +138 -0
  218. package/dist/quantization/optimized-pq.d.ts.map +1 -0
  219. package/dist/quantization/optimized-pq.js +320 -0
  220. package/dist/quantization/optimized-pq.js.map +1 -0
  221. package/dist/quantization/optimized-pq.mjs +313 -0
  222. package/dist/quantization/product-quantization.d.ts +109 -0
  223. package/dist/quantization/product-quantization.d.ts.map +1 -0
  224. package/dist/quantization/product-quantization.js +287 -0
  225. package/dist/quantization/product-quantization.js.map +1 -0
  226. package/dist/quantization/product-quantization.mjs +282 -0
  227. package/dist/quantization/scalar-quantization.d.ts +100 -0
  228. package/dist/quantization/scalar-quantization.d.ts.map +1 -0
  229. package/dist/quantization/scalar-quantization.js +324 -0
  230. package/dist/quantization/scalar-quantization.js.map +1 -0
  231. package/dist/quantization/scalar-quantization.mjs +319 -0
  232. package/dist/query/index.d.ts +6 -0
  233. package/dist/query/index.d.ts.map +1 -0
  234. package/dist/query/index.js +9 -0
  235. package/dist/query/index.js.map +1 -0
  236. package/dist/query/index.mjs +4 -0
  237. package/dist/query/query-builder.d.ts +323 -0
  238. package/dist/query/query-builder.d.ts.map +1 -0
  239. package/dist/query/query-builder.js +524 -0
  240. package/dist/query/query-builder.js.map +1 -0
  241. package/dist/query/query-builder.mjs +519 -0
  242. package/dist/reasoning/context-synthesizer.d.ts +57 -0
  243. package/dist/reasoning/context-synthesizer.d.ts.map +1 -0
  244. package/dist/reasoning/context-synthesizer.js +224 -0
  245. package/dist/reasoning/context-synthesizer.js.map +1 -0
  246. package/dist/reasoning/context-synthesizer.mjs +219 -0
  247. package/dist/reasoning/experience-curator.d.ts +66 -0
  248. package/dist/reasoning/experience-curator.d.ts.map +1 -0
  249. package/dist/reasoning/experience-curator.js +288 -0
  250. package/dist/reasoning/experience-curator.js.map +1 -0
  251. package/dist/reasoning/experience-curator.mjs +283 -0
  252. package/dist/reasoning/memory-optimizer.d.ts +69 -0
  253. package/dist/reasoning/memory-optimizer.d.ts.map +1 -0
  254. package/dist/reasoning/memory-optimizer.js +331 -0
  255. package/dist/reasoning/memory-optimizer.js.map +1 -0
  256. package/dist/reasoning/memory-optimizer.mjs +326 -0
  257. package/dist/reasoning/pattern-matcher.d.ts +59 -0
  258. package/dist/reasoning/pattern-matcher.d.ts.map +1 -0
  259. package/dist/reasoning/pattern-matcher.js +229 -0
  260. package/dist/reasoning/pattern-matcher.js.map +1 -0
  261. package/dist/reasoning/pattern-matcher.mjs +224 -0
  262. package/dist/reasoningbank/adapter/agentdb-adapter.d.ts +118 -0
  263. package/dist/reasoningbank/adapter/agentdb-adapter.d.ts.map +1 -0
  264. package/dist/reasoningbank/adapter/agentdb-adapter.js +477 -0
  265. package/dist/reasoningbank/adapter/agentdb-adapter.js.map +1 -0
  266. package/dist/reasoningbank/adapter/types.d.ts +113 -0
  267. package/dist/reasoningbank/adapter/types.d.ts.map +1 -0
  268. package/dist/reasoningbank/adapter/types.js +9 -0
  269. package/dist/reasoningbank/adapter/types.js.map +1 -0
  270. package/dist/reasoningbank/cli/commands.d.ts +16 -0
  271. package/dist/reasoningbank/cli/commands.d.ts.map +1 -0
  272. package/dist/reasoningbank/cli/commands.js +272 -0
  273. package/dist/reasoningbank/cli/commands.js.map +1 -0
  274. package/dist/reasoningbank/mcp/agentdb-tools.d.ts +319 -0
  275. package/dist/reasoningbank/mcp/agentdb-tools.d.ts.map +1 -0
  276. package/dist/reasoningbank/mcp/agentdb-tools.js +301 -0
  277. package/dist/reasoningbank/mcp/agentdb-tools.js.map +1 -0
  278. package/dist/reasoningbank/migration/migrate.d.ts +25 -0
  279. package/dist/reasoningbank/migration/migrate.d.ts.map +1 -0
  280. package/dist/reasoningbank/migration/migrate.js +178 -0
  281. package/dist/reasoningbank/migration/migrate.js.map +1 -0
  282. package/dist/reasoningbank/reasoning/context-synthesizer.d.ts +37 -0
  283. package/dist/reasoningbank/reasoning/context-synthesizer.d.ts.map +1 -0
  284. package/dist/reasoningbank/reasoning/context-synthesizer.js +114 -0
  285. package/dist/reasoningbank/reasoning/context-synthesizer.js.map +1 -0
  286. package/dist/reasoningbank/reasoning/experience-curator.d.ts +39 -0
  287. package/dist/reasoningbank/reasoning/experience-curator.d.ts.map +1 -0
  288. package/dist/reasoningbank/reasoning/experience-curator.js +98 -0
  289. package/dist/reasoningbank/reasoning/experience-curator.js.map +1 -0
  290. package/dist/reasoningbank/reasoning/memory-optimizer.d.ts +44 -0
  291. package/dist/reasoningbank/reasoning/memory-optimizer.d.ts.map +1 -0
  292. package/dist/reasoningbank/reasoning/memory-optimizer.js +184 -0
  293. package/dist/reasoningbank/reasoning/memory-optimizer.js.map +1 -0
  294. package/dist/reasoningbank/reasoning/pattern-matcher.d.ts +40 -0
  295. package/dist/reasoningbank/reasoning/pattern-matcher.d.ts.map +1 -0
  296. package/dist/reasoningbank/reasoning/pattern-matcher.js +87 -0
  297. package/dist/reasoningbank/reasoning/pattern-matcher.js.map +1 -0
  298. package/dist/reasoningbank/sync/quic-sync.d.ts +77 -0
  299. package/dist/reasoningbank/sync/quic-sync.d.ts.map +1 -0
  300. package/dist/reasoningbank/sync/quic-sync.js +165 -0
  301. package/dist/reasoningbank/sync/quic-sync.js.map +1 -0
  302. package/dist/sync/conflict.d.ts +78 -0
  303. package/dist/sync/conflict.d.ts.map +1 -0
  304. package/dist/sync/conflict.js +202 -0
  305. package/dist/sync/conflict.js.map +1 -0
  306. package/dist/sync/conflict.mjs +196 -0
  307. package/dist/sync/coordinator.d.ts +111 -0
  308. package/dist/sync/coordinator.d.ts.map +1 -0
  309. package/dist/sync/coordinator.js +256 -0
  310. package/dist/sync/coordinator.js.map +1 -0
  311. package/dist/sync/coordinator.mjs +250 -0
  312. package/dist/sync/delta.d.ts +81 -0
  313. package/dist/sync/delta.d.ts.map +1 -0
  314. package/dist/sync/delta.js +245 -0
  315. package/dist/sync/delta.js.map +1 -0
  316. package/dist/sync/delta.mjs +238 -0
  317. package/dist/sync/index.d.ts +11 -0
  318. package/dist/sync/index.d.ts.map +1 -0
  319. package/dist/sync/index.js +22 -0
  320. package/dist/sync/index.js.map +1 -0
  321. package/dist/sync/index.mjs +9 -0
  322. package/dist/sync/quic-sync.d.ts +81 -0
  323. package/dist/sync/quic-sync.d.ts.map +1 -0
  324. package/dist/sync/quic-sync.js +329 -0
  325. package/dist/sync/quic-sync.js.map +1 -0
  326. package/dist/sync/quic-sync.mjs +323 -0
  327. package/dist/sync/types.d.ts +168 -0
  328. package/dist/sync/types.d.ts.map +1 -0
  329. package/dist/sync/types.js +8 -0
  330. package/dist/sync/types.js.map +1 -0
  331. package/dist/sync/types.mjs +6 -0
  332. package/dist/types/index.d.ts +117 -0
  333. package/dist/types/index.d.ts.map +1 -0
  334. package/dist/types/index.js +6 -0
  335. package/dist/types/index.js.map +1 -0
  336. package/dist/types/index.mjs +4 -0
  337. package/dist/wasm-loader.d.ts +32 -0
  338. package/dist/wasm-loader.d.ts.map +1 -0
  339. package/dist/wasm-loader.js +75 -0
  340. package/dist/wasm-loader.js.map +1 -0
  341. package/dist/wasm-loader.mjs +64 -0
  342. package/examples/adaptive-learning.ts +284 -0
  343. package/examples/browser/README.md +732 -0
  344. package/examples/browser/adaptive-recommendations/index.html +427 -0
  345. package/examples/browser/collaborative-filtering/index.html +310 -0
  346. package/examples/browser/continual-learning/index.html +736 -0
  347. package/examples/browser/experience-replay/index.html +616 -0
  348. package/examples/browser/index.html +369 -0
  349. package/examples/browser/meta-learning/index.html +789 -0
  350. package/examples/browser/neuro-symbolic/index.html +692 -0
  351. package/examples/browser/pattern-learning/index.html +620 -0
  352. package/examples/browser/quantum-inspired/index.html +728 -0
  353. package/examples/browser/rag/index.html +624 -0
  354. package/examples/browser/swarm-intelligence/index.html +811 -0
  355. package/examples/browser-basic.html +170 -0
  356. package/examples/hnsw-example.ts +148 -0
  357. package/examples/node-basic.js +70 -0
  358. package/examples/quic-sync-example.ts +310 -0
  359. package/examples/quick-start.js +68 -0
  360. package/examples/wasm-example.ts +222 -0
  361. package/package.json +118 -0
@@ -0,0 +1,329 @@
1
+ "use strict";
2
+ /**
3
+ * SQLiteVector QUIC Sync - Main Synchronization Layer
4
+ *
5
+ * Real-time shard synchronization using QUIC transport from agentic-flow
6
+ */
7
+ Object.defineProperty(exports, "__esModule", { value: true });
8
+ exports.VectorQuicSync = void 0;
9
+ exports.createVectorSync = createVectorSync;
10
+ class QuicTransport {
11
+ static async create(config) {
12
+ throw new Error('QUIC transport not available - install @agentic-flow/core or set up local QUIC server');
13
+ }
14
+ async send(address, message) {
15
+ throw new Error('QUIC transport not available');
16
+ }
17
+ async receive(address) {
18
+ throw new Error('QUIC transport not available');
19
+ }
20
+ async request(address, message) {
21
+ await this.send(address, message);
22
+ return this.receive(address);
23
+ }
24
+ async getStats() {
25
+ return { active: 0, idle: 0, created: 0, closed: 0 };
26
+ }
27
+ async close() { }
28
+ }
29
+ const delta_1 = require("./delta");
30
+ const conflict_1 = require("./conflict");
31
+ /**
32
+ * QUIC-based vector database synchronization
33
+ */
34
+ class VectorQuicSync {
35
+ constructor(db, nodeId, config = {}) {
36
+ this.session = null;
37
+ this.syncTimers = new Map();
38
+ this.nodeId = nodeId;
39
+ this.changelogReader = new delta_1.ChangelogReader(db);
40
+ this.conflictTracker = new conflict_1.ConflictTracker();
41
+ // Default configuration
42
+ this.config = {
43
+ conflictStrategy: config.conflictStrategy || 'last-write-wins',
44
+ batchSize: config.batchSize || 100,
45
+ compression: config.compression ?? true,
46
+ syncIntervalMs: config.syncIntervalMs || 0,
47
+ maxRetries: config.maxRetries || 3,
48
+ retryBackoffMs: config.retryBackoffMs || 1000,
49
+ persistSession: config.persistSession ?? true
50
+ };
51
+ this.conflictResolver = new conflict_1.ConflictResolver(this.config.conflictStrategy);
52
+ }
53
+ /**
54
+ * Initialize QUIC transport and sync session
55
+ */
56
+ async initialize(quicConfig) {
57
+ // Create QUIC transport
58
+ this.transport = await QuicTransport.create({
59
+ serverName: quicConfig?.serverName || 'vector-sync',
60
+ maxIdleTimeoutMs: quicConfig?.maxIdleTimeoutMs || 60000,
61
+ maxConcurrentStreams: quicConfig?.maxConcurrentStreams || 100,
62
+ enable0Rtt: quicConfig?.enable0Rtt ?? true
63
+ });
64
+ // Restore or create session
65
+ if (this.config.persistSession) {
66
+ await this.restoreSession();
67
+ }
68
+ if (!this.session) {
69
+ this.session = {
70
+ id: `session-${this.nodeId}-${Date.now()}`,
71
+ nodeId: this.nodeId,
72
+ shardIds: [],
73
+ lastChangeIds: new Map(),
74
+ versionVectors: new Map(),
75
+ pendingConflicts: [],
76
+ createdAt: Date.now() * 1000,
77
+ updatedAt: Date.now() * 1000
78
+ };
79
+ }
80
+ }
81
+ /**
82
+ * Synchronize shard with remote peer
83
+ */
84
+ async sync(shardId, peerAddress, force = false) {
85
+ const startTime = Date.now();
86
+ try {
87
+ // Add shard to session
88
+ if (!this.session.shardIds.includes(shardId)) {
89
+ this.session.shardIds.push(shardId);
90
+ }
91
+ // Get local state
92
+ const lastChangeId = this.session.lastChangeIds.get(shardId) || 0;
93
+ const localChangeId = await this.changelogReader.getLatestChangeId(shardId);
94
+ // Check if sync needed
95
+ if (!force && lastChangeId === localChangeId) {
96
+ return {
97
+ shardId,
98
+ changesApplied: 0,
99
+ conflictsDetected: 0,
100
+ conflictsResolved: 0,
101
+ conflictsUnresolved: [],
102
+ durationMs: Date.now() - startTime,
103
+ success: true
104
+ };
105
+ }
106
+ // Read local changes
107
+ const localChanges = await this.changelogReader.readChanges(shardId, lastChangeId);
108
+ // Request remote changes
109
+ const remoteChanges = await this.requestRemoteChanges(peerAddress, shardId, lastChangeId);
110
+ // Send local changes
111
+ if (localChanges.length > 0) {
112
+ await this.sendLocalChanges(peerAddress, shardId, localChanges);
113
+ }
114
+ // Resolve conflicts and apply changes
115
+ const { resolved, conflicts } = this.conflictResolver.resolveAll(localChanges, remoteChanges);
116
+ // Apply resolved changes
117
+ const applied = await this.applyChanges(shardId, resolved);
118
+ // Track unresolved conflicts
119
+ for (const conflict of conflicts) {
120
+ this.conflictTracker.addConflict(conflict);
121
+ }
122
+ // Update session
123
+ this.session.lastChangeIds.set(shardId, localChangeId);
124
+ const versionVector = await this.changelogReader.getVersionVector(shardId);
125
+ this.session.versionVectors.set(shardId, versionVector);
126
+ this.session.updatedAt = Date.now() * 1000;
127
+ if (this.config.persistSession) {
128
+ await this.saveSession();
129
+ }
130
+ return {
131
+ shardId,
132
+ changesApplied: applied,
133
+ conflictsDetected: conflicts.length,
134
+ conflictsResolved: conflicts.length,
135
+ conflictsUnresolved: this.conflictTracker.getForShard(shardId),
136
+ durationMs: Date.now() - startTime,
137
+ success: true
138
+ };
139
+ }
140
+ catch (error) {
141
+ return {
142
+ shardId,
143
+ changesApplied: 0,
144
+ conflictsDetected: 0,
145
+ conflictsResolved: 0,
146
+ conflictsUnresolved: [],
147
+ durationMs: Date.now() - startTime,
148
+ success: false,
149
+ error: error instanceof Error ? error.message : String(error)
150
+ };
151
+ }
152
+ }
153
+ /**
154
+ * Request remote changes from peer
155
+ */
156
+ async requestRemoteChanges(peerAddress, shardId, fromChangeId) {
157
+ const message = {
158
+ id: `sync-request-${Date.now()}`,
159
+ type: 'sync-request',
160
+ payload: {
161
+ shardId,
162
+ fromChangeId,
163
+ nodeId: this.nodeId
164
+ }
165
+ };
166
+ // Send request via QUIC
167
+ const response = await this.transport.request(peerAddress, message);
168
+ if (response.type === 'sync-response') {
169
+ const deltaBytes = new Uint8Array(response.payload.delta);
170
+ const delta = delta_1.DeltaEncoder.deserialize(deltaBytes);
171
+ return delta_1.DeltaEncoder.decode(delta);
172
+ }
173
+ return [];
174
+ }
175
+ /**
176
+ * Send local changes to peer
177
+ */
178
+ async sendLocalChanges(peerAddress, shardId, changes) {
179
+ // Batch changes
180
+ const batches = delta_1.DeltaEncoder.batch(changes, this.config.batchSize);
181
+ for (const batch of batches) {
182
+ const delta = delta_1.DeltaEncoder.encode(shardId, batch, this.config.compression ? 'msgpack' : 'none');
183
+ const deltaBytes = delta_1.DeltaEncoder.serialize(delta);
184
+ const message = {
185
+ id: `sync-push-${Date.now()}`,
186
+ type: 'sync-push',
187
+ payload: {
188
+ shardId,
189
+ delta: Array.from(deltaBytes),
190
+ nodeId: this.nodeId
191
+ }
192
+ };
193
+ await this.transport.send(peerAddress, message);
194
+ }
195
+ }
196
+ /**
197
+ * Apply changes to local database
198
+ */
199
+ async applyChanges(shardId, changes) {
200
+ let applied = 0;
201
+ for (const change of changes) {
202
+ // Skip changes from this node
203
+ if (change.sourceNode === this.nodeId) {
204
+ continue;
205
+ }
206
+ // Apply based on operation type
207
+ switch (change.operation) {
208
+ case 'insert':
209
+ case 'update':
210
+ // Implementation would insert/update vector in database
211
+ applied++;
212
+ break;
213
+ case 'delete':
214
+ // Implementation would delete vector from database
215
+ applied++;
216
+ break;
217
+ }
218
+ }
219
+ return applied;
220
+ }
221
+ /**
222
+ * Start automatic periodic sync
223
+ */
224
+ startAutoSync(shardId, peerAddress) {
225
+ if (this.config.syncIntervalMs === 0) {
226
+ throw new Error('syncIntervalMs must be > 0 for auto-sync');
227
+ }
228
+ // Clear existing timer
229
+ this.stopAutoSync(shardId);
230
+ // Start periodic sync
231
+ const timer = setInterval(async () => {
232
+ await this.sync(shardId, peerAddress);
233
+ }, this.config.syncIntervalMs);
234
+ this.syncTimers.set(shardId, timer);
235
+ }
236
+ /**
237
+ * Stop automatic sync for shard
238
+ */
239
+ stopAutoSync(shardId) {
240
+ const timer = this.syncTimers.get(shardId);
241
+ if (timer) {
242
+ clearInterval(timer);
243
+ this.syncTimers.delete(shardId);
244
+ }
245
+ }
246
+ /**
247
+ * Stop all automatic syncs
248
+ */
249
+ stopAllAutoSyncs() {
250
+ for (const shardId of this.syncTimers.keys()) {
251
+ this.stopAutoSync(shardId);
252
+ }
253
+ }
254
+ /**
255
+ * Get current session
256
+ */
257
+ getSession() {
258
+ return this.session;
259
+ }
260
+ /**
261
+ * Get shard state
262
+ */
263
+ async getShardState(shardId) {
264
+ const currentChangeId = await this.changelogReader.getLatestChangeId(shardId);
265
+ const versionVector = await this.changelogReader.getVersionVector(shardId);
266
+ const lastSyncAt = this.session?.lastChangeIds.get(shardId) || 0;
267
+ return {
268
+ shardId,
269
+ currentChangeId,
270
+ versionVector,
271
+ vectorCount: 0, // Would query actual count
272
+ lastSyncAt,
273
+ status: 'idle'
274
+ };
275
+ }
276
+ /**
277
+ * Get unresolved conflicts
278
+ */
279
+ getUnresolvedConflicts(shardId) {
280
+ return shardId
281
+ ? this.conflictTracker.getForShard(shardId)
282
+ : this.conflictTracker.getUnresolved();
283
+ }
284
+ /**
285
+ * Save session to persistent storage
286
+ */
287
+ async saveSession() {
288
+ if (!this.session)
289
+ return;
290
+ // Serialize session
291
+ const sessionData = {
292
+ ...this.session,
293
+ lastChangeIds: Object.fromEntries(this.session.lastChangeIds),
294
+ versionVectors: Object.fromEntries(Array.from(this.session.versionVectors.entries()).map(([k, v]) => [
295
+ k,
296
+ Object.fromEntries(v)
297
+ ]))
298
+ };
299
+ // Save to database or file
300
+ // Implementation depends on storage backend
301
+ }
302
+ /**
303
+ * Restore session from persistent storage
304
+ */
305
+ async restoreSession() {
306
+ // Load from database or file
307
+ // Implementation depends on storage backend
308
+ }
309
+ /**
310
+ * Close sync and cleanup resources
311
+ */
312
+ async close() {
313
+ this.stopAllAutoSyncs();
314
+ if (this.config.persistSession && this.session) {
315
+ await this.saveSession();
316
+ }
317
+ await this.transport.close();
318
+ }
319
+ }
320
+ exports.VectorQuicSync = VectorQuicSync;
321
+ /**
322
+ * Create VectorQuicSync instance with convenience wrapper
323
+ */
324
+ async function createVectorSync(db, nodeId, config, quicConfig) {
325
+ const sync = new VectorQuicSync(db, nodeId, config);
326
+ await sync.initialize(quicConfig);
327
+ return sync;
328
+ }
329
+ //# sourceMappingURL=quic-sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"quic-sync.js","sourceRoot":"","sources":["../../src/sync/quic-sync.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,323 @@
1
+ /**
2
+ * SQLiteVector QUIC Sync - Main Synchronization Layer
3
+ *
4
+ * Real-time shard synchronization using QUIC transport from agentic-flow
5
+ */
6
+ class QuicTransport {
7
+ static async create(config) {
8
+ throw new Error('QUIC transport not available - install @agentic-flow/core or set up local QUIC server');
9
+ }
10
+ async send(address, message) {
11
+ throw new Error('QUIC transport not available');
12
+ }
13
+ async receive(address) {
14
+ throw new Error('QUIC transport not available');
15
+ }
16
+ async request(address, message) {
17
+ await this.send(address, message);
18
+ return this.receive(address);
19
+ }
20
+ async getStats() {
21
+ return { active: 0, idle: 0, created: 0, closed: 0 };
22
+ }
23
+ async close() { }
24
+ }
25
+ import { DeltaEncoder, ChangelogReader } from './delta.mjs';
26
+ import { ConflictResolver, ConflictTracker } from './conflict.mjs';
27
+ /**
28
+ * QUIC-based vector database synchronization
29
+ */
30
+ export class VectorQuicSync {
31
+ constructor(db, nodeId, config = {}) {
32
+ this.session = null;
33
+ this.syncTimers = new Map();
34
+ this.nodeId = nodeId;
35
+ this.changelogReader = new ChangelogReader(db);
36
+ this.conflictTracker = new ConflictTracker();
37
+ // Default configuration
38
+ this.config = {
39
+ conflictStrategy: config.conflictStrategy || 'last-write-wins',
40
+ batchSize: config.batchSize || 100,
41
+ compression: config.compression ?? true,
42
+ syncIntervalMs: config.syncIntervalMs || 0,
43
+ maxRetries: config.maxRetries || 3,
44
+ retryBackoffMs: config.retryBackoffMs || 1000,
45
+ persistSession: config.persistSession ?? true
46
+ };
47
+ this.conflictResolver = new ConflictResolver(this.config.conflictStrategy);
48
+ }
49
+ /**
50
+ * Initialize QUIC transport and sync session
51
+ */
52
+ async initialize(quicConfig) {
53
+ // Create QUIC transport
54
+ this.transport = await QuicTransport.create({
55
+ serverName: quicConfig?.serverName || 'vector-sync',
56
+ maxIdleTimeoutMs: quicConfig?.maxIdleTimeoutMs || 60000,
57
+ maxConcurrentStreams: quicConfig?.maxConcurrentStreams || 100,
58
+ enable0Rtt: quicConfig?.enable0Rtt ?? true
59
+ });
60
+ // Restore or create session
61
+ if (this.config.persistSession) {
62
+ await this.restoreSession();
63
+ }
64
+ if (!this.session) {
65
+ this.session = {
66
+ id: `session-${this.nodeId}-${Date.now()}`,
67
+ nodeId: this.nodeId,
68
+ shardIds: [],
69
+ lastChangeIds: new Map(),
70
+ versionVectors: new Map(),
71
+ pendingConflicts: [],
72
+ createdAt: Date.now() * 1000,
73
+ updatedAt: Date.now() * 1000
74
+ };
75
+ }
76
+ }
77
+ /**
78
+ * Synchronize shard with remote peer
79
+ */
80
+ async sync(shardId, peerAddress, force = false) {
81
+ const startTime = Date.now();
82
+ try {
83
+ // Add shard to session
84
+ if (!this.session.shardIds.includes(shardId)) {
85
+ this.session.shardIds.push(shardId);
86
+ }
87
+ // Get local state
88
+ const lastChangeId = this.session.lastChangeIds.get(shardId) || 0;
89
+ const localChangeId = await this.changelogReader.getLatestChangeId(shardId);
90
+ // Check if sync needed
91
+ if (!force && lastChangeId === localChangeId) {
92
+ return {
93
+ shardId,
94
+ changesApplied: 0,
95
+ conflictsDetected: 0,
96
+ conflictsResolved: 0,
97
+ conflictsUnresolved: [],
98
+ durationMs: Date.now() - startTime,
99
+ success: true
100
+ };
101
+ }
102
+ // Read local changes
103
+ const localChanges = await this.changelogReader.readChanges(shardId, lastChangeId);
104
+ // Request remote changes
105
+ const remoteChanges = await this.requestRemoteChanges(peerAddress, shardId, lastChangeId);
106
+ // Send local changes
107
+ if (localChanges.length > 0) {
108
+ await this.sendLocalChanges(peerAddress, shardId, localChanges);
109
+ }
110
+ // Resolve conflicts and apply changes
111
+ const { resolved, conflicts } = this.conflictResolver.resolveAll(localChanges, remoteChanges);
112
+ // Apply resolved changes
113
+ const applied = await this.applyChanges(shardId, resolved);
114
+ // Track unresolved conflicts
115
+ for (const conflict of conflicts) {
116
+ this.conflictTracker.addConflict(conflict);
117
+ }
118
+ // Update session
119
+ this.session.lastChangeIds.set(shardId, localChangeId);
120
+ const versionVector = await this.changelogReader.getVersionVector(shardId);
121
+ this.session.versionVectors.set(shardId, versionVector);
122
+ this.session.updatedAt = Date.now() * 1000;
123
+ if (this.config.persistSession) {
124
+ await this.saveSession();
125
+ }
126
+ return {
127
+ shardId,
128
+ changesApplied: applied,
129
+ conflictsDetected: conflicts.length,
130
+ conflictsResolved: conflicts.length,
131
+ conflictsUnresolved: this.conflictTracker.getForShard(shardId),
132
+ durationMs: Date.now() - startTime,
133
+ success: true
134
+ };
135
+ }
136
+ catch (error) {
137
+ return {
138
+ shardId,
139
+ changesApplied: 0,
140
+ conflictsDetected: 0,
141
+ conflictsResolved: 0,
142
+ conflictsUnresolved: [],
143
+ durationMs: Date.now() - startTime,
144
+ success: false,
145
+ error: error instanceof Error ? error.message : String(error)
146
+ };
147
+ }
148
+ }
149
+ /**
150
+ * Request remote changes from peer
151
+ */
152
+ async requestRemoteChanges(peerAddress, shardId, fromChangeId) {
153
+ const message = {
154
+ id: `sync-request-${Date.now()}`,
155
+ type: 'sync-request',
156
+ payload: {
157
+ shardId,
158
+ fromChangeId,
159
+ nodeId: this.nodeId
160
+ }
161
+ };
162
+ // Send request via QUIC
163
+ const response = await this.transport.request(peerAddress, message);
164
+ if (response.type === 'sync-response') {
165
+ const deltaBytes = new Uint8Array(response.payload.delta);
166
+ const delta = DeltaEncoder.deserialize(deltaBytes);
167
+ return DeltaEncoder.decode(delta);
168
+ }
169
+ return [];
170
+ }
171
+ /**
172
+ * Send local changes to peer
173
+ */
174
+ async sendLocalChanges(peerAddress, shardId, changes) {
175
+ // Batch changes
176
+ const batches = DeltaEncoder.batch(changes, this.config.batchSize);
177
+ for (const batch of batches) {
178
+ const delta = DeltaEncoder.encode(shardId, batch, this.config.compression ? 'msgpack' : 'none');
179
+ const deltaBytes = DeltaEncoder.serialize(delta);
180
+ const message = {
181
+ id: `sync-push-${Date.now()}`,
182
+ type: 'sync-push',
183
+ payload: {
184
+ shardId,
185
+ delta: Array.from(deltaBytes),
186
+ nodeId: this.nodeId
187
+ }
188
+ };
189
+ await this.transport.send(peerAddress, message);
190
+ }
191
+ }
192
+ /**
193
+ * Apply changes to local database
194
+ */
195
+ async applyChanges(shardId, changes) {
196
+ let applied = 0;
197
+ for (const change of changes) {
198
+ // Skip changes from this node
199
+ if (change.sourceNode === this.nodeId) {
200
+ continue;
201
+ }
202
+ // Apply based on operation type
203
+ switch (change.operation) {
204
+ case 'insert':
205
+ case 'update':
206
+ // Implementation would insert/update vector in database
207
+ applied++;
208
+ break;
209
+ case 'delete':
210
+ // Implementation would delete vector from database
211
+ applied++;
212
+ break;
213
+ }
214
+ }
215
+ return applied;
216
+ }
217
+ /**
218
+ * Start automatic periodic sync
219
+ */
220
+ startAutoSync(shardId, peerAddress) {
221
+ if (this.config.syncIntervalMs === 0) {
222
+ throw new Error('syncIntervalMs must be > 0 for auto-sync');
223
+ }
224
+ // Clear existing timer
225
+ this.stopAutoSync(shardId);
226
+ // Start periodic sync
227
+ const timer = setInterval(async () => {
228
+ await this.sync(shardId, peerAddress);
229
+ }, this.config.syncIntervalMs);
230
+ this.syncTimers.set(shardId, timer);
231
+ }
232
+ /**
233
+ * Stop automatic sync for shard
234
+ */
235
+ stopAutoSync(shardId) {
236
+ const timer = this.syncTimers.get(shardId);
237
+ if (timer) {
238
+ clearInterval(timer);
239
+ this.syncTimers.delete(shardId);
240
+ }
241
+ }
242
+ /**
243
+ * Stop all automatic syncs
244
+ */
245
+ stopAllAutoSyncs() {
246
+ for (const shardId of this.syncTimers.keys()) {
247
+ this.stopAutoSync(shardId);
248
+ }
249
+ }
250
+ /**
251
+ * Get current session
252
+ */
253
+ getSession() {
254
+ return this.session;
255
+ }
256
+ /**
257
+ * Get shard state
258
+ */
259
+ async getShardState(shardId) {
260
+ const currentChangeId = await this.changelogReader.getLatestChangeId(shardId);
261
+ const versionVector = await this.changelogReader.getVersionVector(shardId);
262
+ const lastSyncAt = this.session?.lastChangeIds.get(shardId) || 0;
263
+ return {
264
+ shardId,
265
+ currentChangeId,
266
+ versionVector,
267
+ vectorCount: 0, // Would query actual count
268
+ lastSyncAt,
269
+ status: 'idle'
270
+ };
271
+ }
272
+ /**
273
+ * Get unresolved conflicts
274
+ */
275
+ getUnresolvedConflicts(shardId) {
276
+ return shardId
277
+ ? this.conflictTracker.getForShard(shardId)
278
+ : this.conflictTracker.getUnresolved();
279
+ }
280
+ /**
281
+ * Save session to persistent storage
282
+ */
283
+ async saveSession() {
284
+ if (!this.session)
285
+ return;
286
+ // Serialize session
287
+ const sessionData = {
288
+ ...this.session,
289
+ lastChangeIds: Object.fromEntries(this.session.lastChangeIds),
290
+ versionVectors: Object.fromEntries(Array.from(this.session.versionVectors.entries()).map(([k, v]) => [
291
+ k,
292
+ Object.fromEntries(v)
293
+ ]))
294
+ };
295
+ // Save to database or file
296
+ // Implementation depends on storage backend
297
+ }
298
+ /**
299
+ * Restore session from persistent storage
300
+ */
301
+ async restoreSession() {
302
+ // Load from database or file
303
+ // Implementation depends on storage backend
304
+ }
305
+ /**
306
+ * Close sync and cleanup resources
307
+ */
308
+ async close() {
309
+ this.stopAllAutoSyncs();
310
+ if (this.config.persistSession && this.session) {
311
+ await this.saveSession();
312
+ }
313
+ await this.transport.close();
314
+ }
315
+ }
316
+ /**
317
+ * Create VectorQuicSync instance with convenience wrapper
318
+ */
319
+ export async function createVectorSync(db, nodeId, config, quicConfig) {
320
+ const sync = new VectorQuicSync(db, nodeId, config);
321
+ await sync.initialize(quicConfig);
322
+ return sync;
323
+ }