@rocicorp/zero 0.25.0-canary.1 → 0.25.0-canary.11

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 (1563) hide show
  1. package/out/analyze-query/src/bin-analyze.js +268 -257
  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 +76 -74
  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-ZZXMKAAG.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/replicache/src/kv/sqlite-store.d.ts.map +1 -1
  132. package/out/{chunk-ECUMGQGC.js → replicache/src/kv/sqlite-store.js} +27 -21
  133. package/out/replicache/src/kv/sqlite-store.js.map +1 -0
  134. package/out/{chunk-ASRS2LFV.js → replicache/src/kv/throw-if-closed.js} +4 -6
  135. package/out/replicache/src/kv/throw-if-closed.js.map +1 -0
  136. package/out/replicache/src/kv/write-impl-base.js +57 -0
  137. package/out/replicache/src/kv/write-impl-base.js.map +1 -0
  138. package/out/replicache/src/kv/write-impl.js +30 -0
  139. package/out/replicache/src/kv/write-impl.js.map +1 -0
  140. package/out/replicache/src/lazy.js +13 -0
  141. package/out/replicache/src/lazy.js.map +1 -0
  142. package/out/replicache/src/log-options.js +9 -0
  143. package/out/replicache/src/log-options.js.map +1 -0
  144. package/out/replicache/src/make-idb-name.js +13 -0
  145. package/out/replicache/src/make-idb-name.js.map +1 -0
  146. package/out/replicache/src/new-client-channel.js +51 -0
  147. package/out/replicache/src/new-client-channel.js.map +1 -0
  148. package/out/replicache/src/on-persist-channel.js +36 -0
  149. package/out/replicache/src/on-persist-channel.js.map +1 -0
  150. package/out/replicache/src/patch-operation.js +42 -0
  151. package/out/replicache/src/patch-operation.js.map +1 -0
  152. package/out/replicache/src/pending-mutations.js +16 -0
  153. package/out/replicache/src/pending-mutations.js.map +1 -0
  154. package/out/replicache/src/persist/client-gc.js +58 -0
  155. package/out/replicache/src/persist/client-gc.js.map +1 -0
  156. package/out/replicache/src/persist/client-group-gc.js +43 -0
  157. package/out/replicache/src/persist/client-group-gc.js.map +1 -0
  158. package/out/replicache/src/persist/client-groups.js +184 -0
  159. package/out/replicache/src/persist/client-groups.js.map +1 -0
  160. package/out/replicache/src/persist/clients.d.ts +3 -2
  161. package/out/replicache/src/persist/clients.d.ts.map +1 -1
  162. package/out/replicache/src/persist/clients.js +353 -0
  163. package/out/replicache/src/persist/clients.js.map +1 -0
  164. package/out/replicache/src/persist/collect-idb-databases.js +188 -0
  165. package/out/replicache/src/persist/collect-idb-databases.js.map +1 -0
  166. package/out/replicache/src/persist/gather-mem-only-visitor.js +27 -0
  167. package/out/replicache/src/persist/gather-mem-only-visitor.js.map +1 -0
  168. package/out/replicache/src/persist/gather-not-cached-visitor.js +37 -0
  169. package/out/replicache/src/persist/gather-not-cached-visitor.js.map +1 -0
  170. package/out/replicache/src/persist/heartbeat.js +48 -0
  171. package/out/replicache/src/persist/heartbeat.js.map +1 -0
  172. package/out/replicache/src/persist/idb-databases-store-db-name.js +14 -0
  173. package/out/replicache/src/persist/idb-databases-store-db-name.js.map +1 -0
  174. package/out/replicache/src/persist/idb-databases-store.js +92 -0
  175. package/out/replicache/src/persist/idb-databases-store.js.map +1 -0
  176. package/out/replicache/src/persist/make-client-id.js +12 -0
  177. package/out/replicache/src/persist/make-client-id.js.map +1 -0
  178. package/out/replicache/src/persist/persist.d.ts +2 -2
  179. package/out/replicache/src/persist/persist.d.ts.map +1 -1
  180. package/out/replicache/src/persist/persist.js +183 -0
  181. package/out/replicache/src/persist/persist.js.map +1 -0
  182. package/out/replicache/src/persist/refresh.d.ts +4 -3
  183. package/out/replicache/src/persist/refresh.d.ts.map +1 -1
  184. package/out/replicache/src/persist/refresh.js +198 -0
  185. package/out/replicache/src/persist/refresh.js.map +1 -0
  186. package/out/replicache/src/process-scheduler.js +96 -0
  187. package/out/replicache/src/process-scheduler.js.map +1 -0
  188. package/out/replicache/src/pusher.js +33 -0
  189. package/out/replicache/src/pusher.js.map +1 -0
  190. package/out/replicache/src/replicache-impl.d.ts +1 -1
  191. package/out/replicache/src/replicache-impl.d.ts.map +1 -1
  192. package/out/replicache/src/replicache-impl.js +1200 -0
  193. package/out/replicache/src/replicache-impl.js.map +1 -0
  194. package/out/replicache/src/replicache-options.d.ts +3 -2
  195. package/out/replicache/src/replicache-options.d.ts.map +1 -1
  196. package/out/replicache/src/report-error.js +6 -0
  197. package/out/replicache/src/report-error.js.map +1 -0
  198. package/out/replicache/src/request-idle.js +13 -0
  199. package/out/replicache/src/request-idle.js.map +1 -0
  200. package/out/replicache/src/scan-iterator.js +146 -0
  201. package/out/replicache/src/scan-iterator.js.map +1 -0
  202. package/out/replicache/src/scan-options.js +45 -0
  203. package/out/replicache/src/scan-options.js.map +1 -0
  204. package/out/replicache/src/set-interval-with-signal.js +12 -0
  205. package/out/replicache/src/set-interval-with-signal.js.map +1 -0
  206. package/out/replicache/src/subscriptions.js +355 -0
  207. package/out/replicache/src/subscriptions.js.map +1 -0
  208. package/out/replicache/src/sync/diff.d.ts +3 -2
  209. package/out/replicache/src/sync/diff.d.ts.map +1 -1
  210. package/out/replicache/src/sync/diff.js +72 -0
  211. package/out/replicache/src/sync/diff.js.map +1 -0
  212. package/out/replicache/src/sync/handle-pull-response-result-type-enum.js +9 -0
  213. package/out/replicache/src/sync/handle-pull-response-result-type-enum.js.map +1 -0
  214. package/out/replicache/src/sync/ids.js +9 -0
  215. package/out/replicache/src/sync/ids.js.map +1 -0
  216. package/out/replicache/src/sync/patch.js +49 -0
  217. package/out/replicache/src/sync/patch.js.map +1 -0
  218. package/out/replicache/src/sync/pull-error.js +16 -0
  219. package/out/replicache/src/sync/pull-error.js.map +1 -0
  220. package/out/replicache/src/sync/pull.d.ts +3 -2
  221. package/out/replicache/src/sync/pull.d.ts.map +1 -1
  222. package/out/replicache/src/sync/pull.js +301 -0
  223. package/out/replicache/src/sync/pull.js.map +1 -0
  224. package/out/replicache/src/sync/push.js +88 -0
  225. package/out/replicache/src/sync/push.js.map +1 -0
  226. package/out/replicache/src/sync/request-id.js +20 -0
  227. package/out/replicache/src/sync/request-id.js.map +1 -0
  228. package/out/replicache/src/sync/sync-head-name.js +5 -0
  229. package/out/replicache/src/sync/sync-head-name.js.map +1 -0
  230. package/out/replicache/src/to-error.js +10 -0
  231. package/out/replicache/src/to-error.js.map +1 -0
  232. package/out/replicache/src/transaction-closed-error.js +19 -0
  233. package/out/replicache/src/transaction-closed-error.js.map +1 -0
  234. package/out/replicache/src/transactions.js +152 -0
  235. package/out/replicache/src/transactions.js.map +1 -0
  236. package/out/replicache/src/version.js +5 -0
  237. package/out/replicache/src/version.js.map +1 -0
  238. package/out/replicache/src/with-transactions.js +28 -0
  239. package/out/replicache/src/with-transactions.js.map +1 -0
  240. package/out/shared/src/abort-error.js +6 -3
  241. package/out/shared/src/abort-error.js.map +1 -1
  242. package/out/shared/src/arrays.js +45 -43
  243. package/out/shared/src/arrays.js.map +1 -1
  244. package/out/shared/src/asserts.js +64 -68
  245. package/out/shared/src/asserts.js.map +1 -1
  246. package/out/shared/src/bigint-json.js +38 -42
  247. package/out/shared/src/bigint-json.js.map +1 -1
  248. package/out/shared/src/binary-search.js +18 -29
  249. package/out/shared/src/binary-search.js.map +1 -1
  250. package/out/shared/src/broadcast-channel.js +24 -0
  251. package/out/shared/src/broadcast-channel.js.map +1 -0
  252. package/out/shared/src/browser-env.js +25 -0
  253. package/out/shared/src/browser-env.js.map +1 -0
  254. package/out/shared/src/btree-set.js +464 -507
  255. package/out/shared/src/btree-set.js.map +1 -1
  256. package/out/shared/src/cache.js +34 -38
  257. package/out/shared/src/cache.js.map +1 -1
  258. package/out/shared/src/centroid.js +24 -24
  259. package/out/shared/src/centroid.js.map +1 -1
  260. package/out/shared/src/config.js +6 -3
  261. package/out/shared/src/config.js.map +1 -1
  262. package/out/shared/src/custom-key-map.js +58 -64
  263. package/out/shared/src/custom-key-map.js.map +1 -1
  264. package/out/shared/src/custom-key-set.js +51 -57
  265. package/out/shared/src/custom-key-set.js.map +1 -1
  266. package/out/shared/src/deep-clone.js +46 -0
  267. package/out/shared/src/deep-clone.js.map +1 -0
  268. package/out/shared/src/deep-merge.d.ts +24 -4
  269. package/out/shared/src/deep-merge.d.ts.map +1 -1
  270. package/out/shared/src/deep-merge.js +27 -0
  271. package/out/shared/src/deep-merge.js.map +1 -0
  272. package/out/shared/src/document-visible.js +74 -0
  273. package/out/shared/src/document-visible.js.map +1 -0
  274. package/out/shared/src/dotenv.js +5 -7
  275. package/out/shared/src/dotenv.js.map +1 -1
  276. package/out/shared/src/error.d.ts +4 -0
  277. package/out/shared/src/error.d.ts.map +1 -0
  278. package/out/shared/src/error.js +71 -0
  279. package/out/shared/src/error.js.map +1 -0
  280. package/out/shared/src/has-own.js +5 -3
  281. package/out/shared/src/has-own.js.map +1 -1
  282. package/out/shared/src/hash.js +15 -14
  283. package/out/shared/src/hash.js.map +1 -1
  284. package/out/shared/src/iterables.d.ts +0 -1
  285. package/out/shared/src/iterables.d.ts.map +1 -1
  286. package/out/shared/src/iterables.js +44 -80
  287. package/out/shared/src/iterables.js.map +1 -1
  288. package/out/shared/src/json-schema.js +30 -33
  289. package/out/shared/src/json-schema.js.map +1 -1
  290. package/out/shared/src/json.js +128 -143
  291. package/out/shared/src/json.js.map +1 -1
  292. package/out/shared/src/logging-test-utils.js +12 -19
  293. package/out/shared/src/logging-test-utils.js.map +1 -1
  294. package/out/shared/src/logging.d.ts.map +1 -1
  295. package/out/shared/src/logging.js +99 -83
  296. package/out/shared/src/logging.js.map +1 -1
  297. package/out/shared/src/must.js +9 -7
  298. package/out/shared/src/must.js.map +1 -1
  299. package/out/shared/src/navigator.js +5 -0
  300. package/out/shared/src/navigator.js.map +1 -0
  301. package/out/shared/src/object-traversal.d.ts +19 -0
  302. package/out/shared/src/object-traversal.d.ts.map +1 -0
  303. package/out/shared/src/object-traversal.js +27 -0
  304. package/out/shared/src/object-traversal.js.map +1 -0
  305. package/out/shared/src/objects.js +21 -22
  306. package/out/shared/src/objects.js.map +1 -1
  307. package/out/shared/src/options.d.ts +2 -0
  308. package/out/shared/src/options.d.ts.map +1 -1
  309. package/out/shared/src/options.js +289 -318
  310. package/out/shared/src/options.js.map +1 -1
  311. package/out/shared/src/parse-big-int.js +12 -10
  312. package/out/shared/src/parse-big-int.js.map +1 -1
  313. package/out/shared/src/promise-race.js +20 -0
  314. package/out/shared/src/promise-race.js.map +1 -0
  315. package/out/shared/src/queue.js +119 -122
  316. package/out/shared/src/queue.js.map +1 -1
  317. package/out/shared/src/rand.js +8 -10
  318. package/out/shared/src/rand.js.map +1 -1
  319. package/out/shared/src/random-uint64.js +9 -0
  320. package/out/shared/src/random-uint64.js.map +1 -0
  321. package/out/shared/src/random-values.js +13 -0
  322. package/out/shared/src/random-values.js.map +1 -0
  323. package/out/shared/src/resolved-promises.js +12 -9
  324. package/out/shared/src/resolved-promises.js.map +1 -1
  325. package/out/shared/src/sentinels.js +13 -6
  326. package/out/shared/src/sentinels.js.map +1 -1
  327. package/out/shared/src/set-utils.js +63 -62
  328. package/out/shared/src/set-utils.js.map +1 -1
  329. package/out/shared/src/size-of-value.js +58 -0
  330. package/out/shared/src/size-of-value.js.map +1 -0
  331. package/out/shared/src/sleep.js +45 -53
  332. package/out/shared/src/sleep.js.map +1 -1
  333. package/out/shared/src/string-compare.js +12 -9
  334. package/out/shared/src/string-compare.js.map +1 -1
  335. package/out/shared/src/subscribable.js +34 -0
  336. package/out/shared/src/subscribable.js.map +1 -0
  337. package/out/shared/src/tdigest-schema.js +7 -7
  338. package/out/shared/src/tdigest-schema.js.map +1 -1
  339. package/out/shared/src/tdigest.js +247 -271
  340. package/out/shared/src/tdigest.js.map +1 -1
  341. package/out/shared/src/valita.js +195 -207
  342. package/out/shared/src/valita.js.map +1 -1
  343. package/out/z2s/src/compiler.d.ts +2 -2
  344. package/out/z2s/src/compiler.d.ts.map +1 -1
  345. package/out/z2s/src/compiler.js +437 -310
  346. package/out/z2s/src/compiler.js.map +1 -1
  347. package/out/z2s/src/sql.d.ts +1 -1
  348. package/out/z2s/src/sql.d.ts.map +1 -1
  349. package/out/z2s/src/sql.js +186 -218
  350. package/out/z2s/src/sql.js.map +1 -1
  351. package/out/zero/package.json.js +9 -0
  352. package/out/zero/package.json.js.map +1 -0
  353. package/out/zero/src/adapters/drizzle.js +5 -2
  354. package/out/zero/src/adapters/drizzle.js.map +1 -1
  355. package/out/zero/src/adapters/pg.js +7 -2
  356. package/out/zero/src/adapters/pg.js.map +1 -1
  357. package/out/zero/src/adapters/postgresjs.js +7 -2
  358. package/out/zero/src/adapters/postgresjs.js.map +1 -1
  359. package/out/zero/src/analyze-query.js +1 -1
  360. package/out/zero/src/analyze-query.js.map +1 -1
  361. package/out/zero/src/ast-to-zql.js +1 -1
  362. package/out/zero/src/ast-to-zql.js.map +1 -1
  363. package/out/zero/src/build-schema.js +3 -5
  364. package/out/zero/src/build-schema.js.map +1 -1
  365. package/out/zero/src/change-protocol/v0.js +5 -3
  366. package/out/zero/src/change-protocol/v0.js.map +1 -1
  367. package/out/zero/src/cli.js +2 -2
  368. package/out/zero/src/cli.js.map +1 -1
  369. package/out/zero/src/deploy-permissions.js +1 -1
  370. package/out/zero/src/deploy-permissions.js.map +1 -1
  371. package/out/zero/src/expo-sqlite.js +5 -0
  372. package/out/zero/src/expo-sqlite.js.map +1 -0
  373. package/out/zero/src/op-sqlite.js +5 -0
  374. package/out/zero/src/op-sqlite.js.map +1 -0
  375. package/out/zero/src/pg.js +29 -3
  376. package/out/zero/src/pg.js.map +1 -1
  377. package/out/zero/src/react-native.js +13 -0
  378. package/out/zero/src/react-native.js.map +1 -0
  379. package/out/zero/src/react.js +17 -0
  380. package/out/zero/src/react.js.map +1 -0
  381. package/out/zero/src/server.js +25 -3
  382. package/out/zero/src/server.js.map +1 -1
  383. package/out/zero/src/solid.js +15 -0
  384. package/out/zero/src/solid.js.map +1 -0
  385. package/out/zero/src/sqlite.js +7 -0
  386. package/out/zero/src/sqlite.js.map +1 -0
  387. package/out/zero/src/transform-query.js +1 -1
  388. package/out/zero/src/transform-query.js.map +1 -1
  389. package/out/zero/src/zero-cache-dev.js +133 -105
  390. package/out/zero/src/zero-cache-dev.js.map +1 -1
  391. package/out/zero/src/zero-out.d.ts +3 -0
  392. package/out/zero/src/zero-out.d.ts.map +1 -0
  393. package/out/zero/src/zero-out.js +13 -0
  394. package/out/zero/src/zero-out.js.map +1 -0
  395. package/out/zero/src/zero.js +67 -0
  396. package/out/zero/src/zero.js.map +1 -0
  397. package/out/zero/src/zqlite.js +11 -3
  398. package/out/zero/src/zqlite.js.map +1 -1
  399. package/out/zero-cache/src/auth/jwt.d.ts +3 -0
  400. package/out/zero-cache/src/auth/jwt.d.ts.map +1 -1
  401. package/out/zero-cache/src/auth/jwt.js +33 -38
  402. package/out/zero-cache/src/auth/jwt.js.map +1 -1
  403. package/out/zero-cache/src/auth/load-permissions.d.ts +1 -1
  404. package/out/zero-cache/src/auth/load-permissions.d.ts.map +1 -1
  405. package/out/zero-cache/src/auth/load-permissions.js +61 -45
  406. package/out/zero-cache/src/auth/load-permissions.js.map +1 -1
  407. package/out/zero-cache/src/auth/read-authorizer.js +79 -91
  408. package/out/zero-cache/src/auth/read-authorizer.js.map +1 -1
  409. package/out/zero-cache/src/auth/write-authorizer.d.ts +4 -3
  410. package/out/zero-cache/src/auth/write-authorizer.d.ts.map +1 -1
  411. package/out/zero-cache/src/auth/write-authorizer.js +387 -328
  412. package/out/zero-cache/src/auth/write-authorizer.js.map +1 -1
  413. package/out/zero-cache/src/config/network.js +42 -45
  414. package/out/zero-cache/src/config/network.js.map +1 -1
  415. package/out/zero-cache/src/config/normalize.js +86 -83
  416. package/out/zero-cache/src/config/normalize.js.map +1 -1
  417. package/out/zero-cache/src/config/zero-config.d.ts +23 -0
  418. package/out/zero-cache/src/config/zero-config.d.ts.map +1 -1
  419. package/out/zero-cache/src/config/zero-config.js +694 -682
  420. package/out/zero-cache/src/config/zero-config.js.map +1 -1
  421. package/out/zero-cache/src/custom/fetch.d.ts +5 -5
  422. package/out/zero-cache/src/custom/fetch.d.ts.map +1 -1
  423. package/out/zero-cache/src/custom/fetch.js +170 -162
  424. package/out/zero-cache/src/custom/fetch.js.map +1 -1
  425. package/out/zero-cache/src/custom-queries/transform-query.d.ts +10 -3
  426. package/out/zero-cache/src/custom-queries/transform-query.d.ts.map +1 -1
  427. package/out/zero-cache/src/custom-queries/transform-query.js +101 -109
  428. package/out/zero-cache/src/custom-queries/transform-query.js.map +1 -1
  429. package/out/zero-cache/src/db/create.js +32 -36
  430. package/out/zero-cache/src/db/create.js.map +1 -1
  431. package/out/zero-cache/src/db/delete-lite-db.js +9 -6
  432. package/out/zero-cache/src/db/delete-lite-db.js.map +1 -1
  433. package/out/zero-cache/src/db/lite-tables.d.ts.map +1 -1
  434. package/out/zero-cache/src/db/lite-tables.js +150 -174
  435. package/out/zero-cache/src/db/lite-tables.js.map +1 -1
  436. package/out/zero-cache/src/db/migration-lite.js +170 -165
  437. package/out/zero-cache/src/db/migration-lite.js.map +1 -1
  438. package/out/zero-cache/src/db/migration.js +157 -137
  439. package/out/zero-cache/src/db/migration.js.map +1 -1
  440. package/out/zero-cache/src/db/mode-enum.d.ts +2 -0
  441. package/out/zero-cache/src/db/mode-enum.d.ts.map +1 -1
  442. package/out/zero-cache/src/db/mode-enum.js +9 -3
  443. package/out/zero-cache/src/db/mode-enum.js.map +1 -1
  444. package/out/zero-cache/src/db/pg-copy.js +51 -90
  445. package/out/zero-cache/src/db/pg-copy.js.map +1 -1
  446. package/out/zero-cache/src/db/pg-to-lite.d.ts +10 -0
  447. package/out/zero-cache/src/db/pg-to-lite.d.ts.map +1 -1
  448. package/out/zero-cache/src/db/pg-to-lite.js +116 -97
  449. package/out/zero-cache/src/db/pg-to-lite.js.map +1 -1
  450. package/out/zero-cache/src/db/pg-type-parser.js +27 -39
  451. package/out/zero-cache/src/db/pg-type-parser.js.map +1 -1
  452. package/out/zero-cache/src/db/postgres-replica-identity-enum.js +11 -6
  453. package/out/zero-cache/src/db/postgres-replica-identity-enum.js.map +1 -1
  454. package/out/zero-cache/src/db/postgres-type-class-enum.js +17 -9
  455. package/out/zero-cache/src/db/postgres-type-class-enum.js.map +1 -1
  456. package/out/zero-cache/src/db/specs.d.ts +1 -7
  457. package/out/zero-cache/src/db/specs.d.ts.map +1 -1
  458. package/out/zero-cache/src/db/specs.js +66 -40
  459. package/out/zero-cache/src/db/specs.js.map +1 -1
  460. package/out/zero-cache/src/db/statements.d.ts +1 -1
  461. package/out/zero-cache/src/db/statements.d.ts.map +1 -1
  462. package/out/zero-cache/src/db/statements.js +59 -52
  463. package/out/zero-cache/src/db/statements.js.map +1 -1
  464. package/out/zero-cache/src/db/transaction-pool.d.ts +1 -1
  465. package/out/zero-cache/src/db/transaction-pool.d.ts.map +1 -1
  466. package/out/zero-cache/src/db/transaction-pool.js +372 -501
  467. package/out/zero-cache/src/db/transaction-pool.js.map +1 -1
  468. package/out/zero-cache/src/db/warmup.js +25 -12
  469. package/out/zero-cache/src/db/warmup.js.map +1 -1
  470. package/out/zero-cache/src/observability/events.js +71 -82
  471. package/out/zero-cache/src/observability/events.js.map +1 -1
  472. package/out/zero-cache/src/observability/metrics.js +54 -32
  473. package/out/zero-cache/src/observability/metrics.js.map +1 -1
  474. package/out/zero-cache/src/scripts/decommission.d.ts +50 -0
  475. package/out/zero-cache/src/scripts/decommission.d.ts.map +1 -0
  476. package/out/zero-cache/src/scripts/decommission.js +55 -0
  477. package/out/zero-cache/src/scripts/decommission.js.map +1 -0
  478. package/out/zero-cache/src/scripts/deploy-permissions.js +128 -118
  479. package/out/zero-cache/src/scripts/deploy-permissions.js.map +1 -1
  480. package/out/zero-cache/src/scripts/permissions.d.ts +1 -1
  481. package/out/zero-cache/src/scripts/permissions.d.ts.map +1 -1
  482. package/out/zero-cache/src/scripts/permissions.js +108 -100
  483. package/out/zero-cache/src/scripts/permissions.js.map +1 -1
  484. package/out/zero-cache/src/server/anonymous-otel-start.js +410 -366
  485. package/out/zero-cache/src/server/anonymous-otel-start.js.map +1 -1
  486. package/out/zero-cache/src/server/change-streamer.d.ts.map +1 -1
  487. package/out/zero-cache/src/server/change-streamer.js +99 -64
  488. package/out/zero-cache/src/server/change-streamer.js.map +1 -1
  489. package/out/zero-cache/src/server/inspector-delegate.d.ts.map +1 -1
  490. package/out/zero-cache/src/server/inspector-delegate.js +112 -108
  491. package/out/zero-cache/src/server/inspector-delegate.js.map +1 -1
  492. package/out/zero-cache/src/server/logging.d.ts +1 -1
  493. package/out/zero-cache/src/server/logging.d.ts.map +1 -1
  494. package/out/zero-cache/src/server/logging.js +26 -19
  495. package/out/zero-cache/src/server/logging.js.map +1 -1
  496. package/out/zero-cache/src/server/main.d.ts.map +1 -1
  497. package/out/zero-cache/src/server/main.js +137 -120
  498. package/out/zero-cache/src/server/main.js.map +1 -1
  499. package/out/zero-cache/src/server/mutator.js +19 -0
  500. package/out/zero-cache/src/server/mutator.js.map +1 -0
  501. package/out/zero-cache/src/server/otel-diag-logger.d.ts +1 -1
  502. package/out/zero-cache/src/server/otel-diag-logger.d.ts.map +1 -1
  503. package/out/zero-cache/src/server/otel-diag-logger.js +67 -70
  504. package/out/zero-cache/src/server/otel-diag-logger.js.map +1 -1
  505. package/out/zero-cache/src/server/otel-log-sink.js +40 -41
  506. package/out/zero-cache/src/server/otel-log-sink.js.map +1 -1
  507. package/out/zero-cache/src/server/otel-start.d.ts +1 -1
  508. package/out/zero-cache/src/server/otel-start.d.ts.map +1 -1
  509. package/out/zero-cache/src/server/otel-start.js +57 -68
  510. package/out/zero-cache/src/server/otel-start.js.map +1 -1
  511. package/out/zero-cache/src/server/reaper.js +34 -26
  512. package/out/zero-cache/src/server/reaper.js.map +1 -1
  513. package/out/zero-cache/src/server/replicator.js +53 -31
  514. package/out/zero-cache/src/server/replicator.js.map +1 -1
  515. package/out/zero-cache/src/server/runner/main.js +6 -4
  516. package/out/zero-cache/src/server/runner/main.js.map +1 -1
  517. package/out/zero-cache/src/server/runner/run-worker.d.ts.map +1 -1
  518. package/out/zero-cache/src/server/runner/run-worker.js +46 -50
  519. package/out/zero-cache/src/server/runner/run-worker.js.map +1 -1
  520. package/out/zero-cache/src/server/runner/runtime.js +33 -32
  521. package/out/zero-cache/src/server/runner/runtime.js.map +1 -1
  522. package/out/zero-cache/src/server/runner/zero-dispatcher.d.ts.map +1 -1
  523. package/out/zero-cache/src/server/runner/zero-dispatcher.js +28 -22
  524. package/out/zero-cache/src/server/runner/zero-dispatcher.js.map +1 -1
  525. package/out/zero-cache/src/server/syncer.d.ts.map +1 -1
  526. package/out/zero-cache/src/server/syncer.js +124 -63
  527. package/out/zero-cache/src/server/syncer.js.map +1 -1
  528. package/out/zero-cache/src/server/worker-dispatcher.d.ts +1 -1
  529. package/out/zero-cache/src/server/worker-dispatcher.d.ts.map +1 -1
  530. package/out/zero-cache/src/server/worker-dispatcher.js +112 -106
  531. package/out/zero-cache/src/server/worker-dispatcher.js.map +1 -1
  532. package/out/zero-cache/src/server/worker-urls.d.ts +7 -0
  533. package/out/zero-cache/src/server/worker-urls.d.ts.map +1 -0
  534. package/out/zero-cache/src/server/worker-urls.js +21 -0
  535. package/out/zero-cache/src/server/worker-urls.js.map +1 -0
  536. package/out/zero-cache/src/services/analyze.d.ts +4 -9
  537. package/out/zero-cache/src/services/analyze.d.ts.map +1 -1
  538. package/out/zero-cache/src/services/analyze.js +118 -121
  539. package/out/zero-cache/src/services/analyze.js.map +1 -1
  540. package/out/zero-cache/src/services/change-source/column-metadata.d.ts +10 -3
  541. package/out/zero-cache/src/services/change-source/column-metadata.d.ts.map +1 -1
  542. package/out/zero-cache/src/services/change-source/column-metadata.js +154 -144
  543. package/out/zero-cache/src/services/change-source/column-metadata.js.map +1 -1
  544. package/out/zero-cache/src/services/change-source/custom/change-source.d.ts +1 -1
  545. package/out/zero-cache/src/services/change-source/custom/change-source.d.ts.map +1 -1
  546. package/out/zero-cache/src/services/change-source/custom/change-source.js +197 -171
  547. package/out/zero-cache/src/services/change-source/custom/change-source.js.map +1 -1
  548. package/out/zero-cache/src/services/change-source/custom/sync-schema.js +11 -3
  549. package/out/zero-cache/src/services/change-source/custom/sync-schema.js.map +1 -1
  550. package/out/zero-cache/src/services/change-source/pg/change-source.d.ts +1 -1
  551. package/out/zero-cache/src/services/change-source/pg/change-source.d.ts.map +1 -1
  552. package/out/zero-cache/src/services/change-source/pg/change-source.js +622 -623
  553. package/out/zero-cache/src/services/change-source/pg/change-source.js.map +1 -1
  554. package/out/zero-cache/src/services/change-source/pg/decommission.js +24 -23
  555. package/out/zero-cache/src/services/change-source/pg/decommission.js.map +1 -1
  556. package/out/zero-cache/src/services/change-source/pg/initial-sync.d.ts +1 -1
  557. package/out/zero-cache/src/services/change-source/pg/initial-sync.d.ts.map +1 -1
  558. package/out/zero-cache/src/services/change-source/pg/initial-sync.js +327 -284
  559. package/out/zero-cache/src/services/change-source/pg/initial-sync.js.map +1 -1
  560. package/out/zero-cache/src/services/change-source/pg/logical-replication/binary-reader.d.ts +2 -3
  561. package/out/zero-cache/src/services/change-source/pg/logical-replication/binary-reader.d.ts.map +1 -1
  562. package/out/zero-cache/src/services/change-source/pg/logical-replication/binary-reader.js +61 -69
  563. package/out/zero-cache/src/services/change-source/pg/logical-replication/binary-reader.js.map +1 -1
  564. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput-parser.js +247 -257
  565. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput-parser.js.map +1 -1
  566. package/out/zero-cache/src/services/change-source/pg/logical-replication/stream.js +127 -119
  567. package/out/zero-cache/src/services/change-source/pg/logical-replication/stream.js.map +1 -1
  568. package/out/zero-cache/src/services/change-source/pg/lsn.js +20 -19
  569. package/out/zero-cache/src/services/change-source/pg/lsn.js.map +1 -1
  570. package/out/zero-cache/src/services/change-source/pg/schema/ddl.d.ts +5 -5
  571. package/out/zero-cache/src/services/change-source/pg/schema/ddl.js +96 -119
  572. package/out/zero-cache/src/services/change-source/pg/schema/ddl.js.map +1 -1
  573. package/out/zero-cache/src/services/change-source/pg/schema/init.js +138 -117
  574. package/out/zero-cache/src/services/change-source/pg/schema/init.js.map +1 -1
  575. package/out/zero-cache/src/services/change-source/pg/schema/published.d.ts +2 -2
  576. package/out/zero-cache/src/services/change-source/pg/schema/published.js +67 -74
  577. package/out/zero-cache/src/services/change-source/pg/schema/published.js.map +1 -1
  578. package/out/zero-cache/src/services/change-source/pg/schema/shard.d.ts +1 -1
  579. package/out/zero-cache/src/services/change-source/pg/schema/shard.js +199 -188
  580. package/out/zero-cache/src/services/change-source/pg/schema/shard.js.map +1 -1
  581. package/out/zero-cache/src/services/change-source/pg/schema/validation.js +53 -38
  582. package/out/zero-cache/src/services/change-source/pg/schema/validation.js.map +1 -1
  583. package/out/zero-cache/src/services/change-source/pg/sync-schema.js +11 -3
  584. package/out/zero-cache/src/services/change-source/pg/sync-schema.js.map +1 -1
  585. package/out/zero-cache/src/services/change-source/protocol/current/control.d.ts +1 -0
  586. package/out/zero-cache/src/services/change-source/protocol/current/control.d.ts.map +1 -1
  587. package/out/zero-cache/src/services/change-source/protocol/current/control.js +13 -19
  588. package/out/zero-cache/src/services/change-source/protocol/current/control.js.map +1 -1
  589. package/out/zero-cache/src/services/change-source/protocol/current/data.js +143 -116
  590. package/out/zero-cache/src/services/change-source/protocol/current/data.js.map +1 -1
  591. package/out/zero-cache/src/services/change-source/protocol/current/downstream.d.ts +2 -0
  592. package/out/zero-cache/src/services/change-source/protocol/current/downstream.d.ts.map +1 -1
  593. package/out/zero-cache/src/services/change-source/protocol/current/downstream.js +29 -19
  594. package/out/zero-cache/src/services/change-source/protocol/current/downstream.js.map +1 -1
  595. package/out/zero-cache/src/services/change-source/protocol/current/json.d.ts +8 -0
  596. package/out/zero-cache/src/services/change-source/protocol/current/json.d.ts.map +1 -0
  597. package/out/zero-cache/src/services/change-source/protocol/current/json.js +19 -0
  598. package/out/zero-cache/src/services/change-source/protocol/current/json.js.map +1 -0
  599. package/out/zero-cache/src/services/change-source/protocol/current/path.js +5 -20
  600. package/out/zero-cache/src/services/change-source/protocol/current/path.js.map +1 -1
  601. package/out/zero-cache/src/services/change-source/protocol/current/status.js +12 -13
  602. package/out/zero-cache/src/services/change-source/protocol/current/status.js.map +1 -1
  603. package/out/zero-cache/src/services/change-source/protocol/current/upstream.d.ts +1 -1
  604. package/out/zero-cache/src/services/change-source/protocol/current/upstream.d.ts.map +1 -1
  605. package/out/zero-cache/src/services/change-source/protocol/current/upstream.js +5 -4
  606. package/out/zero-cache/src/services/change-source/protocol/current/upstream.js.map +1 -1
  607. package/out/zero-cache/src/services/change-source/protocol/current.d.ts +1 -0
  608. package/out/zero-cache/src/services/change-source/protocol/current.d.ts.map +1 -1
  609. package/out/zero-cache/src/services/change-source/protocol/current.js +38 -7
  610. package/out/zero-cache/src/services/change-source/protocol/current.js.map +1 -1
  611. package/out/zero-cache/src/services/change-source/replica-schema.d.ts.map +1 -1
  612. package/out/zero-cache/src/services/change-source/replica-schema.js +67 -37
  613. package/out/zero-cache/src/services/change-source/replica-schema.js.map +1 -1
  614. package/out/zero-cache/src/services/change-streamer/backup-monitor.d.ts +1 -1
  615. package/out/zero-cache/src/services/change-streamer/backup-monitor.d.ts.map +1 -1
  616. package/out/zero-cache/src/services/change-streamer/backup-monitor.js +139 -157
  617. package/out/zero-cache/src/services/change-streamer/backup-monitor.js.map +1 -1
  618. package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +11 -4
  619. package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts.map +1 -1
  620. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js +208 -157
  621. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +1 -1
  622. package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts +1 -1
  623. package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts.map +1 -1
  624. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js +242 -349
  625. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js.map +1 -1
  626. package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts +5 -1
  627. package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts.map +1 -1
  628. package/out/zero-cache/src/services/change-streamer/change-streamer.js +24 -22
  629. package/out/zero-cache/src/services/change-streamer/change-streamer.js.map +1 -1
  630. package/out/zero-cache/src/services/change-streamer/error-type-enum.js +9 -4
  631. package/out/zero-cache/src/services/change-streamer/error-type-enum.js.map +1 -1
  632. package/out/zero-cache/src/services/change-streamer/forwarder.d.ts +1 -1
  633. package/out/zero-cache/src/services/change-streamer/forwarder.d.ts.map +1 -1
  634. package/out/zero-cache/src/services/change-streamer/forwarder.js +53 -57
  635. package/out/zero-cache/src/services/change-streamer/forwarder.js.map +1 -1
  636. package/out/zero-cache/src/services/change-streamer/replica-monitor.d.ts +16 -0
  637. package/out/zero-cache/src/services/change-streamer/replica-monitor.d.ts.map +1 -0
  638. package/out/zero-cache/src/services/change-streamer/replica-monitor.js +48 -0
  639. package/out/zero-cache/src/services/change-streamer/replica-monitor.js.map +1 -0
  640. package/out/zero-cache/src/services/change-streamer/schema/init.js +82 -68
  641. package/out/zero-cache/src/services/change-streamer/schema/init.js.map +1 -1
  642. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts +2 -2
  643. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts.map +1 -1
  644. package/out/zero-cache/src/services/change-streamer/schema/tables.js +93 -78
  645. package/out/zero-cache/src/services/change-streamer/schema/tables.js.map +1 -1
  646. package/out/zero-cache/src/services/change-streamer/snapshot.d.ts +58 -0
  647. package/out/zero-cache/src/services/change-streamer/snapshot.d.ts.map +1 -1
  648. package/out/zero-cache/src/services/change-streamer/snapshot.js +28 -18
  649. package/out/zero-cache/src/services/change-streamer/snapshot.js.map +1 -1
  650. package/out/zero-cache/src/services/change-streamer/storer.d.ts +3 -2
  651. package/out/zero-cache/src/services/change-streamer/storer.d.ts.map +1 -1
  652. package/out/zero-cache/src/services/change-streamer/storer.js +308 -353
  653. package/out/zero-cache/src/services/change-streamer/storer.js.map +1 -1
  654. package/out/zero-cache/src/services/change-streamer/subscriber.d.ts +3 -2
  655. package/out/zero-cache/src/services/change-streamer/subscriber.d.ts.map +1 -1
  656. package/out/zero-cache/src/services/change-streamer/subscriber.js +85 -87
  657. package/out/zero-cache/src/services/change-streamer/subscriber.js.map +1 -1
  658. package/out/zero-cache/src/services/heapz.js +21 -25
  659. package/out/zero-cache/src/services/heapz.js.map +1 -1
  660. package/out/zero-cache/src/services/http-service.d.ts +5 -5
  661. package/out/zero-cache/src/services/http-service.d.ts.map +1 -1
  662. package/out/zero-cache/src/services/http-service.js +57 -59
  663. package/out/zero-cache/src/services/http-service.js.map +1 -1
  664. package/out/zero-cache/src/services/life-cycle.d.ts +1 -1
  665. package/out/zero-cache/src/services/life-cycle.d.ts.map +1 -1
  666. package/out/zero-cache/src/services/life-cycle.js +216 -255
  667. package/out/zero-cache/src/services/life-cycle.js.map +1 -1
  668. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js +76 -130
  669. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js.map +1 -1
  670. package/out/zero-cache/src/services/litestream/commands.d.ts +1 -1
  671. package/out/zero-cache/src/services/litestream/commands.d.ts.map +1 -1
  672. package/out/zero-cache/src/services/litestream/commands.js +201 -154
  673. package/out/zero-cache/src/services/litestream/commands.js.map +1 -1
  674. package/out/zero-cache/src/services/mutagen/error.js +11 -6
  675. package/out/zero-cache/src/services/mutagen/error.js.map +1 -1
  676. package/out/zero-cache/src/services/mutagen/mutagen.d.ts +2 -1
  677. package/out/zero-cache/src/services/mutagen/mutagen.d.ts.map +1 -1
  678. package/out/zero-cache/src/services/mutagen/mutagen.js +271 -267
  679. package/out/zero-cache/src/services/mutagen/mutagen.js.map +1 -1
  680. package/out/zero-cache/src/services/mutagen/pusher.d.ts +217 -21
  681. package/out/zero-cache/src/services/mutagen/pusher.d.ts.map +1 -1
  682. package/out/zero-cache/src/services/mutagen/pusher.js +354 -348
  683. package/out/zero-cache/src/services/mutagen/pusher.js.map +1 -1
  684. package/out/zero-cache/src/services/replicator/change-processor.d.ts.map +1 -1
  685. package/out/zero-cache/src/services/replicator/change-processor.js +483 -497
  686. package/out/zero-cache/src/services/replicator/change-processor.js.map +1 -1
  687. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts +1 -1
  688. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +1 -1
  689. package/out/zero-cache/src/services/replicator/incremental-sync.js +97 -97
  690. package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -1
  691. package/out/zero-cache/src/services/replicator/notifier.js +28 -52
  692. package/out/zero-cache/src/services/replicator/notifier.js.map +1 -1
  693. package/out/zero-cache/src/services/replicator/replication-status.d.ts +2 -0
  694. package/out/zero-cache/src/services/replicator/replication-status.d.ts.map +1 -1
  695. package/out/zero-cache/src/services/replicator/replication-status.js +113 -83
  696. package/out/zero-cache/src/services/replicator/replication-status.js.map +1 -1
  697. package/out/zero-cache/src/services/replicator/replicator.d.ts +1 -1
  698. package/out/zero-cache/src/services/replicator/replicator.d.ts.map +1 -1
  699. package/out/zero-cache/src/services/replicator/replicator.js +33 -26
  700. package/out/zero-cache/src/services/replicator/replicator.js.map +1 -1
  701. package/out/zero-cache/src/services/replicator/schema/change-log.d.ts +1 -1
  702. package/out/zero-cache/src/services/replicator/schema/change-log.d.ts.map +1 -1
  703. package/out/zero-cache/src/services/replicator/schema/change-log.js +74 -86
  704. package/out/zero-cache/src/services/replicator/schema/change-log.js.map +1 -1
  705. package/out/zero-cache/src/services/replicator/schema/constants.js +5 -7
  706. package/out/zero-cache/src/services/replicator/schema/constants.js.map +1 -1
  707. package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts +2 -2
  708. package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts.map +1 -1
  709. package/out/zero-cache/src/services/replicator/schema/replication-state.js +70 -74
  710. package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +1 -1
  711. package/out/zero-cache/src/services/run-ast.d.ts +9 -3
  712. package/out/zero-cache/src/services/run-ast.d.ts.map +1 -1
  713. package/out/zero-cache/src/services/run-ast.js +91 -78
  714. package/out/zero-cache/src/services/run-ast.js.map +1 -1
  715. package/out/zero-cache/src/services/runner.d.ts +1 -1
  716. package/out/zero-cache/src/services/runner.d.ts.map +1 -1
  717. package/out/zero-cache/src/services/runner.js +40 -40
  718. package/out/zero-cache/src/services/runner.js.map +1 -1
  719. package/out/zero-cache/src/services/running-state.d.ts +1 -1
  720. package/out/zero-cache/src/services/running-state.d.ts.map +1 -1
  721. package/out/zero-cache/src/services/running-state.js +122 -119
  722. package/out/zero-cache/src/services/running-state.js.map +1 -1
  723. package/out/zero-cache/src/services/statz.js +184 -162
  724. package/out/zero-cache/src/services/statz.js.map +1 -1
  725. package/out/zero-cache/src/services/view-syncer/active-users-gauge.js +40 -39
  726. package/out/zero-cache/src/services/view-syncer/active-users-gauge.js.map +1 -1
  727. package/out/zero-cache/src/services/view-syncer/client-handler.js +307 -298
  728. package/out/zero-cache/src/services/view-syncer/client-handler.js.map +1 -1
  729. package/out/zero-cache/src/services/view-syncer/client-schema.d.ts.map +1 -1
  730. package/out/zero-cache/src/services/view-syncer/client-schema.js +80 -82
  731. package/out/zero-cache/src/services/view-syncer/client-schema.js.map +1 -1
  732. package/out/zero-cache/src/services/view-syncer/cvr-purger.d.ts.map +1 -1
  733. package/out/zero-cache/src/services/view-syncer/cvr-purger.js +84 -94
  734. package/out/zero-cache/src/services/view-syncer/cvr-purger.js.map +1 -1
  735. package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts +2 -4
  736. package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts.map +1 -1
  737. package/out/zero-cache/src/services/view-syncer/cvr-store.js +654 -611
  738. package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +1 -1
  739. package/out/zero-cache/src/services/view-syncer/cvr.d.ts +1 -1
  740. package/out/zero-cache/src/services/view-syncer/cvr.d.ts.map +1 -1
  741. package/out/zero-cache/src/services/view-syncer/cvr.js +633 -695
  742. package/out/zero-cache/src/services/view-syncer/cvr.js.map +1 -1
  743. package/out/zero-cache/src/services/view-syncer/drain-coordinator.d.ts +1 -0
  744. package/out/zero-cache/src/services/view-syncer/drain-coordinator.d.ts.map +1 -1
  745. package/out/zero-cache/src/services/view-syncer/drain-coordinator.js +38 -55
  746. package/out/zero-cache/src/services/view-syncer/drain-coordinator.js.map +1 -1
  747. package/out/zero-cache/src/services/view-syncer/inspect-handler.d.ts +2 -1
  748. package/out/zero-cache/src/services/view-syncer/inspect-handler.d.ts.map +1 -1
  749. package/out/zero-cache/src/services/view-syncer/inspect-handler.js +175 -85
  750. package/out/zero-cache/src/services/view-syncer/inspect-handler.js.map +1 -1
  751. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +18 -15
  752. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +1 -1
  753. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +579 -462
  754. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -1
  755. package/out/zero-cache/src/services/view-syncer/row-record-cache.d.ts +1 -1
  756. package/out/zero-cache/src/services/view-syncer/row-record-cache.d.ts.map +1 -1
  757. package/out/zero-cache/src/services/view-syncer/row-record-cache.js +229 -277
  758. package/out/zero-cache/src/services/view-syncer/row-record-cache.js.map +1 -1
  759. package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts.map +1 -1
  760. package/out/zero-cache/src/services/view-syncer/schema/cvr.js +57 -122
  761. package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +1 -1
  762. package/out/zero-cache/src/services/view-syncer/schema/init.d.ts.map +1 -1
  763. package/out/zero-cache/src/services/view-syncer/schema/init.js +177 -131
  764. package/out/zero-cache/src/services/view-syncer/schema/init.js.map +1 -1
  765. package/out/zero-cache/src/services/view-syncer/schema/types.d.ts +4 -4
  766. package/out/zero-cache/src/services/view-syncer/schema/types.js +265 -257
  767. package/out/zero-cache/src/services/view-syncer/schema/types.js.map +1 -1
  768. package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts +3 -3
  769. package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts.map +1 -1
  770. package/out/zero-cache/src/services/view-syncer/snapshotter.js +295 -338
  771. package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +1 -1
  772. package/out/zero-cache/src/services/view-syncer/ttl-clock.js +13 -7
  773. package/out/zero-cache/src/services/view-syncer/ttl-clock.js.map +1 -1
  774. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +11 -4
  775. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -1
  776. package/out/zero-cache/src/services/view-syncer/view-syncer.js +1512 -1284
  777. package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -1
  778. package/out/zero-cache/src/types/error-with-level.d.ts.map +1 -1
  779. package/out/zero-cache/src/types/error-with-level.js +30 -21
  780. package/out/zero-cache/src/types/error-with-level.js.map +1 -1
  781. package/out/zero-cache/src/types/http.js +27 -14
  782. package/out/zero-cache/src/types/http.js.map +1 -1
  783. package/out/zero-cache/src/types/lexi-version.js +46 -31
  784. package/out/zero-cache/src/types/lexi-version.js.map +1 -1
  785. package/out/zero-cache/src/types/lite.js +118 -125
  786. package/out/zero-cache/src/types/lite.js.map +1 -1
  787. package/out/zero-cache/src/types/names.js +6 -3
  788. package/out/zero-cache/src/types/names.js.map +1 -1
  789. package/out/zero-cache/src/types/pg-data-type.js +74 -68
  790. package/out/zero-cache/src/types/pg-data-type.js.map +1 -1
  791. package/out/zero-cache/src/types/pg-types.js +17 -72
  792. package/out/zero-cache/src/types/pg-types.js.map +1 -1
  793. package/out/zero-cache/src/types/pg.d.ts +1 -1
  794. package/out/zero-cache/src/types/pg.d.ts.map +1 -1
  795. package/out/zero-cache/src/types/pg.js +213 -233
  796. package/out/zero-cache/src/types/pg.js.map +1 -1
  797. package/out/zero-cache/src/types/processes.d.ts +2 -2
  798. package/out/zero-cache/src/types/processes.d.ts.map +1 -1
  799. package/out/zero-cache/src/types/processes.js +95 -143
  800. package/out/zero-cache/src/types/processes.js.map +1 -1
  801. package/out/zero-cache/src/types/profiler.js +29 -30
  802. package/out/zero-cache/src/types/profiler.js.map +1 -1
  803. package/out/zero-cache/src/types/row-key.js +30 -68
  804. package/out/zero-cache/src/types/row-key.js.map +1 -1
  805. package/out/zero-cache/src/types/schema-versions.js +25 -19
  806. package/out/zero-cache/src/types/schema-versions.js.map +1 -1
  807. package/out/zero-cache/src/types/shards.js +50 -36
  808. package/out/zero-cache/src/types/shards.js.map +1 -1
  809. package/out/zero-cache/src/types/sql.js +9 -13
  810. package/out/zero-cache/src/types/sql.js.map +1 -1
  811. package/out/zero-cache/src/types/streams.d.ts +1 -1
  812. package/out/zero-cache/src/types/streams.d.ts.map +1 -1
  813. package/out/zero-cache/src/types/streams.js +246 -245
  814. package/out/zero-cache/src/types/streams.js.map +1 -1
  815. package/out/zero-cache/src/types/strings.js +14 -11
  816. package/out/zero-cache/src/types/strings.js.map +1 -1
  817. package/out/zero-cache/src/types/subscription.d.ts +16 -1
  818. package/out/zero-cache/src/types/subscription.d.ts.map +1 -1
  819. package/out/zero-cache/src/types/subscription.js +202 -225
  820. package/out/zero-cache/src/types/subscription.js.map +1 -1
  821. package/out/zero-cache/src/types/url-params.js +35 -30
  822. package/out/zero-cache/src/types/url-params.js.map +1 -1
  823. package/out/zero-cache/src/types/websocket-handoff.d.ts +5 -4
  824. package/out/zero-cache/src/types/websocket-handoff.d.ts.map +1 -1
  825. package/out/zero-cache/src/types/websocket-handoff.js +68 -76
  826. package/out/zero-cache/src/types/websocket-handoff.js.map +1 -1
  827. package/out/zero-cache/src/types/ws.js +56 -59
  828. package/out/zero-cache/src/types/ws.js.map +1 -1
  829. package/out/zero-cache/src/workers/connect-params.js +44 -40
  830. package/out/zero-cache/src/workers/connect-params.js.map +1 -1
  831. package/out/zero-cache/src/workers/connection.d.ts.map +1 -1
  832. package/out/zero-cache/src/workers/connection.js +282 -243
  833. package/out/zero-cache/src/workers/connection.js.map +1 -1
  834. package/out/zero-cache/src/workers/mutator.js +24 -0
  835. package/out/zero-cache/src/workers/mutator.js.map +1 -0
  836. package/out/zero-cache/src/workers/replicator.d.ts +1 -1
  837. package/out/zero-cache/src/workers/replicator.d.ts.map +1 -1
  838. package/out/zero-cache/src/workers/replicator.js +103 -106
  839. package/out/zero-cache/src/workers/replicator.js.map +1 -1
  840. package/out/zero-cache/src/workers/syncer-ws-message-handler.js +179 -147
  841. package/out/zero-cache/src/workers/syncer-ws-message-handler.js.map +1 -1
  842. package/out/zero-cache/src/workers/syncer.d.ts +3 -3
  843. package/out/zero-cache/src/workers/syncer.d.ts.map +1 -1
  844. package/out/zero-cache/src/workers/syncer.js +192 -171
  845. package/out/zero-cache/src/workers/syncer.js.map +1 -1
  846. package/out/zero-client/src/client/active-clients-manager.js +199 -0
  847. package/out/zero-client/src/client/active-clients-manager.js.map +1 -0
  848. package/out/zero-client/src/client/bindings.d.ts +43 -0
  849. package/out/zero-client/src/client/bindings.d.ts.map +1 -0
  850. package/out/zero-client/src/client/bindings.js +33 -0
  851. package/out/zero-client/src/client/bindings.js.map +1 -0
  852. package/out/zero-client/src/client/client-error-kind-enum.d.ts +12 -12
  853. package/out/zero-client/src/client/client-error-kind-enum.d.ts.map +1 -1
  854. package/out/zero-client/src/client/client-error-kind-enum.js +29 -0
  855. package/out/zero-client/src/client/client-error-kind-enum.js.map +1 -0
  856. package/out/zero-client/src/client/connection-manager.d.ts +36 -40
  857. package/out/zero-client/src/client/connection-manager.d.ts.map +1 -1
  858. package/out/zero-client/src/client/connection-manager.js +310 -0
  859. package/out/zero-client/src/client/connection-manager.js.map +1 -0
  860. package/out/zero-client/src/client/connection-status-enum.d.ts +2 -0
  861. package/out/zero-client/src/client/connection-status-enum.d.ts.map +1 -1
  862. package/out/zero-client/src/client/connection-status-enum.js +15 -0
  863. package/out/zero-client/src/client/connection-status-enum.js.map +1 -0
  864. package/out/zero-client/src/client/connection.d.ts +57 -6
  865. package/out/zero-client/src/client/connection.d.ts.map +1 -1
  866. package/out/zero-client/src/client/connection.js +103 -0
  867. package/out/zero-client/src/client/connection.js.map +1 -0
  868. package/out/zero-client/src/client/context.d.ts +9 -10
  869. package/out/zero-client/src/client/context.d.ts.map +1 -1
  870. package/out/zero-client/src/client/context.js +104 -0
  871. package/out/zero-client/src/client/context.js.map +1 -0
  872. package/out/zero-client/src/client/crud.d.ts +8 -6
  873. package/out/zero-client/src/client/crud.d.ts.map +1 -1
  874. package/out/zero-client/src/client/crud.js +225 -0
  875. package/out/zero-client/src/client/crud.js.map +1 -0
  876. package/out/zero-client/src/client/custom.d.ts +48 -25
  877. package/out/zero-client/src/client/custom.d.ts.map +1 -1
  878. package/out/zero-client/src/client/custom.js +128 -0
  879. package/out/zero-client/src/client/custom.js.map +1 -0
  880. package/out/zero-client/src/client/delete-clients-manager.d.ts +2 -2
  881. package/out/zero-client/src/client/delete-clients-manager.d.ts.map +1 -1
  882. package/out/zero-client/src/client/delete-clients-manager.js +71 -0
  883. package/out/zero-client/src/client/delete-clients-manager.js.map +1 -0
  884. package/out/zero-client/src/client/enable-analytics.js +18 -0
  885. package/out/zero-client/src/client/enable-analytics.js.map +1 -0
  886. package/out/zero-client/src/client/error.d.ts +51 -166
  887. package/out/zero-client/src/client/error.d.ts.map +1 -1
  888. package/out/zero-client/src/client/error.js +148 -0
  889. package/out/zero-client/src/client/error.js.map +1 -0
  890. package/out/zero-client/src/client/http-string.js +11 -0
  891. package/out/zero-client/src/client/http-string.js.map +1 -0
  892. package/out/zero-client/src/client/inspector/client-group.js +27 -0
  893. package/out/zero-client/src/client/inspector/client-group.js.map +1 -0
  894. package/out/zero-client/src/client/inspector/client.js +28 -0
  895. package/out/zero-client/src/client/inspector/client.js.map +1 -0
  896. package/out/zero-client/src/client/inspector/html-dialog-prompt.d.ts.map +1 -1
  897. package/out/zero-client/src/client/inspector/html-dialog-prompt.js +77 -0
  898. package/out/zero-client/src/client/inspector/html-dialog-prompt.js.map +1 -0
  899. package/out/zero-client/src/client/inspector/inspector.d.ts +8 -3
  900. package/out/zero-client/src/client/inspector/inspector.d.ts.map +1 -1
  901. package/out/zero-client/src/client/inspector/inspector.js +54 -0
  902. package/out/zero-client/src/client/inspector/inspector.js.map +1 -0
  903. package/out/zero-client/src/client/inspector/lazy-inspector.d.ts +4 -1
  904. package/out/zero-client/src/client/inspector/lazy-inspector.d.ts.map +1 -1
  905. package/out/zero-client/src/client/inspector/lazy-inspector.js +243 -0
  906. package/out/zero-client/src/client/inspector/lazy-inspector.js.map +1 -0
  907. package/out/zero-client/src/client/inspector/query.d.ts.map +1 -1
  908. package/out/zero-client/src/client/inspector/query.js +82 -0
  909. package/out/zero-client/src/client/inspector/query.js.map +1 -0
  910. package/out/zero-client/src/client/ivm-branch.d.ts +4 -4
  911. package/out/zero-client/src/client/ivm-branch.d.ts.map +1 -1
  912. package/out/zero-client/src/client/ivm-branch.js +149 -0
  913. package/out/zero-client/src/client/ivm-branch.js.map +1 -0
  914. package/out/zero-client/src/client/keys.js +45 -0
  915. package/out/zero-client/src/client/keys.js.map +1 -0
  916. package/out/zero-client/src/client/log-options.js +60 -0
  917. package/out/zero-client/src/client/log-options.js.map +1 -0
  918. package/out/zero-client/src/client/make-mutate-property.d.ts +43 -0
  919. package/out/zero-client/src/client/make-mutate-property.d.ts.map +1 -0
  920. package/out/zero-client/src/client/make-mutate-property.js +38 -0
  921. package/out/zero-client/src/client/make-mutate-property.js.map +1 -0
  922. package/out/zero-client/src/client/make-replicache-mutators.d.ts +34 -0
  923. package/out/zero-client/src/client/make-replicache-mutators.d.ts.map +1 -0
  924. package/out/zero-client/src/client/make-replicache-mutators.js +103 -0
  925. package/out/zero-client/src/client/make-replicache-mutators.js.map +1 -0
  926. package/out/zero-client/src/client/metric-name-enum.js +15 -0
  927. package/out/zero-client/src/client/metric-name-enum.js.map +1 -0
  928. package/out/zero-client/src/client/metrics.d.ts +2 -2
  929. package/out/zero-client/src/client/metrics.d.ts.map +1 -1
  930. package/out/zero-client/src/client/metrics.js +249 -0
  931. package/out/zero-client/src/client/metrics.js.map +1 -0
  932. package/out/zero-client/src/client/mutation-tracker.d.ts +12 -4
  933. package/out/zero-client/src/client/mutation-tracker.d.ts.map +1 -1
  934. package/out/zero-client/src/client/mutation-tracker.js +363 -0
  935. package/out/zero-client/src/client/mutation-tracker.js.map +1 -0
  936. package/out/zero-client/src/client/mutator-proxy.d.ts +15 -0
  937. package/out/zero-client/src/client/mutator-proxy.d.ts.map +1 -0
  938. package/out/zero-client/src/client/mutator-proxy.js +132 -0
  939. package/out/zero-client/src/client/mutator-proxy.js.map +1 -0
  940. package/out/zero-client/src/client/options.d.ts +77 -24
  941. package/out/zero-client/src/client/options.d.ts.map +1 -1
  942. package/out/zero-client/src/client/options.js +11 -0
  943. package/out/zero-client/src/client/options.js.map +1 -0
  944. package/out/zero-client/src/client/query-manager.d.ts +9 -2
  945. package/out/zero-client/src/client/query-manager.d.ts.map +1 -1
  946. package/out/zero-client/src/client/query-manager.js +377 -0
  947. package/out/zero-client/src/client/query-manager.js.map +1 -0
  948. package/out/zero-client/src/client/reload-error-handler.d.ts +4 -4
  949. package/out/zero-client/src/client/reload-error-handler.d.ts.map +1 -1
  950. package/out/zero-client/src/client/reload-error-handler.js +114 -0
  951. package/out/zero-client/src/client/reload-error-handler.js.map +1 -0
  952. package/out/zero-client/src/client/server-option.js +64 -0
  953. package/out/zero-client/src/client/server-option.js.map +1 -0
  954. package/out/zero-client/src/client/update-needed-reason-type-enum.js +9 -0
  955. package/out/zero-client/src/client/update-needed-reason-type-enum.js.map +1 -0
  956. package/out/zero-client/src/client/version.js +5 -0
  957. package/out/zero-client/src/client/version.js.map +1 -0
  958. package/out/zero-client/src/client/zero-poke-handler.d.ts +4 -4
  959. package/out/zero-client/src/client/zero-poke-handler.d.ts.map +1 -1
  960. package/out/zero-client/src/client/zero-poke-handler.js +303 -0
  961. package/out/zero-client/src/client/zero-poke-handler.js.map +1 -0
  962. package/out/zero-client/src/client/zero-rep.d.ts +5 -2
  963. package/out/zero-client/src/client/zero-rep.d.ts.map +1 -1
  964. package/out/zero-client/src/client/zero-rep.js +72 -0
  965. package/out/zero-client/src/client/zero-rep.js.map +1 -0
  966. package/out/zero-client/src/client/zero.d.ts +104 -26
  967. package/out/zero-client/src/client/zero.d.ts.map +1 -1
  968. package/out/zero-client/src/client/zero.js +1763 -0
  969. package/out/zero-client/src/client/zero.js.map +1 -0
  970. package/out/zero-client/src/mod.d.ts +24 -18
  971. package/out/zero-client/src/mod.d.ts.map +1 -1
  972. package/out/zero-client/src/types/query-result.d.ts +24 -0
  973. package/out/zero-client/src/types/query-result.d.ts.map +1 -0
  974. package/out/zero-client/src/util/nanoid.js +21 -0
  975. package/out/zero-client/src/util/nanoid.js.map +1 -0
  976. package/out/zero-client/src/util/socket.js +7 -0
  977. package/out/zero-client/src/util/socket.js.map +1 -0
  978. package/out/zero-events/src/status.d.ts +1 -1
  979. package/out/zero-events/src/status.d.ts.map +1 -1
  980. package/out/zero-protocol/src/analyze-query-result.d.ts +237 -0
  981. package/out/zero-protocol/src/analyze-query-result.d.ts.map +1 -1
  982. package/out/zero-protocol/src/analyze-query-result.js +159 -24
  983. package/out/zero-protocol/src/analyze-query-result.js.map +1 -1
  984. package/out/zero-protocol/src/application-error.d.ts +27 -0
  985. package/out/zero-protocol/src/application-error.d.ts.map +1 -0
  986. package/out/zero-protocol/src/application-error.js +38 -0
  987. package/out/zero-protocol/src/application-error.js.map +1 -0
  988. package/out/zero-protocol/src/ast.d.ts +2 -2
  989. package/out/zero-protocol/src/ast.js +296 -277
  990. package/out/zero-protocol/src/ast.js.map +1 -1
  991. package/out/zero-protocol/src/change-desired-queries.d.ts +2 -2
  992. package/out/zero-protocol/src/change-desired-queries.js +11 -7
  993. package/out/zero-protocol/src/change-desired-queries.js.map +1 -1
  994. package/out/zero-protocol/src/client-schema.d.ts +2 -2
  995. package/out/zero-protocol/src/client-schema.d.ts.map +1 -1
  996. package/out/zero-protocol/src/client-schema.js +40 -26
  997. package/out/zero-protocol/src/client-schema.js.map +1 -1
  998. package/out/zero-protocol/src/close-connection.js +11 -18
  999. package/out/zero-protocol/src/close-connection.js.map +1 -1
  1000. package/out/zero-protocol/src/connect.d.ts +4 -4
  1001. package/out/zero-protocol/src/connect.d.ts.map +1 -1
  1002. package/out/zero-protocol/src/connect.js +50 -51
  1003. package/out/zero-protocol/src/connect.js.map +1 -1
  1004. package/out/zero-protocol/src/custom-queries.d.ts +31 -99
  1005. package/out/zero-protocol/src/custom-queries.d.ts.map +1 -1
  1006. package/out/zero-protocol/src/custom-queries.js +61 -54
  1007. package/out/zero-protocol/src/custom-queries.js.map +1 -1
  1008. package/out/zero-protocol/src/data.js +9 -4
  1009. package/out/zero-protocol/src/data.js.map +1 -1
  1010. package/out/zero-protocol/src/delete-clients.js +16 -9
  1011. package/out/zero-protocol/src/delete-clients.js.map +1 -1
  1012. package/out/zero-protocol/src/down.d.ts +113 -15
  1013. package/out/zero-protocol/src/down.d.ts.map +1 -1
  1014. package/out/zero-protocol/src/down.js +20 -4
  1015. package/out/zero-protocol/src/down.js.map +1 -1
  1016. package/out/zero-protocol/src/error-kind-enum.js +41 -23
  1017. package/out/zero-protocol/src/error-kind-enum.js.map +1 -1
  1018. package/out/zero-protocol/src/error-origin-enum.js +9 -4
  1019. package/out/zero-protocol/src/error-origin-enum.js.map +1 -1
  1020. package/out/zero-protocol/src/error-reason-enum.js +17 -8
  1021. package/out/zero-protocol/src/error-reason-enum.js.map +1 -1
  1022. package/out/zero-protocol/src/error.d.ts +59 -17
  1023. package/out/zero-protocol/src/error.d.ts.map +1 -1
  1024. package/out/zero-protocol/src/error.js +151 -82
  1025. package/out/zero-protocol/src/error.js.map +1 -1
  1026. package/out/zero-protocol/src/inspect-down.d.ts +318 -18
  1027. package/out/zero-protocol/src/inspect-down.d.ts.map +1 -1
  1028. package/out/zero-protocol/src/inspect-down.js +72 -54
  1029. package/out/zero-protocol/src/inspect-down.js.map +1 -1
  1030. package/out/zero-protocol/src/inspect-up.d.ts +10 -6
  1031. package/out/zero-protocol/src/inspect-up.d.ts.map +1 -1
  1032. package/out/zero-protocol/src/inspect-up.js +39 -26
  1033. package/out/zero-protocol/src/inspect-up.js.map +1 -1
  1034. package/out/zero-protocol/src/mutation-id.js +9 -5
  1035. package/out/zero-protocol/src/mutation-id.js.map +1 -1
  1036. package/out/zero-protocol/src/mutation-type-enum.js +7 -3
  1037. package/out/zero-protocol/src/mutation-type-enum.js.map +1 -1
  1038. package/out/zero-protocol/src/mutations-patch.d.ts +3 -0
  1039. package/out/zero-protocol/src/mutations-patch.d.ts.map +1 -1
  1040. package/out/zero-protocol/src/mutations-patch.js +16 -17
  1041. package/out/zero-protocol/src/mutations-patch.js.map +1 -1
  1042. package/out/zero-protocol/src/ping.js +9 -4
  1043. package/out/zero-protocol/src/ping.js.map +1 -1
  1044. package/out/zero-protocol/src/poke.d.ts +2 -0
  1045. package/out/zero-protocol/src/poke.d.ts.map +1 -1
  1046. package/out/zero-protocol/src/poke.js +55 -72
  1047. package/out/zero-protocol/src/poke.js.map +1 -1
  1048. package/out/zero-protocol/src/pong.js +9 -4
  1049. package/out/zero-protocol/src/pong.js.map +1 -1
  1050. package/out/zero-protocol/src/primary-key.js +19 -5
  1051. package/out/zero-protocol/src/primary-key.js.map +1 -1
  1052. package/out/zero-protocol/src/protocol-version.d.ts +2 -2
  1053. package/out/zero-protocol/src/protocol-version.d.ts.map +1 -1
  1054. package/out/zero-protocol/src/protocol-version.js +7 -57
  1055. package/out/zero-protocol/src/protocol-version.js.map +1 -1
  1056. package/out/zero-protocol/src/pull.js +26 -19
  1057. package/out/zero-protocol/src/pull.js.map +1 -1
  1058. package/out/zero-protocol/src/push.d.ts +11 -4
  1059. package/out/zero-protocol/src/push.d.ts.map +1 -1
  1060. package/out/zero-protocol/src/push.js +179 -175
  1061. package/out/zero-protocol/src/push.js.map +1 -1
  1062. package/out/zero-protocol/src/queries-patch.d.ts +3 -3
  1063. package/out/zero-protocol/src/queries-patch.js +29 -22
  1064. package/out/zero-protocol/src/queries-patch.js.map +1 -1
  1065. package/out/zero-protocol/src/query-hash.js +18 -14
  1066. package/out/zero-protocol/src/query-hash.js.map +1 -1
  1067. package/out/zero-protocol/src/row-patch.js +29 -20
  1068. package/out/zero-protocol/src/row-patch.js.map +1 -1
  1069. package/out/zero-protocol/src/up.d.ts +6 -5
  1070. package/out/zero-protocol/src/up.d.ts.map +1 -1
  1071. package/out/zero-protocol/src/up.js +18 -4
  1072. package/out/zero-protocol/src/up.js.map +1 -1
  1073. package/out/zero-protocol/src/version.js +9 -4
  1074. package/out/zero-protocol/src/version.js.map +1 -1
  1075. package/out/zero-react/src/components/inspector.d.ts +5 -3
  1076. package/out/zero-react/src/components/inspector.d.ts.map +1 -1
  1077. package/out/{inspector-IU2HG74I.js → zero-react/src/components/inspector.js} +4 -9
  1078. package/out/zero-react/src/components/inspector.js.map +1 -0
  1079. package/out/{chunk-VZOYWIRW.js → zero-react/src/components/mark-icon.js} +3 -5
  1080. package/out/zero-react/src/components/mark-icon.js.map +1 -0
  1081. package/out/zero-react/src/components/zero-inspector.d.ts +5 -3
  1082. package/out/zero-react/src/components/zero-inspector.d.ts.map +1 -1
  1083. package/out/zero-react/src/components/zero-inspector.js +44 -0
  1084. package/out/zero-react/src/components/zero-inspector.js.map +1 -0
  1085. package/out/zero-react/src/mod.d.ts +5 -3
  1086. package/out/zero-react/src/mod.d.ts.map +1 -1
  1087. package/out/zero-react/src/use-query.d.ts +11 -28
  1088. package/out/zero-react/src/use-query.d.ts.map +1 -1
  1089. package/out/zero-react/src/use-query.js +286 -0
  1090. package/out/zero-react/src/use-query.js.map +1 -0
  1091. package/out/zero-react/src/use-zero-connection-state.d.ts +1 -1
  1092. package/out/zero-react/src/use-zero-connection-state.d.ts.map +1 -1
  1093. package/out/zero-react/src/use-zero-connection-state.js +14 -0
  1094. package/out/zero-react/src/use-zero-connection-state.js.map +1 -0
  1095. package/out/zero-react/src/use-zero-online.js +14 -0
  1096. package/out/zero-react/src/use-zero-online.js.map +1 -0
  1097. package/out/zero-react/src/zero-provider.d.ts +21 -7
  1098. package/out/zero-react/src/zero-provider.d.ts.map +1 -1
  1099. package/out/zero-react/src/zero-provider.js +61 -0
  1100. package/out/zero-react/src/zero-provider.js.map +1 -0
  1101. package/out/zero-schema/src/builder/relationship-builder.js +22 -19
  1102. package/out/zero-schema/src/builder/relationship-builder.js.map +1 -1
  1103. package/out/zero-schema/src/builder/schema-builder.d.ts +1 -3
  1104. package/out/zero-schema/src/builder/schema-builder.d.ts.map +1 -1
  1105. package/out/zero-schema/src/builder/schema-builder.js +81 -71
  1106. package/out/zero-schema/src/builder/schema-builder.js.map +1 -1
  1107. package/out/zero-schema/src/builder/table-builder.js +117 -116
  1108. package/out/zero-schema/src/builder/table-builder.js.map +1 -1
  1109. package/out/zero-schema/src/compiled-permissions.js +23 -19
  1110. package/out/zero-schema/src/compiled-permissions.js.map +1 -1
  1111. package/out/zero-schema/src/name-mapper.js +43 -38
  1112. package/out/zero-schema/src/name-mapper.js.map +1 -1
  1113. package/out/zero-schema/src/permissions.d.ts +9 -9
  1114. package/out/zero-schema/src/permissions.d.ts.map +1 -1
  1115. package/out/{chunk-55BOUNXO.js → zero-schema/src/permissions.js} +16 -173
  1116. package/out/zero-schema/src/permissions.js.map +1 -0
  1117. package/out/zero-schema/src/schema-config.d.ts +1 -1
  1118. package/out/zero-schema/src/schema-config.d.ts.map +1 -1
  1119. package/out/zero-schema/src/schema-config.js +35 -51
  1120. package/out/zero-schema/src/schema-config.js.map +1 -1
  1121. package/out/zero-server/src/adapters/drizzle.d.ts +2 -2
  1122. package/out/zero-server/src/adapters/drizzle.d.ts.map +1 -1
  1123. package/out/zero-server/src/adapters/drizzle.js +84 -97
  1124. package/out/zero-server/src/adapters/drizzle.js.map +1 -1
  1125. package/out/zero-server/src/adapters/pg.d.ts +8 -2
  1126. package/out/zero-server/src/adapters/pg.d.ts.map +1 -1
  1127. package/out/zero-server/src/adapters/pg.js +54 -74
  1128. package/out/zero-server/src/adapters/pg.js.map +1 -1
  1129. package/out/zero-server/src/adapters/postgresjs.d.ts +7 -2
  1130. package/out/zero-server/src/adapters/postgresjs.d.ts.map +1 -1
  1131. package/out/zero-server/src/adapters/postgresjs.js +40 -54
  1132. package/out/zero-server/src/adapters/postgresjs.js.map +1 -1
  1133. package/out/zero-server/src/custom.d.ts +14 -18
  1134. package/out/zero-server/src/custom.d.ts.map +1 -1
  1135. package/out/zero-server/src/custom.js +185 -105
  1136. package/out/zero-server/src/custom.js.map +1 -1
  1137. package/out/zero-server/src/logging.js +7 -4
  1138. package/out/zero-server/src/logging.js.map +1 -1
  1139. package/out/zero-server/src/mod.d.ts +5 -4
  1140. package/out/zero-server/src/mod.d.ts.map +1 -1
  1141. package/out/zero-server/src/pg-query-executor.d.ts +11 -0
  1142. package/out/zero-server/src/pg-query-executor.d.ts.map +1 -0
  1143. package/out/zero-server/src/pg-query-executor.js +20 -0
  1144. package/out/zero-server/src/pg-query-executor.js.map +1 -0
  1145. package/out/zero-server/src/process-mutations.d.ts +11 -15
  1146. package/out/zero-server/src/process-mutations.d.ts.map +1 -1
  1147. package/out/zero-server/src/process-mutations.js +341 -163
  1148. package/out/zero-server/src/process-mutations.js.map +1 -1
  1149. package/out/zero-server/src/push-processor.d.ts +5 -3
  1150. package/out/zero-server/src/push-processor.d.ts.map +1 -1
  1151. package/out/zero-server/src/push-processor.js +48 -32
  1152. package/out/zero-server/src/push-processor.js.map +1 -1
  1153. package/out/zero-server/src/queries/process-queries.d.ts +66 -4
  1154. package/out/zero-server/src/queries/process-queries.d.ts.map +1 -1
  1155. package/out/zero-server/src/queries/process-queries.js +101 -27
  1156. package/out/zero-server/src/queries/process-queries.js.map +1 -1
  1157. package/out/zero-server/src/schema.d.ts +2 -2
  1158. package/out/zero-server/src/schema.d.ts.map +1 -1
  1159. package/out/zero-server/src/schema.js +136 -124
  1160. package/out/zero-server/src/schema.js.map +1 -1
  1161. package/out/zero-server/src/zql-database.d.ts +9 -6
  1162. package/out/zero-server/src/zql-database.d.ts.map +1 -1
  1163. package/out/zero-server/src/zql-database.js +68 -51
  1164. package/out/zero-server/src/zql-database.js.map +1 -1
  1165. package/out/zero-solid/src/mod.d.ts +7 -0
  1166. package/out/zero-solid/src/mod.d.ts.map +1 -1
  1167. package/out/zero-solid/src/solid-view.d.ts +3 -23
  1168. package/out/zero-solid/src/solid-view.d.ts.map +1 -1
  1169. package/out/{solid.js → zero-solid/src/solid-view.js} +57 -182
  1170. package/out/zero-solid/src/solid-view.js.map +1 -0
  1171. package/out/zero-solid/src/use-query.d.ts +7 -6
  1172. package/out/zero-solid/src/use-query.d.ts.map +1 -1
  1173. package/out/zero-solid/src/use-query.js +57 -0
  1174. package/out/zero-solid/src/use-query.js.map +1 -0
  1175. package/out/zero-solid/src/use-zero-connection-state.d.ts +1 -1
  1176. package/out/zero-solid/src/use-zero-connection-state.d.ts.map +1 -1
  1177. package/out/zero-solid/src/use-zero-connection-state.js +17 -0
  1178. package/out/zero-solid/src/use-zero-connection-state.js.map +1 -0
  1179. package/out/zero-solid/src/use-zero-online.d.ts.map +1 -1
  1180. package/out/zero-solid/src/use-zero-online.js +15 -0
  1181. package/out/zero-solid/src/use-zero-online.js.map +1 -0
  1182. package/out/zero-solid/src/use-zero.d.ts +24 -7
  1183. package/out/zero-solid/src/use-zero.d.ts.map +1 -1
  1184. package/out/zero-solid/src/use-zero.js +70 -0
  1185. package/out/zero-solid/src/use-zero.js.map +1 -0
  1186. package/out/zero-types/src/default-types.d.ts +38 -0
  1187. package/out/zero-types/src/default-types.d.ts.map +1 -0
  1188. package/out/zero-types/src/format.js +7 -4
  1189. package/out/zero-types/src/format.js.map +1 -1
  1190. package/out/zero-types/src/name-mapper.js +43 -40
  1191. package/out/zero-types/src/name-mapper.js.map +1 -1
  1192. package/out/zero-types/src/server-schema.d.ts.map +1 -0
  1193. package/out/zql/src/builder/builder.d.ts +10 -2
  1194. package/out/zql/src/builder/builder.d.ts.map +1 -1
  1195. package/out/zql/src/builder/builder.js +485 -427
  1196. package/out/zql/src/builder/builder.js.map +1 -1
  1197. package/out/zql/src/builder/debug-delegate.d.ts +4 -0
  1198. package/out/zql/src/builder/debug-delegate.d.ts.map +1 -1
  1199. package/out/zql/src/builder/debug-delegate.js +68 -47
  1200. package/out/zql/src/builder/debug-delegate.js.map +1 -1
  1201. package/out/zql/src/builder/filter.js +132 -138
  1202. package/out/zql/src/builder/filter.js.map +1 -1
  1203. package/out/zql/src/builder/like.js +44 -51
  1204. package/out/zql/src/builder/like.js.map +1 -1
  1205. package/out/zql/src/error.d.ts +5 -0
  1206. package/out/zql/src/error.d.ts.map +1 -1
  1207. package/out/zql/src/error.js +18 -6
  1208. package/out/zql/src/error.js.map +1 -1
  1209. package/out/zql/src/ivm/array-view.d.ts +1 -1
  1210. package/out/zql/src/ivm/array-view.d.ts.map +1 -1
  1211. package/out/zql/src/ivm/array-view.js +87 -92
  1212. package/out/zql/src/ivm/array-view.js.map +1 -1
  1213. package/out/zql/src/ivm/constraint.js +74 -127
  1214. package/out/zql/src/ivm/constraint.js.map +1 -1
  1215. package/out/zql/src/ivm/data.d.ts +7 -2
  1216. package/out/zql/src/ivm/data.d.ts.map +1 -1
  1217. package/out/zql/src/ivm/data.js +62 -85
  1218. package/out/zql/src/ivm/data.js.map +1 -1
  1219. package/out/zql/src/ivm/exists.d.ts +3 -2
  1220. package/out/zql/src/ivm/exists.d.ts.map +1 -1
  1221. package/out/zql/src/ivm/exists.js +190 -244
  1222. package/out/zql/src/ivm/exists.js.map +1 -1
  1223. package/out/zql/src/ivm/fan-in.d.ts +2 -0
  1224. package/out/zql/src/ivm/fan-in.d.ts.map +1 -1
  1225. package/out/zql/src/ivm/fan-in.js +54 -51
  1226. package/out/zql/src/ivm/fan-in.js.map +1 -1
  1227. package/out/zql/src/ivm/fan-out.d.ts +2 -0
  1228. package/out/zql/src/ivm/fan-out.d.ts.map +1 -1
  1229. package/out/zql/src/ivm/fan-out.js +52 -50
  1230. package/out/zql/src/ivm/fan-out.js.map +1 -1
  1231. package/out/zql/src/ivm/filter-operators.d.ts +6 -2
  1232. package/out/zql/src/ivm/filter-operators.d.ts.map +1 -1
  1233. package/out/zql/src/ivm/filter-operators.js +103 -87
  1234. package/out/zql/src/ivm/filter-operators.js.map +1 -1
  1235. package/out/zql/src/ivm/filter-push.js +26 -23
  1236. package/out/zql/src/ivm/filter-push.js.map +1 -1
  1237. package/out/zql/src/ivm/filter.d.ts +2 -0
  1238. package/out/zql/src/ivm/filter.d.ts.map +1 -1
  1239. package/out/zql/src/ivm/filter.js +34 -32
  1240. package/out/zql/src/ivm/filter.js.map +1 -1
  1241. package/out/zql/src/ivm/flipped-join.d.ts +1 -1
  1242. package/out/zql/src/ivm/flipped-join.d.ts.map +1 -1
  1243. package/out/zql/src/ivm/flipped-join.js +354 -324
  1244. package/out/zql/src/ivm/flipped-join.js.map +1 -1
  1245. package/out/zql/src/ivm/join-utils.d.ts +2 -1
  1246. package/out/zql/src/ivm/join-utils.d.ts.map +1 -1
  1247. package/out/zql/src/ivm/join-utils.js +92 -78
  1248. package/out/zql/src/ivm/join-utils.js.map +1 -1
  1249. package/out/zql/src/ivm/join.d.ts +1 -1
  1250. package/out/zql/src/ivm/join.d.ts.map +1 -1
  1251. package/out/zql/src/ivm/join.js +305 -206
  1252. package/out/zql/src/ivm/join.js.map +1 -1
  1253. package/out/zql/src/ivm/maybe-split-and-push-edit-change.js +26 -24
  1254. package/out/zql/src/ivm/maybe-split-and-push-edit-change.js.map +1 -1
  1255. package/out/zql/src/ivm/memory-source.d.ts +3 -3
  1256. package/out/zql/src/ivm/memory-source.d.ts.map +1 -1
  1257. package/out/zql/src/ivm/memory-source.js +478 -489
  1258. package/out/zql/src/ivm/memory-source.js.map +1 -1
  1259. package/out/zql/src/ivm/memory-storage.js +32 -31
  1260. package/out/zql/src/ivm/memory-storage.js.map +1 -1
  1261. package/out/zql/src/ivm/operator.d.ts +9 -1
  1262. package/out/zql/src/ivm/operator.d.ts.map +1 -1
  1263. package/out/zql/src/ivm/operator.js +16 -9
  1264. package/out/zql/src/ivm/operator.js.map +1 -1
  1265. package/out/zql/src/ivm/push-accumulated.d.ts +1 -1
  1266. package/out/zql/src/ivm/push-accumulated.d.ts.map +1 -1
  1267. package/out/zql/src/ivm/push-accumulated.js +236 -305
  1268. package/out/zql/src/ivm/push-accumulated.js.map +1 -1
  1269. package/out/zql/src/ivm/skip.d.ts +1 -1
  1270. package/out/zql/src/ivm/skip.d.ts.map +1 -1
  1271. package/out/zql/src/ivm/skip.js +97 -105
  1272. package/out/zql/src/ivm/skip.js.map +1 -1
  1273. package/out/zql/src/ivm/source.d.ts +3 -1
  1274. package/out/zql/src/ivm/source.d.ts.map +1 -1
  1275. package/out/zql/src/ivm/stream.js +20 -16
  1276. package/out/zql/src/ivm/stream.js.map +1 -1
  1277. package/out/zql/src/ivm/take.d.ts +1 -1
  1278. package/out/zql/src/ivm/take.d.ts.map +1 -1
  1279. package/out/zql/src/ivm/take.js +525 -451
  1280. package/out/zql/src/ivm/take.js.map +1 -1
  1281. package/out/zql/src/ivm/union-fan-in.d.ts +2 -1
  1282. package/out/zql/src/ivm/union-fan-in.d.ts.map +1 -1
  1283. package/out/zql/src/ivm/union-fan-in.js +216 -132
  1284. package/out/zql/src/ivm/union-fan-in.js.map +1 -1
  1285. package/out/zql/src/ivm/union-fan-out.d.ts +1 -1
  1286. package/out/zql/src/ivm/union-fan-out.d.ts.map +1 -1
  1287. package/out/zql/src/ivm/union-fan-out.js +46 -45
  1288. package/out/zql/src/ivm/union-fan-out.js.map +1 -1
  1289. package/out/zql/src/ivm/view-apply-change.d.ts.map +1 -1
  1290. package/out/zql/src/ivm/view-apply-change.js +247 -216
  1291. package/out/zql/src/ivm/view-apply-change.js.map +1 -1
  1292. package/out/zql/src/ivm/view.d.ts +3 -2
  1293. package/out/zql/src/ivm/view.d.ts.map +1 -1
  1294. package/out/zql/src/mutate/custom.d.ts +26 -11
  1295. package/out/zql/src/mutate/custom.d.ts.map +1 -1
  1296. package/out/zql/src/mutate/custom.js +15 -7
  1297. package/out/zql/src/mutate/custom.js.map +1 -1
  1298. package/out/zql/src/mutate/mutator-registry.d.ts +93 -0
  1299. package/out/zql/src/mutate/mutator-registry.d.ts.map +1 -0
  1300. package/out/zql/src/mutate/mutator-registry.js +93 -0
  1301. package/out/zql/src/mutate/mutator-registry.js.map +1 -0
  1302. package/out/zql/src/mutate/mutator.d.ts +79 -0
  1303. package/out/zql/src/mutate/mutator.d.ts.map +1 -0
  1304. package/out/zql/src/mutate/mutator.js +31 -0
  1305. package/out/zql/src/mutate/mutator.js.map +1 -0
  1306. package/out/zql/src/planner/planner-builder.d.ts +2 -1
  1307. package/out/zql/src/planner/planner-builder.d.ts.map +1 -1
  1308. package/out/zql/src/planner/planner-builder.js +237 -146
  1309. package/out/zql/src/planner/planner-builder.js.map +1 -1
  1310. package/out/zql/src/planner/planner-connection.d.ts +19 -14
  1311. package/out/zql/src/planner/planner-connection.d.ts.map +1 -1
  1312. package/out/zql/src/planner/planner-connection.js +205 -291
  1313. package/out/zql/src/planner/planner-connection.js.map +1 -1
  1314. package/out/zql/src/planner/planner-constraint.js +8 -11
  1315. package/out/zql/src/planner/planner-constraint.js.map +1 -1
  1316. package/out/zql/src/planner/planner-debug.d.ts +62 -37
  1317. package/out/zql/src/planner/planner-debug.d.ts.map +1 -1
  1318. package/out/zql/src/planner/planner-debug.js +234 -117
  1319. package/out/zql/src/planner/planner-debug.js.map +1 -1
  1320. package/out/zql/src/planner/planner-fan-in.d.ts +5 -3
  1321. package/out/zql/src/planner/planner-fan-in.d.ts.map +1 -1
  1322. package/out/zql/src/planner/planner-fan-in.js +157 -141
  1323. package/out/zql/src/planner/planner-fan-in.js.map +1 -1
  1324. package/out/zql/src/planner/planner-fan-out.d.ts +5 -3
  1325. package/out/zql/src/planner/planner-fan-out.d.ts.map +1 -1
  1326. package/out/zql/src/planner/planner-fan-out.js +73 -42
  1327. package/out/zql/src/planner/planner-fan-out.js.map +1 -1
  1328. package/out/zql/src/planner/planner-graph.d.ts +9 -10
  1329. package/out/zql/src/planner/planner-graph.d.ts.map +1 -1
  1330. package/out/zql/src/planner/planner-graph.js +323 -388
  1331. package/out/zql/src/planner/planner-graph.js.map +1 -1
  1332. package/out/zql/src/planner/planner-join.d.ts +67 -8
  1333. package/out/zql/src/planner/planner-join.d.ts.map +1 -1
  1334. package/out/zql/src/planner/planner-join.js +239 -241
  1335. package/out/zql/src/planner/planner-join.js.map +1 -1
  1336. package/out/zql/src/planner/planner-node.d.ts +35 -3
  1337. package/out/zql/src/planner/planner-node.d.ts.map +1 -1
  1338. package/out/zql/src/planner/planner-node.js +8 -2
  1339. package/out/zql/src/planner/planner-node.js.map +1 -1
  1340. package/out/zql/src/planner/planner-source.d.ts +1 -1
  1341. package/out/zql/src/planner/planner-source.d.ts.map +1 -1
  1342. package/out/zql/src/planner/planner-source.js +23 -12
  1343. package/out/zql/src/planner/planner-source.js.map +1 -1
  1344. package/out/zql/src/planner/planner-terminus.d.ts +4 -3
  1345. package/out/zql/src/planner/planner-terminus.d.ts.map +1 -1
  1346. package/out/zql/src/planner/planner-terminus.js +28 -27
  1347. package/out/zql/src/planner/planner-terminus.js.map +1 -1
  1348. package/out/zql/src/query/abstract-query.d.ts +43 -0
  1349. package/out/zql/src/query/abstract-query.d.ts.map +1 -0
  1350. package/out/zql/src/query/abstract-query.js +408 -0
  1351. package/out/zql/src/query/abstract-query.js.map +1 -0
  1352. package/out/zql/src/query/complete-ordering.d.ts +5 -0
  1353. package/out/zql/src/query/complete-ordering.d.ts.map +1 -0
  1354. package/out/zql/src/query/complete-ordering.js +71 -0
  1355. package/out/zql/src/query/complete-ordering.js.map +1 -0
  1356. package/out/zql/src/query/create-builder.d.ts +9 -0
  1357. package/out/zql/src/query/create-builder.d.ts.map +1 -0
  1358. package/out/zql/src/query/create-builder.js +49 -0
  1359. package/out/zql/src/query/create-builder.js.map +1 -0
  1360. package/out/zql/src/query/error.d.ts +4 -0
  1361. package/out/zql/src/query/error.d.ts.map +1 -0
  1362. package/out/zql/src/query/error.js +13 -0
  1363. package/out/zql/src/query/error.js.map +1 -0
  1364. package/out/zql/src/query/escape-like.js +7 -0
  1365. package/out/zql/src/query/escape-like.js.map +1 -0
  1366. package/out/zql/src/query/expression.d.ts +5 -5
  1367. package/out/zql/src/query/expression.d.ts.map +1 -1
  1368. package/out/zql/src/query/expression.js +153 -151
  1369. package/out/zql/src/query/expression.js.map +1 -1
  1370. package/out/zql/src/query/measure-push-operator.d.ts +1 -1
  1371. package/out/zql/src/query/measure-push-operator.d.ts.map +1 -1
  1372. package/out/zql/src/query/measure-push-operator.js +42 -35
  1373. package/out/zql/src/query/measure-push-operator.js.map +1 -1
  1374. package/out/zql/src/query/metrics-delegate.js +9 -5
  1375. package/out/zql/src/query/metrics-delegate.js.map +1 -1
  1376. package/out/zql/src/query/named.d.ts +21 -12
  1377. package/out/zql/src/query/named.d.ts.map +1 -1
  1378. package/out/zql/src/query/named.js +47 -57
  1379. package/out/zql/src/query/named.js.map +1 -1
  1380. package/out/zql/src/query/query-delegate-base.d.ts +120 -0
  1381. package/out/zql/src/query/query-delegate-base.d.ts.map +1 -0
  1382. package/out/zql/src/query/query-delegate-base.js +250 -0
  1383. package/out/zql/src/query/query-delegate-base.js.map +1 -0
  1384. package/out/zql/src/query/query-delegate.d.ts +27 -4
  1385. package/out/zql/src/query/query-delegate.d.ts.map +1 -1
  1386. package/out/zql/src/query/query-impl.d.ts +7 -62
  1387. package/out/zql/src/query/query-impl.d.ts.map +1 -1
  1388. package/out/zql/src/query/query-impl.js +33 -490
  1389. package/out/zql/src/query/query-impl.js.map +1 -1
  1390. package/out/zql/src/query/query-internals.d.ts +68 -0
  1391. package/out/zql/src/query/query-internals.d.ts.map +1 -0
  1392. package/out/zql/src/query/query-internals.js +11 -0
  1393. package/out/zql/src/query/query-internals.js.map +1 -0
  1394. package/out/zql/src/query/query-registry.d.ts +163 -0
  1395. package/out/zql/src/query/query-registry.d.ts.map +1 -0
  1396. package/out/zql/src/query/query-registry.js +123 -0
  1397. package/out/zql/src/query/query-registry.js.map +1 -0
  1398. package/out/zql/src/query/query.d.ts +65 -240
  1399. package/out/zql/src/query/query.d.ts.map +1 -1
  1400. package/out/zql/src/query/runnable-query-impl.d.ts +22 -0
  1401. package/out/zql/src/query/runnable-query-impl.d.ts.map +1 -0
  1402. package/out/zql/src/query/runnable-query-impl.js +60 -0
  1403. package/out/zql/src/query/runnable-query-impl.js.map +1 -0
  1404. package/out/zql/src/query/schema-query.d.ts +6 -0
  1405. package/out/zql/src/query/schema-query.d.ts.map +1 -0
  1406. package/out/zql/src/query/static-query.d.ts +6 -15
  1407. package/out/zql/src/query/static-query.d.ts.map +1 -1
  1408. package/out/zql/src/query/static-query.js +44 -31
  1409. package/out/zql/src/query/static-query.js.map +1 -1
  1410. package/out/zql/src/query/ttl.js +69 -62
  1411. package/out/zql/src/query/ttl.js.map +1 -1
  1412. package/out/zql/src/query/validate-input.d.ts +15 -0
  1413. package/out/zql/src/query/validate-input.d.ts.map +1 -0
  1414. package/out/zql/src/query/validate-input.js +24 -0
  1415. package/out/zql/src/query/validate-input.js.map +1 -0
  1416. package/out/zqlite/src/database-storage.d.ts +1 -1
  1417. package/out/zqlite/src/database-storage.d.ts.map +1 -1
  1418. package/out/zqlite/src/database-storage.js +99 -102
  1419. package/out/zqlite/src/database-storage.js.map +1 -1
  1420. package/out/zqlite/src/db.d.ts +2 -1
  1421. package/out/zqlite/src/db.d.ts.map +1 -1
  1422. package/out/zqlite/src/db.js +241 -192
  1423. package/out/zqlite/src/db.js.map +1 -1
  1424. package/out/zqlite/src/explain-queries.js +13 -16
  1425. package/out/zqlite/src/explain-queries.js.map +1 -1
  1426. package/out/zqlite/src/internal/sql.js +15 -10
  1427. package/out/zqlite/src/internal/sql.js.map +1 -1
  1428. package/out/zqlite/src/internal/statement-cache.js +86 -110
  1429. package/out/zqlite/src/internal/statement-cache.js.map +1 -1
  1430. package/out/zqlite/src/query-builder.js +172 -143
  1431. package/out/zqlite/src/query-builder.js.map +1 -1
  1432. package/out/zqlite/src/query-delegate.d.ts +5 -19
  1433. package/out/zqlite/src/query-delegate.d.ts.map +1 -1
  1434. package/out/zqlite/src/query-delegate.js +56 -70
  1435. package/out/zqlite/src/query-delegate.js.map +1 -1
  1436. package/out/zqlite/src/sqlite-cost-model.d.ts.map +1 -1
  1437. package/out/zqlite/src/sqlite-cost-model.js +96 -120
  1438. package/out/zqlite/src/sqlite-cost-model.js.map +1 -1
  1439. package/out/zqlite/src/sqlite-stat-fanout.d.ts +121 -0
  1440. package/out/zqlite/src/sqlite-stat-fanout.d.ts.map +1 -0
  1441. package/out/zqlite/src/sqlite-stat-fanout.js +301 -0
  1442. package/out/zqlite/src/sqlite-stat-fanout.js.map +1 -0
  1443. package/out/zqlite/src/table-source.d.ts +15 -4
  1444. package/out/zqlite/src/table-source.d.ts.map +1 -1
  1445. package/out/zqlite/src/table-source.js +444 -311
  1446. package/out/zqlite/src/table-source.js.map +1 -1
  1447. package/package.json +27 -27
  1448. package/out/chunk-424PT5DM.js +0 -23
  1449. package/out/chunk-424PT5DM.js.map +0 -7
  1450. package/out/chunk-55BOUNXO.js.map +0 -7
  1451. package/out/chunk-AFADJQ2O.js +0 -1
  1452. package/out/chunk-AFADJQ2O.js.map +0 -7
  1453. package/out/chunk-AIPM77UE.js +0 -18139
  1454. package/out/chunk-AIPM77UE.js.map +0 -7
  1455. package/out/chunk-ASRS2LFV.js.map +0 -7
  1456. package/out/chunk-ECUMGQGC.js.map +0 -7
  1457. package/out/chunk-EZM3XBAB.js.map +0 -7
  1458. package/out/chunk-TJFNGO7E.js +0 -4126
  1459. package/out/chunk-TJFNGO7E.js.map +0 -7
  1460. package/out/chunk-VZOYWIRW.js.map +0 -7
  1461. package/out/chunk-ZZXMKAAG.js.map +0 -7
  1462. package/out/expo-sqlite.js +0 -11
  1463. package/out/expo-sqlite.js.map +0 -7
  1464. package/out/inspector-IU2HG74I.js.map +0 -7
  1465. package/out/lazy-inspector-OXIFYSSQ.js +0 -574
  1466. package/out/lazy-inspector-OXIFYSSQ.js.map +0 -7
  1467. package/out/op-sqlite.js.map +0 -7
  1468. package/out/react-native.js +0 -25
  1469. package/out/react-native.js.map +0 -7
  1470. package/out/react.js +0 -460
  1471. package/out/react.js.map +0 -7
  1472. package/out/shared/src/enum.js +0 -2
  1473. package/out/shared/src/enum.js.map +0 -1
  1474. package/out/shared/src/expand.js +0 -2
  1475. package/out/shared/src/expand.js.map +0 -1
  1476. package/out/shared/src/immutable.js +0 -2
  1477. package/out/shared/src/immutable.js.map +0 -1
  1478. package/out/shared/src/types.js +0 -2
  1479. package/out/shared/src/types.js.map +0 -1
  1480. package/out/shared/src/writable.js +0 -2
  1481. package/out/shared/src/writable.js.map +0 -1
  1482. package/out/solid.js.map +0 -7
  1483. package/out/sqlite.js +0 -15
  1484. package/out/sqlite.js.map +0 -7
  1485. package/out/zero/package.json +0 -193
  1486. package/out/zero/src/server/change-streamer.js +0 -2
  1487. package/out/zero/src/server/change-streamer.js.map +0 -1
  1488. package/out/zero/src/server/main.js +0 -2
  1489. package/out/zero/src/server/main.js.map +0 -1
  1490. package/out/zero/src/server/reaper.js +0 -2
  1491. package/out/zero/src/server/reaper.js.map +0 -1
  1492. package/out/zero/src/server/replicator.js +0 -2
  1493. package/out/zero/src/server/replicator.js.map +0 -1
  1494. package/out/zero/src/server/runner/main.js +0 -2
  1495. package/out/zero/src/server/runner/main.js.map +0 -1
  1496. package/out/zero/src/server/syncer.js +0 -2
  1497. package/out/zero/src/server/syncer.js.map +0 -1
  1498. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput.types.js +0 -4
  1499. package/out/zero-cache/src/services/change-source/pg/logical-replication/pgoutput.types.js.map +0 -1
  1500. package/out/zero-cache/src/services/change-source/protocol/mod.js +0 -5
  1501. package/out/zero-cache/src/services/change-source/protocol/mod.js.map +0 -1
  1502. package/out/zero-cache/src/services/service.js +0 -2
  1503. package/out/zero-cache/src/services/service.js.map +0 -1
  1504. package/out/zero-cache/src/services/view-syncer/key-columns.d.ts +0 -32
  1505. package/out/zero-cache/src/services/view-syncer/key-columns.d.ts.map +0 -1
  1506. package/out/zero-cache/src/services/view-syncer/key-columns.js +0 -75
  1507. package/out/zero-cache/src/services/view-syncer/key-columns.js.map +0 -1
  1508. package/out/zero-cache/src/types/satisfies.js +0 -2
  1509. package/out/zero-cache/src/types/satisfies.js.map +0 -1
  1510. package/out/zero-client/src/client/on-error.d.ts +0 -15
  1511. package/out/zero-client/src/client/on-error.d.ts.map +0 -1
  1512. package/out/zero-client/src/client/zero-log-context.d.ts +0 -7
  1513. package/out/zero-client/src/client/zero-log-context.d.ts.map +0 -1
  1514. package/out/zero-events/src/index.js +0 -2
  1515. package/out/zero-events/src/index.js.map +0 -1
  1516. package/out/zero-events/src/json.js +0 -2
  1517. package/out/zero-events/src/json.js.map +0 -1
  1518. package/out/zero-events/src/status.js +0 -3
  1519. package/out/zero-events/src/status.js.map +0 -1
  1520. package/out/zero-pg/src/mod.js +0 -6
  1521. package/out/zero-pg/src/mod.js.map +0 -1
  1522. package/out/zero-protocol/src/error-kind.js +0 -3
  1523. package/out/zero-protocol/src/error-kind.js.map +0 -1
  1524. package/out/zero-protocol/src/error-origin.js +0 -3
  1525. package/out/zero-protocol/src/error-origin.js.map +0 -1
  1526. package/out/zero-protocol/src/error-reason.js +0 -3
  1527. package/out/zero-protocol/src/error-reason.js.map +0 -1
  1528. package/out/zero-schema/src/server-schema.d.ts.map +0 -1
  1529. package/out/zero-schema/src/server-schema.js +0 -2
  1530. package/out/zero-schema/src/server-schema.js.map +0 -1
  1531. package/out/zero-schema/src/table-schema.js +0 -7
  1532. package/out/zero-schema/src/table-schema.js.map +0 -1
  1533. package/out/zero-server/src/mod.js +0 -8
  1534. package/out/zero-server/src/mod.js.map +0 -1
  1535. package/out/zero-server/src/query.d.ts +0 -22
  1536. package/out/zero-server/src/query.d.ts.map +0 -1
  1537. package/out/zero-server/src/query.js +0 -61
  1538. package/out/zero-server/src/query.js.map +0 -1
  1539. package/out/zero-types/src/schema-value.js +0 -2
  1540. package/out/zero-types/src/schema-value.js.map +0 -1
  1541. package/out/zero-types/src/schema.js +0 -2
  1542. package/out/zero-types/src/schema.js.map +0 -1
  1543. package/out/zero.js +0 -79
  1544. package/out/zero.js.map +0 -7
  1545. package/out/zql/src/ivm/change.js +0 -2
  1546. package/out/zql/src/ivm/change.js.map +0 -1
  1547. package/out/zql/src/ivm/default-format.js +0 -2
  1548. package/out/zql/src/ivm/default-format.js.map +0 -1
  1549. package/out/zql/src/ivm/schema.js +0 -2
  1550. package/out/zql/src/ivm/schema.js.map +0 -1
  1551. package/out/zql/src/ivm/source.js +0 -2
  1552. package/out/zql/src/ivm/source.js.map +0 -1
  1553. package/out/zql/src/ivm/view.js +0 -2
  1554. package/out/zql/src/ivm/view.js.map +0 -1
  1555. package/out/zql/src/query/query-delegate.js +0 -2
  1556. package/out/zql/src/query/query-delegate.js.map +0 -1
  1557. package/out/zql/src/query/query.js +0 -9
  1558. package/out/zql/src/query/query.js.map +0 -1
  1559. package/out/zql/src/query/typed-view.js +0 -2
  1560. package/out/zql/src/query/typed-view.js.map +0 -1
  1561. package/out/zqlite/src/mod.js +0 -5
  1562. package/out/zqlite/src/mod.js.map +0 -1
  1563. /package/out/{zero-schema → zero-types}/src/server-schema.d.ts +0 -0
@@ -1 +1 @@
1
- {"version":3,"file":"init.js","sourceRoot":"","sources":["../../../../../../../zero-cache/src/services/view-syncer/schema/init.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"init.js","sources":["../../../../../../../zero-cache/src/services/view-syncer/schema/init.ts"],"sourcesContent":["import type {LogContext} from '@rocicorp/logger';\nimport type {PendingQuery, Row} from 'postgres';\nimport {\n runSchemaMigrations,\n type IncrementalMigrationMap,\n type Migration,\n} from '../../../db/migration.ts';\nimport type {PostgresDB} from '../../../types/pg.ts';\nimport {cvrSchema, type ShardID} from '../../../types/shards.ts';\nimport {createRowsVersionTable, setupCVRTables} from './cvr.ts';\n\nexport async function initViewSyncerSchema(\n log: LogContext,\n db: PostgresDB,\n shard: ShardID,\n): Promise<void> {\n const schema = cvrSchema(shard);\n\n const setupMigration: Migration = {\n migrateSchema: (lc, tx) => setupCVRTables(lc, tx, shard),\n minSafeVersion: 1,\n };\n\n const migrateV1toV2: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`ALTER TABLE ${tx(schema)}.instances ADD \"replicaVersion\" TEXT`;\n },\n };\n\n const migrateV2ToV3: Migration = {\n migrateSchema: async (_, tx) => {\n await tx.unsafe(createRowsVersionTable(shard));\n },\n\n /** Populates the cvr.rowsVersion table with versions from cvr.instances. */\n migrateData: async (lc, tx) => {\n const pending: PendingQuery<Row[]>[] = [];\n for await (const versions of tx<\n {clientGroupID: string; version: string}[]\n >`\n SELECT \"clientGroupID\", \"version\" FROM ${tx(schema)}.instances`.cursor(\n 5000,\n )) {\n for (const version of versions) {\n pending.push(\n tx`INSERT INTO ${tx(schema)}.\"rowsVersion\" ${tx(version)} \n ON CONFLICT (\"clientGroupID\")\n DO UPDATE SET ${tx(version)}`.execute(),\n );\n }\n }\n lc.info?.(`initializing rowsVersion for ${pending.length} cvrs`);\n await Promise.all(pending);\n },\n };\n\n const migrateV3ToV4: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`ALTER TABLE ${tx(schema)}.instances ADD \"owner\" TEXT`;\n await tx`ALTER TABLE ${tx(schema)}.instances ADD \"grantedAt\" TIMESTAMPTZ`;\n },\n };\n\n const migrateV5ToV6: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`\n ALTER TABLE ${tx(schema)}.\"rows\"\n DROP CONSTRAINT fk_rows_client_group`;\n await tx`\n ALTER TABLE ${tx(schema)}.\"rowsVersion\"\n DROP CONSTRAINT fk_rows_version_client_group`;\n },\n };\n\n const migrateV6ToV7: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`ALTER TABLE ${tx(schema)}.desires ADD \"expiresAt\" TIMESTAMPTZ`;\n await tx`ALTER TABLE ${tx(\n schema,\n )}.desires ADD \"inactivatedAt\" TIMESTAMPTZ`;\n await tx`ALTER TABLE ${tx(schema)}.desires ADD \"ttl\" INTERVAL`;\n\n await tx`CREATE INDEX desires_expires_at ON ${tx(\n schema,\n )}.desires (\"expiresAt\")`;\n await tx`CREATE INDEX desires_inactivated_at ON ${tx(\n schema,\n )}.desires (\"inactivatedAt\")`;\n },\n };\n\n const migrateV7ToV8: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`ALTER TABLE ${tx(\n schema,\n )}.\"desires\" DROP CONSTRAINT fk_desires_client`;\n },\n };\n\n const migrateV8ToV9: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`ALTER TABLE ${tx(schema)}.instances ADD \"clientSchema\" JSONB`;\n },\n };\n\n const migrateV9ToV10: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`ALTER TABLE ${tx(schema)}.queries ADD \"queryName\" TEXT`;\n await tx`ALTER TABLE ${tx(schema)}.queries ADD \"queryArgs\" JSONB`;\n await tx`ALTER TABLE ${tx(schema)}.queries ALTER COLUMN \"clientAST\" DROP NOT NULL`;\n },\n };\n\n const migrateV10ToV11: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`DROP INDEX IF EXISTS ${tx(schema)}.desires_expires_at`;\n await tx`ALTER TABLE ${tx(schema)}.desires DROP COLUMN \"expiresAt\"`;\n await tx`DROP INDEX IF EXISTS ${tx(schema)}.client_patch_version`;\n await tx`ALTER TABLE ${tx(schema)}.clients DROP COLUMN \"patchVersion\"`;\n await tx`ALTER TABLE ${tx(schema)}.clients DROP COLUMN \"deleted\"`;\n },\n };\n\n const migratedV11ToV12: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`ALTER TABLE ${tx(schema)}.queries ALTER COLUMN \"queryArgs\" TYPE JSON USING \"queryArgs\"::JSON`;\n },\n };\n\n const migratedV12ToV13: Migration = {\n migrateSchema: async (_, tx) => {\n await tx`ALTER TABLE ${tx(schema)}.instances ADD COLUMN \"ttlClock\" DOUBLE PRECISION NOT NULL DEFAULT 0`;\n },\n };\n\n const migratedV13ToV14: Migration = {\n migrateSchema: async (_, sql) => {\n await sql`\n CREATE INDEX instances_last_active ON ${sql(schema)}.instances (\"lastActive\");\n `;\n\n // Update / add foreign key constraints to cascade deletes.\n for (const [table, reference] of [\n ['clients', 'instances'],\n ['queries', 'instances'],\n ['rows', 'rowsVersion'],\n ] as [string, string][]) {\n const constraint = sql(`fk_${table}_client_group`);\n await sql`\n ALTER TABLE ${sql(schema)}.${sql(table)} DROP CONSTRAINT IF EXISTS ${constraint}`;\n await sql`\n ALTER TABLE ${sql(schema)}.${sql(table)} ADD CONSTRAINT ${constraint}\n FOREIGN KEY(\"clientGroupID\")\n REFERENCES ${sql(schema)}.${sql(reference)} (\"clientGroupID\")\n ON DELETE CASCADE;\n `;\n }\n },\n };\n\n const migratedV14ToV15: Migration = {\n migrateSchema: async (_, sql) => {\n // Add new columns for storing inactivatedAt and ttl in milliseconds.\n // This avoids postgres.js type conversion issues with TIMESTAMPTZ and INTERVAL.\n await sql`ALTER TABLE ${sql(schema)}.desires \n ADD COLUMN \"inactivatedAtMs\" DOUBLE PRECISION`;\n await sql`ALTER TABLE ${sql(schema)}.desires \n ADD COLUMN \"ttlMs\" DOUBLE PRECISION`;\n },\n // Migrate existing data: convert TIMESTAMPTZ to milliseconds for inactivatedAt\n // and INTERVAL to milliseconds for ttl\n // Note: EXTRACT(EPOCH FROM NULL) returns NULL, so NULL values are preserved\n migrateData: async (lc, sql) => {\n lc.info?.(\n 'Migrating desires.inactivatedAt to inactivatedAtMs and ttl to ttlMs',\n );\n await sql`\n UPDATE ${sql(schema)}.desires\n SET \"inactivatedAtMs\" = EXTRACT(EPOCH FROM \"inactivatedAt\") * 1000,\n \"ttlMs\" = EXTRACT(EPOCH FROM \"ttl\") * 1000\n `;\n },\n };\n\n const schemaVersionMigrationMap: IncrementalMigrationMap = {\n 2: migrateV1toV2,\n 3: migrateV2ToV3,\n 4: migrateV3ToV4,\n // v5 enables asynchronous row-record flushing, and thus relies on\n // the logic that updates and checks the rowsVersion table in v3.\n 5: {minSafeVersion: 3},\n 6: migrateV5ToV6,\n 7: migrateV6ToV7,\n 8: migrateV7ToV8,\n 9: migrateV8ToV9,\n // v10 adds queryName and queryArgs to the queries table to support\n // custom queries. clientAST is now optional to support migrating\n // off client queries.\n 10: migrateV9ToV10,\n // V11 removes the deprecated queries.\"expiresAt\", clients.\"patchVersion\",\n // clients.\"deleted\" columns.\n 11: migrateV10ToV11,\n 12: migratedV11ToV12,\n // V13 adds instances.\"ttlClock\"\n 13: migratedV12ToV13,\n // V14 adds an index on instances.\"lastActive\" and a FK constraint\n // from rows.\"clientGroupID\" to rowsVersion.\"clientGroupID\" for\n // garbage collection\n 14: migratedV13ToV14,\n // V15 adds desires.\"inactivatedAtTTLClock\" to store TTLClock values\n // directly as DOUBLE PRECISION, avoiding postgres.js TIMESTAMPTZ\n // type conversion issues\n 15: migratedV14ToV15,\n };\n\n await runSchemaMigrations(\n log,\n 'view-syncer',\n cvrSchema(shard),\n db,\n setupMigration,\n schemaVersionMigrationMap,\n );\n}\n"],"names":[],"mappings":"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"}
@@ -483,7 +483,7 @@ export declare const patchSchema: v.ObjectType<{
483
483
  export declare const putRowPatchSchema: v.ObjectType<Omit<{
484
484
  type: v.Type<"row" | "query">;
485
485
  op: v.Type<"put" | "del">;
486
- }, "type" | "id" | "op" | "rowVersion"> & {
486
+ }, "type" | "op" | "id" | "rowVersion"> & {
487
487
  type: v.Type<"row">;
488
488
  op: v.Type<"put">;
489
489
  id: v.ObjectType<{
@@ -497,7 +497,7 @@ export type PutRowPatch = v.Infer<typeof putRowPatchSchema>;
497
497
  export declare const delRowPatchSchema: v.ObjectType<Omit<{
498
498
  type: v.Type<"row" | "query">;
499
499
  op: v.Type<"put" | "del">;
500
- }, "type" | "id" | "op"> & {
500
+ }, "type" | "op" | "id"> & {
501
501
  type: v.Type<"row">;
502
502
  op: v.Type<"del">;
503
503
  id: v.ObjectType<{
@@ -510,7 +510,7 @@ export type DelRowPatch = v.Infer<typeof delRowPatchSchema>;
510
510
  export declare const rowPatchSchema: v.UnionType<[v.ObjectType<Omit<{
511
511
  type: v.Type<"row" | "query">;
512
512
  op: v.Type<"put" | "del">;
513
- }, "type" | "id" | "op" | "rowVersion"> & {
513
+ }, "type" | "op" | "id" | "rowVersion"> & {
514
514
  type: v.Type<"row">;
515
515
  op: v.Type<"put">;
516
516
  id: v.ObjectType<{
@@ -522,7 +522,7 @@ export declare const rowPatchSchema: v.UnionType<[v.ObjectType<Omit<{
522
522
  }, undefined>, v.ObjectType<Omit<{
523
523
  type: v.Type<"row" | "query">;
524
524
  op: v.Type<"put" | "del">;
525
- }, "type" | "id" | "op"> & {
525
+ }, "type" | "op" | "id"> & {
526
526
  type: v.Type<"row">;
527
527
  op: v.Type<"del">;
528
528
  id: v.ObjectType<{
@@ -1,288 +1,296 @@
1
1
  import { jsonValueSchema } from "../../../../../shared/src/bigint-json.js";
2
2
  import { jsonSchema } from "../../../../../shared/src/json-schema.js";
3
- import * as v from "../../../../../shared/src/valita.js";
3
+ import { readonly, literalUnion } from "../../../../../shared/src/valita.js";
4
4
  import { astSchema } from "../../../../../zero-protocol/src/ast.js";
5
- import { versionFromLexi, versionToLexi } from "../../../types/lexi-version.js";
5
+ import { versionToLexi, versionFromLexi } from "../../../types/lexi-version.js";
6
6
  import { ttlClockSchema } from "../ttl-clock.js";
7
- export const cvrVersionSchema = v.object({
8
- /**
9
- * The database `stateVersion` with which the rows in the CVR are consistent.
10
- */
11
- stateVersion: v.string(), // LexiVersion
12
- /**
13
- * `minorVersion` is subversion of `stateVersion` that is initially absent for each
14
- * `stateVersion`, and incremented for configuration changes that affect the contents
15
- * of the CVR such as:
16
- *
17
- * * query set changes
18
- * * query transformation changes (which may happen for changes
19
- * in server-side logic or authorization policies)
20
- *
21
- * Such configuration changes are always correlated with a change to one or more
22
- * `/meta/...` records in the CVR, often (but not always) with corresponding
23
- * patches in `/patches/meta/...`.
24
- *
25
- * When the `stateVersion` moves forward, the `minorVersion` is reset to absent.
26
- * In this manner it behaves like the analogous concept in semantic versioning.
27
- */
28
- minorVersion: v.number().optional(),
7
+ import { object, number, string, array, literal, record, union } from "@badrap/valita";
8
+ const cvrVersionSchema = object({
9
+ /**
10
+ * The database `stateVersion` with which the rows in the CVR are consistent.
11
+ */
12
+ stateVersion: string(),
13
+ // LexiVersion
14
+ /**
15
+ * `minorVersion` is subversion of `stateVersion` that is initially absent for each
16
+ * `stateVersion`, and incremented for configuration changes that affect the contents
17
+ * of the CVR such as:
18
+ *
19
+ * * query set changes
20
+ * * query transformation changes (which may happen for changes
21
+ * in server-side logic or authorization policies)
22
+ *
23
+ * Such configuration changes are always correlated with a change to one or more
24
+ * `/meta/...` records in the CVR, often (but not always) with corresponding
25
+ * patches in `/patches/meta/...`.
26
+ *
27
+ * When the `stateVersion` moves forward, the `minorVersion` is reset to absent.
28
+ * In this manner it behaves like the analogous concept in semantic versioning.
29
+ */
30
+ minorVersion: number().optional()
29
31
  });
30
- export const EMPTY_CVR_VERSION = {
31
- stateVersion: versionToLexi(0),
32
+ const EMPTY_CVR_VERSION = {
33
+ stateVersion: versionToLexi(0)
32
34
  };
33
- export function oneAfter(v) {
34
- return v === null
35
- ? { stateVersion: versionToLexi(0) }
36
- : {
37
- stateVersion: v.stateVersion,
38
- minorVersion: (v.minorVersion ?? 0) + 1,
39
- };
35
+ function oneAfter(v2) {
36
+ return v2 === null ? { stateVersion: versionToLexi(0) } : {
37
+ stateVersion: v2.stateVersion,
38
+ minorVersion: (v2.minorVersion ?? 0) + 1
39
+ };
40
40
  }
41
- export function cmpVersions(a, b) {
42
- return a === null && b === null
43
- ? 0
44
- : a === null
45
- ? -1
46
- : b === null
47
- ? 1
48
- : a.stateVersion < b.stateVersion
49
- ? -1
50
- : a.stateVersion > b.stateVersion
51
- ? 1
52
- : (a.minorVersion ?? 0) - (b.minorVersion ?? 0);
41
+ function cmpVersions(a, b) {
42
+ return a === null && b === null ? 0 : a === null ? -1 : b === null ? 1 : a.stateVersion < b.stateVersion ? -1 : a.stateVersion > b.stateVersion ? 1 : (a.minorVersion ?? 0) - (b.minorVersion ?? 0);
53
43
  }
54
- export function maxVersion(a, b) {
55
- return !b ? a : cmpVersions(b, a) > 0 ? b : a;
44
+ function maxVersion(a, b) {
45
+ return !b ? a : cmpVersions(b, a) > 0 ? b : a;
56
46
  }
57
- export function versionToCookie(v) {
58
- return versionString(v);
47
+ function versionToCookie(v2) {
48
+ return versionString(v2);
59
49
  }
60
- export function versionToNullableCookie(v) {
61
- return v === null ? null : versionToCookie(v);
50
+ function versionToNullableCookie(v2) {
51
+ return v2 === null ? null : versionToCookie(v2);
62
52
  }
63
- export function cookieToVersion(cookie) {
64
- if (cookie === null) {
65
- return null;
66
- }
67
- return versionFromString(cookie);
53
+ function cookieToVersion(cookie) {
54
+ if (cookie === null) {
55
+ return null;
56
+ }
57
+ return versionFromString(cookie);
68
58
  }
69
- // Last Active tracking.
70
- export const cvrIDSchema = v.object({ id: v.string() });
71
- const cvrRecordSchema = v.object({
72
- /**
73
- * CVR records store the CVRVersion at which the record was last patched into
74
- * the CVR, which corresponds with a patch row that is cleaned up when the
75
- * record is changed (updated, deleted, and re-added in the case of rows).
76
- *
77
- * Tombstones are stored for row records but not for config records. This means
78
- * that "orphaned" delete patches for config records may exist, and therefore
79
- * scans of config patches must always run until the end of the list. On the
80
- * contrary, for row patches, the row record tombstones allow cleanup of delete
81
- * patches.
82
- */
83
- patchVersion: cvrVersionSchema,
59
+ object({ id: string() });
60
+ const cvrRecordSchema = object({
61
+ /**
62
+ * CVR records store the CVRVersion at which the record was last patched into
63
+ * the CVR, which corresponds with a patch row that is cleaned up when the
64
+ * record is changed (updated, deleted, and re-added in the case of rows).
65
+ *
66
+ * Tombstones are stored for row records but not for config records. This means
67
+ * that "orphaned" delete patches for config records may exist, and therefore
68
+ * scans of config patches must always run until the end of the list. On the
69
+ * contrary, for row patches, the row record tombstones allow cleanup of delete
70
+ * patches.
71
+ */
72
+ patchVersion: cvrVersionSchema
84
73
  });
85
- export const clientRecordSchema = v.object({
86
- /** The client ID, of which there can be multiple for a client group view. */
87
- id: v.string(),
88
- /** The client's desired query IDs. Patch information is stored in the QueryRecord. */
89
- desiredQueryIDs: v.array(v.string()),
74
+ object({
75
+ /** The client ID, of which there can be multiple for a client group view. */
76
+ id: string(),
77
+ /** The client's desired query IDs. Patch information is stored in the QueryRecord. */
78
+ desiredQueryIDs: array(string())
90
79
  });
91
- export const baseQueryRecordSchema = v.object({
92
- /** The client-specified ID used to identify this query. Typically a hash. */
93
- id: v.string(),
94
- /**
95
- * The hash of the query after server-side transformations, which include:
96
- *
97
- * * Normalization (which may differ from what the client does)
98
- * * Query "expansion" to include primary keys and query-execution-related columns
99
- * * Authorization transforms
100
- *
101
- * Transformations depend on conditions that are independent of the db state version,
102
- * such as server-side logic and authorization policies. As such, the version of a CVR
103
- * version may need to be advanced independent of db state changes. This is done
104
- * via the `minorVersion` counter of the CVRVersion object, which is used to account
105
- * for both changes to the query set and changes to query transformations (which are
106
- * effectively remove-old-query + add-new-query).
107
- *
108
- * Note that the transformed AST itself is **not** stored, as the result of the previous
109
- * transformation is not useful in and of itself. If the current transformation results in
110
- * a different hash than that of the transformation used for the last version of the CVR,
111
- * it is simply handled by invalidating the existing rows, re-executed the query with
112
- * the new transformation, and advancing the CVR's `minorVersion` and this query's
113
- * `transformationVersion`.
114
- *
115
- * Note that the transformationHash is only stored when the query has reached the "gotten"
116
- * state. If the query is in the "desired" but not yet "gotten" state, the field is absent.
117
- */
118
- transformationHash: v.string().optional(),
119
- /**
120
- * The CVR version corresponding to the `transformationHash`. This essentially tracks when
121
- * this version of the query was effectively added to the CVR (as opposed to the
122
- * `patchVersion`, which is simply when the client was notified that its query was added
123
- * to the gotten set). Catchup of clients from old CVR versions require executing all
124
- * queries with a newer `transformationVersion`.
125
- */
126
- transformationVersion: cvrVersionSchema.optional(),
80
+ const baseQueryRecordSchema = object({
81
+ /** The client-specified ID used to identify this query. Typically a hash. */
82
+ id: string(),
83
+ /**
84
+ * The hash of the query after server-side transformations, which include:
85
+ *
86
+ * * Normalization (which may differ from what the client does)
87
+ * * Query "expansion" to include primary keys and query-execution-related columns
88
+ * * Authorization transforms
89
+ *
90
+ * Transformations depend on conditions that are independent of the db state version,
91
+ * such as server-side logic and authorization policies. As such, the version of a CVR
92
+ * version may need to be advanced independent of db state changes. This is done
93
+ * via the `minorVersion` counter of the CVRVersion object, which is used to account
94
+ * for both changes to the query set and changes to query transformations (which are
95
+ * effectively remove-old-query + add-new-query).
96
+ *
97
+ * Note that the transformed AST itself is **not** stored, as the result of the previous
98
+ * transformation is not useful in and of itself. If the current transformation results in
99
+ * a different hash than that of the transformation used for the last version of the CVR,
100
+ * it is simply handled by invalidating the existing rows, re-executed the query with
101
+ * the new transformation, and advancing the CVR's `minorVersion` and this query's
102
+ * `transformationVersion`.
103
+ *
104
+ * Note that the transformationHash is only stored when the query has reached the "gotten"
105
+ * state. If the query is in the "desired" but not yet "gotten" state, the field is absent.
106
+ */
107
+ transformationHash: string().optional(),
108
+ /**
109
+ * The CVR version corresponding to the `transformationHash`. This essentially tracks when
110
+ * this version of the query was effectively added to the CVR (as opposed to the
111
+ * `patchVersion`, which is simply when the client was notified that its query was added
112
+ * to the gotten set). Catchup of clients from old CVR versions require executing all
113
+ * queries with a newer `transformationVersion`.
114
+ */
115
+ transformationVersion: cvrVersionSchema.optional()
127
116
  });
128
- /**
129
- * Internal queries track rows in the database for internal use, such as the
130
- * `lastMutationID`s in the `zero.clients` table. They participate in the standard
131
- * invalidation / update logic for row contents, but not in the desired/got or
132
- * size-based quota logic for client-requested queries.
133
- */
134
- export const internalQueryRecordSchema = baseQueryRecordSchema.extend({
135
- type: v.literal('internal'),
136
- ast: astSchema,
117
+ const internalQueryRecordSchema = baseQueryRecordSchema.extend({
118
+ type: literal("internal"),
119
+ ast: astSchema
137
120
  });
138
- const clientStateSchema = v.object({
139
- /**
140
- * The time at which the query was last inactivated. If this undefined or
141
- * missing then the query is active.
142
- *
143
- * Desired queries are always active and have an undefined inactivatedAt.
144
- */
145
- inactivatedAt: ttlClockSchema.optional(),
146
- /**
147
- * TTL, time to live in milliseconds. If the query is not updated within this
148
- * time. The time to live is the time after it has become inactive. Negative
149
- * values are treated as `'forever'`.
150
- *
151
- * We do clamp this to a maximum of 10 minutes, so that queries do not
152
- * live for a very long time in the CVR.
153
- */
154
- ttl: v.number(),
155
- /**
156
- * The version at which the client state changed (i.e. individual `patchVersion`s).
157
- */
158
- version: cvrVersionSchema,
121
+ const clientStateSchema = object({
122
+ /**
123
+ * The time at which the query was last inactivated. If this undefined or
124
+ * missing then the query is active.
125
+ *
126
+ * Desired queries are always active and have an undefined inactivatedAt.
127
+ */
128
+ inactivatedAt: ttlClockSchema.optional(),
129
+ /**
130
+ * TTL, time to live in milliseconds. If the query is not updated within this
131
+ * time. The time to live is the time after it has become inactive. Negative
132
+ * values are treated as `'forever'`.
133
+ *
134
+ * We do clamp this to a maximum of 10 minutes, so that queries do not
135
+ * live for a very long time in the CVR.
136
+ */
137
+ ttl: number(),
138
+ /**
139
+ * The version at which the client state changed (i.e. individual `patchVersion`s).
140
+ */
141
+ version: cvrVersionSchema
159
142
  });
160
143
  const externalQueryRecordSchema = baseQueryRecordSchema.extend({
161
- /**
162
- * The client state for this query, which includes the inactivatedAt, ttl and
163
- * version. The client state is stored in a record with the client ID as the
164
- * key.
165
- */
166
- clientState: v.record(clientStateSchema),
167
- // For queries, the `patchVersion` indicates when query was added to the got set,
168
- // and is absent if not yet gotten.
169
- patchVersion: cvrVersionSchema.optional(),
144
+ /**
145
+ * The client state for this query, which includes the inactivatedAt, ttl and
146
+ * version. The client state is stored in a record with the client ID as the
147
+ * key.
148
+ */
149
+ clientState: record(clientStateSchema),
150
+ // For queries, the `patchVersion` indicates when query was added to the got set,
151
+ // and is absent if not yet gotten.
152
+ patchVersion: cvrVersionSchema.optional()
170
153
  });
171
- export const clientQueryRecordSchema = externalQueryRecordSchema.extend({
172
- type: v.literal('client'),
173
- /** The original AST as supplied by the client. */
174
- ast: astSchema,
154
+ const clientQueryRecordSchema = externalQueryRecordSchema.extend({
155
+ type: literal("client"),
156
+ /** The original AST as supplied by the client. */
157
+ ast: astSchema
175
158
  });
176
- export const customQueryRecordSchema = externalQueryRecordSchema.extend({
177
- type: v.literal('custom'),
178
- name: v.string(),
179
- args: v.readonly(v.array(jsonSchema)),
159
+ const customQueryRecordSchema = externalQueryRecordSchema.extend({
160
+ type: literal("custom"),
161
+ name: string(),
162
+ args: readonly(array(jsonSchema))
180
163
  });
181
- export const queryRecordSchema = v.union(clientQueryRecordSchema, customQueryRecordSchema, internalQueryRecordSchema);
182
- export const rowIDSchema = v.object({
183
- schema: v.string(),
184
- table: v.string(),
185
- rowKey: v.record(jsonValueSchema),
164
+ union(
165
+ clientQueryRecordSchema,
166
+ customQueryRecordSchema,
167
+ internalQueryRecordSchema
168
+ );
169
+ const rowIDSchema = object({
170
+ schema: string(),
171
+ table: string(),
172
+ rowKey: record(jsonValueSchema)
186
173
  });
187
- export const rowRecordSchema = cvrRecordSchema.extend({
188
- id: rowIDSchema,
189
- rowVersion: v.string(), // '_0_version' of the row
190
- // query hashes => refCount, or `null` for a row that was removed from the
191
- // view (i.e. tombstone).
192
- refCounts: v.record(v.number()).nullable(),
174
+ cvrRecordSchema.extend({
175
+ id: rowIDSchema,
176
+ rowVersion: string(),
177
+ // '_0_version' of the row
178
+ // query hashes => refCount, or `null` for a row that was removed from the
179
+ // view (i.e. tombstone).
180
+ refCounts: record(number()).nullable()
193
181
  });
194
- export const patchSchema = v.object({
195
- type: v.literalUnion('row', 'query'),
196
- op: v.literalUnion('put', 'del'),
182
+ const patchSchema = object({
183
+ type: literalUnion("row", "query"),
184
+ op: literalUnion("put", "del")
197
185
  });
198
- export const putRowPatchSchema = patchSchema.extend({
199
- type: v.literal('row'),
200
- op: v.literal('put'),
201
- id: rowIDSchema,
202
- rowVersion: v.string(), // '_0_version' of the row
186
+ const putRowPatchSchema = patchSchema.extend({
187
+ type: literal("row"),
188
+ op: literal("put"),
189
+ id: rowIDSchema,
190
+ rowVersion: string()
191
+ // '_0_version' of the row
203
192
  });
204
- export const delRowPatchSchema = patchSchema.extend({
205
- type: v.literal('row'),
206
- op: v.literal('del'),
207
- id: rowIDSchema,
193
+ const delRowPatchSchema = patchSchema.extend({
194
+ type: literal("row"),
195
+ op: literal("del"),
196
+ id: rowIDSchema
208
197
  });
209
- export const rowPatchSchema = v.union(putRowPatchSchema, delRowPatchSchema);
210
- export const queryPatchSchema = patchSchema.extend({
211
- type: v.literal('query'),
212
- id: v.string(),
213
- clientID: v.string().optional(), // defined for "desired", undefined for "got"
198
+ union(putRowPatchSchema, delRowPatchSchema);
199
+ patchSchema.extend({
200
+ type: literal("query"),
201
+ id: string(),
202
+ clientID: string().optional()
203
+ // defined for "desired", undefined for "got"
214
204
  });
215
- export const metadataPatchSchema = queryPatchSchema;
216
- export function versionString(v) {
217
- // The separator (e.g. ":") needs to be lexicographically greater than the
218
- // storage key path separator (e.g. "/") so that "01/row-hash" is less than "01:01/row-hash".
219
- // In particular, the traditional separator for major.minor versions (".") does not
220
- // satisfy this quality.
221
- return v.minorVersion
222
- ? `${v.stateVersion}:${versionToLexi(v.minorVersion)}`
223
- : v.stateVersion;
205
+ function versionString(v2) {
206
+ return v2.minorVersion ? `${v2.stateVersion}:${versionToLexi(v2.minorVersion)}` : v2.stateVersion;
224
207
  }
225
- export function versionFromString(str) {
226
- const parts = str.split(':');
227
- const stateVersion = parts[0];
228
- switch (parts.length) {
229
- case 1: {
230
- versionFromLexi(stateVersion); // Purely for validation.
231
- return { stateVersion };
232
- }
233
- case 2: {
234
- const minorVersion = versionFromLexi(parts[1]);
235
- if (minorVersion > BigInt(Number.MAX_SAFE_INTEGER)) {
236
- throw new Error(`minorVersion ${parts[1]} exceeds max safe integer`);
237
- }
238
- return { stateVersion, minorVersion: Number(minorVersion) };
239
- }
240
- default:
241
- throw new TypeError(`Invalid version string ${str}`);
208
+ function versionFromString(str) {
209
+ const parts = str.split(":");
210
+ const stateVersion = parts[0];
211
+ switch (parts.length) {
212
+ case 1: {
213
+ versionFromLexi(stateVersion);
214
+ return { stateVersion };
242
215
  }
243
- }
244
- export function queryRecordToQueryRow(clientGroupID, query) {
245
- switch (query.type) {
246
- case 'internal':
247
- return {
248
- clientGroupID,
249
- queryHash: query.id,
250
- clientAST: query.ast,
251
- queryName: null,
252
- queryArgs: null,
253
- patchVersion: null,
254
- transformationHash: query.transformationHash ?? null,
255
- transformationVersion: maybeVersionString(query.transformationVersion),
256
- internal: true,
257
- deleted: false, // put vs del "got" query
258
- };
259
- case 'client':
260
- return {
261
- clientGroupID,
262
- queryHash: query.id,
263
- clientAST: query.ast,
264
- queryName: null,
265
- queryArgs: null,
266
- patchVersion: maybeVersionString(query.patchVersion),
267
- transformationHash: query.transformationHash ?? null,
268
- transformationVersion: maybeVersionString(query.transformationVersion),
269
- internal: null,
270
- deleted: false, // put vs del "got" query
271
- };
272
- case 'custom':
273
- return {
274
- clientGroupID,
275
- queryHash: query.id,
276
- clientAST: null,
277
- queryName: query.name,
278
- queryArgs: query.args,
279
- patchVersion: maybeVersionString(query.patchVersion),
280
- transformationHash: query.transformationHash ?? null,
281
- transformationVersion: maybeVersionString(query.transformationVersion),
282
- internal: null,
283
- deleted: false, // put vs del "got" query
284
- };
216
+ case 2: {
217
+ const minorVersion = versionFromLexi(parts[1]);
218
+ if (minorVersion > BigInt(Number.MAX_SAFE_INTEGER)) {
219
+ throw new Error(`minorVersion ${parts[1]} exceeds max safe integer`);
220
+ }
221
+ return { stateVersion, minorVersion: Number(minorVersion) };
285
222
  }
223
+ default:
224
+ throw new TypeError(`Invalid version string ${str}`);
225
+ }
286
226
  }
287
- export const maybeVersionString = (v) => v ? versionString(v) : null;
288
- //# sourceMappingURL=types.js.map
227
+ function queryRecordToQueryRow(clientGroupID, query) {
228
+ switch (query.type) {
229
+ case "internal":
230
+ return {
231
+ clientGroupID,
232
+ queryHash: query.id,
233
+ clientAST: query.ast,
234
+ queryName: null,
235
+ queryArgs: null,
236
+ patchVersion: null,
237
+ transformationHash: query.transformationHash ?? null,
238
+ transformationVersion: maybeVersionString(query.transformationVersion),
239
+ internal: true,
240
+ deleted: false
241
+ // put vs del "got" query
242
+ };
243
+ case "client":
244
+ return {
245
+ clientGroupID,
246
+ queryHash: query.id,
247
+ clientAST: query.ast,
248
+ queryName: null,
249
+ queryArgs: null,
250
+ patchVersion: maybeVersionString(query.patchVersion),
251
+ transformationHash: query.transformationHash ?? null,
252
+ transformationVersion: maybeVersionString(query.transformationVersion),
253
+ internal: null,
254
+ deleted: false
255
+ // put vs del "got" query
256
+ };
257
+ case "custom":
258
+ return {
259
+ clientGroupID,
260
+ queryHash: query.id,
261
+ clientAST: null,
262
+ queryName: query.name,
263
+ queryArgs: query.args,
264
+ patchVersion: maybeVersionString(query.patchVersion),
265
+ transformationHash: query.transformationHash ?? null,
266
+ transformationVersion: maybeVersionString(query.transformationVersion),
267
+ internal: null,
268
+ deleted: false
269
+ // put vs del "got" query
270
+ };
271
+ }
272
+ }
273
+ const maybeVersionString = (v2) => v2 ? versionString(v2) : null;
274
+ export {
275
+ EMPTY_CVR_VERSION,
276
+ baseQueryRecordSchema,
277
+ clientQueryRecordSchema,
278
+ cmpVersions,
279
+ cookieToVersion,
280
+ customQueryRecordSchema,
281
+ cvrVersionSchema,
282
+ delRowPatchSchema,
283
+ internalQueryRecordSchema,
284
+ maxVersion,
285
+ maybeVersionString,
286
+ oneAfter,
287
+ patchSchema,
288
+ putRowPatchSchema,
289
+ queryRecordToQueryRow,
290
+ rowIDSchema,
291
+ versionFromString,
292
+ versionString,
293
+ versionToCookie,
294
+ versionToNullableCookie
295
+ };
296
+ //# sourceMappingURL=types.js.map