@rocicorp/zero 0.23.2025081401 → 0.23.2025081901

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 (202) hide show
  1. package/out/analyze-query/src/bin-analyze.d.ts.map +1 -1
  2. package/out/analyze-query/src/bin-analyze.js +56 -99
  3. package/out/analyze-query/src/bin-analyze.js.map +1 -1
  4. package/out/analyze-query/src/explain-queries.d.ts +4 -0
  5. package/out/analyze-query/src/explain-queries.d.ts.map +1 -0
  6. package/out/analyze-query/src/explain-queries.js +18 -0
  7. package/out/analyze-query/src/explain-queries.js.map +1 -0
  8. package/out/analyze-query/src/run-ast.d.ts +29 -0
  9. package/out/analyze-query/src/run-ast.d.ts.map +1 -0
  10. package/out/analyze-query/src/run-ast.js +68 -0
  11. package/out/analyze-query/src/run-ast.js.map +1 -0
  12. package/out/{chunk-KKPRF2XZ.js → chunk-DYTMKRKN.js} +124 -63
  13. package/out/{chunk-KKPRF2XZ.js.map → chunk-DYTMKRKN.js.map} +4 -4
  14. package/out/{chunk-O536GEIT.js → chunk-RPVWLROJ.js} +80 -35
  15. package/out/{chunk-O536GEIT.js.map → chunk-RPVWLROJ.js.map} +3 -3
  16. package/out/{chunk-ZIZNSAHP.js → chunk-ZOMIZNT3.js} +55 -58
  17. package/out/chunk-ZOMIZNT3.js.map +7 -0
  18. package/out/{inspector-J5P4DOGH.js → inspector-NC47TWFX.js} +4 -3
  19. package/out/{inspector-J5P4DOGH.js.map → inspector-NC47TWFX.js.map} +2 -2
  20. package/out/react.js +2 -2
  21. package/out/solid.js +3 -3
  22. package/out/zero/package.json +1 -1
  23. package/out/zero/src/server/reaper.d.ts +2 -0
  24. package/out/zero/src/server/reaper.d.ts.map +1 -0
  25. package/out/zero/src/server/reaper.js +2 -0
  26. package/out/zero/src/server/reaper.js.map +1 -0
  27. package/out/zero-cache/src/auth/write-authorizer.d.ts.map +1 -1
  28. package/out/zero-cache/src/auth/write-authorizer.js +2 -3
  29. package/out/zero-cache/src/auth/write-authorizer.js.map +1 -1
  30. package/out/zero-cache/src/config/zero-config.d.ts +4 -0
  31. package/out/zero-cache/src/config/zero-config.d.ts.map +1 -1
  32. package/out/zero-cache/src/config/zero-config.js +9 -1
  33. package/out/zero-cache/src/config/zero-config.js.map +1 -1
  34. package/out/zero-cache/src/custom-queries/transform-query.d.ts +2 -3
  35. package/out/zero-cache/src/custom-queries/transform-query.d.ts.map +1 -1
  36. package/out/zero-cache/src/custom-queries/transform-query.js +18 -4
  37. package/out/zero-cache/src/custom-queries/transform-query.js.map +1 -1
  38. package/out/zero-cache/src/observability/events.js +1 -2
  39. package/out/zero-cache/src/observability/events.js.map +1 -1
  40. package/out/zero-cache/src/server/inspect-metrics-delegate.d.ts +23 -0
  41. package/out/zero-cache/src/server/inspect-metrics-delegate.d.ts.map +1 -0
  42. package/out/zero-cache/src/server/inspect-metrics-delegate.js +55 -0
  43. package/out/zero-cache/src/server/inspect-metrics-delegate.js.map +1 -0
  44. package/out/zero-cache/src/server/main.d.ts.map +1 -1
  45. package/out/zero-cache/src/server/main.js +12 -15
  46. package/out/zero-cache/src/server/main.js.map +1 -1
  47. package/out/zero-cache/src/server/reaper.d.ts +3 -0
  48. package/out/zero-cache/src/server/reaper.d.ts.map +1 -0
  49. package/out/zero-cache/src/server/reaper.js +31 -0
  50. package/out/zero-cache/src/server/reaper.js.map +1 -0
  51. package/out/zero-cache/src/server/runner/zero-dispatcher.d.ts.map +1 -1
  52. package/out/zero-cache/src/server/runner/zero-dispatcher.js +6 -0
  53. package/out/zero-cache/src/server/runner/zero-dispatcher.js.map +1 -1
  54. package/out/zero-cache/src/server/syncer.d.ts.map +1 -1
  55. package/out/zero-cache/src/server/syncer.js +3 -1
  56. package/out/zero-cache/src/server/syncer.js.map +1 -1
  57. package/out/zero-cache/src/services/analyze.d.ts +6 -0
  58. package/out/zero-cache/src/services/analyze.d.ts.map +1 -0
  59. package/out/zero-cache/src/services/analyze.js +70 -0
  60. package/out/zero-cache/src/services/analyze.js.map +1 -0
  61. package/out/zero-cache/src/services/change-source/custom/change-source.js +1 -1
  62. package/out/zero-cache/src/services/change-source/pg/initial-sync.d.ts.map +1 -1
  63. package/out/zero-cache/src/services/change-source/pg/initial-sync.js +8 -3
  64. package/out/zero-cache/src/services/change-source/pg/initial-sync.js.map +1 -1
  65. package/out/zero-cache/src/services/mutagen/pusher.d.ts +38 -2
  66. package/out/zero-cache/src/services/mutagen/pusher.d.ts.map +1 -1
  67. package/out/zero-cache/src/services/replicator/change-processor.d.ts +3 -2
  68. package/out/zero-cache/src/services/replicator/change-processor.d.ts.map +1 -1
  69. package/out/zero-cache/src/services/replicator/change-processor.js +39 -34
  70. package/out/zero-cache/src/services/replicator/change-processor.js.map +1 -1
  71. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +1 -1
  72. package/out/zero-cache/src/services/replicator/incremental-sync.js +1 -3
  73. package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -1
  74. package/out/zero-cache/src/services/replicator/replication-status.js +1 -1
  75. package/out/zero-cache/src/services/replicator/replication-status.js.map +1 -1
  76. package/out/zero-cache/src/services/running-state.d.ts +5 -0
  77. package/out/zero-cache/src/services/running-state.d.ts.map +1 -1
  78. package/out/zero-cache/src/services/running-state.js +8 -1
  79. package/out/zero-cache/src/services/running-state.js.map +1 -1
  80. package/out/zero-cache/src/services/view-syncer/client-handler.d.ts +2 -0
  81. package/out/zero-cache/src/services/view-syncer/client-handler.d.ts.map +1 -1
  82. package/out/zero-cache/src/services/view-syncer/client-handler.js +3 -0
  83. package/out/zero-cache/src/services/view-syncer/client-handler.js.map +1 -1
  84. package/out/zero-cache/src/services/view-syncer/cvr-purger.d.ts +16 -0
  85. package/out/zero-cache/src/services/view-syncer/cvr-purger.d.ts.map +1 -0
  86. package/out/zero-cache/src/services/view-syncer/cvr-purger.js +86 -0
  87. package/out/zero-cache/src/services/view-syncer/cvr-purger.js.map +1 -0
  88. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +16 -9
  89. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +1 -1
  90. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +50 -30
  91. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -1
  92. package/out/zero-cache/src/services/view-syncer/schema/cvr.d.ts.map +1 -1
  93. package/out/zero-cache/src/services/view-syncer/schema/cvr.js +36 -26
  94. package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +1 -1
  95. package/out/zero-cache/src/services/view-syncer/schema/init.d.ts.map +1 -1
  96. package/out/zero-cache/src/services/view-syncer/schema/init.js +27 -0
  97. package/out/zero-cache/src/services/view-syncer/schema/init.js.map +1 -1
  98. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +2 -9
  99. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -1
  100. package/out/zero-cache/src/services/view-syncer/view-syncer.js +93 -75
  101. package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -1
  102. package/out/zero-cache/src/types/pg.d.ts +1 -1
  103. package/out/zero-cache/src/types/pg.js +1 -1
  104. package/out/zero-client/src/client/context.d.ts +1 -0
  105. package/out/zero-client/src/client/context.d.ts.map +1 -1
  106. package/out/zero-client/src/client/inspector/inspector.d.ts.map +1 -1
  107. package/out/zero-client/src/client/inspector/types.d.ts +1 -0
  108. package/out/zero-client/src/client/inspector/types.d.ts.map +1 -1
  109. package/out/zero-client/src/client/zero.d.ts.map +1 -1
  110. package/out/zero-client/src/mod.d.ts +1 -1
  111. package/out/zero-client/src/mod.d.ts.map +1 -1
  112. package/out/zero-events/src/status.d.ts +10 -9
  113. package/out/zero-events/src/status.d.ts.map +1 -1
  114. package/out/zero-events/src/status.js +7 -10
  115. package/out/zero-events/src/status.js.map +1 -1
  116. package/out/zero-protocol/src/custom-queries.d.ts +77 -5
  117. package/out/zero-protocol/src/custom-queries.d.ts.map +1 -1
  118. package/out/zero-protocol/src/custom-queries.js +19 -1
  119. package/out/zero-protocol/src/custom-queries.js.map +1 -1
  120. package/out/zero-protocol/src/down.d.ts +19 -1
  121. package/out/zero-protocol/src/down.d.ts.map +1 -1
  122. package/out/zero-protocol/src/down.js +2 -1
  123. package/out/zero-protocol/src/down.js.map +1 -1
  124. package/out/zero-protocol/src/inspect-down.d.ts +8 -0
  125. package/out/zero-protocol/src/inspect-down.d.ts.map +1 -1
  126. package/out/zero-protocol/src/inspect-down.js +1 -0
  127. package/out/zero-protocol/src/inspect-down.js.map +1 -1
  128. package/out/zero-protocol/src/protocol-version.d.ts +1 -1
  129. package/out/zero-protocol/src/protocol-version.d.ts.map +1 -1
  130. package/out/zero-protocol/src/protocol-version.js +3 -1
  131. package/out/zero-protocol/src/protocol-version.js.map +1 -1
  132. package/out/zero-server/src/mod.d.ts +1 -0
  133. package/out/zero-server/src/mod.d.ts.map +1 -1
  134. package/out/zero-server/src/mod.js +1 -0
  135. package/out/zero-server/src/mod.js.map +1 -1
  136. package/out/zero-server/src/process-mutations.d.ts +46 -0
  137. package/out/zero-server/src/process-mutations.d.ts.map +1 -0
  138. package/out/zero-server/src/process-mutations.js +187 -0
  139. package/out/zero-server/src/process-mutations.js.map +1 -0
  140. package/out/zero-server/src/push-processor.d.ts +2 -27
  141. package/out/zero-server/src/push-processor.d.ts.map +1 -1
  142. package/out/zero-server/src/push-processor.js +17 -154
  143. package/out/zero-server/src/push-processor.js.map +1 -1
  144. package/out/zero-server/src/queries/process-queries.d.ts +1 -1
  145. package/out/zero-server/src/queries/process-queries.d.ts.map +1 -1
  146. package/out/zero-server/src/queries/process-queries.js +1 -1
  147. package/out/zero-server/src/queries/process-queries.js.map +1 -1
  148. package/out/zero-server/src/zql-database.d.ts +1 -1
  149. package/out/zero-server/src/zql-database.d.ts.map +1 -1
  150. package/out/zero.js +14 -10
  151. package/out/zql/src/builder/builder.d.ts +5 -1
  152. package/out/zql/src/builder/builder.d.ts.map +1 -1
  153. package/out/zql/src/builder/builder.js +49 -16
  154. package/out/zql/src/builder/builder.js.map +1 -1
  155. package/out/zql/src/builder/debug-delegate.d.ts +29 -0
  156. package/out/zql/src/builder/debug-delegate.d.ts.map +1 -0
  157. package/out/zql/src/builder/debug-delegate.js +55 -0
  158. package/out/zql/src/builder/debug-delegate.js.map +1 -0
  159. package/out/zql/src/builder/filter.d.ts +0 -3
  160. package/out/zql/src/builder/filter.d.ts.map +1 -1
  161. package/out/zql/src/builder/filter.js +0 -3
  162. package/out/zql/src/builder/filter.js.map +1 -1
  163. package/out/zql/src/ivm/filter-operators.d.ts +2 -1
  164. package/out/zql/src/ivm/filter-operators.d.ts.map +1 -1
  165. package/out/zql/src/ivm/filter-operators.js +7 -2
  166. package/out/zql/src/ivm/filter-operators.js.map +1 -1
  167. package/out/zql/src/ivm/memory-source.d.ts +2 -0
  168. package/out/zql/src/ivm/memory-source.d.ts.map +1 -1
  169. package/out/zql/src/ivm/memory-source.js.map +1 -1
  170. package/out/zql/src/ivm/source.d.ts +2 -1
  171. package/out/zql/src/ivm/source.d.ts.map +1 -1
  172. package/out/zql/src/query/measure-push-operator.d.ts +19 -0
  173. package/out/zql/src/query/measure-push-operator.d.ts.map +1 -0
  174. package/out/zql/src/query/measure-push-operator.js +36 -0
  175. package/out/zql/src/query/measure-push-operator.js.map +1 -0
  176. package/out/zql/src/query/metrics-delegate.d.ts +3 -0
  177. package/out/zql/src/query/metrics-delegate.d.ts.map +1 -1
  178. package/out/zql/src/query/metrics-delegate.js +6 -1
  179. package/out/zql/src/query/metrics-delegate.js.map +1 -1
  180. package/out/zql/src/query/named.d.ts +38 -9
  181. package/out/zql/src/query/named.d.ts.map +1 -1
  182. package/out/zql/src/query/named.js +49 -24
  183. package/out/zql/src/query/named.js.map +1 -1
  184. package/out/zql/src/query/query-impl.d.ts +1 -1
  185. package/out/zql/src/query/query-impl.d.ts.map +1 -1
  186. package/out/zql/src/query/query-impl.js.map +1 -1
  187. package/out/zqlite/src/query-delegate.d.ts +1 -0
  188. package/out/zqlite/src/query-delegate.d.ts.map +1 -1
  189. package/out/zqlite/src/query-delegate.js +2 -1
  190. package/out/zqlite/src/query-delegate.js.map +1 -1
  191. package/out/zqlite/src/table-source.d.ts +3 -2
  192. package/out/zqlite/src/table-source.d.ts.map +1 -1
  193. package/out/zqlite/src/table-source.js +8 -10
  194. package/out/zqlite/src/table-source.js.map +1 -1
  195. package/package.json +1 -1
  196. package/out/chunk-ZIZNSAHP.js.map +0 -7
  197. package/out/zero-client/src/client/measure-push-operator.d.ts +0 -17
  198. package/out/zero-client/src/client/measure-push-operator.d.ts.map +0 -1
  199. package/out/zqlite/src/runtime-debug.d.ts +0 -23
  200. package/out/zqlite/src/runtime-debug.d.ts.map +0 -1
  201. package/out/zqlite/src/runtime-debug.js +0 -69
  202. package/out/zqlite/src/runtime-debug.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"custom-queries.js","sourceRoot":"","sources":["../../../../zero-protocol/src/custom-queries.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,iCAAiC,CAAC;AAC3D,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAChD,OAAO,EAAC,SAAS,EAAC,MAAM,UAAU,CAAC;AAEnC,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,CAAC,KAAK,CAC/C,CAAC,CAAC,MAAM,CAAC;IACP,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;CACtC,CAAC,CACH,CAAC;AAGF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC7C,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,GAAG,EAAE,SAAS;CACf,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,MAAM,CAAC;IACzC,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACvB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,OAAO,EAAE,UAAU;CACpB,CAAC,CAAC;AAGH,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,CAAC,KAAK,CAChD,CAAC,CAAC,KAAK,CAAC,sBAAsB,EAAE,kBAAkB,CAAC,CACpD,CAAC;AAGF,MAAM,CAAC,MAAM,6BAA6B,GAAG,CAAC,CAAC,KAAK,CAAC;IACnD,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC;IACtB,0BAA0B;CAC3B,CAAC,CAAC;AAKH,MAAM,CAAC,MAAM,8BAA8B,GAAG,CAAC,CAAC,KAAK,CAAC;IACpD,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC;IACxB,2BAA2B;CAC5B,CAAC,CAAC"}
1
+ {"version":3,"file":"custom-queries.js","sourceRoot":"","sources":["../../../../zero-protocol/src/custom-queries.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,iCAAiC,CAAC;AAC3D,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAChD,OAAO,EAAC,SAAS,EAAC,MAAM,UAAU,CAAC;AAEnC,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,CAAC,KAAK,CAC/C,CAAC,CAAC,MAAM,CAAC;IACP,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,IAAI,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;CACtC,CAAC,CACH,CAAC;AAGF,MAAM,CAAC,MAAM,sBAAsB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC7C,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,GAAG,EAAE,SAAS;CACf,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC1C,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;IACvB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,OAAO,EAAE,UAAU;CACpB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,CAAC,MAAM,CAAC;IACtC,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;IACxB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,OAAO,EAAE,UAAU;CACpB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC,CAAC,MAAM,CAAC;IAC3C,KAAK,EAAE,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC;IACxB,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;IACd,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE;IAChB,MAAM,EAAE,CAAC,CAAC,MAAM,EAAE;IAClB,OAAO,EAAE,UAAU;CACpB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CACvC,mBAAmB,EACnB,oBAAoB,EACpB,eAAe,CAChB,CAAC;AAKF,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,CAAC,KAAK,CAChD,CAAC,CAAC,KAAK,CAAC,sBAAsB,EAAE,kBAAkB,CAAC,CACpD,CAAC;AAGF,MAAM,CAAC,MAAM,6BAA6B,GAAG,CAAC,CAAC,KAAK,CAAC;IACnD,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC;IACtB,0BAA0B;CAC3B,CAAC,CAAC;AAIH,MAAM,CAAC,MAAM,2BAA2B,GAAG,CAAC,CAAC,KAAK,CAAC;IACjD,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC;IAC3B,CAAC,CAAC,KAAK,CAAC,kBAAkB,CAAC;CAC5B,CAAC,CAAC;AAGH,MAAM,CAAC,MAAM,8BAA8B,GAAG,CAAC,CAAC,KAAK,CAAC;IACpD,CAAC,CAAC,OAAO,CAAC,aAAa,CAAC;IACxB,2BAA2B;CAC5B,CAAC,CAAC"}
@@ -145,6 +145,7 @@ export declare const downstreamSchema: v.UnionType<[v.TupleType<[v.Type<"connect
145
145
  rowCount: v.Type<number>;
146
146
  metrics: v.Optional<{
147
147
  'query-materialization-server': [number, ...number[]];
148
+ 'query-update-server': [number, ...number[]];
148
149
  } | null>;
149
150
  }, undefined>>;
150
151
  }, undefined>, v.ObjectType<Omit<{
@@ -153,12 +154,29 @@ export declare const downstreamSchema: v.UnionType<[v.TupleType<[v.Type<"connect
153
154
  op: v.Type<"metrics">;
154
155
  value: v.ObjectType<{
155
156
  'query-materialization-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
157
+ 'query-update-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
156
158
  }, undefined>;
157
159
  }, undefined>, v.ObjectType<Omit<{
158
160
  id: v.Type<string>;
159
161
  }, "op" | "value"> & {
160
162
  op: v.Type<"version">;
161
163
  value: v.Type<string>;
162
- }, undefined>]>]>]>;
164
+ }, undefined>]>]>, v.TupleType<[v.Type<"transformError">, v.ArrayType<v.UnionType<[v.ObjectType<{
165
+ error: v.Type<"app">;
166
+ id: v.Type<string>;
167
+ name: v.Type<string>;
168
+ details: v.Type<import("../../shared/src/json.ts").ReadonlyJSONValue>;
169
+ }, undefined>, v.ObjectType<{
170
+ error: v.Type<"http">;
171
+ id: v.Type<string>;
172
+ name: v.Type<string>;
173
+ status: v.Type<number>;
174
+ details: v.Type<import("../../shared/src/json.ts").ReadonlyJSONValue>;
175
+ }, undefined>, v.ObjectType<{
176
+ error: v.Type<"zero">;
177
+ id: v.Type<string>;
178
+ name: v.Type<string>;
179
+ details: v.Type<import("../../shared/src/json.ts").ReadonlyJSONValue>;
180
+ }, undefined>]>>]>]>;
163
181
  export type Downstream = v.Infer<typeof downstreamSchema>;
164
182
  //# sourceMappingURL=down.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"down.d.ts","sourceRoot":"","sources":["../../../../zero-protocol/src/down.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAchD,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBAW5B,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC"}
1
+ {"version":3,"file":"down.d.ts","sourceRoot":"","sources":["../../../../zero-protocol/src/down.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAehD,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;oBAY5B,CAAC;AAEF,MAAM,MAAM,UAAU,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC"}
@@ -1,5 +1,6 @@
1
1
  import * as v from "../../shared/src/valita.js";
2
2
  import { connectedMessageSchema } from "./connect.js";
3
+ import { transformErrorMessageSchema } from "./custom-queries.js";
3
4
  import { deleteClientsMessageSchema } from "./delete-clients.js";
4
5
  import { errorMessageSchema } from "./error.js";
5
6
  import { inspectDownMessageSchema } from "./inspect-down.js";
@@ -7,5 +8,5 @@ import { pokeEndMessageSchema, pokePartMessageSchema, pokeStartMessageSchema, }
7
8
  import { pongMessageSchema } from "./pong.js";
8
9
  import { pullResponseMessageSchema } from "./pull.js";
9
10
  import { pushResponseMessageSchema } from "./push.js";
10
- export const downstreamSchema = v.union(connectedMessageSchema, errorMessageSchema, pongMessageSchema, pokeStartMessageSchema, pokePartMessageSchema, pokeEndMessageSchema, pullResponseMessageSchema, deleteClientsMessageSchema, pushResponseMessageSchema, inspectDownMessageSchema);
11
+ export const downstreamSchema = v.union(connectedMessageSchema, errorMessageSchema, pongMessageSchema, pokeStartMessageSchema, pokePartMessageSchema, pokeEndMessageSchema, pullResponseMessageSchema, deleteClientsMessageSchema, pushResponseMessageSchema, inspectDownMessageSchema, transformErrorMessageSchema);
11
12
  //# sourceMappingURL=down.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"down.js","sourceRoot":"","sources":["../../../../zero-protocol/src/down.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAChD,OAAO,EAAC,sBAAsB,EAAC,MAAM,cAAc,CAAC;AACpD,OAAO,EAAC,0BAA0B,EAAC,MAAM,qBAAqB,CAAC;AAC/D,OAAO,EAAC,kBAAkB,EAAC,MAAM,YAAY,CAAC;AAC9C,OAAO,EAAC,wBAAwB,EAAC,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAC,iBAAiB,EAAC,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAC,yBAAyB,EAAC,MAAM,WAAW,CAAC;AACpD,OAAO,EAAC,yBAAyB,EAAC,MAAM,WAAW,CAAC;AAEpD,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CACrC,sBAAsB,EACtB,kBAAkB,EAClB,iBAAiB,EACjB,sBAAsB,EACtB,qBAAqB,EACrB,oBAAoB,EACpB,yBAAyB,EACzB,0BAA0B,EAC1B,yBAAyB,EACzB,wBAAwB,CACzB,CAAC"}
1
+ {"version":3,"file":"down.js","sourceRoot":"","sources":["../../../../zero-protocol/src/down.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAChD,OAAO,EAAC,sBAAsB,EAAC,MAAM,cAAc,CAAC;AACpD,OAAO,EAAC,2BAA2B,EAAC,MAAM,qBAAqB,CAAC;AAChE,OAAO,EAAC,0BAA0B,EAAC,MAAM,qBAAqB,CAAC;AAC/D,OAAO,EAAC,kBAAkB,EAAC,MAAM,YAAY,CAAC;AAC9C,OAAO,EAAC,wBAAwB,EAAC,MAAM,mBAAmB,CAAC;AAC3D,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,sBAAsB,GACvB,MAAM,WAAW,CAAC;AACnB,OAAO,EAAC,iBAAiB,EAAC,MAAM,WAAW,CAAC;AAC5C,OAAO,EAAC,yBAAyB,EAAC,MAAM,WAAW,CAAC;AACpD,OAAO,EAAC,yBAAyB,EAAC,MAAM,WAAW,CAAC;AAEpD,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,CAAC,KAAK,CACrC,sBAAsB,EACtB,kBAAkB,EAClB,iBAAiB,EACjB,sBAAsB,EACtB,qBAAqB,EACrB,oBAAoB,EACpB,yBAAyB,EACzB,0BAA0B,EAC1B,yBAAyB,EACzB,wBAAwB,EACxB,2BAA2B,CAC5B,CAAC"}
@@ -1,6 +1,7 @@
1
1
  import * as v from '../../shared/src/valita.ts';
2
2
  declare const serverMetricsSchema: v.ObjectType<{
3
3
  'query-materialization-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
4
+ 'query-update-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
4
5
  }, undefined>;
5
6
  export type ServerMetrics = v.Infer<typeof serverMetricsSchema>;
6
7
  declare const inspectQueryRowSchema: v.ObjectType<{
@@ -16,6 +17,7 @@ declare const inspectQueryRowSchema: v.ObjectType<{
16
17
  rowCount: v.Type<number>;
17
18
  metrics: v.Optional<{
18
19
  'query-materialization-server': [number, ...number[]];
20
+ 'query-update-server': [number, ...number[]];
19
21
  } | null>;
20
22
  }, undefined>;
21
23
  export type InspectQueryRow = v.Infer<typeof inspectQueryRowSchema>;
@@ -36,6 +38,7 @@ export declare const inspectQueriesDownSchema: v.ObjectType<Omit<{
36
38
  rowCount: v.Type<number>;
37
39
  metrics: v.Optional<{
38
40
  'query-materialization-server': [number, ...number[]];
41
+ 'query-update-server': [number, ...number[]];
39
42
  } | null>;
40
43
  }, undefined>>;
41
44
  }, undefined>;
@@ -46,6 +49,7 @@ export declare const inspectMetricsDownSchema: v.ObjectType<Omit<{
46
49
  op: v.Type<"metrics">;
47
50
  value: v.ObjectType<{
48
51
  'query-materialization-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
52
+ 'query-update-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
49
53
  }, undefined>;
50
54
  }, undefined>;
51
55
  export type InspectMetricsDown = v.Infer<typeof inspectMetricsDownSchema>;
@@ -72,6 +76,7 @@ export declare const inspectDownBodySchema: v.UnionType<[v.ObjectType<Omit<{
72
76
  rowCount: v.Type<number>;
73
77
  metrics: v.Optional<{
74
78
  'query-materialization-server': [number, ...number[]];
79
+ 'query-update-server': [number, ...number[]];
75
80
  } | null>;
76
81
  }, undefined>>;
77
82
  }, undefined>, v.ObjectType<Omit<{
@@ -80,6 +85,7 @@ export declare const inspectDownBodySchema: v.UnionType<[v.ObjectType<Omit<{
80
85
  op: v.Type<"metrics">;
81
86
  value: v.ObjectType<{
82
87
  'query-materialization-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
88
+ 'query-update-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
83
89
  }, undefined>;
84
90
  }, undefined>, v.ObjectType<Omit<{
85
91
  id: v.Type<string>;
@@ -104,6 +110,7 @@ export declare const inspectDownMessageSchema: v.TupleType<[v.Type<"inspect">, v
104
110
  rowCount: v.Type<number>;
105
111
  metrics: v.Optional<{
106
112
  'query-materialization-server': [number, ...number[]];
113
+ 'query-update-server': [number, ...number[]];
107
114
  } | null>;
108
115
  }, undefined>>;
109
116
  }, undefined>, v.ObjectType<Omit<{
@@ -112,6 +119,7 @@ export declare const inspectDownMessageSchema: v.TupleType<[v.Type<"inspect">, v
112
119
  op: v.Type<"metrics">;
113
120
  value: v.ObjectType<{
114
121
  'query-materialization-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
122
+ 'query-update-server': v.VariadicTupleType<[v.Type<number>], v.Type<number>, []>;
115
123
  }, undefined>;
116
124
  }, undefined>, v.ObjectType<Omit<{
117
125
  id: v.Type<string>;
@@ -1 +1 @@
1
- {"version":3,"file":"inspect-down.d.ts","sourceRoot":"","sources":["../../../../zero-protocol/src/inspect-down.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAGhD,QAAA,MAAM,mBAAmB;;aAEvB,CAAC;AAEH,MAAM,MAAM,aAAa,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAEhE,QAAA,MAAM,qBAAqB;;;;;;;;;;;;;;aAezB,CAAC;AAEH,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC;AAMpE,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;aAGnC,CAAC;AAEH,MAAM,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,wBAAwB,CAAC,CAAC;AAE1E,eAAO,MAAM,wBAAwB;;;;;;;aAGnC,CAAC;AAEH,MAAM,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,wBAAwB,CAAC,CAAC;AAE1E,eAAO,MAAM,wBAAwB;;;;;aAGnC,CAAC;AAEH,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAIjC,CAAC;AAEF,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAGnC,CAAC;AAEH,MAAM,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,wBAAwB,CAAC,CAAC;AAE1E,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC"}
1
+ {"version":3,"file":"inspect-down.d.ts","sourceRoot":"","sources":["../../../../zero-protocol/src/inspect-down.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAGhD,QAAA,MAAM,mBAAmB;;;aAGvB,CAAC;AAEH,MAAM,MAAM,aAAa,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,mBAAmB,CAAC,CAAC;AAEhE,QAAA,MAAM,qBAAqB;;;;;;;;;;;;;;;aAezB,CAAC;AAEH,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC;AAMpE,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;;aAGnC,CAAC;AAEH,MAAM,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,wBAAwB,CAAC,CAAC;AAE1E,eAAO,MAAM,wBAAwB;;;;;;;;aAGnC,CAAC;AAEH,MAAM,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,wBAAwB,CAAC,CAAC;AAE1E,eAAO,MAAM,wBAAwB;;;;;aAGnC,CAAC;AAEH,eAAO,MAAM,qBAAqB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;eAIjC,CAAC;AAEF,eAAO,MAAM,wBAAwB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAGnC,CAAC;AAEH,MAAM,MAAM,kBAAkB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,wBAAwB,CAAC,CAAC;AAE1E,MAAM,MAAM,eAAe,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,qBAAqB,CAAC,CAAC"}
@@ -4,6 +4,7 @@ import * as v from "../../shared/src/valita.js";
4
4
  import { astSchema } from "./ast.js";
5
5
  const serverMetricsSchema = v.object({
6
6
  'query-materialization-server': tdigestSchema,
7
+ 'query-update-server': tdigestSchema,
7
8
  });
8
9
  const inspectQueryRowSchema = v.object({
9
10
  clientID: v.string(),
@@ -1 +1 @@
1
- {"version":3,"file":"inspect-down.js","sourceRoot":"","sources":["../../../../zero-protocol/src/inspect-down.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,iCAAiC,CAAC;AAC3D,OAAO,EAAC,aAAa,EAAC,MAAM,oCAAoC,CAAC;AACjE,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAChD,OAAO,EAAC,SAAS,EAAC,MAAM,UAAU,CAAC;AAEnC,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC;IACnC,8BAA8B,EAAE,aAAa;CAC9C,CAAC,CAAC;AAIH,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC;IACrC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE;IACpB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;IACnB,0BAA0B;IAC1B,GAAG,EAAE,SAAS,CAAC,QAAQ,EAAE;IACzB,8BAA8B;IAC9B,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3B,8BAA8B;IAC9B,IAAI,EAAE,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE;IAC5C,GAAG,EAAE,CAAC,CAAC,OAAO,EAAE;IAChB,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE;IACpB,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE;IACf,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACpC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE;IACpB,OAAO,EAAE,mBAAmB,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE;CACnD,CAAC,CAAC;AAIH,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC;IACrC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;CACf,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,wBAAwB,GAAG,qBAAqB,CAAC,MAAM,CAAC;IACnE,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;IACxB,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,qBAAqB,CAAC;CACtC,CAAC,CAAC;AAIH,MAAM,CAAC,MAAM,wBAAwB,GAAG,qBAAqB,CAAC,MAAM,CAAC;IACnE,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;IACxB,KAAK,EAAE,mBAAmB;CAC3B,CAAC,CAAC;AAIH,MAAM,CAAC,MAAM,wBAAwB,GAAG,qBAAqB,CAAC,MAAM,CAAC;IACnE,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;IACxB,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE;CAClB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,CAAC,KAAK,CAC1C,wBAAwB,EACxB,wBAAwB,EACxB,wBAAwB,CACzB,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,CAAC,KAAK,CAAC;IAC9C,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;IACpB,qBAAqB;CACtB,CAAC,CAAC"}
1
+ {"version":3,"file":"inspect-down.js","sourceRoot":"","sources":["../../../../zero-protocol/src/inspect-down.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,iCAAiC,CAAC;AAC3D,OAAO,EAAC,aAAa,EAAC,MAAM,oCAAoC,CAAC;AACjE,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAChD,OAAO,EAAC,SAAS,EAAC,MAAM,UAAU,CAAC;AAEnC,MAAM,mBAAmB,GAAG,CAAC,CAAC,MAAM,CAAC;IACnC,8BAA8B,EAAE,aAAa;IAC7C,qBAAqB,EAAE,aAAa;CACrC,CAAC,CAAC;AAIH,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC;IACrC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE;IACpB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;IACnB,0BAA0B;IAC1B,GAAG,EAAE,SAAS,CAAC,QAAQ,EAAE;IACzB,8BAA8B;IAC9B,IAAI,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IAC3B,8BAA8B;IAC9B,IAAI,EAAE,CAAC,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC,QAAQ,EAAE;IAC5C,GAAG,EAAE,CAAC,CAAC,OAAO,EAAE;IAChB,OAAO,EAAE,CAAC,CAAC,OAAO,EAAE;IACpB,GAAG,EAAE,CAAC,CAAC,MAAM,EAAE;IACf,aAAa,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;IACpC,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE;IACpB,OAAO,EAAE,mBAAmB,CAAC,QAAQ,EAAE,CAAC,QAAQ,EAAE;CACnD,CAAC,CAAC;AAIH,MAAM,qBAAqB,GAAG,CAAC,CAAC,MAAM,CAAC;IACrC,EAAE,EAAE,CAAC,CAAC,MAAM,EAAE;CACf,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,wBAAwB,GAAG,qBAAqB,CAAC,MAAM,CAAC;IACnE,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;IACxB,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,qBAAqB,CAAC;CACtC,CAAC,CAAC;AAIH,MAAM,CAAC,MAAM,wBAAwB,GAAG,qBAAqB,CAAC,MAAM,CAAC;IACnE,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;IACxB,KAAK,EAAE,mBAAmB;CAC3B,CAAC,CAAC;AAIH,MAAM,CAAC,MAAM,wBAAwB,GAAG,qBAAqB,CAAC,MAAM,CAAC;IACnE,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;IACxB,KAAK,EAAE,CAAC,CAAC,MAAM,EAAE;CAClB,CAAC,CAAC;AAEH,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,CAAC,KAAK,CAC1C,wBAAwB,EACxB,wBAAwB,EACxB,wBAAwB,CACzB,CAAC;AAEF,MAAM,CAAC,MAAM,wBAAwB,GAAG,CAAC,CAAC,KAAK,CAAC;IAC9C,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC;IACpB,qBAAqB;CACtB,CAAC,CAAC"}
@@ -10,7 +10,7 @@
10
10
  * release. The server (`zero-cache`) must be deployed before clients start
11
11
  * running the new code.
12
12
  */
13
- export declare const PROTOCOL_VERSION = 27;
13
+ export declare const PROTOCOL_VERSION = 29;
14
14
  /**
15
15
  * The minimum server-supported sync protocol version (i.e. the version
16
16
  * declared in the "/sync/v{#}/connect" URL). The contract for
@@ -1 +1 @@
1
- {"version":3,"file":"protocol-version.d.ts","sourceRoot":"","sources":["../../../../zero-protocol/src/protocol-version.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;GAWG;AAsBH,eAAO,MAAM,gBAAgB,KAAK,CAAC;AAEnC;;;;;;;;;GASG;AACH,eAAO,MAAM,kCAAkC,KAAK,CAAC"}
1
+ {"version":3,"file":"protocol-version.d.ts","sourceRoot":"","sources":["../../../../zero-protocol/src/protocol-version.ts"],"names":[],"mappings":"AAEA;;;;;;;;;;;GAWG;AAwBH,eAAO,MAAM,gBAAgB,KAAK,CAAC;AAEnC;;;;;;;;;GASG;AACH,eAAO,MAAM,kCAAkC,KAAK,CAAC"}
@@ -32,7 +32,9 @@ import { assert } from "../../shared/src/asserts.js";
32
32
  // -- version 25 modifies `mutationsResults` to include `del` patches (0.22)
33
33
  // -- version 26 adds inspect/metrics and adds metrics to inspect/query (0.23)
34
34
  // -- version 27 adds inspect/version (0.23)
35
- export const PROTOCOL_VERSION = 27;
35
+ // -- version 28 adds more inspect/metrics (0.23)
36
+ // -- version 29 adds error responses for custom queries (0.23)
37
+ export const PROTOCOL_VERSION = 29;
36
38
  /**
37
39
  * The minimum server-supported sync protocol version (i.e. the version
38
40
  * declared in the "/sync/v{#}/connect" URL). The contract for
@@ -1 +1 @@
1
- {"version":3,"file":"protocol-version.js","sourceRoot":"","sources":["../../../../zero-protocol/src/protocol-version.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAC,MAAM,6BAA6B,CAAC;AAEnD;;;;;;;;;;;GAWG;AACH,WAAW;AACX,yDAAyD;AACzD,yDAAyD;AACzD,wEAAwE;AACxE,mDAAmD;AACnD,6CAA6C;AAC7C,uHAAuH;AACvH,6FAA6F;AAC7F,yEAAyE;AACzE,sFAAsF;AACtF,4FAA4F;AAC5F,8EAA8E;AAC9E,6EAA6E;AAC7E,sDAAsD;AACtD,oIAAoI;AACpI,oFAAoF;AACpF,qDAAqD;AACrD,8DAA8D;AAC9D,4EAA4E;AAC5E,8EAA8E;AAC9E,4CAA4C;AAC5C,MAAM,CAAC,MAAM,gBAAgB,GAAG,EAAE,CAAC;AAEnC;;;;;;;;;GASG;AACH,MAAM,CAAC,MAAM,kCAAkC,GAAG,EAAE,CAAC;AAErD,MAAM,CAAC,kCAAkC,GAAG,gBAAgB,CAAC,CAAC"}
1
+ {"version":3,"file":"protocol-version.js","sourceRoot":"","sources":["../../../../zero-protocol/src/protocol-version.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,MAAM,EAAC,MAAM,6BAA6B,CAAC;AAEnD;;;;;;;;;;;GAWG;AACH,WAAW;AACX,yDAAyD;AACzD,yDAAyD;AACzD,wEAAwE;AACxE,mDAAmD;AACnD,6CAA6C;AAC7C,uHAAuH;AACvH,6FAA6F;AAC7F,yEAAyE;AACzE,sFAAsF;AACtF,4FAA4F;AAC5F,8EAA8E;AAC9E,6EAA6E;AAC7E,sDAAsD;AACtD,oIAAoI;AACpI,oFAAoF;AACpF,qDAAqD;AACrD,8DAA8D;AAC9D,4EAA4E;AAC5E,8EAA8E;AAC9E,4CAA4C;AAC5C,iDAAiD;AACjD,+DAA+D;AAC/D,MAAM,CAAC,MAAM,gBAAgB,GAAG,EAAE,CAAC;AAEnC;;;;;;;;;GASG;AACH,MAAM,CAAC,MAAM,kCAAkC,GAAG,EAAE,CAAC;AAErD,MAAM,CAAC,kCAAkC,GAAG,gBAAgB,CAAC,CAAC"}
@@ -1,4 +1,5 @@
1
1
  export * from './queries/process-queries.ts';
2
+ export * from './process-mutations.ts';
2
3
  export * from './push-processor.ts';
3
4
  export * from './custom.ts';
4
5
  export * from './zql-database.ts';
@@ -1 +1 @@
1
- {"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../../../../zero-server/src/mod.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gCAAgC,CAAC"}
1
+ {"version":3,"file":"mod.d.ts","sourceRoot":"","sources":["../../../../zero-server/src/mod.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gCAAgC,CAAC"}
@@ -1,4 +1,5 @@
1
1
  export * from "./queries/process-queries.js";
2
+ export * from "./process-mutations.js";
2
3
  export * from "./push-processor.js";
3
4
  export * from "./custom.js";
4
5
  export * from "./zql-database.js";
@@ -1 +1 @@
1
- {"version":3,"file":"mod.js","sourceRoot":"","sources":["../../../../zero-server/src/mod.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gCAAgC,CAAC"}
1
+ {"version":3,"file":"mod.js","sourceRoot":"","sources":["../../../../zero-server/src/mod.ts"],"names":[],"mappings":"AAAA,cAAc,8BAA8B,CAAC;AAC7C,cAAc,wBAAwB,CAAC;AACvC,cAAc,qBAAqB,CAAC;AACpC,cAAc,aAAa,CAAC;AAC5B,cAAc,mBAAmB,CAAC;AAClC,cAAc,gCAAgC,CAAC"}
@@ -0,0 +1,46 @@
1
+ import type { ReadonlyJSONValue } from '../../shared/src/json.ts';
2
+ import { pushParamsSchema, type CustomMutation, type MutationResponse, type PushResponse } from '../../zero-protocol/src/push.ts';
3
+ import * as v from '../../shared/src/valita.ts';
4
+ import type { LogLevel } from '@rocicorp/logger';
5
+ import type { CustomMutatorDefs, CustomMutatorImpl } from './custom.ts';
6
+ export interface TransactionProviderHooks {
7
+ updateClientMutationID: () => Promise<{
8
+ lastMutationID: number | bigint;
9
+ }>;
10
+ writeMutationResult: (result: MutationResponse) => Promise<void>;
11
+ }
12
+ export interface TransactionProviderInput {
13
+ upstreamSchema: string;
14
+ clientGroupID: string;
15
+ clientID: string;
16
+ mutationID: number;
17
+ }
18
+ /**
19
+ * Defines the abstract interface for a database that PushProcessor can execute
20
+ * transactions against.
21
+ */
22
+ export interface Database<T> {
23
+ transaction: <R>(callback: (tx: T, transactionHooks: TransactionProviderHooks) => Promise<R>, transactionInput: TransactionProviderInput) => Promise<R>;
24
+ }
25
+ export type ExtractTransactionType<D> = D extends Database<infer T> ? T : never;
26
+ export type Params = v.Infer<typeof pushParamsSchema>;
27
+ export type TransactFn = <D extends Database<ExtractTransactionType<D>>>(dbProvider: D, cb: TransactFnCallback<D>) => Promise<MutationResponse>;
28
+ export type TransactFnCallback<D extends Database<ExtractTransactionType<D>>> = (tx: ExtractTransactionType<D>, mutatorName: string, mutatorArgs: ReadonlyJSONValue) => Promise<void>;
29
+ export type Parsed = {
30
+ transact: TransactFn;
31
+ mutations: CustomMutation[];
32
+ };
33
+ /**
34
+ * Call `cb` for each mutation in the request.
35
+ * The callback is called sequentially for each mutation.
36
+ * If a mutation is out of order, the processing will stop and an error will be returned.
37
+ * If a mutation has already been processed, it will be skipped and the processing will continue.
38
+ * If a mutation receives an application error, it will be skipped, the error will be returned to the client, and processing will continue.
39
+ */
40
+ export declare function mapMutationRequest(cb: (transact: TransactFn, mutation: CustomMutation) => Promise<MutationResponse>, queryString: URLSearchParams | Record<string, string>, body: ReadonlyJSONValue, logLevel?: LogLevel | undefined): Promise<PushResponse>;
41
+ export declare function mapMutationRequest(cb: (transact: TransactFn, mutation: CustomMutation) => Promise<MutationResponse>, request: Request, logLevel?: LogLevel | undefined): Promise<PushResponse>;
42
+ export declare class OutOfOrderMutation extends Error {
43
+ constructor(clientID: string, receivedMutationID: number, lastMutationID: number | bigint);
44
+ }
45
+ export declare function getMutation(mutators: CustomMutatorDefs<any>, name: string): CustomMutatorImpl<any, any>;
46
+ //# sourceMappingURL=process-mutations.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"process-mutations.d.ts","sourceRoot":"","sources":["../../../../zero-server/src/process-mutations.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,187 @@
1
+ import { pushBodySchema, pushParamsSchema, } from "../../zero-protocol/src/push.js";
2
+ import * as v from "../../shared/src/valita.js";
3
+ import { MutationAlreadyProcessedError } from "../../zero-cache/src/services/mutagen/mutagen.js";
4
+ import { createLogContext } from "./logging.js";
5
+ import { assert } from "../../shared/src/asserts.js";
6
+ export async function mapMutationRequest(cb, queryOrQueryString, body, logLevel) {
7
+ if (logLevel === undefined) {
8
+ if (queryOrQueryString instanceof Request && typeof body === 'string') {
9
+ logLevel = body;
10
+ }
11
+ else {
12
+ logLevel = 'info';
13
+ }
14
+ }
15
+ let queryString;
16
+ if (queryOrQueryString instanceof Request) {
17
+ const url = new URL(queryOrQueryString.url);
18
+ queryString = url.searchParams;
19
+ body = await queryOrQueryString.json();
20
+ }
21
+ else {
22
+ queryString = queryOrQueryString;
23
+ }
24
+ const req = v.parse(body, pushBodySchema);
25
+ if (queryString instanceof URLSearchParams) {
26
+ queryString = Object.fromEntries(queryString);
27
+ }
28
+ const queryParams = v.parse(queryString, pushParamsSchema, 'passthrough');
29
+ if (req.pushVersion !== 1) {
30
+ return {
31
+ error: 'unsupportedPushVersion',
32
+ };
33
+ }
34
+ const transactor = new Transactor(req, queryParams, logLevel);
35
+ const responses = [];
36
+ for (const m of req.mutations) {
37
+ assert(m.type === 'custom', 'Expected custom mutation');
38
+ const res = await cb((dbProvider, innerCb) => transactor.transact(dbProvider, m, innerCb), m);
39
+ responses.push(res);
40
+ // We only stop processing if the mutation is out of order.
41
+ // If the mutation has already been processed or if it returns an application error,
42
+ // we continue processing the next mutation.
43
+ if ('error' in res.result && res.result.error === 'oooMutation') {
44
+ break;
45
+ }
46
+ }
47
+ return {
48
+ mutations: responses,
49
+ };
50
+ }
51
+ class Transactor {
52
+ #req;
53
+ #params;
54
+ #lc;
55
+ constructor(req, params, logLevel) {
56
+ this.#req = req;
57
+ this.#params = params;
58
+ this.#lc = createLogContext(logLevel).withContext('PushProcessor');
59
+ }
60
+ transact = async (dbProvider, mutation, cb) => {
61
+ let caughtError = undefined;
62
+ for (;;) {
63
+ try {
64
+ const ret = await this.#transactImpl(dbProvider, mutation, cb, caughtError);
65
+ // The first time through we caught an error.
66
+ // We want to report that error as it was an application
67
+ // level error.
68
+ if (caughtError !== undefined) {
69
+ this.#lc.warn?.(`Mutation ${mutation.id} for client ${mutation.clientID} was retried after an error: ${caughtError}`);
70
+ return makeAppErrorResponse(mutation, caughtError);
71
+ }
72
+ return ret;
73
+ }
74
+ catch (e) {
75
+ if (e instanceof OutOfOrderMutation) {
76
+ this.#lc.error?.(e);
77
+ return {
78
+ id: {
79
+ clientID: mutation.clientID,
80
+ id: mutation.id,
81
+ },
82
+ result: {
83
+ error: 'oooMutation',
84
+ details: e.message,
85
+ },
86
+ };
87
+ }
88
+ if (e instanceof MutationAlreadyProcessedError) {
89
+ this.#lc.warn?.(e);
90
+ return {
91
+ id: {
92
+ clientID: mutation.clientID,
93
+ id: mutation.id,
94
+ },
95
+ result: {
96
+ error: 'alreadyProcessed',
97
+ details: e.message,
98
+ },
99
+ };
100
+ }
101
+ // We threw an error while running in error mode.
102
+ // Re-throw the error and stop processing any further
103
+ // mutations as all subsequent mutations will fail by being
104
+ // out of order.
105
+ if (caughtError !== undefined) {
106
+ throw e;
107
+ }
108
+ caughtError = e;
109
+ this.#lc.error?.(`Unexpected error processing mutation ${mutation.id} for client ${mutation.clientID}`, e);
110
+ }
111
+ }
112
+ };
113
+ #transactImpl(dbProvider, mutation, cb, caughtError) {
114
+ return dbProvider.transaction(async (dbTx, transactionHooks) => {
115
+ await this.#checkAndIncrementLastMutationID(transactionHooks, mutation.clientID, mutation.id);
116
+ if (caughtError === undefined) {
117
+ await cb(dbTx, mutation.name, mutation.args[0]);
118
+ }
119
+ else {
120
+ const appError = makeAppErrorResponse(mutation, caughtError);
121
+ await transactionHooks.writeMutationResult(appError);
122
+ }
123
+ return {
124
+ id: {
125
+ clientID: mutation.clientID,
126
+ id: mutation.id,
127
+ },
128
+ result: {},
129
+ };
130
+ }, {
131
+ upstreamSchema: this.#params.schema,
132
+ clientGroupID: this.#req.clientGroupID,
133
+ clientID: mutation.clientID,
134
+ mutationID: mutation.id,
135
+ });
136
+ }
137
+ async #checkAndIncrementLastMutationID(transactionHooks, clientID, receivedMutationID) {
138
+ const { lastMutationID } = await transactionHooks.updateClientMutationID();
139
+ if (receivedMutationID < lastMutationID) {
140
+ throw new MutationAlreadyProcessedError(clientID, receivedMutationID, lastMutationID);
141
+ }
142
+ else if (receivedMutationID > lastMutationID) {
143
+ throw new OutOfOrderMutation(clientID, receivedMutationID, lastMutationID);
144
+ }
145
+ }
146
+ }
147
+ export class OutOfOrderMutation extends Error {
148
+ constructor(clientID, receivedMutationID, lastMutationID) {
149
+ super(`Client ${clientID} sent mutation ID ${receivedMutationID} but expected ${lastMutationID}`);
150
+ }
151
+ }
152
+ function makeAppErrorResponse(m, e) {
153
+ return {
154
+ id: {
155
+ clientID: m.clientID,
156
+ id: m.id,
157
+ },
158
+ result: {
159
+ error: 'app',
160
+ details: e instanceof Error ? e.message : 'exception was not of type `Error`',
161
+ },
162
+ };
163
+ }
164
+ export function getMutation(
165
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
166
+ mutators, name) {
167
+ let path;
168
+ if (name.includes('|')) {
169
+ path = name.split('|');
170
+ }
171
+ else {
172
+ path = name.split('.');
173
+ }
174
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
175
+ let mutator;
176
+ if (path.length === 1) {
177
+ mutator = mutators[path[0]];
178
+ }
179
+ else {
180
+ const nextMap = mutators[path[0]];
181
+ assert(typeof nextMap === 'object' && nextMap !== undefined, `could not find mutator map for ${name}`);
182
+ mutator = nextMap[path[1]];
183
+ }
184
+ assert(typeof mutator === 'function', () => `could not find mutator ${name}`);
185
+ return mutator;
186
+ }
187
+ //# sourceMappingURL=process-mutations.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"process-mutations.js","sourceRoot":"","sources":["../../../../zero-server/src/process-mutations.ts"],"names":[],"mappings":"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"}
@@ -1,29 +1,8 @@
1
1
  import { type LogLevel } from '@rocicorp/logger';
2
2
  import type { ReadonlyJSONValue } from '../../shared/src/json.ts';
3
- import * as v from '../../shared/src/valita.ts';
4
- import { pushParamsSchema, type MutationResponse, type PushResponse } from '../../zero-protocol/src/push.ts';
3
+ import { type PushResponse } from '../../zero-protocol/src/push.ts';
5
4
  import type { CustomMutatorDefs } from './custom.ts';
6
- export type Params = v.Infer<typeof pushParamsSchema>;
7
- export interface TransactionProviderHooks {
8
- updateClientMutationID: () => Promise<{
9
- lastMutationID: number | bigint;
10
- }>;
11
- writeMutationResult: (result: MutationResponse) => Promise<void>;
12
- }
13
- export interface TransactionProviderInput {
14
- upstreamSchema: string;
15
- clientGroupID: string;
16
- clientID: string;
17
- mutationID: number;
18
- }
19
- /**
20
- * Defines the abstract interface for a database that PushProcessor can execute
21
- * transactions against.
22
- */
23
- export interface Database<T> {
24
- transaction: <R>(callback: (tx: T, transactionHooks: TransactionProviderHooks) => Promise<R>, transactionInput: TransactionProviderInput) => Promise<R>;
25
- }
26
- type ExtractTransactionType<D> = D extends Database<infer T> ? T : never;
5
+ import { type ExtractTransactionType, type Database } from '../../zero-server/src/process-mutations.ts';
27
6
  export declare class PushProcessor<D extends Database<ExtractTransactionType<D>>, MD extends CustomMutatorDefs<ExtractTransactionType<D>>> {
28
7
  #private;
29
8
  constructor(dbProvider: D, logLevel?: LogLevel);
@@ -47,8 +26,4 @@ export declare class PushProcessor<D extends Database<ExtractTransactionType<D>>
47
26
  */
48
27
  process(mutators: MD, request: Request): Promise<PushResponse>;
49
28
  }
50
- export declare class OutOfOrderMutation extends Error {
51
- constructor(clientID: string, receivedMutationID: number, lastMutationID: number | bigint);
52
- }
53
- export {};
54
29
  //# sourceMappingURL=push-processor.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"push-processor.d.ts","sourceRoot":"","sources":["../../../../zero-server/src/push-processor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,KAAK,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAE3D,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,CAAC,MAAM,4BAA4B,CAAC;AAEhD,OAAO,EAEL,gBAAgB,EAEhB,KAAK,gBAAgB,EAErB,KAAK,YAAY,EAClB,MAAM,iCAAiC,CAAC;AAGzC,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,aAAa,CAAC;AAEnD,MAAM,MAAM,MAAM,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,gBAAgB,CAAC,CAAC;AAKtD,MAAM,WAAW,wBAAwB;IACvC,sBAAsB,EAAE,MAAM,OAAO,CAAC;QAAC,cAAc,EAAE,MAAM,GAAG,MAAM,CAAA;KAAC,CAAC,CAAC;IACzE,mBAAmB,EAAE,CAAC,MAAM,EAAE,gBAAgB,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CAClE;AAED,MAAM,WAAW,wBAAwB;IACvC,cAAc,EAAE,MAAM,CAAC;IACvB,aAAa,EAAE,MAAM,CAAC;IACtB,QAAQ,EAAE,MAAM,CAAC;IACjB,UAAU,EAAE,MAAM,CAAC;CACpB;AAED;;;GAGG;AACH,MAAM,WAAW,QAAQ,CAAC,CAAC;IACzB,WAAW,EAAE,CAAC,CAAC,EACb,QAAQ,EAAE,CAAC,EAAE,EAAE,CAAC,EAAE,gBAAgB,EAAE,wBAAwB,KAAK,OAAO,CAAC,CAAC,CAAC,EAC3E,gBAAgB,EAAE,wBAAwB,KACvC,OAAO,CAAC,CAAC,CAAC,CAAC;CACjB;AAED,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;AAEzE,qBAAa,aAAa,CACxB,CAAC,SAAS,QAAQ,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,EAC7C,EAAE,SAAS,iBAAiB,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC;;gBAK3C,UAAU,EAAE,CAAC,EAAE,QAAQ,GAAE,QAAiB;IAKtD;;;;;;;;;;OAUG;IACG,OAAO,CACX,QAAQ,EAAE,EAAE,EACZ,WAAW,EAAE,eAAe,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACrD,IAAI,EAAE,iBAAiB,GACtB,OAAO,CAAC,YAAY,CAAC;IAExB;;;;;OAKG;IACG,OAAO,CAAC,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,YAAY,CAAC;CAgOrE;AAED,qBAAa,kBAAmB,SAAQ,KAAK;gBAEzC,QAAQ,EAAE,MAAM,EAChB,kBAAkB,EAAE,MAAM,EAC1B,cAAc,EAAE,MAAM,GAAG,MAAM;CAMlC"}
1
+ {"version":3,"file":"push-processor.d.ts","sourceRoot":"","sources":["../../../../zero-server/src/push-processor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,QAAQ,EAAC,MAAM,kBAAkB,CAAC;AAE/C,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,0BAA0B,CAAC;AAChE,OAAO,EAGL,KAAK,YAAY,EAClB,MAAM,iCAAiC,CAAC;AAEzC,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,aAAa,CAAC;AACnD,OAAO,EACL,KAAK,sBAAsB,EAC3B,KAAK,QAAQ,EAGd,MAAM,4CAA4C,CAAC;AAGpD,qBAAa,aAAa,CACxB,CAAC,SAAS,QAAQ,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,EAC7C,EAAE,SAAS,iBAAiB,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC;;gBAK3C,UAAU,EAAE,CAAC,EAAE,QAAQ,GAAE,QAAiB;IAKtD;;;;;;;;;;OAUG;IACH,OAAO,CACL,QAAQ,EAAE,EAAE,EACZ,WAAW,EAAE,eAAe,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EACrD,IAAI,EAAE,iBAAiB,GACtB,OAAO,CAAC,YAAY,CAAC;IAExB;;;;;OAKG;IACH,OAAO,CAAC,QAAQ,EAAE,EAAE,EAAE,OAAO,EAAE,OAAO,GAAG,OAAO,CAAC,YAAY,CAAC;CA6D/D"}