@rocicorp/zero 0.0.2024100800 → 0.0.202410040736

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 (849) hide show
  1. package/package.json +6 -8
  2. package/out/btree/b+tree.d.ts +0 -471
  3. package/out/btree/b+tree.d.ts.map +0 -1
  4. package/out/btree/b+tree.js +0 -1708
  5. package/out/btree/b+tree.js.map +0 -1
  6. package/out/btree/interfaces.d.ts +0 -270
  7. package/out/btree/interfaces.d.ts.map +0 -1
  8. package/out/btree/interfaces.js +0 -3
  9. package/out/btree/interfaces.js.map +0 -1
  10. package/out/btree/src/mod.d.ts +0 -2
  11. package/out/btree/src/mod.d.ts.map +0 -1
  12. package/out/btree/src/mod.js +0 -2
  13. package/out/btree/src/mod.js.map +0 -1
  14. package/out/chunk-2RUT5EQV.js +0 -28
  15. package/out/chunk-2RUT5EQV.js.map +0 -7
  16. package/out/datadog/src/datadog-log-sink.d.ts +0 -20
  17. package/out/datadog/src/datadog-log-sink.d.ts.map +0 -1
  18. package/out/datadog/src/datadog-log-sink.js +0 -231
  19. package/out/datadog/src/datadog-log-sink.js.map +0 -1
  20. package/out/datadog/src/mod.d.ts +0 -2
  21. package/out/datadog/src/mod.d.ts.map +0 -1
  22. package/out/datadog/src/mod.js +0 -2
  23. package/out/datadog/src/mod.js.map +0 -1
  24. package/out/react.js +0 -114
  25. package/out/react.js.map +0 -7
  26. package/out/replicache/src/async-iterable-to-array.d.ts +0 -2
  27. package/out/replicache/src/async-iterable-to-array.d.ts.map +0 -1
  28. package/out/replicache/src/bg-interval.d.ts +0 -3
  29. package/out/replicache/src/bg-interval.d.ts.map +0 -1
  30. package/out/replicache/src/binary-search.d.ts +0 -15
  31. package/out/replicache/src/binary-search.d.ts.map +0 -1
  32. package/out/replicache/src/broadcast-channel.d.ts +0 -3
  33. package/out/replicache/src/broadcast-channel.d.ts.map +0 -1
  34. package/out/replicache/src/btree/diff.d.ts +0 -4
  35. package/out/replicache/src/btree/diff.d.ts.map +0 -1
  36. package/out/replicache/src/btree/node.d.ts +0 -125
  37. package/out/replicache/src/btree/node.d.ts.map +0 -1
  38. package/out/replicache/src/btree/read.d.ts +0 -32
  39. package/out/replicache/src/btree/read.d.ts.map +0 -1
  40. package/out/replicache/src/btree/splice.d.ts +0 -9
  41. package/out/replicache/src/btree/splice.d.ts.map +0 -1
  42. package/out/replicache/src/btree/write.d.ts +0 -24
  43. package/out/replicache/src/btree/write.d.ts.map +0 -1
  44. package/out/replicache/src/call-default-fetch.d.ts +0 -6
  45. package/out/replicache/src/call-default-fetch.d.ts.map +0 -1
  46. package/out/replicache/src/config.d.ts +0 -13
  47. package/out/replicache/src/config.d.ts.map +0 -1
  48. package/out/replicache/src/connection-loop-delegates.d.ts +0 -20
  49. package/out/replicache/src/connection-loop-delegates.d.ts.map +0 -1
  50. package/out/replicache/src/connection-loop.d.ts +0 -28
  51. package/out/replicache/src/connection-loop.d.ts.map +0 -1
  52. package/out/replicache/src/cookies.d.ts +0 -29
  53. package/out/replicache/src/cookies.d.ts.map +0 -1
  54. package/out/replicache/src/dag/chunk.d.ts +0 -35
  55. package/out/replicache/src/dag/chunk.d.ts.map +0 -1
  56. package/out/replicache/src/dag/gc.d.ts +0 -42
  57. package/out/replicache/src/dag/gc.d.ts.map +0 -1
  58. package/out/replicache/src/dag/key-type-enum.d.ts +0 -10
  59. package/out/replicache/src/dag/key-type-enum.d.ts.map +0 -1
  60. package/out/replicache/src/dag/key.d.ts +0 -21
  61. package/out/replicache/src/dag/key.d.ts.map +0 -1
  62. package/out/replicache/src/dag/lazy-store.d.ts +0 -181
  63. package/out/replicache/src/dag/lazy-store.d.ts.map +0 -1
  64. package/out/replicache/src/dag/store-impl.d.ts +0 -38
  65. package/out/replicache/src/dag/store-impl.d.ts.map +0 -1
  66. package/out/replicache/src/dag/store.d.ts +0 -36
  67. package/out/replicache/src/dag/store.d.ts.map +0 -1
  68. package/out/replicache/src/dag/visitor.d.ts +0 -13
  69. package/out/replicache/src/dag/visitor.d.ts.map +0 -1
  70. package/out/replicache/src/db/commit.d.ts +0 -127
  71. package/out/replicache/src/db/commit.d.ts.map +0 -1
  72. package/out/replicache/src/db/index-operation-enum.d.ts +0 -6
  73. package/out/replicache/src/db/index-operation-enum.d.ts.map +0 -1
  74. package/out/replicache/src/db/index.d.ts +0 -30
  75. package/out/replicache/src/db/index.d.ts.map +0 -1
  76. package/out/replicache/src/db/meta-type-enum.d.ts +0 -12
  77. package/out/replicache/src/db/meta-type-enum.d.ts.map +0 -1
  78. package/out/replicache/src/db/read.d.ts +0 -24
  79. package/out/replicache/src/db/read.d.ts.map +0 -1
  80. package/out/replicache/src/db/rebase.d.ts +0 -10
  81. package/out/replicache/src/db/rebase.d.ts.map +0 -1
  82. package/out/replicache/src/db/scan.d.ts +0 -15
  83. package/out/replicache/src/db/scan.d.ts.map +0 -1
  84. package/out/replicache/src/db/write.d.ts +0 -39
  85. package/out/replicache/src/db/write.d.ts.map +0 -1
  86. package/out/replicache/src/error-responses.d.ts +0 -26
  87. package/out/replicache/src/error-responses.d.ts.map +0 -1
  88. package/out/replicache/src/filter-async-iterable.d.ts +0 -10
  89. package/out/replicache/src/filter-async-iterable.d.ts.map +0 -1
  90. package/out/replicache/src/format-version-enum.d.ts +0 -13
  91. package/out/replicache/src/format-version-enum.d.ts.map +0 -1
  92. package/out/replicache/src/format-version.d.ts +0 -3
  93. package/out/replicache/src/format-version.d.ts.map +0 -1
  94. package/out/replicache/src/frozen-json.d.ts +0 -35
  95. package/out/replicache/src/frozen-json.d.ts.map +0 -1
  96. package/out/replicache/src/get-default-puller.d.ts +0 -14
  97. package/out/replicache/src/get-default-puller.d.ts.map +0 -1
  98. package/out/replicache/src/get-default-pusher.d.ts +0 -10
  99. package/out/replicache/src/get-default-pusher.d.ts.map +0 -1
  100. package/out/replicache/src/hash.d.ts +0 -29
  101. package/out/replicache/src/hash.d.ts.map +0 -1
  102. package/out/replicache/src/http-request-info.d.ts +0 -6
  103. package/out/replicache/src/http-request-info.d.ts.map +0 -1
  104. package/out/replicache/src/impl.d.ts +0 -4
  105. package/out/replicache/src/impl.d.ts.map +0 -1
  106. package/out/replicache/src/index-defs.d.ts +0 -36
  107. package/out/replicache/src/index-defs.d.ts.map +0 -1
  108. package/out/replicache/src/invoke-kind-enum.d.ts +0 -6
  109. package/out/replicache/src/invoke-kind-enum.d.ts.map +0 -1
  110. package/out/replicache/src/iterable-union.d.ts +0 -5
  111. package/out/replicache/src/iterable-union.d.ts.map +0 -1
  112. package/out/replicache/src/kv/idb-store-with-mem-fallback.d.ts +0 -25
  113. package/out/replicache/src/kv/idb-store-with-mem-fallback.d.ts.map +0 -1
  114. package/out/replicache/src/kv/idb-store.d.ts +0 -18
  115. package/out/replicache/src/kv/idb-store.d.ts.map +0 -1
  116. package/out/replicache/src/kv/mem-store.d.ts +0 -23
  117. package/out/replicache/src/kv/mem-store.d.ts.map +0 -1
  118. package/out/replicache/src/kv/read-impl.d.ts +0 -11
  119. package/out/replicache/src/kv/read-impl.d.ts.map +0 -1
  120. package/out/replicache/src/kv/store.d.ts +0 -76
  121. package/out/replicache/src/kv/store.d.ts.map +0 -1
  122. package/out/replicache/src/kv/write-impl-base.d.ts +0 -18
  123. package/out/replicache/src/kv/write-impl-base.d.ts.map +0 -1
  124. package/out/replicache/src/kv/write-impl.d.ts +0 -9
  125. package/out/replicache/src/kv/write-impl.d.ts.map +0 -1
  126. package/out/replicache/src/lazy.d.ts +0 -2
  127. package/out/replicache/src/lazy.d.ts.map +0 -1
  128. package/out/replicache/src/log-options.d.ts +0 -10
  129. package/out/replicache/src/log-options.d.ts.map +0 -1
  130. package/out/replicache/src/merge-async-iterables.d.ts +0 -16
  131. package/out/replicache/src/merge-async-iterables.d.ts.map +0 -1
  132. package/out/replicache/src/mod.d.ts +0 -38
  133. package/out/replicache/src/mod.d.ts.map +0 -1
  134. package/out/replicache/src/mutation-recovery.d.ts +0 -43
  135. package/out/replicache/src/mutation-recovery.d.ts.map +0 -1
  136. package/out/replicache/src/new-client-channel.d.ts +0 -6
  137. package/out/replicache/src/new-client-channel.d.ts.map +0 -1
  138. package/out/replicache/src/on-persist-channel.d.ts +0 -10
  139. package/out/replicache/src/on-persist-channel.d.ts.map +0 -1
  140. package/out/replicache/src/patch-operation.d.ts +0 -32
  141. package/out/replicache/src/patch-operation.d.ts.map +0 -1
  142. package/out/replicache/src/pending-mutations.d.ts +0 -14
  143. package/out/replicache/src/pending-mutations.d.ts.map +0 -1
  144. package/out/replicache/src/persist/client-gc.d.ts +0 -17
  145. package/out/replicache/src/persist/client-gc.d.ts.map +0 -1
  146. package/out/replicache/src/persist/client-group-gc.d.ts +0 -10
  147. package/out/replicache/src/persist/client-group-gc.d.ts.map +0 -1
  148. package/out/replicache/src/persist/client-groups.d.ts +0 -72
  149. package/out/replicache/src/persist/client-groups.d.ts.map +0 -1
  150. package/out/replicache/src/persist/clients.d.ts +0 -155
  151. package/out/replicache/src/persist/clients.d.ts.map +0 -1
  152. package/out/replicache/src/persist/collect-idb-databases.d.ts +0 -91
  153. package/out/replicache/src/persist/collect-idb-databases.d.ts.map +0 -1
  154. package/out/replicache/src/persist/gather-mem-only-visitor.d.ts +0 -12
  155. package/out/replicache/src/persist/gather-mem-only-visitor.d.ts.map +0 -1
  156. package/out/replicache/src/persist/gather-not-cached-visitor.d.ts +0 -17
  157. package/out/replicache/src/persist/gather-not-cached-visitor.d.ts.map +0 -1
  158. package/out/replicache/src/persist/heartbeat.d.ts +0 -9
  159. package/out/replicache/src/persist/heartbeat.d.ts.map +0 -1
  160. package/out/replicache/src/persist/idb-databases-store-db-name.d.ts +0 -5
  161. package/out/replicache/src/persist/idb-databases-store-db-name.d.ts.map +0 -1
  162. package/out/replicache/src/persist/idb-databases-store.d.ts +0 -24
  163. package/out/replicache/src/persist/idb-databases-store.d.ts.map +0 -1
  164. package/out/replicache/src/persist/make-client-id.d.ts +0 -6
  165. package/out/replicache/src/persist/make-client-id.d.ts.map +0 -1
  166. package/out/replicache/src/persist/persist.d.ts +0 -26
  167. package/out/replicache/src/persist/persist.d.ts.map +0 -1
  168. package/out/replicache/src/persist/refresh.d.ts +0 -13
  169. package/out/replicache/src/persist/refresh.d.ts.map +0 -1
  170. package/out/replicache/src/process-scheduler.d.ts +0 -20
  171. package/out/replicache/src/process-scheduler.d.ts.map +0 -1
  172. package/out/replicache/src/puller.d.ts +0 -61
  173. package/out/replicache/src/puller.d.ts.map +0 -1
  174. package/out/replicache/src/pusher.d.ts +0 -33
  175. package/out/replicache/src/pusher.d.ts.map +0 -1
  176. package/out/replicache/src/replicache-impl.d.ts +0 -321
  177. package/out/replicache/src/replicache-impl.d.ts.map +0 -1
  178. package/out/replicache/src/replicache-options.d.ts +0 -209
  179. package/out/replicache/src/replicache-options.d.ts.map +0 -1
  180. package/out/replicache/src/replicache.d.ts +0 -298
  181. package/out/replicache/src/replicache.d.ts.map +0 -1
  182. package/out/replicache/src/request-idle.d.ts +0 -6
  183. package/out/replicache/src/request-idle.d.ts.map +0 -1
  184. package/out/replicache/src/scan-iterator.d.ts +0 -127
  185. package/out/replicache/src/scan-iterator.d.ts.map +0 -1
  186. package/out/replicache/src/scan-options.d.ts +0 -67
  187. package/out/replicache/src/scan-options.d.ts.map +0 -1
  188. package/out/replicache/src/set-interval-with-signal.d.ts +0 -2
  189. package/out/replicache/src/set-interval-with-signal.d.ts.map +0 -1
  190. package/out/replicache/src/size-of-value.d.ts +0 -19
  191. package/out/replicache/src/size-of-value.d.ts.map +0 -1
  192. package/out/replicache/src/subscriptions.d.ts +0 -137
  193. package/out/replicache/src/subscriptions.d.ts.map +0 -1
  194. package/out/replicache/src/sync/diff.d.ts +0 -31
  195. package/out/replicache/src/sync/diff.d.ts.map +0 -1
  196. package/out/replicache/src/sync/handle-pull-response-result-type-enum.d.ts +0 -8
  197. package/out/replicache/src/sync/handle-pull-response-result-type-enum.d.ts.map +0 -1
  198. package/out/replicache/src/sync/ids.d.ts +0 -13
  199. package/out/replicache/src/sync/ids.d.ts.map +0 -1
  200. package/out/replicache/src/sync/patch.d.ts +0 -5
  201. package/out/replicache/src/sync/patch.d.ts.map +0 -1
  202. package/out/replicache/src/sync/pull-error.d.ts +0 -9
  203. package/out/replicache/src/sync/pull-error.d.ts.map +0 -1
  204. package/out/replicache/src/sync/pull.d.ts +0 -78
  205. package/out/replicache/src/sync/pull.d.ts.map +0 -1
  206. package/out/replicache/src/sync/push.d.ts +0 -65
  207. package/out/replicache/src/sync/push.d.ts.map +0 -1
  208. package/out/replicache/src/sync/request-id.d.ts +0 -10
  209. package/out/replicache/src/sync/request-id.d.ts.map +0 -1
  210. package/out/replicache/src/sync/sync-head-name.d.ts +0 -2
  211. package/out/replicache/src/sync/sync-head-name.d.ts.map +0 -1
  212. package/out/replicache/src/test-license-key.d.ts +0 -3
  213. package/out/replicache/src/test-license-key.d.ts.map +0 -1
  214. package/out/replicache/src/to-error.d.ts +0 -2
  215. package/out/replicache/src/to-error.d.ts.map +0 -1
  216. package/out/replicache/src/transaction-closed-error.d.ts +0 -12
  217. package/out/replicache/src/transaction-closed-error.d.ts.map +0 -1
  218. package/out/replicache/src/transactions.d.ts +0 -156
  219. package/out/replicache/src/transactions.d.ts.map +0 -1
  220. package/out/replicache/src/types.d.ts +0 -57
  221. package/out/replicache/src/types.d.ts.map +0 -1
  222. package/out/replicache/src/version.d.ts +0 -5
  223. package/out/replicache/src/version.d.ts.map +0 -1
  224. package/out/replicache/src/with-transactions.d.ts +0 -23
  225. package/out/replicache/src/with-transactions.d.ts.map +0 -1
  226. package/out/shared/src/abort-error.d.ts +0 -4
  227. package/out/shared/src/abort-error.d.ts.map +0 -1
  228. package/out/shared/src/abort-error.js +0 -4
  229. package/out/shared/src/abort-error.js.map +0 -1
  230. package/out/shared/src/asserts.d.ts +0 -17
  231. package/out/shared/src/asserts.d.ts.map +0 -1
  232. package/out/shared/src/asserts.js +0 -73
  233. package/out/shared/src/asserts.js.map +0 -1
  234. package/out/shared/src/browser-env.d.ts +0 -3
  235. package/out/shared/src/browser-env.d.ts.map +0 -1
  236. package/out/shared/src/config.d.ts +0 -3
  237. package/out/shared/src/config.d.ts.map +0 -1
  238. package/out/shared/src/config.js +0 -3
  239. package/out/shared/src/config.js.map +0 -1
  240. package/out/shared/src/custom-key-map.d.ts +0 -26
  241. package/out/shared/src/custom-key-map.d.ts.map +0 -1
  242. package/out/shared/src/custom-key-map.js +0 -65
  243. package/out/shared/src/custom-key-map.js.map +0 -1
  244. package/out/shared/src/deep-clone.d.ts +0 -4
  245. package/out/shared/src/deep-clone.d.ts.map +0 -1
  246. package/out/shared/src/document-visible.d.ts +0 -9
  247. package/out/shared/src/document-visible.d.ts.map +0 -1
  248. package/out/shared/src/has-own.d.ts +0 -5
  249. package/out/shared/src/has-own.d.ts.map +0 -1
  250. package/out/shared/src/has-own.js +0 -8
  251. package/out/shared/src/has-own.js.map +0 -1
  252. package/out/shared/src/immutable.d.ts +0 -11
  253. package/out/shared/src/immutable.d.ts.map +0 -1
  254. package/out/shared/src/iterables.d.ts +0 -11
  255. package/out/shared/src/iterables.d.ts.map +0 -1
  256. package/out/shared/src/json-schema.d.ts +0 -5
  257. package/out/shared/src/json-schema.d.ts.map +0 -1
  258. package/out/shared/src/json-schema.js +0 -36
  259. package/out/shared/src/json-schema.js.map +0 -1
  260. package/out/shared/src/json.d.ts +0 -55
  261. package/out/shared/src/json.d.ts.map +0 -1
  262. package/out/shared/src/json.js +0 -164
  263. package/out/shared/src/json.js.map +0 -1
  264. package/out/shared/src/must.d.ts +0 -2
  265. package/out/shared/src/must.d.ts.map +0 -1
  266. package/out/shared/src/must.js +0 -8
  267. package/out/shared/src/must.js.map +0 -1
  268. package/out/shared/src/navigator.d.ts +0 -7
  269. package/out/shared/src/navigator.d.ts.map +0 -1
  270. package/out/shared/src/parse-big-int.d.ts +0 -2
  271. package/out/shared/src/parse-big-int.d.ts.map +0 -1
  272. package/out/shared/src/parse-big-int.js +0 -11
  273. package/out/shared/src/parse-big-int.js.map +0 -1
  274. package/out/shared/src/queue.d.ts +0 -40
  275. package/out/shared/src/queue.d.ts.map +0 -1
  276. package/out/shared/src/queue.js +0 -118
  277. package/out/shared/src/queue.js.map +0 -1
  278. package/out/shared/src/rand.d.ts +0 -7
  279. package/out/shared/src/rand.d.ts.map +0 -1
  280. package/out/shared/src/rand.js +0 -11
  281. package/out/shared/src/rand.js.map +0 -1
  282. package/out/shared/src/random-uint64.d.ts +0 -2
  283. package/out/shared/src/random-uint64.d.ts.map +0 -1
  284. package/out/shared/src/random-values.d.ts +0 -2
  285. package/out/shared/src/random-values.d.ts.map +0 -1
  286. package/out/shared/src/resolved-promises.d.ts +0 -5
  287. package/out/shared/src/resolved-promises.d.ts.map +0 -1
  288. package/out/shared/src/resolved-promises.js +0 -5
  289. package/out/shared/src/resolved-promises.js.map +0 -1
  290. package/out/shared/src/set-utils.d.ts +0 -9
  291. package/out/shared/src/set-utils.d.ts.map +0 -1
  292. package/out/shared/src/set-utils.js +0 -60
  293. package/out/shared/src/set-utils.js.map +0 -1
  294. package/out/shared/src/sleep.d.ts +0 -15
  295. package/out/shared/src/sleep.d.ts.map +0 -1
  296. package/out/shared/src/sleep.js +0 -54
  297. package/out/shared/src/sleep.js.map +0 -1
  298. package/out/shared/src/string-compare.d.ts +0 -2
  299. package/out/shared/src/string-compare.d.ts.map +0 -1
  300. package/out/shared/src/string-compare.js +0 -10
  301. package/out/shared/src/string-compare.js.map +0 -1
  302. package/out/shared/src/types.d.ts +0 -2
  303. package/out/shared/src/types.d.ts.map +0 -1
  304. package/out/shared/src/valita.d.ts +0 -27
  305. package/out/shared/src/valita.d.ts.map +0 -1
  306. package/out/shared/src/valita.js +0 -118
  307. package/out/shared/src/valita.js.map +0 -1
  308. package/out/shared/src/xxhash.d.ts +0 -3
  309. package/out/shared/src/xxhash.d.ts.map +0 -1
  310. package/out/shared/src/xxhash.js +0 -4
  311. package/out/shared/src/xxhash.js.map +0 -1
  312. package/out/zero/src/cli.d.ts +0 -3
  313. package/out/zero/src/cli.d.ts.map +0 -1
  314. package/out/zero/src/cli.js +0 -3
  315. package/out/zero/src/cli.js.map +0 -1
  316. package/out/zero/src/react.d.ts +0 -2
  317. package/out/zero/src/react.d.ts.map +0 -1
  318. package/out/zero/src/server/change-streamer.d.ts +0 -2
  319. package/out/zero/src/server/change-streamer.d.ts.map +0 -1
  320. package/out/zero/src/server/change-streamer.js +0 -2
  321. package/out/zero/src/server/change-streamer.js.map +0 -1
  322. package/out/zero/src/server/main.d.ts +0 -2
  323. package/out/zero/src/server/main.d.ts.map +0 -1
  324. package/out/zero/src/server/main.js +0 -2
  325. package/out/zero/src/server/main.js.map +0 -1
  326. package/out/zero/src/server/replicator.d.ts +0 -2
  327. package/out/zero/src/server/replicator.d.ts.map +0 -1
  328. package/out/zero/src/server/replicator.js +0 -2
  329. package/out/zero/src/server/replicator.js.map +0 -1
  330. package/out/zero/src/server/syncer.d.ts +0 -2
  331. package/out/zero/src/server/syncer.d.ts.map +0 -1
  332. package/out/zero/src/server/syncer.js +0 -2
  333. package/out/zero/src/server/syncer.js.map +0 -1
  334. package/out/zero/src/zero.d.ts +0 -2
  335. package/out/zero/src/zero.d.ts.map +0 -1
  336. package/out/zero-cache/src/config/zero-config.d.ts +0 -1509
  337. package/out/zero-cache/src/config/zero-config.d.ts.map +0 -1
  338. package/out/zero-cache/src/config/zero-config.js +0 -237
  339. package/out/zero-cache/src/config/zero-config.js.map +0 -1
  340. package/out/zero-cache/src/db/lite-tables.d.ts +0 -5
  341. package/out/zero-cache/src/db/lite-tables.d.ts.map +0 -1
  342. package/out/zero-cache/src/db/lite-tables.js +0 -75
  343. package/out/zero-cache/src/db/lite-tables.js.map +0 -1
  344. package/out/zero-cache/src/db/migration-lite.d.ts +0 -38
  345. package/out/zero-cache/src/db/migration-lite.d.ts.map +0 -1
  346. package/out/zero-cache/src/db/migration-lite.js +0 -161
  347. package/out/zero-cache/src/db/migration-lite.js.map +0 -1
  348. package/out/zero-cache/src/db/migration.d.ts +0 -38
  349. package/out/zero-cache/src/db/migration.d.ts.map +0 -1
  350. package/out/zero-cache/src/db/migration.js +0 -139
  351. package/out/zero-cache/src/db/migration.js.map +0 -1
  352. package/out/zero-cache/src/db/statements.d.ts +0 -32
  353. package/out/zero-cache/src/db/statements.d.ts.map +0 -1
  354. package/out/zero-cache/src/db/statements.js +0 -51
  355. package/out/zero-cache/src/db/statements.js.map +0 -1
  356. package/out/zero-cache/src/db/transaction-pool.d.ts +0 -187
  357. package/out/zero-cache/src/db/transaction-pool.d.ts.map +0 -1
  358. package/out/zero-cache/src/db/transaction-pool.js +0 -445
  359. package/out/zero-cache/src/db/transaction-pool.js.map +0 -1
  360. package/out/zero-cache/src/server/change-streamer.d.ts +0 -3
  361. package/out/zero-cache/src/server/change-streamer.d.ts.map +0 -1
  362. package/out/zero-cache/src/server/change-streamer.js +0 -30
  363. package/out/zero-cache/src/server/change-streamer.js.map +0 -1
  364. package/out/zero-cache/src/server/life-cycle.d.ts +0 -38
  365. package/out/zero-cache/src/server/life-cycle.d.ts.map +0 -1
  366. package/out/zero-cache/src/server/life-cycle.js +0 -110
  367. package/out/zero-cache/src/server/life-cycle.js.map +0 -1
  368. package/out/zero-cache/src/server/logging.d.ts +0 -6
  369. package/out/zero-cache/src/server/logging.d.ts.map +0 -1
  370. package/out/zero-cache/src/server/logging.js +0 -23
  371. package/out/zero-cache/src/server/logging.js.map +0 -1
  372. package/out/zero-cache/src/server/main.d.ts +0 -2
  373. package/out/zero-cache/src/server/main.d.ts.map +0 -1
  374. package/out/zero-cache/src/server/main.js +0 -94
  375. package/out/zero-cache/src/server/main.js.map +0 -1
  376. package/out/zero-cache/src/server/replicator.d.ts +0 -3
  377. package/out/zero-cache/src/server/replicator.d.ts.map +0 -1
  378. package/out/zero-cache/src/server/replicator.js +0 -36
  379. package/out/zero-cache/src/server/replicator.js.map +0 -1
  380. package/out/zero-cache/src/server/syncer.d.ts +0 -3
  381. package/out/zero-cache/src/server/syncer.d.ts.map +0 -1
  382. package/out/zero-cache/src/server/syncer.js +0 -46
  383. package/out/zero-cache/src/server/syncer.js.map +0 -1
  384. package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +0 -23
  385. package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts.map +0 -1
  386. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js +0 -98
  387. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +0 -1
  388. package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts +0 -39
  389. package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts.map +0 -1
  390. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js +0 -212
  391. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js.map +0 -1
  392. package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts +0 -110
  393. package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts.map +0 -1
  394. package/out/zero-cache/src/services/change-streamer/change-streamer.js +0 -7
  395. package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +0 -1
  396. package/out/zero-cache/src/services/change-streamer/forwarder.d.ts +0 -19
  397. package/out/zero-cache/src/services/change-streamer/forwarder.d.ts.map +0 -1
  398. package/out/zero-cache/src/services/change-streamer/forwarder.js +0 -56
  399. package/out/zero-cache/src/services/change-streamer/forwarder.js.map +0 -1
  400. package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts +0 -14
  401. package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts.map +0 -1
  402. package/out/zero-cache/src/services/change-streamer/pg/change-source.js +0 -211
  403. package/out/zero-cache/src/services/change-streamer/pg/change-source.js.map +0 -1
  404. package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts +0 -6
  405. package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts.map +0 -1
  406. package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js +0 -192
  407. package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js.map +0 -1
  408. package/out/zero-cache/src/services/change-streamer/pg/lsn.d.ts +0 -17
  409. package/out/zero-cache/src/services/change-streamer/pg/lsn.d.ts.map +0 -1
  410. package/out/zero-cache/src/services/change-streamer/pg/lsn.js +0 -17
  411. package/out/zero-cache/src/services/change-streamer/pg/lsn.js.map +0 -1
  412. package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts +0 -6
  413. package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts.map +0 -1
  414. package/out/zero-cache/src/services/change-streamer/pg/schema/create.js +0 -29
  415. package/out/zero-cache/src/services/change-streamer/pg/schema/create.js.map +0 -1
  416. package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts +0 -79
  417. package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts.map +0 -1
  418. package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js +0 -237
  419. package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js.map +0 -1
  420. package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts +0 -5
  421. package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts.map +0 -1
  422. package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js +0 -111
  423. package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js.map +0 -1
  424. package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts +0 -26
  425. package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts.map +0 -1
  426. package/out/zero-cache/src/services/change-streamer/pg/schema/published.js +0 -185
  427. package/out/zero-cache/src/services/change-streamer/pg/schema/published.js.map +0 -1
  428. package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts +0 -11
  429. package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts.map +0 -1
  430. package/out/zero-cache/src/services/change-streamer/pg/schema/zero.js +0 -86
  431. package/out/zero-cache/src/services/change-streamer/pg/schema/zero.js.map +0 -1
  432. package/out/zero-cache/src/services/change-streamer/pg/shard-config.d.ts +0 -19
  433. package/out/zero-cache/src/services/change-streamer/pg/shard-config.d.ts.map +0 -1
  434. package/out/zero-cache/src/services/change-streamer/pg/shard-config.js +0 -2
  435. package/out/zero-cache/src/services/change-streamer/pg/shard-config.js.map +0 -1
  436. package/out/zero-cache/src/services/change-streamer/pg/sync-schema.d.ts +0 -4
  437. package/out/zero-cache/src/services/change-streamer/pg/sync-schema.d.ts.map +0 -1
  438. package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js +0 -12
  439. package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js.map +0 -1
  440. package/out/zero-cache/src/services/change-streamer/schema/change.d.ts +0 -31
  441. package/out/zero-cache/src/services/change-streamer/schema/change.d.ts.map +0 -1
  442. package/out/zero-cache/src/services/change-streamer/schema/change.js +0 -2
  443. package/out/zero-cache/src/services/change-streamer/schema/change.js.map +0 -1
  444. package/out/zero-cache/src/services/change-streamer/schema/init.d.ts +0 -4
  445. package/out/zero-cache/src/services/change-streamer/schema/init.d.ts.map +0 -1
  446. package/out/zero-cache/src/services/change-streamer/schema/init.js +0 -10
  447. package/out/zero-cache/src/services/change-streamer/schema/init.js.map +0 -1
  448. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts +0 -22
  449. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts.map +0 -1
  450. package/out/zero-cache/src/services/change-streamer/schema/tables.js +0 -49
  451. package/out/zero-cache/src/services/change-streamer/schema/tables.js.map +0 -1
  452. package/out/zero-cache/src/services/change-streamer/storer.d.ts +0 -22
  453. package/out/zero-cache/src/services/change-streamer/storer.d.ts.map +0 -1
  454. package/out/zero-cache/src/services/change-streamer/storer.js +0 -157
  455. package/out/zero-cache/src/services/change-streamer/storer.js.map +0 -1
  456. package/out/zero-cache/src/services/change-streamer/subscriber.d.ts +0 -27
  457. package/out/zero-cache/src/services/change-streamer/subscriber.d.ts.map +0 -1
  458. package/out/zero-cache/src/services/change-streamer/subscriber.js +0 -70
  459. package/out/zero-cache/src/services/change-streamer/subscriber.js.map +0 -1
  460. package/out/zero-cache/src/services/dispatcher/connect-params.d.ts +0 -21
  461. package/out/zero-cache/src/services/dispatcher/connect-params.d.ts.map +0 -1
  462. package/out/zero-cache/src/services/dispatcher/connect-params.js +0 -38
  463. package/out/zero-cache/src/services/dispatcher/connect-params.js.map +0 -1
  464. package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts +0 -19
  465. package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts.map +0 -1
  466. package/out/zero-cache/src/services/dispatcher/dispatcher.js +0 -54
  467. package/out/zero-cache/src/services/dispatcher/dispatcher.js.map +0 -1
  468. package/out/zero-cache/src/services/dispatcher/websocket-handoff.d.ts +0 -11
  469. package/out/zero-cache/src/services/dispatcher/websocket-handoff.d.ts.map +0 -1
  470. package/out/zero-cache/src/services/dispatcher/websocket-handoff.js +0 -33
  471. package/out/zero-cache/src/services/dispatcher/websocket-handoff.js.map +0 -1
  472. package/out/zero-cache/src/services/limiter/sliding-window-limiter.d.ts +0 -57
  473. package/out/zero-cache/src/services/limiter/sliding-window-limiter.d.ts.map +0 -1
  474. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js +0 -137
  475. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js.map +0 -1
  476. package/out/zero-cache/src/services/mutagen/mutagen.d.ts +0 -28
  477. package/out/zero-cache/src/services/mutagen/mutagen.d.ts.map +0 -1
  478. package/out/zero-cache/src/services/mutagen/mutagen.js +0 -256
  479. package/out/zero-cache/src/services/mutagen/mutagen.js.map +0 -1
  480. package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts +0 -20
  481. package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts.map +0 -1
  482. package/out/zero-cache/src/services/mutagen/write-authorizer.js +0 -187
  483. package/out/zero-cache/src/services/mutagen/write-authorizer.js.map +0 -1
  484. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts +0 -40
  485. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +0 -1
  486. package/out/zero-cache/src/services/replicator/incremental-sync.js +0 -348
  487. package/out/zero-cache/src/services/replicator/incremental-sync.js.map +0 -1
  488. package/out/zero-cache/src/services/replicator/notifier.d.ts +0 -30
  489. package/out/zero-cache/src/services/replicator/notifier.d.ts.map +0 -1
  490. package/out/zero-cache/src/services/replicator/notifier.js +0 -54
  491. package/out/zero-cache/src/services/replicator/notifier.js.map +0 -1
  492. package/out/zero-cache/src/services/replicator/replicator.d.ts +0 -56
  493. package/out/zero-cache/src/services/replicator/replicator.d.ts.map +0 -1
  494. package/out/zero-cache/src/services/replicator/replicator.js +0 -27
  495. package/out/zero-cache/src/services/replicator/replicator.js.map +0 -1
  496. package/out/zero-cache/src/services/replicator/schema/change-log.d.ts +0 -35
  497. package/out/zero-cache/src/services/replicator/schema/change-log.d.ts.map +0 -1
  498. package/out/zero-cache/src/services/replicator/schema/change-log.js +0 -78
  499. package/out/zero-cache/src/services/replicator/schema/change-log.js.map +0 -1
  500. package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts +0 -25
  501. package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts.map +0 -1
  502. package/out/zero-cache/src/services/replicator/schema/replication-state.js +0 -90
  503. package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +0 -1
  504. package/out/zero-cache/src/services/runner.d.ts +0 -18
  505. package/out/zero-cache/src/services/runner.d.ts.map +0 -1
  506. package/out/zero-cache/src/services/runner.js +0 -45
  507. package/out/zero-cache/src/services/runner.js.map +0 -1
  508. package/out/zero-cache/src/services/running-state.d.ts +0 -56
  509. package/out/zero-cache/src/services/running-state.d.ts.map +0 -1
  510. package/out/zero-cache/src/services/running-state.js +0 -106
  511. package/out/zero-cache/src/services/running-state.js.map +0 -1
  512. package/out/zero-cache/src/services/service.d.ts +0 -37
  513. package/out/zero-cache/src/services/service.d.ts.map +0 -1
  514. package/out/zero-cache/src/services/service.js +0 -2
  515. package/out/zero-cache/src/services/service.js.map +0 -1
  516. package/out/zero-cache/src/services/view-syncer/client-handler.d.ts +0 -54
  517. package/out/zero-cache/src/services/view-syncer/client-handler.d.ts.map +0 -1
  518. package/out/zero-cache/src/services/view-syncer/client-handler.js +0 -195
  519. package/out/zero-cache/src/services/view-syncer/client-handler.js.map +0 -1
  520. package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts +0 -44
  521. package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts.map +0 -1
  522. package/out/zero-cache/src/services/view-syncer/cvr-store.js +0 -386
  523. package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +0 -1
  524. package/out/zero-cache/src/services/view-syncer/cvr.d.ts +0 -146
  525. package/out/zero-cache/src/services/view-syncer/cvr.d.ts.map +0 -1
  526. package/out/zero-cache/src/services/view-syncer/cvr.js +0 -446
  527. package/out/zero-cache/src/services/view-syncer/cvr.js.map +0 -1
  528. package/out/zero-cache/src/services/view-syncer/database-storage.d.ts +0 -22
  529. package/out/zero-cache/src/services/view-syncer/database-storage.d.ts.map +0 -1
  530. package/out/zero-cache/src/services/view-syncer/database-storage.js +0 -129
  531. package/out/zero-cache/src/services/view-syncer/database-storage.js.map +0 -1
  532. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +0 -108
  533. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +0 -1
  534. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +0 -300
  535. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +0 -1
  536. package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts +0 -54
  537. package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts.map +0 -1
  538. package/out/zero-cache/src/services/view-syncer/schema/cvr.js +0 -181
  539. package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +0 -1
  540. package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.d.ts +0 -4
  541. package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.d.ts.map +0 -1
  542. package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.js +0 -12
  543. package/out/zero-cache/src/services/view-syncer/schema/pg-migrations.js.map +0 -1
  544. package/out/zero-cache/src/services/view-syncer/schema/types.d.ts +0 -783
  545. package/out/zero-cache/src/services/view-syncer/schema/types.d.ts.map +0 -1
  546. package/out/zero-cache/src/services/view-syncer/schema/types.js +0 -213
  547. package/out/zero-cache/src/services/view-syncer/schema/types.js.map +0 -1
  548. package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts +0 -177
  549. package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts.map +0 -1
  550. package/out/zero-cache/src/services/view-syncer/snapshotter.js +0 -363
  551. package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +0 -1
  552. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +0 -40
  553. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +0 -1
  554. package/out/zero-cache/src/services/view-syncer/view-syncer.js +0 -506
  555. package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +0 -1
  556. package/out/zero-cache/src/types/bigint-json.d.ts +0 -26
  557. package/out/zero-cache/src/types/bigint-json.d.ts.map +0 -1
  558. package/out/zero-cache/src/types/bigint-json.js +0 -49
  559. package/out/zero-cache/src/types/bigint-json.js.map +0 -1
  560. package/out/zero-cache/src/types/error-for-client.d.ts +0 -7
  561. package/out/zero-cache/src/types/error-for-client.d.ts.map +0 -1
  562. package/out/zero-cache/src/types/error-for-client.js +0 -17
  563. package/out/zero-cache/src/types/error-for-client.js.map +0 -1
  564. package/out/zero-cache/src/types/lexi-version.d.ts +0 -29
  565. package/out/zero-cache/src/types/lexi-version.d.ts.map +0 -1
  566. package/out/zero-cache/src/types/lexi-version.js +0 -36
  567. package/out/zero-cache/src/types/lexi-version.js.map +0 -1
  568. package/out/zero-cache/src/types/lite.d.ts +0 -11
  569. package/out/zero-cache/src/types/lite.d.ts.map +0 -1
  570. package/out/zero-cache/src/types/lite.js +0 -26
  571. package/out/zero-cache/src/types/lite.js.map +0 -1
  572. package/out/zero-cache/src/types/names.d.ts +0 -5
  573. package/out/zero-cache/src/types/names.d.ts.map +0 -1
  574. package/out/zero-cache/src/types/names.js +0 -4
  575. package/out/zero-cache/src/types/names.js.map +0 -1
  576. package/out/zero-cache/src/types/pg.d.ts +0 -31
  577. package/out/zero-cache/src/types/pg.d.ts.map +0 -1
  578. package/out/zero-cache/src/types/pg.js +0 -60
  579. package/out/zero-cache/src/types/pg.js.map +0 -1
  580. package/out/zero-cache/src/types/processes.d.ts +0 -57
  581. package/out/zero-cache/src/types/processes.d.ts.map +0 -1
  582. package/out/zero-cache/src/types/processes.js +0 -115
  583. package/out/zero-cache/src/types/processes.js.map +0 -1
  584. package/out/zero-cache/src/types/row-key.d.ts +0 -37
  585. package/out/zero-cache/src/types/row-key.d.ts.map +0 -1
  586. package/out/zero-cache/src/types/row-key.js +0 -64
  587. package/out/zero-cache/src/types/row-key.js.map +0 -1
  588. package/out/zero-cache/src/types/satisfies.d.ts +0 -14
  589. package/out/zero-cache/src/types/satisfies.d.ts.map +0 -1
  590. package/out/zero-cache/src/types/satisfies.js +0 -2
  591. package/out/zero-cache/src/types/satisfies.js.map +0 -1
  592. package/out/zero-cache/src/types/schema-versions.d.ts +0 -8
  593. package/out/zero-cache/src/types/schema-versions.d.ts.map +0 -1
  594. package/out/zero-cache/src/types/schema-versions.js +0 -21
  595. package/out/zero-cache/src/types/schema-versions.js.map +0 -1
  596. package/out/zero-cache/src/types/specs.d.ts +0 -29
  597. package/out/zero-cache/src/types/specs.d.ts.map +0 -1
  598. package/out/zero-cache/src/types/specs.js +0 -2
  599. package/out/zero-cache/src/types/specs.js.map +0 -1
  600. package/out/zero-cache/src/types/sql.d.ts +0 -11
  601. package/out/zero-cache/src/types/sql.d.ts.map +0 -1
  602. package/out/zero-cache/src/types/sql.js +0 -15
  603. package/out/zero-cache/src/types/sql.js.map +0 -1
  604. package/out/zero-cache/src/types/streams.d.ts +0 -33
  605. package/out/zero-cache/src/types/streams.d.ts.map +0 -1
  606. package/out/zero-cache/src/types/streams.js +0 -141
  607. package/out/zero-cache/src/types/streams.js.map +0 -1
  608. package/out/zero-cache/src/types/subscription.d.ts +0 -158
  609. package/out/zero-cache/src/types/subscription.d.ts.map +0 -1
  610. package/out/zero-cache/src/types/subscription.js +0 -233
  611. package/out/zero-cache/src/types/subscription.js.map +0 -1
  612. package/out/zero-cache/src/types/timeout.d.ts +0 -11
  613. package/out/zero-cache/src/types/timeout.d.ts.map +0 -1
  614. package/out/zero-cache/src/types/timeout.js +0 -23
  615. package/out/zero-cache/src/types/timeout.js.map +0 -1
  616. package/out/zero-cache/src/types/url-params.d.ts +0 -10
  617. package/out/zero-cache/src/types/url-params.d.ts.map +0 -1
  618. package/out/zero-cache/src/types/url-params.js +0 -35
  619. package/out/zero-cache/src/types/url-params.js.map +0 -1
  620. package/out/zero-cache/src/workers/connection.d.ts +0 -25
  621. package/out/zero-cache/src/workers/connection.d.ts.map +0 -1
  622. package/out/zero-cache/src/workers/connection.js +0 -189
  623. package/out/zero-cache/src/workers/connection.js.map +0 -1
  624. package/out/zero-cache/src/workers/replicator.d.ts +0 -17
  625. package/out/zero-cache/src/workers/replicator.d.ts.map +0 -1
  626. package/out/zero-cache/src/workers/replicator.js +0 -77
  627. package/out/zero-cache/src/workers/replicator.js.map +0 -1
  628. package/out/zero-cache/src/workers/syncer.d.ts +0 -36
  629. package/out/zero-cache/src/workers/syncer.d.ts.map +0 -1
  630. package/out/zero-cache/src/workers/syncer.js +0 -104
  631. package/out/zero-cache/src/workers/syncer.js.map +0 -1
  632. package/out/zero-client/src/client/context.d.ts +0 -23
  633. package/out/zero-client/src/client/context.d.ts.map +0 -1
  634. package/out/zero-client/src/client/crud.d.ts +0 -52
  635. package/out/zero-client/src/client/crud.d.ts.map +0 -1
  636. package/out/zero-client/src/client/enable-analytics.d.ts +0 -3
  637. package/out/zero-client/src/client/enable-analytics.d.ts.map +0 -1
  638. package/out/zero-client/src/client/http-string.d.ts +0 -7
  639. package/out/zero-client/src/client/http-string.d.ts.map +0 -1
  640. package/out/zero-client/src/client/keys.d.ts +0 -11
  641. package/out/zero-client/src/client/keys.d.ts.map +0 -1
  642. package/out/zero-client/src/client/log-options.d.ts +0 -12
  643. package/out/zero-client/src/client/log-options.d.ts.map +0 -1
  644. package/out/zero-client/src/client/metrics.d.ts +0 -115
  645. package/out/zero-client/src/client/metrics.d.ts.map +0 -1
  646. package/out/zero-client/src/client/options.d.ts +0 -94
  647. package/out/zero-client/src/client/options.d.ts.map +0 -1
  648. package/out/zero-client/src/client/query-manager.d.ts +0 -18
  649. package/out/zero-client/src/client/query-manager.d.ts.map +0 -1
  650. package/out/zero-client/src/client/reload-error-handler.d.ts +0 -5
  651. package/out/zero-client/src/client/reload-error-handler.d.ts.map +0 -1
  652. package/out/zero-client/src/client/replicache-types.d.ts +0 -48
  653. package/out/zero-client/src/client/replicache-types.d.ts.map +0 -1
  654. package/out/zero-client/src/client/server-error.d.ts +0 -12
  655. package/out/zero-client/src/client/server-error.d.ts.map +0 -1
  656. package/out/zero-client/src/client/server-option.d.ts +0 -3
  657. package/out/zero-client/src/client/server-option.d.ts.map +0 -1
  658. package/out/zero-client/src/client/version.d.ts +0 -5
  659. package/out/zero-client/src/client/version.d.ts.map +0 -1
  660. package/out/zero-client/src/client/zero-poke-handler.d.ts +0 -28
  661. package/out/zero-client/src/client/zero-poke-handler.d.ts.map +0 -1
  662. package/out/zero-client/src/client/zero.d.ts +0 -182
  663. package/out/zero-client/src/client/zero.d.ts.map +0 -1
  664. package/out/zero-client/src/mod.d.ts +0 -9
  665. package/out/zero-client/src/mod.d.ts.map +0 -1
  666. package/out/zero-client/src/util/nanoid.d.ts +0 -2
  667. package/out/zero-client/src/util/nanoid.d.ts.map +0 -1
  668. package/out/zero-client/src/util/socket.d.ts +0 -3
  669. package/out/zero-client/src/util/socket.d.ts.map +0 -1
  670. package/out/zero-protocol/src/ast.d.ts +0 -69
  671. package/out/zero-protocol/src/ast.d.ts.map +0 -1
  672. package/out/zero-protocol/src/ast.js +0 -64
  673. package/out/zero-protocol/src/ast.js.map +0 -1
  674. package/out/zero-protocol/src/change-desired-queries.d.ts +0 -71
  675. package/out/zero-protocol/src/change-desired-queries.d.ts.map +0 -1
  676. package/out/zero-protocol/src/change-desired-queries.js +0 -10
  677. package/out/zero-protocol/src/change-desired-queries.js.map +0 -1
  678. package/out/zero-protocol/src/clients-patch.d.ts +0 -37
  679. package/out/zero-protocol/src/clients-patch.d.ts.map +0 -1
  680. package/out/zero-protocol/src/clients-patch.js +0 -15
  681. package/out/zero-protocol/src/clients-patch.js.map +0 -1
  682. package/out/zero-protocol/src/connect.d.ts +0 -88
  683. package/out/zero-protocol/src/connect.d.ts.map +0 -1
  684. package/out/zero-protocol/src/connect.js +0 -25
  685. package/out/zero-protocol/src/connect.js.map +0 -1
  686. package/out/zero-protocol/src/delete-clients.d.ts +0 -11
  687. package/out/zero-protocol/src/delete-clients.d.ts.map +0 -1
  688. package/out/zero-protocol/src/delete-clients.js +0 -9
  689. package/out/zero-protocol/src/delete-clients.js.map +0 -1
  690. package/out/zero-protocol/src/down.d.ts +0 -114
  691. package/out/zero-protocol/src/down.d.ts.map +0 -1
  692. package/out/zero-protocol/src/down.js +0 -8
  693. package/out/zero-protocol/src/down.js.map +0 -1
  694. package/out/zero-protocol/src/entities-patch.d.ts +0 -66
  695. package/out/zero-protocol/src/entities-patch.d.ts.map +0 -1
  696. package/out/zero-protocol/src/entities-patch.js +0 -27
  697. package/out/zero-protocol/src/entities-patch.js.map +0 -1
  698. package/out/zero-protocol/src/entity.d.ts +0 -9
  699. package/out/zero-protocol/src/entity.d.ts.map +0 -1
  700. package/out/zero-protocol/src/entity.js +0 -8
  701. package/out/zero-protocol/src/entity.js.map +0 -1
  702. package/out/zero-protocol/src/error.d.ts +0 -21
  703. package/out/zero-protocol/src/error.d.ts.map +0 -1
  704. package/out/zero-protocol/src/error.js +0 -28
  705. package/out/zero-protocol/src/error.js.map +0 -1
  706. package/out/zero-protocol/src/mod.d.ts +0 -16
  707. package/out/zero-protocol/src/mod.d.ts.map +0 -1
  708. package/out/zero-protocol/src/mod.js +0 -16
  709. package/out/zero-protocol/src/mod.js.map +0 -1
  710. package/out/zero-protocol/src/ping.d.ts +0 -6
  711. package/out/zero-protocol/src/ping.d.ts.map +0 -1
  712. package/out/zero-protocol/src/ping.js +0 -4
  713. package/out/zero-protocol/src/ping.js.map +0 -1
  714. package/out/zero-protocol/src/poke.d.ts +0 -244
  715. package/out/zero-protocol/src/poke.d.ts.map +0 -1
  716. package/out/zero-protocol/src/poke.js +0 -73
  717. package/out/zero-protocol/src/poke.js.map +0 -1
  718. package/out/zero-protocol/src/pong.d.ts +0 -6
  719. package/out/zero-protocol/src/pong.d.ts.map +0 -1
  720. package/out/zero-protocol/src/pong.js +0 -4
  721. package/out/zero-protocol/src/pong.js.map +0 -1
  722. package/out/zero-protocol/src/pull.d.ts +0 -26
  723. package/out/zero-protocol/src/pull.d.ts.map +0 -1
  724. package/out/zero-protocol/src/pull.js +0 -24
  725. package/out/zero-protocol/src/pull.js.map +0 -1
  726. package/out/zero-protocol/src/push.d.ts +0 -257
  727. package/out/zero-protocol/src/push.d.ts.map +0 -1
  728. package/out/zero-protocol/src/push.js +0 -77
  729. package/out/zero-protocol/src/push.js.map +0 -1
  730. package/out/zero-protocol/src/queries-patch.d.ts +0 -103
  731. package/out/zero-protocol/src/queries-patch.d.ts.map +0 -1
  732. package/out/zero-protocol/src/queries-patch.js +0 -17
  733. package/out/zero-protocol/src/queries-patch.js.map +0 -1
  734. package/out/zero-protocol/src/up.d.ts +0 -116
  735. package/out/zero-protocol/src/up.d.ts.map +0 -1
  736. package/out/zero-protocol/src/up.js +0 -9
  737. package/out/zero-protocol/src/up.js.map +0 -1
  738. package/out/zero-protocol/src/version.d.ts +0 -6
  739. package/out/zero-protocol/src/version.d.ts.map +0 -1
  740. package/out/zero-protocol/src/version.js +0 -4
  741. package/out/zero-protocol/src/version.js.map +0 -1
  742. package/out/zero-react/src/mod.d.ts +0 -3
  743. package/out/zero-react/src/mod.d.ts.map +0 -1
  744. package/out/zero-react/src/use-query.d.ts +0 -3
  745. package/out/zero-react/src/use-query.d.ts.map +0 -1
  746. package/out/zero-react/src/use-zero.d.ts +0 -8
  747. package/out/zero-react/src/use-zero.d.ts.map +0 -1
  748. package/out/zero.js +0 -15868
  749. package/out/zero.js.map +0 -7
  750. package/out/zql/src/zql/ast/ast.d.ts +0 -84
  751. package/out/zql/src/zql/ast/ast.d.ts.map +0 -1
  752. package/out/zql/src/zql/ast/ast.js +0 -54
  753. package/out/zql/src/zql/ast/ast.js.map +0 -1
  754. package/out/zql/src/zql/builder/builder.d.ts +0 -56
  755. package/out/zql/src/zql/builder/builder.d.ts.map +0 -1
  756. package/out/zql/src/zql/builder/builder.js +0 -115
  757. package/out/zql/src/zql/builder/builder.js.map +0 -1
  758. package/out/zql/src/zql/builder/error.d.ts +0 -3
  759. package/out/zql/src/zql/builder/error.d.ts.map +0 -1
  760. package/out/zql/src/zql/builder/error.js +0 -3
  761. package/out/zql/src/zql/builder/error.js.map +0 -1
  762. package/out/zql/src/zql/builder/filter.d.ts +0 -6
  763. package/out/zql/src/zql/builder/filter.d.ts.map +0 -1
  764. package/out/zql/src/zql/builder/filter.js +0 -53
  765. package/out/zql/src/zql/builder/filter.js.map +0 -1
  766. package/out/zql/src/zql/builder/like.d.ts +0 -3
  767. package/out/zql/src/zql/builder/like.d.ts.map +0 -1
  768. package/out/zql/src/zql/builder/like.js +0 -60
  769. package/out/zql/src/zql/builder/like.js.map +0 -1
  770. package/out/zql/src/zql/ivm/array-view.d.ts +0 -42
  771. package/out/zql/src/zql/ivm/array-view.d.ts.map +0 -1
  772. package/out/zql/src/zql/ivm/change.d.ts +0 -44
  773. package/out/zql/src/zql/ivm/change.d.ts.map +0 -1
  774. package/out/zql/src/zql/ivm/change.js +0 -2
  775. package/out/zql/src/zql/ivm/change.js.map +0 -1
  776. package/out/zql/src/zql/ivm/data.d.ts +0 -72
  777. package/out/zql/src/zql/ivm/data.d.ts.map +0 -1
  778. package/out/zql/src/zql/ivm/data.js +0 -84
  779. package/out/zql/src/zql/ivm/data.js.map +0 -1
  780. package/out/zql/src/zql/ivm/filter.d.ts +0 -27
  781. package/out/zql/src/zql/ivm/filter.d.ts.map +0 -1
  782. package/out/zql/src/zql/ivm/filter.js +0 -60
  783. package/out/zql/src/zql/ivm/filter.js.map +0 -1
  784. package/out/zql/src/zql/ivm/join.d.ts +0 -37
  785. package/out/zql/src/zql/ivm/join.d.ts.map +0 -1
  786. package/out/zql/src/zql/ivm/join.js +0 -228
  787. package/out/zql/src/zql/ivm/join.js.map +0 -1
  788. package/out/zql/src/zql/ivm/lookahead-iterator.d.ts +0 -13
  789. package/out/zql/src/zql/ivm/lookahead-iterator.d.ts.map +0 -1
  790. package/out/zql/src/zql/ivm/lookahead-iterator.js +0 -45
  791. package/out/zql/src/zql/ivm/lookahead-iterator.js.map +0 -1
  792. package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts +0 -10
  793. package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.d.ts.map +0 -1
  794. package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.js +0 -34
  795. package/out/zql/src/zql/ivm/maybe-split-and-push-edit-change.js.map +0 -1
  796. package/out/zql/src/zql/ivm/memory-source.d.ts +0 -65
  797. package/out/zql/src/zql/ivm/memory-source.d.ts.map +0 -1
  798. package/out/zql/src/zql/ivm/memory-source.js +0 -508
  799. package/out/zql/src/zql/ivm/memory-source.js.map +0 -1
  800. package/out/zql/src/zql/ivm/memory-storage.d.ts +0 -18
  801. package/out/zql/src/zql/ivm/memory-storage.d.ts.map +0 -1
  802. package/out/zql/src/zql/ivm/operator.d.ts +0 -89
  803. package/out/zql/src/zql/ivm/operator.d.ts.map +0 -1
  804. package/out/zql/src/zql/ivm/operator.js +0 -2
  805. package/out/zql/src/zql/ivm/operator.js.map +0 -1
  806. package/out/zql/src/zql/ivm/schema.d.ts +0 -29
  807. package/out/zql/src/zql/ivm/schema.d.ts.map +0 -1
  808. package/out/zql/src/zql/ivm/schema.js +0 -3
  809. package/out/zql/src/zql/ivm/schema.js.map +0 -1
  810. package/out/zql/src/zql/ivm/skip.d.ts +0 -24
  811. package/out/zql/src/zql/ivm/skip.d.ts.map +0 -1
  812. package/out/zql/src/zql/ivm/skip.js +0 -113
  813. package/out/zql/src/zql/ivm/skip.js.map +0 -1
  814. package/out/zql/src/zql/ivm/source.d.ts +0 -57
  815. package/out/zql/src/zql/ivm/source.d.ts.map +0 -1
  816. package/out/zql/src/zql/ivm/source.js +0 -2
  817. package/out/zql/src/zql/ivm/source.js.map +0 -1
  818. package/out/zql/src/zql/ivm/stream.d.ts +0 -11
  819. package/out/zql/src/zql/ivm/stream.d.ts.map +0 -1
  820. package/out/zql/src/zql/ivm/stream.js +0 -19
  821. package/out/zql/src/zql/ivm/stream.js.map +0 -1
  822. package/out/zql/src/zql/ivm/take.d.ts +0 -24
  823. package/out/zql/src/zql/ivm/take.d.ts.map +0 -1
  824. package/out/zql/src/zql/ivm/take.js +0 -453
  825. package/out/zql/src/zql/ivm/take.js.map +0 -1
  826. package/out/zql/src/zql/query/query-impl.d.ts +0 -48
  827. package/out/zql/src/zql/query/query-impl.d.ts.map +0 -1
  828. package/out/zql/src/zql/query/query.d.ts +0 -131
  829. package/out/zql/src/zql/query/query.d.ts.map +0 -1
  830. package/out/zql/src/zql/query/schema.d.ts +0 -53
  831. package/out/zql/src/zql/query/schema.d.ts.map +0 -1
  832. package/out/zql/src/zql/query/typed-view.d.ts +0 -10
  833. package/out/zql/src/zql/query/typed-view.d.ts.map +0 -1
  834. package/out/zqlite/src/db.d.ts +0 -23
  835. package/out/zqlite/src/db.d.ts.map +0 -1
  836. package/out/zqlite/src/db.js +0 -117
  837. package/out/zqlite/src/db.js.map +0 -1
  838. package/out/zqlite/src/internal/sql.d.ts +0 -9
  839. package/out/zqlite/src/internal/sql.d.ts.map +0 -1
  840. package/out/zqlite/src/internal/sql.js +0 -14
  841. package/out/zqlite/src/internal/sql.js.map +0 -1
  842. package/out/zqlite/src/internal/statement-cache.d.ts +0 -67
  843. package/out/zqlite/src/internal/statement-cache.d.ts.map +0 -1
  844. package/out/zqlite/src/internal/statement-cache.js +0 -119
  845. package/out/zqlite/src/internal/statement-cache.js.map +0 -1
  846. package/out/zqlite/src/table-source.d.ts +0 -43
  847. package/out/zqlite/src/table-source.d.ts.map +0 -1
  848. package/out/zqlite/src/table-source.js +0 -393
  849. package/out/zqlite/src/table-source.js.map +0 -1
@@ -1,49 +0,0 @@
1
- import { LogContext } from '@rocicorp/logger';
2
- import postgres from 'postgres';
3
- import { equals } from '../../../../../shared/src/set-utils.js';
4
- export const PG_SCHEMA = 'cdc';
5
- const CREATE_CDC_SCHEMA = `CREATE SCHEMA IF NOT EXISTS cdc;`;
6
- const CREATE_CHANGE_LOG_TABLE = `
7
- CREATE TABLE cdc."ChangeLog" (
8
- watermark TEXT,
9
- pos INT8,
10
- change JSONB NOT NULL,
11
- precommit TEXT, -- Only exists on commit entries. Purely for debugging.
12
- PRIMARY KEY (watermark, pos)
13
- );
14
- `;
15
- const CREATE_REPLICATION_CONFIG_TABLE = `
16
- CREATE TABLE cdc."ReplicationConfig" (
17
- "replicaVersion" TEXT NOT NULL,
18
- "publications" TEXT[] NOT NULL,
19
- "lock" INTEGER PRIMARY KEY DEFAULT 1 CHECK (lock=1)
20
- );
21
- `;
22
- const CREATE_CDC_TABLES = CREATE_CDC_SCHEMA + CREATE_CHANGE_LOG_TABLE + CREATE_REPLICATION_CONFIG_TABLE;
23
- export async function setupCDCTables(lc, db) {
24
- lc.info?.(`Setting up CDC tables`);
25
- await db.unsafe(CREATE_CDC_TABLES);
26
- }
27
- export async function ensureReplicationConfig(lc, db, config) {
28
- // Restrict the fields of the supplied `config`.
29
- const { publications, replicaVersion } = config;
30
- const replicaConfig = { publications, replicaVersion };
31
- await db.begin(async (tx) => {
32
- const results = await tx `SELECT "replicaVersion", "publications" FROM cdc."ReplicationConfig"`;
33
- if (results.length === 0) {
34
- return tx `INSERT INTO cdc."ReplicationConfig" ${tx(replicaConfig)}`;
35
- }
36
- const { replicaVersion, publications } = results[0];
37
- if (replicaVersion !== replicaConfig.replicaVersion ||
38
- !equals(new Set(publications), new Set(replicaConfig.publications))) {
39
- lc.info?.(`Data in cdc tables @${replicaVersion} is incompatible ` +
40
- `with replica @${replicaConfig.replicaVersion}. Clearing tables.`);
41
- return [
42
- tx `TRUNCATE TABLE cdc."ChangeLog"`,
43
- tx `UPDATE cdc."ReplicationConfig" SET ${tx(replicaConfig)}`,
44
- ].map(stmt => stmt.execute());
45
- }
46
- return [];
47
- });
48
- }
49
- //# sourceMappingURL=tables.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tables.js","sourceRoot":"","sources":["../../../../../../../zero-cache/src/services/change-streamer/schema/tables.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAC5C,OAAO,QAAQ,MAAM,UAAU,CAAC;AAChC,OAAO,EAAC,MAAM,EAAC,MAAM,wCAAwC,CAAC;AAI9D,MAAM,CAAC,MAAM,SAAS,GAAG,KAAK,CAAC;AAE/B,MAAM,iBAAiB,GAAG,kCAAkC,CAAC;AAS7D,MAAM,uBAAuB,GAAG;;;;;;;;CAQ/B,CAAC;AAaF,MAAM,+BAA+B,GAAG;;;;;;CAMvC,CAAC;AAEF,MAAM,iBAAiB,GACrB,iBAAiB,GAAG,uBAAuB,GAAG,+BAA+B,CAAC;AAEhF,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,EAAc,EACd,EAA2B;IAE3B,EAAE,CAAC,IAAI,EAAE,CAAC,uBAAuB,CAAC,CAAC;IACnC,MAAM,EAAE,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;AACrC,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,uBAAuB,CAC3C,EAAc,EACd,EAAc,EACd,MAAyB;IAEzB,gDAAgD;IAChD,MAAM,EAAC,YAAY,EAAE,cAAc,EAAC,GAAG,MAAM,CAAC;IAC9C,MAAM,aAAa,GAAG,EAAC,YAAY,EAAE,cAAc,EAAC,CAAC;IAErD,MAAM,EAAE,CAAC,KAAK,CAAC,KAAK,EAAC,EAAE,EAAC,EAAE;QACxB,MAAM,OAAO,GAAG,MAAM,EAAE,CAKvB,sEAAsE,CAAC;QAExE,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACzB,OAAO,EAAE,CAAA,uCAAuC,EAAE,CAAC,aAAa,CAAC,EAAE,CAAC;QACtE,CAAC;QAED,MAAM,EAAC,cAAc,EAAE,YAAY,EAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;QAClD,IACE,cAAc,KAAK,aAAa,CAAC,cAAc;YAC/C,CAAC,MAAM,CAAC,IAAI,GAAG,CAAC,YAAY,CAAC,EAAE,IAAI,GAAG,CAAC,aAAa,CAAC,YAAY,CAAC,CAAC,EACnE,CAAC;YACD,EAAE,CAAC,IAAI,EAAE,CACP,uBAAuB,cAAc,mBAAmB;gBACtD,iBAAiB,aAAa,CAAC,cAAc,oBAAoB,CACpE,CAAC;YACF,OAAO;gBACL,EAAE,CAAA,gCAAgC;gBAClC,EAAE,CAAA,sCAAsC,EAAE,CAAC,aAAa,CAAC,EAAE;aAC5D,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAChC,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -1,22 +0,0 @@
1
- import { LogContext } from '@rocicorp/logger';
2
- import type { PostgresDB } from '../../types/pg.js';
3
- import type { Service } from '../service.js';
4
- import type { WatermarkedChange } from './change-streamer-service.js';
5
- import type { Commit } from './change-streamer.js';
6
- import { Subscriber } from './subscriber.js';
7
- /**
8
- * Handles the storage of changes and the catchup of subscribers
9
- * that are behind.
10
- */
11
- export declare class Storer implements Service {
12
- #private;
13
- readonly id = "storer";
14
- readonly stopped: import("@rocicorp/resolver").Resolver<false, unknown>;
15
- constructor(lc: LogContext, db: PostgresDB, onCommit: (c: Commit) => void);
16
- getLastStoredWatermark(): Promise<string | null>;
17
- store(entry: WatermarkedChange): void;
18
- catchup(sub: Subscriber): void;
19
- run(): Promise<void>;
20
- stop(): Promise<void>;
21
- }
22
- //# sourceMappingURL=storer.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"storer.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/change-streamer/storer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAO5C,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,mBAAmB,CAAC;AAClD,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AAC3C,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,8BAA8B,CAAC;AACpE,OAAO,KAAK,EAAc,MAAM,EAAC,MAAM,sBAAsB,CAAC;AAC9D,OAAO,EAAC,UAAU,EAAC,MAAM,iBAAiB,CAAC;AAU3C;;;GAGG;AACH,qBAAa,MAAO,YAAW,OAAO;;IACpC,QAAQ,CAAC,EAAE,YAAY;IAKvB,QAAQ,CAAC,OAAO,wDAAqB;gBAEzB,EAAE,EAAE,UAAU,EAAE,EAAE,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC,EAAE,MAAM,KAAK,IAAI;IAMnE,sBAAsB,IAAI,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAOtD,KAAK,CAAC,KAAK,EAAE,iBAAiB;IAI9B,OAAO,CAAC,GAAG,EAAE,UAAU;IAIjB,GAAG;IAsIT,IAAI;CAIL"}
@@ -1,157 +0,0 @@
1
- import { LogContext } from '@rocicorp/logger';
2
- import { resolver } from '@rocicorp/resolver';
3
- import { assert } from '../../../../shared/src/asserts.js';
4
- import { Queue } from '../../../../shared/src/queue.js';
5
- import { promiseVoid } from '../../../../shared/src/resolved-promises.js';
6
- import { Mode, TransactionPool } from '../../db/transaction-pool.js';
7
- import { Subscriber } from './subscriber.js';
8
- /**
9
- * Handles the storage of changes and the catchup of subscribers
10
- * that are behind.
11
- */
12
- export class Storer {
13
- id = 'storer';
14
- #lc;
15
- #db;
16
- #onCommit;
17
- #queue = new Queue();
18
- stopped = resolver();
19
- constructor(lc, db, onCommit) {
20
- this.#lc = lc;
21
- this.#db = db;
22
- this.#onCommit = onCommit;
23
- }
24
- async getLastStoredWatermark() {
25
- const result = await this.#db `SELECT MAX(watermark) as max FROM cdc."ChangeLog"`;
26
- return result[0].max;
27
- }
28
- store(entry) {
29
- void this.#queue.enqueue(['change', entry]);
30
- }
31
- catchup(sub) {
32
- void this.#queue.enqueue(['subscriber', sub]);
33
- }
34
- async run() {
35
- let tx = null;
36
- let next;
37
- const catchupQueue = [];
38
- while ((next = await Promise.race([this.#queue.dequeue(), this.stopped.promise]))) {
39
- if (next[0] === 'subscriber') {
40
- const subscriber = next[1];
41
- if (tx) {
42
- catchupQueue.push(subscriber); // Wait for the current tx to complete.
43
- }
44
- else {
45
- this.#processCatchup([subscriber]); // Catch up immediately.
46
- }
47
- continue;
48
- }
49
- // next[0] === 'change'
50
- const [watermark, downstream] = next[1];
51
- const [tag, change] = downstream;
52
- if (tag === 'begin') {
53
- assert(!tx, 'received BEGIN in the middle of a transaction');
54
- tx = {
55
- pool: new TransactionPool(this.#lc.withContext('watermark', watermark), Mode.SERIALIZABLE),
56
- preCommitWatermark: watermark,
57
- pos: 0,
58
- };
59
- tx.pool.run(this.#db);
60
- }
61
- else {
62
- assert(tx, `received ${tag} outside of transaction`);
63
- tx.pos++;
64
- }
65
- const entry = {
66
- watermark: tag === 'commit' ? watermark : tx.preCommitWatermark,
67
- precommit: tag === 'commit' ? tx.preCommitWatermark : null,
68
- pos: tx.pos,
69
- change: change,
70
- };
71
- tx.pool.process(tx => [
72
- // Ignore conflicts to take into account transaction replay when an
73
- // acknowledgement doesn't reach upstream.
74
- tx `INSERT INTO cdc."ChangeLog" ${tx(entry)} ON CONFLICT DO NOTHING`,
75
- ]);
76
- if (tag === 'commit') {
77
- // Sanity check that there are no records between the preCommitWatermark
78
- // and the commit watermark.
79
- const { count } = await tx.pool.processReadTask(async (db) => {
80
- assert(tx);
81
- const results = await db `
82
- SELECT COUNT(*) as count FROM cdc."ChangeLog"
83
- WHERE watermark > ${tx.preCommitWatermark} AND
84
- watermark < ${entry.watermark}
85
- `;
86
- return results[0];
87
- });
88
- if (count > 0) {
89
- const err = new Error(`Unexpected entries between precommit ${tx.preCommitWatermark} and commit ${watermark}`);
90
- tx.pool.fail(err);
91
- await tx.pool.done();
92
- throw err; // tx.pool.done() throws, but this makes it clearer.
93
- }
94
- tx.pool.setDone();
95
- await tx.pool.done();
96
- tx = null;
97
- // ACK the LSN to the upstream Postgres.
98
- this.#onCommit(downstream);
99
- // Before beginning the next transaction, open a READONLY snapshot to
100
- // concurrently catchup any queued subscribers.
101
- this.#processCatchup(catchupQueue.splice(0));
102
- }
103
- }
104
- this.#lc.info?.('storer stopped');
105
- }
106
- #processCatchup(subs) {
107
- if (subs.length === 0) {
108
- return;
109
- }
110
- const reader = new TransactionPool(this.#lc.withContext('pool', 'catchup'), Mode.READONLY);
111
- reader.run(this.#db);
112
- // Run in the background. Errors are handled in #catchup() by disconnecting
113
- // the associated subscriber.
114
- void Promise.all(subs.map(sub => this.#catchup(sub, reader))).finally(() => reader.setDone());
115
- }
116
- async #catchup(sub, reader) {
117
- try {
118
- await reader.processReadTask(async (tx) => {
119
- const start = Date.now();
120
- let count = 0;
121
- for await (const entries of tx `
122
- SELECT watermark, change FROM cdc."ChangeLog"
123
- WHERE watermark > ${sub.watermark}
124
- ORDER BY watermark, pos`.cursor(10000)) {
125
- for (const entry of entries) {
126
- sub.catchup(toDownstream(entry));
127
- count++;
128
- }
129
- }
130
- // Flushes the backlog of messages buffered during catchup and
131
- // allows the subscription to forward subsequent messages immediately.
132
- sub.setCaughtUp();
133
- this.#lc.info?.(`caught up ${sub.id} with ${count} changes (${Date.now() - start} ms)`);
134
- });
135
- }
136
- catch (err) {
137
- sub.fail(err);
138
- this.#lc.error?.(`error while catching up subscriber ${sub.id}`, err);
139
- }
140
- }
141
- stop() {
142
- this.stopped.resolve(false);
143
- return promiseVoid;
144
- }
145
- }
146
- function toDownstream(entry) {
147
- const { watermark, change } = entry;
148
- switch (change.tag) {
149
- case 'begin':
150
- return [watermark, ['begin', change]];
151
- case 'commit':
152
- return [watermark, ['commit', change, { watermark }]];
153
- default:
154
- return [watermark, ['data', change]];
155
- }
156
- }
157
- //# sourceMappingURL=storer.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"storer.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/change-streamer/storer.ts"],"names":[],"mappings":"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"}
@@ -1,27 +0,0 @@
1
- import { Subscription } from '../../types/subscription.js';
2
- import type { WatermarkedChange } from './change-streamer-service.js';
3
- import { type Downstream, ErrorType } from './change-streamer.js';
4
- /**
5
- * Encapsulates a subscriber to changes. All subscribers start in a
6
- * "catchup" phase in which changes are buffered in a backlog while the
7
- * storer is queried to send any changes that were committed since the
8
- * subscriber's watermark. Once the catchup is complete, calls to
9
- * {@link send()} result in immediately sending the change.
10
- */
11
- export declare class Subscriber {
12
- #private;
13
- readonly id: string;
14
- constructor(id: string, watermark: string, downstream: Subscription<Downstream>);
15
- get watermark(): string;
16
- send(change: WatermarkedChange): void;
17
- /** catchup() is called on ChangeEntries loaded from the store. */
18
- catchup(change: WatermarkedChange): void;
19
- /**
20
- * Marks the Subscribe as "caught up" and flushes any backlog of
21
- * entries that were received during the catchup.
22
- */
23
- setCaughtUp(): void;
24
- fail(err?: unknown): void;
25
- close(error?: ErrorType, message?: string): void;
26
- }
27
- //# sourceMappingURL=subscriber.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"subscriber.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/change-streamer/subscriber.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,YAAY,EAAC,MAAM,6BAA6B,CAAC;AACzD,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,8BAA8B,CAAC;AACpE,OAAO,EAAC,KAAK,UAAU,EAAE,SAAS,EAAC,MAAM,sBAAsB,CAAC;AAEhE;;;;;;GAMG;AACH,qBAAa,UAAU;;IACrB,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;gBAMlB,EAAE,EAAE,MAAM,EACV,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,YAAY,CAAC,UAAU,CAAC;IAQtC,IAAI,SAAS,WAEZ;IAED,IAAI,CAAC,MAAM,EAAE,iBAAiB;IAW9B,kEAAkE;IAClE,OAAO,CAAC,MAAM,EAAE,iBAAiB;IAIjC;;;OAGG;IACH,WAAW;IAkBX,IAAI,CAAC,GAAG,CAAC,EAAE,OAAO;IAIlB,KAAK,CAAC,KAAK,CAAC,EAAE,SAAS,EAAE,OAAO,CAAC,EAAE,MAAM;CAM1C"}
@@ -1,70 +0,0 @@
1
- import { assert } from '../../../../shared/src/asserts.js';
2
- import { Subscription } from '../../types/subscription.js';
3
- import { ErrorType } from './change-streamer.js';
4
- /**
5
- * Encapsulates a subscriber to changes. All subscribers start in a
6
- * "catchup" phase in which changes are buffered in a backlog while the
7
- * storer is queried to send any changes that were committed since the
8
- * subscriber's watermark. Once the catchup is complete, calls to
9
- * {@link send()} result in immediately sending the change.
10
- */
11
- export class Subscriber {
12
- id;
13
- #downstream;
14
- #watermark;
15
- #backlog;
16
- constructor(id, watermark, downstream) {
17
- this.id = id;
18
- this.#downstream = downstream;
19
- this.#watermark = watermark;
20
- this.#backlog = [];
21
- }
22
- get watermark() {
23
- return this.#watermark;
24
- }
25
- send(change) {
26
- const [watermark] = change;
27
- if (watermark > this.#watermark) {
28
- if (this.#backlog) {
29
- this.#backlog.push(change);
30
- }
31
- else {
32
- this.#send(change);
33
- }
34
- }
35
- }
36
- /** catchup() is called on ChangeEntries loaded from the store. */
37
- catchup(change) {
38
- this.#send(change);
39
- }
40
- /**
41
- * Marks the Subscribe as "caught up" and flushes any backlog of
42
- * entries that were received during the catchup.
43
- */
44
- setCaughtUp() {
45
- assert(this.#backlog);
46
- for (const change of this.#backlog) {
47
- this.#send(change);
48
- }
49
- this.#backlog = null;
50
- }
51
- #send(change) {
52
- const [watermark, downstream] = change;
53
- if (watermark > this.watermark) {
54
- this.#downstream.push(downstream);
55
- if (downstream[0] === 'commit') {
56
- this.#watermark = watermark;
57
- }
58
- }
59
- }
60
- fail(err) {
61
- this.close(ErrorType.Unknown, String(err));
62
- }
63
- close(error, message) {
64
- if (error) {
65
- this.#downstream.push(['error', { type: error, message }]);
66
- }
67
- this.#downstream.cancel();
68
- }
69
- }
70
- //# sourceMappingURL=subscriber.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"subscriber.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/change-streamer/subscriber.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAC,MAAM,mCAAmC,CAAC;AACzD,OAAO,EAAC,YAAY,EAAC,MAAM,6BAA6B,CAAC;AAEzD,OAAO,EAAkB,SAAS,EAAC,MAAM,sBAAsB,CAAC;AAEhE;;;;;;GAMG;AACH,MAAM,OAAO,UAAU;IACZ,EAAE,CAAS;IACX,WAAW,CAA2B;IAC/C,UAAU,CAAS;IACnB,QAAQ,CAA6B;IAErC,YACE,EAAU,EACV,SAAiB,EACjB,UAAoC;QAEpC,IAAI,CAAC,EAAE,GAAG,EAAE,CAAC;QACb,IAAI,CAAC,WAAW,GAAG,UAAU,CAAC;QAC9B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;QAC5B,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IAED,IAAI,CAAC,MAAyB;QAC5B,MAAM,CAAC,SAAS,CAAC,GAAG,MAAM,CAAC;QAC3B,IAAI,SAAS,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAChC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YAC7B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACrB,CAAC;QACH,CAAC;IACH,CAAC;IAED,kEAAkE;IAClE,OAAO,CAAC,MAAyB;QAC/B,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACrB,CAAC;IAED;;;OAGG;IACH,WAAW;QACT,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACtB,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACrB,CAAC;QACD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IACvB,CAAC;IAED,KAAK,CAAC,MAAyB;QAC7B,MAAM,CAAC,SAAS,EAAE,UAAU,CAAC,GAAG,MAAM,CAAC;QACvC,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAC/B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAClC,IAAI,UAAU,CAAC,CAAC,CAAC,KAAK,QAAQ,EAAE,CAAC;gBAC/B,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;YAC9B,CAAC;QACH,CAAC;IACH,CAAC;IAED,IAAI,CAAC,GAAa;QAChB,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,OAAO,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC;IAC7C,CAAC;IAED,KAAK,CAAC,KAAiB,EAAE,OAAgB;QACvC,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAC,IAAI,EAAE,KAAK,EAAE,OAAO,EAAC,CAAC,CAAC,CAAC;QAC3D,CAAC;QACD,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;IAC5B,CAAC;CACF"}
@@ -1,21 +0,0 @@
1
- import type { IncomingHttpHeaders } from 'node:http2';
2
- export type ConnectParams = {
3
- readonly clientID: string;
4
- readonly clientGroupID: string;
5
- readonly schemaVersion: number;
6
- readonly baseCookie: string | null;
7
- readonly timestamp: number;
8
- readonly lmID: number;
9
- readonly wsID: string;
10
- readonly debugPerf: boolean;
11
- readonly auth: string | undefined;
12
- readonly userID: string;
13
- };
14
- export declare function getConnectParams(url: URL, headers: IncomingHttpHeaders): {
15
- params: ConnectParams;
16
- error: null;
17
- } | {
18
- params: null;
19
- error: string;
20
- };
21
- //# sourceMappingURL=connect-params.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"connect-params.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/connect-params.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,mBAAmB,EAAC,MAAM,YAAY,CAAC;AAGpD,MAAM,MAAM,aAAa,GAAG;IAC1B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,aAAa,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,UAAU,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,SAAS,EAAE,OAAO,CAAC;IAC5B,QAAQ,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,CAAC;IAClC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;CACzB,CAAC;AAEF,wBAAgB,gBAAgB,CAC9B,GAAG,EAAE,GAAG,EACR,OAAO,EAAE,mBAAmB,GAE1B;IACE,MAAM,EAAE,aAAa,CAAC;IACtB,KAAK,EAAE,IAAI,CAAC;CACb,GACD;IACE,MAAM,EAAE,IAAI,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;CACf,CAoCJ"}
@@ -1,38 +0,0 @@
1
- import { URLParams } from '../../types/url-params.js';
2
- export function getConnectParams(url, headers) {
3
- const params = new URLParams(url);
4
- try {
5
- const clientID = params.get('clientID', true);
6
- const clientGroupID = params.get('clientGroupID', true);
7
- const schemaVersion = params.getInteger('schemaVersion', true);
8
- const baseCookie = params.get('baseCookie', false);
9
- const timestamp = params.getInteger('ts', true);
10
- const lmID = params.getInteger('lmid', true);
11
- const wsID = params.get('wsid', false) ?? '';
12
- const userID = params.get('userID', false) ?? '';
13
- const debugPerf = params.getBoolean('debugPerf');
14
- const maybeAuthToken = headers['sec-websocket-protocol'];
15
- return {
16
- params: {
17
- clientID,
18
- clientGroupID,
19
- schemaVersion,
20
- baseCookie,
21
- timestamp,
22
- lmID,
23
- wsID,
24
- debugPerf,
25
- auth: maybeAuthToken ? decodeURIComponent(maybeAuthToken) : undefined,
26
- userID,
27
- },
28
- error: null,
29
- };
30
- }
31
- catch (e) {
32
- return {
33
- params: null,
34
- error: e instanceof Error ? e.message : String(e),
35
- };
36
- }
37
- }
38
- //# sourceMappingURL=connect-params.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"connect-params.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/connect-params.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,SAAS,EAAC,MAAM,2BAA2B,CAAC;AAepD,MAAM,UAAU,gBAAgB,CAC9B,GAAQ,EACR,OAA4B;IAU5B,MAAM,MAAM,GAAG,IAAI,SAAS,CAAC,GAAG,CAAC,CAAC;IAElC,IAAI,CAAC;QACH,MAAM,QAAQ,GAAG,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,IAAI,CAAC,CAAC;QAC9C,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QACxD,MAAM,aAAa,GAAG,MAAM,CAAC,UAAU,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAC/D,MAAM,UAAU,GAAG,MAAM,CAAC,GAAG,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;QACnD,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;QAChD,MAAM,IAAI,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC7C,MAAM,IAAI,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;QAC7C,MAAM,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;QACjD,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;QAEjD,MAAM,cAAc,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAAC;QACzD,OAAO;YACL,MAAM,EAAE;gBACN,QAAQ;gBACR,aAAa;gBACb,aAAa;gBACb,UAAU;gBACV,SAAS;gBACT,IAAI;gBACJ,IAAI;gBACJ,SAAS;gBACT,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,SAAS;gBACrE,MAAM;aACP;YACD,KAAK,EAAE,IAAI;SACZ,CAAC;IACJ,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACX,OAAO;YACL,MAAM,EAAE,IAAI;YACZ,KAAK,EAAE,CAAC,YAAY,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC;SAClD,CAAC;IACJ,CAAC;AACH,CAAC"}
@@ -1,19 +0,0 @@
1
- import { LogContext } from '@rocicorp/logger';
2
- import type { Worker } from '../../types/processes.js';
3
- import type { Service } from '../service.js';
4
- export declare const CONNECT_URL_PATTERN = "/api/sync/:version/connect";
5
- export type Workers = {
6
- syncers: Worker[];
7
- };
8
- export declare const DEFAULT_PORT = 4848;
9
- export type Options = {
10
- port: number;
11
- };
12
- export declare class Dispatcher implements Service {
13
- #private;
14
- readonly id = "dispatcher";
15
- constructor(lc: LogContext, workersByHostname: (hostname: string) => Workers, opts?: Partial<Options>);
16
- run(): Promise<void>;
17
- stop(): Promise<void>;
18
- }
19
- //# sourceMappingURL=dispatcher.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dispatcher.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/dispatcher.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAI5C,OAAO,KAAK,EAAC,MAAM,EAAC,MAAM,0BAA0B,CAAC;AACrD,OAAO,KAAK,EAAC,OAAO,EAAC,MAAM,eAAe,CAAC;AAI3C,eAAO,MAAM,mBAAmB,+BAA+B,CAAC;AAEhE,MAAM,MAAM,OAAO,GAAG;IACpB,OAAO,EAAE,MAAM,EAAE,CAAC;CACnB,CAAC;AAEF,eAAO,MAAM,YAAY,OAAO,CAAC;AAEjC,MAAM,MAAM,OAAO,GAAG;IACpB,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,qBAAa,UAAW,YAAW,OAAO;;IACxC,QAAQ,CAAC,EAAE,gBAAgB;gBAOzB,EAAE,EAAE,UAAU,EACd,iBAAiB,EAAE,CAAC,QAAQ,EAAE,MAAM,KAAK,OAAO,EAChD,IAAI,GAAE,OAAO,CAAC,OAAO,CAAM;IAsCvB,GAAG,IAAI,OAAO,CAAC,IAAI,CAAC;IAOpB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAG5B"}
@@ -1,54 +0,0 @@
1
- import { LogContext } from '@rocicorp/logger';
2
- import Fastify, {} from 'fastify';
3
- import { IncomingMessage } from 'http';
4
- import { h32 } from '../../../../shared/src/xxhash.js';
5
- import { getConnectParams } from './connect-params.js';
6
- import { installWebSocketHandoff } from './websocket-handoff.js';
7
- export const CONNECT_URL_PATTERN = '/api/sync/:version/connect';
8
- export const DEFAULT_PORT = 4848;
9
- export class Dispatcher {
10
- id = 'dispatcher';
11
- #lc;
12
- #workersByHostname;
13
- #fastify;
14
- #port;
15
- constructor(lc, workersByHostname, opts = {}) {
16
- const { port = DEFAULT_PORT } = opts;
17
- this.#lc = lc;
18
- this.#workersByHostname = workersByHostname;
19
- this.#fastify = Fastify();
20
- this.#fastify.get('/', (_req, res) => res.send('OK'));
21
- this.#fastify.addHook('onRequest', (req, _, done) => {
22
- this.#lc?.debug?.(`received request`, req.hostname, req.url);
23
- done();
24
- });
25
- this.#port = port;
26
- installWebSocketHandoff(this.#fastify.server, req => this.#handoff(req));
27
- }
28
- #handoff(req) {
29
- const { headers, url } = req;
30
- const { params, error } = getConnectParams(new URL(url ?? '', 'http://unused/'), headers);
31
- if (error !== null) {
32
- throw new Error(error);
33
- }
34
- const { host } = headers;
35
- if (!host) {
36
- throw new Error('Missing Host field');
37
- }
38
- const { clientGroupID } = params;
39
- const { syncers } = this.#workersByHostname(host);
40
- const syncer = h32(clientGroupID) % syncers.length;
41
- this.#lc.debug?.(`connecting ${clientGroupID} to syncer ${syncer}`);
42
- return { payload: params, receiver: syncers[syncer] };
43
- }
44
- async run() {
45
- const address = await this.#fastify.listen({
46
- port: this.#port,
47
- });
48
- this.#lc.info?.(`Server listening at ${address}`);
49
- }
50
- async stop() {
51
- await this.#fastify.close();
52
- }
53
- }
54
- //# sourceMappingURL=dispatcher.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dispatcher.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/dispatcher.ts"],"names":[],"mappings":"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"}
@@ -1,11 +0,0 @@
1
- import { IncomingMessage, Server } from 'node:http';
2
- import type { WebSocket, WebSocketServer } from 'ws';
3
- import { type Receiver, type Sender } from '../../types/processes.js';
4
- export type WebSocketHandoff<P> = (message: IncomingMessage) => {
5
- payload: P;
6
- receiver: Receiver;
7
- };
8
- export type WebSocketReceiver<P> = (ws: WebSocket, payload: P) => void;
9
- export declare function installWebSocketHandoff<P>(server: Server, handoff: WebSocketHandoff<P>): void;
10
- export declare function installWebSocketReceiver<P>(server: WebSocketServer, receive: WebSocketReceiver<P>, sender: Sender): void;
11
- //# sourceMappingURL=websocket-handoff.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"websocket-handoff.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/websocket-handoff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAE,MAAM,EAAC,MAAM,WAAW,CAAC;AAElD,OAAO,KAAK,EAAC,SAAS,EAAE,eAAe,EAAC,MAAM,IAAI,CAAC;AACnD,OAAO,EAEL,KAAK,QAAQ,EACb,KAAK,MAAM,EACZ,MAAM,0BAA0B,CAAC;AAElC,MAAM,MAAM,gBAAgB,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,eAAe,KAAK;IAC9D,OAAO,EAAE,CAAC,CAAC;IACX,QAAQ,EAAE,QAAQ,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,iBAAiB,CAAC,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,KAAK,IAAI,CAAC;AAEvE,wBAAgB,uBAAuB,CAAC,CAAC,EACvC,MAAM,EAAE,MAAM,EACd,OAAO,EAAE,gBAAgB,CAAC,CAAC,CAAC,QAwB7B;AAED,wBAAgB,wBAAwB,CAAC,CAAC,EACxC,MAAM,EAAE,eAAe,EACvB,OAAO,EAAE,iBAAiB,CAAC,CAAC,CAAC,EAC7B,MAAM,EAAE,MAAM,QAWf"}
@@ -1,33 +0,0 @@
1
- import { IncomingMessage, Server } from 'node:http';
2
- import { Socket } from 'node:net';
3
- import { MESSAGE_TYPES, } from '../../types/processes.js';
4
- export function installWebSocketHandoff(server, handoff) {
5
- server.on('upgrade', (req, socket, head) => {
6
- try {
7
- const { payload, receiver } = handoff(req);
8
- const { headers, method = 'GET' } = req;
9
- const data = [
10
- 'handoff',
11
- {
12
- message: { headers, method },
13
- head,
14
- payload,
15
- },
16
- ];
17
- // "This event is guaranteed to be passed an instance of the <net.Socket> class"
18
- // https://nodejs.org/api/http.html#event-upgrade
19
- receiver.send(data, socket);
20
- }
21
- catch (error) {
22
- socket.write(`HTTP/1.1 400 Bad Request\r\n${String(error)}`);
23
- return;
24
- }
25
- });
26
- }
27
- export function installWebSocketReceiver(server, receive, sender) {
28
- sender.onMessageType('handoff', (msg, socket) => {
29
- const { message, head, payload } = msg;
30
- server.handleUpgrade(message, socket, Buffer.from(head), ws => receive(ws, payload));
31
- });
32
- }
33
- //# sourceMappingURL=websocket-handoff.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"websocket-handoff.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/dispatcher/websocket-handoff.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,eAAe,EAAE,MAAM,EAAC,MAAM,WAAW,CAAC;AAClD,OAAO,EAAC,MAAM,EAAC,MAAM,UAAU,CAAC;AAEhC,OAAO,EACL,aAAa,GAGd,MAAM,0BAA0B,CAAC;AASlC,MAAM,UAAU,uBAAuB,CACrC,MAAc,EACd,OAA4B;IAE5B,MAAM,CAAC,EAAE,CAAC,SAAS,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE;QACzC,IAAI,CAAC;YACH,MAAM,EAAC,OAAO,EAAE,QAAQ,EAAC,GAAG,OAAO,CAAC,GAAG,CAAC,CAAC;YACzC,MAAM,EAAC,OAAO,EAAE,MAAM,GAAG,KAAK,EAAC,GAAG,GAAG,CAAC;YAEtC,MAAM,IAAI,GAAG;gBACX,SAAS;gBACT;oBACE,OAAO,EAAE,EAAC,OAAO,EAAE,MAAM,EAAC;oBAC1B,IAAI;oBACJ,OAAO;iBACR;aACmB,CAAC;YAEvB,gFAAgF;YAChF,iDAAiD;YACjD,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,MAAgB,CAAC,CAAC;QACxC,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,KAAK,CAAC,+BAA+B,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;YAC7D,OAAO;QACT,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,wBAAwB,CACtC,MAAuB,EACvB,OAA6B,EAC7B,MAAc;IAEd,MAAM,CAAC,aAAa,CAAa,SAAS,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;QAC1D,MAAM,EAAC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAC,GAAG,GAAG,CAAC;QACrC,MAAM,CAAC,aAAa,CAClB,OAA0B,EAC1B,MAAgB,EAChB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EACjB,EAAE,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,EAAE,OAAO,CAAC,CAC3B,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -1,57 +0,0 @@
1
- type Window = {
2
- start: number;
3
- count: number;
4
- };
5
- /**
6
- * The limiter is a sliding window rate limiter that allows a maximum
7
- * number of mutations per window.
8
- *
9
- * The window is divided into two parts: the prev window and the next window.
10
- * The prev window is the part of the window that has already passed, and the
11
- * next window is the part of the window that is still in the future.
12
- *
13
- * The limiter keeps track of the number of mutations in each window. When the
14
- * current time moves completely past the next window, the limiter creates new
15
- * windows (this only happens if the limiter is not called for a long time).
16
- * When the current time moves completely into the next window, the
17
- * limiter rotates the windows.
18
- *
19
- * Case 1: need new windows
20
- * |----|----|
21
- * |----| (sliding window)
22
- *
23
- * Case 2: rotate windows
24
- * |----|----|
25
- * |----| (sliding window)
26
- *
27
- * or
28
- *
29
- * |----|----|
30
- * |----| (sliding window)
31
- *
32
- * The leading edge of the sliding window is current time.
33
- *
34
- * The limiter increments the count for the prev window if the current time is
35
- * in the prior window. Otherwise, it increments the count for the next
36
- * window.
37
- *
38
- * The limiter computes the total mutations by: taking the number of mutation in the next window and
39
- * adding the number of mutation from the prev window, weighted by
40
- * the fraction of the window that has passed. The total mutations must be less
41
- * than the maximum number of mutations allowed per window.
42
- *
43
- * |----|----|
44
- * |----| (sliding window)
45
- * ^-- the sliding window covers 25% of the prior window. Only 25% of that window's count counts.
46
- * The entirety of the next window's count counts.
47
- */
48
- export declare class SlidingWindowLimiter {
49
- #private;
50
- constructor(windowSizeMs: number, maxMutations: number);
51
- canDo(): boolean;
52
- totalCallsForTime(now: number): number;
53
- get priorWindow(): Window;
54
- get nextWindow(): Window;
55
- }
56
- export {};
57
- //# sourceMappingURL=sliding-window-limiter.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"sliding-window-limiter.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/limiter/sliding-window-limiter.ts"],"names":[],"mappings":"AAEA,KAAK,MAAM,GAAG;IACZ,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA0CG;AACH,qBAAa,oBAAoB;;gBAOnB,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM;IAOtD,KAAK,IAAI,OAAO;IAsChB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM;IAuBtC,IAAI,WAAW,IAAI,MAAM,CAExB;IAED,IAAI,UAAU,IAAI,MAAM,CAEvB;CA4BF"}