@livestore/common 0.4.0-dev.9 → 0.4.0

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 (513) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/ClientSessionLeaderThreadProxy.d.ts +27 -12
  3. package/dist/ClientSessionLeaderThreadProxy.d.ts.map +1 -1
  4. package/dist/ClientSessionLeaderThreadProxy.js.map +1 -1
  5. package/dist/WorkerTransportError.d.ts +11 -0
  6. package/dist/WorkerTransportError.d.ts.map +1 -0
  7. package/dist/WorkerTransportError.js +11 -0
  8. package/dist/WorkerTransportError.js.map +1 -0
  9. package/dist/adapter-types.d.ts +37 -7
  10. package/dist/adapter-types.d.ts.map +1 -1
  11. package/dist/adapter-types.js +27 -1
  12. package/dist/adapter-types.js.map +1 -1
  13. package/dist/bounded-collections.d.ts.map +1 -1
  14. package/dist/bounded-collections.js +6 -4
  15. package/dist/bounded-collections.js.map +1 -1
  16. package/dist/debug-info.d.ts.map +1 -1
  17. package/dist/debug-info.js +33 -6
  18. package/dist/debug-info.js.map +1 -1
  19. package/dist/devtools/devtools-compatibility.test.d.ts +2 -0
  20. package/dist/devtools/devtools-compatibility.test.d.ts.map +1 -0
  21. package/dist/devtools/devtools-compatibility.test.js +15 -0
  22. package/dist/devtools/devtools-compatibility.test.js.map +1 -0
  23. package/dist/devtools/devtools-messages-client-session.d.ts +55 -24
  24. package/dist/devtools/devtools-messages-client-session.d.ts.map +1 -1
  25. package/dist/devtools/devtools-messages-client-session.js +22 -5
  26. package/dist/devtools/devtools-messages-client-session.js.map +1 -1
  27. package/dist/devtools/devtools-messages-common.d.ts +11 -14
  28. package/dist/devtools/devtools-messages-common.d.ts.map +1 -1
  29. package/dist/devtools/devtools-messages-common.js +7 -9
  30. package/dist/devtools/devtools-messages-common.js.map +1 -1
  31. package/dist/devtools/devtools-messages-leader.d.ts +65 -30
  32. package/dist/devtools/devtools-messages-leader.d.ts.map +1 -1
  33. package/dist/devtools/devtools-messages-leader.js +29 -11
  34. package/dist/devtools/devtools-messages-leader.js.map +1 -1
  35. package/dist/devtools/devtools-sessioninfo.d.ts +14 -2
  36. package/dist/devtools/devtools-sessioninfo.d.ts.map +1 -1
  37. package/dist/devtools/devtools-sessioninfo.js +7 -4
  38. package/dist/devtools/devtools-sessioninfo.js.map +1 -1
  39. package/dist/devtools/mod.d.ts +13 -2
  40. package/dist/devtools/mod.d.ts.map +1 -1
  41. package/dist/devtools/mod.js +10 -3
  42. package/dist/devtools/mod.js.map +1 -1
  43. package/dist/errors.d.ts +48 -18
  44. package/dist/errors.d.ts.map +1 -1
  45. package/dist/errors.js +20 -12
  46. package/dist/errors.js.map +1 -1
  47. package/dist/index.d.ts +4 -1
  48. package/dist/index.d.ts.map +1 -1
  49. package/dist/index.js +4 -1
  50. package/dist/index.js.map +1 -1
  51. package/dist/leader-thread/LeaderSyncProcessor.d.ts +53 -6
  52. package/dist/leader-thread/LeaderSyncProcessor.d.ts.map +1 -1
  53. package/dist/leader-thread/LeaderSyncProcessor.js +325 -257
  54. package/dist/leader-thread/LeaderSyncProcessor.js.map +1 -1
  55. package/dist/leader-thread/RejectedPushError.d.ts +107 -0
  56. package/dist/leader-thread/RejectedPushError.d.ts.map +1 -0
  57. package/dist/leader-thread/RejectedPushError.js +78 -0
  58. package/dist/leader-thread/RejectedPushError.js.map +1 -0
  59. package/dist/leader-thread/connection.js +1 -1
  60. package/dist/leader-thread/connection.js.map +1 -1
  61. package/dist/leader-thread/eventlog.d.ts +19 -14
  62. package/dist/leader-thread/eventlog.d.ts.map +1 -1
  63. package/dist/leader-thread/eventlog.js +78 -18
  64. package/dist/leader-thread/eventlog.js.map +1 -1
  65. package/dist/leader-thread/leader-worker-devtools.d.ts +1 -2
  66. package/dist/leader-thread/leader-worker-devtools.d.ts.map +1 -1
  67. package/dist/leader-thread/leader-worker-devtools.js +90 -58
  68. package/dist/leader-thread/leader-worker-devtools.js.map +1 -1
  69. package/dist/leader-thread/make-leader-thread-layer.d.ts +15 -7
  70. package/dist/leader-thread/make-leader-thread-layer.d.ts.map +1 -1
  71. package/dist/leader-thread/make-leader-thread-layer.js +49 -17
  72. package/dist/leader-thread/make-leader-thread-layer.js.map +1 -1
  73. package/dist/leader-thread/make-leader-thread-layer.test.d.ts +2 -0
  74. package/dist/leader-thread/make-leader-thread-layer.test.d.ts.map +1 -0
  75. package/dist/leader-thread/make-leader-thread-layer.test.js +32 -0
  76. package/dist/leader-thread/make-leader-thread-layer.test.js.map +1 -0
  77. package/dist/leader-thread/materialize-event.d.ts +1 -1
  78. package/dist/leader-thread/materialize-event.d.ts.map +1 -1
  79. package/dist/leader-thread/materialize-event.js +28 -9
  80. package/dist/leader-thread/materialize-event.js.map +1 -1
  81. package/dist/leader-thread/mod.d.ts +1 -0
  82. package/dist/leader-thread/mod.d.ts.map +1 -1
  83. package/dist/leader-thread/mod.js +1 -0
  84. package/dist/leader-thread/mod.js.map +1 -1
  85. package/dist/leader-thread/recreate-db.d.ts +2 -2
  86. package/dist/leader-thread/recreate-db.d.ts.map +1 -1
  87. package/dist/leader-thread/recreate-db.js +6 -6
  88. package/dist/leader-thread/recreate-db.js.map +1 -1
  89. package/dist/leader-thread/shutdown-channel.d.ts +2 -2
  90. package/dist/leader-thread/shutdown-channel.d.ts.map +1 -1
  91. package/dist/leader-thread/shutdown-channel.js +2 -2
  92. package/dist/leader-thread/shutdown-channel.js.map +1 -1
  93. package/dist/leader-thread/stream-events.d.ts +56 -0
  94. package/dist/leader-thread/stream-events.d.ts.map +1 -0
  95. package/dist/leader-thread/stream-events.js +167 -0
  96. package/dist/leader-thread/stream-events.js.map +1 -0
  97. package/dist/leader-thread/types.d.ts +95 -17
  98. package/dist/leader-thread/types.d.ts.map +1 -1
  99. package/dist/leader-thread/types.js +13 -0
  100. package/dist/leader-thread/types.js.map +1 -1
  101. package/dist/logging.d.ts +40 -0
  102. package/dist/logging.d.ts.map +1 -0
  103. package/dist/logging.js +33 -0
  104. package/dist/logging.js.map +1 -0
  105. package/dist/make-client-session.d.ts +5 -3
  106. package/dist/make-client-session.d.ts.map +1 -1
  107. package/dist/make-client-session.js +7 -4
  108. package/dist/make-client-session.js.map +1 -1
  109. package/dist/materializer-helper.d.ts +6 -6
  110. package/dist/materializer-helper.d.ts.map +1 -1
  111. package/dist/materializer-helper.js +18 -8
  112. package/dist/materializer-helper.js.map +1 -1
  113. package/dist/otel.d.ts +2 -1
  114. package/dist/otel.d.ts.map +1 -1
  115. package/dist/otel.js +7 -2
  116. package/dist/otel.js.map +1 -1
  117. package/dist/rematerialize-from-eventlog.d.ts +3 -3
  118. package/dist/rematerialize-from-eventlog.d.ts.map +1 -1
  119. package/dist/rematerialize-from-eventlog.js +40 -29
  120. package/dist/rematerialize-from-eventlog.js.map +1 -1
  121. package/dist/schema/EventDef/define.d.ts +161 -0
  122. package/dist/schema/EventDef/define.d.ts.map +1 -0
  123. package/dist/schema/EventDef/define.js +140 -0
  124. package/dist/schema/EventDef/define.js.map +1 -0
  125. package/dist/schema/EventDef/deprecated.d.ts +99 -0
  126. package/dist/schema/EventDef/deprecated.d.ts.map +1 -0
  127. package/dist/schema/EventDef/deprecated.js +144 -0
  128. package/dist/schema/EventDef/deprecated.js.map +1 -0
  129. package/dist/schema/EventDef/deprecated.test.d.ts +2 -0
  130. package/dist/schema/EventDef/deprecated.test.d.ts.map +1 -0
  131. package/dist/schema/EventDef/deprecated.test.js +95 -0
  132. package/dist/schema/EventDef/deprecated.test.js.map +1 -0
  133. package/dist/schema/EventDef/event-def.d.ts +110 -0
  134. package/dist/schema/EventDef/event-def.d.ts.map +1 -0
  135. package/dist/schema/EventDef/event-def.js +2 -0
  136. package/dist/schema/EventDef/event-def.js.map +1 -0
  137. package/dist/schema/EventDef/facts.d.ts +118 -0
  138. package/dist/schema/EventDef/facts.d.ts.map +1 -0
  139. package/dist/schema/EventDef/facts.js +53 -0
  140. package/dist/schema/EventDef/facts.js.map +1 -0
  141. package/dist/schema/EventDef/materializer.d.ts +155 -0
  142. package/dist/schema/EventDef/materializer.d.ts.map +1 -0
  143. package/dist/schema/EventDef/materializer.js +83 -0
  144. package/dist/schema/EventDef/materializer.js.map +1 -0
  145. package/dist/schema/EventDef/mod.d.ts +6 -0
  146. package/dist/schema/EventDef/mod.d.ts.map +1 -0
  147. package/dist/schema/EventDef/mod.js +6 -0
  148. package/dist/schema/EventDef/mod.js.map +1 -0
  149. package/dist/schema/EventSequenceNumber/client.d.ts +136 -0
  150. package/dist/schema/EventSequenceNumber/client.d.ts.map +1 -0
  151. package/dist/schema/EventSequenceNumber/client.js +193 -0
  152. package/dist/schema/EventSequenceNumber/client.js.map +1 -0
  153. package/dist/schema/EventSequenceNumber/global.d.ts +15 -0
  154. package/dist/schema/EventSequenceNumber/global.d.ts.map +1 -0
  155. package/dist/schema/EventSequenceNumber/global.js +14 -0
  156. package/dist/schema/EventSequenceNumber/global.js.map +1 -0
  157. package/dist/schema/EventSequenceNumber/mod.d.ts +37 -0
  158. package/dist/schema/EventSequenceNumber/mod.d.ts.map +1 -0
  159. package/dist/schema/EventSequenceNumber/mod.js +37 -0
  160. package/dist/schema/EventSequenceNumber/mod.js.map +1 -0
  161. package/dist/schema/EventSequenceNumber.test.js +44 -44
  162. package/dist/schema/EventSequenceNumber.test.js.map +1 -1
  163. package/dist/schema/{LiveStoreEvent.d.ts → LiveStoreEvent/client.d.ts} +102 -111
  164. package/dist/schema/LiveStoreEvent/client.d.ts.map +1 -0
  165. package/dist/schema/LiveStoreEvent/client.js +176 -0
  166. package/dist/schema/LiveStoreEvent/client.js.map +1 -0
  167. package/dist/schema/LiveStoreEvent/client.test.d.ts +2 -0
  168. package/dist/schema/LiveStoreEvent/client.test.d.ts.map +1 -0
  169. package/dist/schema/LiveStoreEvent/client.test.js +111 -0
  170. package/dist/schema/LiveStoreEvent/client.test.js.map +1 -0
  171. package/dist/schema/LiveStoreEvent/for-event-def.d.ts +52 -0
  172. package/dist/schema/LiveStoreEvent/for-event-def.d.ts.map +1 -0
  173. package/dist/schema/LiveStoreEvent/for-event-def.js +2 -0
  174. package/dist/schema/LiveStoreEvent/for-event-def.js.map +1 -0
  175. package/dist/schema/LiveStoreEvent/global.d.ts +36 -0
  176. package/dist/schema/LiveStoreEvent/global.d.ts.map +1 -0
  177. package/dist/schema/LiveStoreEvent/global.js +31 -0
  178. package/dist/schema/LiveStoreEvent/global.js.map +1 -0
  179. package/dist/schema/LiveStoreEvent/input.d.ts +46 -0
  180. package/dist/schema/LiveStoreEvent/input.d.ts.map +1 -0
  181. package/dist/schema/LiveStoreEvent/input.js +26 -0
  182. package/dist/schema/LiveStoreEvent/input.js.map +1 -0
  183. package/dist/schema/LiveStoreEvent/mod.d.ts +5 -0
  184. package/dist/schema/LiveStoreEvent/mod.d.ts.map +1 -0
  185. package/dist/schema/LiveStoreEvent/mod.js +5 -0
  186. package/dist/schema/LiveStoreEvent/mod.js.map +1 -0
  187. package/dist/schema/events.d.ts +1 -1
  188. package/dist/schema/events.d.ts.map +1 -1
  189. package/dist/schema/events.js +1 -1
  190. package/dist/schema/events.js.map +1 -1
  191. package/dist/schema/mod.d.ts +6 -4
  192. package/dist/schema/mod.d.ts.map +1 -1
  193. package/dist/schema/mod.js +5 -4
  194. package/dist/schema/mod.js.map +1 -1
  195. package/dist/schema/schema.d.ts +16 -1
  196. package/dist/schema/schema.d.ts.map +1 -1
  197. package/dist/schema/schema.js +32 -4
  198. package/dist/schema/schema.js.map +1 -1
  199. package/dist/schema/state/sqlite/client-document-def.d.ts +2 -1
  200. package/dist/schema/state/sqlite/client-document-def.d.ts.map +1 -1
  201. package/dist/schema/state/sqlite/client-document-def.js +36 -15
  202. package/dist/schema/state/sqlite/client-document-def.js.map +1 -1
  203. package/dist/schema/state/sqlite/client-document-def.test.js +121 -2
  204. package/dist/schema/state/sqlite/client-document-def.test.js.map +1 -1
  205. package/dist/schema/state/sqlite/column-annotations.d.ts.map +1 -1
  206. package/dist/schema/state/sqlite/column-annotations.js +1 -1
  207. package/dist/schema/state/sqlite/column-annotations.js.map +1 -1
  208. package/dist/schema/state/sqlite/column-annotations.test.js +2 -2
  209. package/dist/schema/state/sqlite/column-annotations.test.js.map +1 -1
  210. package/dist/schema/state/sqlite/column-def.d.ts.map +1 -1
  211. package/dist/schema/state/sqlite/column-def.js +96 -47
  212. package/dist/schema/state/sqlite/column-def.js.map +1 -1
  213. package/dist/schema/state/sqlite/column-def.test.js +51 -12
  214. package/dist/schema/state/sqlite/column-def.test.js.map +1 -1
  215. package/dist/schema/state/sqlite/column-spec.d.ts.map +1 -1
  216. package/dist/schema/state/sqlite/column-spec.js +30 -12
  217. package/dist/schema/state/sqlite/column-spec.js.map +1 -1
  218. package/dist/schema/state/sqlite/column-spec.test.js +24 -15
  219. package/dist/schema/state/sqlite/column-spec.test.js.map +1 -1
  220. package/dist/schema/state/sqlite/db-schema/ast/sqlite.js +2 -2
  221. package/dist/schema/state/sqlite/db-schema/ast/sqlite.js.map +1 -1
  222. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts +16 -10
  223. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts.map +1 -1
  224. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js +15 -4
  225. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js.map +1 -1
  226. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.js +1 -1
  227. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.js.map +1 -1
  228. package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts +1 -1
  229. package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts.map +1 -1
  230. package/dist/schema/state/sqlite/db-schema/dsl/mod.js +1 -1
  231. package/dist/schema/state/sqlite/db-schema/dsl/mod.js.map +1 -1
  232. package/dist/schema/state/sqlite/mod.d.ts +2 -2
  233. package/dist/schema/state/sqlite/mod.d.ts.map +1 -1
  234. package/dist/schema/state/sqlite/mod.js +5 -7
  235. package/dist/schema/state/sqlite/mod.js.map +1 -1
  236. package/dist/schema/state/sqlite/query-builder/api.d.ts +51 -22
  237. package/dist/schema/state/sqlite/query-builder/api.d.ts.map +1 -1
  238. package/dist/schema/state/sqlite/query-builder/astToSql.d.ts.map +1 -1
  239. package/dist/schema/state/sqlite/query-builder/astToSql.js +99 -22
  240. package/dist/schema/state/sqlite/query-builder/astToSql.js.map +1 -1
  241. package/dist/schema/state/sqlite/query-builder/impl.d.ts +1 -1
  242. package/dist/schema/state/sqlite/query-builder/impl.d.ts.map +1 -1
  243. package/dist/schema/state/sqlite/query-builder/impl.js +28 -15
  244. package/dist/schema/state/sqlite/query-builder/impl.js.map +1 -1
  245. package/dist/schema/state/sqlite/query-builder/impl.test.js +231 -93
  246. package/dist/schema/state/sqlite/query-builder/impl.test.js.map +1 -1
  247. package/dist/schema/state/sqlite/schema-helpers.d.ts +2 -2
  248. package/dist/schema/state/sqlite/schema-helpers.d.ts.map +1 -1
  249. package/dist/schema/state/sqlite/schema-helpers.js +24 -14
  250. package/dist/schema/state/sqlite/schema-helpers.js.map +1 -1
  251. package/dist/schema/state/sqlite/schema-helpers.test.d.ts +2 -0
  252. package/dist/schema/state/sqlite/schema-helpers.test.d.ts.map +1 -0
  253. package/dist/schema/state/sqlite/schema-helpers.test.js +36 -0
  254. package/dist/schema/state/sqlite/schema-helpers.test.js.map +1 -0
  255. package/dist/schema/state/sqlite/{system-tables.d.ts → system-tables/eventlog-tables.d.ts} +21 -450
  256. package/dist/schema/state/sqlite/system-tables/eventlog-tables.d.ts.map +1 -0
  257. package/dist/schema/state/sqlite/system-tables/eventlog-tables.js +54 -0
  258. package/dist/schema/state/sqlite/system-tables/eventlog-tables.js.map +1 -0
  259. package/dist/schema/state/sqlite/system-tables/mod.d.ts +3 -0
  260. package/dist/schema/state/sqlite/system-tables/mod.d.ts.map +1 -0
  261. package/dist/schema/state/sqlite/system-tables/mod.js +3 -0
  262. package/dist/schema/state/sqlite/system-tables/mod.js.map +1 -0
  263. package/dist/schema/state/sqlite/system-tables/state-tables.d.ts +456 -0
  264. package/dist/schema/state/sqlite/system-tables/state-tables.d.ts.map +1 -0
  265. package/dist/schema/state/sqlite/system-tables/state-tables.js +55 -0
  266. package/dist/schema/state/sqlite/system-tables/state-tables.js.map +1 -0
  267. package/dist/schema/state/sqlite/table-def.d.ts +5 -3
  268. package/dist/schema/state/sqlite/table-def.d.ts.map +1 -1
  269. package/dist/schema/state/sqlite/table-def.js +1 -1
  270. package/dist/schema/state/sqlite/table-def.js.map +1 -1
  271. package/dist/schema/state/sqlite/table-def.test.js +92 -3
  272. package/dist/schema/state/sqlite/table-def.test.js.map +1 -1
  273. package/dist/schema/unknown-events.d.ts +47 -0
  274. package/dist/schema/unknown-events.d.ts.map +1 -0
  275. package/dist/schema/unknown-events.js +69 -0
  276. package/dist/schema/unknown-events.js.map +1 -0
  277. package/dist/schema-management/__tests__/migrations-autoincrement-quoting.test.d.ts +2 -0
  278. package/dist/schema-management/__tests__/migrations-autoincrement-quoting.test.d.ts.map +1 -0
  279. package/dist/schema-management/__tests__/migrations-autoincrement-quoting.test.js +73 -0
  280. package/dist/schema-management/__tests__/migrations-autoincrement-quoting.test.js.map +1 -0
  281. package/dist/schema-management/common.js +2 -2
  282. package/dist/schema-management/common.js.map +1 -1
  283. package/dist/schema-management/migrations.d.ts +32 -2
  284. package/dist/schema-management/migrations.d.ts.map +1 -1
  285. package/dist/schema-management/migrations.js +38 -6
  286. package/dist/schema-management/migrations.js.map +1 -1
  287. package/dist/schema-management/validate-schema.d.ts +3 -3
  288. package/dist/schema-management/validate-schema.d.ts.map +1 -1
  289. package/dist/schema-management/validate-schema.js +2 -2
  290. package/dist/schema-management/validate-schema.js.map +1 -1
  291. package/dist/sql-queries/sql-queries.d.ts.map +1 -1
  292. package/dist/sql-queries/sql-queries.js +18 -6
  293. package/dist/sql-queries/sql-queries.js.map +1 -1
  294. package/dist/sql-queries/sql-query-builder.d.ts.map +1 -1
  295. package/dist/sql-queries/sql-query-builder.js.map +1 -1
  296. package/dist/sqlite-db-helper.js +3 -3
  297. package/dist/sqlite-db-helper.js.map +1 -1
  298. package/dist/sqlite-types.d.ts +5 -5
  299. package/dist/sqlite-types.d.ts.map +1 -1
  300. package/dist/sqlite-types.js.map +1 -1
  301. package/dist/sync/ClientSessionSyncProcessor.d.ts +12 -12
  302. package/dist/sync/ClientSessionSyncProcessor.d.ts.map +1 -1
  303. package/dist/sync/ClientSessionSyncProcessor.js +99 -114
  304. package/dist/sync/ClientSessionSyncProcessor.js.map +1 -1
  305. package/dist/sync/errors.d.ts +0 -33
  306. package/dist/sync/errors.d.ts.map +1 -1
  307. package/dist/sync/errors.js +5 -22
  308. package/dist/sync/errors.js.map +1 -1
  309. package/dist/sync/index.d.ts +2 -0
  310. package/dist/sync/index.d.ts.map +1 -1
  311. package/dist/sync/index.js +2 -0
  312. package/dist/sync/index.js.map +1 -1
  313. package/dist/sync/mock-sync-backend.d.ts +10 -8
  314. package/dist/sync/mock-sync-backend.d.ts.map +1 -1
  315. package/dist/sync/mock-sync-backend.js +71 -69
  316. package/dist/sync/mock-sync-backend.js.map +1 -1
  317. package/dist/sync/next/compact-events.d.ts.map +1 -1
  318. package/dist/sync/next/compact-events.js +11 -12
  319. package/dist/sync/next/compact-events.js.map +1 -1
  320. package/dist/sync/next/facts.d.ts +5 -5
  321. package/dist/sync/next/facts.d.ts.map +1 -1
  322. package/dist/sync/next/facts.js +7 -8
  323. package/dist/sync/next/facts.js.map +1 -1
  324. package/dist/sync/next/history-dag-common.d.ts +54 -15
  325. package/dist/sync/next/history-dag-common.d.ts.map +1 -1
  326. package/dist/sync/next/history-dag-common.js +198 -9
  327. package/dist/sync/next/history-dag-common.js.map +1 -1
  328. package/dist/sync/next/history-dag.d.ts.map +1 -1
  329. package/dist/sync/next/history-dag.js +11 -11
  330. package/dist/sync/next/history-dag.js.map +1 -1
  331. package/dist/sync/next/rebase-events.d.ts +5 -5
  332. package/dist/sync/next/rebase-events.d.ts.map +1 -1
  333. package/dist/sync/next/rebase-events.js +6 -6
  334. package/dist/sync/next/rebase-events.js.map +1 -1
  335. package/dist/sync/next/test/compact-events.calculator.test.js +2 -2
  336. package/dist/sync/next/test/compact-events.calculator.test.js.map +1 -1
  337. package/dist/sync/next/test/compact-events.test.d.ts.map +1 -1
  338. package/dist/sync/next/test/compact-events.test.js +2 -2
  339. package/dist/sync/next/test/compact-events.test.js.map +1 -1
  340. package/dist/sync/next/test/event-fixtures.d.ts +2 -2
  341. package/dist/sync/next/test/event-fixtures.d.ts.map +1 -1
  342. package/dist/sync/next/test/event-fixtures.js +11 -11
  343. package/dist/sync/next/test/event-fixtures.js.map +1 -1
  344. package/dist/sync/sync-backend-kv.d.ts +3 -3
  345. package/dist/sync/sync-backend-kv.d.ts.map +1 -1
  346. package/dist/sync/sync-backend-kv.js +3 -3
  347. package/dist/sync/sync-backend-kv.js.map +1 -1
  348. package/dist/sync/sync-backend.d.ts +33 -13
  349. package/dist/sync/sync-backend.d.ts.map +1 -1
  350. package/dist/sync/sync-backend.js +38 -1
  351. package/dist/sync/sync-backend.js.map +1 -1
  352. package/dist/sync/sync.d.ts +23 -2
  353. package/dist/sync/sync.d.ts.map +1 -1
  354. package/dist/sync/syncstate.d.ts +55 -55
  355. package/dist/sync/syncstate.d.ts.map +1 -1
  356. package/dist/sync/syncstate.js +80 -98
  357. package/dist/sync/syncstate.js.map +1 -1
  358. package/dist/sync/syncstate.test.js +221 -132
  359. package/dist/sync/syncstate.test.js.map +1 -1
  360. package/dist/sync/transport-chunking.d.ts +36 -0
  361. package/dist/sync/transport-chunking.d.ts.map +1 -0
  362. package/dist/sync/transport-chunking.js +56 -0
  363. package/dist/sync/transport-chunking.js.map +1 -0
  364. package/dist/sync/validate-push-payload.d.ts +2 -2
  365. package/dist/sync/validate-push-payload.d.ts.map +1 -1
  366. package/dist/sync/validate-push-payload.js +4 -6
  367. package/dist/sync/validate-push-payload.js.map +1 -1
  368. package/dist/testing/event-factory.d.ts +3 -3
  369. package/dist/testing/event-factory.d.ts.map +1 -1
  370. package/dist/testing/event-factory.js +5 -7
  371. package/dist/testing/event-factory.js.map +1 -1
  372. package/dist/util.js +2 -2
  373. package/dist/util.js.map +1 -1
  374. package/dist/version.d.ts +24 -5
  375. package/dist/version.d.ts.map +1 -1
  376. package/dist/version.js +25 -8
  377. package/dist/version.js.map +1 -1
  378. package/package.json +67 -15
  379. package/src/ClientSessionLeaderThreadProxy.ts +27 -12
  380. package/src/WorkerTransportError.ts +12 -0
  381. package/src/adapter-types.ts +50 -7
  382. package/src/bounded-collections.ts +6 -5
  383. package/src/debug-info.ts +37 -6
  384. package/src/devtools/devtools-compatibility.test.ts +18 -0
  385. package/src/devtools/devtools-messages-client-session.ts +22 -4
  386. package/src/devtools/devtools-messages-common.ts +7 -12
  387. package/src/devtools/devtools-messages-leader.ts +29 -10
  388. package/src/devtools/devtools-sessioninfo.ts +8 -5
  389. package/src/devtools/mod.ts +11 -2
  390. package/src/errors.ts +32 -24
  391. package/src/index.ts +4 -1
  392. package/src/leader-thread/LeaderSyncProcessor.ts +523 -373
  393. package/src/leader-thread/RejectedPushError.ts +106 -0
  394. package/src/leader-thread/connection.ts +1 -1
  395. package/src/leader-thread/eventlog.ts +112 -39
  396. package/src/leader-thread/leader-worker-devtools.ts +201 -120
  397. package/src/leader-thread/make-leader-thread-layer.test.ts +44 -0
  398. package/src/leader-thread/make-leader-thread-layer.ts +125 -40
  399. package/src/leader-thread/materialize-event.ts +40 -10
  400. package/src/leader-thread/mod.ts +1 -0
  401. package/src/leader-thread/recreate-db.ts +7 -7
  402. package/src/leader-thread/shutdown-channel.ts +4 -8
  403. package/src/leader-thread/stream-events.ts +206 -0
  404. package/src/leader-thread/types.ts +68 -18
  405. package/src/logging.ts +62 -0
  406. package/src/make-client-session.ts +11 -5
  407. package/src/materializer-helper.ts +27 -16
  408. package/src/otel.ts +13 -2
  409. package/src/rematerialize-from-eventlog.ts +61 -51
  410. package/src/schema/EventDef/define.ts +217 -0
  411. package/src/schema/EventDef/deprecated.test.ts +129 -0
  412. package/src/schema/EventDef/deprecated.ts +175 -0
  413. package/src/schema/EventDef/event-def.ts +125 -0
  414. package/src/schema/EventDef/facts.ts +135 -0
  415. package/src/schema/EventDef/materializer.ts +172 -0
  416. package/src/schema/EventDef/mod.ts +5 -0
  417. package/src/schema/EventSequenceNumber/client.ts +257 -0
  418. package/src/schema/EventSequenceNumber/global.ts +19 -0
  419. package/src/schema/EventSequenceNumber/mod.ts +37 -0
  420. package/src/schema/EventSequenceNumber.test.ts +72 -53
  421. package/src/schema/LiveStoreEvent/client.test.ts +129 -0
  422. package/src/schema/LiveStoreEvent/client.ts +235 -0
  423. package/src/schema/LiveStoreEvent/for-event-def.ts +60 -0
  424. package/src/schema/LiveStoreEvent/global.ts +45 -0
  425. package/src/schema/LiveStoreEvent/input.ts +63 -0
  426. package/src/schema/LiveStoreEvent/mod.ts +4 -0
  427. package/src/schema/events.ts +1 -1
  428. package/src/schema/mod.ts +6 -4
  429. package/src/schema/schema.ts +46 -5
  430. package/src/schema/state/sqlite/client-document-def.test.ts +144 -5
  431. package/src/schema/state/sqlite/client-document-def.ts +47 -34
  432. package/src/schema/state/sqlite/column-annotations.test.ts +3 -2
  433. package/src/schema/state/sqlite/column-annotations.ts +2 -1
  434. package/src/schema/state/sqlite/column-def.test.ts +66 -12
  435. package/src/schema/state/sqlite/column-def.ts +119 -47
  436. package/src/schema/state/sqlite/column-spec.test.ts +32 -17
  437. package/src/schema/state/sqlite/column-spec.ts +37 -11
  438. package/src/schema/state/sqlite/db-schema/ast/sqlite.ts +2 -2
  439. package/src/schema/state/sqlite/db-schema/dsl/field-defs.test.ts +2 -1
  440. package/src/schema/state/sqlite/db-schema/dsl/field-defs.ts +41 -15
  441. package/src/schema/state/sqlite/db-schema/dsl/mod.ts +13 -19
  442. package/src/schema/state/sqlite/mod.ts +7 -8
  443. package/src/schema/state/sqlite/query-builder/api.ts +55 -17
  444. package/src/schema/state/sqlite/query-builder/astToSql.ts +110 -21
  445. package/src/schema/state/sqlite/query-builder/impl.test.ts +267 -93
  446. package/src/schema/state/sqlite/query-builder/impl.ts +26 -13
  447. package/src/schema/state/sqlite/schema-helpers.test.ts +44 -0
  448. package/src/schema/state/sqlite/schema-helpers.ts +30 -22
  449. package/src/schema/state/sqlite/system-tables/eventlog-tables.ts +64 -0
  450. package/src/schema/state/sqlite/system-tables/mod.ts +2 -0
  451. package/src/schema/state/sqlite/system-tables/state-tables.ts +69 -0
  452. package/src/schema/state/sqlite/table-def.test.ts +114 -3
  453. package/src/schema/state/sqlite/table-def.ts +16 -22
  454. package/src/schema/unknown-events.ts +131 -0
  455. package/src/schema-management/__tests__/migrations-autoincrement-quoting.test.ts +88 -0
  456. package/src/schema-management/common.ts +2 -2
  457. package/src/schema-management/migrations.ts +42 -9
  458. package/src/schema-management/validate-schema.ts +3 -3
  459. package/src/sql-queries/sql-queries.ts +18 -6
  460. package/src/sql-queries/sql-query-builder.ts +1 -0
  461. package/src/sqlite-db-helper.ts +3 -3
  462. package/src/sqlite-types.ts +6 -5
  463. package/src/sync/ClientSessionSyncProcessor.ts +152 -142
  464. package/src/sync/errors.ts +12 -24
  465. package/src/sync/index.ts +2 -0
  466. package/src/sync/mock-sync-backend.ts +146 -104
  467. package/src/sync/next/compact-events.ts +10 -11
  468. package/src/sync/next/facts.ts +13 -14
  469. package/src/sync/next/history-dag-common.ts +280 -26
  470. package/src/sync/next/history-dag.ts +17 -13
  471. package/src/sync/next/rebase-events.ts +12 -12
  472. package/src/sync/next/test/compact-events.calculator.test.ts +3 -2
  473. package/src/sync/next/test/compact-events.test.ts +4 -3
  474. package/src/sync/next/test/event-fixtures.ts +13 -13
  475. package/src/sync/sync-backend-kv.ts +4 -3
  476. package/src/sync/sync-backend.ts +66 -17
  477. package/src/sync/sync.ts +24 -2
  478. package/src/sync/syncstate.test.ts +583 -419
  479. package/src/sync/syncstate.ts +127 -122
  480. package/src/sync/transport-chunking.ts +90 -0
  481. package/src/sync/validate-push-payload.ts +6 -8
  482. package/src/testing/event-factory.ts +10 -12
  483. package/src/util.ts +2 -2
  484. package/src/version.ts +33 -8
  485. package/dist/schema/EventDef.d.ts +0 -126
  486. package/dist/schema/EventDef.d.ts.map +0 -1
  487. package/dist/schema/EventDef.js +0 -46
  488. package/dist/schema/EventDef.js.map +0 -1
  489. package/dist/schema/EventSequenceNumber.d.ts +0 -80
  490. package/dist/schema/EventSequenceNumber.d.ts.map +0 -1
  491. package/dist/schema/EventSequenceNumber.js +0 -139
  492. package/dist/schema/EventSequenceNumber.js.map +0 -1
  493. package/dist/schema/LiveStoreEvent.d.ts.map +0 -1
  494. package/dist/schema/LiveStoreEvent.js +0 -147
  495. package/dist/schema/LiveStoreEvent.js.map +0 -1
  496. package/dist/schema/state/sqlite/system-tables.d.ts.map +0 -1
  497. package/dist/schema/state/sqlite/system-tables.js +0 -81
  498. package/dist/schema/state/sqlite/system-tables.js.map +0 -1
  499. package/dist/sync/next/graphology.d.ts +0 -8
  500. package/dist/sync/next/graphology.d.ts.map +0 -1
  501. package/dist/sync/next/graphology.js +0 -30
  502. package/dist/sync/next/graphology.js.map +0 -1
  503. package/dist/sync/next/graphology_.d.ts +0 -3
  504. package/dist/sync/next/graphology_.d.ts.map +0 -1
  505. package/dist/sync/next/graphology_.js +0 -3
  506. package/dist/sync/next/graphology_.js.map +0 -1
  507. package/src/schema/EventDef.ts +0 -222
  508. package/src/schema/EventSequenceNumber.ts +0 -199
  509. package/src/schema/LiveStoreEvent.ts +0 -286
  510. package/src/schema/state/sqlite/system-tables.ts +0 -106
  511. package/src/sync/next/ambient.d.ts +0 -3
  512. package/src/sync/next/graphology.ts +0 -41
  513. package/src/sync/next/graphology_.ts +0 -2
@@ -1,70 +1,106 @@
1
1
  import { Effect, FiberMap, Option, Stream, SubscriptionRef } from '@livestore/utils/effect'
2
2
  import { nanoid } from '@livestore/utils/nanoid'
3
3
 
4
- import { Devtools, IntentionalShutdownCause, liveStoreVersion, UnexpectedError } from '../index.ts'
4
+ import {
5
+ Devtools,
6
+ devtoolsProtocolVersion,
7
+ IntentionalShutdownCause,
8
+ isDevtoolsProtocolVersionSupported,
9
+ liveStoreVersion,
10
+ resolveDevtoolsProtocolVersion,
11
+ UnknownError,
12
+ } from '../index.ts'
5
13
  import { SystemTables } from '../schema/mod.ts'
6
14
  import type { DevtoolsOptions, PersistenceInfoPair } from './types.ts'
7
15
  import { LeaderThreadCtx } from './types.ts'
8
16
 
9
17
  type SendMessageToDevtools = (message: Devtools.Leader.MessageFromApp) => Effect.Effect<void>
10
18
 
11
- // TODO bind scope to the webchannel lifetime
12
- export const bootDevtools = (options: DevtoolsOptions) =>
13
- Effect.gen(function* () {
14
- if (options.enabled === false) {
15
- return
16
- }
17
-
18
- const { syncProcessor, extraIncomingMessagesQueue, clientId, storeId } = yield* LeaderThreadCtx
19
-
20
- yield* listenToDevtools({
21
- incomingMessages: Stream.fromQueue(extraIncomingMessagesQueue),
22
- sendMessage: () => Effect.void,
23
- }).pipe(Effect.tapCauseLogPretty, Effect.forkScoped)
24
-
25
- const { node, persistenceInfo, mode } = yield* options.boot
26
-
27
- yield* node.listenForChannel.pipe(
28
- Stream.filter(
29
- (res) =>
30
- Devtools.isChannelName.devtoolsClientLeader(res.channelName, { storeId, clientId }) && res.mode === mode,
31
- ),
32
- Stream.tap(({ channelName, source }) =>
33
- Effect.gen(function* () {
34
- const channel = yield* node.makeChannel({
35
- target: source,
36
- channelName,
37
- schema: { listen: Devtools.Leader.MessageToApp, send: Devtools.Leader.MessageFromApp },
38
- mode,
39
- })
40
-
41
- const sendMessage: SendMessageToDevtools = (message) =>
42
- channel
43
- .send(message)
44
- .pipe(
45
- Effect.withSpan('@livestore/common:leader-thread:devtools:sendToDevtools'),
46
- Effect.interruptible,
47
- Effect.ignoreLogged,
48
- )
49
-
50
- const syncState = yield* syncProcessor.syncState
19
+ /**
20
+ * Type guard for DevtoolsViteNotInstalledError.
21
+ * This error is defined in @livestore/adapter-node but we need to handle it here.
22
+ */
23
+ const isDevtoolsViteNotInstalledError = (
24
+ error: unknown,
25
+ ): error is { _tag: 'DevtoolsViteNotInstalledError'; message: string } =>
26
+ typeof error === 'object' && error !== null && '_tag' in error && error._tag === 'DevtoolsViteNotInstalledError'
51
27
 
52
- yield* syncProcessor.pull({ cursor: syncState.localHead }).pipe(
53
- Stream.tap(({ payload }) => sendMessage(Devtools.Leader.SyncPull.make({ payload, liveStoreVersion }))),
54
- Stream.runDrain,
55
- Effect.forkScoped,
56
- )
57
-
58
- yield* listenToDevtools({
59
- incomingMessages: channel.listen.pipe(Stream.flatten(), Stream.orDie),
60
- sendMessage,
61
- persistenceInfo,
62
- })
63
- }).pipe(Effect.tapCauseLogPretty, Effect.forkScoped),
28
+ // TODO bind scope to the webchannel lifetime
29
+ export const bootDevtools = Effect.fn('@livestore/common:leader-thread:devtools:boot')(function* (
30
+ options: DevtoolsOptions,
31
+ ) {
32
+ if (options.enabled === false) {
33
+ return
34
+ }
35
+
36
+ const { syncProcessor, extraIncomingMessagesQueue, clientId, storeId } = yield* LeaderThreadCtx
37
+
38
+ yield* listenToDevtools({
39
+ incomingMessages: Stream.fromQueue(extraIncomingMessagesQueue),
40
+ sendMessage: () => Effect.void,
41
+ }).pipe(Effect.tapCauseLogPretty, Effect.forkScoped)
42
+
43
+ const bootResult = yield* options.boot.pipe(
44
+ Effect.map(Option.some),
45
+ Effect.catchIf(isDevtoolsViteNotInstalledError, (error) =>
46
+ Effect.logWarning(`[@livestore/devtools] ${error.message} Devtools will be disabled.`).pipe(
47
+ Effect.as(Option.none()),
64
48
  ),
65
- Stream.runDrain,
66
- )
67
- }).pipe(Effect.withSpan('@livestore/common:leader-thread:devtools:boot'))
49
+ ),
50
+ Effect.catchAllCause((cause) =>
51
+ Effect.logWarning(
52
+ `[@livestore/devtools] Failed to start devtools server. Devtools will be disabled.`,
53
+ cause,
54
+ ).pipe(Effect.as(Option.none())),
55
+ ),
56
+ )
57
+
58
+ if (Option.isNone(bootResult) === true) {
59
+ return
60
+ }
61
+
62
+ const { node, persistenceInfo, mode } = bootResult.value
63
+
64
+ yield* node.listenForChannel.pipe(
65
+ Stream.filter(
66
+ (res) => Devtools.isChannelName.devtoolsClientLeader(res.channelName, { storeId, clientId }) && res.mode === mode,
67
+ ),
68
+ Stream.tap(({ channelName, source }) =>
69
+ Effect.gen(function* () {
70
+ const channel = yield* node.makeChannel({
71
+ target: source,
72
+ channelName,
73
+ schema: { listen: Devtools.Leader.MessageToApp, send: Devtools.Leader.MessageFromApp },
74
+ mode,
75
+ })
76
+
77
+ const sendMessage: SendMessageToDevtools = (message) =>
78
+ channel
79
+ .send(message)
80
+ .pipe(
81
+ Effect.withSpan('@livestore/common:leader-thread:devtools:sendToDevtools'),
82
+ Effect.interruptible,
83
+ Effect.ignoreLogged,
84
+ )
85
+
86
+ const syncState = yield* syncProcessor.syncState
87
+
88
+ yield* syncProcessor.pull({ cursor: syncState.localHead }).pipe(
89
+ Stream.tap(({ payload }) => sendMessage(Devtools.Leader.SyncPull.make({ payload, liveStoreVersion }))),
90
+ Stream.runDrain,
91
+ Effect.forkScoped,
92
+ )
93
+
94
+ yield* listenToDevtools({
95
+ incomingMessages: channel.listen.pipe(Stream.flatten(), Stream.orDie),
96
+ sendMessage,
97
+ persistenceInfo,
98
+ })
99
+ }).pipe(Effect.tapCauseLogPretty, Effect.forkScoped),
100
+ ),
101
+ Stream.runDrain,
102
+ )
103
+ })
68
104
 
69
105
  const listenToDevtools = ({
70
106
  incomingMessages,
@@ -94,6 +130,22 @@ const listenToDevtools = ({
94
130
  type RequestId = string
95
131
  const handledRequestIds = new Set<RequestId>()
96
132
 
133
+ type LoadDatabaseKind = 'state' | 'eventlog'
134
+ const loadDatabaseBatchTracker = new Map<string, Set<LoadDatabaseKind>>()
135
+
136
+ const registerBatchProgress = (batchId: string, kind: LoadDatabaseKind) => {
137
+ const entry = loadDatabaseBatchTracker.get(batchId) ?? new Set<LoadDatabaseKind>()
138
+ entry.add(kind)
139
+ loadDatabaseBatchTracker.set(batchId, entry)
140
+ const finished = entry.has('state') && entry.has('eventlog')
141
+
142
+ if (finished === true) {
143
+ loadDatabaseBatchTracker.delete(batchId)
144
+ }
145
+
146
+ return finished
147
+ }
148
+
97
149
  yield* incomingMessages.pipe(
98
150
  Stream.tap((decodedEvent) =>
99
151
  Effect.gen(function* () {
@@ -113,7 +165,7 @@ const listenToDevtools = ({
113
165
  // So far I could only observe this problem with webmesh proxy channels (e.g. for Expo)
114
166
  // Proof: https://share.cleanshot.com/V9G87B0B
115
167
  // Also see `store/devtools.ts` for same problem
116
- if (handledRequestIds.has(requestId)) {
168
+ if (handledRequestIds.has(requestId) === true) {
117
169
  // yield* Effect.logWarning(`Duplicate message`, decodedEvent)
118
170
  return
119
171
  }
@@ -122,7 +174,19 @@ const listenToDevtools = ({
122
174
 
123
175
  switch (decodedEvent._tag) {
124
176
  case 'LSD.Leader.Ping': {
125
- yield* sendMessage(Devtools.Leader.Pong.make({ ...reqPayload }))
177
+ if (isDevtoolsProtocolVersionSupported(decodedEvent.devtoolsProtocolVersion) === false) {
178
+ yield* sendMessage(
179
+ Devtools.Leader.VersionMismatch.make({
180
+ ...reqPayload,
181
+ appVersion: liveStoreVersion,
182
+ receivedVersion: decodedEvent.liveStoreVersion,
183
+ appDevtoolsProtocolVersion: devtoolsProtocolVersion,
184
+ receivedDevtoolsProtocolVersion: resolveDevtoolsProtocolVersion(decodedEvent.devtoolsProtocolVersion),
185
+ }),
186
+ )
187
+ return
188
+ }
189
+ yield* sendMessage(Devtools.Leader.Pong.make({ ...reqPayload, devtoolsProtocolVersion }))
126
190
  return
127
191
  }
128
192
  case 'LSD.Leader.SnapshotReq': {
@@ -133,74 +197,85 @@ const listenToDevtools = ({
133
197
  return
134
198
  }
135
199
  case 'LSD.Leader.LoadDatabaseFile.Request': {
136
- const { data } = decodedEvent
200
+ const { data, batchId } = decodedEvent
137
201
 
138
- let tableNames: Set<string>
139
-
140
- try {
141
- const tmpDb = yield* makeSqliteDb({ _tag: 'in-memory' })
142
- tmpDb.import(data)
143
- const tableNameResults = tmpDb.select<{ name: string }>(
144
- `select name from sqlite_master where type = 'table'`,
145
- )
146
-
147
- tableNames = new Set(tableNameResults.map((_) => _.name))
148
-
149
- tmpDb.close()
150
- } catch (cause) {
151
- yield* Effect.logError(`Error importing database file`, cause)
152
- yield* sendMessage(
153
- Devtools.Leader.LoadDatabaseFile.Error.make({
154
- ...reqPayload,
155
- cause: { _tag: 'unexpected-error', cause },
156
- }),
202
+ const handleLoadDb = Effect.gen(function* () {
203
+ const tableNames = yield* Effect.acquireRelease(makeSqliteDb({ _tag: 'in-memory' }), (db) =>
204
+ Effect.sync(() => db.close()),
205
+ ).pipe(
206
+ Effect.flatMap((db) =>
207
+ Effect.try(() => {
208
+ db.import(data)
209
+ const rows = db.select<{ name: string }>(`select name from sqlite_master where type = 'table'`)
210
+ return new Set(rows.map((r) => r.name))
211
+ }),
212
+ ),
157
213
  )
158
214
 
159
- return
160
- }
215
+ let databaseKind: LoadDatabaseKind | undefined
161
216
 
162
- try {
163
- if (tableNames.has(SystemTables.EVENTLOG_META_TABLE)) {
164
- // Is eventlog db
217
+ if (tableNames.has(SystemTables.EVENTLOG_META_TABLE) === true) {
218
+ databaseKind = 'eventlog'
165
219
  yield* SubscriptionRef.set(shutdownStateSubRef, 'shutting-down')
220
+ yield* Effect.try(() => dbEventlog.import(data))
166
221
 
167
- dbEventlog.import(data)
168
-
169
- dbState.destroy()
222
+ if (batchId === undefined) {
223
+ yield* Effect.try(() => dbState.destroy())
224
+ }
170
225
  } else if (
171
- tableNames.has(SystemTables.SCHEMA_META_TABLE) &&
172
- tableNames.has(SystemTables.SCHEMA_EVENT_DEFS_META_TABLE)
226
+ tableNames.has(SystemTables.SCHEMA_META_TABLE) === true &&
227
+ tableNames.has(SystemTables.SCHEMA_EVENT_DEFS_META_TABLE) === true
173
228
  ) {
174
- // Is state db
229
+ databaseKind = 'state'
175
230
  yield* SubscriptionRef.set(shutdownStateSubRef, 'shutting-down')
231
+ yield* Effect.try(() => dbState.import(data))
176
232
 
177
- dbState.import(data)
178
-
179
- dbEventlog.destroy()
233
+ if (batchId === undefined) {
234
+ yield* Effect.try(() => dbEventlog.destroy())
235
+ }
180
236
  } else {
181
- yield* sendMessage(
182
- Devtools.Leader.LoadDatabaseFile.Error.make({
183
- ...reqPayload,
184
- cause: { _tag: 'unsupported-database' },
185
- }),
186
- )
187
- return
237
+ return yield* Effect.fail({ _tag: 'unsupported-database' } as const)
188
238
  }
189
239
 
240
+ const resolvedDatabaseKind = databaseKind
241
+ if (resolvedDatabaseKind === undefined) {
242
+ return yield* Effect.fail({ _tag: 'unsupported-database' } as const)
243
+ }
244
+
245
+ const shouldShutdown =
246
+ batchId === undefined ? true : registerBatchProgress(batchId, resolvedDatabaseKind)
247
+
190
248
  yield* sendMessage(Devtools.Leader.LoadDatabaseFile.Success.make({ ...reqPayload }))
191
- yield* shutdownChannel.send(IntentionalShutdownCause.make({ reason: 'devtools-import' })) ?? Effect.void
192
249
 
193
- return
194
- } catch (cause) {
195
- yield* Effect.logError(`Error importing database file`, cause)
196
- yield* sendMessage(
197
- Devtools.Leader.LoadDatabaseFile.Error.make({
198
- ...reqPayload,
199
- cause: { _tag: 'unexpected-error', cause },
200
- }),
201
- )
202
- return
203
- }
250
+ if (shouldShutdown === true) {
251
+ yield* shutdownChannel.send(IntentionalShutdownCause.make({ reason: 'devtools-import' }))
252
+ }
253
+ })
254
+
255
+ yield* handleLoadDb.pipe(
256
+ Effect.catchTag('unsupported-database', () =>
257
+ sendMessage(
258
+ Devtools.Leader.LoadDatabaseFile.Error.make({
259
+ ...reqPayload,
260
+ cause: { _tag: 'unsupported-database' as const },
261
+ }),
262
+ ),
263
+ ),
264
+ Effect.catchAll((cause) =>
265
+ Effect.logWarning('Error importing database file', cause).pipe(
266
+ Effect.zipRight(
267
+ sendMessage(
268
+ Devtools.Leader.LoadDatabaseFile.Error.make({
269
+ ...reqPayload,
270
+ cause: { _tag: 'unknown-error' as const, cause },
271
+ }),
272
+ ),
273
+ ),
274
+ ),
275
+ ),
276
+ )
277
+
278
+ return
204
279
  }
205
280
  case 'LSD.Leader.ResetAllData.Request': {
206
281
  const { mode } = decodedEvent
@@ -215,7 +290,7 @@ const listenToDevtools = ({
215
290
 
216
291
  yield* sendMessage(Devtools.Leader.ResetAllData.Success.make({ ...reqPayload }))
217
292
 
218
- yield* shutdownChannel.send(IntentionalShutdownCause.make({ reason: 'devtools-reset' })) ?? Effect.void
293
+ yield* shutdownChannel.send(IntentionalShutdownCause.make({ reason: 'devtools-reset' }))
219
294
 
220
295
  return
221
296
  }
@@ -286,10 +361,10 @@ const listenToDevtools = ({
286
361
  return
287
362
  }
288
363
  case 'LSD.Leader.SyncHistoryUnsubscribe': {
289
- const { requestId } = decodedEvent
290
- console.log('LSD.SyncHistoryUnsubscribe', requestId)
364
+ const unsubscribeRequestId = decodedEvent.requestId
365
+ console.log('LSD.SyncHistoryUnsubscribe', unsubscribeRequestId)
291
366
 
292
- yield* FiberMap.remove(subscriptionFiberMap, requestId)
367
+ yield* FiberMap.remove(subscriptionFiberMap, unsubscribeRequestId)
293
368
 
294
369
  return
295
370
  }
@@ -314,12 +389,18 @@ const listenToDevtools = ({
314
389
 
315
390
  yield* Stream.zipLatest(
316
391
  syncBackend.isConnected.changes,
317
- devtools.enabled ? devtools.syncBackendLatchState.changes : Stream.make({ latchClosed: false }),
392
+ devtools.enabled === true
393
+ ? devtools.syncBackendLatchState.changes
394
+ : Stream.make({ latchClosed: false }),
318
395
  ).pipe(
319
396
  Stream.tap(([isConnected, { latchClosed }]) =>
320
397
  sendMessage(
321
398
  Devtools.Leader.NetworkStatusRes.make({
322
- networkStatus: { isConnected, timestampMs: Date.now(), latchClosed },
399
+ networkStatus: {
400
+ isConnected,
401
+ timestampMs: Date.now(),
402
+ devtools: { latchClosed },
403
+ },
323
404
  subscriptionId,
324
405
  ...reqPayload,
325
406
  requestId: nanoid(10),
@@ -336,9 +417,9 @@ const listenToDevtools = ({
336
417
  return
337
418
  }
338
419
  case 'LSD.Leader.NetworkStatusUnsubscribe': {
339
- const { requestId } = decodedEvent
420
+ const unsubscribeRequestId = decodedEvent.requestId
340
421
 
341
- yield* FiberMap.remove(subscriptionFiberMap, requestId)
422
+ yield* FiberMap.remove(subscriptionFiberMap, unsubscribeRequestId)
342
423
 
343
424
  return
344
425
  }
@@ -395,7 +476,7 @@ const listenToDevtools = ({
395
476
  }
396
477
  }).pipe(Effect.withSpan(`@livestore/common:leader-thread:onDevtoolsMessage:${decodedEvent._tag}`)),
397
478
  ),
398
- UnexpectedError.mapToUnexpectedErrorStream,
479
+ UnknownError.mapToUnknownErrorStream,
399
480
  Stream.runDrain,
400
481
  )
401
482
  })
@@ -0,0 +1,44 @@
1
+ import { Vitest } from '@livestore/utils-dev/node-vitest'
2
+ import { Effect, Stream, SubscriptionRef } from '@livestore/utils/effect'
3
+
4
+ import { makeMockSyncBackend } from '../sync/mock-sync-backend.ts'
5
+ import type { SyncBackend } from '../sync/sync.ts'
6
+ import { makeNetworkStatusSubscribable } from './make-leader-thread-layer.ts'
7
+ import type { DevtoolsContext } from './types.ts'
8
+
9
+ Vitest.describe('makeNetworkStatusSubscribable', () => {
10
+ Vitest.scopedLive('tracks sync backend connectivity and devtools latch state', () =>
11
+ Effect.gen(function* () {
12
+ const mockBackend = yield* makeMockSyncBackend({ startConnected: false })
13
+ const syncBackend = yield* mockBackend.makeSyncBackend
14
+ const latchStateRef = yield* SubscriptionRef.make<{ latchClosed: boolean }>({ latchClosed: false })
15
+
16
+ const devtoolsContext: DevtoolsContext = {
17
+ enabled: true,
18
+ syncBackendLatch: yield* Effect.makeLatch(true),
19
+ syncBackendLatchState: latchStateRef,
20
+ }
21
+
22
+ const networkStatus = yield* makeNetworkStatusSubscribable({ syncBackend, devtoolsContext })
23
+
24
+ const initial = yield* networkStatus
25
+ Vitest.expect(initial.isConnected).toBe(false)
26
+ Vitest.expect(initial.devtools.latchClosed).toBe(false)
27
+
28
+ const waitFor = (predicate: (status: SyncBackend.NetworkStatus) => boolean) =>
29
+ networkStatus.changes.pipe(Stream.filter(predicate), Stream.runHead, Effect.flatten)
30
+
31
+ const onlineFiber = yield* waitFor((status) => status.isConnected).pipe(Effect.forkScoped)
32
+ yield* mockBackend.connect
33
+ const online = yield* onlineFiber
34
+ Vitest.expect(online.isConnected).toBe(true)
35
+ Vitest.expect(online.timestampMs).toBeGreaterThan(initial.timestampMs)
36
+
37
+ const latchedFiber = yield* waitFor((status) => status.devtools.latchClosed).pipe(Effect.forkScoped)
38
+ yield* SubscriptionRef.set(latchStateRef, { latchClosed: true })
39
+ const latched = yield* latchedFiber
40
+ Vitest.expect(latched.devtools.latchClosed).toBe(true)
41
+ Vitest.expect(latched.timestampMs).toBeGreaterThanOrEqual(online.timestampMs)
42
+ }),
43
+ )
44
+ })