@rocicorp/zero 0.0.202410041744 → 0.2.2024101100

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 (383) hide show
  1. package/out/btree/src/mod.d.ts +2 -0
  2. package/out/btree/src/mod.d.ts.map +1 -0
  3. package/out/btree/src/mod.js +2 -0
  4. package/out/btree/src/mod.js.map +1 -0
  5. package/out/datadog/src/mod.js +2 -0
  6. package/out/datadog/src/mod.js.map +1 -0
  7. package/out/react.js +9 -3
  8. package/out/react.js.map +3 -3
  9. package/out/replicache/src/btree/node.d.ts.map +1 -1
  10. package/out/replicache/src/config.d.ts.map +1 -1
  11. package/out/replicache/src/connection-loop.d.ts.map +1 -1
  12. package/out/replicache/src/cookies.d.ts.map +1 -1
  13. package/out/replicache/src/dag/gc.d.ts.map +1 -1
  14. package/out/replicache/src/dag/lazy-store.d.ts.map +1 -1
  15. package/out/replicache/src/db/scan.d.ts.map +1 -1
  16. package/out/replicache/src/frozen-json.d.ts.map +1 -1
  17. package/out/replicache/src/get-default-puller.d.ts.map +1 -1
  18. package/out/replicache/src/hash.d.ts.map +1 -1
  19. package/out/replicache/src/http-request-info.d.ts.map +1 -1
  20. package/out/replicache/src/index-defs.d.ts.map +1 -1
  21. package/out/replicache/src/kv/idb-store.d.ts.map +1 -1
  22. package/out/replicache/src/kv/store.d.ts.map +1 -1
  23. package/out/replicache/src/kv/write-impl-base.d.ts.map +1 -1
  24. package/out/replicache/src/mod.d.ts.map +1 -1
  25. package/out/replicache/src/mutation-recovery.d.ts.map +1 -1
  26. package/out/replicache/src/patch-operation.d.ts.map +1 -1
  27. package/out/replicache/src/pending-mutations.d.ts.map +1 -1
  28. package/out/replicache/src/persist/client-groups.d.ts.map +1 -1
  29. package/out/replicache/src/persist/clients.d.ts.map +1 -1
  30. package/out/replicache/src/puller.d.ts.map +1 -1
  31. package/out/replicache/src/replicache-impl.d.ts +0 -1
  32. package/out/replicache/src/replicache-impl.d.ts.map +1 -1
  33. package/out/replicache/src/replicache.d.ts.map +1 -1
  34. package/out/replicache/src/scan-iterator.d.ts.map +1 -1
  35. package/out/replicache/src/subscriptions.d.ts +1 -1
  36. package/out/replicache/src/subscriptions.d.ts.map +1 -1
  37. package/out/replicache/src/sync/ids.d.ts.map +1 -1
  38. package/out/replicache/src/sync/patch.d.ts.map +1 -1
  39. package/out/replicache/src/sync/pull.d.ts.map +1 -1
  40. package/out/replicache/src/sync/push.d.ts.map +1 -1
  41. package/out/replicache/src/sync/request-id.d.ts.map +1 -1
  42. package/out/replicache/src/transactions.d.ts.map +1 -1
  43. package/out/replicache/src/types.d.ts.map +1 -1
  44. package/out/shared/src/browser-env.d.ts +4 -2
  45. package/out/shared/src/browser-env.d.ts.map +1 -1
  46. package/out/shared/src/h64-with-reverse.d.ts +6 -0
  47. package/out/shared/src/h64-with-reverse.d.ts.map +1 -0
  48. package/out/shared/src/h64-with-reverse.js +13 -0
  49. package/out/shared/src/h64-with-reverse.js.map +1 -0
  50. package/out/shared/src/reverse-string.d.ts +2 -0
  51. package/out/shared/src/reverse-string.d.ts.map +1 -0
  52. package/out/shared/src/reverse-string.js +8 -0
  53. package/out/shared/src/reverse-string.js.map +1 -0
  54. package/out/zero/src/cli.js +0 -0
  55. package/out/zero/src/react.d.ts +1 -1
  56. package/out/zero/src/react.d.ts.map +1 -1
  57. package/out/zero/src/server/change-streamer.d.ts.map +1 -1
  58. package/out/zero/src/server/change-streamer.js.map +1 -1
  59. package/out/zero/src/server/main.d.ts.map +1 -1
  60. package/out/zero/src/server/main.js.map +1 -1
  61. package/out/zero/src/server/replicator.d.ts.map +1 -1
  62. package/out/zero/src/server/replicator.js.map +1 -1
  63. package/out/zero/src/server/syncer.d.ts.map +1 -1
  64. package/out/zero/src/server/syncer.js.map +1 -1
  65. package/out/zero/src/zero.d.ts +1 -1
  66. package/out/zero/src/zero.d.ts.map +1 -1
  67. package/out/zero-cache/src/config/zero-config.d.ts +46 -21
  68. package/out/zero-cache/src/config/zero-config.d.ts.map +1 -1
  69. package/out/zero-cache/src/config/zero-config.js +38 -20
  70. package/out/zero-cache/src/config/zero-config.js.map +1 -1
  71. package/out/zero-cache/src/db/lite-tables.d.ts.map +1 -1
  72. package/out/zero-cache/src/db/lite-tables.js.map +1 -1
  73. package/out/zero-cache/src/db/migration-lite.d.ts.map +1 -1
  74. package/out/zero-cache/src/db/migration-lite.js.map +1 -1
  75. package/out/zero-cache/src/db/migration.d.ts.map +1 -1
  76. package/out/zero-cache/src/db/migration.js.map +1 -1
  77. package/out/zero-cache/src/db/statements.d.ts +2 -0
  78. package/out/zero-cache/src/db/statements.d.ts.map +1 -1
  79. package/out/zero-cache/src/db/statements.js +6 -0
  80. package/out/zero-cache/src/db/statements.js.map +1 -1
  81. package/out/zero-cache/src/db/transaction-pool.js.map +1 -1
  82. package/out/zero-cache/src/server/change-streamer.d.ts.map +1 -1
  83. package/out/zero-cache/src/server/change-streamer.js +5 -5
  84. package/out/zero-cache/src/server/change-streamer.js.map +1 -1
  85. package/out/zero-cache/src/server/life-cycle.d.ts +38 -0
  86. package/out/zero-cache/src/server/life-cycle.d.ts.map +1 -0
  87. package/out/zero-cache/src/server/life-cycle.js +125 -0
  88. package/out/zero-cache/src/server/life-cycle.js.map +1 -0
  89. package/out/zero-cache/src/server/logging.d.ts.map +1 -1
  90. package/out/zero-cache/src/server/logging.js +43 -4
  91. package/out/zero-cache/src/server/logging.js.map +1 -1
  92. package/out/zero-cache/src/server/main.js +18 -16
  93. package/out/zero-cache/src/server/main.js.map +1 -1
  94. package/out/zero-cache/src/server/replicator.d.ts.map +1 -1
  95. package/out/zero-cache/src/server/replicator.js +12 -11
  96. package/out/zero-cache/src/server/replicator.js.map +1 -1
  97. package/out/zero-cache/src/server/syncer.d.ts.map +1 -1
  98. package/out/zero-cache/src/server/syncer.js +9 -8
  99. package/out/zero-cache/src/server/syncer.js.map +1 -1
  100. package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts +3 -3
  101. package/out/zero-cache/src/services/change-streamer/change-streamer-http.d.ts.map +1 -1
  102. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js +11 -10
  103. package/out/zero-cache/src/services/change-streamer/change-streamer-http.js.map +1 -1
  104. package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts +2 -2
  105. package/out/zero-cache/src/services/change-streamer/change-streamer-service.d.ts.map +1 -1
  106. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js +4 -4
  107. package/out/zero-cache/src/services/change-streamer/change-streamer-service.js.map +1 -1
  108. package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts +2 -2
  109. package/out/zero-cache/src/services/change-streamer/change-streamer.d.ts.map +1 -1
  110. package/out/zero-cache/src/services/change-streamer/pg/change-source.d.ts.map +1 -1
  111. package/out/zero-cache/src/services/change-streamer/pg/change-source.js +10 -5
  112. package/out/zero-cache/src/services/change-streamer/pg/change-source.js.map +1 -1
  113. package/out/zero-cache/src/services/change-streamer/pg/initial-sync.d.ts.map +1 -1
  114. package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js +6 -6
  115. package/out/zero-cache/src/services/change-streamer/pg/initial-sync.js.map +1 -1
  116. package/out/zero-cache/src/services/change-streamer/pg/lsn.d.ts +1 -1
  117. package/out/zero-cache/src/services/change-streamer/pg/lsn.d.ts.map +1 -1
  118. package/out/zero-cache/src/services/change-streamer/pg/lsn.js +1 -1
  119. package/out/zero-cache/src/services/change-streamer/pg/lsn.js.map +1 -1
  120. package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts +1 -1
  121. package/out/zero-cache/src/services/change-streamer/pg/schema/create.d.ts.map +1 -1
  122. package/out/zero-cache/src/services/change-streamer/pg/schema/create.js +1 -1
  123. package/out/zero-cache/src/services/change-streamer/pg/schema/create.js.map +1 -1
  124. package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts +1 -1
  125. package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.d.ts.map +1 -1
  126. package/out/zero-cache/src/services/change-streamer/pg/schema/ddl.js.map +1 -1
  127. package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts +3 -2
  128. package/out/zero-cache/src/services/change-streamer/pg/schema/lite.d.ts.map +1 -1
  129. package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js +20 -68
  130. package/out/zero-cache/src/services/change-streamer/pg/schema/lite.js.map +1 -1
  131. package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts +1 -1
  132. package/out/zero-cache/src/services/change-streamer/pg/schema/published.d.ts.map +1 -1
  133. package/out/zero-cache/src/services/change-streamer/pg/schema/published.js.map +1 -1
  134. package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts +1 -1
  135. package/out/zero-cache/src/services/change-streamer/pg/schema/zero.d.ts.map +1 -1
  136. package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js +1 -1
  137. package/out/zero-cache/src/services/change-streamer/pg/sync-schema.js.map +1 -1
  138. package/out/zero-cache/src/services/change-streamer/schema/change.d.ts +2 -2
  139. package/out/zero-cache/src/services/change-streamer/schema/change.d.ts.map +1 -1
  140. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts +1 -1
  141. package/out/zero-cache/src/services/change-streamer/schema/tables.d.ts.map +1 -1
  142. package/out/zero-cache/src/services/change-streamer/schema/tables.js.map +1 -1
  143. package/out/zero-cache/src/services/change-streamer/storer.d.ts +1 -1
  144. package/out/zero-cache/src/services/change-streamer/storer.d.ts.map +1 -1
  145. package/out/zero-cache/src/services/change-streamer/storer.js +1 -1
  146. package/out/zero-cache/src/services/change-streamer/storer.js.map +1 -1
  147. package/out/zero-cache/src/services/change-streamer/subscriber.d.ts +1 -1
  148. package/out/zero-cache/src/services/change-streamer/subscriber.d.ts.map +1 -1
  149. package/out/zero-cache/src/services/change-streamer/subscriber.js +1 -1
  150. package/out/zero-cache/src/services/change-streamer/subscriber.js.map +1 -1
  151. package/out/zero-cache/src/services/dispatcher/connect-params.d.ts +1 -0
  152. package/out/zero-cache/src/services/dispatcher/connect-params.d.ts.map +1 -1
  153. package/out/zero-cache/src/services/dispatcher/connect-params.js +3 -1
  154. package/out/zero-cache/src/services/dispatcher/connect-params.js.map +1 -1
  155. package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts +1 -1
  156. package/out/zero-cache/src/services/dispatcher/dispatcher.d.ts.map +1 -1
  157. package/out/zero-cache/src/services/dispatcher/dispatcher.js +2 -6
  158. package/out/zero-cache/src/services/dispatcher/dispatcher.js.map +1 -1
  159. package/out/zero-cache/src/services/limiter/sliding-window-limiter.d.ts.map +1 -1
  160. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js +15 -8
  161. package/out/zero-cache/src/services/limiter/sliding-window-limiter.js.map +1 -1
  162. package/out/zero-cache/src/services/mutagen/mutagen.d.ts +8 -4
  163. package/out/zero-cache/src/services/mutagen/mutagen.d.ts.map +1 -1
  164. package/out/zero-cache/src/services/mutagen/mutagen.js +25 -16
  165. package/out/zero-cache/src/services/mutagen/mutagen.js.map +1 -1
  166. package/out/zero-cache/src/services/mutagen/write-authorizer.d.ts.map +1 -1
  167. package/out/zero-cache/src/services/mutagen/write-authorizer.js +1 -1
  168. package/out/zero-cache/src/services/mutagen/write-authorizer.js.map +1 -1
  169. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts +8 -7
  170. package/out/zero-cache/src/services/replicator/incremental-sync.d.ts.map +1 -1
  171. package/out/zero-cache/src/services/replicator/incremental-sync.js +88 -57
  172. package/out/zero-cache/src/services/replicator/incremental-sync.js.map +1 -1
  173. package/out/zero-cache/src/services/replicator/replicator.d.ts +4 -13
  174. package/out/zero-cache/src/services/replicator/replicator.d.ts.map +1 -1
  175. package/out/zero-cache/src/services/replicator/replicator.js +2 -2
  176. package/out/zero-cache/src/services/replicator/replicator.js.map +1 -1
  177. package/out/zero-cache/src/services/replicator/schema/change-log.d.ts +7 -7
  178. package/out/zero-cache/src/services/replicator/schema/change-log.d.ts.map +1 -1
  179. package/out/zero-cache/src/services/replicator/schema/change-log.js +3 -3
  180. package/out/zero-cache/src/services/replicator/schema/change-log.js.map +1 -1
  181. package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts +1 -1
  182. package/out/zero-cache/src/services/replicator/schema/replication-state.d.ts.map +1 -1
  183. package/out/zero-cache/src/services/replicator/schema/replication-state.js +1 -1
  184. package/out/zero-cache/src/services/replicator/schema/replication-state.js.map +1 -1
  185. package/out/zero-cache/src/services/runner.d.ts +2 -5
  186. package/out/zero-cache/src/services/runner.d.ts.map +1 -1
  187. package/out/zero-cache/src/services/runner.js +4 -22
  188. package/out/zero-cache/src/services/runner.js.map +1 -1
  189. package/out/zero-cache/src/services/running-state.d.ts.map +1 -1
  190. package/out/zero-cache/src/services/running-state.js +3 -3
  191. package/out/zero-cache/src/services/running-state.js.map +1 -1
  192. package/out/zero-cache/src/services/service.d.ts +8 -0
  193. package/out/zero-cache/src/services/service.d.ts.map +1 -1
  194. package/out/zero-cache/src/services/view-syncer/client-handler.d.ts +3 -2
  195. package/out/zero-cache/src/services/view-syncer/client-handler.d.ts.map +1 -1
  196. package/out/zero-cache/src/services/view-syncer/client-handler.js +14 -3
  197. package/out/zero-cache/src/services/view-syncer/client-handler.js.map +1 -1
  198. package/out/zero-cache/src/services/view-syncer/cvr-store.d.ts.map +1 -1
  199. package/out/zero-cache/src/services/view-syncer/cvr-store.js +1 -1
  200. package/out/zero-cache/src/services/view-syncer/cvr-store.js.map +1 -1
  201. package/out/zero-cache/src/services/view-syncer/cvr.d.ts +1 -1
  202. package/out/zero-cache/src/services/view-syncer/cvr.d.ts.map +1 -1
  203. package/out/zero-cache/src/services/view-syncer/cvr.js +1 -1
  204. package/out/zero-cache/src/services/view-syncer/cvr.js.map +1 -1
  205. package/out/zero-cache/src/services/view-syncer/database-storage.d.ts.map +1 -1
  206. package/out/zero-cache/src/services/view-syncer/database-storage.js.map +1 -1
  207. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts +12 -9
  208. package/out/zero-cache/src/services/view-syncer/pipeline-driver.d.ts.map +1 -1
  209. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js +33 -23
  210. package/out/zero-cache/src/services/view-syncer/pipeline-driver.js.map +1 -1
  211. package/out/zero-cache/src/services/view-syncer/schema/cvr.js +1 -1
  212. package/out/zero-cache/src/services/view-syncer/schema/cvr.js.map +1 -1
  213. package/out/zero-cache/src/services/view-syncer/schema/types.d.ts.map +1 -1
  214. package/out/zero-cache/src/services/view-syncer/schema/types.js.map +1 -1
  215. package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts +30 -14
  216. package/out/zero-cache/src/services/view-syncer/snapshotter.d.ts.map +1 -1
  217. package/out/zero-cache/src/services/view-syncer/snapshotter.js +38 -37
  218. package/out/zero-cache/src/services/view-syncer/snapshotter.js.map +1 -1
  219. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts +3 -0
  220. package/out/zero-cache/src/services/view-syncer/view-syncer.d.ts.map +1 -1
  221. package/out/zero-cache/src/services/view-syncer/view-syncer.js +28 -44
  222. package/out/zero-cache/src/services/view-syncer/view-syncer.js.map +1 -1
  223. package/out/zero-cache/src/types/bigint-json.d.ts.map +1 -1
  224. package/out/zero-cache/src/types/bigint-json.js.map +1 -1
  225. package/out/zero-cache/src/types/error-for-client.d.ts.map +1 -1
  226. package/out/zero-cache/src/types/lexi-version.js.map +1 -1
  227. package/out/zero-cache/src/types/lite.d.ts +30 -8
  228. package/out/zero-cache/src/types/lite.d.ts.map +1 -1
  229. package/out/zero-cache/src/types/lite.js +114 -15
  230. package/out/zero-cache/src/types/lite.js.map +1 -1
  231. package/out/zero-cache/src/types/pg.d.ts +21 -0
  232. package/out/zero-cache/src/types/pg.d.ts.map +1 -1
  233. package/out/zero-cache/src/types/pg.js +49 -6
  234. package/out/zero-cache/src/types/pg.js.map +1 -1
  235. package/out/zero-cache/src/types/processes.d.ts +1 -1
  236. package/out/zero-cache/src/types/processes.d.ts.map +1 -1
  237. package/out/zero-cache/src/types/processes.js +8 -14
  238. package/out/zero-cache/src/types/processes.js.map +1 -1
  239. package/out/zero-cache/src/types/row-key.d.ts +4 -1
  240. package/out/zero-cache/src/types/row-key.d.ts.map +1 -1
  241. package/out/zero-cache/src/types/row-key.js +5 -14
  242. package/out/zero-cache/src/types/row-key.js.map +1 -1
  243. package/out/zero-cache/src/types/schema-versions.d.ts +8 -0
  244. package/out/zero-cache/src/types/schema-versions.d.ts.map +1 -0
  245. package/out/zero-cache/src/types/schema-versions.js +21 -0
  246. package/out/zero-cache/src/types/schema-versions.js.map +1 -0
  247. package/out/zero-cache/src/types/streams.d.ts +2 -2
  248. package/out/zero-cache/src/types/streams.d.ts.map +1 -1
  249. package/out/zero-cache/src/types/streams.js +36 -26
  250. package/out/zero-cache/src/types/streams.js.map +1 -1
  251. package/out/zero-cache/src/types/timeout.js.map +1 -1
  252. package/out/zero-cache/src/workers/connection.d.ts.map +1 -1
  253. package/out/zero-cache/src/workers/connection.js +6 -6
  254. package/out/zero-cache/src/workers/connection.js.map +1 -1
  255. package/out/zero-cache/src/workers/replicator.d.ts +4 -4
  256. package/out/zero-cache/src/workers/replicator.d.ts.map +1 -1
  257. package/out/zero-cache/src/workers/replicator.js +3 -31
  258. package/out/zero-cache/src/workers/replicator.js.map +1 -1
  259. package/out/zero-cache/src/workers/syncer.d.ts +12 -4
  260. package/out/zero-cache/src/workers/syncer.d.ts.map +1 -1
  261. package/out/zero-cache/src/workers/syncer.js +34 -2
  262. package/out/zero-cache/src/workers/syncer.js.map +1 -1
  263. package/out/zero-client/src/client/context.d.ts +4 -4
  264. package/out/zero-client/src/client/context.d.ts.map +1 -1
  265. package/out/zero-client/src/client/crud.d.ts +20 -18
  266. package/out/zero-client/src/client/crud.d.ts.map +1 -1
  267. package/out/zero-client/src/client/keys.d.ts +2 -2
  268. package/out/zero-client/src/client/keys.d.ts.map +1 -1
  269. package/out/zero-client/src/client/log-options.d.ts +1 -1
  270. package/out/zero-client/src/client/log-options.d.ts.map +1 -1
  271. package/out/zero-client/src/client/make-id-from-primary-key.d.ts +5 -0
  272. package/out/zero-client/src/client/make-id-from-primary-key.d.ts.map +1 -0
  273. package/out/zero-client/src/client/metrics.d.ts.map +1 -1
  274. package/out/zero-client/src/client/options.d.ts +1 -1
  275. package/out/zero-client/src/client/options.d.ts.map +1 -1
  276. package/out/zero-client/src/client/query-manager.d.ts +5 -3
  277. package/out/zero-client/src/client/query-manager.d.ts.map +1 -1
  278. package/out/zero-client/src/client/replicache-types.d.ts +1 -1
  279. package/out/zero-client/src/client/replicache-types.d.ts.map +1 -1
  280. package/out/zero-client/src/client/server-error.d.ts.map +1 -1
  281. package/out/zero-client/src/client/server-option.d.ts.map +1 -1
  282. package/out/zero-client/src/client/zero-poke-handler.d.ts +5 -4
  283. package/out/zero-client/src/client/zero-poke-handler.d.ts.map +1 -1
  284. package/out/zero-client/src/client/zero.d.ts +3 -3
  285. package/out/zero-client/src/client/zero.d.ts.map +1 -1
  286. package/out/zero-client/src/mod.d.ts +2 -2
  287. package/out/zero-client/src/mod.d.ts.map +1 -1
  288. package/out/zero-client/src/util/socket.d.ts.map +1 -1
  289. package/out/zero-protocol/src/ast.d.ts.map +1 -1
  290. package/out/zero-protocol/src/ast.js +5 -8
  291. package/out/zero-protocol/src/ast.js.map +1 -1
  292. package/out/zero-protocol/src/change-desired-queries.d.ts.map +1 -1
  293. package/out/zero-protocol/src/change-desired-queries.js.map +1 -1
  294. package/out/zero-protocol/src/clients-patch.d.ts.map +1 -1
  295. package/out/zero-protocol/src/clients-patch.js.map +1 -1
  296. package/out/zero-protocol/src/connect.d.ts.map +1 -1
  297. package/out/zero-protocol/src/connect.js.map +1 -1
  298. package/out/zero-protocol/src/delete-clients.d.ts.map +1 -1
  299. package/out/zero-protocol/src/delete-clients.js.map +1 -1
  300. package/out/zero-protocol/src/down.d.ts +9 -5
  301. package/out/zero-protocol/src/down.d.ts.map +1 -1
  302. package/out/zero-protocol/src/down.js.map +1 -1
  303. package/out/zero-protocol/src/entities-patch.d.ts +15 -15
  304. package/out/zero-protocol/src/entities-patch.d.ts.map +1 -1
  305. package/out/zero-protocol/src/entities-patch.js +5 -4
  306. package/out/zero-protocol/src/entities-patch.js.map +1 -1
  307. package/out/zero-protocol/src/error.d.ts +2 -1
  308. package/out/zero-protocol/src/error.d.ts.map +1 -1
  309. package/out/zero-protocol/src/error.js +2 -1
  310. package/out/zero-protocol/src/error.js.map +1 -1
  311. package/out/zero-protocol/src/ping.d.ts.map +1 -1
  312. package/out/zero-protocol/src/ping.js.map +1 -1
  313. package/out/zero-protocol/src/poke.d.ts +18 -10
  314. package/out/zero-protocol/src/poke.d.ts.map +1 -1
  315. package/out/zero-protocol/src/poke.js +4 -0
  316. package/out/zero-protocol/src/poke.js.map +1 -1
  317. package/out/zero-protocol/src/pong.d.ts.map +1 -1
  318. package/out/zero-protocol/src/pong.js.map +1 -1
  319. package/out/zero-protocol/src/primary-key.d.ts +9 -0
  320. package/out/zero-protocol/src/primary-key.d.ts.map +1 -0
  321. package/out/zero-protocol/src/primary-key.js +7 -0
  322. package/out/zero-protocol/src/primary-key.js.map +1 -0
  323. package/out/zero-protocol/src/pull.d.ts.map +1 -1
  324. package/out/zero-protocol/src/pull.js.map +1 -1
  325. package/out/zero-protocol/src/push.d.ts +53 -53
  326. package/out/zero-protocol/src/push.d.ts.map +1 -1
  327. package/out/zero-protocol/src/push.js +5 -5
  328. package/out/zero-protocol/src/push.js.map +1 -1
  329. package/out/zero-protocol/src/queries-patch.d.ts.map +1 -1
  330. package/out/zero-protocol/src/queries-patch.js.map +1 -1
  331. package/out/zero-protocol/src/up.d.ts +8 -8
  332. package/out/zero-protocol/src/up.d.ts.map +1 -1
  333. package/out/zero-protocol/src/up.js.map +1 -1
  334. package/out/zero-protocol/src/version.d.ts.map +1 -1
  335. package/out/zero-protocol/src/version.js.map +1 -1
  336. package/out/zero-react/src/use-query.d.ts +1 -1
  337. package/out/zero-react/src/use-query.d.ts.map +1 -1
  338. package/out/zero-react/src/use-zero.d.ts +1 -1
  339. package/out/zero-react/src/use-zero.d.ts.map +1 -1
  340. package/out/zero.js +294 -124
  341. package/out/zero.js.map +4 -4
  342. package/out/zql/src/zql/ast/ast.js.map +1 -1
  343. package/out/zql/src/zql/builder/builder.d.ts.map +1 -1
  344. package/out/zql/src/zql/builder/builder.js.map +1 -1
  345. package/out/zql/src/zql/builder/filter.js.map +1 -1
  346. package/out/zql/src/zql/builder/like.js.map +1 -1
  347. package/out/zql/src/zql/ivm/array-view.d.ts.map +1 -1
  348. package/out/zql/src/zql/ivm/data.d.ts.map +1 -1
  349. package/out/zql/src/zql/ivm/data.js +1 -1
  350. package/out/zql/src/zql/ivm/data.js.map +1 -1
  351. package/out/zql/src/zql/ivm/filter.js.map +1 -1
  352. package/out/zql/src/zql/ivm/join.js.map +1 -1
  353. package/out/zql/src/zql/ivm/memory-source.d.ts.map +1 -1
  354. package/out/zql/src/zql/ivm/memory-source.js +1 -1
  355. package/out/zql/src/zql/ivm/memory-source.js.map +1 -1
  356. package/out/zql/src/zql/ivm/memory-storage.d.ts.map +1 -1
  357. package/out/zql/src/zql/ivm/operator.d.ts.map +1 -1
  358. package/out/zql/src/zql/ivm/schema.d.ts +1 -1
  359. package/out/zql/src/zql/ivm/schema.d.ts.map +1 -1
  360. package/out/zql/src/zql/ivm/schema.js.map +1 -1
  361. package/out/zql/src/zql/ivm/skip.js.map +1 -1
  362. package/out/zql/src/zql/ivm/take.js.map +1 -1
  363. package/out/zql/src/zql/query/query-impl.d.ts +4 -1
  364. package/out/zql/src/zql/query/query-impl.d.ts.map +1 -1
  365. package/out/zql/src/zql/query/query.d.ts +2 -1
  366. package/out/zql/src/zql/query/query.d.ts.map +1 -1
  367. package/out/zql/src/zql/query/typed-view.d.ts.map +1 -1
  368. package/out/zqlite/src/db.js +1 -1
  369. package/out/zqlite/src/db.js.map +1 -1
  370. package/out/zqlite/src/internal/statement-cache.js.map +1 -1
  371. package/out/zqlite/src/table-source.d.ts +1 -1
  372. package/out/zqlite/src/table-source.d.ts.map +1 -1
  373. package/out/zqlite/src/table-source.js +36 -33
  374. package/out/zqlite/src/table-source.js.map +1 -1
  375. package/package.json +10 -6
  376. package/out/zero-cache/src/services/replicator/checkpointer.d.ts +0 -79
  377. package/out/zero-cache/src/services/replicator/checkpointer.d.ts.map +0 -1
  378. package/out/zero-cache/src/services/replicator/checkpointer.js +0 -124
  379. package/out/zero-cache/src/services/replicator/checkpointer.js.map +0 -1
  380. package/out/zero-protocol/src/entity.d.ts +0 -9
  381. package/out/zero-protocol/src/entity.d.ts.map +0 -1
  382. package/out/zero-protocol/src/entity.js +0 -8
  383. package/out/zero-protocol/src/entity.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"transaction-pool.js","sourceRoot":"","sources":["../../../../../zero-cache/src/db/transaction-pool.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"transaction-pool.js","sourceRoot":"","sources":["../../../../../zero-cache/src/db/transaction-pool.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"change-streamer.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/change-streamer.ts"],"names":[],"mappings":"AAOA,OAAO,EAGL,KAAK,MAAM,EACZ,MAAM,uBAAuB,CAAC;AAK/B,wBAA8B,SAAS,CAAC,MAAM,EAAE,MAAM,iBAqCrD"}
1
+ {"version":3,"file":"change-streamer.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/change-streamer.ts"],"names":[],"mappings":"AAMA,OAAO,EAGL,KAAK,MAAM,EACZ,MAAM,uBAAuB,CAAC;AAM/B,wBAA8B,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAqCrE"}
@@ -3,28 +3,28 @@ import { getZeroConfig } from '../config/zero-config.js';
3
3
  import { ChangeStreamerHttpServer } from '../services/change-streamer/change-streamer-http.js';
4
4
  import { initializeStreamer } from '../services/change-streamer/change-streamer-service.js';
5
5
  import { initializeChangeSource } from '../services/change-streamer/pg/change-source.js';
6
- import { runOrExit } from '../services/runner.js';
7
6
  import { pgClient } from '../types/pg.js';
8
7
  import { parentWorker, singleProcessMode, } from '../types/processes.js';
8
+ import { exitAfter, runUntilKilled } from './life-cycle.js';
9
9
  import { createLogContext } from './logging.js';
10
10
  const MAX_CHANGE_DB_CONNECTIONS = 5;
11
11
  export default async function runWorker(parent) {
12
12
  const config = await getZeroConfig();
13
13
  const lc = createLogContext(config.log, { worker: 'change-streamer' });
14
14
  // Kick off DB connection warmup in the background.
15
- const changeDB = pgClient(lc, config.changeDbUri, {
15
+ const changeDB = pgClient(lc, config.changeDBConnStr, {
16
16
  max: MAX_CHANGE_DB_CONNECTIONS,
17
17
  });
18
18
  void Promise.allSettled(Array.from({ length: MAX_CHANGE_DB_CONNECTIONS }, () => changeDB `SELECT 1`.simple().execute()));
19
19
  // Note: This performs initial sync of the replica if necessary.
20
- const { changeSource, replicationConfig } = await initializeChangeSource(lc, config.upstreamUri, config.shard, config.replicaDbFile);
20
+ const { changeSource, replicationConfig } = await initializeChangeSource(lc, config.upstreamDBConnStr, config.shard, config.replicaDBFile);
21
21
  const changeStreamer = await initializeStreamer(lc, changeDB, changeSource, replicationConfig);
22
22
  const changeStreamerWebServer = new ChangeStreamerHttpServer(lc, changeStreamer);
23
- void runOrExit(lc, changeStreamer, changeStreamerWebServer);
24
23
  parent.send(['ready', { ready: true }]);
24
+ return runUntilKilled(lc, parent, changeStreamer, changeStreamerWebServer);
25
25
  }
26
26
  // fork()
27
27
  if (!singleProcessMode()) {
28
- void runWorker(must(parentWorker));
28
+ void exitAfter(() => runWorker(must(parentWorker)));
29
29
  }
30
30
  //# sourceMappingURL=change-streamer.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"change-streamer.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/change-streamer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAC,aAAa,EAAC,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAC,wBAAwB,EAAC,MAAM,qDAAqD,CAAC;AAC7F,OAAO,EAAC,kBAAkB,EAAC,MAAM,wDAAwD,CAAC;AAC1F,OAAO,EAAC,sBAAsB,EAAC,MAAM,iDAAiD,CAAC;AACvF,OAAO,EAAC,SAAS,EAAC,MAAM,uBAAuB,CAAC;AAChD,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AACxC,OAAO,EACL,YAAY,EACZ,iBAAiB,GAElB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAC,gBAAgB,EAAC,MAAM,cAAc,CAAC;AAE9C,MAAM,yBAAyB,GAAG,CAAC,CAAC;AAEpC,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,SAAS,CAAC,MAAc;IACpD,MAAM,MAAM,GAAG,MAAM,aAAa,EAAE,CAAC;IACrC,MAAM,EAAE,GAAG,gBAAgB,CAAC,MAAM,CAAC,GAAG,EAAE,EAAC,MAAM,EAAE,iBAAiB,EAAC,CAAC,CAAC;IAErE,mDAAmD;IACnD,MAAM,QAAQ,GAAG,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,WAAW,EAAE;QAChD,GAAG,EAAE,yBAAyB;KAC/B,CAAC,CAAC;IACH,KAAK,OAAO,CAAC,UAAU,CACrB,KAAK,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,yBAAyB,EAAC,EAAE,GAAG,EAAE,CACnD,QAAQ,CAAA,UAAU,CAAC,MAAM,EAAE,CAAC,OAAO,EAAE,CACtC,CACF,CAAC;IAEF,gEAAgE;IAChE,MAAM,EAAC,YAAY,EAAE,iBAAiB,EAAC,GAAG,MAAM,sBAAsB,CACpE,EAAE,EACF,MAAM,CAAC,WAAW,EAClB,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,aAAa,CACrB,CAAC;IAEF,MAAM,cAAc,GAAG,MAAM,kBAAkB,CAC7C,EAAE,EACF,QAAQ,EACR,YAAY,EACZ,iBAAiB,CAClB,CAAC;IAEF,MAAM,uBAAuB,GAAG,IAAI,wBAAwB,CAC1D,EAAE,EACF,cAAc,CACf,CAAC;IAEF,KAAK,SAAS,CAAC,EAAE,EAAE,cAAc,EAAE,uBAAuB,CAAC,CAAC;IAE5D,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAC,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;AACxC,CAAC;AAED,SAAS;AACT,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;IACzB,KAAK,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC;AACrC,CAAC"}
1
+ {"version":3,"file":"change-streamer.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/change-streamer.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,IAAI,EAAC,MAAM,6BAA6B,CAAC;AACjD,OAAO,EAAC,aAAa,EAAC,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAC,wBAAwB,EAAC,MAAM,qDAAqD,CAAC;AAC7F,OAAO,EAAC,kBAAkB,EAAC,MAAM,wDAAwD,CAAC;AAC1F,OAAO,EAAC,sBAAsB,EAAC,MAAM,iDAAiD,CAAC;AACvF,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AACxC,OAAO,EACL,YAAY,EACZ,iBAAiB,GAElB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAAC,SAAS,EAAE,cAAc,EAAC,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAC,gBAAgB,EAAC,MAAM,cAAc,CAAC;AAE9C,MAAM,yBAAyB,GAAG,CAAC,CAAC;AAEpC,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,SAAS,CAAC,MAAc;IACpD,MAAM,MAAM,GAAG,MAAM,aAAa,EAAE,CAAC;IACrC,MAAM,EAAE,GAAG,gBAAgB,CAAC,MAAM,CAAC,GAAG,EAAE,EAAC,MAAM,EAAE,iBAAiB,EAAC,CAAC,CAAC;IAErE,mDAAmD;IACnD,MAAM,QAAQ,GAAG,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,eAAe,EAAE;QACpD,GAAG,EAAE,yBAAyB;KAC/B,CAAC,CAAC;IACH,KAAK,OAAO,CAAC,UAAU,CACrB,KAAK,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,yBAAyB,EAAC,EAAE,GAAG,EAAE,CACnD,QAAQ,CAAA,UAAU,CAAC,MAAM,EAAE,CAAC,OAAO,EAAE,CACtC,CACF,CAAC;IAEF,gEAAgE;IAChE,MAAM,EAAC,YAAY,EAAE,iBAAiB,EAAC,GAAG,MAAM,sBAAsB,CACpE,EAAE,EACF,MAAM,CAAC,iBAAiB,EACxB,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,aAAa,CACrB,CAAC;IAEF,MAAM,cAAc,GAAG,MAAM,kBAAkB,CAC7C,EAAE,EACF,QAAQ,EACR,YAAY,EACZ,iBAAiB,CAClB,CAAC;IAEF,MAAM,uBAAuB,GAAG,IAAI,wBAAwB,CAC1D,EAAE,EACF,cAAc,CACf,CAAC;IAEF,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAC,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;IAEtC,OAAO,cAAc,CAAC,EAAE,EAAE,MAAM,EAAE,cAAc,EAAE,uBAAuB,CAAC,CAAC;AAC7E,CAAC;AAED,SAAS;AACT,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;IACzB,KAAK,SAAS,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;AACtD,CAAC"}
@@ -0,0 +1,38 @@
1
+ import { LogContext } from '@rocicorp/logger';
2
+ import type { EventEmitter } from 'stream';
3
+ import type { SingletonService } from '../services/service.js';
4
+ import type { Worker } from '../types/processes.js';
5
+ /**
6
+ * * `user-facing` workers serve external requests and are the first to
7
+ * receive a `SIGTERM` or `SIGINT` signal for graceful shutdown.
8
+ *
9
+ * * `supporting` workers support `user-facing` workers and are sent
10
+ * the `SIGTERM` signal only after all `user-facing` workers have
11
+ * exited.
12
+ *
13
+ * For other kill signals, such as `SIGQUIT`, all workers
14
+ * are stopped without draining. Additionally, if any worker exits
15
+ * unexpectedly, all workers sent an immediate `SIGQUIT` signal.
16
+ */
17
+ export type WorkerType = 'user-facing' | 'supporting';
18
+ export declare const GRACEFUL_SHUTDOWN: readonly ["SIGTERM", "SIGINT"];
19
+ export declare const FORCEFUL_SHUTDOWN: readonly ["SIGQUIT"];
20
+ /**
21
+ * Handles termination signals and coordination of graceful shutdown.
22
+ */
23
+ export declare class Terminator {
24
+ #private;
25
+ constructor(lc: LogContext, proc?: EventEmitter, exit?: (code: number) => never);
26
+ addWorker(worker: Worker, type: WorkerType): Worker;
27
+ logErrorAndExit(err: unknown): never;
28
+ }
29
+ /**
30
+ * Runs the specified services, stopping them on `SIGTERM` or `SIGINT` with
31
+ * an optional {@link SingletonService.drain drain()}, or stopping them
32
+ * without draining for `SIGQUIT`.
33
+ *
34
+ * @returns a Promise that resolves/rejects when any of the services stops/throws.
35
+ */
36
+ export declare function runUntilKilled(lc: LogContext, parent: Worker, ...services: SingletonService[]): Promise<void>;
37
+ export declare function exitAfter(run: () => Promise<void>): Promise<void>;
38
+ //# sourceMappingURL=life-cycle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"life-cycle.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/life-cycle.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAC,MAAM,kBAAkB,CAAC;AAC5C,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,QAAQ,CAAC;AACzC,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,wBAAwB,CAAC;AAC7D,OAAO,KAAK,EAAC,MAAM,EAAC,MAAM,uBAAuB,CAAC;AAElD;;;;;;;;;;;GAWG;AACH,MAAM,MAAM,UAAU,GAAG,aAAa,GAAG,YAAY,CAAC;AAEtD,eAAO,MAAM,iBAAiB,gCAAiC,CAAC;AAChE,eAAO,MAAM,iBAAiB,sBAAuB,CAAC;AAEtD;;GAEG;AACH,qBAAa,UAAU;;gBASnB,EAAE,EAAE,UAAU,EAEd,IAAI,GAAE,YAAsB,EAC5B,IAAI,UAAU,MAAM,UAAuB;IAiC7C,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,UAAU,GAAG,MAAM;IAWnD,eAAe,CAAC,GAAG,EAAE,OAAO,GAAG,KAAK;CAqCrC;AAQD;;;;;;GAMG;AAEH,wBAAsB,cAAc,CAClC,EAAE,EAAE,UAAU,EACd,MAAM,EAAE,MAAM,EACd,GAAG,QAAQ,EAAE,gBAAgB,EAAE,GAC9B,OAAO,CAAC,IAAI,CAAC,CA0Bf;AAED,wBAAsB,SAAS,CAAC,GAAG,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,iBAQvD"}
@@ -0,0 +1,125 @@
1
+ import { LogContext } from '@rocicorp/logger';
2
+ export const GRACEFUL_SHUTDOWN = ['SIGTERM', 'SIGINT'];
3
+ export const FORCEFUL_SHUTDOWN = ['SIGQUIT'];
4
+ /**
5
+ * Handles termination signals and coordination of graceful shutdown.
6
+ */
7
+ export class Terminator {
8
+ #lc;
9
+ #userFacing = new Set();
10
+ #all = new Set();
11
+ #exit;
12
+ #drainStart = 0;
13
+ constructor(lc,
14
+ // testing hooks
15
+ proc = process, exit = (code) => process.exit(code)) {
16
+ this.#lc = lc.withContext('component', 'terminator');
17
+ // Propagate `SIGTERM` and `SIGINT` to all user-facing workers,
18
+ // initiating a graceful shutdown. The terminator process will
19
+ // exit once all user-facing workers have exited ...
20
+ for (const signal of GRACEFUL_SHUTDOWN) {
21
+ proc.on(signal, () => {
22
+ this.#drainStart = Date.now();
23
+ if (this.#userFacing.size) {
24
+ kill(this.#userFacing, signal);
25
+ }
26
+ else {
27
+ exit(0);
28
+ }
29
+ });
30
+ }
31
+ // ... which will result in sending `SIGTERM` to the remaining workers.
32
+ proc.on('exit', code => kill(this.#all, code === 0 ? GRACEFUL_SHUTDOWN[0] : FORCEFUL_SHUTDOWN[0]));
33
+ // For other (catchable) kill signals, exit with a non-zero error code
34
+ // to send a `SIGQUIT` to all workers. For this signal, workers are
35
+ // stopped immediately without draining. See `runUntilKilled()`.
36
+ for (const signal of FORCEFUL_SHUTDOWN) {
37
+ proc.on(signal, () => exit(-1));
38
+ }
39
+ this.#exit = exit;
40
+ }
41
+ addWorker(worker, type) {
42
+ if (type === 'user-facing') {
43
+ this.#userFacing.add(worker);
44
+ }
45
+ this.#all.add(worker);
46
+ worker.on('error', err => this.logErrorAndExit(err));
47
+ worker.on('close', code => this.#onExit(code, worker, type));
48
+ return worker;
49
+ }
50
+ logErrorAndExit(err) {
51
+ this.#lc.error?.(`shutting down for error`, err);
52
+ this.#exit(-1);
53
+ }
54
+ #onExit(code, worker, type) {
55
+ if (code !== 0) {
56
+ this.#lc.error?.(`shutting down because worker exited with code ${code}`);
57
+ return this.#exit(code);
58
+ }
59
+ if (type === 'supporting') {
60
+ // The replication-manager has no user-facing workers.
61
+ // In this case, code === 0 shutdowns are not errors.
62
+ const log = code === 0 && this.#userFacing.size === 0 ? 'info' : 'error';
63
+ this.#lc[log]?.(`shutting down because supporting worker exited with code ${code}`);
64
+ return this.#exit(log === 'error' ? -1 : code);
65
+ }
66
+ if (this.#drainStart === 0) {
67
+ this.#lc.error?.(`shutting down because user-facing worker exited before SIGTERM`);
68
+ return this.#exit(-1);
69
+ }
70
+ // user-facing worker finished draining.
71
+ this.#userFacing.delete(worker);
72
+ this.#all.delete(worker);
73
+ if (this.#userFacing.size === 0) {
74
+ this.#lc.info?.(`all user-facing workers drained (${Date.now() - this.#drainStart} ms)`);
75
+ return this.#exit(0);
76
+ }
77
+ }
78
+ }
79
+ function kill(workers, signal) {
80
+ for (const worker of workers) {
81
+ worker.kill(signal);
82
+ }
83
+ }
84
+ /**
85
+ * Runs the specified services, stopping them on `SIGTERM` or `SIGINT` with
86
+ * an optional {@link SingletonService.drain drain()}, or stopping them
87
+ * without draining for `SIGQUIT`.
88
+ *
89
+ * @returns a Promise that resolves/rejects when any of the services stops/throws.
90
+ */
91
+ export async function runUntilKilled(lc, parent, ...services) {
92
+ for (const signal of [...GRACEFUL_SHUTDOWN, ...FORCEFUL_SHUTDOWN]) {
93
+ parent.once(signal, () => {
94
+ const GRACEFUL_SIGNALS = GRACEFUL_SHUTDOWN;
95
+ services.forEach(async (svc) => {
96
+ if (GRACEFUL_SIGNALS.includes(signal) && svc.drain) {
97
+ lc.info?.(`draining ${svc.constructor.name} (${svc.id})`);
98
+ await svc.drain();
99
+ }
100
+ lc.info?.(`stopping ${svc.constructor.name} (${svc.id}) for ${signal}`);
101
+ await svc.stop();
102
+ });
103
+ });
104
+ }
105
+ try {
106
+ // Run all services and resolve when any of them stops.
107
+ const svc = await Promise.race(services.map(svc => svc.run().then(() => svc)));
108
+ lc.info?.(`${svc.constructor.name} (${svc.id}) stopped`);
109
+ }
110
+ catch (e) {
111
+ lc.error?.(`exiting on error`, e);
112
+ throw e;
113
+ }
114
+ }
115
+ export async function exitAfter(run) {
116
+ try {
117
+ await run();
118
+ process.exit(0);
119
+ }
120
+ catch (e) {
121
+ console.error(e);
122
+ process.exit(-1);
123
+ }
124
+ }
125
+ //# sourceMappingURL=life-cycle.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"life-cycle.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/life-cycle.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/logging.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAA6B,MAAM,kBAAkB,CAAC;AAGxE,OAAO,EAAC,KAAK,SAAS,EAAC,MAAM,0BAA0B,CAAC;AAkBxD,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,SAAS,EACjB,OAAO,EAAE;IAAC,MAAM,EAAE,MAAM,CAAA;CAAC,GACxB,UAAU,CAGZ"}
1
+ {"version":3,"file":"logging.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/logging.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EAMX,MAAM,kBAAkB,CAAC;AAG1B,OAAO,EAAC,KAAK,SAAS,EAAC,MAAM,0BAA0B,CAAC;AAqBxD,wBAAgB,gBAAgB,CAC9B,MAAM,EAAE,SAAS,EACjB,OAAO,EAAE;IAAC,MAAM,EAAE,MAAM,CAAA;CAAC,GACxB,UAAU,CAGZ"}
@@ -1,11 +1,13 @@
1
- import { LogContext, TeeLogSink, consoleLogSink } from '@rocicorp/logger';
2
- import { DatadogLogSink } from '../../../datadog/src/datadog-log-sink.js';
1
+ import { LogContext, TeeLogSink, consoleLogSink, } from '@rocicorp/logger';
3
2
  import { pid } from 'node:process';
3
+ import { DatadogLogSink } from '../../../datadog/src/mod.js';
4
4
  import {} from '../config/zero-config.js';
5
+ import { stringify } from '../types/bigint-json.js';
5
6
  const DATADOG_SOURCE = 'zeroWorker';
6
7
  function createLogSink(config) {
8
+ const logSink = config.format === 'json' ? consoleJsonLogSink : consoleLogSink;
7
9
  if (config.datadogLogsApiKey === undefined) {
8
- return consoleLogSink;
10
+ return logSink;
9
11
  }
10
12
  return new TeeLogSink([
11
13
  new DatadogLogSink({
@@ -13,11 +15,48 @@ function createLogSink(config) {
13
15
  service: config.datadogServiceLabel ?? '',
14
16
  source: DATADOG_SOURCE,
15
17
  }),
16
- consoleLogSink,
18
+ logSink,
17
19
  ]);
18
20
  }
19
21
  export function createLogContext(config, context) {
20
22
  const ctx = { ...context, pid };
21
23
  return new LogContext(config.level, ctx, createLogSink(config));
22
24
  }
25
+ const consoleJsonLogSink = {
26
+ log(level, context, ...args) {
27
+ // If the last arg is an object or an Error, combine those fields into the message.
28
+ const lastObj = errorOrObject(args.at(-1));
29
+ if (lastObj) {
30
+ args.pop();
31
+ }
32
+ const message = args.length
33
+ ? {
34
+ message: args
35
+ .map(s => (typeof s === 'string' ? s : stringify(s)))
36
+ .join(' '),
37
+ }
38
+ : undefined;
39
+ console[level](stringify({
40
+ level: level.toUpperCase(),
41
+ ...context,
42
+ ...message,
43
+ ...lastObj,
44
+ }));
45
+ },
46
+ };
47
+ function errorOrObject(v) {
48
+ if (v instanceof Error) {
49
+ return {
50
+ ...v, // some properties of Error subclasses may be enumerable
51
+ name: v.name,
52
+ message: v.message,
53
+ stack: v.stack,
54
+ ...('cause' in v ? { cause: errorOrObject(v.cause) } : null),
55
+ };
56
+ }
57
+ if (v && typeof v === 'object') {
58
+ return v;
59
+ }
60
+ return undefined;
61
+ }
23
62
  //# sourceMappingURL=logging.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/logging.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,UAAU,EAAE,UAAU,EAAE,cAAc,EAAC,MAAM,kBAAkB,CAAC;AACxE,OAAO,EAAC,cAAc,EAAC,MAAM,iCAAiC,CAAC;AAC/D,OAAO,EAAC,GAAG,EAAC,MAAM,cAAc,CAAC;AACjC,OAAO,EAAgB,MAAM,0BAA0B,CAAC;AAExD,MAAM,cAAc,GAAG,YAAY,CAAC;AAEpC,SAAS,aAAa,CAAC,MAAiB;IACtC,IAAI,MAAM,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;QAC3C,OAAO,cAAc,CAAC;IACxB,CAAC;IACD,OAAO,IAAI,UAAU,CAAC;QACpB,IAAI,cAAc,CAAC;YACjB,MAAM,EAAE,MAAM,CAAC,iBAAiB;YAChC,OAAO,EAAE,MAAM,CAAC,mBAAmB,IAAI,EAAE;YACzC,MAAM,EAAE,cAAc;SACvB,CAAC;QACF,cAAc;KACf,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,MAAiB,EACjB,OAAyB;IAEzB,MAAM,GAAG,GAAG,EAAC,GAAG,OAAO,EAAE,GAAG,EAAC,CAAC;IAC9B,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,GAAG,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC;AAClE,CAAC"}
1
+ {"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/logging.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,UAAU,EACV,UAAU,EACV,cAAc,GAIf,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EAAC,GAAG,EAAC,MAAM,cAAc,CAAC;AACjC,OAAO,EAAC,cAAc,EAAC,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAgB,MAAM,0BAA0B,CAAC;AACxD,OAAO,EAAC,SAAS,EAAC,MAAM,yBAAyB,CAAC;AAElD,MAAM,cAAc,GAAG,YAAY,CAAC;AAEpC,SAAS,aAAa,CAAC,MAAiB;IACtC,MAAM,OAAO,GACX,MAAM,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,cAAc,CAAC;IACjE,IAAI,MAAM,CAAC,iBAAiB,KAAK,SAAS,EAAE,CAAC;QAC3C,OAAO,OAAO,CAAC;IACjB,CAAC;IACD,OAAO,IAAI,UAAU,CAAC;QACpB,IAAI,cAAc,CAAC;YACjB,MAAM,EAAE,MAAM,CAAC,iBAAiB;YAChC,OAAO,EAAE,MAAM,CAAC,mBAAmB,IAAI,EAAE;YACzC,MAAM,EAAE,cAAc;SACvB,CAAC;QACF,OAAO;KACR,CAAC,CAAC;AACL,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,MAAiB,EACjB,OAAyB;IAEzB,MAAM,GAAG,GAAG,EAAC,GAAG,OAAO,EAAE,GAAG,EAAC,CAAC;IAC9B,OAAO,IAAI,UAAU,CAAC,MAAM,CAAC,KAAK,EAAE,GAAG,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC;AAClE,CAAC;AAED,MAAM,kBAAkB,GAAY;IAClC,GAAG,CAAC,KAAe,EAAE,OAA4B,EAAE,GAAG,IAAe;QACnE,mFAAmF;QACnF,MAAM,OAAO,GAAG,aAAa,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3C,IAAI,OAAO,EAAE,CAAC;YACZ,IAAI,CAAC,GAAG,EAAE,CAAC;QACb,CAAC;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM;YACzB,CAAC,CAAC;gBACE,OAAO,EAAE,IAAI;qBACV,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;qBACpD,IAAI,CAAC,GAAG,CAAC;aACb;YACH,CAAC,CAAC,SAAS,CAAC;QAEd,OAAO,CAAC,KAAK,CAAC,CACZ,SAAS,CAAC;YACR,KAAK,EAAE,KAAK,CAAC,WAAW,EAAE;YAC1B,GAAG,OAAO;YACV,GAAG,OAAO;YACV,GAAG,OAAO;SACX,CAAC,CACH,CAAC;IACJ,CAAC;CACF,CAAC;AAEF,SAAS,aAAa,CAAC,CAAU;IAC/B,IAAI,CAAC,YAAY,KAAK,EAAE,CAAC;QACvB,OAAO;YACL,GAAG,CAAC,EAAE,wDAAwD;YAC9D,IAAI,EAAE,CAAC,CAAC,IAAI;YACZ,OAAO,EAAE,CAAC,CAAC,OAAO;YAClB,KAAK,EAAE,CAAC,CAAC,KAAK;YACd,GAAG,CAAC,OAAO,IAAI,CAAC,CAAC,CAAC,CAAC,EAAC,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC,KAAK,CAAC,EAAC,CAAC,CAAC,CAAC,IAAI,CAAC;SAC3D,CAAC;IACJ,CAAC;IACD,IAAI,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,EAAE,CAAC;QAC/B,OAAO,CAAC,CAAC;IACX,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC"}
@@ -9,16 +9,14 @@ import { pgClient } from '../types/pg.js';
9
9
  import { childWorker } from '../types/processes.js';
10
10
  import { orTimeout } from '../types/timeout.js';
11
11
  import { createNotifierFrom, handleSubscriptionsFrom, subscribeTo, } from '../workers/replicator.js';
12
+ import { GRACEFUL_SHUTDOWN, Terminator } from './life-cycle.js';
12
13
  import { createLogContext } from './logging.js';
13
14
  const startMs = Date.now();
14
15
  const config = await getZeroConfig();
15
16
  const lc = createLogContext(config.log, { worker: 'dispatcher' });
16
- function logErrorAndExit(err) {
17
- lc.error?.(err);
18
- process.exit(1);
19
- }
17
+ const terminator = new Terminator(lc);
20
18
  const ready = [];
21
- function loadWorker(modulePath, id, ...args) {
19
+ function loadWorker(modulePath, type, id, ...args) {
22
20
  // modulePath is relative to this file
23
21
  const ext = path.extname(import.meta.url);
24
22
  // modulePath is .ts. If we have been compiled, it should be changed to .js
@@ -28,17 +26,15 @@ function loadWorker(modulePath, id, ...args) {
28
26
  const name = path.basename(absModulePath, ext) + (id ? ` (${id})` : '');
29
27
  const { promise, resolve } = resolver();
30
28
  ready.push(promise);
31
- return worker
32
- .onceMessageType('ready', () => {
29
+ return terminator.addWorker(worker, type).onceMessageType('ready', () => {
33
30
  lc.debug?.(`${name} ready (${Date.now() - startMs} ms)`);
34
31
  resolve();
35
- })
36
- .on('close', logErrorAndExit);
32
+ });
37
33
  }
38
34
  const { promise: changeStreamerReady, resolve } = resolver();
39
- const changeStreamer = config.changeStreamerUri
35
+ const changeStreamer = config.changeStreamerConnStr
40
36
  ? resolve()
41
- : loadWorker('./change-streamer.ts').once('message', resolve);
37
+ : loadWorker('./change-streamer.ts', 'supporting').once('message', resolve);
42
38
  const numSyncers = config.numSyncWorkers
43
39
  ? Number(config.numSyncWorkers)
44
40
  : // Reserve 1 core for the replicator. The change-streamer is not CPU heavy.
@@ -47,7 +43,7 @@ if (numSyncers) {
47
43
  // Technically, setting up the CVR DB schema is the responsibility of the Syncer,
48
44
  // but it is done here in the main thread because it is wasteful to have all of
49
45
  // the Syncers attempt the migration in parallel.
50
- const cvrDB = pgClient(lc, config.cvrDbUri);
46
+ const cvrDB = pgClient(lc, config.cvrDBConnStr);
51
47
  await initViewSyncerSchema(lc, cvrDB);
52
48
  void cvrDB.end();
53
49
  }
@@ -56,7 +52,7 @@ if (numSyncers) {
56
52
  await changeStreamerReady;
57
53
  if (config.litestream) {
58
54
  const mode = 'backup';
59
- const replicator = loadWorker('./replicator.ts', mode, mode).once('message', () => subscribeTo(lc, replicator));
55
+ const replicator = loadWorker('./replicator.ts', 'supporting', mode, mode).once('message', () => subscribeTo(lc, replicator));
60
56
  const notifier = createNotifierFrom(lc, replicator);
61
57
  if (changeStreamer) {
62
58
  handleSubscriptionsFrom(lc, changeStreamer, notifier);
@@ -65,10 +61,10 @@ if (config.litestream) {
65
61
  const syncers = [];
66
62
  if (numSyncers) {
67
63
  const mode = config.litestream ? 'serving-copy' : 'serving';
68
- const replicator = loadWorker('./replicator.ts', mode, mode).once('message', () => subscribeTo(lc, replicator));
64
+ const replicator = loadWorker('./replicator.ts', 'supporting', mode, mode).once('message', () => subscribeTo(lc, replicator));
69
65
  const notifier = createNotifierFrom(lc, replicator);
70
66
  for (let i = 0; i < numSyncers; i++) {
71
- syncers.push(loadWorker('./syncer.ts', i + 1));
67
+ syncers.push(loadWorker('./syncer.ts', 'user-facing', i + 1));
72
68
  }
73
69
  syncers.forEach(syncer => handleSubscriptionsFrom(lc, syncer, notifier));
74
70
  }
@@ -86,7 +82,13 @@ if (numSyncers) {
86
82
  await dispatcher.run();
87
83
  }
88
84
  catch (err) {
89
- logErrorAndExit(err);
85
+ terminator.logErrorAndExit(err);
86
+ }
87
+ for (const signal of GRACEFUL_SHUTDOWN) {
88
+ process.on(signal, () => {
89
+ lc.info?.('drain mode: no longer accepting connections');
90
+ return dispatcher.stop();
91
+ });
90
92
  }
91
93
  }
92
94
  //# sourceMappingURL=main.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/main.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"main.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/main.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAC,MAAM,oBAAoB,CAAC;AAC5C,OAAO,eAAe,CAAC;AACvB,OAAO,EAAC,oBAAoB,EAAC,MAAM,SAAS,CAAC;AAC7C,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAC,aAAa,EAAC,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAC,UAAU,EAAe,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAC,oBAAoB,EAAC,MAAM,iDAAiD,CAAC;AACrF,OAAO,EAAC,QAAQ,EAAC,MAAM,gBAAgB,CAAC;AACxC,OAAO,EAAC,WAAW,EAAc,MAAM,uBAAuB,CAAC;AAC/D,OAAO,EAAC,SAAS,EAAC,MAAM,qBAAqB,CAAC;AAC9C,OAAO,EACL,kBAAkB,EAClB,uBAAuB,EAEvB,WAAW,GACZ,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAC,iBAAiB,EAAE,UAAU,EAAkB,MAAM,iBAAiB,CAAC;AAC/E,OAAO,EAAC,gBAAgB,EAAC,MAAM,cAAc,CAAC;AAE9C,MAAM,OAAO,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;AAC3B,MAAM,MAAM,GAAG,MAAM,aAAa,EAAE,CAAC;AACrC,MAAM,EAAE,GAAG,gBAAgB,CAAC,MAAM,CAAC,GAAG,EAAE,EAAC,MAAM,EAAE,YAAY,EAAC,CAAC,CAAC;AAEhE,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,EAAE,CAAC,CAAC;AACtC,MAAM,KAAK,GAAoB,EAAE,CAAC;AAElC,SAAS,UAAU,CACjB,UAAkB,EAClB,IAAgB,EAChB,EAAoB,EACpB,GAAG,IAAc;IAEjB,sCAAsC;IACtC,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1C,2EAA2E;IAC3E,UAAU,GAAG,UAAU,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IAC9C,MAAM,aAAa,GAAG,IAAI,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,CAAC;IACpE,MAAM,MAAM,GAAG,WAAW,CAAC,aAAa,EAAE,GAAG,IAAI,CAAC,CAAC;IACnD,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACxE,MAAM,EAAC,OAAO,EAAE,OAAO,EAAC,GAAG,QAAQ,EAAE,CAAC;IACtC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAEpB,OAAO,UAAU,CAAC,SAAS,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,eAAe,CAAC,OAAO,EAAE,GAAG,EAAE;QACtE,EAAE,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,WAAW,IAAI,CAAC,GAAG,EAAE,GAAG,OAAO,MAAM,CAAC,CAAC;QACzD,OAAO,EAAE,CAAC;IACZ,CAAC,CAAC,CAAC;AACL,CAAC;AAED,MAAM,EAAC,OAAO,EAAE,mBAAmB,EAAE,OAAO,EAAC,GAAG,QAAQ,EAAE,CAAC;AAC3D,MAAM,cAAc,GAAG,MAAM,CAAC,qBAAqB;IACjD,CAAC,CAAC,OAAO,EAAE;IACX,CAAC,CAAC,UAAU,CAAC,sBAAsB,EAAE,YAAY,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;AAE9E,MAAM,UAAU,GAAG,MAAM,CAAC,cAAc;IACtC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,cAAc,CAAC;IAC/B,CAAC,CAAC,2EAA2E;QAC3E,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,oBAAoB,EAAE,GAAG,CAAC,CAAC,CAAC;AAE5C,IAAI,UAAU,EAAE,CAAC;IACf,iFAAiF;IACjF,+EAA+E;IAC/E,iDAAiD;IACjD,MAAM,KAAK,GAAG,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;IAChD,MAAM,oBAAoB,CAAC,EAAE,EAAE,KAAK,CAAC,CAAC;IACtC,KAAK,KAAK,CAAC,GAAG,EAAE,CAAC;AACnB,CAAC;AAED,qEAAqE;AACrE,kDAAkD;AAClD,MAAM,mBAAmB,CAAC;AAE1B,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;IACtB,MAAM,IAAI,GAAoB,QAAQ,CAAC;IACvC,MAAM,UAAU,GAAG,UAAU,CAC3B,iBAAiB,EACjB,YAAY,EACZ,IAAI,EACJ,IAAI,CACL,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC,CAAC;IACrD,MAAM,QAAQ,GAAG,kBAAkB,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IACpD,IAAI,cAAc,EAAE,CAAC;QACnB,uBAAuB,CAAC,EAAE,EAAE,cAAc,EAAE,QAAQ,CAAC,CAAC;IACxD,CAAC;AACH,CAAC;AAED,MAAM,OAAO,GAAa,EAAE,CAAC;AAC7B,IAAI,UAAU,EAAE,CAAC;IACf,MAAM,IAAI,GAAoB,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7E,MAAM,UAAU,GAAG,UAAU,CAC3B,iBAAiB,EACjB,YAAY,EACZ,IAAI,EACJ,IAAI,CACL,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC,CAAC;IACrD,MAAM,QAAQ,GAAG,kBAAkB,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IACpD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,EAAE,CAAC,EAAE,EAAE,CAAC;QACpC,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,aAAa,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAChE,CAAC;IACD,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC,uBAAuB,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,CAAC,CAAC,CAAC;AAC3E,CAAC;AAED,EAAE,CAAC,IAAI,EAAE,CAAC,qCAAqC,CAAC,CAAC;AACjD,IAAI,CAAC,MAAM,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC,CAAC,KAAK,WAAW,EAAE,CAAC;IAClE,EAAE,CAAC,IAAI,EAAE,CAAC,oCAAoC,IAAI,CAAC,GAAG,EAAE,GAAG,OAAO,MAAM,CAAC,CAAC;AAC5E,CAAC;KAAM,CAAC;IACN,EAAE,CAAC,IAAI,EAAE,CAAC,sBAAsB,IAAI,CAAC,GAAG,EAAE,GAAG,OAAO,MAAM,CAAC,CAAC;AAC9D,CAAC;AAED,IAAI,UAAU,EAAE,CAAC;IACf,MAAM,OAAO,GAAY,EAAC,OAAO,EAAC,CAAC;IAEnC,MAAM,UAAU,GAAG,IAAI,UAAU,CAAC,EAAE,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,CAAC;IACrD,IAAI,CAAC;QACH,MAAM,UAAU,CAAC,GAAG,EAAE,CAAC;IACzB,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,UAAU,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC;IAClC,CAAC;IAED,KAAK,MAAM,MAAM,IAAI,iBAAiB,EAAE,CAAC;QACvC,OAAO,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;YACtB,EAAE,CAAC,IAAI,EAAE,CAAC,6CAA6C,CAAC,CAAC;YACzD,OAAO,UAAU,CAAC,IAAI,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACL,CAAC;AACH,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"replicator.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/replicator.ts"],"names":[],"mappings":"AAQA,OAAO,EAGL,KAAK,MAAM,EACZ,MAAM,uBAAuB,CAAC;AAQ/B,wBAA8B,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,IAAI,EAAE,MAAM,EAAE,iBA+BxE"}
1
+ {"version":3,"file":"replicator.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/replicator.ts"],"names":[],"mappings":"AASA,OAAO,EAGL,KAAK,MAAM,EACZ,MAAM,uBAAuB,CAAC;AAS/B,wBAA8B,SAAS,CACrC,MAAM,EAAE,MAAM,EACd,GAAG,IAAI,EAAE,MAAM,EAAE,GAChB,OAAO,CAAC,IAAI,CAAC,CAkCf"}
@@ -3,33 +3,34 @@ import { assert } from '../../../shared/src/asserts.js';
3
3
  import { must } from '../../../shared/src/must.js';
4
4
  import { getZeroConfig } from '../config/zero-config.js';
5
5
  import { ChangeStreamerHttpClient } from '../services/change-streamer/change-streamer-http.js';
6
- import { NULL_CHECKPOINTER } from '../services/replicator/checkpointer.js';
7
- import { ReplicatorService } from '../services/replicator/replicator.js';
8
- import { runOrExit } from '../services/runner.js';
6
+ import { ReplicatorService, } from '../services/replicator/replicator.js';
9
7
  import { parentWorker, singleProcessMode, } from '../types/processes.js';
10
8
  import { setUpMessageHandlers, setupReplica, } from '../workers/replicator.js';
9
+ import { exitAfter, runUntilKilled } from './life-cycle.js';
11
10
  import { createLogContext } from './logging.js';
12
11
  export default async function runWorker(parent, ...args) {
13
12
  const config = await getZeroConfig();
14
13
  assert(args.length > 0, `replicator mode not specified`);
15
- const mode = args[0];
16
- const workerName = `${mode === 'backup' ? 'backup' : 'serving'}-replicator`;
14
+ const fileMode = args[0];
15
+ const mode = fileMode === 'backup' ? 'backup' : 'serving';
16
+ const workerName = `${mode}-replicator`;
17
17
  const lc = createLogContext(config.log, { worker: workerName });
18
- const replica = setupReplica(lc, mode, config.replicaDbFile);
19
- const changeStreamer = config.changeStreamerUri
20
- ? new ChangeStreamerHttpClient(lc, config.changeStreamerUri)
18
+ const replica = setupReplica(lc, fileMode, config.replicaDBFile);
19
+ const changeStreamer = config.changeStreamerConnStr
20
+ ? new ChangeStreamerHttpClient(lc, config.changeStreamerConnStr)
21
21
  : new ChangeStreamerHttpClient(lc);
22
- const replicator = new ReplicatorService(lc, `${workerName}-${pid}`, changeStreamer, replica, NULL_CHECKPOINTER);
22
+ const replicator = new ReplicatorService(lc, `${workerName}-${pid}`, mode, changeStreamer, replica);
23
23
  setUpMessageHandlers(lc, replicator, parent);
24
- void runOrExit(lc, replicator);
24
+ const running = runUntilKilled(lc, parent, replicator);
25
25
  // Signal readiness once the first ReplicaVersionReady notification is received.
26
26
  for await (const _ of replicator.subscribe()) {
27
27
  parent.send(['ready', { ready: true }]);
28
28
  break;
29
29
  }
30
+ return running;
30
31
  }
31
32
  // fork()
32
33
  if (!singleProcessMode()) {
33
- void runWorker(must(parentWorker), ...process.argv.slice(2));
34
+ void exitAfter(() => runWorker(must(parentWorker), ...process.argv.slice(2)));
34
35
  }
35
36
  //# sourceMappingURL=replicator.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"replicator.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/replicator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAC,MAAM,cAAc,CAAC;AACjC,OAAO,EAAC,MAAM,EAAC,MAAM,uBAAuB,CAAC;AAC7C,OAAO,EAAC,IAAI,EAAC,MAAM,oBAAoB,CAAC;AACxC,OAAO,EAAC,aAAa,EAAC,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAC,wBAAwB,EAAC,MAAM,qDAAqD,CAAC;AAC7F,OAAO,EAAC,iBAAiB,EAAC,MAAM,wCAAwC,CAAC;AACzE,OAAO,EAAC,iBAAiB,EAAC,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAC,SAAS,EAAC,MAAM,uBAAuB,CAAC;AAChD,OAAO,EACL,YAAY,EACZ,iBAAiB,GAElB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EAEL,oBAAoB,EACpB,YAAY,GACb,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAC,gBAAgB,EAAC,MAAM,cAAc,CAAC;AAE9C,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,SAAS,CAAC,MAAc,EAAE,GAAG,IAAc;IACvE,MAAM,MAAM,GAAG,MAAM,aAAa,EAAE,CAAC;IACrC,MAAM,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,+BAA+B,CAAC,CAAC;IAEzD,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAmB,CAAC;IACvC,MAAM,UAAU,GAAG,GAAG,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,aAAa,CAAC;IAC5E,MAAM,EAAE,GAAG,gBAAgB,CAAC,MAAM,CAAC,GAAG,EAAE,EAAC,MAAM,EAAE,UAAU,EAAC,CAAC,CAAC;IAE9D,MAAM,OAAO,GAAG,YAAY,CAAC,EAAE,EAAE,IAAI,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC;IAE7D,MAAM,cAAc,GAAG,MAAM,CAAC,iBAAiB;QAC7C,CAAC,CAAC,IAAI,wBAAwB,CAAC,EAAE,EAAE,MAAM,CAAC,iBAAiB,CAAC;QAC5D,CAAC,CAAC,IAAI,wBAAwB,CAAC,EAAE,CAAC,CAAC;IAErC,MAAM,UAAU,GAAG,IAAI,iBAAiB,CACtC,EAAE,EACF,GAAG,UAAU,IAAI,GAAG,EAAE,EACtB,cAAc,EACd,OAAO,EACP,iBAAiB,CAClB,CAAC;IAEF,oBAAoB,CAAC,EAAE,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;IAE7C,KAAK,SAAS,CAAC,EAAE,EAAE,UAAU,CAAC,CAAC;IAE/B,gFAAgF;IAChF,IAAI,KAAK,EAAE,MAAM,CAAC,IAAI,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC;QAC7C,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAC,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;QACtC,MAAM;IACR,CAAC;AACH,CAAC;AAED,SAAS;AACT,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;IACzB,KAAK,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;AAC/D,CAAC"}
1
+ {"version":3,"file":"replicator.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/replicator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,GAAG,EAAC,MAAM,cAAc,CAAC;AACjC,OAAO,EAAC,MAAM,EAAC,MAAM,gCAAgC,CAAC;AACtD,OAAO,EAAC,IAAI,EAAC,MAAM,6BAA6B,CAAC;AACjD,OAAO,EAAC,aAAa,EAAC,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAC,wBAAwB,EAAC,MAAM,qDAAqD,CAAC;AAC7F,OAAO,EACL,iBAAiB,GAElB,MAAM,sCAAsC,CAAC;AAC9C,OAAO,EACL,YAAY,EACZ,iBAAiB,GAElB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EACL,oBAAoB,EACpB,YAAY,GAEb,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAC,SAAS,EAAE,cAAc,EAAC,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAC,gBAAgB,EAAC,MAAM,cAAc,CAAC;AAE9C,MAAM,CAAC,OAAO,CAAC,KAAK,UAAU,SAAS,CACrC,MAAc,EACd,GAAG,IAAc;IAEjB,MAAM,MAAM,GAAG,MAAM,aAAa,EAAE,CAAC;IACrC,MAAM,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,+BAA+B,CAAC,CAAC;IAEzD,MAAM,QAAQ,GAAG,IAAI,CAAC,CAAC,CAAoB,CAAC;IAC5C,MAAM,IAAI,GAAmB,QAAQ,KAAK,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC;IAC1E,MAAM,UAAU,GAAG,GAAG,IAAI,aAAa,CAAC;IACxC,MAAM,EAAE,GAAG,gBAAgB,CAAC,MAAM,CAAC,GAAG,EAAE,EAAC,MAAM,EAAE,UAAU,EAAC,CAAC,CAAC;IAE9D,MAAM,OAAO,GAAG,YAAY,CAAC,EAAE,EAAE,QAAQ,EAAE,MAAM,CAAC,aAAa,CAAC,CAAC;IAEjE,MAAM,cAAc,GAAG,MAAM,CAAC,qBAAqB;QACjD,CAAC,CAAC,IAAI,wBAAwB,CAAC,EAAE,EAAE,MAAM,CAAC,qBAAqB,CAAC;QAChE,CAAC,CAAC,IAAI,wBAAwB,CAAC,EAAE,CAAC,CAAC;IAErC,MAAM,UAAU,GAAG,IAAI,iBAAiB,CACtC,EAAE,EACF,GAAG,UAAU,IAAI,GAAG,EAAE,EACtB,IAAI,EACJ,cAAc,EACd,OAAO,CACR,CAAC;IAEF,oBAAoB,CAAC,EAAE,EAAE,UAAU,EAAE,MAAM,CAAC,CAAC;IAE7C,MAAM,OAAO,GAAG,cAAc,CAAC,EAAE,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC;IAEvD,gFAAgF;IAChF,IAAI,KAAK,EAAE,MAAM,CAAC,IAAI,UAAU,CAAC,SAAS,EAAE,EAAE,CAAC;QAC7C,MAAM,CAAC,IAAI,CAAC,CAAC,OAAO,EAAE,EAAC,KAAK,EAAE,IAAI,EAAC,CAAC,CAAC,CAAC;QACtC,MAAM;IACR,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED,SAAS;AACT,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;IACzB,KAAK,SAAS,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;AAChF,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"syncer.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/syncer.ts"],"names":[],"mappings":"AAaA,OAAO,EAGL,KAAK,MAAM,EACZ,MAAM,uBAAuB,CAAC;AAK/B,wBAA8B,SAAS,CAAC,MAAM,EAAE,MAAM,iBAoDrD"}
1
+ {"version":3,"file":"syncer.d.ts","sourceRoot":"","sources":["../../../../../zero-cache/src/server/syncer.ts"],"names":[],"mappings":"AAaA,OAAO,EAGL,KAAK,MAAM,EACZ,MAAM,uBAAuB,CAAC;AAM/B,wBAA8B,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CA2DrE"}
@@ -13,6 +13,7 @@ import { pgClient } from '../types/pg.js';
13
13
  import { parentWorker, singleProcessMode, } from '../types/processes.js';
14
14
  import { Subscription } from '../types/subscription.js';
15
15
  import { Syncer } from '../workers/syncer.js';
16
+ import { exitAfter, runUntilKilled } from './life-cycle.js';
16
17
  import { createLogContext } from './logging.js';
17
18
  export default async function runWorker(parent) {
18
19
  const config = await getZeroConfig();
@@ -20,26 +21,26 @@ export default async function runWorker(parent) {
20
21
  const MAX_CVR_CONNECTIONS = 5;
21
22
  const MAX_MUTAGEN_CONNECTIONS = 5;
22
23
  const lc = createLogContext(config.log, { worker: 'syncer' });
23
- const cvrDB = pgClient(lc, config.cvrDbUri, {
24
+ const cvrDB = pgClient(lc, config.cvrDBConnStr, {
24
25
  max: MAX_CVR_CONNECTIONS,
25
26
  });
26
- const upstreamDB = pgClient(lc, config.upstreamUri, {
27
+ const upstreamDB = pgClient(lc, config.upstreamDBConnStr, {
27
28
  max: MAX_MUTAGEN_CONNECTIONS,
28
29
  });
29
30
  const dbWarmup = Promise.allSettled([
30
31
  ...Array.from({ length: MAX_CVR_CONNECTIONS }, () => cvrDB `SELECT 1`.simple().execute()),
31
32
  ...Array.from({ length: MAX_MUTAGEN_CONNECTIONS }, () => upstreamDB `SELECT 1`.simple().execute()),
32
33
  ]);
33
- const tmpDir = config.storageDbTmpDir ?? tmpdir();
34
+ const tmpDir = config.storageDBTmpDir ?? tmpdir();
34
35
  const operatorStorage = DatabaseStorage.create(lc, path.join(tmpDir, `sync-worker-${pid}-${randInt(1000000, 9999999)}`));
35
- const viewSyncerFactory = (id, sub) => new ViewSyncerService(lc, id, cvrDB, new PipelineDriver(lc, new Snapshotter(lc, config.replicaDbFile), operatorStorage.createClientGroupStorage(id)), sub);
36
+ const viewSyncerFactory = (id, sub) => new ViewSyncerService(lc, id, cvrDB, new PipelineDriver(lc, new Snapshotter(lc, config.replicaDBFile), operatorStorage.createClientGroupStorage(id)), sub);
36
37
  const mutagenFactory = (id) => new MutagenService(lc, config.shard.id, id, upstreamDB, config);
37
- new Syncer(lc, config, viewSyncerFactory, mutagenFactory, parent).run();
38
- await dbWarmup;
39
- parent.send(['ready', { ready: true }]);
38
+ const syncer = new Syncer(lc, config, viewSyncerFactory, mutagenFactory, parent);
39
+ void dbWarmup.then(() => parent.send(['ready', { ready: true }]));
40
+ return runUntilKilled(lc, parent, syncer);
40
41
  }
41
42
  // fork()
42
43
  if (!singleProcessMode()) {
43
- void runWorker(must(parentWorker));
44
+ void exitAfter(() => runWorker(must(parentWorker)));
44
45
  }
45
46
  //# sourceMappingURL=syncer.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"syncer.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/syncer.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"syncer.js","sourceRoot":"","sources":["../../../../../zero-cache/src/server/syncer.ts"],"names":[],"mappings":"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"}