@livestore/common 0.4.0-dev.2 → 0.4.0-dev.20

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 (449) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/ClientSessionLeaderThreadProxy.d.ts +17 -12
  3. package/dist/ClientSessionLeaderThreadProxy.d.ts.map +1 -1
  4. package/dist/ClientSessionLeaderThreadProxy.js.map +1 -1
  5. package/dist/adapter-types.d.ts +14 -6
  6. package/dist/adapter-types.d.ts.map +1 -1
  7. package/dist/adapter-types.js.map +1 -1
  8. package/dist/debug-info.d.ts.map +1 -1
  9. package/dist/debug-info.js +33 -6
  10. package/dist/debug-info.js.map +1 -1
  11. package/dist/devtools/devtools-messages-client-session.d.ts +28 -23
  12. package/dist/devtools/devtools-messages-client-session.d.ts.map +1 -1
  13. package/dist/devtools/devtools-messages-client-session.js +2 -2
  14. package/dist/devtools/devtools-messages-client-session.js.map +1 -1
  15. package/dist/devtools/devtools-messages-common.d.ts +7 -14
  16. package/dist/devtools/devtools-messages-common.d.ts.map +1 -1
  17. package/dist/devtools/devtools-messages-common.js +1 -6
  18. package/dist/devtools/devtools-messages-common.js.map +1 -1
  19. package/dist/devtools/devtools-messages-leader.d.ts +36 -29
  20. package/dist/devtools/devtools-messages-leader.d.ts.map +1 -1
  21. package/dist/devtools/devtools-messages-leader.js +8 -8
  22. package/dist/devtools/devtools-messages-leader.js.map +1 -1
  23. package/dist/devtools/devtools-sessioninfo.d.ts +14 -2
  24. package/dist/devtools/devtools-sessioninfo.d.ts.map +1 -1
  25. package/dist/devtools/devtools-sessioninfo.js +7 -4
  26. package/dist/devtools/devtools-sessioninfo.js.map +1 -1
  27. package/dist/devtools/mod.d.ts +13 -2
  28. package/dist/devtools/mod.d.ts.map +1 -1
  29. package/dist/devtools/mod.js +10 -3
  30. package/dist/devtools/mod.js.map +1 -1
  31. package/dist/errors.d.ts +52 -10
  32. package/dist/errors.d.ts.map +1 -1
  33. package/dist/errors.js +25 -6
  34. package/dist/errors.js.map +1 -1
  35. package/dist/index.d.ts +2 -1
  36. package/dist/index.d.ts.map +1 -1
  37. package/dist/index.js +2 -1
  38. package/dist/index.js.map +1 -1
  39. package/dist/leader-thread/LeaderSyncProcessor.d.ts +8 -4
  40. package/dist/leader-thread/LeaderSyncProcessor.d.ts.map +1 -1
  41. package/dist/leader-thread/LeaderSyncProcessor.js +156 -73
  42. package/dist/leader-thread/LeaderSyncProcessor.js.map +1 -1
  43. package/dist/leader-thread/eventlog.d.ts +15 -21
  44. package/dist/leader-thread/eventlog.d.ts.map +1 -1
  45. package/dist/leader-thread/eventlog.js +18 -18
  46. package/dist/leader-thread/eventlog.js.map +1 -1
  47. package/dist/leader-thread/leader-worker-devtools.d.ts +2 -2
  48. package/dist/leader-thread/leader-worker-devtools.d.ts.map +1 -1
  49. package/dist/leader-thread/leader-worker-devtools.js +30 -42
  50. package/dist/leader-thread/leader-worker-devtools.js.map +1 -1
  51. package/dist/leader-thread/make-leader-thread-layer.d.ts +6 -6
  52. package/dist/leader-thread/make-leader-thread-layer.d.ts.map +1 -1
  53. package/dist/leader-thread/make-leader-thread-layer.js +79 -27
  54. package/dist/leader-thread/make-leader-thread-layer.js.map +1 -1
  55. package/dist/leader-thread/make-leader-thread-layer.test.d.ts +2 -0
  56. package/dist/leader-thread/make-leader-thread-layer.test.d.ts.map +1 -0
  57. package/dist/leader-thread/make-leader-thread-layer.test.js +32 -0
  58. package/dist/leader-thread/make-leader-thread-layer.test.js.map +1 -0
  59. package/dist/leader-thread/materialize-event.d.ts +3 -3
  60. package/dist/leader-thread/materialize-event.d.ts.map +1 -1
  61. package/dist/leader-thread/materialize-event.js +25 -11
  62. package/dist/leader-thread/materialize-event.js.map +1 -1
  63. package/dist/leader-thread/recreate-db.d.ts +2 -3
  64. package/dist/leader-thread/recreate-db.d.ts.map +1 -1
  65. package/dist/leader-thread/recreate-db.js +5 -5
  66. package/dist/leader-thread/recreate-db.js.map +1 -1
  67. package/dist/leader-thread/shutdown-channel.d.ts +2 -2
  68. package/dist/leader-thread/shutdown-channel.d.ts.map +1 -1
  69. package/dist/leader-thread/shutdown-channel.js +2 -2
  70. package/dist/leader-thread/shutdown-channel.js.map +1 -1
  71. package/dist/leader-thread/types.d.ts +21 -19
  72. package/dist/leader-thread/types.d.ts.map +1 -1
  73. package/dist/leader-thread/types.js.map +1 -1
  74. package/dist/logging.d.ts +40 -0
  75. package/dist/logging.d.ts.map +1 -0
  76. package/dist/logging.js +33 -0
  77. package/dist/logging.js.map +1 -0
  78. package/dist/make-client-session.d.ts +5 -3
  79. package/dist/make-client-session.d.ts.map +1 -1
  80. package/dist/make-client-session.js +5 -2
  81. package/dist/make-client-session.js.map +1 -1
  82. package/dist/materializer-helper.d.ts +6 -6
  83. package/dist/materializer-helper.d.ts.map +1 -1
  84. package/dist/materializer-helper.js +20 -4
  85. package/dist/materializer-helper.js.map +1 -1
  86. package/dist/rematerialize-from-eventlog.d.ts +2 -2
  87. package/dist/rematerialize-from-eventlog.d.ts.map +1 -1
  88. package/dist/rematerialize-from-eventlog.js +29 -20
  89. package/dist/rematerialize-from-eventlog.js.map +1 -1
  90. package/dist/schema/EventDef/define.d.ts +147 -0
  91. package/dist/schema/EventDef/define.d.ts.map +1 -0
  92. package/dist/schema/EventDef/define.js +139 -0
  93. package/dist/schema/EventDef/define.js.map +1 -0
  94. package/dist/schema/EventDef/event-def.d.ts +106 -0
  95. package/dist/schema/EventDef/event-def.d.ts.map +1 -0
  96. package/dist/schema/EventDef/event-def.js +2 -0
  97. package/dist/schema/EventDef/event-def.js.map +1 -0
  98. package/dist/schema/EventDef/facts.d.ts +118 -0
  99. package/dist/schema/EventDef/facts.d.ts.map +1 -0
  100. package/dist/schema/EventDef/facts.js +53 -0
  101. package/dist/schema/EventDef/facts.js.map +1 -0
  102. package/dist/schema/EventDef/materializer.d.ts +155 -0
  103. package/dist/schema/EventDef/materializer.d.ts.map +1 -0
  104. package/dist/schema/EventDef/materializer.js +83 -0
  105. package/dist/schema/EventDef/materializer.js.map +1 -0
  106. package/dist/schema/EventDef/mod.d.ts +5 -0
  107. package/dist/schema/EventDef/mod.d.ts.map +1 -0
  108. package/dist/schema/EventDef/mod.js +5 -0
  109. package/dist/schema/EventDef/mod.js.map +1 -0
  110. package/dist/schema/EventSequenceNumber/client.d.ts +136 -0
  111. package/dist/schema/EventSequenceNumber/client.d.ts.map +1 -0
  112. package/dist/schema/EventSequenceNumber/client.js +193 -0
  113. package/dist/schema/EventSequenceNumber/client.js.map +1 -0
  114. package/dist/schema/EventSequenceNumber/global.d.ts +15 -0
  115. package/dist/schema/EventSequenceNumber/global.d.ts.map +1 -0
  116. package/dist/schema/EventSequenceNumber/global.js +14 -0
  117. package/dist/schema/EventSequenceNumber/global.js.map +1 -0
  118. package/dist/schema/EventSequenceNumber/mod.d.ts +37 -0
  119. package/dist/schema/EventSequenceNumber/mod.d.ts.map +1 -0
  120. package/dist/schema/EventSequenceNumber/mod.js +37 -0
  121. package/dist/schema/EventSequenceNumber/mod.js.map +1 -0
  122. package/dist/schema/EventSequenceNumber.test.js +43 -43
  123. package/dist/schema/EventSequenceNumber.test.js.map +1 -1
  124. package/dist/schema/{LiveStoreEvent.d.ts → LiveStoreEvent/client.d.ts} +89 -106
  125. package/dist/schema/LiveStoreEvent/client.d.ts.map +1 -0
  126. package/dist/schema/{LiveStoreEvent.js → LiveStoreEvent/client.js} +74 -58
  127. package/dist/schema/LiveStoreEvent/client.js.map +1 -0
  128. package/dist/schema/LiveStoreEvent/for-event-def.d.ts +52 -0
  129. package/dist/schema/LiveStoreEvent/for-event-def.d.ts.map +1 -0
  130. package/dist/schema/LiveStoreEvent/for-event-def.js +2 -0
  131. package/dist/schema/LiveStoreEvent/for-event-def.js.map +1 -0
  132. package/dist/schema/LiveStoreEvent/global.d.ts +36 -0
  133. package/dist/schema/LiveStoreEvent/global.d.ts.map +1 -0
  134. package/dist/schema/LiveStoreEvent/global.js +31 -0
  135. package/dist/schema/LiveStoreEvent/global.js.map +1 -0
  136. package/dist/schema/LiveStoreEvent/input.d.ts +46 -0
  137. package/dist/schema/LiveStoreEvent/input.d.ts.map +1 -0
  138. package/dist/schema/LiveStoreEvent/input.js +26 -0
  139. package/dist/schema/LiveStoreEvent/input.js.map +1 -0
  140. package/dist/schema/LiveStoreEvent/mod.d.ts +5 -0
  141. package/dist/schema/LiveStoreEvent/mod.d.ts.map +1 -0
  142. package/dist/schema/LiveStoreEvent/mod.js +5 -0
  143. package/dist/schema/LiveStoreEvent/mod.js.map +1 -0
  144. package/dist/schema/events.d.ts +1 -1
  145. package/dist/schema/events.d.ts.map +1 -1
  146. package/dist/schema/events.js +1 -1
  147. package/dist/schema/events.js.map +1 -1
  148. package/dist/schema/mod.d.ts +6 -4
  149. package/dist/schema/mod.d.ts.map +1 -1
  150. package/dist/schema/mod.js +5 -4
  151. package/dist/schema/mod.js.map +1 -1
  152. package/dist/schema/schema.d.ts +16 -1
  153. package/dist/schema/schema.d.ts.map +1 -1
  154. package/dist/schema/schema.js +27 -2
  155. package/dist/schema/schema.js.map +1 -1
  156. package/dist/schema/state/sqlite/client-document-def.d.ts +36 -6
  157. package/dist/schema/state/sqlite/client-document-def.d.ts.map +1 -1
  158. package/dist/schema/state/sqlite/client-document-def.js +97 -6
  159. package/dist/schema/state/sqlite/client-document-def.js.map +1 -1
  160. package/dist/schema/state/sqlite/client-document-def.test.js +16 -0
  161. package/dist/schema/state/sqlite/client-document-def.test.js.map +1 -1
  162. package/dist/schema/state/sqlite/column-annotations.d.ts.map +1 -1
  163. package/dist/schema/state/sqlite/column-annotations.js +14 -6
  164. package/dist/schema/state/sqlite/column-annotations.js.map +1 -1
  165. package/dist/schema/state/sqlite/column-annotations.test.js +1 -1
  166. package/dist/schema/state/sqlite/column-annotations.test.js.map +1 -1
  167. package/dist/schema/state/sqlite/column-def.js +69 -22
  168. package/dist/schema/state/sqlite/column-def.js.map +1 -1
  169. package/dist/schema/state/sqlite/column-def.test.js +46 -7
  170. package/dist/schema/state/sqlite/column-def.test.js.map +1 -1
  171. package/dist/schema/state/sqlite/column-spec.d.ts.map +1 -1
  172. package/dist/schema/state/sqlite/column-spec.js +30 -12
  173. package/dist/schema/state/sqlite/column-spec.js.map +1 -1
  174. package/dist/schema/state/sqlite/column-spec.test.js +23 -14
  175. package/dist/schema/state/sqlite/column-spec.test.js.map +1 -1
  176. package/dist/schema/state/sqlite/db-schema/ast/sqlite.d.ts +2 -1
  177. package/dist/schema/state/sqlite/db-schema/ast/sqlite.d.ts.map +1 -1
  178. package/dist/schema/state/sqlite/db-schema/ast/sqlite.js +23 -6
  179. package/dist/schema/state/sqlite/db-schema/ast/sqlite.js.map +1 -1
  180. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts +14 -8
  181. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts.map +1 -1
  182. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js +5 -3
  183. package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js.map +1 -1
  184. package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts.map +1 -1
  185. package/dist/schema/state/sqlite/db-schema/dsl/mod.js +2 -1
  186. package/dist/schema/state/sqlite/db-schema/dsl/mod.js.map +1 -1
  187. package/dist/schema/state/sqlite/mod.d.ts +3 -3
  188. package/dist/schema/state/sqlite/mod.d.ts.map +1 -1
  189. package/dist/schema/state/sqlite/mod.js +3 -3
  190. package/dist/schema/state/sqlite/mod.js.map +1 -1
  191. package/dist/schema/state/sqlite/query-builder/api.d.ts +17 -10
  192. package/dist/schema/state/sqlite/query-builder/api.d.ts.map +1 -1
  193. package/dist/schema/state/sqlite/query-builder/astToSql.d.ts.map +1 -1
  194. package/dist/schema/state/sqlite/query-builder/astToSql.js +22 -15
  195. package/dist/schema/state/sqlite/query-builder/astToSql.js.map +1 -1
  196. package/dist/schema/state/sqlite/query-builder/impl.d.ts.map +1 -1
  197. package/dist/schema/state/sqlite/query-builder/impl.js +6 -3
  198. package/dist/schema/state/sqlite/query-builder/impl.js.map +1 -1
  199. package/dist/schema/state/sqlite/query-builder/impl.test.js +252 -88
  200. package/dist/schema/state/sqlite/query-builder/impl.test.js.map +1 -1
  201. package/dist/schema/state/sqlite/schema-helpers.d.ts +2 -2
  202. package/dist/schema/state/sqlite/schema-helpers.d.ts.map +1 -1
  203. package/dist/schema/state/sqlite/schema-helpers.js +22 -12
  204. package/dist/schema/state/sqlite/schema-helpers.js.map +1 -1
  205. package/dist/schema/state/sqlite/schema-helpers.test.d.ts +2 -0
  206. package/dist/schema/state/sqlite/schema-helpers.test.d.ts.map +1 -0
  207. package/dist/schema/state/sqlite/schema-helpers.test.js +36 -0
  208. package/dist/schema/state/sqlite/schema-helpers.test.js.map +1 -0
  209. package/dist/schema/state/sqlite/{system-tables.d.ts → system-tables/eventlog-tables.d.ts} +63 -456
  210. package/dist/schema/state/sqlite/system-tables/eventlog-tables.d.ts.map +1 -0
  211. package/dist/schema/state/sqlite/system-tables/eventlog-tables.js +54 -0
  212. package/dist/schema/state/sqlite/system-tables/eventlog-tables.js.map +1 -0
  213. package/dist/schema/state/sqlite/system-tables/mod.d.ts +3 -0
  214. package/dist/schema/state/sqlite/system-tables/mod.d.ts.map +1 -0
  215. package/dist/schema/state/sqlite/system-tables/mod.js +3 -0
  216. package/dist/schema/state/sqlite/system-tables/mod.js.map +1 -0
  217. package/dist/schema/state/sqlite/system-tables/state-tables.d.ts +456 -0
  218. package/dist/schema/state/sqlite/system-tables/state-tables.d.ts.map +1 -0
  219. package/dist/schema/state/sqlite/system-tables/state-tables.js +55 -0
  220. package/dist/schema/state/sqlite/system-tables/state-tables.js.map +1 -0
  221. package/dist/schema/state/sqlite/table-def.d.ts +4 -4
  222. package/dist/schema/state/sqlite/table-def.d.ts.map +1 -1
  223. package/dist/schema/state/sqlite/table-def.js +2 -2
  224. package/dist/schema/state/sqlite/table-def.js.map +1 -1
  225. package/dist/schema/state/sqlite/table-def.test.js +80 -0
  226. package/dist/schema/state/sqlite/table-def.test.js.map +1 -1
  227. package/dist/schema/unknown-events.d.ts +47 -0
  228. package/dist/schema/unknown-events.d.ts.map +1 -0
  229. package/dist/schema/unknown-events.js +69 -0
  230. package/dist/schema/unknown-events.js.map +1 -0
  231. package/dist/schema-management/__tests__/migrations-autoincrement-quoting.test.d.ts +2 -0
  232. package/dist/schema-management/__tests__/migrations-autoincrement-quoting.test.d.ts.map +1 -0
  233. package/dist/schema-management/__tests__/migrations-autoincrement-quoting.test.js +73 -0
  234. package/dist/schema-management/__tests__/migrations-autoincrement-quoting.test.js.map +1 -0
  235. package/dist/schema-management/migrations.d.ts +32 -2
  236. package/dist/schema-management/migrations.d.ts.map +1 -1
  237. package/dist/schema-management/migrations.js +37 -5
  238. package/dist/schema-management/migrations.js.map +1 -1
  239. package/dist/schema-management/validate-schema.d.ts +3 -3
  240. package/dist/schema-management/validate-schema.d.ts.map +1 -1
  241. package/dist/schema-management/validate-schema.js +2 -2
  242. package/dist/schema-management/validate-schema.js.map +1 -1
  243. package/dist/sql-queries/sql-queries.d.ts.map +1 -1
  244. package/dist/sql-queries/sql-queries.js +11 -1
  245. package/dist/sql-queries/sql-queries.js.map +1 -1
  246. package/dist/sql-queries/sql-query-builder.d.ts.map +1 -1
  247. package/dist/sql-queries/sql-query-builder.js +2 -1
  248. package/dist/sql-queries/sql-query-builder.js.map +1 -1
  249. package/dist/sqlite-types.d.ts +3 -3
  250. package/dist/sqlite-types.d.ts.map +1 -1
  251. package/dist/sync/ClientSessionSyncProcessor.d.ts +11 -13
  252. package/dist/sync/ClientSessionSyncProcessor.d.ts.map +1 -1
  253. package/dist/sync/ClientSessionSyncProcessor.js +45 -42
  254. package/dist/sync/ClientSessionSyncProcessor.js.map +1 -1
  255. package/dist/sync/errors.d.ts +66 -0
  256. package/dist/sync/errors.d.ts.map +1 -0
  257. package/dist/sync/errors.js +36 -0
  258. package/dist/sync/errors.js.map +1 -0
  259. package/dist/sync/index.d.ts +3 -0
  260. package/dist/sync/index.d.ts.map +1 -1
  261. package/dist/sync/index.js +3 -0
  262. package/dist/sync/index.js.map +1 -1
  263. package/dist/sync/mock-sync-backend.d.ts +23 -0
  264. package/dist/sync/mock-sync-backend.d.ts.map +1 -0
  265. package/dist/sync/mock-sync-backend.js +114 -0
  266. package/dist/sync/mock-sync-backend.js.map +1 -0
  267. package/dist/sync/next/compact-events.d.ts.map +1 -1
  268. package/dist/sync/next/compact-events.js +6 -7
  269. package/dist/sync/next/compact-events.js.map +1 -1
  270. package/dist/sync/next/facts.d.ts +5 -5
  271. package/dist/sync/next/facts.d.ts.map +1 -1
  272. package/dist/sync/next/facts.js +1 -2
  273. package/dist/sync/next/facts.js.map +1 -1
  274. package/dist/sync/next/history-dag-common.d.ts +54 -15
  275. package/dist/sync/next/history-dag-common.d.ts.map +1 -1
  276. package/dist/sync/next/history-dag-common.js +198 -9
  277. package/dist/sync/next/history-dag-common.js.map +1 -1
  278. package/dist/sync/next/history-dag.d.ts.map +1 -1
  279. package/dist/sync/next/history-dag.js +10 -8
  280. package/dist/sync/next/history-dag.js.map +1 -1
  281. package/dist/sync/next/rebase-events.d.ts +5 -5
  282. package/dist/sync/next/rebase-events.d.ts.map +1 -1
  283. package/dist/sync/next/rebase-events.js +5 -5
  284. package/dist/sync/next/rebase-events.js.map +1 -1
  285. package/dist/sync/next/test/event-fixtures.d.ts +2 -2
  286. package/dist/sync/next/test/event-fixtures.d.ts.map +1 -1
  287. package/dist/sync/next/test/event-fixtures.js +9 -9
  288. package/dist/sync/next/test/event-fixtures.js.map +1 -1
  289. package/dist/sync/sync-backend-kv.d.ts +7 -0
  290. package/dist/sync/sync-backend-kv.d.ts.map +1 -0
  291. package/dist/sync/sync-backend-kv.js +18 -0
  292. package/dist/sync/sync-backend-kv.js.map +1 -0
  293. package/dist/sync/sync-backend.d.ts +105 -0
  294. package/dist/sync/sync-backend.d.ts.map +1 -0
  295. package/dist/sync/sync-backend.js +61 -0
  296. package/dist/sync/sync-backend.js.map +1 -0
  297. package/dist/sync/sync.d.ts +9 -86
  298. package/dist/sync/sync.d.ts.map +1 -1
  299. package/dist/sync/sync.js +2 -27
  300. package/dist/sync/sync.js.map +1 -1
  301. package/dist/sync/syncstate.d.ts +57 -44
  302. package/dist/sync/syncstate.d.ts.map +1 -1
  303. package/dist/sync/syncstate.js +50 -45
  304. package/dist/sync/syncstate.js.map +1 -1
  305. package/dist/sync/syncstate.test.js +83 -46
  306. package/dist/sync/syncstate.test.js.map +1 -1
  307. package/dist/sync/transport-chunking.d.ts +36 -0
  308. package/dist/sync/transport-chunking.d.ts.map +1 -0
  309. package/dist/sync/transport-chunking.js +56 -0
  310. package/dist/sync/transport-chunking.js.map +1 -0
  311. package/dist/sync/validate-push-payload.d.ts +2 -2
  312. package/dist/sync/validate-push-payload.d.ts.map +1 -1
  313. package/dist/sync/validate-push-payload.js +6 -6
  314. package/dist/sync/validate-push-payload.js.map +1 -1
  315. package/dist/testing/event-factory.d.ts +68 -0
  316. package/dist/testing/event-factory.d.ts.map +1 -0
  317. package/dist/testing/event-factory.js +78 -0
  318. package/dist/testing/event-factory.js.map +1 -0
  319. package/dist/testing/mod.d.ts +2 -0
  320. package/dist/testing/mod.d.ts.map +1 -0
  321. package/dist/testing/mod.js +2 -0
  322. package/dist/testing/mod.js.map +1 -0
  323. package/dist/version.d.ts +16 -6
  324. package/dist/version.d.ts.map +1 -1
  325. package/dist/version.js +16 -6
  326. package/dist/version.js.map +1 -1
  327. package/package.json +7 -8
  328. package/src/ClientSessionLeaderThreadProxy.ts +17 -12
  329. package/src/adapter-types.ts +18 -6
  330. package/src/debug-info.ts +37 -6
  331. package/src/devtools/devtools-messages-client-session.ts +2 -2
  332. package/src/devtools/devtools-messages-common.ts +1 -8
  333. package/src/devtools/devtools-messages-leader.ts +8 -8
  334. package/src/devtools/devtools-sessioninfo.ts +8 -5
  335. package/src/devtools/mod.ts +11 -2
  336. package/src/errors.ts +38 -11
  337. package/src/index.ts +2 -1
  338. package/src/leader-thread/LeaderSyncProcessor.ts +242 -103
  339. package/src/leader-thread/eventlog.ts +33 -34
  340. package/src/leader-thread/leader-worker-devtools.ts +50 -54
  341. package/src/leader-thread/make-leader-thread-layer.test.ts +44 -0
  342. package/src/leader-thread/make-leader-thread-layer.ts +156 -37
  343. package/src/leader-thread/materialize-event.ts +37 -12
  344. package/src/leader-thread/recreate-db.ts +15 -7
  345. package/src/leader-thread/shutdown-channel.ts +16 -2
  346. package/src/leader-thread/types.ts +21 -19
  347. package/src/logging.ts +62 -0
  348. package/src/make-client-session.ts +9 -3
  349. package/src/materializer-helper.ts +27 -10
  350. package/src/rematerialize-from-eventlog.ts +37 -27
  351. package/src/schema/EventDef/define.ts +201 -0
  352. package/src/schema/EventDef/event-def.ts +120 -0
  353. package/src/schema/EventDef/facts.ts +135 -0
  354. package/src/schema/EventDef/materializer.ts +172 -0
  355. package/src/schema/EventDef/mod.ts +4 -0
  356. package/src/schema/EventSequenceNumber/client.ts +257 -0
  357. package/src/schema/EventSequenceNumber/global.ts +19 -0
  358. package/src/schema/EventSequenceNumber/mod.ts +37 -0
  359. package/src/schema/EventSequenceNumber.test.ts +70 -52
  360. package/src/schema/LiveStoreEvent/client.ts +221 -0
  361. package/src/schema/LiveStoreEvent/for-event-def.ts +60 -0
  362. package/src/schema/LiveStoreEvent/global.ts +45 -0
  363. package/src/schema/LiveStoreEvent/input.ts +63 -0
  364. package/src/schema/LiveStoreEvent/mod.ts +4 -0
  365. package/src/schema/events.ts +1 -1
  366. package/src/schema/mod.ts +6 -4
  367. package/src/schema/schema.ts +39 -3
  368. package/src/schema/state/sqlite/client-document-def.test.ts +19 -2
  369. package/src/schema/state/sqlite/client-document-def.ts +120 -8
  370. package/src/schema/state/sqlite/column-annotations.test.ts +1 -1
  371. package/src/schema/state/sqlite/column-annotations.ts +16 -6
  372. package/src/schema/state/sqlite/column-def.test.ts +60 -7
  373. package/src/schema/state/sqlite/column-def.ts +88 -21
  374. package/src/schema/state/sqlite/column-spec.test.ts +29 -16
  375. package/src/schema/state/sqlite/column-spec.ts +36 -11
  376. package/src/schema/state/sqlite/db-schema/ast/sqlite.ts +26 -6
  377. package/src/schema/state/sqlite/db-schema/dsl/field-defs.ts +29 -12
  378. package/src/schema/state/sqlite/db-schema/dsl/mod.ts +2 -1
  379. package/src/schema/state/sqlite/mod.ts +4 -3
  380. package/src/schema/state/sqlite/query-builder/api.ts +19 -10
  381. package/src/schema/state/sqlite/query-builder/astToSql.ts +23 -14
  382. package/src/schema/state/sqlite/query-builder/impl.test.ts +305 -92
  383. package/src/schema/state/sqlite/query-builder/impl.ts +8 -3
  384. package/src/schema/state/sqlite/schema-helpers.test.ts +44 -0
  385. package/src/schema/state/sqlite/schema-helpers.ts +28 -20
  386. package/src/schema/state/sqlite/system-tables/eventlog-tables.ts +64 -0
  387. package/src/schema/state/sqlite/system-tables/mod.ts +2 -0
  388. package/src/schema/state/sqlite/system-tables/state-tables.ts +69 -0
  389. package/src/schema/state/sqlite/table-def.test.ts +101 -0
  390. package/src/schema/state/sqlite/table-def.ts +9 -8
  391. package/src/schema/unknown-events.ts +131 -0
  392. package/src/schema-management/__tests__/migrations-autoincrement-quoting.test.ts +86 -0
  393. package/src/schema-management/migrations.ts +41 -8
  394. package/src/schema-management/validate-schema.ts +3 -3
  395. package/src/sql-queries/sql-queries.ts +9 -1
  396. package/src/sql-queries/sql-query-builder.ts +2 -1
  397. package/src/sqlite-types.ts +3 -3
  398. package/src/sync/ClientSessionSyncProcessor.ts +69 -62
  399. package/src/sync/errors.ts +38 -0
  400. package/src/sync/index.ts +3 -0
  401. package/src/sync/mock-sync-backend.ts +184 -0
  402. package/src/sync/next/compact-events.ts +6 -7
  403. package/src/sync/next/facts.ts +7 -9
  404. package/src/sync/next/history-dag-common.ts +277 -26
  405. package/src/sync/next/history-dag.ts +16 -10
  406. package/src/sync/next/rebase-events.ts +11 -11
  407. package/src/sync/next/test/event-fixtures.ts +11 -11
  408. package/src/sync/sync-backend-kv.ts +22 -0
  409. package/src/sync/sync-backend.ts +185 -0
  410. package/src/sync/sync.ts +9 -91
  411. package/src/sync/syncstate.test.ts +96 -52
  412. package/src/sync/syncstate.ts +69 -58
  413. package/src/sync/transport-chunking.ts +90 -0
  414. package/src/sync/validate-push-payload.ts +8 -9
  415. package/src/testing/event-factory.ts +131 -0
  416. package/src/testing/mod.ts +1 -0
  417. package/src/version.ts +16 -6
  418. package/dist/schema/EventDef.d.ts +0 -123
  419. package/dist/schema/EventDef.d.ts.map +0 -1
  420. package/dist/schema/EventDef.js +0 -46
  421. package/dist/schema/EventDef.js.map +0 -1
  422. package/dist/schema/EventSequenceNumber.d.ts +0 -80
  423. package/dist/schema/EventSequenceNumber.d.ts.map +0 -1
  424. package/dist/schema/EventSequenceNumber.js +0 -139
  425. package/dist/schema/EventSequenceNumber.js.map +0 -1
  426. package/dist/schema/LiveStoreEvent.d.ts.map +0 -1
  427. package/dist/schema/LiveStoreEvent.js.map +0 -1
  428. package/dist/schema/state/sqlite/system-tables.d.ts.map +0 -1
  429. package/dist/schema/state/sqlite/system-tables.js +0 -79
  430. package/dist/schema/state/sqlite/system-tables.js.map +0 -1
  431. package/dist/schema-management/migrations.test.d.ts +0 -2
  432. package/dist/schema-management/migrations.test.d.ts.map +0 -1
  433. package/dist/schema-management/migrations.test.js +0 -52
  434. package/dist/schema-management/migrations.test.js.map +0 -1
  435. package/dist/sync/next/graphology.d.ts +0 -8
  436. package/dist/sync/next/graphology.d.ts.map +0 -1
  437. package/dist/sync/next/graphology.js +0 -30
  438. package/dist/sync/next/graphology.js.map +0 -1
  439. package/dist/sync/next/graphology_.d.ts +0 -3
  440. package/dist/sync/next/graphology_.d.ts.map +0 -1
  441. package/dist/sync/next/graphology_.js +0 -3
  442. package/dist/sync/next/graphology_.js.map +0 -1
  443. package/src/schema/EventDef.ts +0 -219
  444. package/src/schema/EventSequenceNumber.ts +0 -199
  445. package/src/schema/LiveStoreEvent.ts +0 -287
  446. package/src/schema/state/sqlite/system-tables.ts +0 -104
  447. package/src/sync/next/ambient.d.ts +0 -3
  448. package/src/sync/next/graphology.ts +0 -41
  449. package/src/sync/next/graphology_.ts +0 -2
@@ -0,0 +1,147 @@
1
+ /**
2
+ * Event Definition Functions
3
+ *
4
+ * This module provides functions for creating event definitions in LiveStore.
5
+ * Events are the core unit of state change - all mutations to the database
6
+ * happen through events that are committed to the eventlog.
7
+ *
8
+ * @example
9
+ * ```ts
10
+ * import { Events } from '@livestore/livestore'
11
+ * import { Schema } from 'effect'
12
+ *
13
+ * // Define events for your application
14
+ * export const events = {
15
+ * // Synced events are sent to the sync backend
16
+ * todoCreated: Events.synced({
17
+ * name: 'v1.TodoCreated',
18
+ * schema: Schema.Struct({ id: Schema.String, text: Schema.String }),
19
+ * }),
20
+ *
21
+ * // Client-only events stay local (useful for UI state)
22
+ * uiStateSet: Events.clientOnly({
23
+ * name: 'UiStateSet',
24
+ * schema: Schema.Struct({ selectedId: Schema.NullOr(Schema.String) }),
25
+ * }),
26
+ * }
27
+ * ```
28
+ * @module
29
+ */
30
+ import { Schema } from '@livestore/utils/effect';
31
+ import type { EventDef } from './event-def.ts';
32
+ import type { EventDefFactInput, EventDefFacts } from './facts.ts';
33
+ /** Options for defining an event. */
34
+ export type DefineEventOptions<TTo, TDerived extends boolean = false> = {
35
+ /**
36
+ * Callback defining fact constraints for this event.
37
+ * @experimental This feature is not fully implemented yet.
38
+ */
39
+ facts?: (args: TTo, currentFacts: EventDefFacts) => {
40
+ modify?: {
41
+ /** Facts to set (create or update). */
42
+ set?: Iterable<EventDefFactInput>;
43
+ /** Facts to unset (remove). */
44
+ unset?: Iterable<EventDefFactInput>;
45
+ };
46
+ /**
47
+ * Facts that must exist for this event to be valid.
48
+ * Used for history constraints and compaction rules.
49
+ */
50
+ require?: Iterable<EventDefFactInput>;
51
+ };
52
+ /**
53
+ * When true, the event is only synced within the same client's sessions
54
+ * but never sent to the sync backend. Useful for UI state.
55
+ * @default false
56
+ */
57
+ clientOnly?: boolean;
58
+ /**
59
+ * When true, marks this as a derived event that cannot have materializers.
60
+ * @default false
61
+ */
62
+ derived?: TDerived;
63
+ };
64
+ /**
65
+ * Creates an event definition with full control over all options.
66
+ *
67
+ * This is the low-level function for creating events. For most cases,
68
+ * prefer using `synced()` or `clientOnly()` which provide simpler APIs.
69
+ *
70
+ * @example
71
+ * ```ts
72
+ * const customEvent = defineEvent({
73
+ * name: 'v1.CustomEvent',
74
+ * schema: Schema.Struct({ data: Schema.String }),
75
+ * clientOnly: false,
76
+ * derived: false,
77
+ * })
78
+ * ```
79
+ */
80
+ export declare const defineEvent: <TName extends string, TType, TEncoded = TType, TDerived extends boolean = false>(args: {
81
+ name: TName;
82
+ schema: Schema.Schema<TType, TEncoded>;
83
+ } & DefineEventOptions<TType, TDerived>) => EventDef<TName, TType, TEncoded, TDerived>;
84
+ /**
85
+ * Creates a synced event definition.
86
+ *
87
+ * Synced events are sent to the sync backend and distributed to all connected
88
+ * clients. Use this for collaborative data that should be shared across users
89
+ * and devices.
90
+ *
91
+ * Event names should be versioned (e.g., `v1.TodoCreated`) to support
92
+ * schema evolution over time.
93
+ *
94
+ * @example
95
+ * ```ts
96
+ * import { Events } from '@livestore/livestore'
97
+ * import { Schema } from 'effect'
98
+ *
99
+ * const todoCreated = Events.synced({
100
+ * name: 'v1.TodoCreated',
101
+ * schema: Schema.Struct({
102
+ * id: Schema.String,
103
+ * text: Schema.String,
104
+ * completed: Schema.Boolean,
105
+ * }),
106
+ * })
107
+ *
108
+ * // Commit the event
109
+ * store.commit(todoCreated({ id: 'abc', text: 'Buy milk', completed: false }))
110
+ * ```
111
+ */
112
+ export declare const synced: <TName extends string, TType, TEncoded = TType>(args: {
113
+ name: TName;
114
+ schema: Schema.Schema<TType, TEncoded>;
115
+ } & Omit<DefineEventOptions<TType, false>, "derived" | "clientOnly">) => EventDef<TName, TType, TEncoded>;
116
+ /**
117
+ * Creates a client-only event definition.
118
+ *
119
+ * Client-only events are synced within the same client's sessions (e.g., across
120
+ * browser tabs) but are never sent to the sync backend. Use this for local UI
121
+ * state like selected items, filter settings, or draft content.
122
+ *
123
+ * Note: Client-only events still require materializers and are stored in the
124
+ * local eventlog, they just don't participate in server-side sync.
125
+ *
126
+ * @example
127
+ * ```ts
128
+ * import { Events } from '@livestore/livestore'
129
+ * import { Schema } from 'effect'
130
+ *
131
+ * const uiStateSet = Events.clientOnly({
132
+ * name: 'UiStateSet',
133
+ * schema: Schema.Struct({
134
+ * selectedTodoId: Schema.NullOr(Schema.String),
135
+ * filterMode: Schema.Literal('all', 'active', 'completed'),
136
+ * }),
137
+ * })
138
+ *
139
+ * // Update local UI state
140
+ * store.commit(uiStateSet({ selectedTodoId: 'abc', filterMode: 'active' }))
141
+ * ```
142
+ */
143
+ export declare const clientOnly: <TName extends string, TType, TEncoded = TType>(args: {
144
+ name: TName;
145
+ schema: Schema.Schema<TType, TEncoded>;
146
+ } & Omit<DefineEventOptions<TType, false>, "derived" | "clientOnly">) => EventDef<TName, TType, TEncoded>;
147
+ //# sourceMappingURL=define.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"define.d.ts","sourceRoot":"","sources":["../../../src/schema/EventDef/define.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AAGH,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAEhD,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAA;AAC9C,OAAO,KAAK,EAAE,iBAAiB,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAElE,qCAAqC;AACrC,MAAM,MAAM,kBAAkB,CAAC,GAAG,EAAE,QAAQ,SAAS,OAAO,GAAG,KAAK,IAAI;IACtE;;;OAGG;IACH,KAAK,CAAC,EAAE,CACN,IAAI,EAAE,GAAG,EACT,YAAY,EAAE,aAAa,KACxB;QACH,MAAM,CAAC,EAAE;YACP,uCAAuC;YACvC,GAAG,CAAC,EAAE,QAAQ,CAAC,iBAAiB,CAAC,CAAA;YACjC,+BAA+B;YAC/B,KAAK,CAAC,EAAE,QAAQ,CAAC,iBAAiB,CAAC,CAAA;SACpC,CAAA;QACD;;;WAGG;QACH,OAAO,CAAC,EAAE,QAAQ,CAAC,iBAAiB,CAAC,CAAA;KACtC,CAAA;IAED;;;;OAIG;IACH,UAAU,CAAC,EAAE,OAAO,CAAA;IAEpB;;;OAGG;IACH,OAAO,CAAC,EAAE,QAAQ,CAAA;CACnB,CAAA;AAED;;;;;;;;;;;;;;;GAeG;AACH,eAAO,MAAM,WAAW,GAAI,KAAK,SAAS,MAAM,EAAE,KAAK,EAAE,QAAQ,GAAG,KAAK,EAAE,QAAQ,SAAS,OAAO,GAAG,KAAK,EACzG,MAAM;IACJ,IAAI,EAAE,KAAK,CAAA;IACX,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;CACvC,GAAG,kBAAkB,CAAC,KAAK,EAAE,QAAQ,CAAC,KACtC,QAAQ,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,CAqC3C,CAAA;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,eAAO,MAAM,MAAM,GAAI,KAAK,SAAS,MAAM,EAAE,KAAK,EAAE,QAAQ,GAAG,KAAK,EAClE,MAAM;IACJ,IAAI,EAAE,KAAK,CAAA;IACX,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;CACvC,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,SAAS,GAAG,YAAY,CAAC,KACnE,QAAQ,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,CAAgD,CAAA;AAElF;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,eAAO,MAAM,UAAU,GAAI,KAAK,SAAS,MAAM,EAAE,KAAK,EAAE,QAAQ,GAAG,KAAK,EACtE,MAAM;IACJ,IAAI,EAAE,KAAK,CAAA;IACX,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;CACvC,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,EAAE,KAAK,CAAC,EAAE,SAAS,GAAG,YAAY,CAAC,KACnE,QAAQ,CAAC,KAAK,EAAE,KAAK,EAAE,QAAQ,CAA+C,CAAA"}
@@ -0,0 +1,139 @@
1
+ /**
2
+ * Event Definition Functions
3
+ *
4
+ * This module provides functions for creating event definitions in LiveStore.
5
+ * Events are the core unit of state change - all mutations to the database
6
+ * happen through events that are committed to the eventlog.
7
+ *
8
+ * @example
9
+ * ```ts
10
+ * import { Events } from '@livestore/livestore'
11
+ * import { Schema } from 'effect'
12
+ *
13
+ * // Define events for your application
14
+ * export const events = {
15
+ * // Synced events are sent to the sync backend
16
+ * todoCreated: Events.synced({
17
+ * name: 'v1.TodoCreated',
18
+ * schema: Schema.Struct({ id: Schema.String, text: Schema.String }),
19
+ * }),
20
+ *
21
+ * // Client-only events stay local (useful for UI state)
22
+ * uiStateSet: Events.clientOnly({
23
+ * name: 'UiStateSet',
24
+ * schema: Schema.Struct({ selectedId: Schema.NullOr(Schema.String) }),
25
+ * }),
26
+ * }
27
+ * ```
28
+ * @module
29
+ */
30
+ import { shouldNeverHappen } from '@livestore/utils';
31
+ import { Schema } from '@livestore/utils/effect';
32
+ /**
33
+ * Creates an event definition with full control over all options.
34
+ *
35
+ * This is the low-level function for creating events. For most cases,
36
+ * prefer using `synced()` or `clientOnly()` which provide simpler APIs.
37
+ *
38
+ * @example
39
+ * ```ts
40
+ * const customEvent = defineEvent({
41
+ * name: 'v1.CustomEvent',
42
+ * schema: Schema.Struct({ data: Schema.String }),
43
+ * clientOnly: false,
44
+ * derived: false,
45
+ * })
46
+ * ```
47
+ */
48
+ export const defineEvent = (args) => {
49
+ const { name, schema, ...options } = args;
50
+ const makePartialEvent = (args) => {
51
+ const res = Schema.validateEither(schema)(args);
52
+ if (res._tag === 'Left') {
53
+ shouldNeverHappen(`Invalid event args for event '${name}':`, res.left.message, '\n');
54
+ }
55
+ return { name: name, args };
56
+ };
57
+ Object.defineProperty(makePartialEvent, 'name', { value: name });
58
+ Object.defineProperty(makePartialEvent, 'schema', { value: schema });
59
+ Object.defineProperty(makePartialEvent, 'encoded', {
60
+ value: (args) => ({ name: name, args }),
61
+ });
62
+ Object.defineProperty(makePartialEvent, 'options', {
63
+ value: {
64
+ clientOnly: options?.clientOnly ?? false,
65
+ facts: options?.facts
66
+ ? (args, currentFacts) => {
67
+ const res = options.facts(args, currentFacts);
68
+ return {
69
+ modify: {
70
+ set: res.modify?.set ? new Set(res.modify.set) : new Set(),
71
+ unset: res.modify?.unset ? new Set(res.modify.unset) : new Set(),
72
+ },
73
+ require: res.require ? new Set(res.require) : new Set(),
74
+ };
75
+ }
76
+ : undefined,
77
+ derived: options?.derived ?? false,
78
+ },
79
+ });
80
+ return makePartialEvent;
81
+ };
82
+ /**
83
+ * Creates a synced event definition.
84
+ *
85
+ * Synced events are sent to the sync backend and distributed to all connected
86
+ * clients. Use this for collaborative data that should be shared across users
87
+ * and devices.
88
+ *
89
+ * Event names should be versioned (e.g., `v1.TodoCreated`) to support
90
+ * schema evolution over time.
91
+ *
92
+ * @example
93
+ * ```ts
94
+ * import { Events } from '@livestore/livestore'
95
+ * import { Schema } from 'effect'
96
+ *
97
+ * const todoCreated = Events.synced({
98
+ * name: 'v1.TodoCreated',
99
+ * schema: Schema.Struct({
100
+ * id: Schema.String,
101
+ * text: Schema.String,
102
+ * completed: Schema.Boolean,
103
+ * }),
104
+ * })
105
+ *
106
+ * // Commit the event
107
+ * store.commit(todoCreated({ id: 'abc', text: 'Buy milk', completed: false }))
108
+ * ```
109
+ */
110
+ export const synced = (args) => defineEvent({ ...args, clientOnly: false });
111
+ /**
112
+ * Creates a client-only event definition.
113
+ *
114
+ * Client-only events are synced within the same client's sessions (e.g., across
115
+ * browser tabs) but are never sent to the sync backend. Use this for local UI
116
+ * state like selected items, filter settings, or draft content.
117
+ *
118
+ * Note: Client-only events still require materializers and are stored in the
119
+ * local eventlog, they just don't participate in server-side sync.
120
+ *
121
+ * @example
122
+ * ```ts
123
+ * import { Events } from '@livestore/livestore'
124
+ * import { Schema } from 'effect'
125
+ *
126
+ * const uiStateSet = Events.clientOnly({
127
+ * name: 'UiStateSet',
128
+ * schema: Schema.Struct({
129
+ * selectedTodoId: Schema.NullOr(Schema.String),
130
+ * filterMode: Schema.Literal('all', 'active', 'completed'),
131
+ * }),
132
+ * })
133
+ *
134
+ * // Update local UI state
135
+ * store.commit(uiStateSet({ selectedTodoId: 'abc', filterMode: 'active' }))
136
+ * ```
137
+ */
138
+ export const clientOnly = (args) => defineEvent({ ...args, clientOnly: true });
139
+ //# sourceMappingURL=define.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"define.js","sourceRoot":"","sources":["../../../src/schema/EventDef/define.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4BG;AAEH,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AA0ChD;;;;;;;;;;;;;;;GAeG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,CACzB,IAGuC,EACK,EAAE;IAC9C,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,EAAE,GAAG,IAAI,CAAA;IAEzC,MAAM,gBAAgB,GAAG,CAAC,IAAW,EAAE,EAAE;QACvC,MAAM,GAAG,GAAG,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAA;QAC/C,IAAI,GAAG,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;YACxB,iBAAiB,CAAC,iCAAiC,IAAI,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAA;QACtF,CAAC;QACD,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAA;IAC7B,CAAC,CAAA;IAED,MAAM,CAAC,cAAc,CAAC,gBAAgB,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAA;IAChE,MAAM,CAAC,cAAc,CAAC,gBAAgB,EAAE,QAAQ,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAA;IACpE,MAAM,CAAC,cAAc,CAAC,gBAAgB,EAAE,SAAS,EAAE;QACjD,KAAK,EAAE,CAAC,IAAc,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;KAClD,CAAC,CAAA;IAEF,MAAM,CAAC,cAAc,CAAC,gBAAgB,EAAE,SAAS,EAAE;QACjD,KAAK,EAAE;YACL,UAAU,EAAE,OAAO,EAAE,UAAU,IAAI,KAAK;YACxC,KAAK,EAAE,OAAO,EAAE,KAAK;gBACnB,CAAC,CAAC,CAAC,IAAI,EAAE,YAAY,EAAE,EAAE;oBACrB,MAAM,GAAG,GAAG,OAAO,CAAC,KAAM,CAAC,IAAI,EAAE,YAAY,CAAC,CAAA;oBAC9C,OAAO;wBACL,MAAM,EAAE;4BACN,GAAG,EAAE,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;4BAC1D,KAAK,EAAE,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;yBACjE;wBACD,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,GAAG,EAAE;qBACxD,CAAA;gBACH,CAAC;gBACH,CAAC,CAAC,SAAS;YACb,OAAO,EAAE,OAAO,EAAE,OAAO,IAAI,KAAK;SACD;KACpC,CAAC,CAAA;IAEF,OAAO,gBAA8D,CAAA;AACvE,CAAC,CAAA;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,MAAM,CAAC,MAAM,MAAM,GAAG,CACpB,IAGoE,EAClC,EAAE,CAAC,WAAW,CAAC,EAAE,GAAG,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAAA;AAElF;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,CAAC,MAAM,UAAU,GAAG,CACxB,IAGoE,EAClC,EAAE,CAAC,WAAW,CAAC,EAAE,GAAG,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAA"}
@@ -0,0 +1,106 @@
1
+ import type { Schema } from '@livestore/utils/effect';
2
+ import type { FactsCallback } from './facts.ts';
3
+ /**
4
+ * Core type representing an event definition in LiveStore.
5
+ *
6
+ * An EventDef defines the structure and behavior of an event type, including:
7
+ * - A unique name identifying the event type (conventionally versioned, e.g., `v1.TodoCreated`)
8
+ * - A schema for validating and encoding/decoding event arguments
9
+ * - Options controlling sync behavior and constraints
10
+ *
11
+ * EventDefs are callable - invoking them creates a partial event object suitable for `store.commit()`.
12
+ *
13
+ * @example
14
+ * ```ts
15
+ * import { Events } from '@livestore/livestore'
16
+ * import { Schema } from 'effect'
17
+ *
18
+ * const todoCreated = Events.synced({
19
+ * name: 'v1.TodoCreated',
20
+ * schema: Schema.Struct({
21
+ * id: Schema.String,
22
+ * text: Schema.String,
23
+ * }),
24
+ * })
25
+ *
26
+ * // Use the EventDef as a constructor
27
+ * store.commit(todoCreated({ id: 'abc', text: 'Buy milk' }))
28
+ * ```
29
+ */
30
+ export type EventDef<TName extends string, TType, TEncoded = TType, TDerived extends boolean = false> = {
31
+ /** Unique identifier for this event type. Conventionally versioned (e.g., `v1.TodoCreated`). */
32
+ name: TName;
33
+ /** Effect Schema used for validating and encoding/decoding event arguments. */
34
+ schema: Schema.Schema<TType, TEncoded>;
35
+ options: {
36
+ /**
37
+ * When true, the event is only synced within the same client's sessions (e.g., across tabs)
38
+ * but never sent to the sync backend. Useful for UI state like selected items or filters.
39
+ */
40
+ clientOnly: boolean;
41
+ /**
42
+ * Callback defining fact constraints for this event.
43
+ * @experimental This feature is not fully implemented yet.
44
+ */
45
+ facts: FactsCallback<TType> | undefined;
46
+ /** Whether this is a derived event. Derived events cannot have materializers. */
47
+ derived: TDerived;
48
+ };
49
+ /**
50
+ * Callable signature - creates a partial event with decoded arguments.
51
+ * The returned object can be passed directly to `store.commit()`.
52
+ */
53
+ (args: TType): {
54
+ name: TName;
55
+ args: TType;
56
+ };
57
+ /**
58
+ * Creates a partial event with pre-encoded arguments.
59
+ * Useful when working with already-serialized data.
60
+ */
61
+ encoded: (args: TEncoded) => {
62
+ name: TName;
63
+ args: TEncoded;
64
+ };
65
+ /** Type helper for accessing the event's shape with name and decoded args. */
66
+ readonly Event: {
67
+ name: TName;
68
+ args: TType;
69
+ };
70
+ };
71
+ export declare namespace EventDef {
72
+ /**
73
+ * Wildcard type matching any EventDef regardless of type parameters.
74
+ * Used as a type constraint in generic functions and collections.
75
+ */
76
+ type Any = EventDef<string, any, any, boolean>;
77
+ /**
78
+ * EventDef without the callable function signature.
79
+ * Used in contexts where only the metadata (name, schema, options) is needed,
80
+ * such as materializer definitions.
81
+ */
82
+ type AnyWithoutFn = Pick<Any, 'name' | 'schema' | 'options'>;
83
+ }
84
+ /**
85
+ * Container holding a Map of event definitions keyed by name.
86
+ * Used internally by LiveStoreSchema.
87
+ */
88
+ export type EventDefMap = {
89
+ map: Map<string, EventDef.Any>;
90
+ };
91
+ /**
92
+ * Plain object record of event definitions keyed by name.
93
+ * This is the typical shape when defining events in user code.
94
+ *
95
+ * @example
96
+ * ```ts
97
+ * const events = {
98
+ * todoCreated: Events.synced({ name: 'v1.TodoCreated', schema: ... }),
99
+ * todoDeleted: Events.synced({ name: 'v1.TodoDeleted', schema: ... }),
100
+ * } satisfies EventDefRecord
101
+ * ```
102
+ */
103
+ export type EventDefRecord = {
104
+ [name: string]: EventDef.Any;
105
+ };
106
+ //# sourceMappingURL=event-def.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-def.d.ts","sourceRoot":"","sources":["../../../src/schema/EventDef/event-def.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAErD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAE/C;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,MAAM,MAAM,QAAQ,CAAC,KAAK,SAAS,MAAM,EAAE,KAAK,EAAE,QAAQ,GAAG,KAAK,EAAE,QAAQ,SAAS,OAAO,GAAG,KAAK,IAAI;IACtG,gGAAgG;IAChG,IAAI,EAAE,KAAK,CAAA;IAEX,+EAA+E;IAC/E,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAA;IAEtC,OAAO,EAAE;QACP;;;WAGG;QACH,UAAU,EAAE,OAAO,CAAA;QAEnB;;;WAGG;QACH,KAAK,EAAE,aAAa,CAAC,KAAK,CAAC,GAAG,SAAS,CAAA;QAEvC,iFAAiF;QACjF,OAAO,EAAE,QAAQ,CAAA;KAClB,CAAA;IAED;;;OAGG;IACH,CACE,IAAI,EAAE,KAAK,GACV;QACD,IAAI,EAAE,KAAK,CAAA;QACX,IAAI,EAAE,KAAK,CAAA;KACZ,CAAA;IAED;;;OAGG;IACH,OAAO,EAAE,CAAC,IAAI,EAAE,QAAQ,KAAK;QAC3B,IAAI,EAAE,KAAK,CAAA;QACX,IAAI,EAAE,QAAQ,CAAA;KACf,CAAA;IAED,8EAA8E;IAC9E,QAAQ,CAAC,KAAK,EAAE;QACd,IAAI,EAAE,KAAK,CAAA;QACX,IAAI,EAAE,KAAK,CAAA;KACZ,CAAA;CACF,CAAA;AAED,yBAAiB,QAAQ,CAAC;IACxB;;;OAGG;IACH,KAAY,GAAG,GAAG,QAAQ,CAAC,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,CAAC,CAAA;IAErD;;;;OAIG;IACH,KAAY,YAAY,GAAG,IAAI,CAAC,GAAG,EAAE,MAAM,GAAG,QAAQ,GAAG,SAAS,CAAC,CAAA;CACpE;AAED;;;GAGG;AACH,MAAM,MAAM,WAAW,GAAG;IACxB,GAAG,EAAE,GAAG,CAAC,MAAM,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAA;CAC/B,CAAA;AAED;;;;;;;;;;;GAWG;AACH,MAAM,MAAM,cAAc,GAAG;IAC3B,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAAC,GAAG,CAAA;CAC7B,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=event-def.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"event-def.js","sourceRoot":"","sources":["../../../src/schema/EventDef/event-def.ts"],"names":[],"mappings":""}
@@ -0,0 +1,118 @@
1
+ /**
2
+ * Facts System for Event Constraints (Experimental)
3
+ *
4
+ * The facts system enables defining constraints and dependencies between events.
5
+ * Facts are key-value pairs that events can read, set, or require, allowing
6
+ * LiveStore to understand event relationships for:
7
+ * - History constraints (ordering requirements)
8
+ * - Event compaction (which events can be safely merged)
9
+ * - Conflict detection during sync
10
+ *
11
+ * @experimental This system is not fully implemented yet.
12
+ *
13
+ * @example
14
+ * ```ts
15
+ * const facts = defineFacts({
16
+ * todoExists: (id: string) => [`todo:${id}`, true],
17
+ * userOwns: (userId: string, todoId: string) => [`owns:${userId}:${todoId}`, true],
18
+ * })
19
+ *
20
+ * const todoCreated = Events.synced({
21
+ * name: 'v1.TodoCreated',
22
+ * schema: Schema.Struct({ id: Schema.String, userId: Schema.String }),
23
+ * facts: ({ id, userId }) => ({
24
+ * modify: { set: [facts.todoExists(id), facts.userOwns(userId, id)] },
25
+ * require: [],
26
+ * }),
27
+ * })
28
+ * ```
29
+ * @module
30
+ */
31
+ /** String key identifying a fact (e.g., `"todo:abc123"` or `"user:owner:xyz"`). */
32
+ export type EventDefKey = string;
33
+ /** String identifier for a fact type. */
34
+ export type EventDefFact = string;
35
+ /** Immutable map of fact keys to their current values. */
36
+ export type EventDefFacts = ReadonlyMap<string, any>;
37
+ /**
38
+ * Groups of facts that an event interacts with.
39
+ * Used internally to track how events modify and depend on facts.
40
+ */
41
+ export type EventDefFactsGroup = {
42
+ /** Facts this event sets to a new value. */
43
+ modifySet: EventDefFacts;
44
+ /** Facts this event removes/unsets. */
45
+ modifyUnset: EventDefFacts;
46
+ /**
47
+ * Facts this event requires to exist with specific values.
48
+ * Events on independent dependency branches are commutative,
49
+ * which can facilitate more prioritized syncing.
50
+ */
51
+ depRequire: EventDefFacts;
52
+ /** Facts this event reads (but doesn't require). */
53
+ depRead: EventDefFacts;
54
+ };
55
+ /** Mutable snapshot of facts state at a point in time. */
56
+ export type EventDefFactsSnapshot = Map<string, any>;
57
+ /**
58
+ * Input format for specifying a fact.
59
+ * Either a simple key string (value defaults to `true`) or a `[key, value]` tuple.
60
+ *
61
+ * @example
62
+ * ```ts
63
+ * // Simple key (value = true)
64
+ * const fact1: EventDefFactInput = 'todo:abc123'
65
+ *
66
+ * // Key-value tuple
67
+ * const fact2: EventDefFactInput = ['todo:abc123', { status: 'active' }]
68
+ * ```
69
+ */
70
+ export type EventDefFactInput = string | readonly [string, any];
71
+ /**
72
+ * Callback function that defines how an event interacts with the facts system.
73
+ * Called during event processing to determine fact constraints.
74
+ *
75
+ * @example
76
+ * ```ts
77
+ * const factsCallback: FactsCallback<{ id: string }> = (args, currentFacts) => ({
78
+ * modify: {
79
+ * set: [`item:${args.id}`], // Create/update this fact
80
+ * unset: [], // No facts to remove
81
+ * },
82
+ * require: currentFacts.has('initialized') ? [] : ['initialized'],
83
+ * })
84
+ * ```
85
+ */
86
+ export type FactsCallback<TTo> = (args: TTo, currentFacts: EventDefFacts) => {
87
+ modify: {
88
+ /** Facts to set (create or update). */
89
+ set: Iterable<EventDefFactInput>;
90
+ /** Facts to unset (remove). */
91
+ unset: Iterable<EventDefFactInput>;
92
+ };
93
+ /** Facts that must exist with specific values for this event to be valid. */
94
+ require: Iterable<EventDefFactInput>;
95
+ };
96
+ /**
97
+ * Helper to define a typed record of fact constructors.
98
+ * Returns the input unchanged but provides type inference.
99
+ *
100
+ * @example
101
+ * ```ts
102
+ * const facts = defineFacts({
103
+ * // Simple fact (value = true)
104
+ * initialized: 'system:initialized',
105
+ *
106
+ * // Parameterized fact constructor
107
+ * todoExists: (id: string) => [`todo:${id}`, true] as const,
108
+ *
109
+ * // Fact with complex value
110
+ * todoStatus: (id: string, status: string) => [`todo:${id}:status`, status] as const,
111
+ * })
112
+ *
113
+ * // Usage
114
+ * facts.todoExists('abc') // => ['todo:abc', true]
115
+ * ```
116
+ */
117
+ export declare const defineFacts: <TRecord extends Record<string, EventDefFactInput | ((...args: any[]) => EventDefFactInput)>>(record: TRecord) => TRecord;
118
+ //# sourceMappingURL=facts.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"facts.d.ts","sourceRoot":"","sources":["../../../src/schema/EventDef/facts.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AAEH,mFAAmF;AACnF,MAAM,MAAM,WAAW,GAAG,MAAM,CAAA;AAEhC,yCAAyC;AACzC,MAAM,MAAM,YAAY,GAAG,MAAM,CAAA;AAEjC,0DAA0D;AAC1D,MAAM,MAAM,aAAa,GAAG,WAAW,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;AAEpD;;;GAGG;AACH,MAAM,MAAM,kBAAkB,GAAG;IAC/B,4CAA4C;IAC5C,SAAS,EAAE,aAAa,CAAA;IAExB,uCAAuC;IACvC,WAAW,EAAE,aAAa,CAAA;IAE1B;;;;OAIG;IACH,UAAU,EAAE,aAAa,CAAA;IAEzB,oDAAoD;IACpD,OAAO,EAAE,aAAa,CAAA;CACvB,CAAA;AAED,0DAA0D;AAC1D,MAAM,MAAM,qBAAqB,GAAG,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;AAEpD;;;;;;;;;;;;GAYG;AACH,MAAM,MAAM,iBAAiB,GAAG,MAAM,GAAG,SAAS,CAAC,MAAM,EAAE,GAAG,CAAC,CAAA;AAE/D;;;;;;;;;;;;;;GAcG;AACH,MAAM,MAAM,aAAa,CAAC,GAAG,IAAI,CAC/B,IAAI,EAAE,GAAG,EACT,YAAY,EAAE,aAAa,KACxB;IACH,MAAM,EAAE;QACN,uCAAuC;QACvC,GAAG,EAAE,QAAQ,CAAC,iBAAiB,CAAC,CAAA;QAChC,+BAA+B;QAC/B,KAAK,EAAE,QAAQ,CAAC,iBAAiB,CAAC,CAAA;KACnC,CAAA;IACD,6EAA6E;IAC7E,OAAO,EAAE,QAAQ,CAAC,iBAAiB,CAAC,CAAA;CACrC,CAAA;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,eAAO,MAAM,WAAW,GACtB,OAAO,SAAS,MAAM,CAAC,MAAM,EAAE,iBAAiB,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,iBAAiB,CAAC,CAAC,EAE3F,QAAQ,OAAO,KACd,OAAiB,CAAA"}
@@ -0,0 +1,53 @@
1
+ /**
2
+ * Facts System for Event Constraints (Experimental)
3
+ *
4
+ * The facts system enables defining constraints and dependencies between events.
5
+ * Facts are key-value pairs that events can read, set, or require, allowing
6
+ * LiveStore to understand event relationships for:
7
+ * - History constraints (ordering requirements)
8
+ * - Event compaction (which events can be safely merged)
9
+ * - Conflict detection during sync
10
+ *
11
+ * @experimental This system is not fully implemented yet.
12
+ *
13
+ * @example
14
+ * ```ts
15
+ * const facts = defineFacts({
16
+ * todoExists: (id: string) => [`todo:${id}`, true],
17
+ * userOwns: (userId: string, todoId: string) => [`owns:${userId}:${todoId}`, true],
18
+ * })
19
+ *
20
+ * const todoCreated = Events.synced({
21
+ * name: 'v1.TodoCreated',
22
+ * schema: Schema.Struct({ id: Schema.String, userId: Schema.String }),
23
+ * facts: ({ id, userId }) => ({
24
+ * modify: { set: [facts.todoExists(id), facts.userOwns(userId, id)] },
25
+ * require: [],
26
+ * }),
27
+ * })
28
+ * ```
29
+ * @module
30
+ */
31
+ /**
32
+ * Helper to define a typed record of fact constructors.
33
+ * Returns the input unchanged but provides type inference.
34
+ *
35
+ * @example
36
+ * ```ts
37
+ * const facts = defineFacts({
38
+ * // Simple fact (value = true)
39
+ * initialized: 'system:initialized',
40
+ *
41
+ * // Parameterized fact constructor
42
+ * todoExists: (id: string) => [`todo:${id}`, true] as const,
43
+ *
44
+ * // Fact with complex value
45
+ * todoStatus: (id: string, status: string) => [`todo:${id}:status`, status] as const,
46
+ * })
47
+ *
48
+ * // Usage
49
+ * facts.todoExists('abc') // => ['todo:abc', true]
50
+ * ```
51
+ */
52
+ export const defineFacts = (record) => record;
53
+ //# sourceMappingURL=facts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"facts.js","sourceRoot":"","sources":["../../../src/schema/EventDef/facts.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AAgFH;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG,CAGzB,MAAe,EACN,EAAE,CAAC,MAAM,CAAA"}