@rocicorp/zero 0.25.0-canary.7 → 0.25.0-canary.8

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 (1332) hide show
  1. package/out/analyze-query/src/bin-analyze.js +258 -236
  2. package/out/analyze-query/src/bin-analyze.js.map +1 -1
  3. package/out/analyze-query/src/bin-transform.js +31 -23
  4. package/out/analyze-query/src/bin-transform.js.map +1 -1
  5. package/out/analyze-query/src/explain-queries.js +13 -16
  6. package/out/analyze-query/src/explain-queries.js.map +1 -1
  7. package/out/analyze-query/src/run-ast.d.ts +3 -2
  8. package/out/analyze-query/src/run-ast.d.ts.map +1 -1
  9. package/out/analyze-query/src/run-ast.js +79 -73
  10. package/out/analyze-query/src/run-ast.js.map +1 -1
  11. package/out/ast-to-zql/src/ast-to-zql.js +146 -180
  12. package/out/ast-to-zql/src/ast-to-zql.js.map +1 -1
  13. package/out/ast-to-zql/src/bin.js +51 -54
  14. package/out/ast-to-zql/src/bin.js.map +1 -1
  15. package/out/ast-to-zql/src/format.js +15 -14
  16. package/out/ast-to-zql/src/format.js.map +1 -1
  17. package/out/datadog/src/datadog-log-sink.js +223 -0
  18. package/out/datadog/src/datadog-log-sink.js.map +1 -0
  19. package/out/otel/src/enabled.js +15 -15
  20. package/out/otel/src/enabled.js.map +1 -1
  21. package/out/otel/src/log-options.js +36 -31
  22. package/out/otel/src/log-options.js.map +1 -1
  23. package/out/otel/src/maybe-time.js +14 -11
  24. package/out/otel/src/maybe-time.js.map +1 -1
  25. package/out/otel/src/span.js +30 -27
  26. package/out/otel/src/span.js.map +1 -1
  27. package/out/otel/src/test-log-config.js +10 -7
  28. package/out/otel/src/test-log-config.js.map +1 -1
  29. package/out/otel/src/version.js +5 -2
  30. package/out/otel/src/version.js.map +1 -1
  31. package/out/replicache/src/async-iterable-to-array.js +11 -0
  32. package/out/replicache/src/async-iterable-to-array.js.map +1 -0
  33. package/out/replicache/src/bg-interval.js +38 -0
  34. package/out/replicache/src/bg-interval.js.map +1 -0
  35. package/out/replicache/src/btree/diff.js +8 -0
  36. package/out/replicache/src/btree/diff.js.map +1 -0
  37. package/out/replicache/src/btree/node.js +400 -0
  38. package/out/replicache/src/btree/node.js.map +1 -0
  39. package/out/replicache/src/btree/read.d.ts +3 -2
  40. package/out/replicache/src/btree/read.d.ts.map +1 -1
  41. package/out/replicache/src/btree/read.js +266 -0
  42. package/out/replicache/src/btree/read.js.map +1 -0
  43. package/out/replicache/src/btree/splice.js +83 -0
  44. package/out/replicache/src/btree/splice.js.map +1 -0
  45. package/out/replicache/src/btree/write.d.ts +1 -1
  46. package/out/replicache/src/btree/write.d.ts.map +1 -1
  47. package/out/replicache/src/btree/write.js +163 -0
  48. package/out/replicache/src/btree/write.js.map +1 -0
  49. package/out/replicache/src/call-default-fetch.js +34 -0
  50. package/out/replicache/src/call-default-fetch.js.map +1 -0
  51. package/out/replicache/src/connection-loop-delegates.js +34 -0
  52. package/out/replicache/src/connection-loop-delegates.js.map +1 -0
  53. package/out/replicache/src/connection-loop.js +251 -0
  54. package/out/replicache/src/connection-loop.js.map +1 -0
  55. package/out/replicache/src/cookies.js +40 -0
  56. package/out/replicache/src/cookies.js.map +1 -0
  57. package/out/replicache/src/dag/chunk.js +59 -0
  58. package/out/replicache/src/dag/chunk.js.map +1 -0
  59. package/out/replicache/src/dag/gc.js +117 -0
  60. package/out/replicache/src/dag/gc.js.map +1 -0
  61. package/out/replicache/src/dag/key.js +20 -0
  62. package/out/replicache/src/dag/key.js.map +1 -0
  63. package/out/replicache/src/dag/lazy-store.d.ts +2 -1
  64. package/out/replicache/src/dag/lazy-store.d.ts.map +1 -1
  65. package/out/replicache/src/dag/lazy-store.js +515 -0
  66. package/out/replicache/src/dag/lazy-store.js.map +1 -0
  67. package/out/replicache/src/dag/store-impl.js +183 -0
  68. package/out/replicache/src/dag/store-impl.js.map +1 -0
  69. package/out/replicache/src/dag/store.js +27 -0
  70. package/out/replicache/src/dag/store.js.map +1 -0
  71. package/out/replicache/src/dag/visitor.js +22 -0
  72. package/out/replicache/src/dag/visitor.js.map +1 -0
  73. package/out/replicache/src/db/commit.js +358 -0
  74. package/out/replicache/src/db/commit.js.map +1 -0
  75. package/out/replicache/src/db/index-operation-enum.js +7 -0
  76. package/out/replicache/src/db/index-operation-enum.js.map +1 -0
  77. package/out/replicache/src/db/index.js +134 -0
  78. package/out/replicache/src/db/index.js.map +1 -0
  79. package/out/replicache/src/db/meta-type-enum.js +7 -0
  80. package/out/replicache/src/db/meta-type-enum.js.map +1 -0
  81. package/out/replicache/src/db/read.d.ts +3 -2
  82. package/out/replicache/src/db/read.d.ts.map +1 -1
  83. package/out/replicache/src/db/read.js +72 -0
  84. package/out/replicache/src/db/read.js.map +1 -0
  85. package/out/replicache/src/db/rebase.d.ts +2 -2
  86. package/out/replicache/src/db/rebase.d.ts.map +1 -1
  87. package/out/replicache/src/db/rebase.js +85 -0
  88. package/out/replicache/src/db/rebase.js.map +1 -0
  89. package/out/replicache/src/db/write.d.ts +2 -1
  90. package/out/replicache/src/db/write.d.ts.map +1 -1
  91. package/out/replicache/src/db/write.js +296 -0
  92. package/out/replicache/src/db/write.js.map +1 -0
  93. package/out/replicache/src/deleted-clients.js +104 -0
  94. package/out/replicache/src/deleted-clients.js.map +1 -0
  95. package/out/replicache/src/error-responses.js +34 -0
  96. package/out/replicache/src/error-responses.js.map +1 -0
  97. package/out/replicache/src/format-version-enum.js +11 -0
  98. package/out/replicache/src/format-version-enum.js.map +1 -0
  99. package/out/{chunk-EZM3XBAB.js → replicache/src/frozen-json.js} +8 -75
  100. package/out/replicache/src/frozen-json.js.map +1 -0
  101. package/out/replicache/src/get-default-puller.js +61 -0
  102. package/out/replicache/src/get-default-puller.js.map +1 -0
  103. package/out/replicache/src/get-default-pusher.js +39 -0
  104. package/out/replicache/src/get-default-pusher.js.map +1 -0
  105. package/out/replicache/src/get-kv-store-provider.js +23 -0
  106. package/out/replicache/src/get-kv-store-provider.js.map +1 -0
  107. package/out/replicache/src/hash.js +38 -0
  108. package/out/replicache/src/hash.js.map +1 -0
  109. package/out/replicache/src/http-request-info.js +10 -0
  110. package/out/replicache/src/http-request-info.js.map +1 -0
  111. package/out/replicache/src/http-status-unauthorized.js +5 -0
  112. package/out/replicache/src/http-status-unauthorized.js.map +1 -0
  113. package/out/replicache/src/index-defs.js +32 -0
  114. package/out/replicache/src/index-defs.js.map +1 -0
  115. package/out/replicache/src/invoke-kind-enum.js +7 -0
  116. package/out/replicache/src/invoke-kind-enum.js.map +1 -0
  117. package/out/{chunk-HCZQVP5R.js → replicache/src/kv/expo-sqlite/store.js} +8 -16
  118. package/out/replicache/src/kv/expo-sqlite/store.js.map +1 -0
  119. package/out/replicache/src/kv/idb-store-with-mem-fallback.js +80 -0
  120. package/out/replicache/src/kv/idb-store-with-mem-fallback.js.map +1 -0
  121. package/out/replicache/src/kv/idb-store.js +183 -0
  122. package/out/replicache/src/kv/idb-store.js.map +1 -0
  123. package/out/replicache/src/kv/mem-store.js +51 -0
  124. package/out/replicache/src/kv/mem-store.js.map +1 -0
  125. package/out/{op-sqlite.js → replicache/src/kv/op-sqlite/store.js} +7 -18
  126. package/out/replicache/src/kv/op-sqlite/store.js.map +1 -0
  127. package/out/replicache/src/kv/op-sqlite/types.js +6 -0
  128. package/out/replicache/src/kv/op-sqlite/types.js.map +1 -0
  129. package/out/replicache/src/kv/read-impl.js +27 -0
  130. package/out/replicache/src/kv/read-impl.js.map +1 -0
  131. package/out/{chunk-WPAQ4EPM.js → replicache/src/kv/sqlite-store.js} +15 -19
  132. package/out/replicache/src/kv/sqlite-store.js.map +1 -0
  133. package/out/{chunk-ASRS2LFV.js → replicache/src/kv/throw-if-closed.js} +4 -6
  134. package/out/replicache/src/kv/throw-if-closed.js.map +1 -0
  135. package/out/replicache/src/kv/write-impl-base.js +57 -0
  136. package/out/replicache/src/kv/write-impl-base.js.map +1 -0
  137. package/out/replicache/src/kv/write-impl.js +30 -0
  138. package/out/replicache/src/kv/write-impl.js.map +1 -0
  139. package/out/replicache/src/lazy.js +13 -0
  140. package/out/replicache/src/lazy.js.map +1 -0
  141. package/out/replicache/src/log-options.js +9 -0
  142. package/out/replicache/src/log-options.js.map +1 -0
  143. package/out/replicache/src/make-idb-name.js +13 -0
  144. package/out/replicache/src/make-idb-name.js.map +1 -0
  145. package/out/replicache/src/new-client-channel.js +51 -0
  146. package/out/replicache/src/new-client-channel.js.map +1 -0
  147. package/out/replicache/src/on-persist-channel.js +36 -0
  148. package/out/replicache/src/on-persist-channel.js.map +1 -0
  149. package/out/replicache/src/patch-operation.js +42 -0
  150. package/out/replicache/src/patch-operation.js.map +1 -0
  151. package/out/replicache/src/pending-mutations.js +16 -0
  152. package/out/replicache/src/pending-mutations.js.map +1 -0
  153. package/out/replicache/src/persist/client-gc.js +58 -0
  154. package/out/replicache/src/persist/client-gc.js.map +1 -0
  155. package/out/replicache/src/persist/client-group-gc.js +43 -0
  156. package/out/replicache/src/persist/client-group-gc.js.map +1 -0
  157. package/out/replicache/src/persist/client-groups.js +184 -0
  158. package/out/replicache/src/persist/client-groups.js.map +1 -0
  159. package/out/replicache/src/persist/clients.d.ts +3 -2
  160. package/out/replicache/src/persist/clients.d.ts.map +1 -1
  161. package/out/replicache/src/persist/clients.js +353 -0
  162. package/out/replicache/src/persist/clients.js.map +1 -0
  163. package/out/replicache/src/persist/collect-idb-databases.js +188 -0
  164. package/out/replicache/src/persist/collect-idb-databases.js.map +1 -0
  165. package/out/replicache/src/persist/gather-mem-only-visitor.js +27 -0
  166. package/out/replicache/src/persist/gather-mem-only-visitor.js.map +1 -0
  167. package/out/replicache/src/persist/gather-not-cached-visitor.js +37 -0
  168. package/out/replicache/src/persist/gather-not-cached-visitor.js.map +1 -0
  169. package/out/replicache/src/persist/heartbeat.js +48 -0
  170. package/out/replicache/src/persist/heartbeat.js.map +1 -0
  171. package/out/replicache/src/persist/idb-databases-store-db-name.js +14 -0
  172. package/out/replicache/src/persist/idb-databases-store-db-name.js.map +1 -0
  173. package/out/replicache/src/persist/idb-databases-store.js +92 -0
  174. package/out/replicache/src/persist/idb-databases-store.js.map +1 -0
  175. package/out/replicache/src/persist/make-client-id.js +12 -0
  176. package/out/replicache/src/persist/make-client-id.js.map +1 -0
  177. package/out/replicache/src/persist/persist.d.ts +2 -2
  178. package/out/replicache/src/persist/persist.d.ts.map +1 -1
  179. package/out/replicache/src/persist/persist.js +183 -0
  180. package/out/replicache/src/persist/persist.js.map +1 -0
  181. package/out/replicache/src/persist/refresh.d.ts +4 -3
  182. package/out/replicache/src/persist/refresh.d.ts.map +1 -1
  183. package/out/replicache/src/persist/refresh.js +198 -0
  184. package/out/replicache/src/persist/refresh.js.map +1 -0
  185. package/out/replicache/src/process-scheduler.js +96 -0
  186. package/out/replicache/src/process-scheduler.js.map +1 -0
  187. package/out/replicache/src/pusher.js +33 -0
  188. package/out/replicache/src/pusher.js.map +1 -0
  189. package/out/replicache/src/replicache-impl.d.ts +1 -1
  190. package/out/replicache/src/replicache-impl.d.ts.map +1 -1
  191. package/out/replicache/src/replicache-impl.js +1200 -0
  192. package/out/replicache/src/replicache-impl.js.map +1 -0
  193. package/out/replicache/src/report-error.js +6 -0
  194. package/out/replicache/src/report-error.js.map +1 -0
  195. package/out/replicache/src/request-idle.js +13 -0
  196. package/out/replicache/src/request-idle.js.map +1 -0
  197. package/out/replicache/src/scan-iterator.js +146 -0
  198. package/out/replicache/src/scan-iterator.js.map +1 -0
  199. package/out/replicache/src/scan-options.js +45 -0
  200. package/out/replicache/src/scan-options.js.map +1 -0
  201. package/out/replicache/src/set-interval-with-signal.js +12 -0
  202. package/out/replicache/src/set-interval-with-signal.js.map +1 -0
  203. package/out/replicache/src/subscriptions.js +355 -0
  204. package/out/replicache/src/subscriptions.js.map +1 -0
  205. package/out/replicache/src/sync/diff.d.ts +3 -2
  206. package/out/replicache/src/sync/diff.d.ts.map +1 -1
  207. package/out/replicache/src/sync/diff.js +72 -0
  208. package/out/replicache/src/sync/diff.js.map +1 -0
  209. package/out/replicache/src/sync/handle-pull-response-result-type-enum.js +9 -0
  210. package/out/replicache/src/sync/handle-pull-response-result-type-enum.js.map +1 -0
  211. package/out/replicache/src/sync/ids.js +9 -0
  212. package/out/replicache/src/sync/ids.js.map +1 -0
  213. package/out/replicache/src/sync/patch.js +49 -0
  214. package/out/replicache/src/sync/patch.js.map +1 -0
  215. package/out/replicache/src/sync/pull-error.js +16 -0
  216. package/out/replicache/src/sync/pull-error.js.map +1 -0
  217. package/out/replicache/src/sync/pull.d.ts +3 -2
  218. package/out/replicache/src/sync/pull.d.ts.map +1 -1
  219. package/out/replicache/src/sync/pull.js +301 -0
  220. package/out/replicache/src/sync/pull.js.map +1 -0
  221. package/out/replicache/src/sync/push.js +88 -0
  222. package/out/replicache/src/sync/push.js.map +1 -0
  223. package/out/replicache/src/sync/request-id.js +20 -0
  224. package/out/replicache/src/sync/request-id.js.map +1 -0
  225. package/out/replicache/src/sync/sync-head-name.js +5 -0
  226. package/out/replicache/src/sync/sync-head-name.js.map +1 -0
  227. package/out/replicache/src/to-error.js +10 -0
  228. package/out/replicache/src/to-error.js.map +1 -0
  229. package/out/replicache/src/transaction-closed-error.js +19 -0
  230. package/out/replicache/src/transaction-closed-error.js.map +1 -0
  231. package/out/replicache/src/transactions.js +152 -0
  232. package/out/replicache/src/transactions.js.map +1 -0
  233. package/out/replicache/src/version.js +5 -0
  234. package/out/replicache/src/version.js.map +1 -0
  235. package/out/replicache/src/with-transactions.js +28 -0
  236. package/out/replicache/src/with-transactions.js.map +1 -0
  237. package/out/shared/src/abort-error.js +6 -3
  238. package/out/shared/src/abort-error.js.map +1 -1
  239. package/out/shared/src/arrays.js +45 -43
  240. package/out/shared/src/arrays.js.map +1 -1
  241. package/out/shared/src/asserts.js +64 -68
  242. package/out/shared/src/asserts.js.map +1 -1
  243. package/out/shared/src/bigint-json.js +38 -42
  244. package/out/shared/src/bigint-json.js.map +1 -1
  245. package/out/shared/src/binary-search.js +18 -29
  246. package/out/shared/src/binary-search.js.map +1 -1
  247. package/out/shared/src/broadcast-channel.js +24 -0
  248. package/out/shared/src/broadcast-channel.js.map +1 -0
  249. package/out/shared/src/browser-env.js +25 -0
  250. package/out/shared/src/browser-env.js.map +1 -0
  251. package/out/shared/src/btree-set.js +464 -507
  252. package/out/shared/src/btree-set.js.map +1 -1
  253. package/out/shared/src/cache.js +34 -38
  254. package/out/shared/src/cache.js.map +1 -1
  255. package/out/shared/src/centroid.js +24 -24
  256. package/out/shared/src/centroid.js.map +1 -1
  257. package/out/shared/src/config.js +6 -3
  258. package/out/shared/src/config.js.map +1 -1
  259. package/out/shared/src/custom-key-map.js +58 -64
  260. package/out/shared/src/custom-key-map.js.map +1 -1
  261. package/out/shared/src/custom-key-set.js +51 -57
  262. package/out/shared/src/custom-key-set.js.map +1 -1
  263. package/out/shared/src/deep-clone.js +46 -0
  264. package/out/shared/src/deep-clone.js.map +1 -0
  265. package/out/shared/src/document-visible.js +74 -0
  266. package/out/shared/src/document-visible.js.map +1 -0
  267. package/out/shared/src/dotenv.js +5 -7
  268. package/out/shared/src/dotenv.js.map +1 -1
  269. package/out/shared/src/error.js +57 -56
  270. package/out/shared/src/error.js.map +1 -1
  271. package/out/shared/src/has-own.js +5 -3
  272. package/out/shared/src/has-own.js.map +1 -1
  273. package/out/shared/src/hash.js +15 -14
  274. package/out/shared/src/hash.js.map +1 -1
  275. package/out/shared/src/iterables.js +71 -73
  276. package/out/shared/src/iterables.js.map +1 -1
  277. package/out/shared/src/json-schema.js +30 -33
  278. package/out/shared/src/json-schema.js.map +1 -1
  279. package/out/shared/src/json.js +128 -143
  280. package/out/shared/src/json.js.map +1 -1
  281. package/out/shared/src/logging-test-utils.js +12 -19
  282. package/out/shared/src/logging-test-utils.js.map +1 -1
  283. package/out/shared/src/logging.js +83 -83
  284. package/out/shared/src/logging.js.map +1 -1
  285. package/out/shared/src/must.js +9 -7
  286. package/out/shared/src/must.js.map +1 -1
  287. package/out/shared/src/navigator.js +5 -0
  288. package/out/shared/src/navigator.js.map +1 -0
  289. package/out/shared/src/objects.js +21 -22
  290. package/out/shared/src/objects.js.map +1 -1
  291. package/out/shared/src/options.js +289 -322
  292. package/out/shared/src/options.js.map +1 -1
  293. package/out/shared/src/parse-big-int.js +12 -10
  294. package/out/shared/src/parse-big-int.js.map +1 -1
  295. package/out/shared/src/promise-race.js +20 -0
  296. package/out/shared/src/promise-race.js.map +1 -0
  297. package/out/shared/src/queue.js +119 -122
  298. package/out/shared/src/queue.js.map +1 -1
  299. package/out/shared/src/rand.js +8 -10
  300. package/out/shared/src/rand.js.map +1 -1
  301. package/out/shared/src/random-uint64.js +9 -0
  302. package/out/shared/src/random-uint64.js.map +1 -0
  303. package/out/shared/src/random-values.js +13 -0
  304. package/out/shared/src/random-values.js.map +1 -0
  305. package/out/shared/src/resolved-promises.js +12 -9
  306. package/out/shared/src/resolved-promises.js.map +1 -1
  307. package/out/shared/src/sentinels.js +13 -6
  308. package/out/shared/src/sentinels.js.map +1 -1
  309. package/out/shared/src/set-utils.js +63 -62
  310. package/out/shared/src/set-utils.js.map +1 -1
  311. package/out/shared/src/size-of-value.js +58 -0
  312. package/out/shared/src/size-of-value.js.map +1 -0
  313. package/out/shared/src/sleep.js +45 -53
  314. package/out/shared/src/sleep.js.map +1 -1
  315. package/out/shared/src/string-compare.js +12 -9
  316. package/out/shared/src/string-compare.js.map +1 -1
  317. package/out/shared/src/subscribable.js +34 -0
  318. package/out/shared/src/subscribable.js.map +1 -0
  319. package/out/shared/src/tdigest-schema.js +7 -7
  320. package/out/shared/src/tdigest-schema.js.map +1 -1
  321. package/out/shared/src/tdigest.js +247 -271
  322. package/out/shared/src/tdigest.js.map +1 -1
  323. package/out/shared/src/valita.js +195 -207
  324. package/out/shared/src/valita.js.map +1 -1
  325. package/out/z2s/src/compiler.d.ts.map +1 -1
  326. package/out/z2s/src/compiler.js +437 -310
  327. package/out/z2s/src/compiler.js.map +1 -1
  328. package/out/z2s/src/sql.js +186 -218
  329. package/out/z2s/src/sql.js.map +1 -1
  330. package/out/zero/package.json.js +9 -0
  331. package/out/zero/package.json.js.map +1 -0
  332. package/out/zero/src/adapters/drizzle.js +5 -2
  333. package/out/zero/src/adapters/drizzle.js.map +1 -1
  334. package/out/zero/src/adapters/pg.js +7 -2
  335. package/out/zero/src/adapters/pg.js.map +1 -1
  336. package/out/zero/src/adapters/postgresjs.js +7 -2
  337. package/out/zero/src/adapters/postgresjs.js.map +1 -1
  338. package/out/zero/src/analyze-query.js +1 -1
  339. package/out/zero/src/analyze-query.js.map +1 -1
  340. package/out/zero/src/ast-to-zql.js +1 -1
  341. package/out/zero/src/ast-to-zql.js.map +1 -1
  342. package/out/zero/src/build-schema.js +3 -5
  343. package/out/zero/src/build-schema.js.map +1 -1
  344. package/out/zero/src/change-protocol/v0.js +5 -3
  345. package/out/zero/src/change-protocol/v0.js.map +1 -1
  346. package/out/zero/src/cli.js +2 -2
  347. package/out/zero/src/cli.js.map +1 -1
  348. package/out/zero/src/deploy-permissions.js +1 -1
  349. package/out/zero/src/deploy-permissions.js.map +1 -1
  350. package/out/zero/src/expo-sqlite.js +5 -0
  351. package/out/zero/src/expo-sqlite.js.map +1 -0
  352. package/out/zero/src/op-sqlite.js +5 -0
  353. package/out/zero/src/op-sqlite.js.map +1 -0
  354. package/out/zero/src/pg.js +31 -3
  355. package/out/zero/src/pg.js.map +1 -1
  356. package/out/zero/src/react-native.js +13 -0
  357. package/out/zero/src/react-native.js.map +1 -0
  358. package/out/zero/src/react.js +17 -0
  359. package/out/zero/src/react.js.map +1 -0
  360. package/out/zero/src/server.js +27 -3
  361. package/out/zero/src/server.js.map +1 -1
  362. package/out/zero/src/solid.js +15 -0
  363. package/out/zero/src/solid.js.map +1 -0
  364. package/out/zero/src/sqlite.js +7 -0
  365. package/out/zero/src/sqlite.js.map +1 -0
  366. package/out/zero/src/transform-query.js +1 -1
  367. package/out/zero/src/transform-query.js.map +1 -1
  368. package/out/zero/src/zero-cache-dev.js +135 -126
  369. package/out/zero/src/zero-cache-dev.js.map +1 -1
  370. package/out/zero/src/zero-out.js +6 -6
  371. package/out/zero/src/zero-out.js.map +1 -1
  372. package/out/zero/src/zero.js +55 -0
  373. package/out/zero/src/zero.js.map +1 -0
  374. package/out/zero/src/zqlite.js +11 -3
  375. package/out/zero/src/zqlite.js.map +1 -1
  376. package/out/zero-cache/src/auth/jwt.js +33 -38
  377. package/out/zero-cache/src/auth/jwt.js.map +1 -1
  378. package/out/zero-cache/src/auth/load-permissions.js +61 -45
  379. package/out/zero-cache/src/auth/load-permissions.js.map +1 -1
  380. package/out/zero-cache/src/auth/read-authorizer.js +79 -91
  381. package/out/zero-cache/src/auth/read-authorizer.js.map +1 -1
  382. package/out/zero-cache/src/auth/write-authorizer.d.ts +2 -2
  383. package/out/zero-cache/src/auth/write-authorizer.d.ts.map +1 -1
  384. package/out/zero-cache/src/auth/write-authorizer.js +394 -349
  385. package/out/zero-cache/src/auth/write-authorizer.js.map +1 -1
  386. package/out/zero-cache/src/config/network.js +42 -45
  387. package/out/zero-cache/src/config/network.js.map +1 -1
  388. package/out/zero-cache/src/config/normalize.js +86 -83
  389. package/out/zero-cache/src/config/normalize.js.map +1 -1
  390. package/out/zero-cache/src/config/zero-config.js +676 -682
  391. package/out/zero-cache/src/config/zero-config.js.map +1 -1
  392. package/out/zero-cache/src/custom/fetch.d.ts.map +1 -1
  393. package/out/zero-cache/src/custom/fetch.js +166 -162
  394. package/out/zero-cache/src/custom/fetch.js.map +1 -1
  395. package/out/zero-cache/src/custom-queries/transform-query.d.ts +7 -0
  396. package/out/zero-cache/src/custom-queries/transform-query.d.ts.map +1 -1
  397. package/out/zero-cache/src/custom-queries/transform-query.js +101 -106
  398. package/out/zero-cache/src/custom-queries/transform-query.js.map +1 -1
  399. package/out/zero-cache/src/db/create.js +32 -36
  400. package/out/zero-cache/src/db/create.js.map +1 -1
  401. package/out/zero-cache/src/db/delete-lite-db.js +9 -6
  402. package/out/zero-cache/src/db/delete-lite-db.js.map +1 -1
  403. package/out/zero-cache/src/db/lite-tables.d.ts.map +1 -1
  404. package/out/zero-cache/src/db/lite-tables.js +150 -174
  405. package/out/zero-cache/src/db/lite-tables.js.map +1 -1
  406. package/out/zero-cache/src/db/migration-lite.js +170 -165
  407. package/out/zero-cache/src/db/migration-lite.js.map +1 -1
  408. package/out/zero-cache/src/db/migration.js +157 -137
  409. package/out/zero-cache/src/db/migration.js.map +1 -1
  410. package/out/zero-cache/src/db/mode-enum.js +9 -4
  411. package/out/zero-cache/src/db/mode-enum.js.map +1 -1
  412. package/out/zero-cache/src/db/pg-copy.js +51 -90
  413. package/out/zero-cache/src/db/pg-copy.js.map +1 -1
  414. package/out/zero-cache/src/db/pg-to-lite.js +114 -109
  415. package/out/zero-cache/src/db/pg-to-lite.js.map +1 -1
  416. package/out/zero-cache/src/db/pg-type-parser.js +27 -39
  417. package/out/zero-cache/src/db/pg-type-parser.js.map +1 -1
  418. package/out/zero-cache/src/db/postgres-replica-identity-enum.js +11 -6
  419. package/out/zero-cache/src/db/postgres-replica-identity-enum.js.map +1 -1
  420. package/out/zero-cache/src/db/postgres-type-class-enum.js +17 -9
  421. package/out/zero-cache/src/db/postgres-type-class-enum.js.map +1 -1
  422. package/out/zero-cache/src/db/specs.d.ts +0 -6
  423. package/out/zero-cache/src/db/specs.d.ts.map +1 -1
  424. package/out/zero-cache/src/db/specs.js +66 -40
  425. package/out/zero-cache/src/db/specs.js.map +1 -1
  426. package/out/zero-cache/src/db/statements.d.ts +1 -1
  427. package/out/zero-cache/src/db/statements.d.ts.map +1 -1
  428. package/out/zero-cache/src/db/statements.js +59 -52
  429. package/out/zero-cache/src/db/statements.js.map +1 -1
  430. package/out/zero-cache/src/db/transaction-pool.d.ts +1 -1
  431. package/out/zero-cache/src/db/transaction-pool.d.ts.map +1 -1
  432. package/out/zero-cache/src/db/transaction-pool.js +375 -501
  433. package/out/zero-cache/src/db/transaction-pool.js.map +1 -1
  434. package/out/zero-cache/src/db/warmup.js +25 -12
  435. package/out/zero-cache/src/db/warmup.js.map +1 -1
  436. package/out/zero-cache/src/observability/events.js +71 -82
  437. package/out/zero-cache/src/observability/events.js.map +1 -1
  438. package/out/zero-cache/src/observability/metrics.js +54 -32
  439. package/out/zero-cache/src/observability/metrics.js.map +1 -1
  440. package/out/zero-cache/src/scripts/decommission.js +47 -43
  441. package/out/zero-cache/src/scripts/decommission.js.map +1 -1
  442. package/out/zero-cache/src/scripts/deploy-permissions.js +128 -118
  443. package/out/zero-cache/src/scripts/deploy-permissions.js.map +1 -1
  444. package/out/zero-cache/src/scripts/permissions.js +107 -99
  445. package/out/zero-cache/src/scripts/permissions.js.map +1 -1
  446. package/out/zero-cache/src/server/anonymous-otel-start.js +410 -366
  447. package/out/zero-cache/src/server/anonymous-otel-start.js.map +1 -1
  448. package/out/zero-cache/src/server/change-streamer.js +104 -60
  449. package/out/zero-cache/src/server/change-streamer.js.map +1 -1
  450. package/out/zero-cache/src/server/inspector-delegate.js +112 -109
  451. package/out/zero-cache/src/server/inspector-delegate.js.map +1 -1
  452. package/out/zero-cache/src/server/logging.d.ts +1 -1
  453. package/out/zero-cache/src/server/logging.d.ts.map +1 -1
  454. package/out/zero-cache/src/server/logging.js +26 -19
  455. package/out/zero-cache/src/server/logging.js.map +1 -1
  456. package/out/zero-cache/src/server/main.d.ts.map +1 -1
  457. package/out/zero-cache/src/server/main.js +137 -120
  458. package/out/zero-cache/src/server/main.js.map +1 -1
  459. package/out/zero-cache/src/server/mutator.js +19 -0
  460. package/out/zero-cache/src/server/mutator.js.map +1 -0
  461. package/out/zero-cache/src/server/otel-diag-logger.d.ts +1 -1
  462. package/out/zero-cache/src/server/otel-diag-logger.d.ts.map +1 -1
  463. package/out/zero-cache/src/server/otel-diag-logger.js +67 -70
  464. package/out/zero-cache/src/server/otel-diag-logger.js.map +1 -1
  465. package/out/zero-cache/src/server/otel-log-sink.js +40 -41
  466. package/out/zero-cache/src/server/otel-log-sink.js.map +1 -1
  467. package/out/zero-cache/src/server/otel-start.d.ts +1 -1
  468. package/out/zero-cache/src/server/otel-start.d.ts.map +1 -1
  469. package/out/zero-cache/src/server/otel-start.js +57 -68
  470. package/out/zero-cache/src/server/otel-start.js.map +1 -1
  471. package/out/zero-cache/src/server/reaper.js +34 -26
  472. package/out/zero-cache/src/server/reaper.js.map +1 -1
  473. package/out/zero-cache/src/server/replicator.js +53 -31
  474. package/out/zero-cache/src/server/replicator.js.map +1 -1
  475. package/out/zero-cache/src/server/runner/main.js +6 -4
  476. package/out/zero-cache/src/server/runner/main.js.map +1 -1
  477. package/out/zero-cache/src/server/runner/run-worker.d.ts.map +1 -1
  478. package/out/zero-cache/src/server/runner/run-worker.js +46 -50
  479. package/out/zero-cache/src/server/runner/run-worker.js.map +1 -1
  480. package/out/zero-cache/src/server/runner/runtime.js +33 -32
  481. package/out/zero-cache/src/server/runner/runtime.js.map +1 -1
  482. package/out/zero-cache/src/server/runner/zero-dispatcher.d.ts.map +1 -1
  483. package/out/zero-cache/src/server/runner/zero-dispatcher.js +28 -22
  484. package/out/zero-cache/src/server/runner/zero-dispatcher.js.map +1 -1
  485. package/out/zero-cache/src/server/syncer.js +112 -63
  486. package/out/zero-cache/src/server/syncer.js.map +1 -1
  487. package/out/zero-cache/src/server/worker-dispatcher.d.ts +1 -1
  488. package/out/zero-cache/src/server/worker-dispatcher.d.ts.map +1 -1
  489. package/out/zero-cache/src/server/worker-dispatcher.js +112 -106
  490. package/out/zero-cache/src/server/worker-dispatcher.js.map +1 -1
  491. package/out/zero-cache/src/server/worker-urls.d.ts +7 -0
  492. package/out/zero-cache/src/server/worker-urls.d.ts.map +1 -0
  493. package/out/zero-cache/src/server/worker-urls.js +21 -0
  494. package/out/zero-cache/src/server/worker-urls.js.map +1 -0
  495. package/out/zero-cache/src/services/analyze.d.ts +3 -4
  496. package/out/zero-cache/src/services/analyze.d.ts.map +1 -1
  497. package/out/zero-cache/src/services/analyze.js +96 -122
  498. package/out/zero-cache/src/services/analyze.js.map +1 -1
  499. package/out/zero-cache/src/services/change-source/column-metadata.js +152 -155
  500. package/out/zero-cache/src/services/change-source/column-metadata.js.map +1 -1
  501. package/out/zero-cache/src/services/change-source/custom/change-source.d.ts +1 -1
  502. package/out/zero-cache/src/services/change-source/custom/change-source.d.ts.map +1 -1
  503. package/out/zero-cache/src/services/change-source/custom/change-source.js +197 -171
  504. package/out/zero-cache/src/services/change-source/custom/change-source.js.map +1 -1
  505. package/out/zero-cache/src/services/change-source/custom/sync-schema.js +11 -3
  506. package/out/zero-cache/src/services/change-source/custom/sync-schema.js.map +1 -1
  507. package/out/zero-cache/src/services/change-source/pg/change-source.d.ts +1 -1
  508. package/out/zero-cache/src/services/change-source/pg/change-source.d.ts.map +1 -1
  509. package/out/zero-cache/src/services/change-source/pg/change-source.js +601 -622
  510. package/out/zero-cache/src/services/change-source/pg/change-source.js.map +1 -1
  511. package/out/zero-cache/src/services/change-source/pg/decommission.js +24 -23
  512. package/out/zero-cache/src/services/change-source/pg/decommission.js.map +1 -1
  513. package/out/zero-cache/src/services/change-source/pg/initial-sync.d.ts +1 -1
  514. package/out/zero-cache/src/services/change-source/pg/initial-sync.d.ts.map +1 -1
  515. package/out/zero-cache/src/services/change-source/pg/initial-sync.js +327 -284
  516. package/out/zero-cache/src/services/change-source/pg/initial-sync.js.map +1 -1
  517. package/out/zero-cache/src/services/change-source/pg/logical-replication/binary-reader.js +61 -69
  518. package/out/zero-cache/src/services/change-source/pg/logical-replication/binary-reader.js.map +1 -1
  519. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput-parser.js +247 -257
  520. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput-parser.js.map +1 -1
  521. package/out/zero-cache/src/services/change-source/pg/logical-replication/stream.js +127 -119
  522. package/out/zero-cache/src/services/change-source/pg/logical-replication/stream.js.map +1 -1
  523. package/out/zero-cache/src/services/change-source/pg/lsn.js +20 -19
  524. package/out/zero-cache/src/services/change-source/pg/lsn.js.map +1 -1
  525. package/out/zero-cache/src/services/change-source/pg/schema/ddl.js +96 -119
  526. package/out/zero-cache/src/services/change-source/pg/schema/ddl.js.map +1 -1
  527. package/out/zero-cache/src/services/change-source/pg/schema/init.js +138 -117
  528. package/out/zero-cache/src/services/change-source/pg/schema/init.js.map +1 -1
  529. package/out/zero-cache/src/services/change-source/pg/schema/published.js +67 -74
  530. package/out/zero-cache/src/services/change-source/pg/schema/published.js.map +1 -1
  531. package/out/zero-cache/src/services/change-source/pg/schema/shard.js +199 -188
  532. package/out/zero-cache/src/services/change-source/pg/schema/shard.js.map +1 -1
  533. package/out/zero-cache/src/services/change-source/pg/schema/validation.js +53 -38
  534. package/out/zero-cache/src/services/change-source/pg/schema/validation.js.map +1 -1
  535. package/out/zero-cache/src/services/change-source/pg/sync-schema.js +11 -3
  536. package/out/zero-cache/src/services/change-source/pg/sync-schema.js.map +1 -1
  537. package/out/zero-cache/src/services/change-source/protocol/current/control.js +9 -19
  538. package/out/zero-cache/src/services/change-source/protocol/current/control.js.map +1 -1
  539. package/out/zero-cache/src/services/change-source/protocol/current/data.js +143 -116
  540. package/out/zero-cache/src/services/change-source/protocol/current/data.js.map +1 -1
  541. package/out/zero-cache/src/services/change-source/protocol/current/downstream.js +29 -19
  542. package/out/zero-cache/src/services/change-source/protocol/current/downstream.js.map +1 -1
  543. package/out/zero-cache/src/services/change-source/protocol/current/path.js +5 -20
  544. package/out/zero-cache/src/services/change-source/protocol/current/path.js.map +1 -1
  545. package/out/zero-cache/src/services/change-source/protocol/current/status.js +12 -13
  546. package/out/zero-cache/src/services/change-source/protocol/current/status.js.map +1 -1
  547. package/out/zero-cache/src/services/change-source/protocol/current/upstream.d.ts +1 -1
  548. package/out/zero-cache/src/services/change-source/protocol/current/upstream.d.ts.map +1 -1
  549. package/out/zero-cache/src/services/change-source/protocol/current/upstream.js +5 -4
  550. package/out/zero-cache/src/services/change-source/protocol/current/upstream.js.map +1 -1
  551. package/out/zero-cache/src/services/change-source/protocol/current.js +35 -7
  552. package/out/zero-cache/src/services/change-source/protocol/current.js.map +1 -1
  553. package/out/zero-cache/src/services/change-source/replica-schema.js +64 -47
  554. package/out/zero-cache/src/services/change-source/replica-schema.js.map +1 -1
  555. package/out/zero-cache/src/services/change-streamer/backup-monitor.js +139 -161
  556. package/out/zero-cache/src/services/change-streamer/backup-monitor.js.map +1 -1
  557. package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +2 -2
  558. package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts.map +1 -1
  559. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js +178 -158
  560. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +1 -1
  561. package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts +1 -1
  562. package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts.map +1 -1
  563. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js +234 -355
  564. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js.map +1 -1
  565. package/out/zero-cache/src/services/change-streamer/change-streamer.js +24 -26
  566. package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +1 -1
  567. package/out/zero-cache/src/services/change-streamer/error-type-enum.js +9 -4
  568. package/out/zero-cache/src/services/change-streamer/error-type-enum.js.map +1 -1
  569. package/out/zero-cache/src/services/change-streamer/forwarder.d.ts +1 -1
  570. package/out/zero-cache/src/services/change-streamer/forwarder.d.ts.map +1 -1
  571. package/out/zero-cache/src/services/change-streamer/forwarder.js +53 -57
  572. package/out/zero-cache/src/services/change-streamer/forwarder.js.map +1 -1
  573. package/out/zero-cache/src/services/change-streamer/replica-monitor.js +40 -44
  574. package/out/zero-cache/src/services/change-streamer/replica-monitor.js.map +1 -1
  575. package/out/zero-cache/src/services/change-streamer/schema/init.js +82 -68
  576. package/out/zero-cache/src/services/change-streamer/schema/init.js.map +1 -1
  577. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts +2 -2
  578. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts.map +1 -1
  579. package/out/zero-cache/src/services/change-streamer/schema/tables.js +93 -78
  580. package/out/zero-cache/src/services/change-streamer/schema/tables.js.map +1 -1
  581. package/out/zero-cache/src/services/change-streamer/snapshot.js +28 -37
  582. package/out/zero-cache/src/services/change-streamer/snapshot.js.map +1 -1
  583. package/out/zero-cache/src/services/change-streamer/storer.d.ts +2 -2
  584. package/out/zero-cache/src/services/change-streamer/storer.d.ts.map +1 -1
  585. package/out/zero-cache/src/services/change-streamer/storer.js +309 -372
  586. package/out/zero-cache/src/services/change-streamer/storer.js.map +1 -1
  587. package/out/zero-cache/src/services/change-streamer/subscriber.d.ts +2 -1
  588. package/out/zero-cache/src/services/change-streamer/subscriber.d.ts.map +1 -1
  589. package/out/zero-cache/src/services/change-streamer/subscriber.js +83 -90
  590. package/out/zero-cache/src/services/change-streamer/subscriber.js.map +1 -1
  591. package/out/zero-cache/src/services/heapz.js +21 -25
  592. package/out/zero-cache/src/services/heapz.js.map +1 -1
  593. package/out/zero-cache/src/services/http-service.d.ts +1 -1
  594. package/out/zero-cache/src/services/http-service.d.ts.map +1 -1
  595. package/out/zero-cache/src/services/http-service.js +56 -59
  596. package/out/zero-cache/src/services/http-service.js.map +1 -1
  597. package/out/zero-cache/src/services/life-cycle.d.ts +1 -1
  598. package/out/zero-cache/src/services/life-cycle.d.ts.map +1 -1
  599. package/out/zero-cache/src/services/life-cycle.js +216 -255
  600. package/out/zero-cache/src/services/life-cycle.js.map +1 -1
  601. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js +76 -130
  602. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js.map +1 -1
  603. package/out/zero-cache/src/services/litestream/commands.d.ts +1 -1
  604. package/out/zero-cache/src/services/litestream/commands.d.ts.map +1 -1
  605. package/out/zero-cache/src/services/litestream/commands.js +193 -178
  606. package/out/zero-cache/src/services/litestream/commands.js.map +1 -1
  607. package/out/zero-cache/src/services/mutagen/error.js +11 -6
  608. package/out/zero-cache/src/services/mutagen/error.js.map +1 -1
  609. package/out/zero-cache/src/services/mutagen/mutagen.js +270 -267
  610. package/out/zero-cache/src/services/mutagen/mutagen.js.map +1 -1
  611. package/out/zero-cache/src/services/mutagen/pusher.js +351 -344
  612. package/out/zero-cache/src/services/mutagen/pusher.js.map +1 -1
  613. package/out/zero-cache/src/services/replicator/change-processor.js +483 -530
  614. package/out/zero-cache/src/services/replicator/change-processor.js.map +1 -1
  615. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts +1 -1
  616. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +1 -1
  617. package/out/zero-cache/src/services/replicator/incremental-sync.js +97 -97
  618. package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -1
  619. package/out/zero-cache/src/services/replicator/notifier.js +28 -52
  620. package/out/zero-cache/src/services/replicator/notifier.js.map +1 -1
  621. package/out/zero-cache/src/services/replicator/replication-status.js +100 -83
  622. package/out/zero-cache/src/services/replicator/replication-status.js.map +1 -1
  623. package/out/zero-cache/src/services/replicator/replicator.d.ts +1 -1
  624. package/out/zero-cache/src/services/replicator/replicator.d.ts.map +1 -1
  625. package/out/zero-cache/src/services/replicator/replicator.js +33 -26
  626. package/out/zero-cache/src/services/replicator/replicator.js.map +1 -1
  627. package/out/zero-cache/src/services/replicator/schema/change-log.d.ts +1 -1
  628. package/out/zero-cache/src/services/replicator/schema/change-log.d.ts.map +1 -1
  629. package/out/zero-cache/src/services/replicator/schema/change-log.js +74 -86
  630. package/out/zero-cache/src/services/replicator/schema/change-log.js.map +1 -1
  631. package/out/zero-cache/src/services/replicator/schema/constants.js +5 -7
  632. package/out/zero-cache/src/services/replicator/schema/constants.js.map +1 -1
  633. package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts +2 -2
  634. package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts.map +1 -1
  635. package/out/zero-cache/src/services/replicator/schema/replication-state.js +70 -74
  636. package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +1 -1
  637. package/out/zero-cache/src/services/run-ast.d.ts +5 -3
  638. package/out/zero-cache/src/services/run-ast.d.ts.map +1 -1
  639. package/out/zero-cache/src/services/run-ast.js +80 -79
  640. package/out/zero-cache/src/services/run-ast.js.map +1 -1
  641. package/out/zero-cache/src/services/runner.d.ts +1 -1
  642. package/out/zero-cache/src/services/runner.d.ts.map +1 -1
  643. package/out/zero-cache/src/services/runner.js +40 -40
  644. package/out/zero-cache/src/services/runner.js.map +1 -1
  645. package/out/zero-cache/src/services/running-state.d.ts +1 -1
  646. package/out/zero-cache/src/services/running-state.d.ts.map +1 -1
  647. package/out/zero-cache/src/services/running-state.js +122 -119
  648. package/out/zero-cache/src/services/running-state.js.map +1 -1
  649. package/out/zero-cache/src/services/statz.js +184 -162
  650. package/out/zero-cache/src/services/statz.js.map +1 -1
  651. package/out/zero-cache/src/services/view-syncer/active-users-gauge.js +40 -39
  652. package/out/zero-cache/src/services/view-syncer/active-users-gauge.js.map +1 -1
  653. package/out/zero-cache/src/services/view-syncer/client-handler.js +307 -298
  654. package/out/zero-cache/src/services/view-syncer/client-handler.js.map +1 -1
  655. package/out/zero-cache/src/services/view-syncer/client-schema.d.ts.map +1 -1
  656. package/out/zero-cache/src/services/view-syncer/client-schema.js +80 -82
  657. package/out/zero-cache/src/services/view-syncer/client-schema.js.map +1 -1
  658. package/out/zero-cache/src/services/view-syncer/cvr-purger.js +83 -92
  659. package/out/zero-cache/src/services/view-syncer/cvr-purger.js.map +1 -1
  660. package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts +2 -4
  661. package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts.map +1 -1
  662. package/out/zero-cache/src/services/view-syncer/cvr-store.js +628 -616
  663. package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +1 -1
  664. package/out/zero-cache/src/services/view-syncer/cvr.d.ts +1 -1
  665. package/out/zero-cache/src/services/view-syncer/cvr.d.ts.map +1 -1
  666. package/out/zero-cache/src/services/view-syncer/cvr.js +631 -694
  667. package/out/zero-cache/src/services/view-syncer/cvr.js.map +1 -1
  668. package/out/zero-cache/src/services/view-syncer/drain-coordinator.js +38 -60
  669. package/out/zero-cache/src/services/view-syncer/drain-coordinator.js.map +1 -1
  670. package/out/zero-cache/src/services/view-syncer/inspect-handler.d.ts +2 -1
  671. package/out/zero-cache/src/services/view-syncer/inspect-handler.d.ts.map +1 -1
  672. package/out/zero-cache/src/services/view-syncer/inspect-handler.js +168 -158
  673. package/out/zero-cache/src/services/view-syncer/inspect-handler.js.map +1 -1
  674. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +14 -13
  675. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +1 -1
  676. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +529 -482
  677. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -1
  678. package/out/zero-cache/src/services/view-syncer/row-record-cache.js +229 -280
  679. package/out/zero-cache/src/services/view-syncer/row-record-cache.js.map +1 -1
  680. package/out/zero-cache/src/services/view-syncer/schema/cvr.js +53 -120
  681. package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +1 -1
  682. package/out/zero-cache/src/services/view-syncer/schema/init.js +171 -150
  683. package/out/zero-cache/src/services/view-syncer/schema/init.js.map +1 -1
  684. package/out/zero-cache/src/services/view-syncer/schema/types.js +265 -257
  685. package/out/zero-cache/src/services/view-syncer/schema/types.js.map +1 -1
  686. package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts +3 -3
  687. package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts.map +1 -1
  688. package/out/zero-cache/src/services/view-syncer/snapshotter.js +295 -338
  689. package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +1 -1
  690. package/out/zero-cache/src/services/view-syncer/ttl-clock.js +13 -7
  691. package/out/zero-cache/src/services/view-syncer/ttl-clock.js.map +1 -1
  692. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +3 -3
  693. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -1
  694. package/out/zero-cache/src/services/view-syncer/view-syncer.js +1485 -1307
  695. package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -1
  696. package/out/zero-cache/src/types/error-with-level.d.ts.map +1 -1
  697. package/out/zero-cache/src/types/error-with-level.js +29 -25
  698. package/out/zero-cache/src/types/error-with-level.js.map +1 -1
  699. package/out/zero-cache/src/types/http.js +27 -14
  700. package/out/zero-cache/src/types/http.js.map +1 -1
  701. package/out/zero-cache/src/types/lexi-version.js +46 -31
  702. package/out/zero-cache/src/types/lexi-version.js.map +1 -1
  703. package/out/zero-cache/src/types/lite.js +118 -125
  704. package/out/zero-cache/src/types/lite.js.map +1 -1
  705. package/out/zero-cache/src/types/names.js +6 -3
  706. package/out/zero-cache/src/types/names.js.map +1 -1
  707. package/out/zero-cache/src/types/pg-data-type.js +74 -68
  708. package/out/zero-cache/src/types/pg-data-type.js.map +1 -1
  709. package/out/zero-cache/src/types/pg-types.js +17 -72
  710. package/out/zero-cache/src/types/pg-types.js.map +1 -1
  711. package/out/zero-cache/src/types/pg.d.ts +1 -1
  712. package/out/zero-cache/src/types/pg.d.ts.map +1 -1
  713. package/out/zero-cache/src/types/pg.js +213 -233
  714. package/out/zero-cache/src/types/pg.js.map +1 -1
  715. package/out/zero-cache/src/types/processes.d.ts +2 -2
  716. package/out/zero-cache/src/types/processes.d.ts.map +1 -1
  717. package/out/zero-cache/src/types/processes.js +95 -143
  718. package/out/zero-cache/src/types/processes.js.map +1 -1
  719. package/out/zero-cache/src/types/profiler.js +29 -30
  720. package/out/zero-cache/src/types/profiler.js.map +1 -1
  721. package/out/zero-cache/src/types/row-key.js +30 -68
  722. package/out/zero-cache/src/types/row-key.js.map +1 -1
  723. package/out/zero-cache/src/types/schema-versions.js +25 -19
  724. package/out/zero-cache/src/types/schema-versions.js.map +1 -1
  725. package/out/zero-cache/src/types/shards.js +50 -36
  726. package/out/zero-cache/src/types/shards.js.map +1 -1
  727. package/out/zero-cache/src/types/sql.js +9 -13
  728. package/out/zero-cache/src/types/sql.js.map +1 -1
  729. package/out/zero-cache/src/types/streams.js +245 -254
  730. package/out/zero-cache/src/types/streams.js.map +1 -1
  731. package/out/zero-cache/src/types/strings.js +14 -11
  732. package/out/zero-cache/src/types/strings.js.map +1 -1
  733. package/out/zero-cache/src/types/subscription.js +200 -259
  734. package/out/zero-cache/src/types/subscription.js.map +1 -1
  735. package/out/zero-cache/src/types/url-params.js +35 -30
  736. package/out/zero-cache/src/types/url-params.js.map +1 -1
  737. package/out/zero-cache/src/types/websocket-handoff.d.ts +3 -2
  738. package/out/zero-cache/src/types/websocket-handoff.d.ts.map +1 -1
  739. package/out/zero-cache/src/types/websocket-handoff.js +68 -76
  740. package/out/zero-cache/src/types/websocket-handoff.js.map +1 -1
  741. package/out/zero-cache/src/types/ws.js +56 -59
  742. package/out/zero-cache/src/types/ws.js.map +1 -1
  743. package/out/zero-cache/src/workers/connect-params.js +44 -40
  744. package/out/zero-cache/src/workers/connect-params.js.map +1 -1
  745. package/out/zero-cache/src/workers/connection.d.ts.map +1 -1
  746. package/out/zero-cache/src/workers/connection.js +277 -243
  747. package/out/zero-cache/src/workers/connection.js.map +1 -1
  748. package/out/zero-cache/src/workers/mutator.js +24 -0
  749. package/out/zero-cache/src/workers/mutator.js.map +1 -0
  750. package/out/zero-cache/src/workers/replicator.d.ts +1 -1
  751. package/out/zero-cache/src/workers/replicator.d.ts.map +1 -1
  752. package/out/zero-cache/src/workers/replicator.js +103 -106
  753. package/out/zero-cache/src/workers/replicator.js.map +1 -1
  754. package/out/zero-cache/src/workers/syncer-ws-message-handler.js +179 -147
  755. package/out/zero-cache/src/workers/syncer-ws-message-handler.js.map +1 -1
  756. package/out/zero-cache/src/workers/syncer.d.ts +3 -3
  757. package/out/zero-cache/src/workers/syncer.d.ts.map +1 -1
  758. package/out/zero-cache/src/workers/syncer.js +192 -169
  759. package/out/zero-cache/src/workers/syncer.js.map +1 -1
  760. package/out/zero-client/src/client/active-clients-manager.js +199 -0
  761. package/out/zero-client/src/client/active-clients-manager.js.map +1 -0
  762. package/out/zero-client/src/client/bindings.d.ts +8 -7
  763. package/out/zero-client/src/client/bindings.d.ts.map +1 -1
  764. package/out/zero-client/src/client/bindings.js +33 -0
  765. package/out/zero-client/src/client/bindings.js.map +1 -0
  766. package/out/zero-client/src/client/client-error-kind-enum.js +29 -0
  767. package/out/zero-client/src/client/client-error-kind-enum.js.map +1 -0
  768. package/out/zero-client/src/client/connection-manager.d.ts +12 -31
  769. package/out/zero-client/src/client/connection-manager.d.ts.map +1 -1
  770. package/out/zero-client/src/client/connection-manager.js +310 -0
  771. package/out/zero-client/src/client/connection-manager.js.map +1 -0
  772. package/out/zero-client/src/client/connection-status-enum.js +15 -0
  773. package/out/zero-client/src/client/connection-status-enum.js.map +1 -0
  774. package/out/zero-client/src/client/connection.d.ts +45 -2
  775. package/out/zero-client/src/client/connection.d.ts.map +1 -1
  776. package/out/zero-client/src/client/connection.js +103 -0
  777. package/out/zero-client/src/client/connection.js.map +1 -0
  778. package/out/zero-client/src/client/context.d.ts +3 -6
  779. package/out/zero-client/src/client/context.d.ts.map +1 -1
  780. package/out/zero-client/src/client/context.js +104 -0
  781. package/out/zero-client/src/client/context.js.map +1 -0
  782. package/out/zero-client/src/client/crud.js +225 -0
  783. package/out/zero-client/src/client/crud.js.map +1 -0
  784. package/out/zero-client/src/client/custom.d.ts +9 -12
  785. package/out/zero-client/src/client/custom.d.ts.map +1 -1
  786. package/out/zero-client/src/client/custom.js +123 -0
  787. package/out/zero-client/src/client/custom.js.map +1 -0
  788. package/out/zero-client/src/client/delete-clients-manager.js +71 -0
  789. package/out/zero-client/src/client/delete-clients-manager.js.map +1 -0
  790. package/out/zero-client/src/client/enable-analytics.js +18 -0
  791. package/out/zero-client/src/client/enable-analytics.js.map +1 -0
  792. package/out/zero-client/src/client/error.d.ts +2 -1
  793. package/out/zero-client/src/client/error.d.ts.map +1 -1
  794. package/out/zero-client/src/client/error.js +148 -0
  795. package/out/zero-client/src/client/error.js.map +1 -0
  796. package/out/zero-client/src/client/http-string.js +11 -0
  797. package/out/zero-client/src/client/http-string.js.map +1 -0
  798. package/out/zero-client/src/client/inspector/client-group.js +27 -0
  799. package/out/zero-client/src/client/inspector/client-group.js.map +1 -0
  800. package/out/zero-client/src/client/inspector/client.js +28 -0
  801. package/out/zero-client/src/client/inspector/client.js.map +1 -0
  802. package/out/zero-client/src/client/inspector/html-dialog-prompt.js +77 -0
  803. package/out/zero-client/src/client/inspector/html-dialog-prompt.js.map +1 -0
  804. package/out/zero-client/src/client/inspector/inspector.d.ts +1 -1
  805. package/out/zero-client/src/client/inspector/inspector.d.ts.map +1 -1
  806. package/out/zero-client/src/client/inspector/inspector.js +47 -0
  807. package/out/zero-client/src/client/inspector/inspector.js.map +1 -0
  808. package/out/zero-client/src/client/inspector/lazy-inspector.d.ts +1 -1
  809. package/out/zero-client/src/client/inspector/lazy-inspector.d.ts.map +1 -1
  810. package/out/zero-client/src/client/inspector/lazy-inspector.js +243 -0
  811. package/out/zero-client/src/client/inspector/lazy-inspector.js.map +1 -0
  812. package/out/zero-client/src/client/inspector/query.d.ts.map +1 -1
  813. package/out/zero-client/src/client/inspector/query.js +82 -0
  814. package/out/zero-client/src/client/inspector/query.js.map +1 -0
  815. package/out/zero-client/src/client/ivm-branch.d.ts +4 -4
  816. package/out/zero-client/src/client/ivm-branch.d.ts.map +1 -1
  817. package/out/zero-client/src/client/ivm-branch.js +149 -0
  818. package/out/zero-client/src/client/ivm-branch.js.map +1 -0
  819. package/out/zero-client/src/client/keys.js +45 -0
  820. package/out/zero-client/src/client/keys.js.map +1 -0
  821. package/out/zero-client/src/client/log-options.js +60 -0
  822. package/out/zero-client/src/client/log-options.js.map +1 -0
  823. package/out/zero-client/src/client/metric-name-enum.js +15 -0
  824. package/out/zero-client/src/client/metric-name-enum.js.map +1 -0
  825. package/out/zero-client/src/client/metrics.d.ts.map +1 -1
  826. package/out/zero-client/src/client/metrics.js +249 -0
  827. package/out/zero-client/src/client/metrics.js.map +1 -0
  828. package/out/zero-client/src/client/mutation-tracker.js +363 -0
  829. package/out/zero-client/src/client/mutation-tracker.js.map +1 -0
  830. package/out/zero-client/src/client/mutator-proxy.d.ts +1 -2
  831. package/out/zero-client/src/client/mutator-proxy.d.ts.map +1 -1
  832. package/out/zero-client/src/client/mutator-proxy.js +132 -0
  833. package/out/zero-client/src/client/mutator-proxy.js.map +1 -0
  834. package/out/zero-client/src/client/options.d.ts +36 -19
  835. package/out/zero-client/src/client/options.d.ts.map +1 -1
  836. package/out/zero-client/src/client/options.js +11 -0
  837. package/out/zero-client/src/client/options.js.map +1 -0
  838. package/out/zero-client/src/client/query-manager.d.ts +4 -4
  839. package/out/zero-client/src/client/query-manager.d.ts.map +1 -1
  840. package/out/zero-client/src/client/query-manager.js +377 -0
  841. package/out/zero-client/src/client/query-manager.js.map +1 -0
  842. package/out/zero-client/src/client/reload-error-handler.d.ts +1 -1
  843. package/out/zero-client/src/client/reload-error-handler.d.ts.map +1 -1
  844. package/out/zero-client/src/client/reload-error-handler.js +114 -0
  845. package/out/zero-client/src/client/reload-error-handler.js.map +1 -0
  846. package/out/zero-client/src/client/server-option.js +64 -0
  847. package/out/zero-client/src/client/server-option.js.map +1 -0
  848. package/out/zero-client/src/client/update-needed-reason-type-enum.js +9 -0
  849. package/out/zero-client/src/client/update-needed-reason-type-enum.js.map +1 -0
  850. package/out/zero-client/src/client/version.js +5 -0
  851. package/out/zero-client/src/client/version.js.map +1 -0
  852. package/out/zero-client/src/client/zero-poke-handler.js +303 -0
  853. package/out/zero-client/src/client/zero-poke-handler.js.map +1 -0
  854. package/out/zero-client/src/client/zero-rep.d.ts +2 -2
  855. package/out/zero-client/src/client/zero-rep.d.ts.map +1 -1
  856. package/out/zero-client/src/client/zero-rep.js +72 -0
  857. package/out/zero-client/src/client/zero-rep.js.map +1 -0
  858. package/out/zero-client/src/client/zero.d.ts +26 -9
  859. package/out/zero-client/src/client/zero.d.ts.map +1 -1
  860. package/out/zero-client/src/client/zero.js +1825 -0
  861. package/out/zero-client/src/client/zero.js.map +1 -0
  862. package/out/zero-client/src/mod.d.ts +4 -12
  863. package/out/zero-client/src/mod.d.ts.map +1 -1
  864. package/out/zero-client/src/util/nanoid.js +21 -0
  865. package/out/zero-client/src/util/nanoid.js.map +1 -0
  866. package/out/zero-client/src/util/socket.js +7 -0
  867. package/out/zero-client/src/util/socket.js.map +1 -0
  868. package/out/zero-protocol/src/analyze-query-result.js +32 -24
  869. package/out/zero-protocol/src/analyze-query-result.js.map +1 -1
  870. package/out/zero-protocol/src/application-error.js +35 -37
  871. package/out/zero-protocol/src/application-error.js.map +1 -1
  872. package/out/zero-protocol/src/ast.d.ts +1 -1
  873. package/out/zero-protocol/src/ast.js +296 -277
  874. package/out/zero-protocol/src/ast.js.map +1 -1
  875. package/out/zero-protocol/src/change-desired-queries.d.ts +2 -2
  876. package/out/zero-protocol/src/change-desired-queries.js +11 -7
  877. package/out/zero-protocol/src/change-desired-queries.js.map +1 -1
  878. package/out/zero-protocol/src/client-schema.d.ts +2 -2
  879. package/out/zero-protocol/src/client-schema.d.ts.map +1 -1
  880. package/out/zero-protocol/src/client-schema.js +40 -26
  881. package/out/zero-protocol/src/client-schema.js.map +1 -1
  882. package/out/zero-protocol/src/close-connection.js +11 -18
  883. package/out/zero-protocol/src/close-connection.js.map +1 -1
  884. package/out/zero-protocol/src/connect.d.ts +4 -4
  885. package/out/zero-protocol/src/connect.js +46 -51
  886. package/out/zero-protocol/src/connect.js.map +1 -1
  887. package/out/zero-protocol/src/custom-queries.d.ts +4 -4
  888. package/out/zero-protocol/src/custom-queries.js +61 -39
  889. package/out/zero-protocol/src/custom-queries.js.map +1 -1
  890. package/out/zero-protocol/src/data.js +9 -4
  891. package/out/zero-protocol/src/data.js.map +1 -1
  892. package/out/zero-protocol/src/delete-clients.js +16 -9
  893. package/out/zero-protocol/src/delete-clients.js.map +1 -1
  894. package/out/zero-protocol/src/down.d.ts +6 -6
  895. package/out/zero-protocol/src/down.js +20 -4
  896. package/out/zero-protocol/src/down.js.map +1 -1
  897. package/out/zero-protocol/src/error-kind-enum.js +41 -23
  898. package/out/zero-protocol/src/error-kind-enum.js.map +1 -1
  899. package/out/zero-protocol/src/error-origin-enum.js +9 -4
  900. package/out/zero-protocol/src/error-origin-enum.js.map +1 -1
  901. package/out/zero-protocol/src/error-reason-enum.js +17 -8
  902. package/out/zero-protocol/src/error-reason-enum.js.map +1 -1
  903. package/out/zero-protocol/src/error.d.ts +17 -17
  904. package/out/zero-protocol/src/error.js +151 -89
  905. package/out/zero-protocol/src/error.js.map +1 -1
  906. package/out/zero-protocol/src/inspect-down.d.ts +18 -18
  907. package/out/zero-protocol/src/inspect-down.js +72 -54
  908. package/out/zero-protocol/src/inspect-down.js.map +1 -1
  909. package/out/zero-protocol/src/inspect-up.d.ts +6 -6
  910. package/out/zero-protocol/src/inspect-up.js +38 -26
  911. package/out/zero-protocol/src/inspect-up.js.map +1 -1
  912. package/out/zero-protocol/src/mutation-id.js +9 -5
  913. package/out/zero-protocol/src/mutation-id.js.map +1 -1
  914. package/out/zero-protocol/src/mutation-type-enum.js +7 -3
  915. package/out/zero-protocol/src/mutation-type-enum.js.map +1 -1
  916. package/out/zero-protocol/src/mutations-patch.js +16 -17
  917. package/out/zero-protocol/src/mutations-patch.js.map +1 -1
  918. package/out/zero-protocol/src/ping.js +9 -4
  919. package/out/zero-protocol/src/ping.js.map +1 -1
  920. package/out/zero-protocol/src/poke.js +55 -72
  921. package/out/zero-protocol/src/poke.js.map +1 -1
  922. package/out/zero-protocol/src/pong.js +9 -4
  923. package/out/zero-protocol/src/pong.js.map +1 -1
  924. package/out/zero-protocol/src/primary-key.js +19 -5
  925. package/out/zero-protocol/src/primary-key.js.map +1 -1
  926. package/out/zero-protocol/src/protocol-version.d.ts +2 -2
  927. package/out/zero-protocol/src/protocol-version.d.ts.map +1 -1
  928. package/out/zero-protocol/src/protocol-version.js +7 -59
  929. package/out/zero-protocol/src/protocol-version.js.map +1 -1
  930. package/out/zero-protocol/src/pull.js +26 -19
  931. package/out/zero-protocol/src/pull.js.map +1 -1
  932. package/out/zero-protocol/src/push.d.ts +4 -4
  933. package/out/zero-protocol/src/push.js +179 -176
  934. package/out/zero-protocol/src/push.js.map +1 -1
  935. package/out/zero-protocol/src/queries-patch.d.ts +3 -3
  936. package/out/zero-protocol/src/queries-patch.js +29 -22
  937. package/out/zero-protocol/src/queries-patch.js.map +1 -1
  938. package/out/zero-protocol/src/query-hash.js +18 -14
  939. package/out/zero-protocol/src/query-hash.js.map +1 -1
  940. package/out/zero-protocol/src/row-patch.js +29 -20
  941. package/out/zero-protocol/src/row-patch.js.map +1 -1
  942. package/out/zero-protocol/src/up.d.ts +5 -5
  943. package/out/zero-protocol/src/up.js +18 -4
  944. package/out/zero-protocol/src/up.js.map +1 -1
  945. package/out/zero-protocol/src/version.js +9 -4
  946. package/out/zero-protocol/src/version.js.map +1 -1
  947. package/out/{inspector-GP3CBZRU.js → zero-react/src/components/inspector.js} +4 -9
  948. package/out/zero-react/src/components/inspector.js.map +1 -0
  949. package/out/{chunk-VZOYWIRW.js → zero-react/src/components/mark-icon.js} +3 -5
  950. package/out/zero-react/src/components/mark-icon.js.map +1 -0
  951. package/out/zero-react/src/components/zero-inspector.js +44 -0
  952. package/out/zero-react/src/components/zero-inspector.js.map +1 -0
  953. package/out/zero-react/src/mod.d.ts +1 -3
  954. package/out/zero-react/src/mod.d.ts.map +1 -1
  955. package/out/zero-react/src/use-query.d.ts +4 -4
  956. package/out/zero-react/src/use-query.d.ts.map +1 -1
  957. package/out/{react.js → zero-react/src/use-query.js} +25 -217
  958. package/out/zero-react/src/use-query.js.map +1 -0
  959. package/out/zero-react/src/use-zero-connection-state.d.ts +1 -1
  960. package/out/zero-react/src/use-zero-connection-state.d.ts.map +1 -1
  961. package/out/zero-react/src/use-zero-connection-state.js +14 -0
  962. package/out/zero-react/src/use-zero-connection-state.js.map +1 -0
  963. package/out/zero-react/src/use-zero-online.js +14 -0
  964. package/out/zero-react/src/use-zero-online.js.map +1 -0
  965. package/out/zero-react/src/zero-provider.d.ts +7 -6
  966. package/out/zero-react/src/zero-provider.d.ts.map +1 -1
  967. package/out/zero-react/src/zero-provider.js +59 -0
  968. package/out/zero-react/src/zero-provider.js.map +1 -0
  969. package/out/zero-schema/src/builder/relationship-builder.js +27 -0
  970. package/out/zero-schema/src/builder/relationship-builder.js.map +1 -0
  971. package/out/zero-schema/src/builder/schema-builder.js +88 -0
  972. package/out/zero-schema/src/builder/schema-builder.js.map +1 -0
  973. package/out/zero-schema/src/builder/table-builder.js +129 -0
  974. package/out/zero-schema/src/builder/table-builder.js.map +1 -0
  975. package/out/zero-schema/src/compiled-permissions.js +23 -19
  976. package/out/zero-schema/src/compiled-permissions.js.map +1 -1
  977. package/out/zero-schema/src/name-mapper.js +43 -38
  978. package/out/zero-schema/src/name-mapper.js.map +1 -1
  979. package/out/zero-schema/src/permissions.d.ts.map +1 -1
  980. package/out/zero-schema/src/permissions.js +199 -0
  981. package/out/zero-schema/src/permissions.js.map +1 -0
  982. package/out/zero-schema/src/schema-config.js +35 -51
  983. package/out/zero-schema/src/schema-config.js.map +1 -1
  984. package/out/zero-server/src/adapters/drizzle.d.ts +1 -1
  985. package/out/zero-server/src/adapters/drizzle.d.ts.map +1 -1
  986. package/out/zero-server/src/adapters/drizzle.js +83 -100
  987. package/out/zero-server/src/adapters/drizzle.js.map +1 -1
  988. package/out/zero-server/src/adapters/pg.d.ts +3 -2
  989. package/out/zero-server/src/adapters/pg.d.ts.map +1 -1
  990. package/out/zero-server/src/adapters/pg.js +53 -77
  991. package/out/zero-server/src/adapters/pg.js.map +1 -1
  992. package/out/zero-server/src/adapters/postgresjs.d.ts +1 -1
  993. package/out/zero-server/src/adapters/postgresjs.d.ts.map +1 -1
  994. package/out/zero-server/src/adapters/postgresjs.js +39 -57
  995. package/out/zero-server/src/adapters/postgresjs.js.map +1 -1
  996. package/out/zero-server/src/custom.d.ts +6 -6
  997. package/out/zero-server/src/custom.d.ts.map +1 -1
  998. package/out/zero-server/src/custom.js +185 -117
  999. package/out/zero-server/src/custom.js.map +1 -1
  1000. package/out/zero-server/src/logging.js +7 -4
  1001. package/out/zero-server/src/logging.js.map +1 -1
  1002. package/out/zero-server/src/mod.d.ts +2 -0
  1003. package/out/zero-server/src/mod.d.ts.map +1 -1
  1004. package/out/zero-server/src/pg-query-executor.js +17 -14
  1005. package/out/zero-server/src/pg-query-executor.js.map +1 -1
  1006. package/out/zero-server/src/process-mutations.js +293 -274
  1007. package/out/zero-server/src/process-mutations.js.map +1 -1
  1008. package/out/zero-server/src/push-processor.js +55 -31
  1009. package/out/zero-server/src/push-processor.js.map +1 -1
  1010. package/out/zero-server/src/queries/process-queries.d.ts +63 -2
  1011. package/out/zero-server/src/queries/process-queries.d.ts.map +1 -1
  1012. package/out/zero-server/src/queries/process-queries.js +101 -95
  1013. package/out/zero-server/src/queries/process-queries.js.map +1 -1
  1014. package/out/zero-server/src/query-registry.d.ts +10 -0
  1015. package/out/zero-server/src/query-registry.d.ts.map +1 -0
  1016. package/out/zero-server/src/query-registry.js +35 -0
  1017. package/out/zero-server/src/query-registry.js.map +1 -0
  1018. package/out/zero-server/src/schema.js +136 -124
  1019. package/out/zero-server/src/schema.js.map +1 -1
  1020. package/out/zero-server/src/zql-database.d.ts +4 -4
  1021. package/out/zero-server/src/zql-database.d.ts.map +1 -1
  1022. package/out/zero-server/src/zql-database.js +66 -47
  1023. package/out/zero-server/src/zql-database.js.map +1 -1
  1024. package/out/zero-solid/src/mod.d.ts +1 -2
  1025. package/out/zero-solid/src/mod.d.ts.map +1 -1
  1026. package/out/zero-solid/src/solid-view.d.ts +1 -1
  1027. package/out/zero-solid/src/solid-view.d.ts.map +1 -1
  1028. package/out/{solid.js → zero-solid/src/solid-view.js} +42 -196
  1029. package/out/zero-solid/src/solid-view.js.map +1 -0
  1030. package/out/zero-solid/src/use-query.d.ts +1 -1
  1031. package/out/zero-solid/src/use-query.d.ts.map +1 -1
  1032. package/out/zero-solid/src/use-query.js +70 -0
  1033. package/out/zero-solid/src/use-query.js.map +1 -0
  1034. package/out/zero-solid/src/use-zero-connection-state.d.ts +1 -1
  1035. package/out/zero-solid/src/use-zero-connection-state.d.ts.map +1 -1
  1036. package/out/zero-solid/src/use-zero-connection-state.js +15 -0
  1037. package/out/zero-solid/src/use-zero-connection-state.js.map +1 -0
  1038. package/out/zero-solid/src/use-zero-online.js +13 -0
  1039. package/out/zero-solid/src/use-zero-online.js.map +1 -0
  1040. package/out/zero-solid/src/use-zero.d.ts +1 -1
  1041. package/out/zero-solid/src/use-zero.d.ts.map +1 -1
  1042. package/out/zero-solid/src/use-zero.js +74 -0
  1043. package/out/zero-solid/src/use-zero.js.map +1 -0
  1044. package/out/zero-types/src/format.js +7 -4
  1045. package/out/zero-types/src/format.js.map +1 -1
  1046. package/out/zero-types/src/name-mapper.js +43 -40
  1047. package/out/zero-types/src/name-mapper.js.map +1 -1
  1048. package/out/zql/src/builder/builder.d.ts +2 -1
  1049. package/out/zql/src/builder/builder.d.ts.map +1 -1
  1050. package/out/zql/src/builder/builder.js +486 -428
  1051. package/out/zql/src/builder/builder.js.map +1 -1
  1052. package/out/zql/src/builder/debug-delegate.js +68 -64
  1053. package/out/zql/src/builder/debug-delegate.js.map +1 -1
  1054. package/out/zql/src/builder/filter.js +132 -138
  1055. package/out/zql/src/builder/filter.js.map +1 -1
  1056. package/out/zql/src/builder/like.js +44 -51
  1057. package/out/zql/src/builder/like.js.map +1 -1
  1058. package/out/zql/src/error.d.ts +5 -0
  1059. package/out/zql/src/error.d.ts.map +1 -1
  1060. package/out/zql/src/error.js +18 -6
  1061. package/out/zql/src/error.js.map +1 -1
  1062. package/out/zql/src/ivm/array-view.js +86 -92
  1063. package/out/zql/src/ivm/array-view.js.map +1 -1
  1064. package/out/zql/src/ivm/constraint.js +74 -127
  1065. package/out/zql/src/ivm/constraint.js.map +1 -1
  1066. package/out/zql/src/ivm/data.js +59 -85
  1067. package/out/zql/src/ivm/data.js.map +1 -1
  1068. package/out/zql/src/ivm/exists.js +236 -243
  1069. package/out/zql/src/ivm/exists.js.map +1 -1
  1070. package/out/zql/src/ivm/fan-in.js +50 -51
  1071. package/out/zql/src/ivm/fan-in.js.map +1 -1
  1072. package/out/zql/src/ivm/fan-out.js +48 -50
  1073. package/out/zql/src/ivm/fan-out.js.map +1 -1
  1074. package/out/zql/src/ivm/filter-operators.js +87 -87
  1075. package/out/zql/src/ivm/filter-operators.js.map +1 -1
  1076. package/out/zql/src/ivm/filter-push.js +26 -23
  1077. package/out/zql/src/ivm/filter-push.js.map +1 -1
  1078. package/out/zql/src/ivm/filter.js +30 -32
  1079. package/out/zql/src/ivm/filter.js.map +1 -1
  1080. package/out/zql/src/ivm/flipped-join.js +343 -326
  1081. package/out/zql/src/ivm/flipped-join.js.map +1 -1
  1082. package/out/zql/src/ivm/join-utils.js +85 -79
  1083. package/out/zql/src/ivm/join-utils.js.map +1 -1
  1084. package/out/zql/src/ivm/join.js +287 -207
  1085. package/out/zql/src/ivm/join.js.map +1 -1
  1086. package/out/zql/src/ivm/maybe-split-and-push-edit-change.js +26 -24
  1087. package/out/zql/src/ivm/maybe-split-and-push-edit-change.js.map +1 -1
  1088. package/out/zql/src/ivm/memory-source.d.ts +2 -2
  1089. package/out/zql/src/ivm/memory-source.d.ts.map +1 -1
  1090. package/out/zql/src/ivm/memory-source.js +471 -489
  1091. package/out/zql/src/ivm/memory-source.js.map +1 -1
  1092. package/out/zql/src/ivm/memory-storage.js +32 -31
  1093. package/out/zql/src/ivm/memory-storage.js.map +1 -1
  1094. package/out/zql/src/ivm/operator.js +8 -9
  1095. package/out/zql/src/ivm/operator.js.map +1 -1
  1096. package/out/zql/src/ivm/push-accumulated.js +236 -305
  1097. package/out/zql/src/ivm/push-accumulated.js.map +1 -1
  1098. package/out/zql/src/ivm/skip.js +92 -106
  1099. package/out/zql/src/ivm/skip.js.map +1 -1
  1100. package/out/zql/src/ivm/source.d.ts +3 -1
  1101. package/out/zql/src/ivm/source.d.ts.map +1 -1
  1102. package/out/zql/src/ivm/stream.js +20 -16
  1103. package/out/zql/src/ivm/stream.js.map +1 -1
  1104. package/out/zql/src/ivm/take.js +502 -456
  1105. package/out/zql/src/ivm/take.js.map +1 -1
  1106. package/out/zql/src/ivm/union-fan-in.js +156 -134
  1107. package/out/zql/src/ivm/union-fan-in.js.map +1 -1
  1108. package/out/zql/src/ivm/union-fan-out.js +46 -45
  1109. package/out/zql/src/ivm/union-fan-out.js.map +1 -1
  1110. package/out/zql/src/ivm/view-apply-change.js +246 -216
  1111. package/out/zql/src/ivm/view-apply-change.js.map +1 -1
  1112. package/out/zql/src/ivm/view.d.ts +2 -2
  1113. package/out/zql/src/ivm/view.d.ts.map +1 -1
  1114. package/out/zql/src/mutate/custom.d.ts +10 -10
  1115. package/out/zql/src/mutate/custom.d.ts.map +1 -1
  1116. package/out/zql/src/mutate/custom.js +15 -7
  1117. package/out/zql/src/mutate/custom.js.map +1 -1
  1118. package/out/zql/src/planner/planner-builder.js +238 -172
  1119. package/out/zql/src/planner/planner-builder.js.map +1 -1
  1120. package/out/zql/src/planner/planner-connection.js +202 -251
  1121. package/out/zql/src/planner/planner-connection.js.map +1 -1
  1122. package/out/zql/src/planner/planner-constraint.js +8 -11
  1123. package/out/zql/src/planner/planner-constraint.js.map +1 -1
  1124. package/out/zql/src/planner/planner-fan-in.js +154 -164
  1125. package/out/zql/src/planner/planner-fan-in.js.map +1 -1
  1126. package/out/zql/src/planner/planner-fan-out.js +71 -60
  1127. package/out/zql/src/planner/planner-fan-out.js.map +1 -1
  1128. package/out/zql/src/planner/planner-graph.d.ts +6 -6
  1129. package/out/zql/src/planner/planner-graph.d.ts.map +1 -1
  1130. package/out/zql/src/planner/planner-graph.js +315 -338
  1131. package/out/zql/src/planner/planner-graph.js.map +1 -1
  1132. package/out/zql/src/planner/planner-join.js +234 -342
  1133. package/out/zql/src/planner/planner-join.js.map +1 -1
  1134. package/out/zql/src/planner/planner-source.js +23 -12
  1135. package/out/zql/src/planner/planner-source.js.map +1 -1
  1136. package/out/zql/src/planner/planner-terminus.js +28 -27
  1137. package/out/zql/src/planner/planner-terminus.js.map +1 -1
  1138. package/out/zql/src/query/complete-ordering.d.ts +5 -0
  1139. package/out/zql/src/query/complete-ordering.d.ts.map +1 -0
  1140. package/out/zql/src/query/complete-ordering.js +71 -0
  1141. package/out/zql/src/query/complete-ordering.js.map +1 -0
  1142. package/out/zql/src/query/define-query.d.ts +47 -23
  1143. package/out/zql/src/query/define-query.d.ts.map +1 -1
  1144. package/out/zql/src/query/define-query.js +45 -51
  1145. package/out/zql/src/query/define-query.js.map +1 -1
  1146. package/out/zql/src/query/error.js +12 -8
  1147. package/out/zql/src/query/error.js.map +1 -1
  1148. package/out/zql/src/query/escape-like.js +7 -0
  1149. package/out/zql/src/query/escape-like.js.map +1 -0
  1150. package/out/zql/src/query/expression.js +153 -151
  1151. package/out/zql/src/query/expression.js.map +1 -1
  1152. package/out/zql/src/query/measure-push-operator.js +42 -35
  1153. package/out/zql/src/query/measure-push-operator.js.map +1 -1
  1154. package/out/zql/src/query/metrics-delegate.js +9 -5
  1155. package/out/zql/src/query/metrics-delegate.js.map +1 -1
  1156. package/out/zql/src/query/named.d.ts +9 -5
  1157. package/out/zql/src/query/named.d.ts.map +1 -1
  1158. package/out/zql/src/query/named.js +70 -85
  1159. package/out/zql/src/query/named.js.map +1 -1
  1160. package/out/zql/src/query/query-definitions.d.ts +32 -0
  1161. package/out/zql/src/query/query-definitions.d.ts.map +1 -0
  1162. package/out/zql/src/query/query-delegate-base.d.ts +6 -14
  1163. package/out/zql/src/query/query-delegate-base.d.ts.map +1 -1
  1164. package/out/zql/src/query/query-delegate-base.js +118 -134
  1165. package/out/zql/src/query/query-delegate-base.js.map +1 -1
  1166. package/out/zql/src/query/query-delegate.d.ts +6 -8
  1167. package/out/zql/src/query/query-delegate.d.ts.map +1 -1
  1168. package/out/zql/src/query/query-impl.d.ts +17 -18
  1169. package/out/zql/src/query/query-impl.d.ts.map +1 -1
  1170. package/out/zql/src/query/query-impl.js +511 -433
  1171. package/out/zql/src/query/query-impl.js.map +1 -1
  1172. package/out/zql/src/query/query-internals.d.ts +11 -13
  1173. package/out/zql/src/query/query-internals.d.ts.map +1 -1
  1174. package/out/zql/src/query/query-internals.js +13 -19
  1175. package/out/zql/src/query/query-internals.js.map +1 -1
  1176. package/out/zql/src/query/query.d.ts +15 -16
  1177. package/out/zql/src/query/query.d.ts.map +1 -1
  1178. package/out/zql/src/query/static-query.d.ts +3 -3
  1179. package/out/zql/src/query/static-query.d.ts.map +1 -1
  1180. package/out/zql/src/query/static-query.js +41 -18
  1181. package/out/zql/src/query/static-query.js.map +1 -1
  1182. package/out/zql/src/query/ttl.js +69 -62
  1183. package/out/zql/src/query/ttl.js.map +1 -1
  1184. package/out/zql/src/query/validate-input.d.ts +15 -0
  1185. package/out/zql/src/query/validate-input.d.ts.map +1 -0
  1186. package/out/zql/src/query/validate-input.js +25 -0
  1187. package/out/zql/src/query/validate-input.js.map +1 -0
  1188. package/out/zqlite/src/database-storage.d.ts +1 -1
  1189. package/out/zqlite/src/database-storage.d.ts.map +1 -1
  1190. package/out/zqlite/src/database-storage.js +99 -102
  1191. package/out/zqlite/src/database-storage.js.map +1 -1
  1192. package/out/zqlite/src/db.js +241 -194
  1193. package/out/zqlite/src/db.js.map +1 -1
  1194. package/out/zqlite/src/explain-queries.js +13 -16
  1195. package/out/zqlite/src/explain-queries.js.map +1 -1
  1196. package/out/zqlite/src/internal/sql.js +15 -10
  1197. package/out/zqlite/src/internal/sql.js.map +1 -1
  1198. package/out/zqlite/src/internal/statement-cache.js +86 -110
  1199. package/out/zqlite/src/internal/statement-cache.js.map +1 -1
  1200. package/out/zqlite/src/query-builder.js +172 -143
  1201. package/out/zqlite/src/query-builder.js.map +1 -1
  1202. package/out/zqlite/src/query-delegate.d.ts +2 -2
  1203. package/out/zqlite/src/query-delegate.d.ts.map +1 -1
  1204. package/out/zqlite/src/query-delegate.js +53 -43
  1205. package/out/zqlite/src/query-delegate.js.map +1 -1
  1206. package/out/zqlite/src/sqlite-cost-model.js +94 -125
  1207. package/out/zqlite/src/sqlite-cost-model.js.map +1 -1
  1208. package/out/zqlite/src/sqlite-stat-fanout.js +277 -353
  1209. package/out/zqlite/src/sqlite-stat-fanout.js.map +1 -1
  1210. package/out/zqlite/src/table-source.d.ts +9 -4
  1211. package/out/zqlite/src/table-source.d.ts.map +1 -1
  1212. package/out/zqlite/src/table-source.js +424 -327
  1213. package/out/zqlite/src/table-source.js.map +1 -1
  1214. package/package.json +22 -25
  1215. package/out/chunk-424PT5DM.js +0 -23
  1216. package/out/chunk-424PT5DM.js.map +0 -7
  1217. package/out/chunk-AFADJQ2O.js +0 -1
  1218. package/out/chunk-AFADJQ2O.js.map +0 -7
  1219. package/out/chunk-ASRS2LFV.js.map +0 -7
  1220. package/out/chunk-EZM3XBAB.js.map +0 -7
  1221. package/out/chunk-FODUNUAD.js +0 -18850
  1222. package/out/chunk-FODUNUAD.js.map +0 -7
  1223. package/out/chunk-HCZQVP5R.js.map +0 -7
  1224. package/out/chunk-S633A55A.js +0 -495
  1225. package/out/chunk-S633A55A.js.map +0 -7
  1226. package/out/chunk-TAUDS4QP.js +0 -4129
  1227. package/out/chunk-TAUDS4QP.js.map +0 -7
  1228. package/out/chunk-VZOYWIRW.js.map +0 -7
  1229. package/out/chunk-WPAQ4EPM.js.map +0 -7
  1230. package/out/expo-sqlite.js +0 -11
  1231. package/out/expo-sqlite.js.map +0 -7
  1232. package/out/inspector-GP3CBZRU.js.map +0 -7
  1233. package/out/lazy-inspector-XLKVABX2.js +0 -575
  1234. package/out/lazy-inspector-XLKVABX2.js.map +0 -7
  1235. package/out/op-sqlite.js.map +0 -7
  1236. package/out/react-native.js +0 -25
  1237. package/out/react-native.js.map +0 -7
  1238. package/out/react.js.map +0 -7
  1239. package/out/shared/src/enum.js +0 -2
  1240. package/out/shared/src/enum.js.map +0 -1
  1241. package/out/shared/src/expand.js +0 -2
  1242. package/out/shared/src/expand.js.map +0 -1
  1243. package/out/shared/src/immutable.js +0 -2
  1244. package/out/shared/src/immutable.js.map +0 -1
  1245. package/out/shared/src/types.js +0 -2
  1246. package/out/shared/src/types.js.map +0 -1
  1247. package/out/shared/src/writable.js +0 -2
  1248. package/out/shared/src/writable.js.map +0 -1
  1249. package/out/solid.js.map +0 -7
  1250. package/out/sqlite.js +0 -15
  1251. package/out/sqlite.js.map +0 -7
  1252. package/out/zero/package.json +0 -195
  1253. package/out/zero/src/server/change-streamer.js +0 -2
  1254. package/out/zero/src/server/change-streamer.js.map +0 -1
  1255. package/out/zero/src/server/main.js +0 -2
  1256. package/out/zero/src/server/main.js.map +0 -1
  1257. package/out/zero/src/server/reaper.js +0 -2
  1258. package/out/zero/src/server/reaper.js.map +0 -1
  1259. package/out/zero/src/server/replicator.js +0 -2
  1260. package/out/zero/src/server/replicator.js.map +0 -1
  1261. package/out/zero/src/server/runner/main.js +0 -2
  1262. package/out/zero/src/server/runner/main.js.map +0 -1
  1263. package/out/zero/src/server/syncer.js +0 -2
  1264. package/out/zero/src/server/syncer.js.map +0 -1
  1265. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput.types.js +0 -4
  1266. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput.types.js.map +0 -1
  1267. package/out/zero-cache/src/services/change-source/protocol/mod.js +0 -5
  1268. package/out/zero-cache/src/services/change-source/protocol/mod.js.map +0 -1
  1269. package/out/zero-cache/src/services/service.js +0 -2
  1270. package/out/zero-cache/src/services/service.js.map +0 -1
  1271. package/out/zero-cache/src/services/view-syncer/key-columns.d.ts +0 -32
  1272. package/out/zero-cache/src/services/view-syncer/key-columns.d.ts.map +0 -1
  1273. package/out/zero-cache/src/services/view-syncer/key-columns.js +0 -75
  1274. package/out/zero-cache/src/services/view-syncer/key-columns.js.map +0 -1
  1275. package/out/zero-cache/src/types/satisfies.js +0 -2
  1276. package/out/zero-cache/src/types/satisfies.js.map +0 -1
  1277. package/out/zero-events/src/index.js +0 -2
  1278. package/out/zero-events/src/index.js.map +0 -1
  1279. package/out/zero-events/src/json.js +0 -2
  1280. package/out/zero-events/src/json.js.map +0 -1
  1281. package/out/zero-events/src/status.js +0 -3
  1282. package/out/zero-events/src/status.js.map +0 -1
  1283. package/out/zero-pg/src/mod.js +0 -6
  1284. package/out/zero-pg/src/mod.js.map +0 -1
  1285. package/out/zero-protocol/src/error-kind.js +0 -3
  1286. package/out/zero-protocol/src/error-kind.js.map +0 -1
  1287. package/out/zero-protocol/src/error-origin.js +0 -3
  1288. package/out/zero-protocol/src/error-origin.js.map +0 -1
  1289. package/out/zero-protocol/src/error-reason.js +0 -3
  1290. package/out/zero-protocol/src/error-reason.js.map +0 -1
  1291. package/out/zero-schema/src/table-schema.js +0 -7
  1292. package/out/zero-schema/src/table-schema.js.map +0 -1
  1293. package/out/zero-server/src/mod.js +0 -8
  1294. package/out/zero-server/src/mod.js.map +0 -1
  1295. package/out/zero-types/src/schema-value.js +0 -2
  1296. package/out/zero-types/src/schema-value.js.map +0 -1
  1297. package/out/zero-types/src/schema.js +0 -2
  1298. package/out/zero-types/src/schema.js.map +0 -1
  1299. package/out/zero-types/src/server-schema.js +0 -2
  1300. package/out/zero-types/src/server-schema.js.map +0 -1
  1301. package/out/zero.js +0 -95
  1302. package/out/zero.js.map +0 -7
  1303. package/out/zql/src/ivm/change.js +0 -2
  1304. package/out/zql/src/ivm/change.js.map +0 -1
  1305. package/out/zql/src/ivm/default-format.js +0 -2
  1306. package/out/zql/src/ivm/default-format.js.map +0 -1
  1307. package/out/zql/src/ivm/schema.js +0 -2
  1308. package/out/zql/src/ivm/schema.js.map +0 -1
  1309. package/out/zql/src/ivm/source.js +0 -2
  1310. package/out/zql/src/ivm/source.js.map +0 -1
  1311. package/out/zql/src/ivm/view.js +0 -2
  1312. package/out/zql/src/ivm/view.js.map +0 -1
  1313. package/out/zql/src/planner/planner-debug.js +0 -176
  1314. package/out/zql/src/planner/planner-debug.js.map +0 -1
  1315. package/out/zql/src/planner/planner-node.js +0 -2
  1316. package/out/zql/src/planner/planner-node.js.map +0 -1
  1317. package/out/zql/src/query/chained-query.d.ts +0 -35
  1318. package/out/zql/src/query/chained-query.d.ts.map +0 -1
  1319. package/out/zql/src/query/chained-query.js +0 -66
  1320. package/out/zql/src/query/chained-query.js.map +0 -1
  1321. package/out/zql/src/query/query-delegate.js +0 -2
  1322. package/out/zql/src/query/query-delegate.js.map +0 -1
  1323. package/out/zql/src/query/query.js +0 -8
  1324. package/out/zql/src/query/query.js.map +0 -1
  1325. package/out/zql/src/query/root-named-query.d.ts +0 -33
  1326. package/out/zql/src/query/root-named-query.d.ts.map +0 -1
  1327. package/out/zql/src/query/root-named-query.js +0 -95
  1328. package/out/zql/src/query/root-named-query.js.map +0 -1
  1329. package/out/zql/src/query/typed-view.js +0 -2
  1330. package/out/zql/src/query/typed-view.js.map +0 -1
  1331. package/out/zqlite/src/mod.js +0 -5
  1332. package/out/zqlite/src/mod.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"cvr.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/view-syncer/cvr.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"cvr.js","sources":["../../../../../../zero-cache/src/services/view-syncer/cvr.ts"],"sourcesContent":["import type {LogContext} from '@rocicorp/logger';\nimport {assert} from '../../../../shared/src/asserts.ts';\nimport {type JSONObject} from '../../../../shared/src/bigint-json.ts';\nimport {CustomKeyMap} from '../../../../shared/src/custom-key-map.ts';\nimport {\n deepEqual,\n type ReadonlyJSONValue,\n} from '../../../../shared/src/json.ts';\nimport {must} from '../../../../shared/src/must.ts';\nimport {\n difference,\n intersection,\n union,\n} from '../../../../shared/src/set-utils.ts';\nimport {stringCompare} from '../../../../shared/src/string-compare.ts';\nimport type {AST} from '../../../../zero-protocol/src/ast.ts';\nimport type {ClientSchema} from '../../../../zero-protocol/src/client-schema.ts';\nimport {ErrorOrigin} from '../../../../zero-protocol/src/error-origin.ts';\nimport {ProtocolError} from '../../../../zero-protocol/src/error.ts';\nimport {\n clampTTL,\n compareTTL,\n DEFAULT_TTL_MS,\n} from '../../../../zql/src/query/ttl.ts';\nimport {recordQuery} from '../../server/anonymous-otel-start.ts';\nimport type {LexiVersion} from '../../types/lexi-version.ts';\nimport {rowIDString} from '../../types/row-key.ts';\nimport {upstreamSchema, type ShardID} from '../../types/shards.ts';\nimport type {Patch, PatchToVersion} from './client-handler.ts';\nimport {type CVRFlushStats, type CVRStore} from './cvr-store.ts';\nimport {\n cmpVersions,\n maxVersion,\n oneAfter,\n type ClientQueryRecord,\n type ClientRecord,\n type CustomQueryRecord,\n type CVRVersion,\n type InternalQueryRecord,\n type QueryRecord,\n type RowID,\n type RowRecord,\n} from './schema/types.ts';\nimport {ttlClockAsNumber, type TTLClock} from './ttl-clock.ts';\n\nexport type RowUpdate = {\n version?: string; // Undefined for an unref.\n contents?: JSONObject; // Undefined for an unref.\n refCounts: {[hash: string]: number}; // Counts are negative when a row is unrefed.\n};\n\n/** Internally used mutable CVR type. */\nexport type CVR = {\n id: string;\n version: CVRVersion;\n lastActive: number;\n ttlClock: TTLClock;\n replicaVersion: string | null;\n clients: Record<string, ClientRecord>;\n queries: Record<string, QueryRecord>;\n clientSchema: ClientSchema | null;\n};\n\n/** Exported immutable CVR type. */\n// TODO: Use Immutable<CVR> when the AST is immutable.\nexport type CVRSnapshot = {\n readonly id: string;\n readonly version: CVRVersion;\n readonly lastActive: number;\n readonly ttlClock: TTLClock;\n readonly replicaVersion: string | null;\n readonly clients: Readonly<Record<string, ClientRecord>>;\n readonly queries: Readonly<Record<string, QueryRecord>>;\n readonly clientSchema: ClientSchema | null;\n};\n\nconst CLIENT_LMID_QUERY_ID = 'lmids';\nconst CLIENT_MUTATION_RESULTS_QUERY_ID = 'mutationResults';\n\nfunction assertNotInternal(\n query: QueryRecord,\n): asserts query is ClientQueryRecord {\n if (query.type === 'internal') {\n // This should never happen for behaving clients, as query ids should be hashes.\n throw new Error(`Query ID ${query.id} is reserved for internal use`);\n }\n}\n\nexport function getMutationResultsQuery(\n upstreamSchema: string,\n clientGroupID: string,\n): InternalQueryRecord {\n return {\n id: CLIENT_MUTATION_RESULTS_QUERY_ID,\n type: 'internal',\n ast: {\n schema: '',\n table: `${upstreamSchema}.mutations`,\n where: {\n type: 'and',\n conditions: [\n {\n type: 'simple',\n left: {\n type: 'column',\n name: 'clientGroupID',\n },\n op: '=',\n right: {\n type: 'literal',\n value: clientGroupID,\n },\n },\n ],\n },\n orderBy: [\n ['clientGroupID', 'asc'],\n ['clientID', 'asc'],\n ['mutationID', 'asc'],\n ],\n },\n };\n}\n\n/**\n * The base CVRUpdater contains logic common to the {@link CVRConfigDrivenUpdater} and\n * {@link CVRQueryDrivenUpdater}. The CVRUpdater class itself is exported for updating\n * the `lastActive` time of the CVR in the absence of any changes to the CVR contents.\n * Although activity is automatically tracked when the CVR contents change, there may be\n * edge cases in which a client actively connects to a CVR that doesn't itself change.\n * Calling `new CVRUpdater(...).flush()` will explicitly update the active index and\n * prevent the CVR from being garbage collected.\n */\nexport class CVRUpdater {\n protected readonly _orig: CVRSnapshot;\n protected readonly _cvr: CVR;\n\n protected readonly _cvrStore: CVRStore;\n\n /**\n * @param cvrStore The CVRStore to use for storage\n * @param cvr The current CVR\n */\n constructor(\n cvrStore: CVRStore,\n cvr: CVRSnapshot,\n replicaVersion: string | null,\n ) {\n this._cvrStore = cvrStore;\n this._orig = cvr;\n this._cvr = structuredClone(cvr) as CVR; // mutable deep copy\n this._cvr.replicaVersion = replicaVersion;\n }\n\n protected _setVersion(version: CVRVersion) {\n assert(cmpVersions(this._cvr.version, version) < 0);\n this._cvr.version = version;\n return version;\n }\n\n /**\n * Ensures that the new CVR has a higher version than the original.\n * This method is idempotent in that it will always return the same\n * (possibly bumped) version.\n */\n protected _ensureNewVersion(): CVRVersion {\n if (cmpVersions(this._orig.version, this._cvr.version) === 0) {\n this._setVersion(oneAfter(this._cvr.version));\n }\n return this._cvr.version;\n }\n\n async flush(\n lc: LogContext,\n lastConnectTime: number,\n lastActive: number,\n ttlClock: TTLClock,\n ): Promise<{\n cvr: CVRSnapshot;\n flushed: CVRFlushStats | false;\n }> {\n this._cvr.ttlClock = ttlClock;\n this._cvr.lastActive = lastActive;\n const flushed = await this._cvrStore.flush(\n lc,\n this._orig.version,\n this._cvr,\n lastConnectTime,\n );\n if (!flushed) {\n return {cvr: this._orig, flushed: false};\n }\n return {cvr: this._cvr, flushed};\n }\n}\n\n/**\n * A {@link CVRConfigDrivenUpdater} is used for updating a CVR with config-driven\n * changes. Note that this may result in row deletion (e.g. if queries get dropped),\n * but the `stateVersion` of the CVR does not change.\n */\nexport class CVRConfigDrivenUpdater extends CVRUpdater {\n readonly #shard: ShardID;\n\n constructor(cvrStore: CVRStore, cvr: CVRSnapshot, shard: ShardID) {\n super(cvrStore, cvr, cvr.replicaVersion);\n this.#shard = shard;\n }\n\n ensureClient(id: string): ClientRecord {\n let client = this._cvr.clients[id];\n if (client) {\n return client;\n }\n // Add the ClientRecord and PutPatch\n client = {id, desiredQueryIDs: []};\n this._cvr.clients[id] = client;\n\n this._ensureNewVersion();\n this._cvrStore.insertClient(client);\n\n if (!this._cvr.queries[CLIENT_LMID_QUERY_ID]) {\n const lmidsQuery: InternalQueryRecord = {\n id: CLIENT_LMID_QUERY_ID,\n ast: {\n schema: '',\n table: `${upstreamSchema(this.#shard)}.clients`,\n where: {\n type: 'simple',\n left: {\n type: 'column',\n name: 'clientGroupID',\n },\n op: '=',\n right: {\n type: 'literal',\n value: this._cvr.id,\n },\n },\n orderBy: [\n ['clientGroupID', 'asc'],\n ['clientID', 'asc'],\n ],\n },\n type: 'internal',\n };\n this._cvr.queries[CLIENT_LMID_QUERY_ID] = lmidsQuery;\n this._cvrStore.putQuery(lmidsQuery);\n }\n if (!this._cvr.queries[CLIENT_MUTATION_RESULTS_QUERY_ID]) {\n const mutationResultsQuery: InternalQueryRecord = getMutationResultsQuery(\n upstreamSchema(this.#shard),\n this._cvr.id,\n );\n this._cvr.queries[CLIENT_MUTATION_RESULTS_QUERY_ID] =\n mutationResultsQuery;\n this._cvrStore.putQuery(mutationResultsQuery);\n }\n\n return client;\n }\n\n setClientSchema(lc: LogContext, clientSchema: ClientSchema) {\n if (this._cvr.clientSchema === null) {\n this._cvr.clientSchema = clientSchema;\n this._cvrStore.putInstance(this._cvr);\n } else if (!deepEqual(this._cvr.clientSchema, clientSchema)) {\n // This should not be possible with a correct Zero client, as clients\n // of a CVR should all have the same schema (given that the schema hash\n // is part of the idb key). In fact, clients joining an existing group\n // (i.e. non-empty baseCookie) do not send the clientSchema message.\n lc.warn?.(\n `New schema ${JSON.stringify(\n clientSchema,\n )} does not match existing schema ${JSON.stringify(\n this._cvr.clientSchema,\n )}`,\n );\n throw new ProtocolError({\n kind: 'InvalidConnectionRequest',\n message: `Provided schema does not match previous schema`,\n origin: ErrorOrigin.ZeroCache,\n });\n }\n }\n\n putDesiredQueries(\n clientID: string,\n queries: Readonly<{\n hash: string;\n ast?: AST | undefined;\n name?: string | undefined;\n args?: readonly ReadonlyJSONValue[] | undefined;\n ttl?: number | undefined;\n }>[],\n ): PatchToVersion[] {\n const patches: PatchToVersion[] = [];\n const client = this.ensureClient(clientID);\n const current = new Set(client.desiredQueryIDs);\n\n // Find the new/changed desired queries.\n const needed: Set<string> = new Set();\n\n const recordQueryForTelemetry = (q: (typeof queries)[0]) => {\n const {ast, name, args} = q;\n if (ast) {\n recordQuery('crud');\n } else if (name && args) {\n recordQuery('custom');\n }\n };\n\n for (const q of queries) {\n const {hash, ttl = DEFAULT_TTL_MS} = q;\n const query = this._cvr.queries[hash];\n if (!query) {\n // New query - record for telemetry\n recordQueryForTelemetry(q);\n needed.add(hash);\n continue;\n }\n if (query.type === 'internal') {\n continue;\n }\n\n const oldClientState = query.clientState[clientID];\n // Old query was inactivated or never desired by this client.\n if (!oldClientState || oldClientState.inactivatedAt !== undefined) {\n // Reactivated query - record for telemetry\n recordQueryForTelemetry(q);\n needed.add(hash);\n continue;\n }\n\n if (compareTTL(ttl, oldClientState.ttl) > 0) {\n // TTL update only - don't record for telemetry\n needed.add(hash);\n }\n }\n\n if (needed.size === 0) {\n return patches;\n }\n const newVersion = this._ensureNewVersion();\n client.desiredQueryIDs = [...union(current, needed)].sort(stringCompare);\n\n for (const id of needed) {\n const q = must(queries.find(({hash}) => hash === id));\n const {ast, name, args} = q;\n\n const ttl = clampTTL(q.ttl ?? DEFAULT_TTL_MS);\n const query =\n this._cvr.queries[id] ?? newQueryRecord(id, ast, name, args);\n assertNotInternal(query);\n\n const inactivatedAt = undefined;\n\n query.clientState[clientID] = {\n inactivatedAt,\n ttl,\n version: newVersion,\n };\n this._cvr.queries[id] = query;\n patches.push({\n toVersion: newVersion,\n patch: {type: 'query', op: 'put', id, clientID},\n });\n\n this._cvrStore.putQuery(query);\n this._cvrStore.putDesiredQuery(\n newVersion,\n query,\n client,\n false,\n inactivatedAt,\n ttl,\n );\n }\n return patches;\n }\n\n markDesiredQueriesAsInactive(\n clientID: string,\n queryHashes: string[],\n ttlClock: TTLClock,\n ): PatchToVersion[] {\n return this.#deleteQueries(clientID, queryHashes, ttlClock);\n }\n\n deleteDesiredQueries(\n clientID: string,\n queryHashes: string[],\n ): PatchToVersion[] {\n return this.#deleteQueries(clientID, queryHashes, undefined);\n }\n\n #deleteQueries(\n clientID: string,\n queryHashes: string[],\n inactivatedAt: TTLClock | undefined,\n ): PatchToVersion[] {\n const patches: PatchToVersion[] = [];\n const client = this.ensureClient(clientID);\n const current = new Set(client.desiredQueryIDs);\n const unwanted = new Set(queryHashes);\n const remove = intersection(unwanted, current);\n if (remove.size === 0) {\n return patches;\n }\n\n const newVersion = this._ensureNewVersion();\n client.desiredQueryIDs = [...difference(current, remove)].sort(\n stringCompare,\n );\n\n for (const id of remove) {\n const query = this._cvr.queries[id];\n if (!query) {\n continue; // Query itself has already been removed. Should not happen?\n }\n assertNotInternal(query);\n\n let ttl = DEFAULT_TTL_MS;\n if (inactivatedAt === undefined) {\n delete query.clientState[clientID];\n } else {\n // client state can be missing if the query never transformed so we never\n // recorded it.\n const clientState = query.clientState[clientID];\n if (clientState !== undefined) {\n assert(\n clientState.inactivatedAt === undefined,\n `Query ${id} is already inactivated`,\n );\n // Clamp TTL to ensure we don't propagate historical unclamped values.\n ttl = clampTTL(clientState.ttl);\n query.clientState[clientID] = {\n inactivatedAt,\n ttl,\n version: newVersion,\n };\n }\n }\n\n this._cvrStore.putQuery(query);\n this._cvrStore.putDesiredQuery(\n newVersion,\n query,\n client,\n true,\n inactivatedAt,\n ttl,\n );\n patches.push({\n toVersion: newVersion,\n patch: {type: 'query', op: 'del', id, clientID},\n });\n }\n return patches;\n }\n\n clearDesiredQueries(clientID: string): PatchToVersion[] {\n const client = this.ensureClient(clientID);\n return this.#deleteQueries(clientID, client.desiredQueryIDs, undefined);\n }\n\n deleteClient(clientID: string, ttlClock: TTLClock): PatchToVersion[] {\n // clientID might not be part of this client group but if it is, this delete\n // may generate changes to the desired queries.\n\n const client = this._cvr.clients[clientID];\n if (!client) {\n // Clients in different client groups are no longer deleted, leaving\n // cleanup to inactive CVR purging logic.\n return [];\n }\n\n // When a client is deleted we mark all of its desired queries as inactive.\n // They will then be removed when the queries expire.\n const patches = this.markDesiredQueriesAsInactive(\n clientID,\n client.desiredQueryIDs,\n ttlClock,\n );\n delete this._cvr.clients[clientID];\n this._cvrStore.deleteClient(clientID);\n\n return patches;\n }\n}\n\ntype Hash = string;\nexport type Column = string;\nexport type RefCounts = Record<Hash, number>;\n\ntype RowPatchInfo = {\n rowVersion: string | null; // null for a row-del\n toVersion: CVRVersion; // patchVersion\n};\n\n/**\n * A {@link CVRQueryDrivenUpdater} is used for updating a CVR after making queries.\n * The caller should invoke:\n *\n * * {@link trackQueries} for queries that are being executed or removed.\n * * {@link received} for all rows received from the executed queries\n * * {@link deleteUnreferencedRows} to remove any rows that have\n * fallen out of the query result view.\n * * {@link flush}\n *\n * After flushing, the caller should perform any necessary catchup of\n * config and row patches for clients that are behind. See\n * {@link CVRStore.catchupConfigPatches} and {@link CVRStore.catchupRowPatches}.\n */\nexport class CVRQueryDrivenUpdater extends CVRUpdater {\n readonly #removedOrExecutedQueryIDs = new Set<string>();\n readonly #receivedRows = new CustomKeyMap<RowID, RefCounts | null>(\n rowIDString,\n );\n readonly #lastPatches = new CustomKeyMap<RowID, RowPatchInfo>(rowIDString);\n\n #existingRows: Promise<Iterable<RowRecord>> | undefined = undefined;\n\n /**\n * @param stateVersion The `stateVersion` at which the queries were executed.\n */\n constructor(\n cvrStore: CVRStore,\n cvr: CVRSnapshot,\n stateVersion: LexiVersion,\n replicaVersion: string,\n ) {\n super(cvrStore, cvr, replicaVersion);\n\n assert(\n // We should either be setting the cvr.replicaVersion for the first time, or it should\n // be something newer than the current cvr.replicaVersion. Otherwise, the CVR should\n // have been rejected by the ViewSyncer.\n (cvr.replicaVersion ?? replicaVersion) <= replicaVersion,\n `Cannot sync from an older replicaVersion: CVR=${cvr.replicaVersion}, DB=${replicaVersion}`,\n );\n assert(stateVersion >= cvr.version.stateVersion);\n if (stateVersion > cvr.version.stateVersion) {\n this._setVersion({stateVersion});\n }\n }\n\n /**\n * Initiates the tracking of the specified `executed` and `removed` queries.\n * This kicks of a lookup of existing {@link RowRecord}s currently associated\n * with those queries, which will be used to reconcile the rows to keep\n * after all rows have been {@link received()}.\n *\n * \"transformed\" queries are queries that are currently\n * gotten and running in the pipeline driver but\n * received a new transformation hash due to an auth token\n * update.\n *\n * @returns The new CVRVersion to be used when all changes are committed.\n */\n trackQueries(\n lc: LogContext,\n executed: {id: string; transformationHash: string}[],\n removed: {id: string; transformationHash: string | undefined}[],\n ): {newVersion: CVRVersion; queryPatches: PatchToVersion[]} {\n assert(this.#existingRows === undefined, `trackQueries already called`);\n\n const queryPatches: Patch[] = [\n executed.map(q => this.#trackExecuted(q.id, q.transformationHash)),\n removed.map(q => this.#trackRemoved(q.id)),\n ].flat(2);\n\n this.#existingRows = this.#lookupRowsForExecutedAndRemovedQueries(lc);\n\n return {\n newVersion: this._cvr.version,\n queryPatches: queryPatches.map(patch => ({\n patch,\n toVersion: this._cvr.version,\n })),\n };\n }\n\n async #lookupRowsForExecutedAndRemovedQueries(\n lc: LogContext,\n ): Promise<Iterable<RowRecord>> {\n const results = new CustomKeyMap<RowID, RowRecord>(rowIDString);\n\n if (this.#removedOrExecutedQueryIDs.size === 0) {\n // Query-less update. This can happen for config only changes.\n return [];\n }\n\n // Utilizes the in-memory RowCache.\n const allRowRecords = (await this._cvrStore.getRowRecords()).values();\n let total = 0;\n for (const existing of allRowRecords) {\n total++;\n assert(existing.refCounts !== null); // allRowRecords does not include null.\n for (const id of Object.keys(existing.refCounts)) {\n if (this.#removedOrExecutedQueryIDs.has(id)) {\n results.set(existing.id, existing);\n break;\n }\n }\n }\n\n lc.debug?.(\n `found ${\n results.size\n } (of ${total}) rows for executed / removed queries ${[\n ...this.#removedOrExecutedQueryIDs,\n ]}`,\n );\n return results.values();\n }\n\n /**\n * Tracks an executed query, ensures that it is marked as \"gotten\",\n * updating the CVR and creating put patches if necessary.\n *\n * This must be called for all executed queries.\n */\n #trackExecuted(queryID: string, transformationHash: string): Patch[] {\n assert(!this.#removedOrExecutedQueryIDs.has(queryID));\n this.#removedOrExecutedQueryIDs.add(queryID);\n\n let gotQueryPatch: Patch | undefined;\n const query = this._cvr.queries[queryID];\n if (query.transformationHash !== transformationHash) {\n const transformationVersion = this._ensureNewVersion();\n\n if (query.type !== 'internal' && query.patchVersion === undefined) {\n // client query: desired -> gotten\n query.patchVersion = transformationVersion;\n gotQueryPatch = {\n type: 'query',\n op: 'put',\n id: query.id,\n };\n }\n\n query.transformationHash = transformationHash;\n query.transformationVersion = transformationVersion;\n this._cvrStore.updateQuery(query);\n }\n return gotQueryPatch ? [gotQueryPatch] : [];\n }\n\n /**\n * Tracks a query removed from the \"gotten\" set. In addition to producing the\n * appropriate patches for deleting the query, the removed query is taken into\n * account when computing the final row records in\n * {@link deleteUnreferencedRows}.\n * Namely, any rows with columns that are no longer referenced by a\n * query are deleted.\n *\n * This must only be called on queries that are not \"desired\" by any client.\n */\n #trackRemoved(queryID: string): Patch[] {\n const query = this._cvr.queries[queryID];\n assertNotInternal(query);\n\n assert(!this.#removedOrExecutedQueryIDs.has(queryID));\n this.#removedOrExecutedQueryIDs.add(queryID);\n delete this._cvr.queries[queryID];\n\n const newVersion = this._ensureNewVersion();\n const queryPatch = {type: 'query', op: 'del', id: queryID} as const;\n this._cvrStore.markQueryAsDeleted(newVersion, queryPatch);\n return [queryPatch];\n }\n\n /**\n * Asserts that a new version has already been set.\n *\n * After {@link #executed} and {@link #removed} are called, we must have properly\n * decided on the final CVR version because the poke-start message declares the\n * final cookie (i.e. version), and that must be sent before any poke parts\n * generated from {@link received} are sent.\n */\n #assertNewVersion(): CVRVersion {\n assert(cmpVersions(this._orig.version, this._cvr.version) < 0);\n return this._cvr.version;\n }\n\n updatedVersion(): CVRVersion {\n return this._cvr.version;\n }\n\n /**\n * Tracks rows received from executing queries. This will update row records\n * and row patches if the received rows have a new version. The method also\n * returns (put) patches to be returned to update their state, versioned by\n * patchVersion so that only the patches new to the clients are sent.\n */\n async received(\n _lc: LogContext,\n rows: Map<RowID, RowUpdate>,\n ): Promise<PatchToVersion[]> {\n const patches: PatchToVersion[] = [];\n const existingRows = await this._cvrStore.getRowRecords();\n\n for (const [id, update] of rows.entries()) {\n const {contents, version, refCounts} = update;\n\n let existing = existingRows.get(id);\n // Accumulate all received refCounts to determine which rows to prune.\n const previouslyReceived = this.#receivedRows.get(id);\n\n const merged =\n previouslyReceived !== undefined\n ? mergeRefCounts(previouslyReceived, refCounts)\n : mergeRefCounts(\n existing?.refCounts,\n refCounts,\n this.#removedOrExecutedQueryIDs,\n );\n\n this.#receivedRows.set(id, merged);\n\n const newRowVersion = merged === null ? undefined : version;\n const patchVersion =\n existing && existing.rowVersion === newRowVersion\n ? existing.patchVersion // existing row is unchanged\n : this.#assertNewVersion();\n\n // Note: for determining what to commit to the CVR store, use the\n // `version` of the update even if `merged` is null (i.e. don't\n // use `newRowVersion`). This will be deduped by the cvr-store flush\n // if it is redundant. In rare cases--namely, if the row key has\n // changed--we _do_ want to add row-put for the new row key with\n // `refCounts: null` in order to correctly record a delete patch\n // for that row, as the row with the old key will be removed.\n const rowVersion = version ?? existing?.rowVersion;\n if (rowVersion) {\n this._cvrStore.putRowRecord({\n id,\n rowVersion,\n patchVersion,\n refCounts: merged,\n });\n } else {\n // This means that a row that was not in the CVR was added during\n // this update, and then subsequently removed. Since there's no\n // corresponding row in the CVR itself, cancel the previous put.\n // Note that we still send a 'del' patch to the client in order to\n // cancel the previous 'put' patch.\n this._cvrStore.delRowRecord(id);\n }\n\n // Dedupe against the lastPatch sent for the row, and ensure that\n // toVersion never backtracks (lest it be undesirably filtered).\n const lastPatch = this.#lastPatches.get(id);\n const toVersion = maxVersion(patchVersion, lastPatch?.toVersion);\n\n if (merged === null) {\n // All refCounts have gone to zero, if row was previously synced\n // delete it.\n if (existing || previouslyReceived) {\n // dedupe\n if (lastPatch?.rowVersion !== null) {\n patches.push({\n patch: {\n type: 'row',\n op: 'del',\n id,\n },\n toVersion,\n });\n this.#lastPatches.set(id, {rowVersion: null, toVersion});\n }\n }\n } else if (contents) {\n assert(rowVersion);\n // dedupe\n if (!lastPatch?.rowVersion || lastPatch.rowVersion < rowVersion) {\n patches.push({\n patch: {\n type: 'row',\n op: 'put',\n id,\n contents,\n },\n toVersion,\n });\n this.#lastPatches.set(id, {rowVersion, toVersion});\n }\n }\n }\n return patches;\n }\n\n /**\n * Computes and updates the row records based on:\n * * The {@link #executed} queries\n * * The {@link #removed} queries\n * * The {@link received} rows\n *\n * Returns the final delete and patch ops that must be sent to the client\n * to delete rows that are no longer referenced by any query.\n *\n * This is Step [5] of the\n * [CVR Sync Algorithm](https://www.notion.so/replicache/Sync-and-Client-View-Records-CVR-a18e02ec3ec543449ea22070855ff33d?pvs=4#7874f9b80a514be2b8cd5cf538b88d37).\n */\n async deleteUnreferencedRows(lc?: LogContext): Promise<PatchToVersion[]> {\n if (this.#removedOrExecutedQueryIDs.size === 0) {\n // Query-less update. This can happen for config-only changes.\n assert(this.#receivedRows.size === 0);\n return [];\n }\n\n // patches to send to the client.\n const patches: PatchToVersion[] = [];\n\n const start = Date.now();\n assert(this.#existingRows, `trackQueries() was not called`);\n for (const existing of await this.#existingRows) {\n const deletedID = this.#deleteUnreferencedRow(existing);\n if (deletedID === null) {\n continue;\n }\n patches.push({\n toVersion: this._cvr.version,\n patch: {type: 'row', op: 'del', id: deletedID},\n });\n }\n lc?.debug?.(\n `computed ${patches.length} delete patches (${Date.now() - start} ms)`,\n );\n\n return patches;\n }\n\n #deleteUnreferencedRow(existing: RowRecord): RowID | null {\n if (this.#receivedRows.get(existing.id)) {\n return null;\n }\n\n const newRefCounts = mergeRefCounts(\n existing.refCounts,\n undefined,\n this.#removedOrExecutedQueryIDs,\n );\n // If a row is still referenced, we update the refCounts but not the\n // patchVersion (as the existence and contents of the row have not\n // changed from the clients' perspective). If the row is deleted, it\n // gets a new patchVersion (and corresponding poke).\n const patchVersion = newRefCounts\n ? existing.patchVersion\n : this.#assertNewVersion();\n const rowRecord: RowRecord = {\n ...existing,\n patchVersion,\n refCounts: newRefCounts,\n };\n\n this._cvrStore.putRowRecord(rowRecord);\n\n // Return the id to delete if no longer referenced.\n return newRefCounts ? null : existing.id;\n }\n}\n\nfunction mergeRefCounts(\n existing: RefCounts | null | undefined,\n received: RefCounts | null | undefined,\n removeHashes?: Set<string>,\n): RefCounts | null {\n let merged: RefCounts = {};\n if (!existing) {\n merged = received ?? {};\n } else {\n [existing, received].forEach((refCounts, i) => {\n if (!refCounts) {\n return;\n }\n for (const [hash, count] of Object.entries(refCounts)) {\n if (i === 0 /* existing */ && removeHashes?.has(hash)) {\n continue; // removeHashes from existing row.\n }\n merged[hash] = (merged[hash] ?? 0) + count;\n if (merged[hash] === 0) {\n delete merged[hash];\n }\n }\n\n return merged;\n });\n }\n\n return Object.values(merged).some(v => v > 0) ? merged : null;\n}\n\n/**\n * The query must be inactive for all clients to be considered inactive.\n * This is because expiration is defined that way: a query is expired for a client group\n * only if it is expired for all clients in the group.\n *\n * If all clients have inactivated the query, we return\n * the one with the expiration furthest in the future.\n */\nexport function getInactiveQueries(cvr: CVR): {\n hash: string;\n inactivatedAt: TTLClock;\n ttl: number;\n}[] {\n // We no longer support a TTL larger than 10 minutes.\n const inactive: Map<\n string,\n {\n hash: string;\n inactivatedAt: TTLClock;\n ttl: number;\n }\n > = new Map();\n for (const [queryID, query] of Object.entries(cvr.queries)) {\n if (query.type === 'internal') {\n continue;\n }\n for (const clientState of Object.values(query.clientState)) {\n // 1. Take the longest TTL\n // 2. If the query is not inactivated (for any client), do not return it\n const {inactivatedAt, ttl} = clientState;\n const existing = inactive.get(queryID);\n if (inactivatedAt === undefined) {\n if (existing) {\n inactive.delete(queryID);\n }\n break;\n }\n\n const clampedTTL = clampTTL(ttl);\n if (existing) {\n // The stored one might be too large because from a previous version of\n // zero\n const existingTTL = clampTTL(existing.ttl);\n // Use the last eviction time.\n if (\n existingTTL + ttlClockAsNumber(existing.inactivatedAt) <\n ttlClockAsNumber(inactivatedAt) + clampedTTL\n ) {\n existing.ttl = clampedTTL;\n existing.inactivatedAt = inactivatedAt;\n }\n } else {\n inactive.set(queryID, {\n hash: queryID,\n inactivatedAt,\n ttl: clampedTTL,\n });\n }\n }\n }\n\n // First sort all the queries that have TTL. Oldest first.\n return [...inactive.values()].sort((a, b) => {\n if (a.ttl === b.ttl) {\n return (\n ttlClockAsNumber(a.inactivatedAt) - ttlClockAsNumber(b.inactivatedAt)\n );\n }\n return (\n ttlClockAsNumber(a.inactivatedAt) +\n a.ttl -\n ttlClockAsNumber(b.inactivatedAt) -\n b.ttl\n );\n });\n}\n\nexport function nextEvictionTime(cvr: CVR): TTLClock | undefined {\n let next: number | undefined;\n for (const {inactivatedAt, ttl} of getInactiveQueries(cvr)) {\n const expire = ttlClockAsNumber(inactivatedAt) + ttl;\n if (next === undefined || expire < next) {\n next = expire;\n }\n }\n return next as TTLClock | undefined;\n}\n\nfunction newQueryRecord(\n id: string,\n ast: AST | undefined,\n name: string | undefined,\n args: readonly ReadonlyJSONValue[] | undefined,\n): ClientQueryRecord | CustomQueryRecord {\n if (ast !== undefined) {\n assert(\n name === undefined && args === undefined,\n 'Cannot provide name or args with ast',\n );\n return {\n id,\n type: 'client',\n ast,\n clientState: {},\n } satisfies ClientQueryRecord;\n }\n\n assert(\n name !== undefined && args !== undefined,\n 'Must provide name and args',\n );\n return {\n id,\n type: 'custom',\n name,\n args,\n clientState: {},\n } satisfies CustomQueryRecord;\n}\n"],"names":["upstreamSchema","ErrorOrigin.ZeroCache"],"mappings":"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"}
@@ -1,64 +1,42 @@
1
- import { resolver } from '@rocicorp/resolver';
1
+ import { resolver } from "@rocicorp/resolver";
2
2
  import { assert } from "../../../../shared/src/asserts.js";
3
- // The target (additional) utilization to impose on the server
4
- // that receives the drained connections.
5
3
  const TARGET_UTILIZATION = 0.6;
6
- /**
7
- * There are two types of drains:
8
- * 1. Elective drains happen when a view-syncer is about to process
9
- * a replication event and drains instead because {@link shouldDrain()}
10
- * returned true. In this case, it exits its processing loop and
11
- * calls {@link drainNextIn()} immediately.
12
- * 2. Force drains are performed by the Syncer, which picks a random
13
- * view-syncer and calls {@link stop()}.
14
- *
15
- * In the case of a forced drain, the view-syncer may be queued up
16
- * behind a large amount of CPU-consuming events, and thus it may take
17
- * a long time before it actually stops. Elective drains are preferred because
18
- * they are less subject to that variance. However, elective drains only happen
19
- * if there is a task to be processed, so forced drains are still necessary
20
- * for draining servers with no work / tasks.
21
- *
22
- * The Syncer kicks off the drain process by calling {@link drainNextIn drainNextIn(0)},
23
- * which sets off a short {@link forceDrainTimeout} but starts returning `true` for
24
- * {@link shouldDrain()} for elective drains. In the latter case, the drained
25
- * view-syncer immediately exiting its processing loop and calls
26
- * {@link drainNextIn drainNextIn(myHydrationTime)} to reset the timeout
27
- * for the next elective or forced drain.
28
- */
29
- export class DrainCoordinator {
30
- #draining = resolver();
31
- #nextDrainTime = 0;
32
- #timeout = resolver();
33
- #timeoutID;
34
- get draining() {
35
- return this.#draining.promise;
36
- }
37
- shouldDrain() {
38
- return this.#nextDrainTime && this.#nextDrainTime <= Date.now();
39
- }
40
- drainNextIn(interval) {
41
- this.#draining.resolve('draining');
42
- // Increase the timeout between drains to give the receiving
43
- // server space to perform normal processing.
44
- interval /= TARGET_UTILIZATION;
45
- const now = Date.now();
46
- assert(this.#nextDrainTime <= now, `drainNextIn() should only be called if shouldDrain()`);
47
- this.#nextDrainTime = now + interval;
48
- // Push the forceDrainTimeout forward.
49
- clearTimeout(this.#timeoutID);
50
- this.#timeoutID = setTimeout(() => {
51
- this.#timeout.resolve();
52
- this.#timeout = resolver();
53
- }, interval + FORCE_DRAIN_PADDING);
54
- }
55
- get forceDrainTimeout() {
56
- return this.#timeout.promise;
57
- }
58
- // Exposed for testing.
59
- get nextDrainTime() {
60
- return this.#nextDrainTime;
61
- }
4
+ class DrainCoordinator {
5
+ #draining = resolver();
6
+ #nextDrainTime = 0;
7
+ #timeout = resolver();
8
+ #timeoutID;
9
+ get draining() {
10
+ return this.#draining.promise;
11
+ }
12
+ shouldDrain() {
13
+ return this.#nextDrainTime && this.#nextDrainTime <= Date.now();
14
+ }
15
+ drainNextIn(interval) {
16
+ this.#draining.resolve("draining");
17
+ interval /= TARGET_UTILIZATION;
18
+ const now = Date.now();
19
+ assert(
20
+ this.#nextDrainTime <= now,
21
+ `drainNextIn() should only be called if shouldDrain()`
22
+ );
23
+ this.#nextDrainTime = now + interval;
24
+ clearTimeout(this.#timeoutID);
25
+ this.#timeoutID = setTimeout(() => {
26
+ this.#timeout.resolve();
27
+ this.#timeout = resolver();
28
+ }, interval + FORCE_DRAIN_PADDING);
29
+ }
30
+ get forceDrainTimeout() {
31
+ return this.#timeout.promise;
32
+ }
33
+ // Exposed for testing.
34
+ get nextDrainTime() {
35
+ return this.#nextDrainTime;
36
+ }
62
37
  }
63
38
  const FORCE_DRAIN_PADDING = 2;
64
- //# sourceMappingURL=drain-coordinator.js.map
39
+ export {
40
+ DrainCoordinator
41
+ };
42
+ //# sourceMappingURL=drain-coordinator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"drain-coordinator.js","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/view-syncer/drain-coordinator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,oBAAoB,CAAC;AAC5C,OAAO,EAAC,MAAM,EAAC,MAAM,mCAAmC,CAAC;AAEzD,8DAA8D;AAC9D,yCAAyC;AACzC,MAAM,kBAAkB,GAAG,GAAG,CAAC;AAE/B;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,OAAO,gBAAgB;IAClB,SAAS,GAAG,QAAQ,EAAc,CAAC;IAC5C,cAAc,GAAG,CAAC,CAAC;IACnB,QAAQ,GAAG,QAAQ,EAAE,CAAC;IACtB,UAAU,CAA6B;IAEvC,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC;IAChC,CAAC;IAED,WAAW;QACT,OAAO,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,GAAG,EAAE,CAAC;IAClE,CAAC;IAED,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;QACnC,4DAA4D;QAC5D,6CAA6C;QAC7C,QAAQ,IAAI,kBAAkB,CAAC;QAE/B,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,MAAM,CACJ,IAAI,CAAC,cAAc,IAAI,GAAG,EAC1B,sDAAsD,CACvD,CAAC;QACF,IAAI,CAAC,cAAc,GAAG,GAAG,GAAG,QAAQ,CAAC;QAErC,sCAAsC;QACtC,YAAY,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC9B,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,QAAQ,GAAG,QAAQ,EAAE,CAAC;QAC7B,CAAC,EAAE,QAAQ,GAAG,mBAAmB,CAAC,CAAC;IACrC,CAAC;IAED,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC;IAC/B,CAAC;IAED,uBAAuB;IACvB,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;CACF;AAED,MAAM,mBAAmB,GAAG,CAAC,CAAC"}
1
+ {"version":3,"file":"drain-coordinator.js","sources":["../../../../../../zero-cache/src/services/view-syncer/drain-coordinator.ts"],"sourcesContent":["import {resolver} from '@rocicorp/resolver';\nimport {assert} from '../../../../shared/src/asserts.ts';\n\n// The target (additional) utilization to impose on the server\n// that receives the drained connections.\nconst TARGET_UTILIZATION = 0.6;\n\n/**\n * There are two types of drains:\n * 1. Elective drains happen when a view-syncer is about to process\n * a replication event and drains instead because {@link shouldDrain()}\n * returned true. In this case, it exits its processing loop and\n * calls {@link drainNextIn()} immediately.\n * 2. Force drains are performed by the Syncer, which picks a random\n * view-syncer and calls {@link stop()}.\n *\n * In the case of a forced drain, the view-syncer may be queued up\n * behind a large amount of CPU-consuming events, and thus it may take\n * a long time before it actually stops. Elective drains are preferred because\n * they are less subject to that variance. However, elective drains only happen\n * if there is a task to be processed, so forced drains are still necessary\n * for draining servers with no work / tasks.\n *\n * The Syncer kicks off the drain process by calling {@link drainNextIn drainNextIn(0)},\n * which sets off a short {@link forceDrainTimeout} but starts returning `true` for\n * {@link shouldDrain()} for elective drains. In the latter case, the drained\n * view-syncer immediately exiting its processing loop and calls\n * {@link drainNextIn drainNextIn(myHydrationTime)} to reset the timeout\n * for the next elective or forced drain.\n */\nexport class DrainCoordinator {\n readonly #draining = resolver<'draining'>();\n #nextDrainTime = 0;\n #timeout = resolver();\n #timeoutID: NodeJS.Timeout | undefined;\n\n get draining(): Promise<'draining'> {\n return this.#draining.promise;\n }\n\n shouldDrain() {\n return this.#nextDrainTime && this.#nextDrainTime <= Date.now();\n }\n\n drainNextIn(interval: number) {\n this.#draining.resolve('draining');\n // Increase the timeout between drains to give the receiving\n // server space to perform normal processing.\n interval /= TARGET_UTILIZATION;\n\n const now = Date.now();\n assert(\n this.#nextDrainTime <= now,\n `drainNextIn() should only be called if shouldDrain()`,\n );\n this.#nextDrainTime = now + interval;\n\n // Push the forceDrainTimeout forward.\n clearTimeout(this.#timeoutID);\n this.#timeoutID = setTimeout(() => {\n this.#timeout.resolve();\n this.#timeout = resolver();\n }, interval + FORCE_DRAIN_PADDING);\n }\n\n get forceDrainTimeout() {\n return this.#timeout.promise;\n }\n\n // Exposed for testing.\n get nextDrainTime() {\n return this.#nextDrainTime;\n }\n}\n\nconst FORCE_DRAIN_PADDING = 2;\n"],"names":[],"mappings":";;AAKA,MAAM,qBAAqB;AAyBpB,MAAM,iBAAiB;AAAA,EACnB,YAAY,SAAA;AAAA,EACrB,iBAAiB;AAAA,EACjB,WAAW,SAAA;AAAA,EACX;AAAA,EAEA,IAAI,WAAgC;AAClC,WAAO,KAAK,UAAU;AAAA,EACxB;AAAA,EAEA,cAAc;AACZ,WAAO,KAAK,kBAAkB,KAAK,kBAAkB,KAAK,IAAA;AAAA,EAC5D;AAAA,EAEA,YAAY,UAAkB;AAC5B,SAAK,UAAU,QAAQ,UAAU;AAGjC,gBAAY;AAEZ,UAAM,MAAM,KAAK,IAAA;AACjB;AAAA,MACE,KAAK,kBAAkB;AAAA,MACvB;AAAA,IAAA;AAEF,SAAK,iBAAiB,MAAM;AAG5B,iBAAa,KAAK,UAAU;AAC5B,SAAK,aAAa,WAAW,MAAM;AACjC,WAAK,SAAS,QAAA;AACd,WAAK,WAAW,SAAA;AAAA,IAClB,GAAG,WAAW,mBAAmB;AAAA,EACnC;AAAA,EAEA,IAAI,oBAAoB;AACtB,WAAO,KAAK,SAAS;AAAA,EACvB;AAAA;AAAA,EAGA,IAAI,gBAAgB;AAClB,WAAO,KAAK;AAAA,EACd;AACF;AAEA,MAAM,sBAAsB;"}
@@ -6,5 +6,6 @@ import type { InspectorDelegate } from '../../server/inspector-delegate.ts';
6
6
  import type { ClientHandler } from './client-handler.ts';
7
7
  import type { CVRStore } from './cvr-store.ts';
8
8
  import type { CVRSnapshot } from './cvr.ts';
9
- export declare function handleInspect(lc: LogContext, body: InspectUpBody, cvr: CVRSnapshot, client: ClientHandler, inspectorDelegate: InspectorDelegate, clientGroupID: string, cvrStore: CVRStore, config: NormalizedZeroConfig, headerOptions: HeaderOptions, userQueryURL: string | undefined, authData: string | undefined): Promise<void>;
9
+ import type { TokenData } from './view-syncer.ts';
10
+ export declare function handleInspect(lc: LogContext, body: InspectUpBody, cvr: CVRSnapshot, client: ClientHandler, inspectorDelegate: InspectorDelegate, clientGroupID: string, cvrStore: CVRStore, config: NormalizedZeroConfig, headerOptions: HeaderOptions, userQueryURL: string | undefined, authData: TokenData | undefined): Promise<void>;
10
11
  //# sourceMappingURL=inspect-handler.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"inspect-handler.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/view-syncer/inspect-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAEjD,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,6CAA6C,CAAC;AAG/E,OAAO,KAAK,EAAC,oBAAoB,EAAC,MAAM,2BAA2B,CAAC;AAKpE,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,oCAAoC,CAAC;AAE1E,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,qBAAqB,CAAC;AACvD,OAAO,KAAK,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AAC7C,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,UAAU,CAAC;AAE1C,wBAAsB,aAAa,CACjC,EAAE,EAAE,UAAU,EACd,IAAI,EAAE,aAAa,EACnB,GAAG,EAAE,WAAW,EAChB,MAAM,EAAE,aAAa,EACrB,iBAAiB,EAAE,iBAAiB,EACpC,aAAa,EAAE,MAAM,EACrB,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,oBAAoB,EAC5B,aAAa,EAAE,aAAa,EAC5B,YAAY,EAAE,MAAM,GAAG,SAAS,EAChC,QAAQ,EAAE,MAAM,GAAG,SAAS,GAC3B,OAAO,CAAC,IAAI,CAAC,CA4If"}
1
+ {"version":3,"file":"inspect-handler.d.ts","sourceRoot":"","sources":["../../../../../../zero-cache/src/services/view-syncer/inspect-handler.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAEjD,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,6CAA6C,CAAC;AAG/E,OAAO,KAAK,EAAC,oBAAoB,EAAC,MAAM,2BAA2B,CAAC;AAKpE,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,uBAAuB,CAAC;AAEzD,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,oCAAoC,CAAC;AAE1E,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,qBAAqB,CAAC;AACvD,OAAO,KAAK,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AAC7C,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,UAAU,CAAC;AAC1C,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,kBAAkB,CAAC;AAGhD,wBAAsB,aAAa,CACjC,EAAE,EAAE,UAAU,EACd,IAAI,EAAE,aAAa,EACnB,GAAG,EAAE,WAAW,EAChB,MAAM,EAAE,aAAa,EACrB,iBAAiB,EAAE,iBAAiB,EACpC,aAAa,EAAE,MAAM,EACrB,QAAQ,EAAE,QAAQ,EAClB,MAAM,EAAE,oBAAoB,EAC5B,aAAa,EAAE,aAAa,EAC5B,YAAY,EAAE,MAAM,GAAG,SAAS,EAChC,QAAQ,EAAE,SAAS,GAAG,SAAS,GAC9B,OAAO,CAAC,IAAI,CAAC,CA6If"}