@lix-js/sdk 0.5.0-preview.1 → 0.5.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 (3052) hide show
  1. package/README.md +6 -6
  2. package/dist/account/create-account.d.ts +2 -3
  3. package/dist/account/create-account.d.ts.map +1 -1
  4. package/dist/account/create-account.js +7 -9
  5. package/dist/account/create-account.js.map +1 -1
  6. package/dist/account/create-account.test.js +5 -17
  7. package/dist/account/create-account.test.js.map +1 -1
  8. package/dist/account/index.d.ts +1 -1
  9. package/dist/account/index.d.ts.map +1 -1
  10. package/dist/account/index.js +1 -1
  11. package/dist/account/index.js.map +1 -1
  12. package/dist/account/schema-definition.d.ts +53 -0
  13. package/dist/account/schema-definition.d.ts.map +1 -0
  14. package/dist/account/schema-definition.js +50 -0
  15. package/dist/account/schema-definition.js.map +1 -0
  16. package/dist/account/schema.test.js +91 -64
  17. package/dist/account/schema.test.js.map +1 -1
  18. package/dist/account/switch-account.d.ts +1 -1
  19. package/dist/account/switch-account.d.ts.map +1 -1
  20. package/dist/account/switch-account.test.js +5 -15
  21. package/dist/account/switch-account.test.js.map +1 -1
  22. package/dist/change/index.d.ts +1 -1
  23. package/dist/change/index.d.ts.map +1 -1
  24. package/dist/change/index.js +1 -1
  25. package/dist/change/index.js.map +1 -1
  26. package/dist/change/schema-definition.d.ts +82 -0
  27. package/dist/change/schema-definition.d.ts.map +1 -0
  28. package/dist/change/schema-definition.js +36 -0
  29. package/dist/change/schema-definition.js.map +1 -0
  30. package/dist/change/schema.bench.d.ts +2 -0
  31. package/dist/change/schema.bench.d.ts.map +1 -0
  32. package/dist/change/schema.bench.js +334 -0
  33. package/dist/change/schema.bench.js.map +1 -0
  34. package/dist/change/schema.d.ts +3 -54
  35. package/dist/change/schema.d.ts.map +1 -1
  36. package/dist/change/schema.js +27 -39
  37. package/dist/change/schema.js.map +1 -1
  38. package/dist/change/schema.test.js +85 -9
  39. package/dist/change/schema.test.js.map +1 -1
  40. package/dist/change-author/index.d.ts +1 -1
  41. package/dist/change-author/index.d.ts.map +1 -1
  42. package/dist/change-author/index.js +1 -1
  43. package/dist/change-author/index.js.map +1 -1
  44. package/dist/change-author/schema-definition.d.ts +37 -0
  45. package/dist/change-author/schema-definition.d.ts.map +1 -0
  46. package/dist/change-author/schema-definition.js +35 -0
  47. package/dist/change-author/schema-definition.js.map +1 -0
  48. package/dist/change-author/schema.test.js +132 -17
  49. package/dist/change-author/schema.test.js.map +1 -1
  50. package/dist/change-proposal/accept-change-proposal.d.ts +7 -0
  51. package/dist/change-proposal/accept-change-proposal.d.ts.map +1 -0
  52. package/dist/change-proposal/accept-change-proposal.js +36 -0
  53. package/dist/change-proposal/accept-change-proposal.js.map +1 -0
  54. package/dist/change-proposal/accept-change-proposal.test.d.ts +2 -0
  55. package/dist/change-proposal/accept-change-proposal.test.d.ts.map +1 -0
  56. package/dist/change-proposal/accept-change-proposal.test.js +55 -0
  57. package/dist/change-proposal/accept-change-proposal.test.js.map +1 -0
  58. package/dist/change-proposal/create-change-proposal.d.ts +11 -9
  59. package/dist/change-proposal/create-change-proposal.d.ts.map +1 -1
  60. package/dist/change-proposal/create-change-proposal.js +28 -43
  61. package/dist/change-proposal/create-change-proposal.js.map +1 -1
  62. package/dist/change-proposal/create-change-proposal.test.js +61 -82
  63. package/dist/change-proposal/create-change-proposal.test.js.map +1 -1
  64. package/dist/change-proposal/index.d.ts +4 -2
  65. package/dist/change-proposal/index.d.ts.map +1 -1
  66. package/dist/change-proposal/index.js +4 -2
  67. package/dist/change-proposal/index.js.map +1 -1
  68. package/dist/change-proposal/reject-change-proposal.d.ts +7 -0
  69. package/dist/change-proposal/reject-change-proposal.d.ts.map +1 -0
  70. package/dist/change-proposal/reject-change-proposal.js +15 -0
  71. package/dist/change-proposal/reject-change-proposal.js.map +1 -0
  72. package/dist/change-proposal/reject-change-proposal.test.d.ts +2 -0
  73. package/dist/change-proposal/reject-change-proposal.test.d.ts.map +1 -0
  74. package/dist/change-proposal/reject-change-proposal.test.js +28 -0
  75. package/dist/change-proposal/reject-change-proposal.test.js.map +1 -0
  76. package/dist/change-proposal/schema-definition.d.ts +45 -0
  77. package/dist/change-proposal/schema-definition.d.ts.map +1 -0
  78. package/dist/change-proposal/schema-definition.js +34 -0
  79. package/dist/change-proposal/schema-definition.js.map +1 -0
  80. package/dist/change-proposal/schema.test.d.ts.map +1 -0
  81. package/dist/change-proposal/schema.test.js +103 -0
  82. package/dist/change-proposal/schema.test.js.map +1 -0
  83. package/dist/change-set/apply-change-set.d.ts +1 -1
  84. package/dist/change-set/apply-change-set.d.ts.map +1 -1
  85. package/dist/change-set/apply-change-set.js +29 -41
  86. package/dist/change-set/apply-change-set.js.map +1 -1
  87. package/dist/change-set/apply-change-set.test.js +4 -3
  88. package/dist/change-set/apply-change-set.test.js.map +1 -1
  89. package/dist/change-set/create-change-set.d.ts +3 -5
  90. package/dist/change-set/create-change-set.d.ts.map +1 -1
  91. package/dist/change-set/create-change-set.js +5 -27
  92. package/dist/change-set/create-change-set.js.map +1 -1
  93. package/dist/change-set/create-change-set.test.js +5 -43
  94. package/dist/change-set/create-change-set.test.js.map +1 -1
  95. package/dist/change-set/index.d.ts +1 -1
  96. package/dist/change-set/index.d.ts.map +1 -1
  97. package/dist/change-set/index.js +1 -1
  98. package/dist/change-set/index.js.map +1 -1
  99. package/dist/change-set/schema-definition.d.ts +73 -0
  100. package/dist/change-set/schema-definition.d.ts.map +1 -0
  101. package/dist/change-set/schema-definition.js +72 -0
  102. package/dist/change-set/schema-definition.js.map +1 -0
  103. package/dist/change-set/schema.test.js +12 -154
  104. package/dist/change-set/schema.test.js.map +1 -1
  105. package/dist/commit/index.d.ts +1 -5
  106. package/dist/commit/index.d.ts.map +1 -1
  107. package/dist/commit/index.js +1 -5
  108. package/dist/commit/index.js.map +1 -1
  109. package/dist/commit/schema-definition.d.ts +97 -0
  110. package/dist/commit/schema-definition.d.ts.map +1 -0
  111. package/dist/commit/schema-definition.js +89 -0
  112. package/dist/commit/schema-definition.js.map +1 -0
  113. package/dist/commit/schema.test.js +116 -37
  114. package/dist/commit/schema.test.js.map +1 -1
  115. package/dist/conversation/create-conversation-message.d.ts +11 -0
  116. package/dist/conversation/create-conversation-message.d.ts.map +1 -0
  117. package/dist/conversation/create-conversation-message.js +59 -0
  118. package/dist/conversation/create-conversation-message.js.map +1 -0
  119. package/dist/conversation/create-conversation-message.test.d.ts +2 -0
  120. package/dist/conversation/create-conversation-message.test.d.ts.map +1 -0
  121. package/dist/conversation/create-conversation-message.test.js +98 -0
  122. package/dist/conversation/create-conversation-message.test.js.map +1 -0
  123. package/dist/conversation/create-conversation.d.ts +39 -0
  124. package/dist/conversation/create-conversation.d.ts.map +1 -0
  125. package/dist/conversation/create-conversation.js +80 -0
  126. package/dist/conversation/create-conversation.js.map +1 -0
  127. package/dist/conversation/create-conversation.test.d.ts +2 -0
  128. package/dist/conversation/create-conversation.test.d.ts.map +1 -0
  129. package/dist/conversation/create-conversation.test.js +157 -0
  130. package/dist/conversation/create-conversation.test.js.map +1 -0
  131. package/dist/conversation/index.d.ts +4 -0
  132. package/dist/conversation/index.d.ts.map +1 -0
  133. package/dist/conversation/index.js +4 -0
  134. package/dist/conversation/index.js.map +1 -0
  135. package/dist/conversation/schema-definition.d.ts +64 -0
  136. package/dist/conversation/schema-definition.d.ts.map +1 -0
  137. package/dist/conversation/schema-definition.js +59 -0
  138. package/dist/conversation/schema-definition.js.map +1 -0
  139. package/dist/database/index.d.ts +0 -1
  140. package/dist/database/index.d.ts.map +1 -1
  141. package/dist/database/index.js +0 -1
  142. package/dist/database/index.js.map +1 -1
  143. package/dist/database/init-db.d.ts +30 -4
  144. package/dist/database/init-db.d.ts.map +1 -1
  145. package/dist/database/init-db.js +71 -91
  146. package/dist/database/init-db.js.map +1 -1
  147. package/dist/database/kysely/index.d.ts +2 -0
  148. package/dist/database/kysely/index.d.ts.map +1 -0
  149. package/dist/database/kysely/index.js +2 -0
  150. package/dist/database/kysely/index.js.map +1 -0
  151. package/dist/database/kysely/json-column-config.d.ts +6 -0
  152. package/dist/database/kysely/json-column-config.d.ts.map +1 -0
  153. package/dist/database/kysely/json-column-config.js +55 -0
  154. package/dist/database/kysely/json-column-config.js.map +1 -0
  155. package/dist/database/kysely/plugins/json-column-plugin.d.ts.map +1 -0
  156. package/dist/database/kysely/plugins/json-column-plugin.js +216 -0
  157. package/dist/database/kysely/plugins/json-column-plugin.js.map +1 -0
  158. package/dist/database/kysely/plugins/json-column-plugin.test.d.ts.map +1 -0
  159. package/dist/database/kysely/plugins/json-column-plugin.test.js +441 -0
  160. package/dist/database/kysely/plugins/json-column-plugin.test.js.map +1 -0
  161. package/dist/database/kysely/plugins/view-insert-returning-error-plugin.d.ts.map +1 -0
  162. package/dist/database/kysely/plugins/view-insert-returning-error-plugin.js.map +1 -0
  163. package/dist/database/kysely/plugins/view-insert-returning-error-plugin.test.d.ts.map +1 -0
  164. package/dist/database/kysely/plugins/view-insert-returning-error-plugin.test.js +51 -0
  165. package/dist/database/kysely/plugins/view-insert-returning-error-plugin.test.js.map +1 -0
  166. package/dist/database/kysely/plugins.d.ts +3 -0
  167. package/dist/database/kysely/plugins.d.ts.map +1 -0
  168. package/dist/database/kysely/plugins.js +15 -0
  169. package/dist/database/kysely/plugins.js.map +1 -0
  170. package/dist/database/nano-id.test.js +1 -1
  171. package/dist/database/nano-id.test.js.map +1 -1
  172. package/dist/database/schema-view-map.d.ts +3 -0
  173. package/dist/database/schema-view-map.d.ts.map +1 -0
  174. package/dist/database/schema-view-map.js +35 -0
  175. package/dist/database/schema-view-map.js.map +1 -0
  176. package/dist/database/schema.d.ts +70 -34
  177. package/dist/database/schema.d.ts.map +1 -1
  178. package/dist/database/schema.js +15 -34
  179. package/dist/database/schema.js.map +1 -1
  180. package/dist/database/sqlite/content-from-database.d.ts +10 -0
  181. package/dist/database/sqlite/content-from-database.d.ts.map +1 -0
  182. package/dist/database/sqlite/content-from-database.js +11 -0
  183. package/dist/database/sqlite/content-from-database.js.map +1 -0
  184. package/dist/database/sqlite/create-in-memory-database.d.ts +23 -0
  185. package/dist/database/sqlite/create-in-memory-database.d.ts.map +1 -0
  186. package/dist/database/sqlite/create-in-memory-database.js +44 -0
  187. package/dist/database/sqlite/create-in-memory-database.js.map +1 -0
  188. package/dist/database/sqlite/environment-dialect.d.ts +21 -0
  189. package/dist/database/sqlite/environment-dialect.d.ts.map +1 -0
  190. package/dist/database/sqlite/environment-dialect.js +198 -0
  191. package/dist/database/sqlite/environment-dialect.js.map +1 -0
  192. package/dist/database/sqlite/environment-dialect.test.d.ts +2 -0
  193. package/dist/database/sqlite/environment-dialect.test.d.ts.map +1 -0
  194. package/dist/database/sqlite/environment-dialect.test.js +66 -0
  195. package/dist/database/sqlite/environment-dialect.test.js.map +1 -0
  196. package/dist/database/sqlite/import-database.d.ts +18 -0
  197. package/dist/database/sqlite/import-database.d.ts.map +1 -0
  198. package/dist/database/sqlite/import-database.js +24 -0
  199. package/dist/database/sqlite/import-database.js.map +1 -0
  200. package/dist/database/sqlite/index.d.ts +8 -0
  201. package/dist/database/sqlite/index.d.ts.map +1 -0
  202. package/dist/database/sqlite/index.js +7 -0
  203. package/dist/database/sqlite/index.js.map +1 -0
  204. package/dist/database/sqlite/kysely-driver/connection-mutex.d.ts +6 -0
  205. package/dist/database/sqlite/kysely-driver/connection-mutex.d.ts.map +1 -0
  206. package/dist/database/sqlite/kysely-driver/connection-mutex.js +19 -0
  207. package/dist/database/sqlite/kysely-driver/connection-mutex.js.map +1 -0
  208. package/dist/database/sqlite/kysely-driver/index.d.ts +5 -0
  209. package/dist/database/sqlite/kysely-driver/index.d.ts.map +1 -0
  210. package/dist/database/sqlite/kysely-driver/index.js +4 -0
  211. package/dist/database/sqlite/kysely-driver/index.js.map +1 -0
  212. package/dist/database/sqlite/kysely-driver/sqlite-wasm-connection.d.ts +9 -0
  213. package/dist/database/sqlite/kysely-driver/sqlite-wasm-connection.d.ts.map +1 -0
  214. package/dist/database/sqlite/kysely-driver/sqlite-wasm-connection.js +43 -0
  215. package/dist/database/sqlite/kysely-driver/sqlite-wasm-connection.js.map +1 -0
  216. package/dist/database/sqlite/kysely-driver/sqlite-wasm-dialect-config.d.ts +19 -0
  217. package/dist/database/sqlite/kysely-driver/sqlite-wasm-dialect-config.d.ts.map +1 -0
  218. package/dist/database/sqlite/kysely-driver/sqlite-wasm-dialect-config.js +2 -0
  219. package/dist/database/sqlite/kysely-driver/sqlite-wasm-dialect-config.js.map +1 -0
  220. package/dist/database/sqlite/kysely-driver/sqlite-wasm-driver.d.ts +14 -0
  221. package/dist/database/sqlite/kysely-driver/sqlite-wasm-driver.d.ts.map +1 -0
  222. package/dist/database/sqlite/kysely-driver/sqlite-wasm-driver.js +45 -0
  223. package/dist/database/sqlite/kysely-driver/sqlite-wasm-driver.js.map +1 -0
  224. package/dist/database/sqlite/lix-dialect.d.ts +23 -0
  225. package/dist/database/sqlite/lix-dialect.d.ts.map +1 -0
  226. package/dist/database/sqlite/lix-dialect.js +24 -0
  227. package/dist/database/sqlite/lix-dialect.js.map +1 -0
  228. package/dist/database/sqlite/load-database-in-memory.d.ts +13 -0
  229. package/dist/database/sqlite/load-database-in-memory.d.ts.map +1 -0
  230. package/dist/database/sqlite/load-database-in-memory.js +23 -0
  231. package/dist/database/sqlite/load-database-in-memory.js.map +1 -0
  232. package/dist/database/sqlite/sqlite-wasm-binary.d.ts +2 -0
  233. package/dist/database/sqlite/sqlite-wasm-binary.js +42835 -0
  234. package/dist/dependency/kysely/helpers/sqlite.d.ts +5 -0
  235. package/dist/dependency/kysely/helpers/sqlite.d.ts.map +1 -0
  236. package/dist/dependency/kysely/helpers/sqlite.js +5 -0
  237. package/dist/dependency/kysely/helpers/sqlite.js.map +1 -0
  238. package/dist/dependency/kysely/index.d.ts +9 -0
  239. package/dist/dependency/kysely/index.d.ts.map +1 -0
  240. package/dist/dependency/kysely/index.js +9 -0
  241. package/dist/dependency/kysely/index.js.map +1 -0
  242. package/dist/dependency/zettel-ast/index.d.ts.map +1 -0
  243. package/dist/dependency/zettel-ast/index.js.map +1 -0
  244. package/dist/diff/index.d.ts +3 -0
  245. package/dist/diff/index.d.ts.map +1 -0
  246. package/dist/diff/index.js +3 -0
  247. package/dist/diff/index.js.map +1 -0
  248. package/dist/diff/select-commit-diff.bench.d.ts +2 -0
  249. package/dist/diff/select-commit-diff.bench.d.ts.map +1 -0
  250. package/dist/diff/select-commit-diff.bench.js +136 -0
  251. package/dist/diff/select-commit-diff.bench.js.map +1 -0
  252. package/dist/diff/select-commit-diff.d.ts +56 -0
  253. package/dist/diff/select-commit-diff.d.ts.map +1 -0
  254. package/dist/diff/select-commit-diff.js +212 -0
  255. package/dist/diff/select-commit-diff.js.map +1 -0
  256. package/dist/diff/select-commit-diff.test.d.ts +2 -0
  257. package/dist/diff/select-commit-diff.test.d.ts.map +1 -0
  258. package/dist/diff/select-commit-diff.test.js +52 -0
  259. package/dist/diff/select-commit-diff.test.js.map +1 -0
  260. package/dist/diff/select-working-diff.bench.d.ts +2 -0
  261. package/dist/diff/select-working-diff.bench.d.ts.map +1 -0
  262. package/dist/diff/select-working-diff.bench.js +82 -0
  263. package/dist/diff/select-working-diff.bench.js.map +1 -0
  264. package/dist/diff/select-working-diff.d.ts +105 -0
  265. package/dist/diff/select-working-diff.d.ts.map +1 -0
  266. package/dist/diff/select-working-diff.js +95 -0
  267. package/dist/diff/select-working-diff.js.map +1 -0
  268. package/dist/diff/select-working-diff.test.d.ts +2 -0
  269. package/dist/diff/select-working-diff.test.d.ts.map +1 -0
  270. package/dist/diff/select-working-diff.test.js +231 -0
  271. package/dist/diff/select-working-diff.test.js.map +1 -0
  272. package/dist/engine/boot.d.ts +90 -0
  273. package/dist/engine/boot.d.ts.map +1 -0
  274. package/dist/engine/boot.js +149 -0
  275. package/dist/engine/boot.js.map +1 -0
  276. package/dist/engine/boot.test.d.ts +2 -0
  277. package/dist/engine/boot.test.d.ts.map +1 -0
  278. package/dist/engine/boot.test.js +75 -0
  279. package/dist/engine/boot.test.js.map +1 -0
  280. package/dist/engine/cel-environment/cel-environment.d.ts +17 -0
  281. package/dist/engine/cel-environment/cel-environment.d.ts.map +1 -0
  282. package/dist/engine/cel-environment/cel-environment.js +54 -0
  283. package/dist/engine/cel-environment/cel-environment.js.map +1 -0
  284. package/dist/engine/cel-environment/cel-environment.test.d.ts +2 -0
  285. package/dist/engine/cel-environment/cel-environment.test.d.ts.map +1 -0
  286. package/dist/engine/cel-environment/cel-environment.test.js +19 -0
  287. package/dist/engine/cel-environment/cel-environment.test.js.map +1 -0
  288. package/dist/engine/deterministic-mode/is-deterministic-mode.d.ts +36 -0
  289. package/dist/engine/deterministic-mode/is-deterministic-mode.d.ts.map +1 -0
  290. package/dist/engine/deterministic-mode/is-deterministic-mode.js +80 -0
  291. package/dist/engine/deterministic-mode/is-deterministic-mode.js.map +1 -0
  292. package/dist/engine/deterministic-mode/is-deterministic-mode.test.d.ts.map +1 -0
  293. package/dist/engine/deterministic-mode/is-deterministic-mode.test.js +95 -0
  294. package/dist/engine/deterministic-mode/is-deterministic-mode.test.js.map +1 -0
  295. package/dist/engine/deterministic-mode/options.d.ts +48 -0
  296. package/dist/engine/deterministic-mode/options.d.ts.map +1 -0
  297. package/dist/engine/deterministic-mode/options.js +47 -0
  298. package/dist/engine/deterministic-mode/options.js.map +1 -0
  299. package/dist/engine/deterministic-mode/options.test.d.ts.map +1 -0
  300. package/dist/engine/deterministic-mode/options.test.js +111 -0
  301. package/dist/engine/deterministic-mode/options.test.js.map +1 -0
  302. package/dist/engine/entity-views/build-json-object-entries.d.ts +12 -0
  303. package/dist/engine/entity-views/build-json-object-entries.d.ts.map +1 -0
  304. package/dist/engine/entity-views/build-json-object-entries.js +37 -0
  305. package/dist/engine/entity-views/build-json-object-entries.js.map +1 -0
  306. package/dist/engine/entity-views/build-json-object-entries.test.d.ts +2 -0
  307. package/dist/engine/entity-views/build-json-object-entries.test.d.ts.map +1 -0
  308. package/dist/engine/entity-views/build-json-object-entries.test.js +35 -0
  309. package/dist/engine/entity-views/build-json-object-entries.test.js.map +1 -0
  310. package/dist/engine/entity-views/entity-state-by-version.d.ts +238 -0
  311. package/dist/engine/entity-views/entity-state-by-version.d.ts.map +1 -0
  312. package/dist/engine/entity-views/entity-state-by-version.js +2 -0
  313. package/dist/engine/entity-views/entity-state-by-version.js.map +1 -0
  314. package/dist/engine/entity-views/entity-state-history.d.ts +189 -0
  315. package/dist/engine/entity-views/entity-state-history.d.ts.map +1 -0
  316. package/dist/engine/entity-views/entity-state-history.js +2 -0
  317. package/dist/engine/entity-views/entity-state-history.js.map +1 -0
  318. package/dist/engine/entity-views/entity-state.d.ts +218 -0
  319. package/dist/engine/entity-views/entity-state.d.ts.map +1 -0
  320. package/dist/engine/entity-views/entity-state.js +2 -0
  321. package/dist/engine/entity-views/entity-state.js.map +1 -0
  322. package/dist/engine/entity-views/entity-view-builder.d.ts +34 -0
  323. package/dist/engine/entity-views/entity-view-builder.d.ts.map +1 -0
  324. package/dist/engine/entity-views/entity-view-builder.js +4 -0
  325. package/dist/engine/entity-views/entity-view-builder.js.map +1 -0
  326. package/dist/engine/entity-views/index.d.ts.map +1 -0
  327. package/dist/engine/entity-views/index.js.map +1 -0
  328. package/dist/engine/entity-views/types.d.ts +309 -0
  329. package/dist/engine/entity-views/types.d.ts.map +1 -0
  330. package/dist/engine/entity-views/types.js.map +1 -0
  331. package/dist/engine/entity-views/types.test.d.ts.map +1 -0
  332. package/dist/engine/entity-views/types.test.js +62 -0
  333. package/dist/engine/entity-views/types.test.js.map +1 -0
  334. package/dist/engine/execute-sync.d.ts +5 -0
  335. package/dist/engine/execute-sync.d.ts.map +1 -0
  336. package/dist/engine/execute-sync.js +38 -0
  337. package/dist/engine/execute-sync.js.map +1 -0
  338. package/dist/engine/execute-sync.test.d.ts.map +1 -0
  339. package/dist/engine/execute-sync.test.js +64 -0
  340. package/dist/engine/execute-sync.test.js.map +1 -0
  341. package/dist/engine/explain-query.d.ts +15 -0
  342. package/dist/engine/explain-query.d.ts.map +1 -0
  343. package/dist/engine/explain-query.js +66 -0
  344. package/dist/engine/explain-query.js.map +1 -0
  345. package/dist/engine/explain-query.test.d.ts +2 -0
  346. package/dist/engine/explain-query.test.d.ts.map +1 -0
  347. package/dist/engine/explain-query.test.js +17 -0
  348. package/dist/engine/explain-query.test.js.map +1 -0
  349. package/dist/engine/functions/function-registry.d.ts +20 -0
  350. package/dist/engine/functions/function-registry.d.ts.map +1 -0
  351. package/dist/engine/functions/function-registry.js +25 -0
  352. package/dist/engine/functions/function-registry.js.map +1 -0
  353. package/dist/engine/functions/generate-human-id.d.ts +43 -0
  354. package/dist/engine/functions/generate-human-id.d.ts.map +1 -0
  355. package/dist/engine/functions/generate-human-id.js +335 -0
  356. package/dist/engine/functions/generate-human-id.js.map +1 -0
  357. package/dist/engine/functions/generate-human-id.test.d.ts.map +1 -0
  358. package/dist/engine/functions/generate-human-id.test.js +156 -0
  359. package/dist/engine/functions/generate-human-id.test.js.map +1 -0
  360. package/dist/engine/functions/index.d.ts +7 -0
  361. package/dist/engine/functions/index.d.ts.map +1 -0
  362. package/dist/engine/functions/index.js +7 -0
  363. package/dist/engine/functions/index.js.map +1 -0
  364. package/dist/engine/functions/nano-id.bench.d.ts +2 -0
  365. package/dist/engine/functions/nano-id.bench.d.ts.map +1 -0
  366. package/dist/engine/functions/nano-id.bench.js +48 -0
  367. package/dist/engine/functions/nano-id.bench.js.map +1 -0
  368. package/dist/engine/functions/nano-id.d.ts +69 -0
  369. package/dist/engine/functions/nano-id.d.ts.map +1 -0
  370. package/dist/engine/functions/nano-id.js +170 -0
  371. package/dist/engine/functions/nano-id.js.map +1 -0
  372. package/dist/engine/functions/nano-id.test.d.ts.map +1 -0
  373. package/dist/engine/functions/nano-id.test.js +163 -0
  374. package/dist/engine/functions/nano-id.test.js.map +1 -0
  375. package/dist/engine/functions/random.d.ts +57 -0
  376. package/dist/engine/functions/random.d.ts.map +1 -0
  377. package/dist/engine/functions/random.js +214 -0
  378. package/dist/engine/functions/random.js.map +1 -0
  379. package/dist/engine/functions/random.test.d.ts.map +1 -0
  380. package/dist/engine/functions/random.test.js +244 -0
  381. package/dist/engine/functions/random.test.js.map +1 -0
  382. package/dist/engine/functions/register-builtins.d.ts +9 -0
  383. package/dist/engine/functions/register-builtins.d.ts.map +1 -0
  384. package/dist/engine/functions/register-builtins.js +110 -0
  385. package/dist/engine/functions/register-builtins.js.map +1 -0
  386. package/dist/engine/functions/sequence.d.ts +77 -0
  387. package/dist/engine/functions/sequence.d.ts.map +1 -0
  388. package/dist/engine/functions/sequence.js +136 -0
  389. package/dist/engine/functions/sequence.js.map +1 -0
  390. package/dist/engine/functions/sequence.test.d.ts.map +1 -0
  391. package/dist/engine/functions/sequence.test.js +77 -0
  392. package/dist/engine/functions/sequence.test.js.map +1 -0
  393. package/dist/engine/functions/timestamp.d.ts +44 -0
  394. package/dist/engine/functions/timestamp.d.ts.map +1 -0
  395. package/dist/engine/functions/timestamp.js +70 -0
  396. package/dist/engine/functions/timestamp.js.map +1 -0
  397. package/dist/engine/functions/timestamp.test.d.ts.map +1 -0
  398. package/dist/engine/functions/timestamp.test.js +147 -0
  399. package/dist/engine/functions/timestamp.test.js.map +1 -0
  400. package/dist/engine/functions/uuid-v7.d.ts +50 -0
  401. package/dist/engine/functions/uuid-v7.d.ts.map +1 -0
  402. package/dist/engine/functions/uuid-v7.js +75 -0
  403. package/dist/engine/functions/uuid-v7.js.map +1 -0
  404. package/dist/engine/functions/uuid-v7.test.d.ts.map +1 -0
  405. package/dist/engine/functions/uuid-v7.test.js +114 -0
  406. package/dist/engine/functions/uuid-v7.test.js.map +1 -0
  407. package/dist/engine/index.d.ts +2 -0
  408. package/dist/engine/index.d.ts.map +1 -0
  409. package/dist/engine/index.js +2 -0
  410. package/dist/engine/index.js.map +1 -0
  411. package/dist/engine/internal-query-builder.d.ts +26 -0
  412. package/dist/engine/internal-query-builder.d.ts.map +1 -0
  413. package/dist/engine/internal-query-builder.js +34 -0
  414. package/dist/engine/internal-query-builder.js.map +1 -0
  415. package/dist/engine/preprocessor/create-preprocessor.d.ts +18 -0
  416. package/dist/engine/preprocessor/create-preprocessor.d.ts.map +1 -0
  417. package/dist/engine/preprocessor/create-preprocessor.js +217 -0
  418. package/dist/engine/preprocessor/create-preprocessor.js.map +1 -0
  419. package/dist/engine/preprocessor/create-preprocessor.test.d.ts +2 -0
  420. package/dist/engine/preprocessor/create-preprocessor.test.d.ts.map +1 -0
  421. package/dist/engine/preprocessor/create-preprocessor.test.js +216 -0
  422. package/dist/engine/preprocessor/create-preprocessor.test.js.map +1 -0
  423. package/dist/engine/preprocessor/entity-views/delete.d.ts +3 -0
  424. package/dist/engine/preprocessor/entity-views/delete.d.ts.map +1 -0
  425. package/dist/engine/preprocessor/entity-views/delete.js +235 -0
  426. package/dist/engine/preprocessor/entity-views/delete.js.map +1 -0
  427. package/dist/engine/preprocessor/entity-views/delete.test.d.ts +2 -0
  428. package/dist/engine/preprocessor/entity-views/delete.test.d.ts.map +1 -0
  429. package/dist/engine/preprocessor/entity-views/delete.test.js +700 -0
  430. package/dist/engine/preprocessor/entity-views/delete.test.js.map +1 -0
  431. package/dist/engine/preprocessor/entity-views/insert.d.ts +3 -0
  432. package/dist/engine/preprocessor/entity-views/insert.d.ts.map +1 -0
  433. package/dist/engine/preprocessor/entity-views/insert.js +675 -0
  434. package/dist/engine/preprocessor/entity-views/insert.js.map +1 -0
  435. package/dist/engine/preprocessor/entity-views/insert.test.d.ts +2 -0
  436. package/dist/engine/preprocessor/entity-views/insert.test.d.ts.map +1 -0
  437. package/dist/engine/preprocessor/entity-views/insert.test.js +1014 -0
  438. package/dist/engine/preprocessor/entity-views/insert.test.js.map +1 -0
  439. package/dist/engine/preprocessor/entity-views/select.bench.d.ts +2 -0
  440. package/dist/engine/preprocessor/entity-views/select.bench.d.ts.map +1 -0
  441. package/dist/engine/preprocessor/entity-views/select.bench.js +145 -0
  442. package/dist/engine/preprocessor/entity-views/select.bench.js.map +1 -0
  443. package/dist/engine/preprocessor/entity-views/select.d.ts +6 -0
  444. package/dist/engine/preprocessor/entity-views/select.d.ts.map +1 -0
  445. package/dist/engine/preprocessor/entity-views/select.js +1306 -0
  446. package/dist/engine/preprocessor/entity-views/select.js.map +1 -0
  447. package/dist/engine/preprocessor/entity-views/select.test.d.ts +2 -0
  448. package/dist/engine/preprocessor/entity-views/select.test.d.ts.map +1 -0
  449. package/dist/engine/preprocessor/entity-views/select.test.js +320 -0
  450. package/dist/engine/preprocessor/entity-views/select.test.js.map +1 -0
  451. package/dist/engine/preprocessor/entity-views/shared.d.ts +165 -0
  452. package/dist/engine/preprocessor/entity-views/shared.d.ts.map +1 -0
  453. package/dist/engine/preprocessor/entity-views/shared.js +1080 -0
  454. package/dist/engine/preprocessor/entity-views/shared.js.map +1 -0
  455. package/dist/engine/preprocessor/entity-views/update.d.ts +3 -0
  456. package/dist/engine/preprocessor/entity-views/update.d.ts.map +1 -0
  457. package/dist/engine/preprocessor/entity-views/update.js +527 -0
  458. package/dist/engine/preprocessor/entity-views/update.js.map +1 -0
  459. package/dist/engine/preprocessor/entity-views/update.test.d.ts +2 -0
  460. package/dist/engine/preprocessor/entity-views/update.test.d.ts.map +1 -0
  461. package/dist/engine/preprocessor/entity-views/update.test.js +356 -0
  462. package/dist/engine/preprocessor/entity-views/update.test.js.map +1 -0
  463. package/dist/engine/preprocessor/inheritance/version-inheritance-cache.d.ts +38 -0
  464. package/dist/engine/preprocessor/inheritance/version-inheritance-cache.d.ts.map +1 -0
  465. package/dist/engine/preprocessor/inheritance/version-inheritance-cache.js +296 -0
  466. package/dist/engine/preprocessor/inheritance/version-inheritance-cache.js.map +1 -0
  467. package/dist/engine/preprocessor/inheritance/version-inheritance-cache.test.d.ts +2 -0
  468. package/dist/engine/preprocessor/inheritance/version-inheritance-cache.test.d.ts.map +1 -0
  469. package/dist/engine/preprocessor/inheritance/version-inheritance-cache.test.js +80 -0
  470. package/dist/engine/preprocessor/inheritance/version-inheritance-cache.test.js.map +1 -0
  471. package/dist/engine/preprocessor/sql-parser/ast-helpers.d.ts +110 -0
  472. package/dist/engine/preprocessor/sql-parser/ast-helpers.d.ts.map +1 -0
  473. package/dist/engine/preprocessor/sql-parser/ast-helpers.js +196 -0
  474. package/dist/engine/preprocessor/sql-parser/ast-helpers.js.map +1 -0
  475. package/dist/engine/preprocessor/sql-parser/column-usage.d.ts +14 -0
  476. package/dist/engine/preprocessor/sql-parser/column-usage.d.ts.map +1 -0
  477. package/dist/engine/preprocessor/sql-parser/column-usage.js +300 -0
  478. package/dist/engine/preprocessor/sql-parser/column-usage.js.map +1 -0
  479. package/dist/engine/preprocessor/sql-parser/compile.d.ts +30 -0
  480. package/dist/engine/preprocessor/sql-parser/compile.d.ts.map +1 -0
  481. package/dist/engine/preprocessor/sql-parser/compile.js +719 -0
  482. package/dist/engine/preprocessor/sql-parser/compile.js.map +1 -0
  483. package/dist/engine/preprocessor/sql-parser/compile.test.d.ts +2 -0
  484. package/dist/engine/preprocessor/sql-parser/compile.test.d.ts.map +1 -0
  485. package/dist/engine/preprocessor/sql-parser/compile.test.js +100 -0
  486. package/dist/engine/preprocessor/sql-parser/compile.test.js.map +1 -0
  487. package/dist/engine/preprocessor/sql-parser/cst.d.ts +49 -0
  488. package/dist/engine/preprocessor/sql-parser/cst.d.ts.map +1 -0
  489. package/dist/engine/preprocessor/sql-parser/cst.js +768 -0
  490. package/dist/engine/preprocessor/sql-parser/cst.js.map +1 -0
  491. package/dist/engine/preprocessor/sql-parser/lexer.d.ts +93 -0
  492. package/dist/engine/preprocessor/sql-parser/lexer.d.ts.map +1 -0
  493. package/dist/engine/preprocessor/sql-parser/lexer.js +517 -0
  494. package/dist/engine/preprocessor/sql-parser/lexer.js.map +1 -0
  495. package/dist/engine/preprocessor/sql-parser/nodes.d.ts +268 -0
  496. package/dist/engine/preprocessor/sql-parser/nodes.d.ts.map +1 -0
  497. package/dist/engine/preprocessor/sql-parser/nodes.js +20 -0
  498. package/dist/engine/preprocessor/sql-parser/nodes.js.map +1 -0
  499. package/dist/engine/preprocessor/sql-parser/parse.d.ts +15 -0
  500. package/dist/engine/preprocessor/sql-parser/parse.d.ts.map +1 -0
  501. package/dist/engine/preprocessor/sql-parser/parse.js +1503 -0
  502. package/dist/engine/preprocessor/sql-parser/parse.js.map +1 -0
  503. package/dist/engine/preprocessor/sql-parser/parse.test.d.ts +2 -0
  504. package/dist/engine/preprocessor/sql-parser/parse.test.d.ts.map +1 -0
  505. package/dist/engine/preprocessor/sql-parser/parse.test.js +1483 -0
  506. package/dist/engine/preprocessor/sql-parser/parse.test.js.map +1 -0
  507. package/dist/engine/preprocessor/sql-parser/visitor.d.ts +80 -0
  508. package/dist/engine/preprocessor/sql-parser/visitor.d.ts.map +1 -0
  509. package/dist/engine/preprocessor/sql-parser/visitor.js +875 -0
  510. package/dist/engine/preprocessor/sql-parser/visitor.js.map +1 -0
  511. package/dist/engine/preprocessor/sql-parser/visitor.test.d.ts +2 -0
  512. package/dist/engine/preprocessor/sql-parser/visitor.test.d.ts.map +1 -0
  513. package/dist/engine/preprocessor/sql-parser/visitor.test.js +142 -0
  514. package/dist/engine/preprocessor/sql-parser/visitor.test.js.map +1 -0
  515. package/dist/engine/preprocessor/steps/cache-populator.d.ts +12 -0
  516. package/dist/engine/preprocessor/steps/cache-populator.d.ts.map +1 -0
  517. package/dist/engine/preprocessor/steps/cache-populator.js +603 -0
  518. package/dist/engine/preprocessor/steps/cache-populator.js.map +1 -0
  519. package/dist/engine/preprocessor/steps/cache-populator.test.d.ts +2 -0
  520. package/dist/engine/preprocessor/steps/cache-populator.test.d.ts.map +1 -0
  521. package/dist/engine/preprocessor/steps/cache-populator.test.js +95 -0
  522. package/dist/engine/preprocessor/steps/cache-populator.test.js.map +1 -0
  523. package/dist/engine/preprocessor/steps/expand-sql-views.d.ts +13 -0
  524. package/dist/engine/preprocessor/steps/expand-sql-views.d.ts.map +1 -0
  525. package/dist/engine/preprocessor/steps/expand-sql-views.js +894 -0
  526. package/dist/engine/preprocessor/steps/expand-sql-views.js.map +1 -0
  527. package/dist/engine/preprocessor/steps/expand-sql-views.test.d.ts +2 -0
  528. package/dist/engine/preprocessor/steps/expand-sql-views.test.d.ts.map +1 -0
  529. package/dist/engine/preprocessor/steps/expand-sql-views.test.js +1177 -0
  530. package/dist/engine/preprocessor/steps/expand-sql-views.test.js.map +1 -0
  531. package/dist/engine/preprocessor/steps/rewrite-active-version-subquery.d.ts +7 -0
  532. package/dist/engine/preprocessor/steps/rewrite-active-version-subquery.d.ts.map +1 -0
  533. package/dist/engine/preprocessor/steps/rewrite-active-version-subquery.js +190 -0
  534. package/dist/engine/preprocessor/steps/rewrite-active-version-subquery.js.map +1 -0
  535. package/dist/engine/preprocessor/steps/rewrite-active-version-subquery.test.d.ts +2 -0
  536. package/dist/engine/preprocessor/steps/rewrite-active-version-subquery.test.d.ts.map +1 -0
  537. package/dist/engine/preprocessor/steps/rewrite-active-version-subquery.test.js +74 -0
  538. package/dist/engine/preprocessor/steps/rewrite-active-version-subquery.test.js.map +1 -0
  539. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.bench.d.ts +2 -0
  540. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.bench.d.ts.map +1 -0
  541. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.bench.js +64 -0
  542. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.bench.js.map +1 -0
  543. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.d.ts +16 -0
  544. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.d.ts.map +1 -0
  545. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.js +2305 -0
  546. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.js.map +1 -0
  547. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.test.d.ts +2 -0
  548. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.test.d.ts.map +1 -0
  549. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.test.js +975 -0
  550. package/dist/engine/preprocessor/steps/rewrite-vtable-selects.test.js.map +1 -0
  551. package/dist/engine/preprocessor/types.d.ts +93 -0
  552. package/dist/engine/preprocessor/types.d.ts.map +1 -0
  553. package/dist/engine/preprocessor/types.js.map +1 -0
  554. package/dist/engine/sql-parser/tokenizer.d.ts +60 -0
  555. package/dist/engine/sql-parser/tokenizer.d.ts.map +1 -0
  556. package/dist/engine/sql-parser/tokenizer.js +188 -0
  557. package/dist/engine/sql-parser/tokenizer.js.map +1 -0
  558. package/dist/engine/sql-parser/tokenizer.test.d.ts +2 -0
  559. package/dist/engine/sql-parser/tokenizer.test.d.ts.map +1 -0
  560. package/dist/engine/sql-parser/tokenizer.test.js +252 -0
  561. package/dist/engine/sql-parser/tokenizer.test.js.map +1 -0
  562. package/dist/engine/with-runtime-cache.d.ts +27 -0
  563. package/dist/engine/with-runtime-cache.d.ts.map +1 -0
  564. package/dist/engine/with-runtime-cache.js +140 -0
  565. package/dist/engine/with-runtime-cache.js.map +1 -0
  566. package/dist/engine/with-runtime-cache.test.d.ts +2 -0
  567. package/dist/engine/with-runtime-cache.test.d.ts.map +1 -0
  568. package/dist/engine/with-runtime-cache.test.js +129 -0
  569. package/dist/engine/with-runtime-cache.test.js.map +1 -0
  570. package/dist/entity/conversation/attach-conversation.d.ts +49 -0
  571. package/dist/entity/conversation/attach-conversation.d.ts.map +1 -0
  572. package/dist/entity/conversation/attach-conversation.js +74 -0
  573. package/dist/entity/conversation/attach-conversation.js.map +1 -0
  574. package/dist/entity/conversation/attach-conversation.test.d.ts +2 -0
  575. package/dist/entity/conversation/attach-conversation.test.d.ts.map +1 -0
  576. package/dist/entity/conversation/attach-conversation.test.js +220 -0
  577. package/dist/entity/conversation/attach-conversation.test.js.map +1 -0
  578. package/dist/entity/conversation/schema-definition.d.ts +43 -0
  579. package/dist/entity/conversation/schema-definition.d.ts.map +1 -0
  580. package/dist/entity/conversation/schema-definition.js +44 -0
  581. package/dist/entity/conversation/schema-definition.js.map +1 -0
  582. package/dist/entity/conversation/schema.test.d.ts.map +1 -0
  583. package/dist/entity/conversation/schema.test.js +91 -0
  584. package/dist/entity/conversation/schema.test.js.map +1 -0
  585. package/dist/entity/eb-entity.d.ts +4 -4
  586. package/dist/entity/eb-entity.d.ts.map +1 -1
  587. package/dist/entity/eb-entity.js +6 -6
  588. package/dist/entity/eb-entity.js.map +1 -1
  589. package/dist/entity/eb-entity.test.js +143 -66
  590. package/dist/entity/eb-entity.test.js.map +1 -1
  591. package/dist/entity/index.d.ts +5 -5
  592. package/dist/entity/index.d.ts.map +1 -1
  593. package/dist/entity/index.js +2 -2
  594. package/dist/entity/index.js.map +1 -1
  595. package/dist/entity/label/attach-label.d.ts +79 -0
  596. package/dist/entity/label/attach-label.d.ts.map +1 -0
  597. package/dist/entity/label/attach-label.js +144 -0
  598. package/dist/entity/label/attach-label.js.map +1 -0
  599. package/dist/entity/label/attach-label.test.d.ts +2 -0
  600. package/dist/entity/label/attach-label.test.d.ts.map +1 -0
  601. package/dist/entity/label/attach-label.test.js +295 -0
  602. package/dist/entity/label/attach-label.test.js.map +1 -0
  603. package/dist/entity/label/schema-definition.d.ts +43 -0
  604. package/dist/entity/label/schema-definition.d.ts.map +1 -0
  605. package/dist/entity/label/schema-definition.js +39 -0
  606. package/dist/entity/label/schema-definition.js.map +1 -0
  607. package/dist/entity/label/schema.test.js +266 -33
  608. package/dist/entity/label/schema.test.js.map +1 -1
  609. package/dist/entity/types.d.ts +11 -0
  610. package/dist/entity/types.d.ts.map +1 -0
  611. package/dist/entity/types.js +2 -0
  612. package/dist/entity/types.js.map +1 -0
  613. package/dist/environment/api.d.ts +38 -0
  614. package/dist/environment/api.d.ts.map +1 -0
  615. package/dist/environment/api.js +2 -0
  616. package/dist/environment/api.js.map +1 -0
  617. package/dist/environment/api.test.d.ts +2 -0
  618. package/dist/environment/api.test.d.ts.map +1 -0
  619. package/dist/environment/api.test.js +76 -0
  620. package/dist/environment/api.test.js.map +1 -0
  621. package/dist/environment/in-memory.d.ts +22 -0
  622. package/dist/environment/in-memory.d.ts.map +1 -0
  623. package/dist/environment/in-memory.js +55 -0
  624. package/dist/environment/in-memory.js.map +1 -0
  625. package/dist/environment/in-memory.test.d.ts.map +1 -0
  626. package/dist/environment/in-memory.test.js +69 -0
  627. package/dist/environment/in-memory.test.js.map +1 -0
  628. package/dist/environment/index.d.ts +4 -0
  629. package/dist/environment/index.d.ts.map +1 -0
  630. package/dist/environment/index.js +3 -0
  631. package/dist/environment/index.js.map +1 -0
  632. package/dist/environment/kysely/kysely-driver.test.d.ts +2 -0
  633. package/dist/environment/kysely/kysely-driver.test.d.ts.map +1 -0
  634. package/dist/environment/kysely/kysely-driver.test.js +26 -0
  635. package/dist/environment/kysely/kysely-driver.test.js.map +1 -0
  636. package/dist/environment/load-from-string.d.ts +3 -0
  637. package/dist/environment/load-from-string.d.ts.map +1 -0
  638. package/dist/environment/load-from-string.js +64 -0
  639. package/dist/environment/load-from-string.js.map +1 -0
  640. package/dist/environment/load-from-string.test.d.ts +2 -0
  641. package/dist/environment/load-from-string.test.d.ts.map +1 -0
  642. package/dist/environment/load-from-string.test.js +16 -0
  643. package/dist/environment/load-from-string.test.js.map +1 -0
  644. package/dist/environment/opfs-sah.browser.test.d.ts +2 -0
  645. package/dist/environment/opfs-sah.browser.test.d.ts.map +1 -0
  646. package/dist/environment/opfs-sah.browser.test.js +309 -0
  647. package/dist/environment/opfs-sah.browser.test.js.map +1 -0
  648. package/dist/environment/opfs-sah.d.ts +63 -0
  649. package/dist/environment/opfs-sah.d.ts.map +1 -0
  650. package/dist/environment/opfs-sah.js +240 -0
  651. package/dist/environment/opfs-sah.js.map +1 -0
  652. package/dist/environment/opfs-sah.worker.d.ts +2 -0
  653. package/dist/environment/opfs-sah.worker.d.ts.map +1 -0
  654. package/dist/environment/opfs-sah.worker.js +212 -0
  655. package/dist/environment/opfs-sah.worker.js.map +1 -0
  656. package/dist/environment/test-actors/echo.actor.d.ts +2 -0
  657. package/dist/environment/test-actors/echo.actor.d.ts.map +1 -0
  658. package/dist/environment/test-actors/echo.actor.js +7 -0
  659. package/dist/environment/test-actors/echo.actor.js.map +1 -0
  660. package/dist/filesystem/directory/ensure-directories.d.ts +48 -0
  661. package/dist/filesystem/directory/ensure-directories.d.ts.map +1 -0
  662. package/dist/filesystem/directory/ensure-directories.js +223 -0
  663. package/dist/filesystem/directory/ensure-directories.js.map +1 -0
  664. package/dist/filesystem/directory/schema-definition.d.ts +36 -0
  665. package/dist/filesystem/directory/schema-definition.d.ts.map +1 -0
  666. package/dist/filesystem/directory/schema-definition.js +35 -0
  667. package/dist/filesystem/directory/schema-definition.js.map +1 -0
  668. package/dist/filesystem/directory/schema.d.ts +11 -0
  669. package/dist/filesystem/directory/schema.d.ts.map +1 -0
  670. package/dist/filesystem/directory/schema.js +494 -0
  671. package/dist/filesystem/directory/schema.js.map +1 -0
  672. package/dist/filesystem/directory/schema.test.d.ts.map +1 -0
  673. package/dist/filesystem/directory/schema.test.js +93 -0
  674. package/dist/filesystem/directory/schema.test.js.map +1 -0
  675. package/dist/filesystem/file/cache/clear-file-data-cache.d.ts +17 -0
  676. package/dist/filesystem/file/cache/clear-file-data-cache.d.ts.map +1 -0
  677. package/dist/filesystem/file/cache/clear-file-data-cache.js +54 -0
  678. package/dist/filesystem/file/cache/clear-file-data-cache.js.map +1 -0
  679. package/dist/filesystem/file/cache/lixcol-schema.d.ts +27 -0
  680. package/dist/filesystem/file/cache/lixcol-schema.d.ts.map +1 -0
  681. package/dist/filesystem/file/cache/lixcol-schema.js +31 -0
  682. package/dist/filesystem/file/cache/lixcol-schema.js.map +1 -0
  683. package/dist/filesystem/file/cache/path-cache-schema.d.ts +25 -0
  684. package/dist/filesystem/file/cache/path-cache-schema.d.ts.map +1 -0
  685. package/dist/filesystem/file/cache/path-cache-schema.js +30 -0
  686. package/dist/filesystem/file/cache/path-cache-schema.js.map +1 -0
  687. package/dist/filesystem/file/cache/schema.d.ts +21 -0
  688. package/dist/filesystem/file/cache/schema.d.ts.map +1 -0
  689. package/dist/filesystem/file/cache/schema.js +24 -0
  690. package/dist/filesystem/file/cache/schema.js.map +1 -0
  691. package/dist/filesystem/file/cache/schema.test.d.ts.map +1 -0
  692. package/dist/filesystem/file/cache/schema.test.js +264 -0
  693. package/dist/filesystem/file/cache/schema.test.js.map +1 -0
  694. package/dist/filesystem/file/cache/update-file-data-cache.d.ts +20 -0
  695. package/dist/filesystem/file/cache/update-file-data-cache.d.ts.map +1 -0
  696. package/dist/filesystem/file/cache/update-file-data-cache.js +25 -0
  697. package/dist/filesystem/file/cache/update-file-data-cache.js.map +1 -0
  698. package/dist/filesystem/file/cache/update-file-lixcol-cache.d.ts +21 -0
  699. package/dist/filesystem/file/cache/update-file-lixcol-cache.d.ts.map +1 -0
  700. package/dist/filesystem/file/cache/update-file-lixcol-cache.js +78 -0
  701. package/dist/filesystem/file/cache/update-file-lixcol-cache.js.map +1 -0
  702. package/dist/filesystem/file/cache/update-file-path-cache.d.ts +25 -0
  703. package/dist/filesystem/file/cache/update-file-path-cache.d.ts.map +1 -0
  704. package/dist/filesystem/file/cache/update-file-path-cache.js +38 -0
  705. package/dist/filesystem/file/cache/update-file-path-cache.js.map +1 -0
  706. package/dist/filesystem/file/descriptor-utils.d.ts +70 -0
  707. package/dist/filesystem/file/descriptor-utils.d.ts.map +1 -0
  708. package/dist/filesystem/file/descriptor-utils.js +218 -0
  709. package/dist/filesystem/file/descriptor-utils.js.map +1 -0
  710. package/dist/filesystem/file/file-handlers.d.ts +22 -0
  711. package/dist/filesystem/file/file-handlers.d.ts.map +1 -0
  712. package/dist/filesystem/file/file-handlers.js +540 -0
  713. package/dist/filesystem/file/file-handlers.js.map +1 -0
  714. package/dist/filesystem/file/file-handlers.test.d.ts.map +1 -0
  715. package/dist/filesystem/file/file-handlers.test.js +344 -0
  716. package/dist/filesystem/file/file-handlers.test.js.map +1 -0
  717. package/dist/filesystem/file/materialize-file-data-at-commit.d.ts +9 -0
  718. package/dist/filesystem/file/materialize-file-data-at-commit.d.ts.map +1 -0
  719. package/dist/filesystem/file/materialize-file-data-at-commit.js +156 -0
  720. package/dist/filesystem/file/materialize-file-data-at-commit.js.map +1 -0
  721. package/dist/filesystem/file/materialize-file-data.d.ts +8 -0
  722. package/dist/filesystem/file/materialize-file-data.d.ts.map +1 -0
  723. package/dist/filesystem/file/materialize-file-data.js +111 -0
  724. package/dist/filesystem/file/materialize-file-data.js.map +1 -0
  725. package/dist/filesystem/file/materialize-file-data.test.d.ts.map +1 -0
  726. package/dist/filesystem/file/materialize-file-data.test.js +104 -0
  727. package/dist/filesystem/file/materialize-file-data.test.js.map +1 -0
  728. package/dist/filesystem/file/schema-definition.d.ts +46 -0
  729. package/dist/filesystem/file/schema-definition.d.ts.map +1 -0
  730. package/dist/filesystem/file/schema-definition.js +39 -0
  731. package/dist/filesystem/file/schema-definition.js.map +1 -0
  732. package/dist/filesystem/file/schema.d.ts +47 -0
  733. package/dist/filesystem/file/schema.d.ts.map +1 -0
  734. package/dist/filesystem/file/schema.js +610 -0
  735. package/dist/filesystem/file/schema.js.map +1 -0
  736. package/dist/filesystem/file/schema.test.d.ts.map +1 -0
  737. package/dist/filesystem/file/schema.test.js +1885 -0
  738. package/dist/filesystem/file/schema.test.js.map +1 -0
  739. package/dist/filesystem/file/select-file-data.d.ts +21 -0
  740. package/dist/filesystem/file/select-file-data.d.ts.map +1 -0
  741. package/dist/filesystem/file/select-file-data.js +48 -0
  742. package/dist/filesystem/file/select-file-data.js.map +1 -0
  743. package/dist/filesystem/file/select-file-lixcol.d.ts +27 -0
  744. package/dist/filesystem/file/select-file-lixcol.d.ts.map +1 -0
  745. package/dist/filesystem/file/select-file-lixcol.js +120 -0
  746. package/dist/filesystem/file/select-file-lixcol.js.map +1 -0
  747. package/dist/filesystem/file/store-detected-change-schema.d.ts +8 -0
  748. package/dist/filesystem/file/store-detected-change-schema.d.ts.map +1 -0
  749. package/dist/filesystem/file/store-detected-change-schema.js +38 -0
  750. package/dist/filesystem/file/store-detected-change-schema.js.map +1 -0
  751. package/dist/filesystem/file/store-detected-change-schema.test.d.ts.map +1 -0
  752. package/dist/filesystem/file/store-detected-change-schema.test.js +222 -0
  753. package/dist/filesystem/file/store-detected-change-schema.test.js.map +1 -0
  754. package/dist/filesystem/file/unknown-file-fallback-plugin.d.ts +23 -0
  755. package/dist/filesystem/file/unknown-file-fallback-plugin.d.ts.map +1 -0
  756. package/dist/filesystem/file/unknown-file-fallback-plugin.js +74 -0
  757. package/dist/filesystem/file/unknown-file-fallback-plugin.js.map +1 -0
  758. package/dist/filesystem/file/unknown-file-fallback-plugin.test.d.ts.map +1 -0
  759. package/dist/filesystem/file/unknown-file-fallback-plugin.test.js +319 -0
  760. package/dist/filesystem/file/unknown-file-fallback-plugin.test.js.map +1 -0
  761. package/dist/filesystem/fs.bench.d.ts +2 -0
  762. package/dist/filesystem/fs.bench.d.ts.map +1 -0
  763. package/dist/filesystem/fs.bench.js +534 -0
  764. package/dist/filesystem/fs.bench.js.map +1 -0
  765. package/dist/filesystem/index.d.ts +5 -0
  766. package/dist/filesystem/index.d.ts.map +1 -0
  767. package/dist/filesystem/index.js +4 -0
  768. package/dist/filesystem/index.js.map +1 -0
  769. package/dist/filesystem/path.d.ts +37 -0
  770. package/dist/filesystem/path.d.ts.map +1 -0
  771. package/dist/filesystem/path.js +94 -0
  772. package/dist/filesystem/path.js.map +1 -0
  773. package/dist/filesystem/path.test.d.ts +2 -0
  774. package/dist/filesystem/path.test.d.ts.map +1 -0
  775. package/dist/filesystem/path.test.js +102 -0
  776. package/dist/filesystem/path.test.js.map +1 -0
  777. package/dist/filesystem/schema.d.ts +11 -0
  778. package/dist/filesystem/schema.d.ts.map +1 -0
  779. package/dist/filesystem/schema.js +13 -0
  780. package/dist/filesystem/schema.js.map +1 -0
  781. package/dist/filesystem/schema.test.d.ts.map +1 -0
  782. package/dist/filesystem/schema.test.js +502 -0
  783. package/dist/filesystem/schema.test.js.map +1 -0
  784. package/dist/filesystem/util/glob.d.ts +18 -0
  785. package/dist/filesystem/util/glob.d.ts.map +1 -0
  786. package/dist/filesystem/util/glob.js +26 -0
  787. package/dist/filesystem/util/glob.js.map +1 -0
  788. package/dist/hooks/create-hooks.d.ts +66 -11
  789. package/dist/hooks/create-hooks.d.ts.map +1 -1
  790. package/dist/hooks/create-hooks.js +15 -0
  791. package/dist/hooks/create-hooks.js.map +1 -1
  792. package/dist/hooks/create-hooks.test.js +114 -17
  793. package/dist/hooks/create-hooks.test.js.map +1 -1
  794. package/dist/index.d.ts +9 -5
  795. package/dist/index.d.ts.map +1 -1
  796. package/dist/index.js +9 -5
  797. package/dist/index.js.map +1 -1
  798. package/dist/key-value/index.d.ts +1 -1
  799. package/dist/key-value/index.d.ts.map +1 -1
  800. package/dist/key-value/index.js +1 -1
  801. package/dist/key-value/index.js.map +1 -1
  802. package/dist/key-value/schema-definition.d.ts +74 -0
  803. package/dist/key-value/schema-definition.d.ts.map +1 -0
  804. package/dist/key-value/schema-definition.js +19 -0
  805. package/dist/key-value/schema-definition.js.map +1 -0
  806. package/dist/key-value/schema.test.js +113 -12
  807. package/dist/key-value/schema.test.js.map +1 -1
  808. package/dist/label/create-label.d.ts +2 -2
  809. package/dist/label/create-label.d.ts.map +1 -1
  810. package/dist/label/create-label.js +7 -4
  811. package/dist/label/create-label.js.map +1 -1
  812. package/dist/label/create-label.test.js +2 -2
  813. package/dist/label/create-label.test.js.map +1 -1
  814. package/dist/label/index.d.ts +1 -1
  815. package/dist/label/index.d.ts.map +1 -1
  816. package/dist/label/index.js +1 -1
  817. package/dist/label/index.js.map +1 -1
  818. package/dist/label/schema-definition.d.ts +24 -0
  819. package/dist/label/schema-definition.d.ts.map +1 -0
  820. package/dist/label/schema-definition.js +21 -0
  821. package/dist/label/schema-definition.js.map +1 -0
  822. package/dist/lix/index.d.ts +0 -3
  823. package/dist/lix/index.d.ts.map +1 -1
  824. package/dist/lix/index.js +0 -3
  825. package/dist/lix/index.js.map +1 -1
  826. package/dist/lix/new-lix.d.ts +3 -3
  827. package/dist/lix/new-lix.d.ts.map +1 -1
  828. package/dist/lix/new-lix.js +208 -83
  829. package/dist/lix/new-lix.js.map +1 -1
  830. package/dist/lix/new-lix.test.js +77 -23
  831. package/dist/lix/new-lix.test.js.map +1 -1
  832. package/dist/lix/open-lix.bench.d.ts +2 -0
  833. package/dist/lix/open-lix.bench.d.ts.map +1 -0
  834. package/dist/lix/open-lix.bench.js +22 -0
  835. package/dist/lix/open-lix.bench.js.map +1 -0
  836. package/dist/lix/open-lix.d.ts +85 -32
  837. package/dist/lix/open-lix.d.ts.map +1 -1
  838. package/dist/lix/open-lix.js +66 -158
  839. package/dist/lix/open-lix.js.map +1 -1
  840. package/dist/lix/open-lix.test.js +93 -18
  841. package/dist/lix/open-lix.test.js.map +1 -1
  842. package/dist/log/create-lix-own-log.d.ts +18 -19
  843. package/dist/log/create-lix-own-log.d.ts.map +1 -1
  844. package/dist/log/create-lix-own-log.js +28 -29
  845. package/dist/log/create-lix-own-log.js.map +1 -1
  846. package/dist/log/create-lix-own-log.test.js +40 -12
  847. package/dist/log/create-lix-own-log.test.js.map +1 -1
  848. package/dist/log/create-log.d.ts +22 -12
  849. package/dist/log/create-log.d.ts.map +1 -1
  850. package/dist/log/create-log.js +20 -11
  851. package/dist/log/create-log.js.map +1 -1
  852. package/dist/log/index.d.ts +1 -1
  853. package/dist/log/index.d.ts.map +1 -1
  854. package/dist/log/index.js +1 -1
  855. package/dist/log/index.js.map +1 -1
  856. package/dist/log/schema-definition.d.ts +36 -0
  857. package/dist/log/schema-definition.d.ts.map +1 -0
  858. package/dist/log/schema-definition.js +39 -0
  859. package/dist/log/schema-definition.js.map +1 -0
  860. package/dist/log/schema.test.js +51 -18
  861. package/dist/log/schema.test.js.map +1 -1
  862. package/dist/observe/create-observe.d.ts.map +1 -1
  863. package/dist/observe/create-observe.js +194 -97
  864. package/dist/observe/create-observe.js.map +1 -1
  865. package/dist/observe/create-observe.test.js +409 -19
  866. package/dist/observe/create-observe.test.js.map +1 -1
  867. package/dist/observe/determine-schema-keys.d.ts +8 -0
  868. package/dist/observe/determine-schema-keys.d.ts.map +1 -1
  869. package/dist/observe/determine-schema-keys.js +249 -7
  870. package/dist/observe/determine-schema-keys.js.map +1 -1
  871. package/dist/observe/determine-schema-keys.test.js +69 -27
  872. package/dist/observe/determine-schema-keys.test.js.map +1 -1
  873. package/dist/plugin/index.d.ts +2 -1
  874. package/dist/plugin/index.d.ts.map +1 -1
  875. package/dist/plugin/index.js +1 -0
  876. package/dist/plugin/index.js.map +1 -1
  877. package/dist/plugin/lix-plugin.d.ts +46 -7
  878. package/dist/plugin/lix-plugin.d.ts.map +1 -1
  879. package/dist/plugin/lix-plugin.test-d.js +1 -0
  880. package/dist/plugin/lix-plugin.test-d.js.map +1 -1
  881. package/dist/plugin/lix-plugin.test.d.ts +2 -0
  882. package/dist/plugin/lix-plugin.test.d.ts.map +1 -0
  883. package/dist/plugin/lix-plugin.test.js +49 -0
  884. package/dist/plugin/lix-plugin.test.js.map +1 -0
  885. package/dist/plugin/mock-json-plugin.d.ts.map +1 -1
  886. package/dist/plugin/mock-json-plugin.js +1 -0
  887. package/dist/plugin/mock-json-plugin.js.map +1 -1
  888. package/dist/plugin/mock-json-plugin.test.js +14 -4
  889. package/dist/plugin/mock-json-plugin.test.js.map +1 -1
  890. package/dist/plugin/query-sync.d.ts +85 -0
  891. package/dist/plugin/query-sync.d.ts.map +1 -0
  892. package/dist/plugin/query-sync.js +110 -0
  893. package/dist/plugin/query-sync.js.map +1 -0
  894. package/dist/plugin/query-sync.test.d.ts +2 -0
  895. package/dist/plugin/query-sync.test.d.ts.map +1 -0
  896. package/dist/plugin/query-sync.test.js +110 -0
  897. package/dist/plugin/query-sync.test.js.map +1 -0
  898. package/dist/query-filter/commit-is-ancestor-of.d.ts +1 -1
  899. package/dist/query-filter/commit-is-ancestor-of.d.ts.map +1 -1
  900. package/dist/query-filter/commit-is-ancestor-of.test.js +77 -167
  901. package/dist/query-filter/commit-is-ancestor-of.test.js.map +1 -1
  902. package/dist/query-filter/commit-is-descendant-of.d.ts +1 -1
  903. package/dist/query-filter/commit-is-descendant-of.d.ts.map +1 -1
  904. package/dist/query-filter/commit-is-descendant-of.test.js +96 -203
  905. package/dist/query-filter/commit-is-descendant-of.test.js.map +1 -1
  906. package/dist/query-filter/index.d.ts +0 -3
  907. package/dist/query-filter/index.d.ts.map +1 -1
  908. package/dist/query-filter/index.js +0 -3
  909. package/dist/query-filter/index.js.map +1 -1
  910. package/dist/schema-definition/definition.d.ts +135 -29
  911. package/dist/schema-definition/definition.d.ts.map +1 -1
  912. package/dist/schema-definition/definition.js +68 -8
  913. package/dist/schema-definition/definition.js.map +1 -1
  914. package/dist/schema-definition/definition.test-d.js +78 -10
  915. package/dist/schema-definition/definition.test-d.js.map +1 -1
  916. package/dist/schema-definition/definition.test.js +334 -98
  917. package/dist/schema-definition/definition.test.js.map +1 -1
  918. package/dist/schema-definition/json-pointer.d.ts +51 -0
  919. package/dist/schema-definition/json-pointer.d.ts.map +1 -0
  920. package/dist/schema-definition/json-pointer.js +143 -0
  921. package/dist/schema-definition/json-pointer.js.map +1 -0
  922. package/dist/schema-definition/json-pointer.test.d.ts +2 -0
  923. package/dist/schema-definition/json-pointer.test.d.ts.map +1 -0
  924. package/dist/schema-definition/json-pointer.test.js +72 -0
  925. package/dist/schema-definition/json-pointer.test.js.map +1 -0
  926. package/dist/schema-definition/validate-lix-schema.d.ts.map +1 -1
  927. package/dist/schema-definition/validate-lix-schema.js +73 -0
  928. package/dist/schema-definition/validate-lix-schema.js.map +1 -1
  929. package/dist/schema-definition/validate-lix-schema.test.js +77 -0
  930. package/dist/schema-definition/validate-lix-schema.test.js.map +1 -1
  931. package/dist/server-protocol-handler/environment/create-in-memory-environment.js +1 -1
  932. package/dist/server-protocol-handler/environment/create-in-memory-environment.js.map +1 -1
  933. package/dist/server-protocol-handler/routes/get-v1.d.ts.map +1 -1
  934. package/dist/server-protocol-handler/routes/get-v1.js +4 -2
  935. package/dist/server-protocol-handler/routes/get-v1.js.map +1 -1
  936. package/dist/server-protocol-handler/routes/push-v1.test.js +1 -1
  937. package/dist/server-protocol-handler/routes/push-v1.test.js.map +1 -1
  938. package/dist/services/env-variables/index.d.ts +1 -1
  939. package/dist/services/env-variables/index.js +2 -2
  940. package/dist/services/env-variables/index.js.map +1 -1
  941. package/dist/services/telemetry/capture.test.js +4 -4
  942. package/dist/services/telemetry/capture.test.js.map +1 -1
  943. package/dist/snapshot/schema.d.ts +1 -1
  944. package/dist/snapshot/schema.d.ts.map +1 -1
  945. package/dist/snapshot/schema.js +6 -2
  946. package/dist/snapshot/schema.js.map +1 -1
  947. package/dist/snapshot/schema.test.js +26 -26
  948. package/dist/snapshot/schema.test.js.map +1 -1
  949. package/dist/state/cache/builtin-schemas.d.ts +3 -0
  950. package/dist/state/cache/builtin-schemas.d.ts.map +1 -0
  951. package/dist/state/cache/builtin-schemas.js +16 -0
  952. package/dist/state/cache/builtin-schemas.js.map +1 -0
  953. package/dist/state/cache/clear-state-cache.d.ts +12 -3
  954. package/dist/state/cache/clear-state-cache.d.ts.map +1 -1
  955. package/dist/state/cache/clear-state-cache.js +34 -5
  956. package/dist/state/cache/clear-state-cache.js.map +1 -1
  957. package/dist/state/cache/clear-state-cache.test.js +18 -14
  958. package/dist/state/cache/clear-state-cache.test.js.map +1 -1
  959. package/dist/state/cache/create-schema-cache-table.d.ts +37 -0
  960. package/dist/state/cache/create-schema-cache-table.d.ts.map +1 -0
  961. package/dist/state/cache/create-schema-cache-table.js +137 -0
  962. package/dist/state/cache/create-schema-cache-table.js.map +1 -0
  963. package/dist/state/cache/create-schema-cache-table.test.d.ts +2 -0
  964. package/dist/state/cache/create-schema-cache-table.test.d.ts.map +1 -0
  965. package/dist/state/cache/create-schema-cache-table.test.js +49 -0
  966. package/dist/state/cache/create-schema-cache-table.test.js.map +1 -0
  967. package/dist/state/cache/is-stale-state-cache.d.ts +24 -2
  968. package/dist/state/cache/is-stale-state-cache.d.ts.map +1 -1
  969. package/dist/state/cache/is-stale-state-cache.js +56 -14
  970. package/dist/state/cache/is-stale-state-cache.js.map +1 -1
  971. package/dist/state/cache/is-stale-state-cache.test.js +22 -19
  972. package/dist/state/cache/is-stale-state-cache.test.js.map +1 -1
  973. package/dist/state/cache/mark-state-cache-as-stale.d.ts +3 -3
  974. package/dist/state/cache/mark-state-cache-as-stale.d.ts.map +1 -1
  975. package/dist/state/cache/mark-state-cache-as-stale.js +39 -31
  976. package/dist/state/cache/mark-state-cache-as-stale.js.map +1 -1
  977. package/dist/state/cache/populate-state-cache.d.ts +16 -6
  978. package/dist/state/cache/populate-state-cache.d.ts.map +1 -1
  979. package/dist/state/cache/populate-state-cache.js +172 -82
  980. package/dist/state/cache/populate-state-cache.js.map +1 -1
  981. package/dist/state/cache/populate-state-cache.test.js +478 -156
  982. package/dist/state/cache/populate-state-cache.test.js.map +1 -1
  983. package/dist/state/cache/schema-indexes.d.ts +19 -0
  984. package/dist/state/cache/schema-indexes.d.ts.map +1 -0
  985. package/dist/state/cache/schema-indexes.js +137 -0
  986. package/dist/state/cache/schema-indexes.js.map +1 -0
  987. package/dist/state/cache/schema-indexes.test.d.ts +2 -0
  988. package/dist/state/cache/schema-indexes.test.d.ts.map +1 -0
  989. package/dist/state/cache/schema-indexes.test.js +124 -0
  990. package/dist/state/cache/schema-indexes.test.js.map +1 -0
  991. package/dist/state/cache/schema-resolver.d.ts +34 -0
  992. package/dist/state/cache/schema-resolver.d.ts.map +1 -0
  993. package/dist/state/cache/schema-resolver.js +49 -0
  994. package/dist/state/cache/schema-resolver.js.map +1 -0
  995. package/dist/state/cache/schema.bench.d.ts +2 -0
  996. package/dist/state/cache/schema.bench.d.ts.map +1 -0
  997. package/dist/state/cache/schema.bench.js +305 -0
  998. package/dist/state/cache/schema.bench.js.map +1 -0
  999. package/dist/state/cache/schema.d.ts +10 -7
  1000. package/dist/state/cache/schema.d.ts.map +1 -1
  1001. package/dist/state/cache/schema.js +39 -19
  1002. package/dist/state/cache/schema.js.map +1 -1
  1003. package/dist/state/cache/schema.test.d.ts +2 -0
  1004. package/dist/state/cache/schema.test.d.ts.map +1 -0
  1005. package/dist/state/cache/schema.test.js +126 -0
  1006. package/dist/state/cache/schema.test.js.map +1 -0
  1007. package/dist/state/cache/select-from-state-cache.d.ts +11 -0
  1008. package/dist/state/cache/select-from-state-cache.d.ts.map +1 -0
  1009. package/dist/state/cache/select-from-state-cache.js +50 -0
  1010. package/dist/state/cache/select-from-state-cache.js.map +1 -0
  1011. package/dist/state/cache/select-from-state-cache.test.d.ts +2 -0
  1012. package/dist/state/cache/select-from-state-cache.test.d.ts.map +1 -0
  1013. package/dist/state/cache/select-from-state-cache.test.js +49 -0
  1014. package/dist/state/cache/select-from-state-cache.test.js.map +1 -0
  1015. package/dist/state/cache/update-state-cache.bench.d.ts +2 -0
  1016. package/dist/state/cache/update-state-cache.bench.d.ts.map +1 -0
  1017. package/dist/state/cache/update-state-cache.bench.js +129 -0
  1018. package/dist/state/cache/update-state-cache.bench.js.map +1 -0
  1019. package/dist/state/cache/update-state-cache.d.ts +33 -14
  1020. package/dist/state/cache/update-state-cache.d.ts.map +1 -1
  1021. package/dist/state/cache/update-state-cache.js +358 -274
  1022. package/dist/state/cache/update-state-cache.js.map +1 -1
  1023. package/dist/state/cache/update-state-cache.test.js +761 -231
  1024. package/dist/state/cache/update-state-cache.test.js.map +1 -1
  1025. package/dist/state/cache-v2/cache-columns.d.ts +3 -0
  1026. package/dist/state/cache-v2/cache-columns.d.ts.map +1 -0
  1027. package/dist/state/cache-v2/cache-columns.js +20 -0
  1028. package/dist/state/cache-v2/cache-columns.js.map +1 -0
  1029. package/dist/state/cache-v2/clear-state-cache.d.ts +17 -0
  1030. package/dist/state/cache-v2/clear-state-cache.d.ts.map +1 -0
  1031. package/dist/state/cache-v2/clear-state-cache.js +42 -0
  1032. package/dist/state/cache-v2/clear-state-cache.js.map +1 -0
  1033. package/dist/state/cache-v2/clear-state-cache.test.d.ts +2 -0
  1034. package/dist/state/cache-v2/clear-state-cache.test.d.ts.map +1 -0
  1035. package/dist/state/cache-v2/clear-state-cache.test.js +87 -0
  1036. package/dist/state/cache-v2/clear-state-cache.test.js.map +1 -0
  1037. package/dist/state/cache-v2/create-schema-cache-table.d.ts +48 -0
  1038. package/dist/state/cache-v2/create-schema-cache-table.d.ts.map +1 -0
  1039. package/dist/state/cache-v2/create-schema-cache-table.js +152 -0
  1040. package/dist/state/cache-v2/create-schema-cache-table.js.map +1 -0
  1041. package/dist/state/cache-v2/create-schema-cache-table.test.d.ts +2 -0
  1042. package/dist/state/cache-v2/create-schema-cache-table.test.d.ts.map +1 -0
  1043. package/dist/state/cache-v2/create-schema-cache-table.test.js +76 -0
  1044. package/dist/state/cache-v2/create-schema-cache-table.test.js.map +1 -0
  1045. package/dist/state/cache-v2/is-stale-state-cache.d.ts +27 -0
  1046. package/dist/state/cache-v2/is-stale-state-cache.d.ts.map +1 -0
  1047. package/dist/state/cache-v2/is-stale-state-cache.js +64 -0
  1048. package/dist/state/cache-v2/is-stale-state-cache.js.map +1 -0
  1049. package/dist/state/cache-v2/is-stale-state-cache.test.d.ts +2 -0
  1050. package/dist/state/cache-v2/is-stale-state-cache.test.d.ts.map +1 -0
  1051. package/dist/state/cache-v2/is-stale-state-cache.test.js +30 -0
  1052. package/dist/state/cache-v2/is-stale-state-cache.test.js.map +1 -0
  1053. package/dist/state/cache-v2/mark-state-cache-as-stale.d.ts +22 -0
  1054. package/dist/state/cache-v2/mark-state-cache-as-stale.d.ts.map +1 -0
  1055. package/dist/state/cache-v2/mark-state-cache-as-stale.js +62 -0
  1056. package/dist/state/cache-v2/mark-state-cache-as-stale.js.map +1 -0
  1057. package/dist/state/cache-v2/populate-state-cache.d.ts +22 -0
  1058. package/dist/state/cache-v2/populate-state-cache.d.ts.map +1 -0
  1059. package/dist/state/cache-v2/populate-state-cache.js +143 -0
  1060. package/dist/state/cache-v2/populate-state-cache.js.map +1 -0
  1061. package/dist/state/cache-v2/populate-state-cache.test.d.ts +2 -0
  1062. package/dist/state/cache-v2/populate-state-cache.test.d.ts.map +1 -0
  1063. package/dist/state/cache-v2/populate-state-cache.test.js +102 -0
  1064. package/dist/state/cache-v2/populate-state-cache.test.js.map +1 -0
  1065. package/dist/state/cache-v2/schema-metadata.d.ts +20 -0
  1066. package/dist/state/cache-v2/schema-metadata.d.ts.map +1 -0
  1067. package/dist/state/cache-v2/schema-metadata.js +18 -0
  1068. package/dist/state/cache-v2/schema-metadata.js.map +1 -0
  1069. package/dist/state/cache-v2/schema.bench.d.ts +2 -0
  1070. package/dist/state/cache-v2/schema.bench.d.ts.map +1 -0
  1071. package/dist/state/cache-v2/schema.bench.js +194 -0
  1072. package/dist/state/cache-v2/schema.bench.js.map +1 -0
  1073. package/dist/state/cache-v2/schema.d.ts +30 -0
  1074. package/dist/state/cache-v2/schema.d.ts.map +1 -0
  1075. package/dist/state/cache-v2/schema.js +72 -0
  1076. package/dist/state/cache-v2/schema.js.map +1 -0
  1077. package/dist/state/cache-v2/schema.test.d.ts +2 -0
  1078. package/dist/state/cache-v2/schema.test.d.ts.map +1 -0
  1079. package/dist/state/cache-v2/schema.test.js +246 -0
  1080. package/dist/state/cache-v2/schema.test.js.map +1 -0
  1081. package/dist/state/cache-v2/select-from-state-cache.d.ts +19 -0
  1082. package/dist/state/cache-v2/select-from-state-cache.d.ts.map +1 -0
  1083. package/dist/state/cache-v2/select-from-state-cache.js +141 -0
  1084. package/dist/state/cache-v2/select-from-state-cache.js.map +1 -0
  1085. package/dist/state/cache-v2/select-from-state-cache.test.d.ts +2 -0
  1086. package/dist/state/cache-v2/select-from-state-cache.test.d.ts.map +1 -0
  1087. package/dist/state/cache-v2/select-from-state-cache.test.js +72 -0
  1088. package/dist/state/cache-v2/select-from-state-cache.test.js.map +1 -0
  1089. package/dist/state/cache-v2/sqlite-type-mapper.d.ts +6 -0
  1090. package/dist/state/cache-v2/sqlite-type-mapper.d.ts.map +1 -0
  1091. package/dist/state/cache-v2/sqlite-type-mapper.js +50 -0
  1092. package/dist/state/cache-v2/sqlite-type-mapper.js.map +1 -0
  1093. package/dist/state/cache-v2/sqlite-type-mapper.test.d.ts +2 -0
  1094. package/dist/state/cache-v2/sqlite-type-mapper.test.d.ts.map +1 -0
  1095. package/dist/state/cache-v2/sqlite-type-mapper.test.js +41 -0
  1096. package/dist/state/cache-v2/sqlite-type-mapper.test.js.map +1 -0
  1097. package/dist/state/cache-v2/update-state-cache.bench.d.ts +2 -0
  1098. package/dist/state/cache-v2/update-state-cache.bench.d.ts.map +1 -0
  1099. package/dist/state/cache-v2/update-state-cache.bench.js +165 -0
  1100. package/dist/state/cache-v2/update-state-cache.bench.js.map +1 -0
  1101. package/dist/state/cache-v2/update-state-cache.d.ts +23 -0
  1102. package/dist/state/cache-v2/update-state-cache.d.ts.map +1 -0
  1103. package/dist/state/cache-v2/update-state-cache.js +403 -0
  1104. package/dist/state/cache-v2/update-state-cache.js.map +1 -0
  1105. package/dist/state/cache-v2/update-state-cache.test.d.ts +2 -0
  1106. package/dist/state/cache-v2/update-state-cache.test.d.ts.map +1 -0
  1107. package/dist/state/cache-v2/update-state-cache.test.js +281 -0
  1108. package/dist/state/cache-v2/update-state-cache.test.js.map +1 -0
  1109. package/dist/state/create-checkpoint.d.ts +22 -0
  1110. package/dist/state/create-checkpoint.d.ts.map +1 -0
  1111. package/dist/state/create-checkpoint.js +226 -0
  1112. package/dist/state/create-checkpoint.js.map +1 -0
  1113. package/dist/state/create-checkpoint.test.d.ts.map +1 -0
  1114. package/dist/state/create-checkpoint.test.js +649 -0
  1115. package/dist/state/create-checkpoint.test.js.map +1 -0
  1116. package/dist/state/index.d.ts +7 -0
  1117. package/dist/state/index.d.ts.map +1 -0
  1118. package/dist/state/index.js +5 -0
  1119. package/dist/state/index.js.map +1 -0
  1120. package/dist/state/materialize-state.bench.d.ts +2 -0
  1121. package/dist/state/materialize-state.bench.d.ts.map +1 -0
  1122. package/dist/state/materialize-state.bench.js +196 -0
  1123. package/dist/state/materialize-state.bench.js.map +1 -0
  1124. package/dist/state/materialize-state.d.ts +4 -2
  1125. package/dist/state/materialize-state.d.ts.map +1 -1
  1126. package/dist/state/materialize-state.js +450 -119
  1127. package/dist/state/materialize-state.js.map +1 -1
  1128. package/dist/state/materialize-state.test.js +625 -245
  1129. package/dist/state/materialize-state.test.js.map +1 -1
  1130. package/dist/state/schema.bench.js +100 -28
  1131. package/dist/state/schema.bench.js.map +1 -1
  1132. package/dist/state/schema.d.ts +4 -42
  1133. package/dist/state/schema.d.ts.map +1 -1
  1134. package/dist/state/schema.js +29 -783
  1135. package/dist/state/schema.js.map +1 -1
  1136. package/dist/state/transaction/insert-transaction-state.d.ts +65 -0
  1137. package/dist/state/transaction/insert-transaction-state.d.ts.map +1 -0
  1138. package/dist/state/transaction/insert-transaction-state.js +116 -0
  1139. package/dist/state/transaction/insert-transaction-state.js.map +1 -0
  1140. package/dist/state/transaction/insert-transaction-state.test.d.ts.map +1 -0
  1141. package/dist/state/transaction/insert-transaction-state.test.js +946 -0
  1142. package/dist/state/transaction/insert-transaction-state.test.js.map +1 -0
  1143. package/dist/state/transaction/schema.d.ts +22 -0
  1144. package/dist/state/transaction/schema.d.ts.map +1 -0
  1145. package/dist/state/transaction/schema.js +25 -0
  1146. package/dist/state/transaction/schema.js.map +1 -0
  1147. package/dist/state/transition.bench.d.ts +2 -0
  1148. package/dist/state/transition.bench.d.ts.map +1 -0
  1149. package/dist/state/transition.bench.js +215 -0
  1150. package/dist/state/transition.bench.js.map +1 -0
  1151. package/dist/state/transition.d.ts +21 -0
  1152. package/dist/state/transition.d.ts.map +1 -0
  1153. package/dist/state/transition.js +336 -0
  1154. package/dist/state/transition.js.map +1 -0
  1155. package/dist/state/transition.test.d.ts +2 -0
  1156. package/dist/state/transition.test.d.ts.map +1 -0
  1157. package/dist/state/transition.test.js +226 -0
  1158. package/dist/state/transition.test.js.map +1 -0
  1159. package/dist/state/untracked/schema.d.ts +3 -3
  1160. package/dist/state/untracked/schema.d.ts.map +1 -1
  1161. package/dist/state/untracked/schema.js +13 -6
  1162. package/dist/state/untracked/schema.js.map +1 -1
  1163. package/dist/state/untracked/schema.test.js +36 -36
  1164. package/dist/state/untracked/schema.test.js.map +1 -1
  1165. package/dist/state/untracked/update-untracked-state.d.ts +8 -8
  1166. package/dist/state/untracked/update-untracked-state.d.ts.map +1 -1
  1167. package/dist/state/untracked/update-untracked-state.js +111 -80
  1168. package/dist/state/untracked/update-untracked-state.js.map +1 -1
  1169. package/dist/state/untracked/update-untracked-state.test.js +170 -152
  1170. package/dist/state/untracked/update-untracked-state.test.js.map +1 -1
  1171. package/dist/state/views/state-by-version.d.ts +30 -0
  1172. package/dist/state/views/state-by-version.d.ts.map +1 -0
  1173. package/dist/state/views/state-by-version.js +94 -0
  1174. package/dist/state/views/state-by-version.js.map +1 -0
  1175. package/dist/state/views/state-with-tombstones.d.ts +34 -0
  1176. package/dist/state/views/state-with-tombstones.d.ts.map +1 -0
  1177. package/dist/state/views/state-with-tombstones.js +37 -0
  1178. package/dist/state/views/state-with-tombstones.js.map +1 -0
  1179. package/dist/state/views/state-with-tombstones.test.d.ts +2 -0
  1180. package/dist/state/views/state-with-tombstones.test.d.ts.map +1 -0
  1181. package/dist/state/views/state-with-tombstones.test.js +148 -0
  1182. package/dist/state/views/state-with-tombstones.test.js.map +1 -0
  1183. package/dist/state/views/state.bench.d.ts +2 -0
  1184. package/dist/state/views/state.bench.d.ts.map +1 -0
  1185. package/dist/state/views/state.bench.js +308 -0
  1186. package/dist/state/views/state.bench.js.map +1 -0
  1187. package/dist/state/views/state.d.ts +15 -0
  1188. package/dist/state/views/state.d.ts.map +1 -0
  1189. package/dist/state/views/state.js +85 -0
  1190. package/dist/state/views/state.js.map +1 -0
  1191. package/dist/state/views/state.test.d.ts +2 -0
  1192. package/dist/state/views/state.test.d.ts.map +1 -0
  1193. package/dist/state/views/state.test.js +340 -0
  1194. package/dist/state/views/state.test.js.map +1 -0
  1195. package/dist/state/vtable/commit.bench.d.ts +2 -0
  1196. package/dist/state/vtable/commit.bench.d.ts.map +1 -0
  1197. package/dist/state/vtable/commit.bench.js +287 -0
  1198. package/dist/state/vtable/commit.bench.js.map +1 -0
  1199. package/dist/state/vtable/commit.d.ts +18 -0
  1200. package/dist/state/vtable/commit.d.ts.map +1 -0
  1201. package/dist/state/vtable/commit.js +426 -0
  1202. package/dist/state/vtable/commit.js.map +1 -0
  1203. package/dist/state/vtable/commit.test.d.ts.map +1 -0
  1204. package/dist/state/vtable/commit.test.js +1644 -0
  1205. package/dist/state/vtable/commit.test.js.map +1 -0
  1206. package/dist/state/vtable/generate-commit.d.ts +33 -0
  1207. package/dist/state/vtable/generate-commit.d.ts.map +1 -0
  1208. package/dist/state/vtable/generate-commit.js +277 -0
  1209. package/dist/state/vtable/generate-commit.js.map +1 -0
  1210. package/dist/state/vtable/generate-commit.test.d.ts +2 -0
  1211. package/dist/state/vtable/generate-commit.test.d.ts.map +1 -0
  1212. package/dist/state/vtable/generate-commit.test.js +377 -0
  1213. package/dist/state/vtable/generate-commit.test.js.map +1 -0
  1214. package/dist/state/vtable/index.d.ts +3 -0
  1215. package/dist/state/vtable/index.d.ts.map +1 -0
  1216. package/dist/state/vtable/index.js +3 -0
  1217. package/dist/state/vtable/index.js.map +1 -0
  1218. package/dist/state/vtable/insert-vtable-log.d.ts +18 -0
  1219. package/dist/state/vtable/insert-vtable-log.d.ts.map +1 -0
  1220. package/dist/state/vtable/insert-vtable-log.js +49 -0
  1221. package/dist/state/vtable/insert-vtable-log.js.map +1 -0
  1222. package/dist/state/vtable/primary-key.d.ts +41 -0
  1223. package/dist/state/vtable/primary-key.d.ts.map +1 -0
  1224. package/dist/state/vtable/primary-key.js +64 -0
  1225. package/dist/state/vtable/primary-key.js.map +1 -0
  1226. package/dist/state/vtable/primary-key.test.d.ts.map +1 -0
  1227. package/dist/state/vtable/primary-key.test.js +32 -0
  1228. package/dist/state/vtable/primary-key.test.js.map +1 -0
  1229. package/dist/state/vtable/validate-state-mutation.bench.d.ts +2 -0
  1230. package/dist/state/vtable/validate-state-mutation.bench.d.ts.map +1 -0
  1231. package/dist/state/vtable/validate-state-mutation.bench.js +284 -0
  1232. package/dist/state/vtable/validate-state-mutation.bench.js.map +1 -0
  1233. package/dist/state/vtable/validate-state-mutation.d.ts +21 -0
  1234. package/dist/state/vtable/validate-state-mutation.d.ts.map +1 -0
  1235. package/dist/state/vtable/validate-state-mutation.js +886 -0
  1236. package/dist/state/vtable/validate-state-mutation.js.map +1 -0
  1237. package/dist/state/vtable/validate-state-mutation.playground.test.d.ts +2 -0
  1238. package/dist/state/vtable/validate-state-mutation.playground.test.d.ts.map +1 -0
  1239. package/dist/state/vtable/validate-state-mutation.playground.test.js +389 -0
  1240. package/dist/state/vtable/validate-state-mutation.playground.test.js.map +1 -0
  1241. package/dist/state/vtable/validate-state-mutation.test.d.ts.map +1 -0
  1242. package/dist/state/vtable/validate-state-mutation.test.js +3655 -0
  1243. package/dist/state/vtable/validate-state-mutation.test.js.map +1 -0
  1244. package/dist/state/vtable/vtable.d.ts +26 -0
  1245. package/dist/state/vtable/vtable.d.ts.map +1 -0
  1246. package/dist/state/vtable/vtable.insert.bench.d.ts +2 -0
  1247. package/dist/state/vtable/vtable.insert.bench.d.ts.map +1 -0
  1248. package/dist/state/vtable/vtable.insert.bench.js +100 -0
  1249. package/dist/state/vtable/vtable.insert.bench.js.map +1 -0
  1250. package/dist/state/vtable/vtable.js +951 -0
  1251. package/dist/state/vtable/vtable.js.map +1 -0
  1252. package/dist/state/vtable/vtable.select.bench.d.ts +2 -0
  1253. package/dist/state/vtable/vtable.select.bench.d.ts.map +1 -0
  1254. package/dist/state/vtable/vtable.select.bench.js +334 -0
  1255. package/dist/state/vtable/vtable.select.bench.js.map +1 -0
  1256. package/dist/state/vtable/vtable.test.d.ts +2 -0
  1257. package/dist/state/vtable/vtable.test.d.ts.map +1 -0
  1258. package/dist/state/vtable/vtable.test.js +3516 -0
  1259. package/dist/state/vtable/vtable.test.js.map +1 -0
  1260. package/dist/state/working-change-set/refresh-working-change-set.d.ts +21 -0
  1261. package/dist/state/working-change-set/refresh-working-change-set.d.ts.map +1 -0
  1262. package/dist/state/working-change-set/refresh-working-change-set.js +185 -0
  1263. package/dist/state/working-change-set/refresh-working-change-set.js.map +1 -0
  1264. package/dist/state/working-change-set/refresh-working-change-set.test.d.ts +2 -0
  1265. package/dist/state/working-change-set/refresh-working-change-set.test.d.ts.map +1 -0
  1266. package/dist/state/working-change-set/refresh-working-change-set.test.js +89 -0
  1267. package/dist/state/working-change-set/refresh-working-change-set.test.js.map +1 -0
  1268. package/dist/state/writer.d.ts +42 -0
  1269. package/dist/state/writer.d.ts.map +1 -0
  1270. package/dist/state/writer.js +62 -0
  1271. package/dist/state/writer.js.map +1 -0
  1272. package/dist/state-history/schema.d.ts +7 -3
  1273. package/dist/state-history/schema.d.ts.map +1 -1
  1274. package/dist/state-history/schema.js +95 -31
  1275. package/dist/state-history/schema.js.map +1 -1
  1276. package/dist/state-history/schema.test.js +30 -30
  1277. package/dist/state-history/schema.test.js.map +1 -1
  1278. package/dist/stored-schema/get-stored-schema.d.ts +27 -0
  1279. package/dist/stored-schema/get-stored-schema.d.ts.map +1 -0
  1280. package/dist/stored-schema/get-stored-schema.js +129 -0
  1281. package/dist/stored-schema/get-stored-schema.js.map +1 -0
  1282. package/dist/stored-schema/get-stored-schema.test.d.ts +2 -0
  1283. package/dist/stored-schema/get-stored-schema.test.d.ts.map +1 -0
  1284. package/dist/stored-schema/get-stored-schema.test.js +259 -0
  1285. package/dist/stored-schema/get-stored-schema.test.js.map +1 -0
  1286. package/dist/stored-schema/index.d.ts +1 -1
  1287. package/dist/stored-schema/index.d.ts.map +1 -1
  1288. package/dist/stored-schema/index.js +1 -1
  1289. package/dist/stored-schema/index.js.map +1 -1
  1290. package/dist/stored-schema/schema-definition.d.ts +22 -0
  1291. package/dist/stored-schema/schema-definition.d.ts.map +1 -0
  1292. package/dist/stored-schema/schema-definition.js +20 -0
  1293. package/dist/stored-schema/schema-definition.js.map +1 -0
  1294. package/dist/stored-schema/schema.test.js +34 -91
  1295. package/dist/stored-schema/schema.test.js.map +1 -1
  1296. package/dist/sync/pull-from-server.test.js +6 -6
  1297. package/dist/sync/pull-from-server.test.js.map +1 -1
  1298. package/dist/sync/push-to-server.test.js +4 -4
  1299. package/dist/sync/push-to-server.test.js.map +1 -1
  1300. package/dist/sync/sync-process.d.ts +1 -1
  1301. package/dist/sync/sync-process.d.ts.map +1 -1
  1302. package/dist/sync/sync-process.js +18 -9
  1303. package/dist/sync/sync-process.js.map +1 -1
  1304. package/dist/sync/sync-process.test.js +3 -6
  1305. package/dist/sync/sync-process.test.js.map +1 -1
  1306. package/dist/test-utilities/simulation-test/cache-miss-simulation.d.ts.map +1 -1
  1307. package/dist/test-utilities/simulation-test/cache-miss-simulation.js +49 -49
  1308. package/dist/test-utilities/simulation-test/cache-miss-simulation.js.map +1 -1
  1309. package/dist/test-utilities/simulation-test/cache-miss-simulation.test.js +53 -30
  1310. package/dist/test-utilities/simulation-test/cache-miss-simulation.test.js.map +1 -1
  1311. package/dist/test-utilities/simulation-test/engine-boundary-simulation.d.ts +3 -0
  1312. package/dist/test-utilities/simulation-test/engine-boundary-simulation.d.ts.map +1 -0
  1313. package/dist/test-utilities/simulation-test/engine-boundary-simulation.js +52 -0
  1314. package/dist/test-utilities/simulation-test/engine-boundary-simulation.js.map +1 -0
  1315. package/dist/test-utilities/simulation-test/engine-boundary-simulation.test.d.ts +2 -0
  1316. package/dist/test-utilities/simulation-test/engine-boundary-simulation.test.d.ts.map +1 -0
  1317. package/dist/test-utilities/simulation-test/engine-boundary-simulation.test.js +10 -0
  1318. package/dist/test-utilities/simulation-test/engine-boundary-simulation.test.js.map +1 -0
  1319. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.d.ts.map +1 -1
  1320. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.js +6 -8
  1321. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.js.map +1 -1
  1322. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.js +5 -5
  1323. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.js.map +1 -1
  1324. package/dist/test-utilities/simulation-test/simulation-test.d.ts +7 -2
  1325. package/dist/test-utilities/simulation-test/simulation-test.d.ts.map +1 -1
  1326. package/dist/test-utilities/simulation-test/simulation-test.js +7 -3
  1327. package/dist/test-utilities/simulation-test/simulation-test.js.map +1 -1
  1328. package/dist/test-utilities/simulation-test/simulation-test.test.js +12 -14
  1329. package/dist/test-utilities/simulation-test/simulation-test.test.js.map +1 -1
  1330. package/dist/version/create-version-from-commit.d.ts +44 -0
  1331. package/dist/version/create-version-from-commit.d.ts.map +1 -0
  1332. package/dist/version/create-version-from-commit.js +119 -0
  1333. package/dist/version/create-version-from-commit.js.map +1 -0
  1334. package/dist/version/create-version-from-commit.test.d.ts +2 -0
  1335. package/dist/version/create-version-from-commit.test.d.ts.map +1 -0
  1336. package/dist/version/create-version-from-commit.test.js +166 -0
  1337. package/dist/version/create-version-from-commit.test.js.map +1 -0
  1338. package/dist/version/create-version.d.ts +5 -14
  1339. package/dist/version/create-version.d.ts.map +1 -1
  1340. package/dist/version/create-version.js +20 -53
  1341. package/dist/version/create-version.js.map +1 -1
  1342. package/dist/version/create-version.test.js +56 -16
  1343. package/dist/version/create-version.test.js.map +1 -1
  1344. package/dist/version/index.d.ts +4 -1
  1345. package/dist/version/index.d.ts.map +1 -1
  1346. package/dist/version/index.js +4 -1
  1347. package/dist/version/index.js.map +1 -1
  1348. package/dist/version/merge-version.d.ts +3 -6
  1349. package/dist/version/merge-version.d.ts.map +1 -1
  1350. package/dist/version/merge-version.js +472 -57
  1351. package/dist/version/merge-version.js.map +1 -1
  1352. package/dist/version/merge-version.test.js +783 -378
  1353. package/dist/version/merge-version.test.js.map +1 -1
  1354. package/dist/version/schema-definition.d.ts +107 -0
  1355. package/dist/version/schema-definition.d.ts.map +1 -0
  1356. package/dist/version/schema-definition.js +93 -0
  1357. package/dist/version/schema-definition.js.map +1 -0
  1358. package/dist/version/schema.d.ts +5 -77
  1359. package/dist/version/schema.d.ts.map +1 -1
  1360. package/dist/version/schema.js +433 -128
  1361. package/dist/version/schema.js.map +1 -1
  1362. package/dist/version/schema.test.js +319 -132
  1363. package/dist/version/schema.test.js.map +1 -1
  1364. package/dist/version/select-active-version.d.ts +2 -2
  1365. package/dist/version/select-active-version.d.ts.map +1 -1
  1366. package/dist/version/select-version-diff.bench.d.ts +2 -0
  1367. package/dist/version/select-version-diff.bench.d.ts.map +1 -0
  1368. package/dist/version/select-version-diff.bench.js +126 -0
  1369. package/dist/version/select-version-diff.bench.js.map +1 -0
  1370. package/dist/version/select-version-diff.d.ts +121 -0
  1371. package/dist/version/select-version-diff.d.ts.map +1 -0
  1372. package/dist/version/select-version-diff.js +179 -0
  1373. package/dist/version/select-version-diff.js.map +1 -0
  1374. package/dist/version/select-version-diff.playground.test.d.ts +2 -0
  1375. package/dist/version/select-version-diff.playground.test.d.ts.map +1 -0
  1376. package/dist/version/select-version-diff.playground.test.js +114 -0
  1377. package/dist/version/select-version-diff.playground.test.js.map +1 -0
  1378. package/dist/version/select-version-diff.test.d.ts +2 -0
  1379. package/dist/version/select-version-diff.test.d.ts.map +1 -0
  1380. package/dist/version/select-version-diff.test.js +689 -0
  1381. package/dist/version/select-version-diff.test.js.map +1 -0
  1382. package/dist/version/switch-version.d.ts +2 -2
  1383. package/dist/version/switch-version.d.ts.map +1 -1
  1384. package/dist/version/switch-version.js +1 -1
  1385. package/dist/version/switch-version.test.js +2 -2
  1386. package/dist/version/switch-version.test.js.map +1 -1
  1387. package/package.json +50 -21
  1388. package/src/account/create-account.test.ts +5 -19
  1389. package/src/account/create-account.ts +11 -14
  1390. package/src/account/index.ts +2 -1
  1391. package/src/account/schema-definition.ts +60 -0
  1392. package/src/account/schema.test.ts +105 -66
  1393. package/src/account/switch-account.test.ts +5 -17
  1394. package/src/account/switch-account.ts +1 -1
  1395. package/src/change/index.ts +1 -1
  1396. package/src/change/schema-definition.ts +84 -0
  1397. package/src/change/schema.bench.ts +411 -0
  1398. package/src/change/schema.test.ts +100 -9
  1399. package/src/change/schema.ts +30 -95
  1400. package/src/change-author/index.ts +1 -1
  1401. package/src/change-author/schema-definition.ts +43 -0
  1402. package/src/change-author/schema.test.ts +383 -237
  1403. package/src/change-proposal/accept-change-proposal.test.ts +64 -0
  1404. package/src/change-proposal/accept-change-proposal.ts +46 -0
  1405. package/src/change-proposal/create-change-proposal.test.ts +64 -89
  1406. package/src/change-proposal/create-change-proposal.ts +33 -58
  1407. package/src/change-proposal/index.ts +7 -2
  1408. package/src/change-proposal/reject-change-proposal.test.ts +34 -0
  1409. package/src/change-proposal/reject-change-proposal.ts +22 -0
  1410. package/src/change-proposal/schema-definition.ts +42 -0
  1411. package/src/change-proposal/schema.test.ts +124 -0
  1412. package/src/change-set/apply-change-set.test.ts +6 -5
  1413. package/src/change-set/apply-change-set.ts +37 -45
  1414. package/src/change-set/create-change-set.test.ts +5 -53
  1415. package/src/change-set/create-change-set.ts +8 -36
  1416. package/src/change-set/index.ts +1 -3
  1417. package/src/change-set/schema-definition.ts +83 -0
  1418. package/src/change-set/schema.test.ts +13 -187
  1419. package/src/commit/index.ts +1 -6
  1420. package/src/commit/schema-definition.ts +103 -0
  1421. package/src/commit/schema.test.ts +133 -37
  1422. package/src/conversation/create-conversation-message.test.ts +118 -0
  1423. package/src/conversation/create-conversation-message.ts +82 -0
  1424. package/src/conversation/create-conversation.test.ts +194 -0
  1425. package/src/conversation/create-conversation.ts +110 -0
  1426. package/src/conversation/index.ts +8 -0
  1427. package/src/conversation/schema-definition.ts +74 -0
  1428. package/src/database/index.ts +0 -1
  1429. package/src/database/init-db.ts +91 -128
  1430. package/src/database/kysely/index.ts +1 -0
  1431. package/src/database/kysely/json-column-config.ts +63 -0
  1432. package/src/database/kysely/plugins/json-column-plugin.test.ts +533 -0
  1433. package/src/database/kysely/plugins/json-column-plugin.ts +286 -0
  1434. package/src/database/kysely/plugins/view-insert-returning-error-plugin.test.ts +62 -0
  1435. package/src/database/kysely/plugins.ts +16 -0
  1436. package/src/database/nano-id.test.ts +1 -1
  1437. package/src/database/schema-view-map.ts +48 -0
  1438. package/src/database/schema.ts +119 -62
  1439. package/src/database/sqlite/content-from-database.ts +12 -0
  1440. package/src/database/sqlite/create-in-memory-database.ts +61 -0
  1441. package/src/database/sqlite/environment-dialect.test.ts +84 -0
  1442. package/src/database/sqlite/environment-dialect.ts +227 -0
  1443. package/src/database/sqlite/import-database.ts +43 -0
  1444. package/src/database/sqlite/index.ts +7 -0
  1445. package/src/database/sqlite/kysely-driver/connection-mutex.ts +23 -0
  1446. package/src/database/sqlite/kysely-driver/index.ts +4 -0
  1447. package/src/database/sqlite/kysely-driver/sqlite-wasm-connection.ts +58 -0
  1448. package/src/database/sqlite/kysely-driver/sqlite-wasm-dialect-config.ts +19 -0
  1449. package/src/database/sqlite/kysely-driver/sqlite-wasm-driver.ts +59 -0
  1450. package/src/database/sqlite/lix-dialect.ts +27 -0
  1451. package/src/database/sqlite/load-database-in-memory.ts +28 -0
  1452. package/src/database/sqlite/sqlite-wasm-binary.d.ts +2 -0
  1453. package/src/database/sqlite/sqlite-wasm-binary.js +42835 -0
  1454. package/src/dependency/kysely/helpers/sqlite.ts +4 -0
  1455. package/src/dependency/kysely/index.ts +8 -0
  1456. package/src/diff/index.ts +2 -0
  1457. package/src/diff/select-commit-diff.bench.ts +156 -0
  1458. package/src/diff/select-commit-diff.test.ts +65 -0
  1459. package/src/diff/select-commit-diff.ts +234 -0
  1460. package/src/diff/select-working-diff.bench.ts +99 -0
  1461. package/src/diff/select-working-diff.test.ts +275 -0
  1462. package/src/diff/select-working-diff.ts +233 -0
  1463. package/src/engine/boot.test.ts +88 -0
  1464. package/src/engine/boot.ts +280 -0
  1465. package/src/engine/cel-environment/cel-environment.test.ts +20 -0
  1466. package/src/engine/cel-environment/cel-environment.ts +85 -0
  1467. package/src/engine/deterministic-mode/is-deterministic-mode.test.ts +121 -0
  1468. package/src/engine/deterministic-mode/is-deterministic-mode.ts +105 -0
  1469. package/src/engine/deterministic-mode/options.test.ts +159 -0
  1470. package/src/engine/deterministic-mode/options.ts +57 -0
  1471. package/src/engine/entity-views/README.md +214 -0
  1472. package/src/engine/entity-views/build-json-object-entries.test.ts +42 -0
  1473. package/src/engine/entity-views/build-json-object-entries.ts +43 -0
  1474. package/src/engine/entity-views/entity-state-by-version.ts +263 -0
  1475. package/src/engine/entity-views/entity-state-history.ts +208 -0
  1476. package/src/engine/entity-views/entity-state.ts +239 -0
  1477. package/src/engine/entity-views/entity-view-builder.ts +58 -0
  1478. package/src/engine/entity-views/types.test.ts +99 -0
  1479. package/src/engine/entity-views/types.ts +330 -0
  1480. package/src/engine/execute-sync.test.ts +90 -0
  1481. package/src/engine/execute-sync.ts +47 -0
  1482. package/src/engine/explain-query.test.ts +21 -0
  1483. package/src/engine/explain-query.ts +89 -0
  1484. package/src/engine/functions/function-registry.ts +69 -0
  1485. package/src/engine/functions/generate-human-id.test.ts +199 -0
  1486. package/src/engine/functions/generate-human-id.ts +383 -0
  1487. package/src/engine/functions/index.ts +6 -0
  1488. package/src/engine/functions/nano-id.bench.ts +57 -0
  1489. package/src/engine/functions/nano-id.test.ts +200 -0
  1490. package/src/engine/functions/nano-id.ts +205 -0
  1491. package/src/engine/functions/random.test.ts +293 -0
  1492. package/src/engine/functions/random.ts +267 -0
  1493. package/src/engine/functions/register-builtins.ts +154 -0
  1494. package/src/engine/functions/sequence.test.ts +99 -0
  1495. package/src/engine/functions/sequence.ts +165 -0
  1496. package/src/engine/functions/timestamp.test.ts +172 -0
  1497. package/src/engine/functions/timestamp.ts +86 -0
  1498. package/src/engine/functions/uuid-v7.test.ts +144 -0
  1499. package/src/engine/functions/uuid-v7.ts +88 -0
  1500. package/src/engine/index.ts +1 -0
  1501. package/src/engine/internal-query-builder.ts +42 -0
  1502. package/src/engine/preprocessor/create-preprocessor.test.ts +275 -0
  1503. package/src/engine/preprocessor/create-preprocessor.ts +267 -0
  1504. package/src/engine/preprocessor/entity-views/__bench__/entity-view-select-all-rows.explain.txt +287 -0
  1505. package/src/engine/preprocessor/entity-views/__bench__/entity-view-select-id-filter.explain.txt +290 -0
  1506. package/src/engine/preprocessor/entity-views/delete.test.ts +994 -0
  1507. package/src/engine/preprocessor/entity-views/delete.ts +359 -0
  1508. package/src/engine/preprocessor/entity-views/insert.test.ts +1175 -0
  1509. package/src/engine/preprocessor/entity-views/insert.ts +903 -0
  1510. package/src/engine/preprocessor/entity-views/select.bench.ts +168 -0
  1511. package/src/engine/preprocessor/entity-views/select.test.ts +385 -0
  1512. package/src/engine/preprocessor/entity-views/select.ts +2079 -0
  1513. package/src/engine/preprocessor/entity-views/shared.ts +1560 -0
  1514. package/src/engine/preprocessor/entity-views/update.test.ts +424 -0
  1515. package/src/engine/preprocessor/entity-views/update.ts +753 -0
  1516. package/src/engine/preprocessor/inheritance/version-inheritance-cache.test.ts +128 -0
  1517. package/src/engine/preprocessor/inheritance/version-inheritance-cache.ts +385 -0
  1518. package/src/engine/preprocessor/sql-parser/ast-helpers.ts +235 -0
  1519. package/src/engine/preprocessor/sql-parser/column-usage.ts +504 -0
  1520. package/src/engine/preprocessor/sql-parser/compile.test.ts +147 -0
  1521. package/src/engine/preprocessor/sql-parser/compile.ts +898 -0
  1522. package/src/engine/preprocessor/sql-parser/cst.ts +1012 -0
  1523. package/src/engine/preprocessor/sql-parser/lexer.ts +608 -0
  1524. package/src/engine/preprocessor/sql-parser/nodes.ts +395 -0
  1525. package/src/engine/preprocessor/sql-parser/parse.test.ts +1646 -0
  1526. package/src/engine/preprocessor/sql-parser/parse.ts +1984 -0
  1527. package/src/engine/preprocessor/sql-parser/visitor.test.ts +173 -0
  1528. package/src/engine/preprocessor/sql-parser/visitor.ts +1403 -0
  1529. package/src/engine/preprocessor/steps/cache-populator.test.ts +128 -0
  1530. package/src/engine/preprocessor/steps/cache-populator.ts +797 -0
  1531. package/src/engine/preprocessor/steps/expand-sql-views.test.ts +1353 -0
  1532. package/src/engine/preprocessor/steps/expand-sql-views.ts +1167 -0
  1533. package/src/engine/preprocessor/steps/rewrite-active-version-subquery.test.ts +83 -0
  1534. package/src/engine/preprocessor/steps/rewrite-active-version-subquery.ts +251 -0
  1535. package/src/engine/preprocessor/steps/rewrite-vtable-selects.bench.ts +68 -0
  1536. package/src/engine/preprocessor/steps/rewrite-vtable-selects.test.ts +1326 -0
  1537. package/src/engine/preprocessor/steps/rewrite-vtable-selects.ts +3751 -0
  1538. package/src/engine/preprocessor/types.ts +103 -0
  1539. package/src/engine/sql-parser/tokenizer.test.ts +408 -0
  1540. package/src/engine/sql-parser/tokenizer.ts +205 -0
  1541. package/src/engine/with-runtime-cache.test.ts +173 -0
  1542. package/src/engine/with-runtime-cache.ts +206 -0
  1543. package/src/entity/conversation/attach-conversation.test.ts +251 -0
  1544. package/src/entity/conversation/attach-conversation.ts +98 -0
  1545. package/src/entity/conversation/schema-definition.ts +52 -0
  1546. package/src/entity/conversation/schema.test.ts +105 -0
  1547. package/src/entity/eb-entity.test.ts +149 -67
  1548. package/src/entity/eb-entity.ts +7 -7
  1549. package/src/entity/index.ts +7 -10
  1550. package/src/entity/label/attach-label.test.ts +356 -0
  1551. package/src/entity/label/attach-label.ts +165 -0
  1552. package/src/entity/label/schema-definition.ts +47 -0
  1553. package/src/entity/label/schema.test.ts +286 -33
  1554. package/src/entity/types.ts +13 -0
  1555. package/src/environment/api.test.ts +102 -0
  1556. package/src/environment/api.ts +39 -0
  1557. package/src/environment/in-memory.test.ts +100 -0
  1558. package/src/environment/in-memory.ts +68 -0
  1559. package/src/environment/index.ts +7 -0
  1560. package/src/environment/kysely/kysely-driver.test.ts +29 -0
  1561. package/src/environment/load-from-string.test.ts +17 -0
  1562. package/src/environment/load-from-string.ts +77 -0
  1563. package/src/environment/opfs-sah.browser.test.ts +352 -0
  1564. package/src/environment/opfs-sah.ts +279 -0
  1565. package/src/environment/opfs-sah.worker.ts +271 -0
  1566. package/src/environment/test-actors/echo.actor.ts +6 -0
  1567. package/src/filesystem/__bench__/batch-file-reads-select-multiple-files.explain.txt +523 -0
  1568. package/src/filesystem/__bench__/file-delete-operations-delete.explain.txt +90 -0
  1569. package/src/filesystem/__bench__/file-delete-operations-insert.explain.txt +11 -0
  1570. package/src/filesystem/__bench__/file-insert-operations.explain.txt +11 -0
  1571. package/src/filesystem/__bench__/file-read-by-exact-path.explain.txt +523 -0
  1572. package/src/filesystem/__bench__/file-read-excluding-file-path-via-not-like.explain.txt +458 -0
  1573. package/src/filesystem/__bench__/file-read-with-path-based-like.explain.txt +523 -0
  1574. package/src/filesystem/__bench__/file-reads-with-varying-sizes.explain.txt +523 -0
  1575. package/src/filesystem/__bench__/file-table-full-scan.explain.txt +522 -0
  1576. package/src/filesystem/__bench__/file-update-by-path.explain.txt +90 -0
  1577. package/src/filesystem/__bench__/mixed-file-read-pattern-80-20-distribution.explain.txt +523 -0
  1578. package/src/filesystem/__bench__/repeated-file-reads-same-file-cache-hit-scenario.explain.txt +523 -0
  1579. package/src/filesystem/__bench__/sequential-file-reads-unique-files.explain.txt +523 -0
  1580. package/src/filesystem/directory/ensure-directories.ts +311 -0
  1581. package/src/filesystem/directory/schema-definition.ts +44 -0
  1582. package/src/filesystem/directory/schema.test.ts +119 -0
  1583. package/src/filesystem/directory/schema.ts +577 -0
  1584. package/src/filesystem/file/cache/clear-file-data-cache.ts +56 -0
  1585. package/src/filesystem/file/cache/lixcol-schema.ts +48 -0
  1586. package/src/filesystem/file/cache/path-cache-schema.ts +45 -0
  1587. package/src/filesystem/file/cache/schema.test.ts +326 -0
  1588. package/src/filesystem/file/cache/schema.ts +36 -0
  1589. package/src/filesystem/file/cache/update-file-data-cache.ts +31 -0
  1590. package/src/filesystem/file/cache/update-file-lixcol-cache.ts +88 -0
  1591. package/src/filesystem/file/cache/update-file-path-cache.ts +47 -0
  1592. package/src/filesystem/file/descriptor-utils.ts +356 -0
  1593. package/src/filesystem/file/file-handlers.test.ts +390 -0
  1594. package/src/filesystem/file/file-handlers.ts +670 -0
  1595. package/src/filesystem/file/materialize-file-data-at-commit.ts +203 -0
  1596. package/src/filesystem/file/materialize-file-data.test.ts +123 -0
  1597. package/src/filesystem/file/materialize-file-data.ts +140 -0
  1598. package/src/filesystem/file/schema-definition.ts +49 -0
  1599. package/src/filesystem/file/schema.test.ts +2452 -0
  1600. package/src/filesystem/file/schema.ts +671 -0
  1601. package/src/filesystem/file/select-file-data.ts +59 -0
  1602. package/src/filesystem/file/select-file-lixcol.ts +144 -0
  1603. package/src/filesystem/file/store-detected-change-schema.test.ts +285 -0
  1604. package/src/filesystem/file/store-detected-change-schema.ts +62 -0
  1605. package/src/filesystem/file/unknown-file-fallback-plugin.test.ts +383 -0
  1606. package/src/filesystem/file/unknown-file-fallback-plugin.ts +96 -0
  1607. package/src/filesystem/fs.bench.ts +661 -0
  1608. package/src/filesystem/index.ts +15 -0
  1609. package/src/filesystem/path.test.ts +130 -0
  1610. package/src/filesystem/path.ts +127 -0
  1611. package/src/filesystem/schema.test.ts +656 -0
  1612. package/src/filesystem/schema.ts +14 -0
  1613. package/src/filesystem/util/glob.ts +31 -0
  1614. package/src/hooks/create-hooks.test.ts +135 -20
  1615. package/src/hooks/create-hooks.ts +92 -5
  1616. package/src/index.ts +9 -5
  1617. package/src/key-value/index.ts +1 -1
  1618. package/src/key-value/schema-definition.ts +78 -0
  1619. package/src/key-value/schema.test.ts +138 -13
  1620. package/src/label/create-label.test.ts +2 -2
  1621. package/src/label/create-label.ts +10 -6
  1622. package/src/label/index.ts +1 -1
  1623. package/src/label/schema-definition.ts +27 -0
  1624. package/src/lix/index.ts +0 -3
  1625. package/src/lix/new-lix.test.ts +90 -23
  1626. package/src/lix/new-lix.ts +239 -92
  1627. package/src/lix/open-lix.bench.ts +23 -0
  1628. package/src/lix/open-lix.test.ts +99 -19
  1629. package/src/lix/open-lix.ts +163 -204
  1630. package/src/log/create-lix-own-log.test.ts +41 -17
  1631. package/src/log/create-lix-own-log.ts +35 -36
  1632. package/src/log/create-log.ts +26 -15
  1633. package/src/log/index.ts +1 -1
  1634. package/src/log/schema-definition.ts +45 -0
  1635. package/src/log/schema.test.ts +57 -18
  1636. package/src/observe/create-observe.test.ts +515 -20
  1637. package/src/observe/create-observe.ts +216 -99
  1638. package/src/observe/determine-schema-keys.test.ts +90 -31
  1639. package/src/observe/determine-schema-keys.ts +267 -8
  1640. package/src/plugin/index.ts +2 -1
  1641. package/src/plugin/lix-plugin.test-d.ts +1 -0
  1642. package/src/plugin/lix-plugin.test.ts +57 -0
  1643. package/src/plugin/lix-plugin.ts +46 -7
  1644. package/src/plugin/mock-json-plugin.test.ts +15 -4
  1645. package/src/plugin/mock-json-plugin.ts +1 -0
  1646. package/src/plugin/query-sync.test.ts +132 -0
  1647. package/src/plugin/query-sync.ts +170 -0
  1648. package/src/query-filter/commit-is-ancestor-of.test.ts +87 -186
  1649. package/src/query-filter/commit-is-ancestor-of.ts +1 -1
  1650. package/src/query-filter/commit-is-descendant-of.test.ts +108 -224
  1651. package/src/query-filter/commit-is-descendant-of.ts +1 -1
  1652. package/src/query-filter/index.ts +0 -3
  1653. package/src/schema-definition/definition.test-d.ts +98 -13
  1654. package/src/schema-definition/definition.test.ts +367 -115
  1655. package/src/schema-definition/definition.ts +164 -29
  1656. package/src/schema-definition/json-pointer.test.ts +101 -0
  1657. package/src/schema-definition/json-pointer.ts +168 -0
  1658. package/src/schema-definition/validate-lix-schema.test.ts +99 -0
  1659. package/src/schema-definition/validate-lix-schema.ts +72 -0
  1660. package/src/server-protocol-handler/environment/create-in-memory-environment.ts +1 -1
  1661. package/src/server-protocol-handler/routes/get-v1.ts +4 -2
  1662. package/src/server-protocol-handler/routes/pull-v1.test.ts +1 -1
  1663. package/src/server-protocol-handler/routes/pull-v1.ts +1 -1
  1664. package/src/server-protocol-handler/routes/push-v1.test.ts +2 -2
  1665. package/src/server-protocol-handler/routes/push-v1.ts +1 -1
  1666. package/src/services/env-variables/index.d.ts +1 -1
  1667. package/src/services/telemetry/capture.test.ts +4 -4
  1668. package/src/snapshot/schema.test.ts +26 -26
  1669. package/src/snapshot/schema.ts +7 -3
  1670. package/src/state/README.md +6 -6
  1671. package/src/state/cache/builtin-schemas.ts +25 -0
  1672. package/src/state/cache/clear-state-cache.test.ts +19 -18
  1673. package/src/state/cache/clear-state-cache.ts +44 -8
  1674. package/src/state/cache/create-schema-cache-table.test.ts +67 -0
  1675. package/src/state/cache/create-schema-cache-table.ts +164 -0
  1676. package/src/state/cache/is-stale-state-cache.test.ts +25 -21
  1677. package/src/state/cache/is-stale-state-cache.ts +74 -17
  1678. package/src/state/cache/mark-state-cache-as-stale.ts +47 -34
  1679. package/src/state/cache/populate-state-cache.test.ts +523 -177
  1680. package/src/state/cache/populate-state-cache.ts +195 -92
  1681. package/src/state/cache/schema-indexes.test.ts +144 -0
  1682. package/src/state/cache/schema-indexes.ts +191 -0
  1683. package/src/state/cache/schema-resolver.ts +59 -0
  1684. package/src/state/cache/schema.bench.ts +361 -0
  1685. package/src/state/cache/schema.test.ts +143 -0
  1686. package/src/state/cache/schema.ts +60 -29
  1687. package/src/state/cache/select-from-state-cache.test.ts +72 -0
  1688. package/src/state/cache/select-from-state-cache.ts +71 -0
  1689. package/src/state/cache/update-state-cache.bench.ts +158 -0
  1690. package/src/state/cache/update-state-cache.test.ts +844 -244
  1691. package/src/state/cache/update-state-cache.ts +436 -295
  1692. package/src/state/cache-v2/cache-columns.ts +20 -0
  1693. package/src/state/cache-v2/clear-state-cache.test.ts +101 -0
  1694. package/src/state/cache-v2/clear-state-cache.ts +51 -0
  1695. package/src/state/cache-v2/create-schema-cache-table.test.ts +96 -0
  1696. package/src/state/cache-v2/create-schema-cache-table.ts +205 -0
  1697. package/src/state/cache-v2/is-stale-state-cache.test.ts +39 -0
  1698. package/src/state/cache-v2/is-stale-state-cache.ts +86 -0
  1699. package/src/state/cache-v2/mark-state-cache-as-stale.ts +78 -0
  1700. package/src/state/cache-v2/populate-state-cache.test.ts +124 -0
  1701. package/src/state/cache-v2/populate-state-cache.ts +178 -0
  1702. package/src/state/cache-v2/schema-metadata.ts +46 -0
  1703. package/src/state/cache-v2/schema.bench.ts +238 -0
  1704. package/src/state/cache-v2/schema.test.ts +330 -0
  1705. package/src/state/cache-v2/schema.ts +114 -0
  1706. package/src/state/cache-v2/select-from-state-cache.test.ts +109 -0
  1707. package/src/state/cache-v2/select-from-state-cache.ts +201 -0
  1708. package/src/state/cache-v2/sqlite-type-mapper.test.ts +56 -0
  1709. package/src/state/cache-v2/sqlite-type-mapper.ts +64 -0
  1710. package/src/state/cache-v2/update-state-cache.bench.ts +198 -0
  1711. package/src/state/cache-v2/update-state-cache.test.ts +344 -0
  1712. package/src/state/cache-v2/update-state-cache.ts +607 -0
  1713. package/src/state/create-checkpoint.test.ts +848 -0
  1714. package/src/state/create-checkpoint.ts +278 -0
  1715. package/src/state/index.ts +24 -0
  1716. package/src/state/materialize-state.bench.ts +231 -0
  1717. package/src/state/materialize-state.test.ts +728 -249
  1718. package/src/state/materialize-state.ts +454 -120
  1719. package/src/state/schema.bench.ts +128 -39
  1720. package/src/state/schema.ts +38 -986
  1721. package/src/state/transaction/insert-transaction-state.test.ts +1119 -0
  1722. package/src/state/transaction/insert-transaction-state.ts +149 -0
  1723. package/src/state/transaction/schema.ts +49 -0
  1724. package/src/state/transition.bench.ts +271 -0
  1725. package/src/state/transition.test.ts +295 -0
  1726. package/src/state/transition.ts +413 -0
  1727. package/src/state/untracked/schema.test.ts +36 -36
  1728. package/src/state/untracked/schema.ts +16 -9
  1729. package/src/state/untracked/update-untracked-state.test.ts +170 -152
  1730. package/src/state/untracked/update-untracked-state.ts +139 -91
  1731. package/src/state/views/__bench__/state-delete-tracked-row.explain.txt +79 -0
  1732. package/src/state/views/__bench__/state-insert-tracked-row.explain.txt +20 -0
  1733. package/src/state/views/__bench__/state-insert-untracked-row.explain.txt +20 -0
  1734. package/src/state/views/__bench__/state-select-recent-file-scan.explain.txt +1133 -0
  1735. package/src/state/views/__bench__/state-select-tracked-entity.explain.txt +296 -0
  1736. package/src/state/views/__bench__/state-select-untracked-filter.explain.txt +301 -0
  1737. package/src/state/views/__bench__/state-update-tracked-row.explain.txt +80 -0
  1738. package/src/state/views/state-by-version.ts +121 -0
  1739. package/src/state/views/state-with-tombstones.test.ts +166 -0
  1740. package/src/state/views/state-with-tombstones.ts +61 -0
  1741. package/src/state/views/state.bench.1_base.json +189 -0
  1742. package/src/state/views/state.bench.2_dml.json +189 -0
  1743. package/src/state/views/state.bench.ts +382 -0
  1744. package/src/state/views/state.test.ts +417 -0
  1745. package/src/state/views/state.ts +97 -0
  1746. package/src/state/vtable/__bench__/cache-entity-version-file-plugin.explain.txt +237 -0
  1747. package/src/state/vtable/__bench__/cache-entity-version-file.explain.txt +236 -0
  1748. package/src/state/vtable/__bench__/cache-entity-version.explain.txt +235 -0
  1749. package/src/state/vtable/__bench__/inherited-cache-entity-version-file-plugin.explain.txt +363 -0
  1750. package/src/state/vtable/__bench__/inherited-cache-entity-version-file.explain.txt +362 -0
  1751. package/src/state/vtable/__bench__/inherited-cache-entity-version.explain.txt +367 -0
  1752. package/src/state/vtable/__bench__/inherited-untracked-entity-version-file-plugin.explain.txt +363 -0
  1753. package/src/state/vtable/__bench__/inherited-untracked-entity-version-file.explain.txt +362 -0
  1754. package/src/state/vtable/__bench__/inherited-untracked-entity-version.explain.txt +367 -0
  1755. package/src/state/vtable/__bench__/transaction-entity-version-file-plugin.explain.txt +237 -0
  1756. package/src/state/vtable/__bench__/transaction-entity-version-file.explain.txt +236 -0
  1757. package/src/state/vtable/__bench__/transaction-entity-version.explain.txt +235 -0
  1758. package/src/state/vtable/__bench__/untracked-entity-version-file-plugin.explain.txt +237 -0
  1759. package/src/state/vtable/__bench__/untracked-entity-version-file.explain.txt +236 -0
  1760. package/src/state/vtable/__bench__/untracked-entity-version.explain.txt +235 -0
  1761. package/src/state/vtable/__playground__/validate-state-mutation.foreign-key.explain.txt +173 -0
  1762. package/src/state/vtable/__playground__/validate-state-mutation.primary-key.explain.txt +173 -0
  1763. package/src/state/vtable/__playground__/validate-state-mutation.unique-nested.explain.txt +173 -0
  1764. package/src/state/vtable/commit.bench.ts +339 -0
  1765. package/src/state/vtable/commit.test.ts +1924 -0
  1766. package/src/state/vtable/commit.ts +508 -0
  1767. package/src/state/vtable/generate-commit.test.ts +417 -0
  1768. package/src/state/vtable/generate-commit.ts +346 -0
  1769. package/src/state/vtable/index.ts +5 -0
  1770. package/src/state/vtable/insert-vtable-log.ts +64 -0
  1771. package/src/state/vtable/primary-key.test.ts +44 -0
  1772. package/src/state/vtable/primary-key.ts +82 -0
  1773. package/src/state/vtable/validate-state-mutation.bench.ts +326 -0
  1774. package/src/state/vtable/validate-state-mutation.playground.test.ts +456 -0
  1775. package/src/state/vtable/validate-state-mutation.test.ts +4265 -0
  1776. package/src/state/vtable/validate-state-mutation.ts +1236 -0
  1777. package/src/state/vtable/vtable.insert.bench.ts +127 -0
  1778. package/src/state/vtable/vtable.select.bench.ts +439 -0
  1779. package/src/state/vtable/vtable.test.ts +4211 -0
  1780. package/src/state/vtable/vtable.ts +1223 -0
  1781. package/src/state/working-change-set/refresh-working-change-set.test.ts +116 -0
  1782. package/src/state/working-change-set/refresh-working-change-set.ts +290 -0
  1783. package/src/state/writer.ts +71 -0
  1784. package/src/state-history/schema.test.ts +30 -30
  1785. package/src/state-history/schema.ts +101 -34
  1786. package/src/stored-schema/get-stored-schema.test.ts +352 -0
  1787. package/src/stored-schema/get-stored-schema.ts +163 -0
  1788. package/src/stored-schema/index.ts +1 -1
  1789. package/src/stored-schema/schema-definition.ts +30 -0
  1790. package/src/stored-schema/schema.test.ts +72 -114
  1791. package/src/sync/pull-from-server.test.ts +6 -6
  1792. package/src/sync/pull-from-server.ts +1 -1
  1793. package/src/sync/push-to-server.test.ts +6 -6
  1794. package/src/sync/push-to-server.ts +1 -1
  1795. package/src/sync/sync-process.test.ts +3 -6
  1796. package/src/sync/sync-process.ts +24 -11
  1797. package/src/test-utilities/simulation-test/cache-miss-simulation.test.ts +67 -31
  1798. package/src/test-utilities/simulation-test/cache-miss-simulation.ts +52 -55
  1799. package/src/test-utilities/simulation-test/engine-boundary-simulation.test.ts +14 -0
  1800. package/src/test-utilities/simulation-test/engine-boundary-simulation.ts +65 -0
  1801. package/src/test-utilities/simulation-test/out-of-order-sequence-simulation.test.ts +5 -5
  1802. package/src/test-utilities/simulation-test/out-of-order-sequence-simulation.ts +6 -14
  1803. package/src/test-utilities/simulation-test/simulation-test.test.ts +42 -38
  1804. package/src/test-utilities/simulation-test/simulation-test.ts +78 -60
  1805. package/src/types/fs.d.ts +11 -0
  1806. package/src/version/create-version-from-commit.test.ts +211 -0
  1807. package/src/version/create-version-from-commit.ts +141 -0
  1808. package/src/version/create-version.test.ts +62 -15
  1809. package/src/version/create-version.ts +24 -65
  1810. package/src/version/index.ts +12 -4
  1811. package/src/version/merge-version.test.ts +1051 -0
  1812. package/src/version/merge-version.ts +583 -0
  1813. package/src/version/schema-definition.ts +111 -0
  1814. package/src/version/schema.test.ts +367 -141
  1815. package/src/version/schema.ts +456 -144
  1816. package/src/version/select-active-version.ts +2 -2
  1817. package/src/version/select-version-diff.bench.ts +145 -0
  1818. package/src/version/select-version-diff.playground-plan.txt +3837 -0
  1819. package/src/version/select-version-diff.playground.test.ts +129 -0
  1820. package/src/version/select-version-diff.test.ts +805 -0
  1821. package/src/version/select-version-diff.ts +201 -0
  1822. package/src/version/switch-version.test.ts +2 -2
  1823. package/src/version/switch-version.ts +2 -2
  1824. package/dist/account/database-schema.d.ts +0 -18
  1825. package/dist/account/database-schema.d.ts.map +0 -1
  1826. package/dist/account/database-schema.js +0 -32
  1827. package/dist/account/database-schema.js.map +0 -1
  1828. package/dist/account/database-schema.test.d.ts +0 -2
  1829. package/dist/account/database-schema.test.d.ts.map +0 -1
  1830. package/dist/account/database-schema.test.js +0 -135
  1831. package/dist/account/database-schema.test.js.map +0 -1
  1832. package/dist/account/schema.d.ts +0 -44
  1833. package/dist/account/schema.d.ts.map +0 -1
  1834. package/dist/account/schema.js +0 -112
  1835. package/dist/account/schema.js.map +0 -1
  1836. package/dist/change/apply-changes.d.ts +0 -38
  1837. package/dist/change/apply-changes.d.ts.map +0 -1
  1838. package/dist/change/apply-changes.js +0 -108
  1839. package/dist/change/apply-changes.js.map +0 -1
  1840. package/dist/change/apply-changes.test.d.ts +0 -2
  1841. package/dist/change/apply-changes.test.d.ts.map +0 -1
  1842. package/dist/change/apply-changes.test.js +0 -312
  1843. package/dist/change/apply-changes.test.js.map +0 -1
  1844. package/dist/change/create-change-v2.d.ts +0 -11
  1845. package/dist/change/create-change-v2.d.ts.map +0 -1
  1846. package/dist/change/create-change-v2.js +0 -31
  1847. package/dist/change/create-change-v2.js.map +0 -1
  1848. package/dist/change/create-change-v2.test.d.ts +0 -2
  1849. package/dist/change/create-change-v2.test.d.ts.map +0 -1
  1850. package/dist/change/create-change-v2.test.js +0 -39
  1851. package/dist/change/create-change-v2.test.js.map +0 -1
  1852. package/dist/change/create-change.d.ts +0 -16
  1853. package/dist/change/create-change.d.ts.map +0 -1
  1854. package/dist/change/create-change.js +0 -45
  1855. package/dist/change/create-change.js.map +0 -1
  1856. package/dist/change/create-change.test.d.ts +0 -2
  1857. package/dist/change/create-change.test.d.ts.map +0 -1
  1858. package/dist/change/create-change.test.js +0 -186
  1859. package/dist/change/create-change.test.js.map +0 -1
  1860. package/dist/change/mock-change.d.ts +0 -10
  1861. package/dist/change/mock-change.d.ts.map +0 -1
  1862. package/dist/change/mock-change.js +0 -21
  1863. package/dist/change/mock-change.js.map +0 -1
  1864. package/dist/change-author/schema.d.ts +0 -34
  1865. package/dist/change-author/schema.d.ts.map +0 -1
  1866. package/dist/change-author/schema.js +0 -41
  1867. package/dist/change-author/schema.js.map +0 -1
  1868. package/dist/change-proposal/database-schema.d.ts +0 -13
  1869. package/dist/change-proposal/database-schema.d.ts.map +0 -1
  1870. package/dist/change-proposal/database-schema.js +0 -17
  1871. package/dist/change-proposal/database-schema.js.map +0 -1
  1872. package/dist/change-proposal/database-schema.test.d.ts +0 -2
  1873. package/dist/change-proposal/database-schema.test.d.ts.map +0 -1
  1874. package/dist/change-proposal/database-schema.test.js +0 -159
  1875. package/dist/change-proposal/database-schema.test.js.map +0 -1
  1876. package/dist/change-schema/index.d.ts +0 -2
  1877. package/dist/change-schema/index.d.ts.map +0 -1
  1878. package/dist/change-schema/index.js +0 -2
  1879. package/dist/change-schema/index.js.map +0 -1
  1880. package/dist/change-schema/types.d.ts +0 -40
  1881. package/dist/change-schema/types.d.ts.map +0 -1
  1882. package/dist/change-schema/types.js.map +0 -1
  1883. package/dist/change-schema/types.test-d.d.ts +0 -2
  1884. package/dist/change-schema/types.test-d.d.ts.map +0 -1
  1885. package/dist/change-schema/types.test-d.js +0 -34
  1886. package/dist/change-schema/types.test-d.js.map +0 -1
  1887. package/dist/change-set/before-after-of-file.d.ts +0 -31
  1888. package/dist/change-set/before-after-of-file.d.ts.map +0 -1
  1889. package/dist/change-set/before-after-of-file.js +0 -191
  1890. package/dist/change-set/before-after-of-file.js.map +0 -1
  1891. package/dist/change-set/before-after-of-file.test.d.ts +0 -2
  1892. package/dist/change-set/before-after-of-file.test.d.ts.map +0 -1
  1893. package/dist/change-set/before-after-of-file.test.js +0 -221
  1894. package/dist/change-set/before-after-of-file.test.js.map +0 -1
  1895. package/dist/change-set/change-set-element-in-symmetric-difference.d.ts +0 -20
  1896. package/dist/change-set/change-set-element-in-symmetric-difference.d.ts.map +0 -1
  1897. package/dist/change-set/change-set-element-in-symmetric-difference.js +0 -36
  1898. package/dist/change-set/change-set-element-in-symmetric-difference.js.map +0 -1
  1899. package/dist/change-set/change-set-element-in-symmetric-difference.test.d.ts +0 -2
  1900. package/dist/change-set/change-set-element-in-symmetric-difference.test.d.ts.map +0 -1
  1901. package/dist/change-set/change-set-element-in-symmetric-difference.test.js +0 -276
  1902. package/dist/change-set/change-set-element-in-symmetric-difference.test.js.map +0 -1
  1903. package/dist/change-set/checkout-change-set.d.ts +0 -15
  1904. package/dist/change-set/checkout-change-set.d.ts.map +0 -1
  1905. package/dist/change-set/checkout-change-set.js +0 -64
  1906. package/dist/change-set/checkout-change-set.js.map +0 -1
  1907. package/dist/change-set/checkout-change-set.test.d.ts +0 -2
  1908. package/dist/change-set/checkout-change-set.test.d.ts.map +0 -1
  1909. package/dist/change-set/checkout-change-set.test.js +0 -127
  1910. package/dist/change-set/checkout-change-set.test.js.map +0 -1
  1911. package/dist/change-set/create-checkpoint.d.ts +0 -19
  1912. package/dist/change-set/create-checkpoint.d.ts.map +0 -1
  1913. package/dist/change-set/create-checkpoint.js +0 -95
  1914. package/dist/change-set/create-checkpoint.js.map +0 -1
  1915. package/dist/change-set/create-checkpoint.test.d.ts +0 -2
  1916. package/dist/change-set/create-checkpoint.test.d.ts.map +0 -1
  1917. package/dist/change-set/create-checkpoint.test.js +0 -347
  1918. package/dist/change-set/create-checkpoint.test.js.map +0 -1
  1919. package/dist/change-set/create-merge-change-set.d.ts +0 -23
  1920. package/dist/change-set/create-merge-change-set.d.ts.map +0 -1
  1921. package/dist/change-set/create-merge-change-set.js +0 -68
  1922. package/dist/change-set/create-merge-change-set.js.map +0 -1
  1923. package/dist/change-set/create-merge-change-set.test.d.ts +0 -2
  1924. package/dist/change-set/create-merge-change-set.test.d.ts.map +0 -1
  1925. package/dist/change-set/create-merge-change-set.test.js +0 -211
  1926. package/dist/change-set/create-merge-change-set.test.js.map +0 -1
  1927. package/dist/change-set/create-transition-change-set.d.ts +0 -18
  1928. package/dist/change-set/create-transition-change-set.d.ts.map +0 -1
  1929. package/dist/change-set/create-transition-change-set.js +0 -102
  1930. package/dist/change-set/create-transition-change-set.js.map +0 -1
  1931. package/dist/change-set/create-transition-change-set.test.d.ts +0 -2
  1932. package/dist/change-set/create-transition-change-set.test.d.ts.map +0 -1
  1933. package/dist/change-set/create-transition-change-set.test.js +0 -211
  1934. package/dist/change-set/create-transition-change-set.test.js.map +0 -1
  1935. package/dist/change-set/create-undo-change-set.d.ts +0 -27
  1936. package/dist/change-set/create-undo-change-set.d.ts.map +0 -1
  1937. package/dist/change-set/create-undo-change-set.js +0 -122
  1938. package/dist/change-set/create-undo-change-set.js.map +0 -1
  1939. package/dist/change-set/create-undo-change-set.test.d.ts +0 -2
  1940. package/dist/change-set/create-undo-change-set.test.d.ts.map +0 -1
  1941. package/dist/change-set/create-undo-change-set.test.js +0 -273
  1942. package/dist/change-set/create-undo-change-set.test.js.map +0 -1
  1943. package/dist/change-set/database-schema.d.ts +0 -39
  1944. package/dist/change-set/database-schema.d.ts.map +0 -1
  1945. package/dist/change-set/database-schema.js +0 -86
  1946. package/dist/change-set/database-schema.js.map +0 -1
  1947. package/dist/change-set/database-schema.test.d.ts +0 -2
  1948. package/dist/change-set/database-schema.test.d.ts.map +0 -1
  1949. package/dist/change-set/database-schema.test.js +0 -547
  1950. package/dist/change-set/database-schema.test.js.map +0 -1
  1951. package/dist/change-set/diff-for-file.d.ts +0 -29
  1952. package/dist/change-set/diff-for-file.d.ts.map +0 -1
  1953. package/dist/change-set/diff-for-file.js +0 -19
  1954. package/dist/change-set/diff-for-file.js.map +0 -1
  1955. package/dist/change-set/get-before-after-of-file.d.ts +0 -31
  1956. package/dist/change-set/get-before-after-of-file.d.ts.map +0 -1
  1957. package/dist/change-set/get-before-after-of-file.js +0 -189
  1958. package/dist/change-set/get-before-after-of-file.js.map +0 -1
  1959. package/dist/change-set/get-before-after-of-file.test.d.ts +0 -2
  1960. package/dist/change-set/get-before-after-of-file.test.d.ts.map +0 -1
  1961. package/dist/change-set/get-before-after-of-file.test.js +0 -220
  1962. package/dist/change-set/get-before-after-of-file.test.js.map +0 -1
  1963. package/dist/change-set/merge-change-sets.d.ts +0 -23
  1964. package/dist/change-set/merge-change-sets.d.ts.map +0 -1
  1965. package/dist/change-set/merge-change-sets.js +0 -69
  1966. package/dist/change-set/merge-change-sets.js.map +0 -1
  1967. package/dist/change-set/merge-change-sets.test.d.ts +0 -2
  1968. package/dist/change-set/merge-change-sets.test.d.ts.map +0 -1
  1969. package/dist/change-set/merge-change-sets.test.js +0 -184
  1970. package/dist/change-set/merge-change-sets.test.js.map +0 -1
  1971. package/dist/change-set/restore-change-set.d.ts +0 -14
  1972. package/dist/change-set/restore-change-set.d.ts.map +0 -1
  1973. package/dist/change-set/restore-change-set.js +0 -98
  1974. package/dist/change-set/restore-change-set.js.map +0 -1
  1975. package/dist/change-set/restore-change-set.test.d.ts +0 -2
  1976. package/dist/change-set/restore-change-set.test.d.ts.map +0 -1
  1977. package/dist/change-set/restore-change-set.test.js +0 -238
  1978. package/dist/change-set/restore-change-set.test.js.map +0 -1
  1979. package/dist/change-set/schema.d.ts +0 -105
  1980. package/dist/change-set/schema.d.ts.map +0 -1
  1981. package/dist/change-set/schema.js +0 -122
  1982. package/dist/change-set/schema.js.map +0 -1
  1983. package/dist/change-set-edge/database-schema.d.ts +0 -11
  1984. package/dist/change-set-edge/database-schema.d.ts.map +0 -1
  1985. package/dist/change-set-edge/database-schema.js +0 -29
  1986. package/dist/change-set-edge/database-schema.js.map +0 -1
  1987. package/dist/change-set-edge/database-schema.test.d.ts +0 -2
  1988. package/dist/change-set-edge/database-schema.test.d.ts.map +0 -1
  1989. package/dist/change-set-edge/database-schema.test.js +0 -166
  1990. package/dist/change-set-edge/database-schema.test.js.map +0 -1
  1991. package/dist/change-set-edge/index.d.ts +0 -2
  1992. package/dist/change-set-edge/index.d.ts.map +0 -1
  1993. package/dist/change-set-edge/index.js +0 -2
  1994. package/dist/change-set-edge/index.js.map +0 -1
  1995. package/dist/change-set-v2/apply-change-set.d.ts +0 -10
  1996. package/dist/change-set-v2/apply-change-set.d.ts.map +0 -1
  1997. package/dist/change-set-v2/apply-change-set.js +0 -147
  1998. package/dist/change-set-v2/apply-change-set.js.map +0 -1
  1999. package/dist/change-set-v2/apply-change-set.test.d.ts +0 -2
  2000. package/dist/change-set-v2/apply-change-set.test.d.ts.map +0 -1
  2001. package/dist/change-set-v2/apply-change-set.test.js +0 -270
  2002. package/dist/change-set-v2/apply-change-set.test.js.map +0 -1
  2003. package/dist/change-set-v2/create-change-set.d.ts +0 -10
  2004. package/dist/change-set-v2/create-change-set.d.ts.map +0 -1
  2005. package/dist/change-set-v2/create-change-set.js +0 -57
  2006. package/dist/change-set-v2/create-change-set.js.map +0 -1
  2007. package/dist/change-set-v2/create-change-set.test.d.ts +0 -2
  2008. package/dist/change-set-v2/create-change-set.test.d.ts.map +0 -1
  2009. package/dist/change-set-v2/create-change-set.test.js +0 -59
  2010. package/dist/change-set-v2/create-change-set.test.js.map +0 -1
  2011. package/dist/change-set-v2/create-checkpoint.d.ts +0 -7
  2012. package/dist/change-set-v2/create-checkpoint.d.ts.map +0 -1
  2013. package/dist/change-set-v2/create-checkpoint.js +0 -79
  2014. package/dist/change-set-v2/create-checkpoint.js.map +0 -1
  2015. package/dist/change-set-v2/create-checkpoint.test.d.ts.map +0 -1
  2016. package/dist/change-set-v2/create-checkpoint.test.js +0 -289
  2017. package/dist/change-set-v2/create-checkpoint.test.js.map +0 -1
  2018. package/dist/change-set-v2/create-merge-change-set.d.ts +0 -23
  2019. package/dist/change-set-v2/create-merge-change-set.d.ts.map +0 -1
  2020. package/dist/change-set-v2/create-merge-change-set.js +0 -68
  2021. package/dist/change-set-v2/create-merge-change-set.js.map +0 -1
  2022. package/dist/change-set-v2/create-merge-change-set.test.d.ts +0 -2
  2023. package/dist/change-set-v2/create-merge-change-set.test.d.ts.map +0 -1
  2024. package/dist/change-set-v2/create-merge-change-set.test.js +0 -223
  2025. package/dist/change-set-v2/create-merge-change-set.test.js.map +0 -1
  2026. package/dist/change-set-v2/index.d.ts +0 -5
  2027. package/dist/change-set-v2/index.d.ts.map +0 -1
  2028. package/dist/change-set-v2/index.js +0 -5
  2029. package/dist/change-set-v2/index.js.map +0 -1
  2030. package/dist/change-set-v2/schema.d.ts +0 -50
  2031. package/dist/change-set-v2/schema.d.ts.map +0 -1
  2032. package/dist/change-set-v2/schema.js +0 -347
  2033. package/dist/change-set-v2/schema.js.map +0 -1
  2034. package/dist/change-set-v2/schema.test.d.ts.map +0 -1
  2035. package/dist/change-set-v2/schema.test.js +0 -713
  2036. package/dist/change-set-v2/schema.test.js.map +0 -1
  2037. package/dist/commit/apply-commit.d.ts +0 -32
  2038. package/dist/commit/apply-commit.d.ts.map +0 -1
  2039. package/dist/commit/apply-commit.js +0 -63
  2040. package/dist/commit/apply-commit.js.map +0 -1
  2041. package/dist/commit/apply-commit.test.d.ts +0 -2
  2042. package/dist/commit/apply-commit.test.d.ts.map +0 -1
  2043. package/dist/commit/apply-commit.test.js +0 -367
  2044. package/dist/commit/apply-commit.test.js.map +0 -1
  2045. package/dist/commit/create-checkpoint.d.ts +0 -19
  2046. package/dist/commit/create-checkpoint.d.ts.map +0 -1
  2047. package/dist/commit/create-checkpoint.js +0 -118
  2048. package/dist/commit/create-checkpoint.js.map +0 -1
  2049. package/dist/commit/create-checkpoint.test.d.ts +0 -2
  2050. package/dist/commit/create-checkpoint.test.d.ts.map +0 -1
  2051. package/dist/commit/create-checkpoint.test.js +0 -472
  2052. package/dist/commit/create-checkpoint.test.js.map +0 -1
  2053. package/dist/commit/create-commit.d.ts +0 -38
  2054. package/dist/commit/create-commit.d.ts.map +0 -1
  2055. package/dist/commit/create-commit.js +0 -68
  2056. package/dist/commit/create-commit.js.map +0 -1
  2057. package/dist/commit/create-merge-commit.d.ts +0 -24
  2058. package/dist/commit/create-merge-commit.d.ts.map +0 -1
  2059. package/dist/commit/create-merge-commit.js +0 -103
  2060. package/dist/commit/create-merge-commit.js.map +0 -1
  2061. package/dist/commit/create-merge-commit.test.d.ts +0 -2
  2062. package/dist/commit/create-merge-commit.test.d.ts.map +0 -1
  2063. package/dist/commit/create-merge-commit.test.js +0 -242
  2064. package/dist/commit/create-merge-commit.test.js.map +0 -1
  2065. package/dist/commit/create-transition-commit.d.ts +0 -18
  2066. package/dist/commit/create-transition-commit.d.ts.map +0 -1
  2067. package/dist/commit/create-transition-commit.js +0 -136
  2068. package/dist/commit/create-transition-commit.js.map +0 -1
  2069. package/dist/commit/create-transition-commit.test.d.ts +0 -2
  2070. package/dist/commit/create-transition-commit.test.d.ts.map +0 -1
  2071. package/dist/commit/create-transition-commit.test.js +0 -221
  2072. package/dist/commit/create-transition-commit.test.js.map +0 -1
  2073. package/dist/commit/create-undo-commit.d.ts +0 -27
  2074. package/dist/commit/create-undo-commit.d.ts.map +0 -1
  2075. package/dist/commit/create-undo-commit.js +0 -143
  2076. package/dist/commit/create-undo-commit.js.map +0 -1
  2077. package/dist/commit/create-undo-commit.test.d.ts +0 -2
  2078. package/dist/commit/create-undo-commit.test.d.ts.map +0 -1
  2079. package/dist/commit/create-undo-commit.test.js +0 -298
  2080. package/dist/commit/create-undo-commit.test.js.map +0 -1
  2081. package/dist/commit/schema.d.ts +0 -73
  2082. package/dist/commit/schema.d.ts.map +0 -1
  2083. package/dist/commit/schema.js +0 -90
  2084. package/dist/commit/schema.js.map +0 -1
  2085. package/dist/database/apply-schema.d.ts +0 -11
  2086. package/dist/database/apply-schema.d.ts.map +0 -1
  2087. package/dist/database/apply-schema.js +0 -99
  2088. package/dist/database/apply-schema.js.map +0 -1
  2089. package/dist/database/execute-sync.d.ts +0 -24
  2090. package/dist/database/execute-sync.d.ts.map +0 -1
  2091. package/dist/database/execute-sync.js +0 -37
  2092. package/dist/database/execute-sync.js.map +0 -1
  2093. package/dist/database/execute-sync.test.d.ts.map +0 -1
  2094. package/dist/database/execute-sync.test.js +0 -111
  2095. package/dist/database/execute-sync.test.js.map +0 -1
  2096. package/dist/database/init-db.test.d.ts +0 -2
  2097. package/dist/database/init-db.test.d.ts.map +0 -1
  2098. package/dist/database/init-db.test.js +0 -19
  2099. package/dist/database/init-db.test.js.map +0 -1
  2100. package/dist/database/kysely-plugin/json-column-plugin.d.ts.map +0 -1
  2101. package/dist/database/kysely-plugin/json-column-plugin.js +0 -210
  2102. package/dist/database/kysely-plugin/json-column-plugin.js.map +0 -1
  2103. package/dist/database/kysely-plugin/json-column-plugin.test.d.ts.map +0 -1
  2104. package/dist/database/kysely-plugin/json-column-plugin.test.js +0 -329
  2105. package/dist/database/kysely-plugin/json-column-plugin.test.js.map +0 -1
  2106. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.d.ts +0 -3
  2107. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.d.ts.map +0 -1
  2108. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js +0 -39
  2109. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js.map +0 -1
  2110. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.test.d.ts +0 -2
  2111. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.test.d.ts.map +0 -1
  2112. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.test.js +0 -162
  2113. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.test.js.map +0 -1
  2114. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.d.ts +0 -12
  2115. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.d.ts.map +0 -1
  2116. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.js +0 -149
  2117. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.js.map +0 -1
  2118. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.no_test.d.ts +0 -2
  2119. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.no_test.d.ts.map +0 -1
  2120. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.no_test.js +0 -162
  2121. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.no_test.js.map +0 -1
  2122. package/dist/database/kysely-plugin/serialize-jsonb-plugin.d.ts +0 -15
  2123. package/dist/database/kysely-plugin/serialize-jsonb-plugin.d.ts.map +0 -1
  2124. package/dist/database/kysely-plugin/serialize-jsonb-plugin.js +0 -171
  2125. package/dist/database/kysely-plugin/serialize-jsonb-plugin.js.map +0 -1
  2126. package/dist/database/kysely-plugin/serialize-jsonb-plugin.test.d.ts +0 -2
  2127. package/dist/database/kysely-plugin/serialize-jsonb-plugin.test.d.ts.map +0 -1
  2128. package/dist/database/kysely-plugin/serialize-jsonb-plugin.test.js +0 -251
  2129. package/dist/database/kysely-plugin/serialize-jsonb-plugin.test.js.map +0 -1
  2130. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.d.ts.map +0 -1
  2131. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.js.map +0 -1
  2132. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.test.d.ts.map +0 -1
  2133. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.test.js +0 -51
  2134. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.test.js.map +0 -1
  2135. package/dist/database/mutation-log/database-schema.d.ts +0 -16
  2136. package/dist/database/mutation-log/database-schema.d.ts.map +0 -1
  2137. package/dist/database/mutation-log/database-schema.js +0 -97
  2138. package/dist/database/mutation-log/database-schema.js.map +0 -1
  2139. package/dist/database/mutation-log/lix-session.d.ts +0 -8
  2140. package/dist/database/mutation-log/lix-session.d.ts.map +0 -1
  2141. package/dist/database/mutation-log/lix-session.js +0 -18
  2142. package/dist/database/mutation-log/lix-session.js.map +0 -1
  2143. package/dist/deterministic/generate-human-id.d.ts +0 -20
  2144. package/dist/deterministic/generate-human-id.d.ts.map +0 -1
  2145. package/dist/deterministic/generate-human-id.js +0 -86
  2146. package/dist/deterministic/generate-human-id.js.map +0 -1
  2147. package/dist/deterministic/generate-human-id.test.d.ts.map +0 -1
  2148. package/dist/deterministic/generate-human-id.test.js +0 -123
  2149. package/dist/deterministic/generate-human-id.test.js.map +0 -1
  2150. package/dist/deterministic/index.d.ts +0 -8
  2151. package/dist/deterministic/index.d.ts.map +0 -1
  2152. package/dist/deterministic/index.js +0 -8
  2153. package/dist/deterministic/index.js.map +0 -1
  2154. package/dist/deterministic/is-deterministic-mode.d.ts +0 -14
  2155. package/dist/deterministic/is-deterministic-mode.d.ts.map +0 -1
  2156. package/dist/deterministic/is-deterministic-mode.js +0 -25
  2157. package/dist/deterministic/is-deterministic-mode.js.map +0 -1
  2158. package/dist/deterministic/is-deterministic-mode.test.d.ts.map +0 -1
  2159. package/dist/deterministic/is-deterministic-mode.test.js +0 -103
  2160. package/dist/deterministic/is-deterministic-mode.test.js.map +0 -1
  2161. package/dist/deterministic/nano-id.d.ts +0 -61
  2162. package/dist/deterministic/nano-id.d.ts.map +0 -1
  2163. package/dist/deterministic/nano-id.js +0 -161
  2164. package/dist/deterministic/nano-id.js.map +0 -1
  2165. package/dist/deterministic/nano-id.test.d.ts.map +0 -1
  2166. package/dist/deterministic/nano-id.test.js +0 -163
  2167. package/dist/deterministic/nano-id.test.js.map +0 -1
  2168. package/dist/deterministic/options.d.ts +0 -53
  2169. package/dist/deterministic/options.d.ts.map +0 -1
  2170. package/dist/deterministic/options.js +0 -52
  2171. package/dist/deterministic/options.js.map +0 -1
  2172. package/dist/deterministic/options.test.d.ts.map +0 -1
  2173. package/dist/deterministic/options.test.js +0 -111
  2174. package/dist/deterministic/options.test.js.map +0 -1
  2175. package/dist/deterministic/random.d.ts +0 -68
  2176. package/dist/deterministic/random.d.ts.map +0 -1
  2177. package/dist/deterministic/random.js +0 -225
  2178. package/dist/deterministic/random.js.map +0 -1
  2179. package/dist/deterministic/random.test.d.ts.map +0 -1
  2180. package/dist/deterministic/random.test.js +0 -244
  2181. package/dist/deterministic/random.test.js.map +0 -1
  2182. package/dist/deterministic/sequence.d.ts +0 -56
  2183. package/dist/deterministic/sequence.d.ts.map +0 -1
  2184. package/dist/deterministic/sequence.js +0 -107
  2185. package/dist/deterministic/sequence.js.map +0 -1
  2186. package/dist/deterministic/sequence.test.d.ts.map +0 -1
  2187. package/dist/deterministic/sequence.test.js +0 -71
  2188. package/dist/deterministic/sequence.test.js.map +0 -1
  2189. package/dist/deterministic/timestamp.d.ts +0 -47
  2190. package/dist/deterministic/timestamp.d.ts.map +0 -1
  2191. package/dist/deterministic/timestamp.js +0 -74
  2192. package/dist/deterministic/timestamp.js.map +0 -1
  2193. package/dist/deterministic/timestamp.test.d.ts.map +0 -1
  2194. package/dist/deterministic/timestamp.test.js +0 -145
  2195. package/dist/deterministic/timestamp.test.js.map +0 -1
  2196. package/dist/deterministic/uuid-v7.d.ts +0 -49
  2197. package/dist/deterministic/uuid-v7.d.ts.map +0 -1
  2198. package/dist/deterministic/uuid-v7.js +0 -75
  2199. package/dist/deterministic/uuid-v7.js.map +0 -1
  2200. package/dist/deterministic/uuid-v7.test.d.ts.map +0 -1
  2201. package/dist/deterministic/uuid-v7.test.js +0 -114
  2202. package/dist/deterministic/uuid-v7.test.js.map +0 -1
  2203. package/dist/discussion/create-comment.d.ts +0 -8
  2204. package/dist/discussion/create-comment.d.ts.map +0 -1
  2205. package/dist/discussion/create-comment.js +0 -12
  2206. package/dist/discussion/create-comment.js.map +0 -1
  2207. package/dist/discussion/create-discussion.d.ts +0 -22
  2208. package/dist/discussion/create-discussion.d.ts.map +0 -1
  2209. package/dist/discussion/create-discussion.js +0 -40
  2210. package/dist/discussion/create-discussion.js.map +0 -1
  2211. package/dist/discussion/create-discussion.test.d.ts +0 -2
  2212. package/dist/discussion/create-discussion.test.d.ts.map +0 -1
  2213. package/dist/discussion/create-discussion.test.js +0 -49
  2214. package/dist/discussion/create-discussion.test.js.map +0 -1
  2215. package/dist/discussion/index.d.ts +0 -3
  2216. package/dist/discussion/index.d.ts.map +0 -1
  2217. package/dist/discussion/index.js +0 -3
  2218. package/dist/discussion/index.js.map +0 -1
  2219. package/dist/entity/label/create-entity-label.d.ts +0 -61
  2220. package/dist/entity/label/create-entity-label.d.ts.map +0 -1
  2221. package/dist/entity/label/create-entity-label.js +0 -92
  2222. package/dist/entity/label/create-entity-label.js.map +0 -1
  2223. package/dist/entity/label/create-entity-label.test.d.ts +0 -2
  2224. package/dist/entity/label/create-entity-label.test.d.ts.map +0 -1
  2225. package/dist/entity/label/create-entity-label.test.js +0 -261
  2226. package/dist/entity/label/create-entity-label.test.js.map +0 -1
  2227. package/dist/entity/label/schema.d.ts +0 -40
  2228. package/dist/entity/label/schema.d.ts.map +0 -1
  2229. package/dist/entity/label/schema.js +0 -42
  2230. package/dist/entity/label/schema.js.map +0 -1
  2231. package/dist/entity/schema.d.ts +0 -13
  2232. package/dist/entity/schema.d.ts.map +0 -1
  2233. package/dist/entity/schema.js +0 -5
  2234. package/dist/entity/schema.js.map +0 -1
  2235. package/dist/entity/thread/create-entity-thread.d.ts +0 -75
  2236. package/dist/entity/thread/create-entity-thread.d.ts.map +0 -1
  2237. package/dist/entity/thread/create-entity-thread.js +0 -109
  2238. package/dist/entity/thread/create-entity-thread.js.map +0 -1
  2239. package/dist/entity/thread/create-entity-thread.test.d.ts +0 -2
  2240. package/dist/entity/thread/create-entity-thread.test.d.ts.map +0 -1
  2241. package/dist/entity/thread/create-entity-thread.test.js +0 -240
  2242. package/dist/entity/thread/create-entity-thread.test.js.map +0 -1
  2243. package/dist/entity/thread/query-threads.test.d.ts +0 -2
  2244. package/dist/entity/thread/query-threads.test.d.ts.map +0 -1
  2245. package/dist/entity/thread/query-threads.test.js +0 -330
  2246. package/dist/entity/thread/query-threads.test.js.map +0 -1
  2247. package/dist/entity/thread/schema.d.ts +0 -40
  2248. package/dist/entity/thread/schema.d.ts.map +0 -1
  2249. package/dist/entity/thread/schema.js +0 -42
  2250. package/dist/entity/thread/schema.js.map +0 -1
  2251. package/dist/entity/thread/schema.test.d.ts.map +0 -1
  2252. package/dist/entity/thread/schema.test.js +0 -144
  2253. package/dist/entity/thread/schema.test.js.map +0 -1
  2254. package/dist/entity-views/entity-state-all.d.ts +0 -269
  2255. package/dist/entity-views/entity-state-all.d.ts.map +0 -1
  2256. package/dist/entity-views/entity-state-all.js +0 -254
  2257. package/dist/entity-views/entity-state-all.js.map +0 -1
  2258. package/dist/entity-views/entity-state-all.test.d.ts +0 -2
  2259. package/dist/entity-views/entity-state-all.test.d.ts.map +0 -1
  2260. package/dist/entity-views/entity-state-all.test.js +0 -544
  2261. package/dist/entity-views/entity-state-all.test.js.map +0 -1
  2262. package/dist/entity-views/entity-state-history.d.ts +0 -218
  2263. package/dist/entity-views/entity-state-history.d.ts.map +0 -1
  2264. package/dist/entity-views/entity-state-history.js +0 -61
  2265. package/dist/entity-views/entity-state-history.js.map +0 -1
  2266. package/dist/entity-views/entity-state-history.test.d.ts +0 -2
  2267. package/dist/entity-views/entity-state-history.test.d.ts.map +0 -1
  2268. package/dist/entity-views/entity-state-history.test.js +0 -329
  2269. package/dist/entity-views/entity-state-history.test.js.map +0 -1
  2270. package/dist/entity-views/entity-state.d.ts +0 -269
  2271. package/dist/entity-views/entity-state.d.ts.map +0 -1
  2272. package/dist/entity-views/entity-state.js +0 -251
  2273. package/dist/entity-views/entity-state.js.map +0 -1
  2274. package/dist/entity-views/entity-state.test.d.ts +0 -2
  2275. package/dist/entity-views/entity-state.test.d.ts.map +0 -1
  2276. package/dist/entity-views/entity-state.test.js +0 -616
  2277. package/dist/entity-views/entity-state.test.js.map +0 -1
  2278. package/dist/entity-views/entity-view-builder.d.ts +0 -92
  2279. package/dist/entity-views/entity-view-builder.d.ts.map +0 -1
  2280. package/dist/entity-views/entity-view-builder.js +0 -63
  2281. package/dist/entity-views/entity-view-builder.js.map +0 -1
  2282. package/dist/entity-views/entity-view-builder.test.d.ts +0 -2
  2283. package/dist/entity-views/entity-view-builder.test.d.ts.map +0 -1
  2284. package/dist/entity-views/entity-view-builder.test.js +0 -247
  2285. package/dist/entity-views/entity-view-builder.test.js.map +0 -1
  2286. package/dist/entity-views/index.d.ts.map +0 -1
  2287. package/dist/entity-views/index.js.map +0 -1
  2288. package/dist/entity-views/types.d.ts +0 -309
  2289. package/dist/entity-views/types.d.ts.map +0 -1
  2290. package/dist/entity-views/types.js.map +0 -1
  2291. package/dist/entity-views/types.test.d.ts.map +0 -1
  2292. package/dist/entity-views/types.test.js +0 -62
  2293. package/dist/entity-views/types.test.js.map +0 -1
  2294. package/dist/file/database-schema.d.ts +0 -25
  2295. package/dist/file/database-schema.d.ts.map +0 -1
  2296. package/dist/file/database-schema.js +0 -26
  2297. package/dist/file/database-schema.js.map +0 -1
  2298. package/dist/file/database-schema.test.d.ts +0 -2
  2299. package/dist/file/database-schema.test.d.ts.map +0 -1
  2300. package/dist/file/database-schema.test.js +0 -60
  2301. package/dist/file/database-schema.test.js.map +0 -1
  2302. package/dist/file/file-handlers.d.ts +0 -15
  2303. package/dist/file/file-handlers.d.ts.map +0 -1
  2304. package/dist/file/file-handlers.js +0 -354
  2305. package/dist/file/file-handlers.js.map +0 -1
  2306. package/dist/file/file-handlers.test.d.ts.map +0 -1
  2307. package/dist/file/file-handlers.test.js +0 -151
  2308. package/dist/file/file-handlers.test.js.map +0 -1
  2309. package/dist/file/index.d.ts +0 -2
  2310. package/dist/file/index.d.ts.map +0 -1
  2311. package/dist/file/index.js +0 -2
  2312. package/dist/file/index.js.map +0 -1
  2313. package/dist/file/materialize-file-data-at-changeset.d.ts +0 -9
  2314. package/dist/file/materialize-file-data-at-changeset.d.ts.map +0 -1
  2315. package/dist/file/materialize-file-data-at-changeset.js +0 -119
  2316. package/dist/file/materialize-file-data-at-changeset.js.map +0 -1
  2317. package/dist/file/materialize-file-data-at-commit.d.ts +0 -9
  2318. package/dist/file/materialize-file-data-at-commit.d.ts.map +0 -1
  2319. package/dist/file/materialize-file-data-at-commit.js +0 -119
  2320. package/dist/file/materialize-file-data-at-commit.js.map +0 -1
  2321. package/dist/file/materialize-file-data.d.ts +0 -8
  2322. package/dist/file/materialize-file-data.d.ts.map +0 -1
  2323. package/dist/file/materialize-file-data.js +0 -91
  2324. package/dist/file/materialize-file-data.js.map +0 -1
  2325. package/dist/file/materialize-file-data.test.d.ts.map +0 -1
  2326. package/dist/file/materialize-file-data.test.js +0 -90
  2327. package/dist/file/materialize-file-data.test.js.map +0 -1
  2328. package/dist/file/schema.d.ts +0 -109
  2329. package/dist/file/schema.d.ts.map +0 -1
  2330. package/dist/file/schema.js +0 -333
  2331. package/dist/file/schema.js.map +0 -1
  2332. package/dist/file/schema.test.d.ts.map +0 -1
  2333. package/dist/file/schema.test.js +0 -1313
  2334. package/dist/file/schema.test.js.map +0 -1
  2335. package/dist/file/store-detected-change-schema.d.ts +0 -8
  2336. package/dist/file/store-detected-change-schema.d.ts.map +0 -1
  2337. package/dist/file/store-detected-change-schema.js +0 -41
  2338. package/dist/file/store-detected-change-schema.js.map +0 -1
  2339. package/dist/file/store-detected-change-schema.test.d.ts.map +0 -1
  2340. package/dist/file/store-detected-change-schema.test.js +0 -211
  2341. package/dist/file/store-detected-change-schema.test.js.map +0 -1
  2342. package/dist/file/unknown-file-fallback-plugin.d.ts +0 -22
  2343. package/dist/file/unknown-file-fallback-plugin.d.ts.map +0 -1
  2344. package/dist/file/unknown-file-fallback-plugin.js +0 -73
  2345. package/dist/file/unknown-file-fallback-plugin.js.map +0 -1
  2346. package/dist/file/unknown-file-fallback-plugin.test.d.ts.map +0 -1
  2347. package/dist/file/unknown-file-fallback-plugin.test.js +0 -305
  2348. package/dist/file/unknown-file-fallback-plugin.test.js.map +0 -1
  2349. package/dist/file/validate-file-path.d.ts +0 -16
  2350. package/dist/file/validate-file-path.d.ts.map +0 -1
  2351. package/dist/file/validate-file-path.js +0 -44
  2352. package/dist/file/validate-file-path.js.map +0 -1
  2353. package/dist/file/validate-file-path.test.d.ts +0 -2
  2354. package/dist/file/validate-file-path.test.d.ts.map +0 -1
  2355. package/dist/file/validate-file-path.test.js +0 -36
  2356. package/dist/file/validate-file-path.test.js.map +0 -1
  2357. package/dist/file-queue/database-schema.d.ts +0 -17
  2358. package/dist/file-queue/database-schema.d.ts.map +0 -1
  2359. package/dist/file-queue/database-schema.js +0 -53
  2360. package/dist/file-queue/database-schema.js.map +0 -1
  2361. package/dist/file-queue/file-handlers.d.ts +0 -24
  2362. package/dist/file-queue/file-handlers.d.ts.map +0 -1
  2363. package/dist/file-queue/file-handlers.js +0 -235
  2364. package/dist/file-queue/file-handlers.js.map +0 -1
  2365. package/dist/file-queue/file-queue-process.d.ts +0 -5
  2366. package/dist/file-queue/file-queue-process.d.ts.map +0 -1
  2367. package/dist/file-queue/file-queue-process.js +0 -100
  2368. package/dist/file-queue/file-queue-process.js.map +0 -1
  2369. package/dist/file-queue/file-queue-process.test.d.ts +0 -2
  2370. package/dist/file-queue/file-queue-process.test.d.ts.map +0 -1
  2371. package/dist/file-queue/file-queue-process.test.js +0 -462
  2372. package/dist/file-queue/file-queue-process.test.js.map +0 -1
  2373. package/dist/file-queue/file-queue-settled.d.ts +0 -13
  2374. package/dist/file-queue/file-queue-settled.d.ts.map +0 -1
  2375. package/dist/file-queue/file-queue-settled.js +0 -25
  2376. package/dist/file-queue/file-queue-settled.js.map +0 -1
  2377. package/dist/file-queue/file-queue-settled.test.d.ts +0 -2
  2378. package/dist/file-queue/file-queue-settled.test.d.ts.map +0 -1
  2379. package/dist/file-queue/file-queue-settled.test.js +0 -47
  2380. package/dist/file-queue/file-queue-settled.test.js.map +0 -1
  2381. package/dist/file-queue/index.d.ts +0 -2
  2382. package/dist/file-queue/index.d.ts.map +0 -1
  2383. package/dist/file-queue/index.js +0 -2
  2384. package/dist/file-queue/index.js.map +0 -1
  2385. package/dist/file-queue/with-skip-file-queue.d.ts +0 -21
  2386. package/dist/file-queue/with-skip-file-queue.d.ts.map +0 -1
  2387. package/dist/file-queue/with-skip-file-queue.js +0 -72
  2388. package/dist/file-queue/with-skip-file-queue.js.map +0 -1
  2389. package/dist/file-queue/with-skip-file-queue.test.d.ts +0 -2
  2390. package/dist/file-queue/with-skip-file-queue.test.d.ts.map +0 -1
  2391. package/dist/file-queue/with-skip-file-queue.test.js +0 -154
  2392. package/dist/file-queue/with-skip-file-queue.test.js.map +0 -1
  2393. package/dist/key-value/database-schema.d.ts +0 -43
  2394. package/dist/key-value/database-schema.d.ts.map +0 -1
  2395. package/dist/key-value/database-schema.js +0 -21
  2396. package/dist/key-value/database-schema.js.map +0 -1
  2397. package/dist/key-value/database-schema.test.d.ts +0 -2
  2398. package/dist/key-value/database-schema.test.d.ts.map +0 -1
  2399. package/dist/key-value/database-schema.test.js +0 -123
  2400. package/dist/key-value/database-schema.test.js.map +0 -1
  2401. package/dist/key-value/schema.d.ts +0 -81
  2402. package/dist/key-value/schema.d.ts.map +0 -1
  2403. package/dist/key-value/schema.js +0 -31
  2404. package/dist/key-value/schema.js.map +0 -1
  2405. package/dist/key-value-v2/schema.d.ts +0 -27
  2406. package/dist/key-value-v2/schema.d.ts.map +0 -1
  2407. package/dist/key-value-v2/schema.js +0 -73
  2408. package/dist/key-value-v2/schema.js.map +0 -1
  2409. package/dist/key-value-v2/schema.test.d.ts.map +0 -1
  2410. package/dist/key-value-v2/schema.test.js +0 -144
  2411. package/dist/key-value-v2/schema.test.js.map +0 -1
  2412. package/dist/label/schema.d.ts +0 -22
  2413. package/dist/label/schema.d.ts.map +0 -1
  2414. package/dist/label/schema.js +0 -26
  2415. package/dist/label/schema.js.map +0 -1
  2416. package/dist/lix/close-lix.d.ts +0 -8
  2417. package/dist/lix/close-lix.d.ts.map +0 -1
  2418. package/dist/lix/close-lix.js +0 -7
  2419. package/dist/lix/close-lix.js.map +0 -1
  2420. package/dist/lix/merge.d.ts +0 -9
  2421. package/dist/lix/merge.d.ts.map +0 -1
  2422. package/dist/lix/merge.get-leaf-changes-only-in-source.d.ts +0 -15
  2423. package/dist/lix/merge.get-leaf-changes-only-in-source.d.ts.map +0 -1
  2424. package/dist/lix/merge.get-leaf-changes-only-in-source.js +0 -34
  2425. package/dist/lix/merge.get-leaf-changes-only-in-source.js.map +0 -1
  2426. package/dist/lix/merge.get-leaf-changes-only-in-source.test.d.ts +0 -2
  2427. package/dist/lix/merge.get-leaf-changes-only-in-source.test.d.ts.map +0 -1
  2428. package/dist/lix/merge.get-leaf-changes-only-in-source.test.js +0 -121
  2429. package/dist/lix/merge.get-leaf-changes-only-in-source.test.js.map +0 -1
  2430. package/dist/lix/merge.js +0 -195
  2431. package/dist/lix/merge.js.map +0 -1
  2432. package/dist/lix/merge.test.d.ts +0 -2
  2433. package/dist/lix/merge.test.d.ts.map +0 -1
  2434. package/dist/lix/merge.test.js +0 -692
  2435. package/dist/lix/merge.test.js.map +0 -1
  2436. package/dist/lix/open-lix-in-memory.d.ts +0 -12
  2437. package/dist/lix/open-lix-in-memory.d.ts.map +0 -1
  2438. package/dist/lix/open-lix-in-memory.js +0 -19
  2439. package/dist/lix/open-lix-in-memory.js.map +0 -1
  2440. package/dist/lix/open-lix-in-memory.test.d.ts +0 -2
  2441. package/dist/lix/open-lix-in-memory.test.d.ts.map +0 -1
  2442. package/dist/lix/open-lix-in-memory.test.js +0 -25
  2443. package/dist/lix/open-lix-in-memory.test.js.map +0 -1
  2444. package/dist/lix/storage/in-memory.d.ts +0 -35
  2445. package/dist/lix/storage/in-memory.d.ts.map +0 -1
  2446. package/dist/lix/storage/in-memory.js +0 -50
  2447. package/dist/lix/storage/in-memory.js.map +0 -1
  2448. package/dist/lix/storage/in-memory.test.d.ts.map +0 -1
  2449. package/dist/lix/storage/in-memory.test.js +0 -85
  2450. package/dist/lix/storage/in-memory.test.js.map +0 -1
  2451. package/dist/lix/storage/lix-storage-adapter.d.ts +0 -46
  2452. package/dist/lix/storage/lix-storage-adapter.d.ts.map +0 -1
  2453. package/dist/lix/storage/lix-storage-adapter.js +0 -2
  2454. package/dist/lix/storage/lix-storage-adapter.js.map +0 -1
  2455. package/dist/lix/storage/opfs.d.ts +0 -95
  2456. package/dist/lix/storage/opfs.d.ts.map +0 -1
  2457. package/dist/lix/storage/opfs.js +0 -263
  2458. package/dist/lix/storage/opfs.js.map +0 -1
  2459. package/dist/lix/storage/opfs.test.d.ts +0 -2
  2460. package/dist/lix/storage/opfs.test.d.ts.map +0 -1
  2461. package/dist/lix/storage/opfs.test.js +0 -350
  2462. package/dist/lix/storage/opfs.test.js.map +0 -1
  2463. package/dist/lix/to-blob.d.ts +0 -11
  2464. package/dist/lix/to-blob.d.ts.map +0 -1
  2465. package/dist/lix/to-blob.js +0 -11
  2466. package/dist/lix/to-blob.js.map +0 -1
  2467. package/dist/log/database-schema.d.ts +0 -33
  2468. package/dist/log/database-schema.d.ts.map +0 -1
  2469. package/dist/log/database-schema.js +0 -14
  2470. package/dist/log/database-schema.js.map +0 -1
  2471. package/dist/log/database-schema.test.d.ts +0 -2
  2472. package/dist/log/database-schema.test.d.ts.map +0 -1
  2473. package/dist/log/database-schema.test.js +0 -22
  2474. package/dist/log/database-schema.test.js.map +0 -1
  2475. package/dist/log/schema.d.ts +0 -32
  2476. package/dist/log/schema.d.ts.map +0 -1
  2477. package/dist/log/schema.js +0 -42
  2478. package/dist/log/schema.js.map +0 -1
  2479. package/dist/own-change-control/apply-own-change.d.ts +0 -14
  2480. package/dist/own-change-control/apply-own-change.d.ts.map +0 -1
  2481. package/dist/own-change-control/apply-own-change.js +0 -83
  2482. package/dist/own-change-control/apply-own-change.js.map +0 -1
  2483. package/dist/own-change-control/apply-own-change.test.d.ts +0 -2
  2484. package/dist/own-change-control/apply-own-change.test.d.ts.map +0 -1
  2485. package/dist/own-change-control/apply-own-change.test.js +0 -335
  2486. package/dist/own-change-control/apply-own-change.test.js.map +0 -1
  2487. package/dist/own-change-control/change-controlled-tables.d.ts +0 -58
  2488. package/dist/own-change-control/change-controlled-tables.d.ts.map +0 -1
  2489. package/dist/own-change-control/change-controlled-tables.js +0 -76
  2490. package/dist/own-change-control/change-controlled-tables.js.map +0 -1
  2491. package/dist/own-change-control/change-controlled-tables.test.d.ts +0 -2
  2492. package/dist/own-change-control/change-controlled-tables.test.d.ts.map +0 -1
  2493. package/dist/own-change-control/change-controlled-tables.test.js +0 -78
  2494. package/dist/own-change-control/change-controlled-tables.test.js.map +0 -1
  2495. package/dist/own-change-control/database-triggers.d.ts +0 -6
  2496. package/dist/own-change-control/database-triggers.d.ts.map +0 -1
  2497. package/dist/own-change-control/database-triggers.js +0 -277
  2498. package/dist/own-change-control/database-triggers.js.map +0 -1
  2499. package/dist/own-change-control/database-triggers.test.d.ts +0 -2
  2500. package/dist/own-change-control/database-triggers.test.d.ts.map +0 -1
  2501. package/dist/own-change-control/database-triggers.test.js +0 -345
  2502. package/dist/own-change-control/database-triggers.test.js.map +0 -1
  2503. package/dist/own-change-control/index.d.ts +0 -2
  2504. package/dist/own-change-control/index.d.ts.map +0 -1
  2505. package/dist/own-change-control/index.js +0 -2
  2506. package/dist/own-change-control/index.js.map +0 -1
  2507. package/dist/own-change-control/with-skip-own-change-control.d.ts +0 -3
  2508. package/dist/own-change-control/with-skip-own-change-control.d.ts.map +0 -1
  2509. package/dist/own-change-control/with-skip-own-change-control.js +0 -50
  2510. package/dist/own-change-control/with-skip-own-change-control.js.map +0 -1
  2511. package/dist/own-change-control/with-skip-own-change-control.test.d.ts +0 -2
  2512. package/dist/own-change-control/with-skip-own-change-control.test.d.ts.map +0 -1
  2513. package/dist/own-change-control/with-skip-own-change-control.test.js +0 -86
  2514. package/dist/own-change-control/with-skip-own-change-control.test.js.map +0 -1
  2515. package/dist/plugin/load-plugin.d.ts +0 -5
  2516. package/dist/plugin/load-plugin.d.ts.map +0 -1
  2517. package/dist/plugin/load-plugin.js +0 -27
  2518. package/dist/plugin/load-plugin.js.map +0 -1
  2519. package/dist/plugin/with-transaction.d.ts +0 -11
  2520. package/dist/plugin/with-transaction.d.ts.map +0 -1
  2521. package/dist/plugin/with-transaction.js +0 -15
  2522. package/dist/plugin/with-transaction.js.map +0 -1
  2523. package/dist/prototype/database-schema.d.ts +0 -43
  2524. package/dist/prototype/database-schema.d.ts.map +0 -1
  2525. package/dist/prototype/database-schema.js +0 -72
  2526. package/dist/prototype/database-schema.js.map +0 -1
  2527. package/dist/prototype/file-handlers.d.ts +0 -24
  2528. package/dist/prototype/file-handlers.d.ts.map +0 -1
  2529. package/dist/prototype/file-handlers.js +0 -129
  2530. package/dist/prototype/file-handlers.js.map +0 -1
  2531. package/dist/prototype/file-schema.d.ts +0 -47
  2532. package/dist/prototype/file-schema.d.ts.map +0 -1
  2533. package/dist/prototype/file-schema.js +0 -135
  2534. package/dist/prototype/file-schema.js.map +0 -1
  2535. package/dist/prototype/file-schema.test.d.ts +0 -2
  2536. package/dist/prototype/file-schema.test.d.ts.map +0 -1
  2537. package/dist/prototype/file-schema.test.js +0 -146
  2538. package/dist/prototype/file-schema.test.js.map +0 -1
  2539. package/dist/prototype/get-and-materialize-row.d.ts +0 -5
  2540. package/dist/prototype/get-and-materialize-row.d.ts.map +0 -1
  2541. package/dist/prototype/get-and-materialize-row.js +0 -99
  2542. package/dist/prototype/get-and-materialize-row.js.map +0 -1
  2543. package/dist/prototype/json-plugin.d.ts +0 -49
  2544. package/dist/prototype/json-plugin.d.ts.map +0 -1
  2545. package/dist/prototype/json-plugin.js +0 -104
  2546. package/dist/prototype/json-plugin.js.map +0 -1
  2547. package/dist/prototype/validate-file-path.d.ts +0 -16
  2548. package/dist/prototype/validate-file-path.d.ts.map +0 -1
  2549. package/dist/prototype/validate-file-path.js +0 -44
  2550. package/dist/prototype/validate-file-path.js.map +0 -1
  2551. package/dist/prototype/validate-file-path.test.d.ts +0 -2
  2552. package/dist/prototype/validate-file-path.test.d.ts.map +0 -1
  2553. package/dist/prototype/validate-file-path.test.js +0 -36
  2554. package/dist/prototype/validate-file-path.test.js.map +0 -1
  2555. package/dist/prototype/version-schema.d.ts +0 -34
  2556. package/dist/prototype/version-schema.d.ts.map +0 -1
  2557. package/dist/prototype/version-schema.js +0 -86
  2558. package/dist/prototype/version-schema.js.map +0 -1
  2559. package/dist/prototype/version-schema.test.d.ts +0 -2
  2560. package/dist/prototype/version-schema.test.d.ts.map +0 -1
  2561. package/dist/prototype/version-schema.test.js +0 -114
  2562. package/dist/prototype/version-schema.test.js.map +0 -1
  2563. package/dist/query-filter/change-conflict-in-version.d.ts +0 -17
  2564. package/dist/query-filter/change-conflict-in-version.d.ts.map +0 -1
  2565. package/dist/query-filter/change-conflict-in-version.js +0 -20
  2566. package/dist/query-filter/change-conflict-in-version.js.map +0 -1
  2567. package/dist/query-filter/change-conflict-in-version.test.d.ts +0 -2
  2568. package/dist/query-filter/change-conflict-in-version.test.d.ts.map +0 -1
  2569. package/dist/query-filter/change-conflict-in-version.test.js +0 -55
  2570. package/dist/query-filter/change-conflict-in-version.test.js.map +0 -1
  2571. package/dist/query-filter/change-has-label.d.ts +0 -31
  2572. package/dist/query-filter/change-has-label.d.ts.map +0 -1
  2573. package/dist/query-filter/change-has-label.js +0 -33
  2574. package/dist/query-filter/change-has-label.js.map +0 -1
  2575. package/dist/query-filter/change-has-label.test.d.ts +0 -2
  2576. package/dist/query-filter/change-has-label.test.d.ts.map +0 -1
  2577. package/dist/query-filter/change-has-label.test.js +0 -71
  2578. package/dist/query-filter/change-has-label.test.js.map +0 -1
  2579. package/dist/query-filter/change-in-version.d.ts +0 -18
  2580. package/dist/query-filter/change-in-version.d.ts.map +0 -1
  2581. package/dist/query-filter/change-in-version.js +0 -31
  2582. package/dist/query-filter/change-in-version.js.map +0 -1
  2583. package/dist/query-filter/change-in-version.test.d.ts +0 -2
  2584. package/dist/query-filter/change-in-version.test.d.ts.map +0 -1
  2585. package/dist/query-filter/change-in-version.test.js +0 -75
  2586. package/dist/query-filter/change-in-version.test.js.map +0 -1
  2587. package/dist/query-filter/change-is-leaf-in-version.d.ts +0 -17
  2588. package/dist/query-filter/change-is-leaf-in-version.d.ts.map +0 -1
  2589. package/dist/query-filter/change-is-leaf-in-version.js +0 -36
  2590. package/dist/query-filter/change-is-leaf-in-version.js.map +0 -1
  2591. package/dist/query-filter/change-is-leaf-in-version.test.d.ts +0 -2
  2592. package/dist/query-filter/change-is-leaf-in-version.test.d.ts.map +0 -1
  2593. package/dist/query-filter/change-is-leaf-in-version.test.js +0 -70
  2594. package/dist/query-filter/change-is-leaf-in-version.test.js.map +0 -1
  2595. package/dist/query-filter/change-is-leaf-of.bench.d.ts +0 -2
  2596. package/dist/query-filter/change-is-leaf-of.bench.d.ts.map +0 -1
  2597. package/dist/query-filter/change-is-leaf-of.bench.js +0 -132
  2598. package/dist/query-filter/change-is-leaf-of.bench.js.map +0 -1
  2599. package/dist/query-filter/change-is-leaf-of.d.ts +0 -31
  2600. package/dist/query-filter/change-is-leaf-of.d.ts.map +0 -1
  2601. package/dist/query-filter/change-is-leaf-of.js +0 -46
  2602. package/dist/query-filter/change-is-leaf-of.js.map +0 -1
  2603. package/dist/query-filter/change-is-leaf-of.test.d.ts +0 -2
  2604. package/dist/query-filter/change-is-leaf-of.test.d.ts.map +0 -1
  2605. package/dist/query-filter/change-is-leaf-of.test.js +0 -71
  2606. package/dist/query-filter/change-is-leaf-of.test.js.map +0 -1
  2607. package/dist/query-filter/change-is-leaf-v2.d.ts +0 -69
  2608. package/dist/query-filter/change-is-leaf-v2.d.ts.map +0 -1
  2609. package/dist/query-filter/change-is-leaf-v2.js +0 -116
  2610. package/dist/query-filter/change-is-leaf-v2.js.map +0 -1
  2611. package/dist/query-filter/change-is-leaf-v2.test.d.ts +0 -2
  2612. package/dist/query-filter/change-is-leaf-v2.test.d.ts.map +0 -1
  2613. package/dist/query-filter/change-is-leaf-v2.test.js +0 -237
  2614. package/dist/query-filter/change-is-leaf-v2.test.js.map +0 -1
  2615. package/dist/query-filter/change-is-leaf.d.ts +0 -20
  2616. package/dist/query-filter/change-is-leaf.d.ts.map +0 -1
  2617. package/dist/query-filter/change-is-leaf.js +0 -20
  2618. package/dist/query-filter/change-is-leaf.js.map +0 -1
  2619. package/dist/query-filter/change-is-leaf.test.d.ts +0 -2
  2620. package/dist/query-filter/change-is-leaf.test.d.ts.map +0 -1
  2621. package/dist/query-filter/change-is-leaf.test.js +0 -122
  2622. package/dist/query-filter/change-is-leaf.test.js.map +0 -1
  2623. package/dist/query-filter/change-is-lowest-common-ancestor-of.d.ts +0 -18
  2624. package/dist/query-filter/change-is-lowest-common-ancestor-of.d.ts.map +0 -1
  2625. package/dist/query-filter/change-is-lowest-common-ancestor-of.js +0 -59
  2626. package/dist/query-filter/change-is-lowest-common-ancestor-of.js.map +0 -1
  2627. package/dist/query-filter/change-is-lowest-common-ancestor-of.test.d.ts +0 -2
  2628. package/dist/query-filter/change-is-lowest-common-ancestor-of.test.d.ts.map +0 -1
  2629. package/dist/query-filter/change-is-lowest-common-ancestor-of.test.js +0 -157
  2630. package/dist/query-filter/change-is-lowest-common-ancestor-of.test.js.map +0 -1
  2631. package/dist/query-filter/change-set-element-in-ancestry-of.d.ts +0 -30
  2632. package/dist/query-filter/change-set-element-in-ancestry-of.d.ts.map +0 -1
  2633. package/dist/query-filter/change-set-element-in-ancestry-of.js +0 -51
  2634. package/dist/query-filter/change-set-element-in-ancestry-of.js.map +0 -1
  2635. package/dist/query-filter/change-set-element-in-ancestry-of.test.d.ts +0 -2
  2636. package/dist/query-filter/change-set-element-in-ancestry-of.test.d.ts.map +0 -1
  2637. package/dist/query-filter/change-set-element-in-ancestry-of.test.js +0 -396
  2638. package/dist/query-filter/change-set-element-in-ancestry-of.test.js.map +0 -1
  2639. package/dist/query-filter/change-set-element-in-symmetric-difference-of.d.ts +0 -21
  2640. package/dist/query-filter/change-set-element-in-symmetric-difference-of.d.ts.map +0 -1
  2641. package/dist/query-filter/change-set-element-in-symmetric-difference-of.js +0 -37
  2642. package/dist/query-filter/change-set-element-in-symmetric-difference-of.js.map +0 -1
  2643. package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.d.ts +0 -2
  2644. package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.d.ts.map +0 -1
  2645. package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.js +0 -276
  2646. package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.js.map +0 -1
  2647. package/dist/query-filter/change-set-element-in-symmetric-difference.d.ts +0 -20
  2648. package/dist/query-filter/change-set-element-in-symmetric-difference.d.ts.map +0 -1
  2649. package/dist/query-filter/change-set-element-in-symmetric-difference.js +0 -36
  2650. package/dist/query-filter/change-set-element-in-symmetric-difference.js.map +0 -1
  2651. package/dist/query-filter/change-set-element-in-symmetric-difference.test.d.ts +0 -2
  2652. package/dist/query-filter/change-set-element-in-symmetric-difference.test.d.ts.map +0 -1
  2653. package/dist/query-filter/change-set-element-in-symmetric-difference.test.js +0 -369
  2654. package/dist/query-filter/change-set-element-in-symmetric-difference.test.js.map +0 -1
  2655. package/dist/query-filter/change-set-element-is-leaf-of.d.ts +0 -29
  2656. package/dist/query-filter/change-set-element-is-leaf-of.d.ts.map +0 -1
  2657. package/dist/query-filter/change-set-element-is-leaf-of.js +0 -113
  2658. package/dist/query-filter/change-set-element-is-leaf-of.js.map +0 -1
  2659. package/dist/query-filter/change-set-element-is-leaf-of.test.d.ts +0 -2
  2660. package/dist/query-filter/change-set-element-is-leaf-of.test.d.ts.map +0 -1
  2661. package/dist/query-filter/change-set-element-is-leaf-of.test.js +0 -574
  2662. package/dist/query-filter/change-set-element-is-leaf-of.test.js.map +0 -1
  2663. package/dist/query-filter/change-set-has-label.d.ts +0 -41
  2664. package/dist/query-filter/change-set-has-label.d.ts.map +0 -1
  2665. package/dist/query-filter/change-set-has-label.js +0 -42
  2666. package/dist/query-filter/change-set-has-label.js.map +0 -1
  2667. package/dist/query-filter/change-set-has-label.test.d.ts +0 -2
  2668. package/dist/query-filter/change-set-has-label.test.d.ts.map +0 -1
  2669. package/dist/query-filter/change-set-has-label.test.js +0 -36
  2670. package/dist/query-filter/change-set-has-label.test.js.map +0 -1
  2671. package/dist/query-filter/change-set-is-ancestor-of.d.ts +0 -51
  2672. package/dist/query-filter/change-set-is-ancestor-of.d.ts.map +0 -1
  2673. package/dist/query-filter/change-set-is-ancestor-of.js +0 -63
  2674. package/dist/query-filter/change-set-is-ancestor-of.js.map +0 -1
  2675. package/dist/query-filter/change-set-is-ancestor-of.test.d.ts +0 -2
  2676. package/dist/query-filter/change-set-is-ancestor-of.test.d.ts.map +0 -1
  2677. package/dist/query-filter/change-set-is-ancestor-of.test.js +0 -153
  2678. package/dist/query-filter/change-set-is-ancestor-of.test.js.map +0 -1
  2679. package/dist/query-filter/change-set-is-descendant-of.d.ts +0 -44
  2680. package/dist/query-filter/change-set-is-descendant-of.d.ts.map +0 -1
  2681. package/dist/query-filter/change-set-is-descendant-of.js +0 -56
  2682. package/dist/query-filter/change-set-is-descendant-of.js.map +0 -1
  2683. package/dist/query-filter/change-set-is-descendant-of.test.d.ts +0 -2
  2684. package/dist/query-filter/change-set-is-descendant-of.test.d.ts.map +0 -1
  2685. package/dist/query-filter/change-set-is-descendant-of.test.js +0 -137
  2686. package/dist/query-filter/change-set-is-descendant-of.test.js.map +0 -1
  2687. package/dist/query-filter/version-change-in-difference.d.ts +0 -20
  2688. package/dist/query-filter/version-change-in-difference.d.ts.map +0 -1
  2689. package/dist/query-filter/version-change-in-difference.js +0 -27
  2690. package/dist/query-filter/version-change-in-difference.js.map +0 -1
  2691. package/dist/query-filter/version-change-in-difference.test.d.ts +0 -2
  2692. package/dist/query-filter/version-change-in-difference.test.d.ts.map +0 -1
  2693. package/dist/query-filter/version-change-in-difference.test.js +0 -85
  2694. package/dist/query-filter/version-change-in-difference.test.js.map +0 -1
  2695. package/dist/query-filter/version-change-in-symmetric-difference.d.ts +0 -21
  2696. package/dist/query-filter/version-change-in-symmetric-difference.d.ts.map +0 -1
  2697. package/dist/query-filter/version-change-in-symmetric-difference.js +0 -38
  2698. package/dist/query-filter/version-change-in-symmetric-difference.js.map +0 -1
  2699. package/dist/query-filter/version-change-in-symmetric-difference.test.d.ts +0 -2
  2700. package/dist/query-filter/version-change-in-symmetric-difference.test.d.ts.map +0 -1
  2701. package/dist/query-filter/version-change-in-symmetric-difference.test.js +0 -84
  2702. package/dist/query-filter/version-change-in-symmetric-difference.test.js.map +0 -1
  2703. package/dist/snapshot/create-snapshot.d.ts +0 -7
  2704. package/dist/snapshot/create-snapshot.d.ts.map +0 -1
  2705. package/dist/snapshot/create-snapshot.js +0 -28
  2706. package/dist/snapshot/create-snapshot.js.map +0 -1
  2707. package/dist/snapshot/create-snapshot.test.d.ts +0 -2
  2708. package/dist/snapshot/create-snapshot.test.d.ts.map +0 -1
  2709. package/dist/snapshot/create-snapshot.test.js +0 -83
  2710. package/dist/snapshot/create-snapshot.test.js.map +0 -1
  2711. package/dist/snapshot/database-schema.d.ts +0 -19
  2712. package/dist/snapshot/database-schema.d.ts.map +0 -1
  2713. package/dist/snapshot/database-schema.js +0 -33
  2714. package/dist/snapshot/database-schema.js.map +0 -1
  2715. package/dist/snapshot/database-schema.test.d.ts +0 -2
  2716. package/dist/snapshot/database-schema.test.d.ts.map +0 -1
  2717. package/dist/snapshot/database-schema.test.js +0 -58
  2718. package/dist/snapshot/database-schema.test.js.map +0 -1
  2719. package/dist/snapshot/index.d.ts +0 -4
  2720. package/dist/snapshot/index.d.ts.map +0 -1
  2721. package/dist/snapshot/index.js +0 -4
  2722. package/dist/snapshot/index.js.map +0 -1
  2723. package/dist/snapshot/json-sha-256.d.ts +0 -9
  2724. package/dist/snapshot/json-sha-256.d.ts.map +0 -1
  2725. package/dist/snapshot/json-sha-256.js +0 -27
  2726. package/dist/snapshot/json-sha-256.js.map +0 -1
  2727. package/dist/snapshot/json-sha-256.test.d.ts +0 -2
  2728. package/dist/snapshot/json-sha-256.test.d.ts.map +0 -1
  2729. package/dist/snapshot/json-sha-256.test.js +0 -48
  2730. package/dist/snapshot/json-sha-256.test.js.map +0 -1
  2731. package/dist/snapshot/mock-json-snapshot.d.ts +0 -8
  2732. package/dist/snapshot/mock-json-snapshot.d.ts.map +0 -1
  2733. package/dist/snapshot/mock-json-snapshot.js +0 -13
  2734. package/dist/snapshot/mock-json-snapshot.js.map +0 -1
  2735. package/dist/state/commit.d.ts +0 -18
  2736. package/dist/state/commit.d.ts.map +0 -1
  2737. package/dist/state/commit.js +0 -457
  2738. package/dist/state/commit.js.map +0 -1
  2739. package/dist/state/commit.test.d.ts.map +0 -1
  2740. package/dist/state/commit.test.js +0 -1173
  2741. package/dist/state/commit.test.js.map +0 -1
  2742. package/dist/state/create-changeset-for-transaction.d.ts +0 -15
  2743. package/dist/state/create-changeset-for-transaction.d.ts.map +0 -1
  2744. package/dist/state/create-changeset-for-transaction.js +0 -237
  2745. package/dist/state/create-changeset-for-transaction.js.map +0 -1
  2746. package/dist/state/get-version-record-by-id-or-throw.d.ts +0 -6
  2747. package/dist/state/get-version-record-by-id-or-throw.d.ts.map +0 -1
  2748. package/dist/state/get-version-record-by-id-or-throw.js +0 -36
  2749. package/dist/state/get-version-record-by-id-or-throw.js.map +0 -1
  2750. package/dist/state/handle-state-mutation.d.ts +0 -6
  2751. package/dist/state/handle-state-mutation.d.ts.map +0 -1
  2752. package/dist/state/handle-state-mutation.js +0 -157
  2753. package/dist/state/handle-state-mutation.js.map +0 -1
  2754. package/dist/state/handle-state-mutation.test.d.ts +0 -2
  2755. package/dist/state/handle-state-mutation.test.d.ts.map +0 -1
  2756. package/dist/state/handle-state-mutation.test.js +0 -686
  2757. package/dist/state/handle-state-mutation.test.js.map +0 -1
  2758. package/dist/state/insert-transaction-state.d.ts +0 -71
  2759. package/dist/state/insert-transaction-state.d.ts.map +0 -1
  2760. package/dist/state/insert-transaction-state.js +0 -272
  2761. package/dist/state/insert-transaction-state.js.map +0 -1
  2762. package/dist/state/insert-transaction-state.test.d.ts.map +0 -1
  2763. package/dist/state/insert-transaction-state.test.js +0 -789
  2764. package/dist/state/insert-transaction-state.test.js.map +0 -1
  2765. package/dist/state/primary-key.d.ts +0 -39
  2766. package/dist/state/primary-key.d.ts.map +0 -1
  2767. package/dist/state/primary-key.js +0 -62
  2768. package/dist/state/primary-key.js.map +0 -1
  2769. package/dist/state/primary-key.test.d.ts.map +0 -1
  2770. package/dist/state/primary-key.test.js +0 -114
  2771. package/dist/state/primary-key.test.js.map +0 -1
  2772. package/dist/state/resolved-state-view.d.ts +0 -33
  2773. package/dist/state/resolved-state-view.d.ts.map +0 -1
  2774. package/dist/state/resolved-state-view.js +0 -182
  2775. package/dist/state/resolved-state-view.js.map +0 -1
  2776. package/dist/state/resolved-state-view.test.d.ts +0 -2
  2777. package/dist/state/resolved-state-view.test.d.ts.map +0 -1
  2778. package/dist/state/resolved-state-view.test.js +0 -433
  2779. package/dist/state/resolved-state-view.test.js.map +0 -1
  2780. package/dist/state/schema.test.d.ts.map +0 -1
  2781. package/dist/state/schema.test.js +0 -2701
  2782. package/dist/state/schema.test.js.map +0 -1
  2783. package/dist/state/validate-snapshot-content.d.ts +0 -9
  2784. package/dist/state/validate-snapshot-content.d.ts.map +0 -1
  2785. package/dist/state/validate-snapshot-content.js +0 -42
  2786. package/dist/state/validate-snapshot-content.js.map +0 -1
  2787. package/dist/state/validate-snapshot-content.test.d.ts +0 -2
  2788. package/dist/state/validate-snapshot-content.test.d.ts.map +0 -1
  2789. package/dist/state/validate-snapshot-content.test.js +0 -67
  2790. package/dist/state/validate-snapshot-content.test.js.map +0 -1
  2791. package/dist/state/validate-state-mutation.d.ts +0 -13
  2792. package/dist/state/validate-state-mutation.d.ts.map +0 -1
  2793. package/dist/state/validate-state-mutation.js +0 -645
  2794. package/dist/state/validate-state-mutation.js.map +0 -1
  2795. package/dist/state/validate-state-mutation.test.d.ts.map +0 -1
  2796. package/dist/state/validate-state-mutation.test.js +0 -2859
  2797. package/dist/state/validate-state-mutation.test.js.map +0 -1
  2798. package/dist/stored-schema/schema.d.ts +0 -25
  2799. package/dist/stored-schema/schema.d.ts.map +0 -1
  2800. package/dist/stored-schema/schema.js +0 -48
  2801. package/dist/stored-schema/schema.js.map +0 -1
  2802. package/dist/thread/comment-utils.d.ts +0 -2
  2803. package/dist/thread/comment-utils.d.ts.map +0 -1
  2804. package/dist/thread/comment-utils.js +0 -2
  2805. package/dist/thread/comment-utils.js.map +0 -1
  2806. package/dist/thread/comment.d.ts +0 -24
  2807. package/dist/thread/comment.d.ts.map +0 -1
  2808. package/dist/thread/comment.js +0 -43
  2809. package/dist/thread/comment.js.map +0 -1
  2810. package/dist/thread/create-thread-comment.d.ts +0 -18
  2811. package/dist/thread/create-thread-comment.d.ts.map +0 -1
  2812. package/dist/thread/create-thread-comment.js +0 -64
  2813. package/dist/thread/create-thread-comment.js.map +0 -1
  2814. package/dist/thread/create-thread-comment.test.d.ts +0 -2
  2815. package/dist/thread/create-thread-comment.test.d.ts.map +0 -1
  2816. package/dist/thread/create-thread-comment.test.js +0 -97
  2817. package/dist/thread/create-thread-comment.test.js.map +0 -1
  2818. package/dist/thread/create-thread.d.ts +0 -42
  2819. package/dist/thread/create-thread.d.ts.map +0 -1
  2820. package/dist/thread/create-thread.js +0 -79
  2821. package/dist/thread/create-thread.js.map +0 -1
  2822. package/dist/thread/create-thread.test.d.ts +0 -2
  2823. package/dist/thread/create-thread.test.d.ts.map +0 -1
  2824. package/dist/thread/create-thread.test.js +0 -175
  2825. package/dist/thread/create-thread.test.js.map +0 -1
  2826. package/dist/thread/database-schema.d.ts +0 -20
  2827. package/dist/thread/database-schema.d.ts.map +0 -1
  2828. package/dist/thread/database-schema.js +0 -57
  2829. package/dist/thread/database-schema.js.map +0 -1
  2830. package/dist/thread/database-schema.test.d.ts +0 -2
  2831. package/dist/thread/database-schema.test.d.ts.map +0 -1
  2832. package/dist/thread/database-schema.test.js +0 -59
  2833. package/dist/thread/database-schema.test.js.map +0 -1
  2834. package/dist/thread/index.d.ts +0 -5
  2835. package/dist/thread/index.d.ts.map +0 -1
  2836. package/dist/thread/index.js +0 -4
  2837. package/dist/thread/index.js.map +0 -1
  2838. package/dist/thread/schema.d.ts +0 -62
  2839. package/dist/thread/schema.d.ts.map +0 -1
  2840. package/dist/thread/schema.js +0 -72
  2841. package/dist/thread/schema.js.map +0 -1
  2842. package/dist/thread/schema.test.d.ts.map +0 -1
  2843. package/dist/thread/schema.test.js +0 -125
  2844. package/dist/thread/schema.test.js.map +0 -1
  2845. package/dist/version/database-schema.d.ts +0 -21
  2846. package/dist/version/database-schema.d.ts.map +0 -1
  2847. package/dist/version/database-schema.js +0 -169
  2848. package/dist/version/database-schema.js.map +0 -1
  2849. package/dist/version/database-schema.test.d.ts +0 -2
  2850. package/dist/version/database-schema.test.d.ts.map +0 -1
  2851. package/dist/version/database-schema.test.js +0 -625
  2852. package/dist/version/database-schema.test.js.map +0 -1
  2853. package/dist/version/update-changes-in-version.d.ts +0 -15
  2854. package/dist/version/update-changes-in-version.d.ts.map +0 -1
  2855. package/dist/version/update-changes-in-version.js +0 -38
  2856. package/dist/version/update-changes-in-version.js.map +0 -1
  2857. package/dist/version/update-changes-in-version.test.d.ts +0 -2
  2858. package/dist/version/update-changes-in-version.test.d.ts.map +0 -1
  2859. package/dist/version/update-changes-in-version.test.js +0 -323
  2860. package/dist/version/update-changes-in-version.test.js.map +0 -1
  2861. package/dist/version-v2/create-version.d.ts +0 -18
  2862. package/dist/version-v2/create-version.d.ts.map +0 -1
  2863. package/dist/version-v2/create-version.js +0 -35
  2864. package/dist/version-v2/create-version.js.map +0 -1
  2865. package/dist/version-v2/create-version.test.d.ts +0 -2
  2866. package/dist/version-v2/create-version.test.d.ts.map +0 -1
  2867. package/dist/version-v2/create-version.test.js +0 -88
  2868. package/dist/version-v2/create-version.test.js.map +0 -1
  2869. package/dist/version-v2/database-schema.d.ts +0 -21
  2870. package/dist/version-v2/database-schema.d.ts.map +0 -1
  2871. package/dist/version-v2/database-schema.js +0 -169
  2872. package/dist/version-v2/database-schema.js.map +0 -1
  2873. package/dist/version-v2/database-schema.test.d.ts +0 -2
  2874. package/dist/version-v2/database-schema.test.d.ts.map +0 -1
  2875. package/dist/version-v2/database-schema.test.js +0 -625
  2876. package/dist/version-v2/database-schema.test.js.map +0 -1
  2877. package/dist/version-v2/index.d.ts +0 -2
  2878. package/dist/version-v2/index.d.ts.map +0 -1
  2879. package/dist/version-v2/index.js +0 -2
  2880. package/dist/version-v2/index.js.map +0 -1
  2881. package/dist/version-v2/swich-version.d.ts +0 -27
  2882. package/dist/version-v2/swich-version.d.ts.map +0 -1
  2883. package/dist/version-v2/swich-version.js +0 -46
  2884. package/dist/version-v2/swich-version.js.map +0 -1
  2885. package/dist/version-v2/switch-version.d.ts +0 -27
  2886. package/dist/version-v2/switch-version.d.ts.map +0 -1
  2887. package/dist/version-v2/switch-version.js +0 -91
  2888. package/dist/version-v2/switch-version.js.map +0 -1
  2889. package/dist/version-v2/switch-version.test.d.ts +0 -2
  2890. package/dist/version-v2/switch-version.test.d.ts.map +0 -1
  2891. package/dist/version-v2/switch-version.test.js +0 -110
  2892. package/dist/version-v2/switch-version.test.js.map +0 -1
  2893. package/dist/version-v2/with-skip-update-working-change-set.d.ts +0 -3
  2894. package/dist/version-v2/with-skip-update-working-change-set.d.ts.map +0 -1
  2895. package/dist/version-v2/with-skip-update-working-change-set.js +0 -50
  2896. package/dist/version-v2/with-skip-update-working-change-set.js.map +0 -1
  2897. package/dist/version-v2/with-skip-update-working-change-set.test.d.ts +0 -2
  2898. package/dist/version-v2/with-skip-update-working-change-set.test.d.ts.map +0 -1
  2899. package/dist/version-v2/with-skip-update-working-change-set.test.js +0 -49
  2900. package/dist/version-v2/with-skip-update-working-change-set.test.js.map +0 -1
  2901. package/dist/zettel-ast/index.d.ts.map +0 -1
  2902. package/dist/zettel-ast/index.js.map +0 -1
  2903. package/src/account/schema.ts +0 -132
  2904. package/src/change-author/schema.ts +0 -54
  2905. package/src/change-proposal/database-schema.test.ts +0 -180
  2906. package/src/change-proposal/database-schema.ts +0 -32
  2907. package/src/change-set/schema.ts +0 -150
  2908. package/src/commit/apply-commit.test.ts +0 -426
  2909. package/src/commit/apply-commit.ts +0 -74
  2910. package/src/commit/create-checkpoint.test.ts +0 -605
  2911. package/src/commit/create-checkpoint.ts +0 -140
  2912. package/src/commit/create-commit.ts +0 -80
  2913. package/src/commit/create-merge-commit.test.ts +0 -268
  2914. package/src/commit/create-merge-commit.ts +0 -138
  2915. package/src/commit/create-transition-commit.test.ts +0 -256
  2916. package/src/commit/create-transition-commit.ts +0 -187
  2917. package/src/commit/create-undo-commit.test.ts +0 -358
  2918. package/src/commit/create-undo-commit.ts +0 -180
  2919. package/src/commit/schema.ts +0 -104
  2920. package/src/database/execute-sync.test.ts +0 -140
  2921. package/src/database/execute-sync.ts +0 -46
  2922. package/src/database/kysely-plugin/json-column-plugin.test.ts +0 -404
  2923. package/src/database/kysely-plugin/json-column-plugin.ts +0 -280
  2924. package/src/database/kysely-plugin/parse-jsonb-plugin-v1.test.ts +0 -204
  2925. package/src/database/kysely-plugin/parse-jsonb-plugin-v1.ts +0 -50
  2926. package/src/database/kysely-plugin/parse-jsonb-plugin-v2.no_test.ts +0 -204
  2927. package/src/database/kysely-plugin/parse-jsonb-plugin-v2.ts +0 -194
  2928. package/src/database/kysely-plugin/serialize-jsonb-plugin.test.ts +0 -307
  2929. package/src/database/kysely-plugin/serialize-jsonb-plugin.ts +0 -221
  2930. package/src/database/kysely-plugin/view-insert-returning-error-plugin.test.ts +0 -62
  2931. package/src/deterministic/generate-human-id.test.ts +0 -154
  2932. package/src/deterministic/generate-human-id.ts +0 -94
  2933. package/src/deterministic/index.ts +0 -7
  2934. package/src/deterministic/is-deterministic-mode.test.ts +0 -133
  2935. package/src/deterministic/is-deterministic-mode.ts +0 -32
  2936. package/src/deterministic/nano-id.test.ts +0 -200
  2937. package/src/deterministic/nano-id.ts +0 -188
  2938. package/src/deterministic/options.test.ts +0 -157
  2939. package/src/deterministic/options.ts +0 -62
  2940. package/src/deterministic/random.test.ts +0 -293
  2941. package/src/deterministic/random.ts +0 -261
  2942. package/src/deterministic/sequence.test.ts +0 -93
  2943. package/src/deterministic/sequence.ts +0 -132
  2944. package/src/deterministic/timestamp.test.ts +0 -170
  2945. package/src/deterministic/timestamp.ts +0 -83
  2946. package/src/deterministic/uuid-v7.test.ts +0 -144
  2947. package/src/deterministic/uuid-v7.ts +0 -82
  2948. package/src/entity/label/create-entity-label.test.ts +0 -316
  2949. package/src/entity/label/create-entity-label.ts +0 -113
  2950. package/src/entity/label/schema.ts +0 -55
  2951. package/src/entity/schema.ts +0 -22
  2952. package/src/entity/thread/create-entity-thread.test.ts +0 -282
  2953. package/src/entity/thread/create-entity-thread.ts +0 -134
  2954. package/src/entity/thread/query-threads.test.ts +0 -394
  2955. package/src/entity/thread/schema.test.ts +0 -170
  2956. package/src/entity/thread/schema.ts +0 -55
  2957. package/src/entity-views/README.md +0 -214
  2958. package/src/entity-views/entity-state-all.test.ts +0 -647
  2959. package/src/entity-views/entity-state-all.ts +0 -575
  2960. package/src/entity-views/entity-state-history.test.ts +0 -387
  2961. package/src/entity-views/entity-state-history.ts +0 -275
  2962. package/src/entity-views/entity-state.test.ts +0 -732
  2963. package/src/entity-views/entity-state.ts +0 -571
  2964. package/src/entity-views/entity-view-builder.test.ts +0 -293
  2965. package/src/entity-views/entity-view-builder.ts +0 -148
  2966. package/src/entity-views/types.test.ts +0 -99
  2967. package/src/entity-views/types.ts +0 -328
  2968. package/src/file/file-handlers.test.ts +0 -174
  2969. package/src/file/file-handlers.ts +0 -404
  2970. package/src/file/index.ts +0 -5
  2971. package/src/file/materialize-file-data-at-commit.ts +0 -157
  2972. package/src/file/materialize-file-data.test.ts +0 -107
  2973. package/src/file/materialize-file-data.ts +0 -120
  2974. package/src/file/schema.test.ts +0 -1646
  2975. package/src/file/schema.ts +0 -427
  2976. package/src/file/store-detected-change-schema.test.ts +0 -248
  2977. package/src/file/store-detected-change-schema.ts +0 -52
  2978. package/src/file/unknown-file-fallback-plugin.test.ts +0 -368
  2979. package/src/file/unknown-file-fallback-plugin.ts +0 -95
  2980. package/src/key-value/schema.ts +0 -98
  2981. package/src/label/schema.ts +0 -37
  2982. package/src/lix/storage/in-memory.test.ts +0 -106
  2983. package/src/lix/storage/in-memory.ts +0 -64
  2984. package/src/lix/storage/lix-storage-adapter.ts +0 -52
  2985. package/src/lix/storage/opfs.test.ts +0 -438
  2986. package/src/lix/storage/opfs.ts +0 -313
  2987. package/src/log/schema.ts +0 -51
  2988. package/src/query-filter/change-set-element-in-ancestry-of.test.ts +0 -440
  2989. package/src/query-filter/change-set-element-in-ancestry-of.ts +0 -69
  2990. package/src/query-filter/change-set-element-in-symmetric-difference.test.ts +0 -410
  2991. package/src/query-filter/change-set-element-in-symmetric-difference.ts +0 -53
  2992. package/src/query-filter/change-set-element-is-leaf-of.test.ts +0 -623
  2993. package/src/query-filter/change-set-element-is-leaf-of.ts +0 -132
  2994. package/src/state/commit.test.ts +0 -1402
  2995. package/src/state/commit.ts +0 -587
  2996. package/src/state/insert-transaction-state.test.ts +0 -928
  2997. package/src/state/insert-transaction-state.ts +0 -306
  2998. package/src/state/primary-key.test.ts +0 -158
  2999. package/src/state/primary-key.ts +0 -80
  3000. package/src/state/resolved-state-view.test.ts +0 -521
  3001. package/src/state/resolved-state-view.ts +0 -202
  3002. package/src/state/schema.test.ts +0 -3260
  3003. package/src/state/validate-state-mutation.test.ts +0 -3308
  3004. package/src/state/validate-state-mutation.ts +0 -866
  3005. package/src/stored-schema/schema.ts +0 -67
  3006. package/src/thread/create-thread-comment.test.ts +0 -122
  3007. package/src/thread/create-thread-comment.ts +0 -84
  3008. package/src/thread/create-thread.test.ts +0 -212
  3009. package/src/thread/create-thread.ts +0 -108
  3010. package/src/thread/index.ts +0 -9
  3011. package/src/thread/schema.test.ts +0 -157
  3012. package/src/thread/schema.ts +0 -90
  3013. /package/dist/{change-set-v2 → change-proposal}/schema.test.d.ts +0 -0
  3014. /package/dist/database/{kysely-plugin → kysely/plugins}/json-column-plugin.d.ts +0 -0
  3015. /package/dist/database/{kysely-plugin → kysely/plugins}/json-column-plugin.test.d.ts +0 -0
  3016. /package/dist/database/{kysely-plugin → kysely/plugins}/view-insert-returning-error-plugin.d.ts +0 -0
  3017. /package/dist/database/{kysely-plugin → kysely/plugins}/view-insert-returning-error-plugin.js +0 -0
  3018. /package/dist/database/{kysely-plugin → kysely/plugins}/view-insert-returning-error-plugin.test.d.ts +0 -0
  3019. /package/dist/{zettel-ast → dependency/zettel-ast}/index.d.ts +0 -0
  3020. /package/dist/{zettel-ast → dependency/zettel-ast}/index.js +0 -0
  3021. /package/dist/{deterministic → engine/deterministic-mode}/is-deterministic-mode.test.d.ts +0 -0
  3022. /package/dist/{deterministic → engine/deterministic-mode}/options.test.d.ts +0 -0
  3023. /package/dist/{entity-views → engine/entity-views}/index.d.ts +0 -0
  3024. /package/dist/{entity-views → engine/entity-views}/index.js +0 -0
  3025. /package/dist/{change-schema → engine/entity-views}/types.js +0 -0
  3026. /package/dist/{entity-views → engine/entity-views}/types.test.d.ts +0 -0
  3027. /package/dist/{database → engine}/execute-sync.test.d.ts +0 -0
  3028. /package/dist/{deterministic → engine/functions}/generate-human-id.test.d.ts +0 -0
  3029. /package/dist/{deterministic → engine/functions}/nano-id.test.d.ts +0 -0
  3030. /package/dist/{deterministic → engine/functions}/random.test.d.ts +0 -0
  3031. /package/dist/{deterministic → engine/functions}/sequence.test.d.ts +0 -0
  3032. /package/dist/{deterministic → engine/functions}/timestamp.test.d.ts +0 -0
  3033. /package/dist/{deterministic → engine/functions}/uuid-v7.test.d.ts +0 -0
  3034. /package/dist/{entity-views → engine/preprocessor}/types.js +0 -0
  3035. /package/dist/entity/{thread → conversation}/schema.test.d.ts +0 -0
  3036. /package/dist/{lix/storage → environment}/in-memory.test.d.ts +0 -0
  3037. /package/dist/{file → filesystem/directory}/schema.test.d.ts +0 -0
  3038. /package/dist/{key-value-v2 → filesystem/file/cache}/schema.test.d.ts +0 -0
  3039. /package/dist/{file → filesystem/file}/file-handlers.test.d.ts +0 -0
  3040. /package/dist/{file → filesystem/file}/materialize-file-data.test.d.ts +0 -0
  3041. /package/dist/{state → filesystem/file}/schema.test.d.ts +0 -0
  3042. /package/dist/{file → filesystem/file}/store-detected-change-schema.test.d.ts +0 -0
  3043. /package/dist/{file → filesystem/file}/unknown-file-fallback-plugin.test.d.ts +0 -0
  3044. /package/dist/{thread → filesystem}/schema.test.d.ts +0 -0
  3045. /package/dist/{change-set-v2 → state}/create-checkpoint.test.d.ts +0 -0
  3046. /package/dist/state/{insert-transaction-state.test.d.ts → transaction/insert-transaction-state.test.d.ts} +0 -0
  3047. /package/dist/state/{commit.test.d.ts → vtable/commit.test.d.ts} +0 -0
  3048. /package/dist/state/{primary-key.test.d.ts → vtable/primary-key.test.d.ts} +0 -0
  3049. /package/dist/state/{validate-state-mutation.test.d.ts → vtable/validate-state-mutation.test.d.ts} +0 -0
  3050. /package/src/database/{kysely-plugin → kysely/plugins}/view-insert-returning-error-plugin.ts +0 -0
  3051. /package/src/{zettel-ast → dependency/zettel-ast}/index.ts +0 -0
  3052. /package/src/{entity-views → engine/entity-views}/index.ts +0 -0
@@ -1,3308 +0,0 @@
1
- import { test, expect } from "vitest";
2
- import { openLix } from "../lix/open-lix.js";
3
- import { validateStateMutation } from "./validate-state-mutation.js";
4
- import type { LixSchemaDefinition } from "../schema-definition/definition.js";
5
- import { Kysely, sql } from "kysely";
6
- import { createVersion } from "../version/create-version.js";
7
- import type { LixChangeSetElement } from "../change-set/schema.js";
8
- import type { LixInternalDatabaseSchema } from "../database/schema.js";
9
-
10
- test("throws if the schema is not a valid lix schema", async () => {
11
- const lix = await openLix({});
12
-
13
- const schema = {
14
- type: "object",
15
- "x-lix-version": "1.0",
16
- properties: {
17
- name: { type: "string" },
18
- },
19
- required: ["name"],
20
- additionalProperties: false,
21
- // @ts-expect-error - x-version is missing
22
- } as const satisfies LixSchemaDefinition;
23
-
24
- const activeVersion = await lix.db
25
- .selectFrom("active_version")
26
- .select("version_id")
27
- .executeTakeFirstOrThrow();
28
-
29
- expect(() =>
30
- validateStateMutation({
31
- lix,
32
- // @ts-expect-error - x-key is missing
33
- schema,
34
- snapshot_content: {},
35
- operation: "insert",
36
- version_id: activeVersion.version_id,
37
- })
38
- ).toThrowError();
39
- });
40
-
41
- test("inserts the version and active version schemas to enable validation", async () => {
42
- const lix = await openLix({});
43
-
44
- const result = await lix.db
45
- .selectFrom("stored_schema")
46
- .where("key", "in", ["lix_version", "lix_active_version"])
47
- .selectAll()
48
- .execute();
49
-
50
- expect(result.length).toBeGreaterThan(0);
51
- });
52
-
53
- test("valid lix schema with a valid snapshot passes", async () => {
54
- const lix = await openLix({});
55
-
56
- const schema = {
57
- type: "object",
58
- "x-lix-version": "1.0",
59
- "x-lix-key": "mock",
60
- properties: {
61
- name: { type: "string" },
62
- },
63
- required: ["name"],
64
- additionalProperties: false,
65
- } as const satisfies LixSchemaDefinition;
66
-
67
- const snapshot = {
68
- content: {
69
- name: "John",
70
- },
71
- };
72
-
73
- const activeVersion = await lix.db
74
- .selectFrom("active_version")
75
- .select("version_id")
76
- .executeTakeFirstOrThrow();
77
-
78
- expect(() =>
79
- validateStateMutation({
80
- lix,
81
- schema,
82
- snapshot_content: snapshot.content,
83
- operation: "insert",
84
- version_id: activeVersion.version_id,
85
- })
86
- ).not.toThrowError();
87
- });
88
-
89
- test("an invalid snapshot fails", async () => {
90
- const lix = await openLix({});
91
-
92
- const schema = {
93
- type: "object",
94
- "x-lix-version": "1.0",
95
- "x-lix-key": "mock",
96
- properties: {
97
- name: { type: "string" },
98
- },
99
- required: ["name"],
100
- additionalProperties: false,
101
- } as const satisfies LixSchemaDefinition;
102
-
103
- const snapshot = {
104
- content: {
105
- foo: "John",
106
- },
107
- };
108
-
109
- const activeVersion = await lix.db
110
- .selectFrom("active_version")
111
- .select("version_id")
112
- .executeTakeFirstOrThrow();
113
-
114
- expect(() =>
115
- validateStateMutation({
116
- lix,
117
- schema,
118
- snapshot_content: snapshot.content,
119
- operation: "insert",
120
- version_id: activeVersion.version_id,
121
- })
122
- ).toThrowError();
123
- });
124
-
125
- test("passes when primary key is unique", async () => {
126
- const lix = await openLix({});
127
-
128
- const schema = {
129
- type: "object",
130
- "x-lix-version": "1.0",
131
- "x-lix-key": "user",
132
- "x-lix-primary-key": ["id"],
133
- properties: {
134
- id: { type: "string" },
135
- name: { type: "string" },
136
- },
137
- required: ["id", "name"],
138
- additionalProperties: false,
139
- } as const satisfies LixSchemaDefinition;
140
-
141
- const snapshot = {
142
- content: {
143
- id: "user1",
144
- name: "John",
145
- },
146
- };
147
-
148
- const activeVersion = await lix.db
149
- .selectFrom("active_version")
150
- .select("version_id")
151
- .executeTakeFirstOrThrow();
152
-
153
- expect(() =>
154
- validateStateMutation({
155
- lix,
156
- schema,
157
- snapshot_content: snapshot.content,
158
- operation: "insert",
159
- version_id: activeVersion.version_id,
160
- })
161
- ).not.toThrowError();
162
- });
163
-
164
- test("throws when primary key violates uniqueness constraint", async () => {
165
- const lix = await openLix({});
166
-
167
- const schema = {
168
- type: "object",
169
- "x-lix-version": "1.0",
170
- "x-lix-key": "user",
171
- "x-lix-primary-key": ["id"],
172
- properties: {
173
- id: { type: "string" },
174
- name: { type: "string" },
175
- },
176
- required: ["id", "name"],
177
- additionalProperties: false,
178
- } as const satisfies LixSchemaDefinition;
179
-
180
- // Store the schema first
181
- await lix.db.insertInto("stored_schema").values({ value: schema }).execute();
182
-
183
- // Insert first user into state
184
- await lix.db
185
- .insertInto("state_all")
186
- .values({
187
- entity_id: "user1",
188
- file_id: "file1",
189
- schema_key: "user",
190
- plugin_key: "test_plugin",
191
- version_id: lix.db.selectFrom("active_version").select("version_id"),
192
- snapshot_content: { id: "user1", name: "John" },
193
- schema_version: "1.0",
194
- })
195
- .execute();
196
-
197
- // Try to insert another user with same primary key
198
- const duplicateSnapshot = {
199
- content: {
200
- id: "user1",
201
- name: "Jane",
202
- },
203
- };
204
-
205
- const activeVersion = await lix.db
206
- .selectFrom("active_version")
207
- .select("version_id")
208
- .executeTakeFirstOrThrow();
209
-
210
- expect(() =>
211
- validateStateMutation({
212
- lix,
213
- schema,
214
- snapshot_content: duplicateSnapshot.content,
215
- operation: "insert",
216
- version_id: activeVersion.version_id,
217
- })
218
- ).toThrowError("Primary key constraint violation");
219
- });
220
-
221
- test("handles composite primary keys", async () => {
222
- const lix = await openLix({});
223
-
224
- const schema = {
225
- type: "object",
226
- "x-lix-version": "1.0",
227
- "x-lix-key": "user_role",
228
- "x-lix-primary-key": ["user_id", "role_id"],
229
- properties: {
230
- user_id: { type: "string" },
231
- role_id: { type: "string" },
232
- assigned_date: { type: "string" },
233
- },
234
- required: ["user_id", "role_id", "assigned_date"],
235
- additionalProperties: false,
236
- } as const satisfies LixSchemaDefinition;
237
-
238
- // Store the schema first
239
- await lix.db.insertInto("stored_schema").values({ value: schema }).execute();
240
-
241
- // Insert first user-role into state
242
- await lix.db
243
- .insertInto("state_all")
244
- .values({
245
- entity_id: "user_role1",
246
- file_id: "file1",
247
- schema_key: "user_role",
248
- plugin_key: "test_plugin",
249
- version_id: lix.db.selectFrom("active_version").select("version_id"),
250
- snapshot_content: {
251
- user_id: "user1",
252
- role_id: "admin",
253
- assigned_date: "2024-01-01",
254
- },
255
- schema_version: "1.0",
256
- })
257
- .execute();
258
-
259
- const activeVersion = await lix.db
260
- .selectFrom("active_version")
261
- .select("version_id")
262
- .executeTakeFirstOrThrow();
263
-
264
- // This should pass (different composite key)
265
- expect(() =>
266
- validateStateMutation({
267
- lix,
268
- schema,
269
- snapshot_content: {
270
- user_id: "user1",
271
- role_id: "editor",
272
- assigned_date: "2024-01-02",
273
- },
274
- operation: "insert",
275
- version_id: activeVersion.version_id,
276
- })
277
- ).not.toThrowError();
278
-
279
- // This should fail (same composite key)
280
- expect(() =>
281
- validateStateMutation({
282
- lix,
283
- schema,
284
- snapshot_content: {
285
- user_id: "user1",
286
- role_id: "admin",
287
- assigned_date: "2024-01-03",
288
- },
289
- operation: "insert",
290
- version_id: activeVersion.version_id,
291
- })
292
- ).toThrowError("Primary key constraint violation");
293
- });
294
-
295
- test("passes when unique constraint is satisfied", async () => {
296
- const lix = await openLix({});
297
-
298
- const activeVersion = await lix.db
299
- .selectFrom("active_version")
300
- .select("version_id")
301
- .executeTakeFirstOrThrow();
302
-
303
- const schema = {
304
- type: "object",
305
- "x-lix-version": "1.0",
306
- "x-lix-key": "user",
307
- "x-lix-primary-key": ["id"],
308
- "x-lix-unique": [["email"], ["username"]],
309
- properties: {
310
- id: { type: "string" },
311
- email: { type: "string" },
312
- username: { type: "string" },
313
- name: { type: "string" },
314
- },
315
- required: ["id", "email", "username", "name"],
316
- additionalProperties: false,
317
- } as const satisfies LixSchemaDefinition;
318
-
319
- const snapshot = {
320
- content: {
321
- id: "user1",
322
- email: "john@example.com",
323
- username: "john_doe",
324
- name: "John Doe",
325
- },
326
- };
327
-
328
- expect(() =>
329
- validateStateMutation({
330
- lix,
331
- schema,
332
- snapshot_content: snapshot.content,
333
- version_id: activeVersion.version_id,
334
- operation: "insert",
335
- })
336
- ).not.toThrowError();
337
- });
338
-
339
- test("throws when single field unique constraint is violated", async () => {
340
- const lix = await openLix({});
341
-
342
- const schema = {
343
- type: "object",
344
- "x-lix-version": "1.0",
345
- "x-lix-key": "user",
346
- "x-lix-primary-key": ["id"],
347
- "x-lix-unique": [["email"], ["username"]],
348
- properties: {
349
- id: { type: "string" },
350
- email: { type: "string" },
351
- username: { type: "string" },
352
- name: { type: "string" },
353
- },
354
- required: ["id", "email", "username", "name"],
355
- additionalProperties: false,
356
- } as const satisfies LixSchemaDefinition;
357
-
358
- // Store the schema first
359
- await lix.db.insertInto("stored_schema").values({ value: schema }).execute();
360
-
361
- // Insert first user into state
362
- await lix.db
363
- .insertInto("state_all")
364
- .values({
365
- entity_id: "user1",
366
- file_id: "file1",
367
- schema_key: "user",
368
- plugin_key: "test_plugin",
369
- version_id: lix.db.selectFrom("active_version").select("version_id"),
370
- snapshot_content: {
371
- id: "user1",
372
- email: "john@example.com",
373
- username: "john_doe",
374
- name: "John Doe",
375
- },
376
- schema_version: "1.0",
377
- })
378
- .execute();
379
-
380
- // Try to insert another user with same email (unique constraint violation)
381
- const duplicateEmailSnapshot = {
382
- content: {
383
- id: "user2",
384
- email: "john@example.com", // Same email
385
- username: "jane_doe",
386
- name: "Jane Doe",
387
- },
388
- };
389
-
390
- const activeVersion = await lix.db
391
- .selectFrom("active_version")
392
- .select("version_id")
393
- .executeTakeFirstOrThrow();
394
-
395
- expect(() =>
396
- validateStateMutation({
397
- lix,
398
- schema,
399
- snapshot_content: duplicateEmailSnapshot.content,
400
- operation: "insert",
401
- version_id: activeVersion.version_id,
402
- })
403
- ).toThrowError("Unique constraint violation");
404
-
405
- // Try to insert another user with same username (unique constraint violation)
406
- const duplicateUsernameSnapshot = {
407
- content: {
408
- id: "user3",
409
- email: "jane@example.com",
410
- username: "john_doe", // Same username
411
- name: "Jane Smith",
412
- },
413
- };
414
-
415
- expect(() =>
416
- validateStateMutation({
417
- lix,
418
- schema,
419
- snapshot_content: duplicateUsernameSnapshot.content,
420
- operation: "insert",
421
- version_id: activeVersion.version_id,
422
- })
423
- ).toThrowError("Unique constraint violation");
424
- });
425
-
426
- test("handles composite unique constraints", async () => {
427
- const lix = await openLix({});
428
-
429
- const schema = {
430
- type: "object",
431
- "x-lix-version": "1.0",
432
- "x-lix-key": "product",
433
- "x-lix-primary-key": ["id"],
434
- "x-lix-unique": [
435
- ["category", "name"], // Composite unique constraint
436
- ["sku"], // Single field unique constraint
437
- ],
438
- properties: {
439
- id: { type: "string" },
440
- category: { type: "string" },
441
- name: { type: "string" },
442
- sku: { type: "string" },
443
- price: { type: "number" },
444
- },
445
- required: ["id", "category", "name", "sku", "price"],
446
- additionalProperties: false,
447
- } as const satisfies LixSchemaDefinition;
448
-
449
- // Store the schema first
450
- await lix.db.insertInto("stored_schema").values({ value: schema }).execute();
451
-
452
- // Insert first product into state
453
- await lix.db
454
- .insertInto("state_all")
455
- .values({
456
- entity_id: "product1",
457
- file_id: "file1",
458
- schema_key: "product",
459
- plugin_key: "test_plugin",
460
- version_id: lix.db.selectFrom("active_version").select("version_id"),
461
- snapshot_content: {
462
- id: "product1",
463
- category: "electronics",
464
- name: "Laptop",
465
- sku: "ELEC-LAP-001",
466
- price: 999.99,
467
- },
468
- schema_version: "1.0",
469
- })
470
- .execute();
471
-
472
- const activeVersion = await lix.db
473
- .selectFrom("active_version")
474
- .select("version_id")
475
- .executeTakeFirstOrThrow();
476
-
477
- // This should pass (different composite unique key)
478
- expect(() =>
479
- validateStateMutation({
480
- lix,
481
- schema,
482
- snapshot_content: {
483
- id: "product2",
484
- category: "electronics",
485
- name: "Desktop", // Different name in same category
486
- sku: "ELEC-DES-001",
487
- price: 1299.99,
488
- },
489
- operation: "insert",
490
- version_id: activeVersion.version_id,
491
- })
492
- ).not.toThrowError();
493
-
494
- // This should pass (same name in different category)
495
- expect(() =>
496
- validateStateMutation({
497
- lix,
498
- schema,
499
- snapshot_content: {
500
- id: "product3",
501
- category: "furniture", // Different category
502
- name: "Laptop", // Same name but different category
503
- sku: "FURN-LAP-001",
504
- price: 599.99,
505
- },
506
- operation: "insert",
507
- version_id: activeVersion.version_id,
508
- })
509
- ).not.toThrowError();
510
-
511
- // This should fail (same composite unique key: category + name)
512
- expect(() =>
513
- validateStateMutation({
514
- lix,
515
- schema,
516
- snapshot_content: {
517
- id: "product4",
518
- category: "electronics",
519
- name: "Laptop", // Same category + name combination
520
- sku: "ELEC-LAP-002",
521
- price: 899.99,
522
- },
523
- operation: "insert",
524
- version_id: activeVersion.version_id,
525
- })
526
- ).toThrowError("Unique constraint violation");
527
-
528
- // This should fail (same SKU)
529
- expect(() =>
530
- validateStateMutation({
531
- lix,
532
- schema,
533
- snapshot_content: {
534
- id: "product5",
535
- category: "accessories",
536
- name: "Mouse",
537
- sku: "ELEC-LAP-001", // Same SKU
538
- price: 29.99,
539
- },
540
- operation: "insert",
541
- version_id: activeVersion.version_id,
542
- })
543
- ).toThrowError("Unique constraint violation");
544
- });
545
-
546
- test("passes when foreign key references exist", async () => {
547
- const lix = await openLix({});
548
-
549
- const userSchema = {
550
- type: "object",
551
- "x-lix-version": "1.0",
552
- "x-lix-key": "user",
553
- "x-lix-primary-key": ["id"],
554
- properties: {
555
- id: { type: "string" },
556
- name: { type: "string" },
557
- },
558
- required: ["id", "name"],
559
- additionalProperties: false,
560
- } as const satisfies LixSchemaDefinition;
561
-
562
- const postSchema = {
563
- type: "object",
564
- "x-lix-version": "1.0",
565
- "x-lix-key": "post",
566
- "x-lix-primary-key": ["id"],
567
- "x-lix-foreign-keys": [
568
- {
569
- properties: ["author_id"],
570
- references: {
571
- schemaKey: "user",
572
- properties: ["id"],
573
- },
574
- },
575
- ],
576
- properties: {
577
- id: { type: "string" },
578
- author_id: { type: "string" },
579
- title: { type: "string" },
580
- },
581
- required: ["id", "author_id", "title"],
582
- additionalProperties: false,
583
- } as const satisfies LixSchemaDefinition;
584
-
585
- // Store schemas
586
- await lix.db
587
- .insertInto("stored_schema")
588
- .values([{ value: userSchema }, { value: postSchema }])
589
- .execute();
590
-
591
- // Insert a user that will be referenced
592
- await lix.db
593
- .insertInto("state_all")
594
- .values({
595
- entity_id: "user1",
596
- file_id: "file1",
597
- schema_key: "user",
598
- plugin_key: "test_plugin",
599
- version_id: lix.db.selectFrom("active_version").select("version_id"),
600
- snapshot_content: {
601
- id: "user1",
602
- name: "John Doe",
603
- },
604
- schema_version: "1.0",
605
- })
606
- .execute();
607
-
608
- const activeVersion = await lix.db
609
- .selectFrom("active_version")
610
- .select("version_id")
611
- .executeTakeFirstOrThrow();
612
-
613
- // This should pass - foreign key reference exists
614
- expect(() =>
615
- validateStateMutation({
616
- lix,
617
- schema: postSchema,
618
- snapshot_content: {
619
- id: "post1",
620
- author_id: "user1",
621
- title: "My First Post",
622
- },
623
- operation: "insert",
624
- version_id: activeVersion.version_id,
625
- })
626
- ).not.toThrowError();
627
- });
628
-
629
- test("throws when foreign key reference does not exist", async () => {
630
- const lix = await openLix({});
631
-
632
- const userSchema = {
633
- type: "object",
634
- "x-lix-version": "1.0",
635
- "x-lix-key": "user",
636
- "x-lix-primary-key": ["id"],
637
- properties: {
638
- id: { type: "string" },
639
- name: { type: "string" },
640
- },
641
- required: ["id", "name"],
642
- additionalProperties: false,
643
- } as const satisfies LixSchemaDefinition;
644
-
645
- const postSchema = {
646
- type: "object",
647
- "x-lix-version": "1.0",
648
- "x-lix-key": "post",
649
- "x-lix-primary-key": ["id"],
650
- "x-lix-foreign-keys": [
651
- {
652
- properties: ["author_id"],
653
- references: {
654
- schemaKey: "user",
655
- properties: ["id"],
656
- },
657
- },
658
- ],
659
- properties: {
660
- id: { type: "string" },
661
- author_id: { type: "string" },
662
- title: { type: "string" },
663
- },
664
- required: ["id", "author_id", "title"],
665
- additionalProperties: false,
666
- } as const satisfies LixSchemaDefinition;
667
-
668
- // Store schemas
669
- await lix.db
670
- .insertInto("stored_schema")
671
- .values([{ value: userSchema }, { value: postSchema }])
672
- .execute();
673
-
674
- const activeVersion = await lix.db
675
- .selectFrom("active_version")
676
- .select("version_id")
677
- .executeTakeFirstOrThrow();
678
-
679
- // This should fail - foreign key reference does not exist
680
- expect(() =>
681
- validateStateMutation({
682
- lix,
683
- schema: postSchema,
684
- snapshot_content: {
685
- id: "post1",
686
- author_id: "nonexistent_user",
687
- title: "My First Post",
688
- },
689
- operation: "insert",
690
- version_id: activeVersion.version_id,
691
- })
692
- ).toThrowError("Foreign key constraint violation");
693
- });
694
-
695
- test("handles multiple foreign keys", async () => {
696
- const lix = await openLix({});
697
-
698
- const userSchema = {
699
- type: "object",
700
- "x-lix-version": "1.0",
701
- "x-lix-key": "user",
702
- "x-lix-primary-key": ["id"],
703
- properties: {
704
- id: { type: "string" },
705
- name: { type: "string" },
706
- },
707
- required: ["id", "name"],
708
- additionalProperties: false,
709
- } as const satisfies LixSchemaDefinition;
710
-
711
- const categorySchema = {
712
- type: "object",
713
- "x-lix-version": "1.0",
714
- "x-lix-key": "category",
715
- "x-lix-primary-key": ["id"],
716
- properties: {
717
- id: { type: "string" },
718
- name: { type: "string" },
719
- },
720
- required: ["id", "name"],
721
- additionalProperties: false,
722
- } as const satisfies LixSchemaDefinition;
723
-
724
- const postSchema = {
725
- type: "object",
726
- "x-lix-version": "1.0",
727
- "x-lix-key": "post",
728
- "x-lix-primary-key": ["id"],
729
- "x-lix-foreign-keys": [
730
- {
731
- properties: ["author_id"],
732
- references: {
733
- schemaKey: "user",
734
- properties: ["id"],
735
- },
736
- },
737
- {
738
- properties: ["category_id"],
739
- references: {
740
- schemaKey: "category",
741
- properties: ["id"],
742
- },
743
- },
744
- ],
745
- properties: {
746
- id: { type: "string" },
747
- author_id: { type: "string" },
748
- category_id: { type: "string" },
749
- title: { type: "string" },
750
- },
751
- required: ["id", "author_id", "category_id", "title"],
752
- additionalProperties: false,
753
- } as const satisfies LixSchemaDefinition;
754
-
755
- // Store schemas
756
- await lix.db
757
- .insertInto("stored_schema")
758
- .values([
759
- { value: userSchema },
760
- { value: categorySchema },
761
- { value: postSchema },
762
- ])
763
- .execute();
764
-
765
- // Insert referenced entities
766
- await lix.db
767
- .insertInto("state_all")
768
- .values([
769
- {
770
- entity_id: "user1",
771
- file_id: "file1",
772
- schema_key: "user",
773
- plugin_key: "test_plugin",
774
- version_id: lix.db.selectFrom("active_version").select("version_id"),
775
- snapshot_content: {
776
- id: "user1",
777
- name: "John Doe",
778
- },
779
- schema_version: "1.0",
780
- },
781
- {
782
- entity_id: "category1",
783
- file_id: "file1",
784
- schema_key: "category",
785
- plugin_key: "test_plugin",
786
- version_id: lix.db.selectFrom("active_version").select("version_id"),
787
- snapshot_content: {
788
- id: "category1",
789
- name: "Technology",
790
- },
791
- schema_version: "1.0",
792
- },
793
- ])
794
- .execute();
795
-
796
- const activeVersion = await lix.db
797
- .selectFrom("active_version")
798
- .select("version_id")
799
- .executeTakeFirstOrThrow();
800
-
801
- // This should pass - all foreign key references exist
802
- expect(() =>
803
- validateStateMutation({
804
- lix,
805
- schema: postSchema,
806
- snapshot_content: {
807
- id: "post1",
808
- author_id: "user1",
809
- category_id: "category1",
810
- title: "My Tech Post",
811
- },
812
- operation: "insert",
813
- version_id: activeVersion.version_id,
814
- })
815
- ).not.toThrowError();
816
-
817
- // This should fail - category reference does not exist
818
- expect(() =>
819
- validateStateMutation({
820
- lix,
821
- schema: postSchema,
822
- snapshot_content: {
823
- id: "post2",
824
- author_id: "user1",
825
- category_id: "nonexistent_category",
826
- title: "Another Post",
827
- },
828
- operation: "insert",
829
- version_id: activeVersion.version_id,
830
- })
831
- ).toThrowError("Foreign key constraint violation");
832
- });
833
-
834
- test("allows null foreign key values", async () => {
835
- const lix = await openLix({});
836
-
837
- const userSchema = {
838
- type: "object",
839
- "x-lix-version": "1.0",
840
- "x-lix-key": "user",
841
- "x-lix-primary-key": ["id"],
842
- properties: {
843
- id: { type: "string" },
844
- name: { type: "string" },
845
- },
846
- required: ["id", "name"],
847
- additionalProperties: false,
848
- } as const satisfies LixSchemaDefinition;
849
-
850
- const postSchema = {
851
- type: "object",
852
- "x-lix-version": "1.0",
853
- "x-lix-key": "post",
854
- "x-lix-primary-key": ["id"],
855
- "x-lix-foreign-keys": [
856
- {
857
- properties: ["author_id"],
858
- references: {
859
- schemaKey: "user",
860
- properties: ["id"],
861
- },
862
- },
863
- ],
864
- properties: {
865
- id: { type: "string" },
866
- author_id: { type: ["string", "null"] },
867
- title: { type: "string" },
868
- },
869
- required: ["id", "title"],
870
- additionalProperties: false,
871
- } as const satisfies LixSchemaDefinition;
872
-
873
- // Store schemas
874
- await lix.db
875
- .insertInto("stored_schema")
876
- .values([{ value: userSchema }, { value: postSchema }])
877
- .execute();
878
-
879
- const activeVersion = await lix.db
880
- .selectFrom("active_version")
881
- .select("version_id")
882
- .executeTakeFirstOrThrow();
883
-
884
- // This should pass - null foreign key is allowed
885
- expect(() =>
886
- validateStateMutation({
887
- lix,
888
- schema: postSchema,
889
- snapshot_content: {
890
- id: "post1",
891
- author_id: null,
892
- title: "Anonymous Post",
893
- },
894
- operation: "insert",
895
- version_id: activeVersion.version_id,
896
- })
897
- ).not.toThrowError();
898
-
899
- // This should also pass - undefined foreign key (when not required)
900
- expect(() =>
901
- validateStateMutation({
902
- lix,
903
- schema: postSchema,
904
- snapshot_content: {
905
- id: "post2",
906
- title: "Another Anonymous Post",
907
- },
908
- operation: "insert",
909
- version_id: activeVersion.version_id,
910
- })
911
- ).not.toThrowError();
912
- });
913
-
914
- test("handles composite foreign keys", async () => {
915
- const lix = await openLix({});
916
-
917
- // Create a schema that uses composite primary key
918
- const addressSchema = {
919
- type: "object",
920
- "x-lix-version": "1.0",
921
- "x-lix-key": "address",
922
- "x-lix-primary-key": ["country", "postal_code", "street"],
923
- properties: {
924
- country: { type: "string" },
925
- postal_code: { type: "string" },
926
- street: { type: "string" },
927
- city: { type: "string" },
928
- },
929
- required: ["country", "postal_code", "street", "city"],
930
- additionalProperties: false,
931
- } as const satisfies LixSchemaDefinition;
932
-
933
- // Create a schema that references the composite key
934
- const deliverySchema = {
935
- type: "object",
936
- "x-lix-version": "1.0",
937
- "x-lix-key": "delivery",
938
- "x-lix-primary-key": ["id"],
939
- "x-lix-foreign-keys": [
940
- {
941
- properties: ["address_country", "address_postal", "address_street"],
942
- references: {
943
- schemaKey: "address",
944
- properties: ["country", "postal_code", "street"],
945
- },
946
- },
947
- ],
948
- properties: {
949
- id: { type: "string" },
950
- address_country: { type: "string" },
951
- address_postal: { type: "string" },
952
- address_street: { type: "string" },
953
- package_id: { type: "string" },
954
- },
955
- required: [
956
- "id",
957
- "address_country",
958
- "address_postal",
959
- "address_street",
960
- "package_id",
961
- ],
962
- additionalProperties: false,
963
- } as const satisfies LixSchemaDefinition;
964
-
965
- // Store schemas
966
- await lix.db
967
- .insertInto("stored_schema")
968
- .values([{ value: addressSchema }, { value: deliverySchema }])
969
- .execute();
970
-
971
- // Insert an address that will be referenced
972
- await lix.db
973
- .insertInto("state_all")
974
- .values({
975
- entity_id: "addr1",
976
- file_id: "file1",
977
- schema_key: "address",
978
- plugin_key: "test_plugin",
979
- version_id: lix.db.selectFrom("active_version").select("version_id"),
980
- snapshot_content: {
981
- country: "USA",
982
- postal_code: "12345",
983
- street: "123 Main St",
984
- city: "Springfield",
985
- },
986
- schema_version: "1.0",
987
- })
988
- .execute();
989
-
990
- const activeVersion = await lix.db
991
- .selectFrom("active_version")
992
- .select("version_id")
993
- .executeTakeFirstOrThrow();
994
-
995
- // This should pass - composite foreign key reference exists
996
- expect(() =>
997
- validateStateMutation({
998
- lix,
999
- schema: deliverySchema,
1000
- snapshot_content: {
1001
- id: "delivery1",
1002
- address_country: "USA",
1003
- address_postal: "12345",
1004
- address_street: "123 Main St",
1005
- package_id: "pkg123",
1006
- },
1007
- operation: "insert",
1008
- version_id: activeVersion.version_id,
1009
- })
1010
- ).not.toThrowError();
1011
-
1012
- // This should fail - composite foreign key reference doesn't exist (wrong postal code)
1013
- expect(() =>
1014
- validateStateMutation({
1015
- lix,
1016
- schema: deliverySchema,
1017
- snapshot_content: {
1018
- id: "delivery2",
1019
- address_country: "USA",
1020
- address_postal: "54321", // Wrong postal code
1021
- address_street: "123 Main St",
1022
- package_id: "pkg456",
1023
- },
1024
- operation: "insert",
1025
- version_id: activeVersion.version_id,
1026
- })
1027
- ).toThrowError(
1028
- /Foreign key constraint violation.*address_country, address_postal, address_street.*referencing.*address.*country, postal_code, street/
1029
- );
1030
- });
1031
-
1032
- test("foreign key referencing real SQL table (change.id)", async () => {
1033
- const lix = await openLix({});
1034
-
1035
- // Insert a real change record into the change table
1036
- await lix.db
1037
- // @ts-expect-error - internal_snapshot is not a public table
1038
- .insertInto("internal_snapshot")
1039
- .values({
1040
- id: "snap1",
1041
- content: sql`jsonb(${JSON.stringify({ id: "entity1" })})`,
1042
- })
1043
- .execute();
1044
-
1045
- await lix.db
1046
- // @ts-expect-error - internal_change is not a public table
1047
- .insertInto("internal_change")
1048
- .values({
1049
- id: "change1",
1050
- entity_id: "entity1",
1051
- plugin_key: "test_plugin",
1052
- schema_key: "test_schema",
1053
- schema_version: "1.0",
1054
- file_id: "file1",
1055
- snapshot_id: "snap1",
1056
- })
1057
- .execute();
1058
-
1059
- const changeSetElementSchema = {
1060
- type: "object",
1061
- "x-lix-version": "1.0",
1062
- "x-lix-key": "change_set_element_test",
1063
- "x-lix-foreign-keys": [
1064
- {
1065
- properties: ["change_id"],
1066
- references: {
1067
- schemaKey: "lix_change",
1068
- properties: ["id"],
1069
- },
1070
- },
1071
- ],
1072
- properties: {
1073
- id: { type: "string" },
1074
- change_id: { type: "string" },
1075
- },
1076
- required: ["id", "change_id"],
1077
- additionalProperties: false,
1078
- } as const satisfies LixSchemaDefinition;
1079
-
1080
- const activeVersion = await lix.db
1081
- .selectFrom("active_version")
1082
- .select("version_id")
1083
- .executeTakeFirstOrThrow();
1084
-
1085
- // This should pass - foreign key references existing change record
1086
- expect(() =>
1087
- validateStateMutation({
1088
- lix,
1089
- schema: changeSetElementSchema,
1090
- snapshot_content: {
1091
- id: "element1",
1092
- change_id: "change1",
1093
- },
1094
- operation: "insert",
1095
- version_id: activeVersion.version_id,
1096
- })
1097
- ).not.toThrowError();
1098
-
1099
- // This should fail - foreign key references non-existent change
1100
- expect(() =>
1101
- validateStateMutation({
1102
- lix,
1103
- schema: changeSetElementSchema,
1104
- snapshot_content: {
1105
- id: "element2",
1106
- change_id: "nonexistent_change",
1107
- },
1108
- operation: "insert",
1109
- version_id: activeVersion.version_id,
1110
- })
1111
- ).toThrowError("Foreign key constraint violation");
1112
- });
1113
-
1114
- test("allows updates with same primary key", async () => {
1115
- const lix = await openLix({});
1116
-
1117
- const activeVersion = await lix.db
1118
- .selectFrom("active_version")
1119
- .select("version_id")
1120
- .executeTakeFirstOrThrow();
1121
-
1122
- const schema = {
1123
- type: "object",
1124
- "x-lix-version": "1.0",
1125
- "x-lix-key": "user",
1126
- "x-lix-primary-key": ["id"],
1127
- properties: {
1128
- id: { type: "string" },
1129
- name: { type: "string" },
1130
- },
1131
- required: ["id", "name"],
1132
- additionalProperties: false,
1133
- } as const satisfies LixSchemaDefinition;
1134
-
1135
- // Store the schema first
1136
- await lix.db.insertInto("stored_schema").values({ value: schema }).execute();
1137
-
1138
- // Insert initial user
1139
- await lix.db
1140
- .insertInto("state_all")
1141
- .values({
1142
- entity_id: "user1",
1143
- file_id: "file1",
1144
- schema_key: "user",
1145
- plugin_key: "test_plugin",
1146
- version_id: lix.db.selectFrom("active_version").select("version_id"),
1147
- snapshot_content: { id: "user1", name: "John Doe" },
1148
- schema_version: "1.0",
1149
- })
1150
- .execute();
1151
-
1152
- // This should pass - updating existing record with same primary key
1153
- expect(() =>
1154
- validateStateMutation({
1155
- lix,
1156
- schema,
1157
- snapshot_content: {
1158
- id: "user1", // Same primary key
1159
- name: "John Smith", // Different data
1160
- },
1161
- operation: "update",
1162
- entity_id: "user1",
1163
- version_id: activeVersion.version_id,
1164
- })
1165
- ).not.toThrowError();
1166
- });
1167
-
1168
- test("unique constraints are validated per version, not globally", async () => {
1169
- const lix = await openLix({});
1170
-
1171
- const schema = {
1172
- type: "object",
1173
- "x-lix-version": "1.0",
1174
- "x-lix-key": "file",
1175
- "x-lix-primary-key": ["id"],
1176
- "x-lix-unique": [["path"]], // Unique path constraint
1177
- properties: {
1178
- id: { type: "string" },
1179
- path: { type: "string" },
1180
- content: { type: "string" },
1181
- },
1182
- required: ["id", "path", "content"],
1183
- additionalProperties: false,
1184
- } as const satisfies LixSchemaDefinition;
1185
-
1186
- // Store the schema first
1187
- await lix.db.insertInto("stored_schema").values({ value: schema }).execute();
1188
-
1189
- // Create two different versions
1190
- await createVersion({
1191
- lix,
1192
- id: "version0",
1193
- });
1194
-
1195
- await createVersion({
1196
- lix,
1197
- id: "version1",
1198
- });
1199
- // Insert file with path "/app.js" in version1
1200
- await lix.db
1201
- .insertInto("state_all")
1202
- .values({
1203
- entity_id: "file1",
1204
- file_id: "file1",
1205
- schema_key: "file",
1206
- plugin_key: "test_plugin",
1207
- version_id: "version0",
1208
- snapshot_content: {
1209
- id: "file1",
1210
- path: "/app.js",
1211
- content: "console.log('version 0');",
1212
- },
1213
- schema_version: "1.0",
1214
- })
1215
- .execute();
1216
-
1217
- // This should pass - same path in different version should be allowed
1218
- expect(() =>
1219
- validateStateMutation({
1220
- lix,
1221
- schema,
1222
- snapshot_content: {
1223
- id: "file2",
1224
- path: "/app.js", // Same path but different version
1225
- content: "console.log('version 1');",
1226
- },
1227
- operation: "insert",
1228
- version_id: "version1",
1229
- })
1230
- ).not.toThrowError();
1231
-
1232
- // This should fail - same path in same version
1233
- expect(() =>
1234
- validateStateMutation({
1235
- lix,
1236
- schema,
1237
- snapshot_content: {
1238
- id: "file3",
1239
- path: "/app.js", // Same path and same version
1240
- content: "console.log('duplicate');",
1241
- },
1242
- operation: "insert",
1243
- version_id: "version0",
1244
- })
1245
- ).toThrowError("Unique constraint violation");
1246
- });
1247
-
1248
- test("throws when version_id is not provided", async () => {
1249
- const lix = await openLix({});
1250
-
1251
- const schema = {
1252
- type: "object",
1253
- "x-lix-version": "1.0",
1254
- "x-lix-key": "user",
1255
- "x-lix-primary-key": ["id"],
1256
- properties: {
1257
- id: { type: "string" },
1258
- name: { type: "string" },
1259
- },
1260
- required: ["id", "name"],
1261
- additionalProperties: false,
1262
- } as const satisfies LixSchemaDefinition;
1263
-
1264
- expect(() =>
1265
- validateStateMutation({
1266
- lix,
1267
- schema,
1268
- snapshot_content: { id: "user1", name: "John" },
1269
- operation: "insert",
1270
- // @ts-expect-error - version_id is required but missing
1271
- version_id: undefined,
1272
- })
1273
- ).toThrowError("version_id is required");
1274
- });
1275
-
1276
- test("throws when referenced version does not exist", async () => {
1277
- const lix = await openLix({});
1278
-
1279
- const schema = {
1280
- type: "object",
1281
- "x-lix-version": "1.0",
1282
- "x-lix-key": "user",
1283
- "x-lix-primary-key": ["id"],
1284
- properties: {
1285
- id: { type: "string" },
1286
- name: { type: "string" },
1287
- },
1288
- required: ["id", "name"],
1289
- additionalProperties: false,
1290
- } as const satisfies LixSchemaDefinition;
1291
-
1292
- expect(() =>
1293
- validateStateMutation({
1294
- lix,
1295
- schema,
1296
- snapshot_content: { id: "user1", name: "John" },
1297
- operation: "insert",
1298
- version_id: "nonexistent_version",
1299
- })
1300
- ).toThrowError("Version with id 'nonexistent_version' does not exist");
1301
- });
1302
-
1303
- test("passes when version_id is provided and version exists", async () => {
1304
- const lix = await openLix({});
1305
-
1306
- const schema = {
1307
- type: "object",
1308
- "x-lix-version": "1.0",
1309
- "x-lix-key": "user",
1310
- "x-lix-primary-key": ["id"],
1311
- properties: {
1312
- id: { type: "string" },
1313
- name: { type: "string" },
1314
- },
1315
- required: ["id", "name"],
1316
- additionalProperties: false,
1317
- } as const satisfies LixSchemaDefinition;
1318
-
1319
- const activeVersion = await lix.db
1320
- .selectFrom("active_version")
1321
- .select("version_id")
1322
- .executeTakeFirstOrThrow();
1323
-
1324
- expect(() =>
1325
- validateStateMutation({
1326
- lix,
1327
- schema,
1328
- snapshot_content: { id: "user1", name: "John" },
1329
- operation: "insert",
1330
- version_id: activeVersion.version_id,
1331
- })
1332
- ).not.toThrowError();
1333
- });
1334
-
1335
- test("should prevent deletion when foreign keys reference the entity", async () => {
1336
- const lix = await openLix({});
1337
-
1338
- const userSchema = {
1339
- type: "object",
1340
- "x-lix-version": "1.0",
1341
- "x-lix-key": "user",
1342
- "x-lix-primary-key": ["id"],
1343
- properties: {
1344
- id: { type: "string" },
1345
- name: { type: "string" },
1346
- },
1347
- required: ["id", "name"],
1348
- additionalProperties: false,
1349
- } as const satisfies LixSchemaDefinition;
1350
-
1351
- const postSchema = {
1352
- type: "object",
1353
- "x-lix-version": "1.0",
1354
- "x-lix-key": "post",
1355
- "x-lix-primary-key": ["id"],
1356
- "x-lix-foreign-keys": [
1357
- {
1358
- properties: ["author_id"],
1359
- references: {
1360
- schemaKey: "user",
1361
- properties: ["id"],
1362
- },
1363
- },
1364
- ],
1365
- properties: {
1366
- id: { type: "string" },
1367
- author_id: { type: "string" },
1368
- title: { type: "string" },
1369
- },
1370
- required: ["id", "author_id", "title"],
1371
- additionalProperties: false,
1372
- } as const satisfies LixSchemaDefinition;
1373
-
1374
- // Store schemas
1375
- await lix.db
1376
- .insertInto("stored_schema")
1377
- .values([{ value: userSchema }, { value: postSchema }])
1378
- .execute();
1379
-
1380
- const activeVersion = await lix.db
1381
- .selectFrom("active_version")
1382
- .select("version_id")
1383
- .executeTakeFirstOrThrow();
1384
-
1385
- // Insert a user that will be referenced
1386
- await lix.db
1387
- .insertInto("state_all")
1388
- .values({
1389
- entity_id: "user1",
1390
- file_id: "file1",
1391
- schema_key: "user",
1392
- plugin_key: "test_plugin",
1393
- version_id: activeVersion.version_id,
1394
- snapshot_content: {
1395
- id: "user1",
1396
- name: "John Doe",
1397
- },
1398
- schema_version: "1.0",
1399
- })
1400
- .execute();
1401
-
1402
- // Insert a post that references the user
1403
- await lix.db
1404
- .insertInto("state_all")
1405
- .values({
1406
- entity_id: "post1",
1407
- file_id: "file1",
1408
- schema_key: "post",
1409
- plugin_key: "test_plugin",
1410
- version_id: activeVersion.version_id,
1411
- snapshot_content: {
1412
- id: "post1",
1413
- author_id: "user1",
1414
- title: "My First Post",
1415
- },
1416
- schema_version: "1.0",
1417
- })
1418
- .execute();
1419
-
1420
- // This should fail - cannot delete user because post references it
1421
- expect(() =>
1422
- validateStateMutation({
1423
- lix,
1424
- schema: userSchema,
1425
- snapshot_content: {}, // Not used for delete operations
1426
- operation: "delete",
1427
- entity_id: "user1",
1428
- version_id: activeVersion.version_id,
1429
- })
1430
- ).toThrowError(
1431
- /Foreign key constraint violation.*referenced by.*post.*author_id/i
1432
- );
1433
- });
1434
-
1435
- test("should allow deletion when no foreign keys reference the entity", async () => {
1436
- const lix = await openLix({});
1437
-
1438
- const userSchema = {
1439
- type: "object",
1440
- "x-lix-version": "1.0",
1441
- "x-lix-key": "user",
1442
- "x-lix-primary-key": ["id"],
1443
- properties: {
1444
- id: { type: "string" },
1445
- name: { type: "string" },
1446
- },
1447
- required: ["id", "name"],
1448
- additionalProperties: false,
1449
- } as const satisfies LixSchemaDefinition;
1450
-
1451
- // Store schema
1452
- await lix.db
1453
- .insertInto("stored_schema")
1454
- .values({ value: userSchema })
1455
- .execute();
1456
-
1457
- const activeVersion = await lix.db
1458
- .selectFrom("active_version")
1459
- .select("version_id")
1460
- .executeTakeFirstOrThrow();
1461
-
1462
- // Insert a user with no references
1463
- await lix.db
1464
- .insertInto("state_all")
1465
- .values({
1466
- entity_id: "user1",
1467
- file_id: "file1",
1468
- schema_key: "user",
1469
- plugin_key: "test_plugin",
1470
- version_id: activeVersion.version_id,
1471
- snapshot_content: {
1472
- id: "user1",
1473
- name: "John Doe",
1474
- },
1475
- schema_version: "1.0",
1476
- })
1477
- .execute();
1478
-
1479
- // This should pass - no foreign keys reference this user
1480
- expect(() =>
1481
- validateStateMutation({
1482
- lix,
1483
- schema: userSchema,
1484
- snapshot_content: {}, // Not used for delete operations
1485
- operation: "delete",
1486
- entity_id: "user1",
1487
- version_id: activeVersion.version_id,
1488
- })
1489
- ).not.toThrowError();
1490
- });
1491
-
1492
- test("should throw when deleting non-existent entity", async () => {
1493
- const lix = await openLix({});
1494
-
1495
- const userSchema = {
1496
- type: "object",
1497
- "x-lix-version": "1.0",
1498
- "x-lix-key": "user",
1499
- "x-lix-primary-key": ["id"],
1500
- properties: {
1501
- id: { type: "string" },
1502
- name: { type: "string" },
1503
- },
1504
- required: ["id", "name"],
1505
- additionalProperties: false,
1506
- } as const satisfies LixSchemaDefinition;
1507
-
1508
- const activeVersion = await lix.db
1509
- .selectFrom("active_version")
1510
- .select("version_id")
1511
- .executeTakeFirstOrThrow();
1512
-
1513
- // This should fail - entity does not exist
1514
- expect(() =>
1515
- validateStateMutation({
1516
- lix,
1517
- schema: userSchema,
1518
- snapshot_content: {},
1519
- operation: "delete",
1520
- entity_id: "nonexistent_user",
1521
- version_id: activeVersion.version_id,
1522
- })
1523
- ).toThrowError(/Entity deletion failed/);
1524
- });
1525
-
1526
- test("should throw when entity_id is missing for delete operations", async () => {
1527
- const lix = await openLix({});
1528
-
1529
- const userSchema = {
1530
- type: "object",
1531
- "x-lix-version": "1.0",
1532
- "x-lix-key": "user",
1533
- "x-lix-primary-key": ["id"],
1534
- properties: {
1535
- id: { type: "string" },
1536
- name: { type: "string" },
1537
- },
1538
- required: ["id", "name"],
1539
- additionalProperties: false,
1540
- } as const satisfies LixSchemaDefinition;
1541
-
1542
- const activeVersion = await lix.db
1543
- .selectFrom("active_version")
1544
- .select("version_id")
1545
- .executeTakeFirstOrThrow();
1546
-
1547
- // This should fail - entity_id is required for delete
1548
- expect(() =>
1549
- validateStateMutation({
1550
- lix,
1551
- schema: userSchema,
1552
- snapshot_content: {},
1553
- operation: "delete",
1554
- // entity_id is missing
1555
- version_id: activeVersion.version_id,
1556
- })
1557
- ).toThrowError("entity_id is required for delete operations");
1558
- });
1559
-
1560
- test("should handle deletion validation for change sets referenced by versions", async () => {
1561
- const lix = await openLix({});
1562
-
1563
- // Create change sets
1564
- await lix.db
1565
- .insertInto("change_set_all")
1566
- .values([
1567
- { id: "cs_referenced", lixcol_version_id: "global" },
1568
- { id: "cs_working", lixcol_version_id: "global" },
1569
- ])
1570
- .execute();
1571
-
1572
- // Create commits that reference the change sets
1573
- await lix.db
1574
- .insertInto("commit_all")
1575
- .values([
1576
- {
1577
- id: "commit_1",
1578
- change_set_id: "cs_referenced",
1579
- lixcol_version_id: "global",
1580
- },
1581
- {
1582
- id: "working_commit_1",
1583
- change_set_id: "cs_working",
1584
- lixcol_version_id: "global",
1585
- },
1586
- ])
1587
- .execute();
1588
-
1589
- // Create a version that references the commits
1590
- await lix.db
1591
- .insertInto("version")
1592
- .values({
1593
- id: "v1",
1594
- name: "test_version",
1595
- commit_id: "commit_1",
1596
- working_commit_id: "working_commit_1",
1597
- })
1598
- .execute();
1599
-
1600
- // const activeVersion = await lix.db
1601
- // .selectFrom("active_version")
1602
- // .select("version_id")
1603
- // .executeTakeFirstOrThrow();
1604
-
1605
- // Get the change set schema
1606
- const changeSetSchema = await lix.db
1607
- .selectFrom("stored_schema")
1608
- .select("value")
1609
- .where("key", "=", "lix_change_set")
1610
- .executeTakeFirstOrThrow();
1611
-
1612
- // This should fail - cannot delete change set because version references it
1613
- expect(() =>
1614
- validateStateMutation({
1615
- lix,
1616
- schema: changeSetSchema.value as LixSchemaDefinition,
1617
- snapshot_content: {},
1618
- operation: "delete",
1619
- entity_id: "cs_referenced",
1620
- version_id: "global",
1621
- })
1622
- ).toThrowError(
1623
- /Foreign key constraint violation.*Cannot delete entity.*referenced by.*lix_commit/i
1624
- );
1625
- });
1626
-
1627
- test("should parse JSON object properties before validation", async () => {
1628
- const lix = await openLix({});
1629
-
1630
- // Define a schema with an object property
1631
- const documentSchema = {
1632
- type: "object",
1633
- "x-lix-version": "1.0",
1634
- "x-lix-key": "document",
1635
- "x-lix-primary-key": ["id"],
1636
- properties: {
1637
- id: { type: "string" },
1638
- title: { type: "string" },
1639
- body: {
1640
- type: "object",
1641
- properties: {
1642
- type: { type: "string" },
1643
- content: { type: "array" },
1644
- },
1645
- required: ["type", "content"],
1646
- },
1647
- },
1648
- required: ["id", "title", "body"],
1649
- additionalProperties: false,
1650
- } as const satisfies LixSchemaDefinition;
1651
-
1652
- // Store the schema
1653
- await lix.db
1654
- .insertInto("stored_schema")
1655
- .values({ value: documentSchema })
1656
- .execute();
1657
-
1658
- const activeVersion = await lix.db
1659
- .selectFrom("active_version")
1660
- .select("version_id")
1661
- .executeTakeFirstOrThrow();
1662
-
1663
- // Test with valid JSON object - this should pass
1664
- const validSnapshotContent = {
1665
- id: "doc1",
1666
- title: "Test Document",
1667
- body: JSON.stringify({
1668
- type: "zettel_doc",
1669
- content: [
1670
- {
1671
- type: "zettel_text_block",
1672
- zettel_key: "test_key",
1673
- style: "zettel_normal",
1674
- children: [],
1675
- },
1676
- ],
1677
- }),
1678
- };
1679
-
1680
- expect(() =>
1681
- validateStateMutation({
1682
- lix,
1683
- schema: documentSchema,
1684
- snapshot_content: validSnapshotContent,
1685
- operation: "insert",
1686
- version_id: activeVersion.version_id,
1687
- })
1688
- ).not.toThrowError();
1689
-
1690
- // Test with invalid JSON object - this should fail
1691
- const invalidSnapshotContent = {
1692
- id: "doc2",
1693
- title: "Invalid Document",
1694
- body: JSON.stringify({
1695
- type: "invalid_type", // Missing required 'content' property
1696
- }),
1697
- };
1698
-
1699
- expect(() =>
1700
- validateStateMutation({
1701
- lix,
1702
- schema: documentSchema,
1703
- snapshot_content: invalidSnapshotContent,
1704
- operation: "insert",
1705
- version_id: activeVersion.version_id,
1706
- })
1707
- ).toThrowError(/body.*must have required property.*content/);
1708
-
1709
- // Test with malformed JSON string - this should fail
1710
- const malformedSnapshotContent = {
1711
- id: "doc3",
1712
- title: "Malformed Document",
1713
- body: "{ invalid json",
1714
- };
1715
-
1716
- expect(() =>
1717
- validateStateMutation({
1718
- lix,
1719
- schema: documentSchema,
1720
- snapshot_content: malformedSnapshotContent,
1721
- operation: "insert",
1722
- version_id: activeVersion.version_id,
1723
- })
1724
- ).toThrowError(/Invalid JSON in property 'body'/);
1725
- });
1726
-
1727
- test("foreign key validation should fail when referenced entity exists in different non-inheriting version", async () => {
1728
- const lix = await openLix({});
1729
-
1730
- // Mock schema for a "User" entity
1731
- const userSchema = {
1732
- "x-lix-key": "mock_user",
1733
- "x-lix-version": "1.0",
1734
- "x-lix-primary-key": ["id"],
1735
- type: "object",
1736
- properties: {
1737
- id: { type: "string" },
1738
- name: { type: "string" },
1739
- },
1740
- required: ["id", "name"],
1741
- additionalProperties: false,
1742
- } as const satisfies LixSchemaDefinition;
1743
-
1744
- // Mock schema for a "Post" entity that references User
1745
- const postSchema = {
1746
- "x-lix-key": "mock_post",
1747
- "x-lix-version": "1.0",
1748
- "x-lix-primary-key": ["id"],
1749
- "x-lix-foreign-keys": [
1750
- {
1751
- properties: ["author_id"],
1752
- references: {
1753
- schemaKey: "mock_user",
1754
- properties: ["id"],
1755
- },
1756
- },
1757
- ],
1758
- type: "object",
1759
- properties: {
1760
- id: { type: "string" },
1761
- title: { type: "string" },
1762
- author_id: { type: "string" },
1763
- },
1764
- required: ["id", "title", "author_id"],
1765
- additionalProperties: false,
1766
- } as const satisfies LixSchemaDefinition;
1767
-
1768
- // Register our mock schemas
1769
- await lix.db
1770
- .insertInto("stored_schema")
1771
- .values([{ value: userSchema }, { value: postSchema }])
1772
- .execute();
1773
-
1774
- // Create two separate versions that don't inherit from each other
1775
- const versionA = await createVersion({
1776
- lix,
1777
- name: "version-a",
1778
- });
1779
-
1780
- const versionB = await createVersion({
1781
- lix,
1782
- name: "version-b",
1783
- });
1784
-
1785
- // Verify they don't inherit from each other
1786
- // Both should inherit from global, but not from each other
1787
- expect(versionA.inherits_from_version_id).toBe("global");
1788
- expect(versionB.inherits_from_version_id).toBe("global");
1789
-
1790
- // Create a user in version A
1791
- await lix.db
1792
- .insertInto("state_all")
1793
- .values({
1794
- entity_id: "user-1",
1795
- schema_key: "mock_user",
1796
- file_id: "test",
1797
- plugin_key: "test_plugin",
1798
- snapshot_content: {
1799
- id: "user-1",
1800
- name: "Alice",
1801
- },
1802
- schema_version: "1.0",
1803
- version_id: versionA.id,
1804
- })
1805
- .execute();
1806
-
1807
- // BUG: This should FAIL because user-1 doesn't exist in version B's context
1808
- // but the current foreign key validation logic will find user-1 in version A
1809
- // and incorrectly allow this validation to succeed
1810
- expect(() =>
1811
- validateStateMutation({
1812
- lix,
1813
- schema: postSchema,
1814
- snapshot_content: {
1815
- id: "post-1",
1816
- title: "My Post",
1817
- author_id: "user-1", // References user-1 which only exists in version A
1818
- },
1819
- operation: "insert",
1820
- version_id: versionB.id,
1821
- })
1822
- ).toThrow(/Foreign key constraint violation.*mock_user.*user-1/);
1823
-
1824
- // Verify that user-1 indeed doesn't exist in version B's context
1825
- const userInVersionB = await lix.db
1826
- .selectFrom("state_all")
1827
- .where("entity_id", "=", "user-1")
1828
- .where("schema_key", "=", "mock_user")
1829
- .where("version_id", "=", versionB.id)
1830
- .selectAll()
1831
- .execute();
1832
-
1833
- expect(userInVersionB).toHaveLength(0);
1834
-
1835
- // But verify it does exist in version A
1836
- const userInVersionA = await lix.db
1837
- .selectFrom("state_all")
1838
- .where("entity_id", "=", "user-1")
1839
- .where("schema_key", "=", "mock_user")
1840
- .where("version_id", "=", versionA.id)
1841
- .selectAll()
1842
- .execute();
1843
-
1844
- expect(userInVersionA).toHaveLength(1);
1845
- });
1846
-
1847
- test("should allow self-referential foreign keys", async () => {
1848
- const lix = await openLix({});
1849
-
1850
- // Define a schema with self-referential foreign key (like version inheritance)
1851
- const versionSchema = {
1852
- type: "object",
1853
- "x-lix-version": "1.0",
1854
- "x-lix-key": "mock_version",
1855
- "x-lix-primary-key": ["id"],
1856
- "x-lix-foreign-keys": [
1857
- {
1858
- properties: ["inherits_from_version_id"],
1859
- references: {
1860
- schemaKey: "mock_version", // Self-referential foreign key
1861
- properties: ["id"],
1862
- },
1863
- },
1864
- ],
1865
- properties: {
1866
- id: { type: "string" },
1867
- name: { type: "string" },
1868
- inherits_from_version_id: { type: ["string", "null"] },
1869
- },
1870
- required: ["id", "name"],
1871
- additionalProperties: false,
1872
- } as const satisfies LixSchemaDefinition;
1873
-
1874
- // Store the schema
1875
- await lix.db
1876
- .insertInto("stored_schema")
1877
- .values({ value: versionSchema })
1878
- .execute();
1879
-
1880
- const activeVersion = await lix.db
1881
- .selectFrom("active_version")
1882
- .select("version_id")
1883
- .executeTakeFirstOrThrow();
1884
-
1885
- // Insert a parent version first (with null inheritance)
1886
- await lix.db
1887
- .insertInto("state_all")
1888
- .values({
1889
- entity_id: "version0",
1890
- file_id: "file1",
1891
- schema_key: "mock_version",
1892
- plugin_key: "test_plugin",
1893
- version_id: activeVersion.version_id,
1894
- snapshot_content: {
1895
- id: "version0",
1896
- name: "version0",
1897
- inherits_from_version_id: null,
1898
- },
1899
- schema_version: "1.0",
1900
- })
1901
- .execute();
1902
-
1903
- // This should pass - child version referencing parent version (valid self-referential FK)
1904
- expect(() =>
1905
- validateStateMutation({
1906
- lix,
1907
- schema: versionSchema,
1908
- snapshot_content: {
1909
- id: "version1",
1910
- name: "version1",
1911
- inherits_from_version_id: "version0", // References another entity in same schema
1912
- },
1913
- operation: "insert",
1914
- version_id: activeVersion.version_id,
1915
- })
1916
- ).not.toThrowError();
1917
-
1918
- // This should also pass - version with null inheritance (no foreign key constraint)
1919
- expect(() =>
1920
- validateStateMutation({
1921
- lix,
1922
- schema: versionSchema,
1923
- snapshot_content: {
1924
- id: "version2",
1925
- name: "version2",
1926
- inherits_from_version_id: null, // No foreign key reference
1927
- },
1928
- operation: "insert",
1929
- version_id: activeVersion.version_id,
1930
- })
1931
- ).not.toThrowError();
1932
-
1933
- // This should fail - referencing non-existent version
1934
- expect(() =>
1935
- validateStateMutation({
1936
- lix,
1937
- schema: versionSchema,
1938
- snapshot_content: {
1939
- id: "version3",
1940
- name: "version3",
1941
- inherits_from_version_id: "nonexistent_version",
1942
- },
1943
- operation: "insert",
1944
- version_id: activeVersion.version_id,
1945
- })
1946
- ).toThrowError("Foreign key constraint violation");
1947
- });
1948
-
1949
- test("should allow self-referential foreign keys for update operations", async () => {
1950
- const lix = await openLix({});
1951
-
1952
- // Define a schema with self-referential foreign key
1953
- const versionSchema = {
1954
- type: "object",
1955
- "x-lix-version": "1.0",
1956
- "x-lix-key": "mock_version",
1957
- "x-lix-primary-key": ["id"],
1958
- "x-lix-foreign-keys": [
1959
- {
1960
- properties: ["inherits_from_version_id"],
1961
- references: {
1962
- schemaKey: "mock_version",
1963
- properties: ["id"],
1964
- },
1965
- },
1966
- ],
1967
- properties: {
1968
- id: { type: "string" },
1969
- name: { type: "string" },
1970
- inherits_from_version_id: { type: ["string", "null"] },
1971
- },
1972
- required: ["id", "name"],
1973
- additionalProperties: false,
1974
- } as const satisfies LixSchemaDefinition;
1975
-
1976
- // Store the schema
1977
- await lix.db
1978
- .insertInto("stored_schema")
1979
- .values({ value: versionSchema })
1980
- .execute();
1981
-
1982
- const activeVersion = await lix.db
1983
- .selectFrom("active_version")
1984
- .select("version_id")
1985
- .executeTakeFirstOrThrow();
1986
-
1987
- // Insert initial versions
1988
- await lix.db
1989
- .insertInto("state_all")
1990
- .values([
1991
- {
1992
- entity_id: "version0",
1993
- file_id: "file1",
1994
- schema_key: "mock_version",
1995
- plugin_key: "test_plugin",
1996
- version_id: activeVersion.version_id,
1997
- snapshot_content: {
1998
- id: "version0",
1999
- name: "version0",
2000
- inherits_from_version_id: null,
2001
- },
2002
- schema_version: "1.0",
2003
- },
2004
- {
2005
- entity_id: "version1",
2006
- file_id: "file1",
2007
- schema_key: "mock_version",
2008
- plugin_key: "test_plugin",
2009
- version_id: activeVersion.version_id,
2010
- snapshot_content: {
2011
- id: "version1",
2012
- name: "version1",
2013
- inherits_from_version_id: "version0",
2014
- },
2015
- schema_version: "1.0",
2016
- },
2017
- ])
2018
- .execute();
2019
-
2020
- // This should pass - updating to reference a different valid version
2021
- expect(() =>
2022
- validateStateMutation({
2023
- lix,
2024
- schema: versionSchema,
2025
- snapshot_content: {
2026
- id: "version1",
2027
- name: "version1_updated",
2028
- inherits_from_version_id: null, // Change from version0 to null
2029
- },
2030
- operation: "update",
2031
- entity_id: "version1",
2032
- version_id: activeVersion.version_id,
2033
- })
2034
- ).not.toThrowError();
2035
-
2036
- // This should fail - updating to reference non-existent version
2037
- expect(() =>
2038
- validateStateMutation({
2039
- lix,
2040
- schema: versionSchema,
2041
- snapshot_content: {
2042
- id: "version1",
2043
- name: "version1_updated",
2044
- inherits_from_version_id: "nonexistent_version",
2045
- },
2046
- operation: "update",
2047
- entity_id: "version1",
2048
- version_id: activeVersion.version_id,
2049
- })
2050
- ).toThrowError("Foreign key constraint violation");
2051
- });
2052
-
2053
- test("should prevent deletion when self-referential foreign keys reference the entity", async () => {
2054
- const lix = await openLix({});
2055
-
2056
- // Define a schema with self-referential foreign key
2057
- const versionSchema = {
2058
- type: "object",
2059
- "x-lix-version": "1.0",
2060
- "x-lix-key": "mock_version",
2061
- "x-lix-primary-key": ["id"],
2062
- "x-lix-foreign-keys": [
2063
- {
2064
- properties: ["inherits_from_version_id"],
2065
- references: {
2066
- schemaKey: "mock_version",
2067
- properties: ["id"],
2068
- },
2069
- },
2070
- ],
2071
- properties: {
2072
- id: { type: "string" },
2073
- name: { type: "string" },
2074
- inherits_from_version_id: { type: ["string", "null"] },
2075
- },
2076
- required: ["id", "name"],
2077
- additionalProperties: false,
2078
- } as const satisfies LixSchemaDefinition;
2079
-
2080
- // Store the schema
2081
- await lix.db
2082
- .insertInto("stored_schema")
2083
- .values({ value: versionSchema })
2084
- .execute();
2085
-
2086
- const activeVersion = await lix.db
2087
- .selectFrom("active_version")
2088
- .select("version_id")
2089
- .executeTakeFirstOrThrow();
2090
-
2091
- // Insert parent and child versions
2092
- await lix.db
2093
- .insertInto("state_all")
2094
- .values([
2095
- {
2096
- entity_id: "version0",
2097
- file_id: "file1",
2098
- schema_key: "mock_version",
2099
- plugin_key: "test_plugin",
2100
- version_id: activeVersion.version_id,
2101
- snapshot_content: {
2102
- id: "version0",
2103
- name: "version0",
2104
- inherits_from_version_id: null,
2105
- },
2106
- schema_version: "1.0",
2107
- },
2108
- {
2109
- entity_id: "version1",
2110
- file_id: "file1",
2111
- schema_key: "mock_version",
2112
- plugin_key: "test_plugin",
2113
- version_id: activeVersion.version_id,
2114
- snapshot_content: {
2115
- id: "version1",
2116
- name: "version1",
2117
- inherits_from_version_id: "version0", // References version0
2118
- },
2119
- schema_version: "1.0",
2120
- },
2121
- ])
2122
- .execute();
2123
-
2124
- // This should fail - cannot delete version0 because version1 references it
2125
- expect(() =>
2126
- validateStateMutation({
2127
- lix,
2128
- schema: versionSchema,
2129
- snapshot_content: {},
2130
- operation: "delete",
2131
- entity_id: "version0",
2132
- version_id: activeVersion.version_id,
2133
- })
2134
- ).toThrowError(
2135
- /Foreign key constraint violation.*referenced by.*mock_version.*inherits_from_version_id/
2136
- );
2137
-
2138
- // This should pass - can delete version1 (no other versions reference it)
2139
- expect(() =>
2140
- validateStateMutation({
2141
- lix,
2142
- schema: versionSchema,
2143
- snapshot_content: {},
2144
- operation: "delete",
2145
- entity_id: "version1",
2146
- version_id: activeVersion.version_id,
2147
- })
2148
- ).not.toThrowError();
2149
- });
2150
-
2151
- // Foreign keys are restricted to the current version context to maintain data integrity
2152
- // and prevent confusing dependency relationships across version boundaries. While entities
2153
- // can be inherited from parent versions through the copy-on-write system, foreign key
2154
- // constraints require explicit, direct relationships within the same version scope.
2155
- // This design choice ensures that:
2156
- // 1. FK constraints are predictable and version-scoped
2157
- // 2. No hidden dependencies exist across version boundaries
2158
- // 3. Copy-on-write semantics remain clear and isolated
2159
- // 4. Data integrity is maintained within each version context
2160
- test("should prevent foreign key references to inherited entities from different version contexts", async () => {
2161
- const lix = await openLix({});
2162
-
2163
- // Create a thread in global context
2164
- await lix.db
2165
- .insertInto("thread_all")
2166
- .values({
2167
- id: "global_thread",
2168
- metadata: { title: "Global Thread" },
2169
- lixcol_version_id: "global",
2170
- })
2171
- .execute();
2172
-
2173
- // Get the active version (should be "main" version)
2174
- const activeVersion = await lix.db
2175
- .selectFrom("active_version")
2176
- .select("version_id")
2177
- .executeTakeFirstOrThrow();
2178
-
2179
- // Get the thread comment schema
2180
- const threadCommentSchema = await lix.db
2181
- .selectFrom("stored_schema")
2182
- .select("value")
2183
- .where("key", "=", "lix_thread_comment")
2184
- .executeTakeFirstOrThrow();
2185
-
2186
- // This should FAIL: attempting to create a thread_comment in the active version
2187
- // that references a thread that only exists in global context.
2188
- // Foreign keys should only work within the same version context.
2189
- expect(() =>
2190
- validateStateMutation({
2191
- lix,
2192
- schema: threadCommentSchema.value as LixSchemaDefinition,
2193
- snapshot_content: {
2194
- id: "comment1",
2195
- thread_id: "global_thread", // References thread in global context
2196
- parent_id: null,
2197
- body: {
2198
- type: "zettel_doc",
2199
- content: [
2200
- {
2201
- type: "zettel_text_block",
2202
- zettel_key: "test_key",
2203
- style: "zettel_normal",
2204
- children: [],
2205
- },
2206
- ],
2207
- },
2208
- },
2209
- operation: "insert",
2210
- version_id: activeVersion.version_id, // But creating comment in active version context
2211
- })
2212
- ).toThrow(/Foreign key constraint violation.*lix_thread.*global_thread/);
2213
- });
2214
-
2215
- test("should prevent change set elements from referencing change sets defined in global context", async () => {
2216
- const lix = await openLix({});
2217
-
2218
- // Create a change set in global context
2219
- await lix.db
2220
- .insertInto("change_set_all")
2221
- .values({
2222
- id: "global_change_set",
2223
- lixcol_version_id: "global",
2224
- })
2225
- .execute();
2226
-
2227
- // Get the active version (should be "main" version)
2228
- const activeVersion = await lix.db
2229
- .selectFrom("active_version")
2230
- .select("version_id")
2231
- .executeTakeFirstOrThrow();
2232
-
2233
- // Get the change set element schema
2234
- const changeSetElementSchema = await lix.db
2235
- .selectFrom("stored_schema")
2236
- .select("value")
2237
- .where("key", "=", "lix_change_set_element")
2238
- .executeTakeFirstOrThrow();
2239
-
2240
- // This should FAIL: attempting to create a change_set_element in the active version
2241
- // that references a change set that exists in global context.
2242
- // The bug is that this currently passes when it should fail.
2243
- expect(() =>
2244
- validateStateMutation({
2245
- lix,
2246
- schema: changeSetElementSchema.value as LixSchemaDefinition,
2247
- snapshot_content: {
2248
- change_set_id: "global_change_set", // References change set in global context
2249
- change_id: "dummy_change_id",
2250
- entity_id: "dummy_entity_id",
2251
- file_id: "dummy_file_id",
2252
- schema_key: "dummy_schema_key",
2253
- } satisfies LixChangeSetElement,
2254
- operation: "insert",
2255
- version_id: activeVersion.version_id, // But creating element in active version context
2256
- })
2257
- ).toThrow(
2258
- /Foreign key constraint violation.*lix_change_set.*global_change_set/
2259
- );
2260
- });
2261
-
2262
- // Untracked state foreign key tests
2263
- // SCENARIO: Tracked → Untracked Foreign Key Reference
2264
- // WHY THIS TEST EXISTS: Untracked entities are local-only and won't be synced to remote.
2265
- // If a tracked entity references an untracked entity, it would create broken references
2266
- // when synced because the untracked entity doesn't exist on the remote.
2267
- // BEHAVIOR: DISALLOWED - This would break data integrity during sync operations.
2268
- test("should prevent tracked entities from referencing untracked entities", async () => {
2269
- const lix = await openLix({});
2270
-
2271
- const userSchema = {
2272
- type: "object",
2273
- "x-lix-version": "1.0",
2274
- "x-lix-key": "user",
2275
- "x-lix-primary-key": ["id"],
2276
- properties: {
2277
- id: { type: "string" },
2278
- name: { type: "string" },
2279
- },
2280
- required: ["id", "name"],
2281
- additionalProperties: false,
2282
- } as const satisfies LixSchemaDefinition;
2283
-
2284
- const postSchema = {
2285
- type: "object",
2286
- "x-lix-version": "1.0",
2287
- "x-lix-key": "post",
2288
- "x-lix-primary-key": ["id"],
2289
- "x-lix-foreign-keys": [
2290
- {
2291
- properties: ["author_id"],
2292
- references: {
2293
- schemaKey: "user",
2294
- properties: ["id"],
2295
- },
2296
- },
2297
- ],
2298
- properties: {
2299
- id: { type: "string" },
2300
- author_id: { type: "string" },
2301
- title: { type: "string" },
2302
- },
2303
- required: ["id", "author_id", "title"],
2304
- additionalProperties: false,
2305
- } as const satisfies LixSchemaDefinition;
2306
-
2307
- // Store schemas
2308
- await lix.db
2309
- .insertInto("stored_schema")
2310
- .values([{ value: userSchema }, { value: postSchema }])
2311
- .execute();
2312
-
2313
- const activeVersion = await lix.db
2314
- .selectFrom("active_version")
2315
- .select("version_id")
2316
- .executeTakeFirstOrThrow();
2317
-
2318
- // Insert an untracked user
2319
- await lix.db
2320
- .insertInto("state_all")
2321
- .values({
2322
- entity_id: "untracked_user",
2323
- file_id: "file1",
2324
- schema_key: "user",
2325
- plugin_key: "test_plugin",
2326
- version_id: activeVersion.version_id,
2327
- snapshot_content: {
2328
- id: "untracked_user",
2329
- name: "Untracked User",
2330
- },
2331
- schema_version: "1.0",
2332
- untracked: true,
2333
- })
2334
- .execute();
2335
-
2336
- // This should FAIL - tracked entity cannot reference untracked entity
2337
- expect(() =>
2338
- validateStateMutation({
2339
- lix,
2340
- schema: postSchema,
2341
- snapshot_content: {
2342
- id: "post1",
2343
- author_id: "untracked_user", // References untracked user
2344
- title: "My Post",
2345
- },
2346
- operation: "insert",
2347
- version_id: activeVersion.version_id,
2348
- })
2349
- ).toThrow(
2350
- /Foreign key constraint violation.*tracked entities cannot reference untracked entities.*This would create broken references during sync/
2351
- );
2352
- });
2353
-
2354
- // SCENARIO: Untracked → Tracked Foreign Key Reference
2355
- // WHY THIS TEST EXISTS: Untracked entities are local-only and won't be synced.
2356
- // Since they remain local, they can safely reference tracked entities without
2357
- // breaking data integrity. The untracked entity simply won't exist on remote.
2358
- // BEHAVIOR: ALLOWED - Safe because untracked entities don't participate in sync.
2359
- test("should allow untracked entities to reference tracked entities", async () => {
2360
- const lix = await openLix({});
2361
-
2362
- const userSchema = {
2363
- type: "object",
2364
- "x-lix-version": "1.0",
2365
- "x-lix-key": "user",
2366
- "x-lix-primary-key": ["id"],
2367
- properties: {
2368
- id: { type: "string" },
2369
- name: { type: "string" },
2370
- },
2371
- required: ["id", "name"],
2372
- additionalProperties: false,
2373
- } as const satisfies LixSchemaDefinition;
2374
-
2375
- const postSchema = {
2376
- type: "object",
2377
- "x-lix-version": "1.0",
2378
- "x-lix-key": "post",
2379
- "x-lix-primary-key": ["id"],
2380
- "x-lix-foreign-keys": [
2381
- {
2382
- properties: ["author_id"],
2383
- references: {
2384
- schemaKey: "user",
2385
- properties: ["id"],
2386
- },
2387
- },
2388
- ],
2389
- properties: {
2390
- id: { type: "string" },
2391
- author_id: { type: "string" },
2392
- title: { type: "string" },
2393
- },
2394
- required: ["id", "author_id", "title"],
2395
- additionalProperties: false,
2396
- } as const satisfies LixSchemaDefinition;
2397
-
2398
- // Store schemas
2399
- await lix.db
2400
- .insertInto("stored_schema")
2401
- .values([{ value: userSchema }, { value: postSchema }])
2402
- .execute();
2403
-
2404
- const activeVersion = await lix.db
2405
- .selectFrom("active_version")
2406
- .select("version_id")
2407
- .executeTakeFirstOrThrow();
2408
-
2409
- // Insert a tracked user
2410
- await lix.db
2411
- .insertInto("state_all")
2412
- .values({
2413
- entity_id: "tracked_user",
2414
- file_id: "file1",
2415
- schema_key: "user",
2416
- plugin_key: "test_plugin",
2417
- version_id: activeVersion.version_id,
2418
- snapshot_content: {
2419
- id: "tracked_user",
2420
- name: "Tracked User",
2421
- },
2422
- schema_version: "1.0",
2423
- untracked: false,
2424
- })
2425
- .execute();
2426
-
2427
- // Create validation arguments for untracked post
2428
- const validationArgs = {
2429
- lix,
2430
- schema: postSchema,
2431
- snapshot_content: {
2432
- id: "untracked_post",
2433
- author_id: "tracked_user", // References tracked user
2434
- title: "My Untracked Post",
2435
- },
2436
- operation: "insert" as const,
2437
- version_id: activeVersion.version_id,
2438
- untracked: true, // Mark as untracked
2439
- };
2440
-
2441
- // This should PASS - untracked entity can reference tracked entity
2442
- expect(() => validateStateMutation(validationArgs)).not.toThrow();
2443
- });
2444
-
2445
- // SCENARIO: Untracked → Untracked Foreign Key Reference
2446
- // WHY THIS TEST EXISTS: Both entities are local-only and won't be synced.
2447
- // They exist in the same local scope, so references between them are valid
2448
- // and won't cause any sync issues since neither entity leaves the local system.
2449
- // BEHAVIOR: ALLOWED - Both entities remain local, maintaining referential integrity.
2450
- test("should allow untracked entities to reference other untracked entities", async () => {
2451
- const lix = await openLix({});
2452
-
2453
- const userSchema = {
2454
- type: "object",
2455
- "x-lix-version": "1.0",
2456
- "x-lix-key": "user",
2457
- "x-lix-primary-key": ["id"],
2458
- properties: {
2459
- id: { type: "string" },
2460
- name: { type: "string" },
2461
- },
2462
- required: ["id", "name"],
2463
- additionalProperties: false,
2464
- } as const satisfies LixSchemaDefinition;
2465
-
2466
- const postSchema = {
2467
- type: "object",
2468
- "x-lix-version": "1.0",
2469
- "x-lix-key": "post",
2470
- "x-lix-primary-key": ["id"],
2471
- "x-lix-foreign-keys": [
2472
- {
2473
- properties: ["author_id"],
2474
- references: {
2475
- schemaKey: "user",
2476
- properties: ["id"],
2477
- },
2478
- },
2479
- ],
2480
- properties: {
2481
- id: { type: "string" },
2482
- author_id: { type: "string" },
2483
- title: { type: "string" },
2484
- },
2485
- required: ["id", "author_id", "title"],
2486
- additionalProperties: false,
2487
- } as const satisfies LixSchemaDefinition;
2488
-
2489
- // Store schemas
2490
- await lix.db
2491
- .insertInto("stored_schema")
2492
- .values([{ value: userSchema }, { value: postSchema }])
2493
- .execute();
2494
-
2495
- const activeVersion = await lix.db
2496
- .selectFrom("active_version")
2497
- .select("version_id")
2498
- .executeTakeFirstOrThrow();
2499
-
2500
- // Insert an untracked user
2501
- await lix.db
2502
- .insertInto("state_all")
2503
- .values({
2504
- entity_id: "untracked_user",
2505
- file_id: "file1",
2506
- schema_key: "user",
2507
- plugin_key: "test_plugin",
2508
- version_id: activeVersion.version_id,
2509
- snapshot_content: {
2510
- id: "untracked_user",
2511
- name: "Untracked User",
2512
- },
2513
- schema_version: "1.0",
2514
- untracked: true,
2515
- })
2516
- .execute();
2517
-
2518
- // Create validation arguments for untracked post
2519
- const validationArgs = {
2520
- lix,
2521
- schema: postSchema,
2522
- snapshot_content: {
2523
- id: "untracked_post",
2524
- author_id: "untracked_user", // References untracked user
2525
- title: "My Untracked Post",
2526
- },
2527
- operation: "insert" as const,
2528
- version_id: activeVersion.version_id,
2529
- untracked: true, // Mark as untracked
2530
- };
2531
-
2532
- // This should PASS - untracked entity can reference another untracked entity
2533
- expect(() => validateStateMutation(validationArgs)).not.toThrow();
2534
- });
2535
-
2536
- test("should detect and prevent cycles in commit graph when lix_debug is enabled", async () => {
2537
- const lix = await openLix({
2538
- keyValues: [{ key: "lix_debug", value: "true" }],
2539
- });
2540
-
2541
- // Get the commit edge schema
2542
- const commitEdgeSchema = await lix.db
2543
- .selectFrom("stored_schema")
2544
- .select("value")
2545
- .where("key", "=", "lix_commit_edge")
2546
- .executeTakeFirstOrThrow();
2547
-
2548
- // Create a few change sets and commits
2549
- await lix.db
2550
- .insertInto("change_set_all")
2551
- .values([
2552
- { id: "cs1", lixcol_version_id: "global" },
2553
- { id: "cs2", lixcol_version_id: "global" },
2554
- { id: "cs3", lixcol_version_id: "global" },
2555
- ])
2556
- .execute();
2557
-
2558
- await lix.db
2559
- .insertInto("commit_all")
2560
- .values([
2561
- { id: "commit1", change_set_id: "cs1", lixcol_version_id: "global" },
2562
- { id: "commit2", change_set_id: "cs2", lixcol_version_id: "global" },
2563
- { id: "commit3", change_set_id: "cs3", lixcol_version_id: "global" },
2564
- ])
2565
- .execute();
2566
-
2567
- // Create edges: commit1 -> commit2 -> commit3
2568
- await lix.db
2569
- .insertInto("commit_edge_all")
2570
- .values([
2571
- {
2572
- parent_id: "commit1",
2573
- child_id: "commit2",
2574
- lixcol_version_id: "global",
2575
- },
2576
- {
2577
- parent_id: "commit2",
2578
- child_id: "commit3",
2579
- lixcol_version_id: "global",
2580
- },
2581
- ])
2582
- .execute();
2583
-
2584
- // This should fail - creating commit3 -> commit1 would create a cycle
2585
- expect(() =>
2586
- validateStateMutation({
2587
- lix,
2588
- schema: commitEdgeSchema.value as LixSchemaDefinition,
2589
- snapshot_content: {
2590
- parent_id: "commit3",
2591
- child_id: "commit1", // This would complete the cycle
2592
- },
2593
- operation: "insert",
2594
- version_id: "global",
2595
- })
2596
- ).toThrowError(
2597
- /Cycle detected in commit graph.*New edge: commit3 -> commit1.*Cycle path: commit1 -> commit2 -> commit3 -> commit1/s
2598
- );
2599
-
2600
- // This should also fail - self-loop
2601
- expect(() =>
2602
- validateStateMutation({
2603
- lix,
2604
- schema: commitEdgeSchema.value as LixSchemaDefinition,
2605
- snapshot_content: {
2606
- parent_id: "commit1",
2607
- child_id: "commit1", // Self-referencing edge
2608
- },
2609
- operation: "insert",
2610
- version_id: "global",
2611
- })
2612
- ).toThrowError(/Self-referencing edges are not allowed/);
2613
- });
2614
-
2615
- test("should not check for cycles when lix_debug is disabled", async () => {
2616
- const lix = await openLix({
2617
- keyValues: [{ key: "lix_debug", value: "false" }],
2618
- });
2619
-
2620
- // Get the commit edge schema
2621
- const commitEdgeSchema = await lix.db
2622
- .selectFrom("stored_schema")
2623
- .select("value")
2624
- .where("key", "=", "lix_commit_edge")
2625
- .executeTakeFirstOrThrow();
2626
-
2627
- // Create a few change sets and commits
2628
- await lix.db
2629
- .insertInto("change_set_all")
2630
- .values([
2631
- { id: "cs1", lixcol_version_id: "global" },
2632
- { id: "cs2", lixcol_version_id: "global" },
2633
- { id: "cs3", lixcol_version_id: "global" },
2634
- ])
2635
- .execute();
2636
-
2637
- await lix.db
2638
- .insertInto("commit_all")
2639
- .values([
2640
- { id: "commit1", change_set_id: "cs1", lixcol_version_id: "global" },
2641
- { id: "commit2", change_set_id: "cs2", lixcol_version_id: "global" },
2642
- { id: "commit3", change_set_id: "cs3", lixcol_version_id: "global" },
2643
- ])
2644
- .execute();
2645
-
2646
- // Create edges: commit1 -> commit2 -> commit3
2647
- await lix.db
2648
- .insertInto("commit_edge_all")
2649
- .values([
2650
- {
2651
- parent_id: "commit1",
2652
- child_id: "commit2",
2653
- lixcol_version_id: "global",
2654
- },
2655
- {
2656
- parent_id: "commit2",
2657
- child_id: "commit3",
2658
- lixcol_version_id: "global",
2659
- },
2660
- ])
2661
- .execute();
2662
-
2663
- // This would create a cycle, but with lix_debug=false it won't be detected
2664
- // (This is intentional for performance - cycle detection is expensive)
2665
- expect(() =>
2666
- validateStateMutation({
2667
- lix,
2668
- schema: commitEdgeSchema.value as LixSchemaDefinition,
2669
- snapshot_content: {
2670
- parent_id: "commit3",
2671
- child_id: "commit1", // This would complete the cycle
2672
- },
2673
- operation: "insert",
2674
- version_id: "global",
2675
- })
2676
- ).not.toThrowError();
2677
- });
2678
-
2679
- test("should validate foreign keys that reference changes in internal_change_in_transaction during transaction", async () => {
2680
- const lix = await openLix({});
2681
-
2682
- // Create a simple mock schema that references a change
2683
- const mockChangeReferencingSchema = {
2684
- type: "object",
2685
- "x-lix-version": "1.0",
2686
- "x-lix-key": "mock_change_reference",
2687
- "x-lix-primary-key": ["change_id"],
2688
- "x-lix-foreign-keys": [
2689
- {
2690
- properties: ["change_id"],
2691
- references: {
2692
- schemaKey: "lix_change",
2693
- properties: ["id"],
2694
- },
2695
- },
2696
- ],
2697
- properties: {
2698
- change_id: { type: "string" },
2699
- },
2700
- required: ["change_id"],
2701
- additionalProperties: false,
2702
- } as const satisfies LixSchemaDefinition;
2703
-
2704
- // Store the mock schema
2705
- await lix.db
2706
- .insertInto("stored_schema")
2707
- .values({ value: mockChangeReferencingSchema })
2708
- .execute();
2709
-
2710
- // Get active version
2711
- const activeVersion = await lix.db
2712
- .selectFrom("active_version")
2713
- .select("version_id")
2714
- .executeTakeFirstOrThrow();
2715
-
2716
- await lix.db.transaction().execute(async (trx) => {
2717
- // Insert a key-value entity which creates a change in internal_change_in_transaction
2718
- await trx
2719
- .insertInto("key_value")
2720
- .values({
2721
- key: "test_key_for_change_reference",
2722
- value: "test_value",
2723
- })
2724
- .execute();
2725
-
2726
- // Get the change ID that was just created in internal_change_in_transaction
2727
- const changes = await (trx as unknown as Kysely<LixInternalDatabaseSchema>)
2728
- .selectFrom("internal_change_in_transaction")
2729
- .select("id")
2730
- .where("entity_id", "=", "test_key_for_change_reference")
2731
- .where("schema_key", "=", "lix_key_value")
2732
- .execute();
2733
-
2734
- expect(changes).toHaveLength(1);
2735
- const changeId = changes[0]!.id;
2736
-
2737
- // This should NOT throw an error because the change exists in internal_change_in_transaction
2738
- // But currently it will throw because validation only checks the "change" table (internal_change)
2739
- // which doesn't include internal_change_in_transaction
2740
- expect(() =>
2741
- validateStateMutation({
2742
- lix: { sqlite: lix.sqlite, db: trx as any },
2743
- schema: mockChangeReferencingSchema,
2744
- snapshot_content: {
2745
- change_id: changeId,
2746
- },
2747
- operation: "insert",
2748
- version_id: activeVersion.version_id,
2749
- })
2750
- ).not.toThrowError();
2751
- });
2752
- });
2753
-
2754
- /**
2755
- * 🧪 Regression-guard for “versionless change FKs”
2756
- *
2757
- * Context from architecture discussion:
2758
- * ─────────────────────────────────────
2759
- * • `lix_change` rows are **version-agnostic** (no `version_id` column) and
2760
- * append-only. They form the immutable source-of-truth that every branch
2761
- * materialises state from.
2762
- *
2763
- * • Therefore **any** version-scoped table is allowed to carry a foreign key
2764
- * that points at `lix_change.id`, because the target row can never disappear
2765
- * or mutate in a way that would break the reference.
2766
- *
2767
- * • The validator treats these targets specially: if the referenced schema’s
2768
- * scope is `versionless`, it skips the usual “same version” check.
2769
- *
2770
- * What this test proves:
2771
- * ──────────────────────
2772
- * 1. A table that references `lix_change.id` can be inserted **in the global
2773
- * context**.
2774
- * 2. The **same row** can also be inserted in an arbitrary branch
2775
- * (`activeVersion.version_id`) without triggering a
2776
- * “foreign-key constraint violation”.
2777
- *
2778
- * If either expectation starts failing, it means the validator has regressed
2779
- * and is once again enforcing version isolation for versionless targets—
2780
- * something we explicitly decided against.
2781
- */
2782
- test("should allow foreign keys to changes from any version context", async () => {
2783
- const lix = await openLix({});
2784
-
2785
- // Create a schema that references change.id (like change_author does)
2786
- const mockSchema = {
2787
- type: "object",
2788
- "x-lix-version": "1.0",
2789
- "x-lix-key": "mock_schema",
2790
- "x-lix-primary-key": ["change_id"],
2791
- "x-lix-foreign-keys": [
2792
- {
2793
- properties: ["change_id"],
2794
- references: {
2795
- schemaKey: "lix_change",
2796
- properties: ["id"],
2797
- },
2798
- },
2799
- ],
2800
- properties: {
2801
- change_id: { type: "string" },
2802
- },
2803
- required: ["change_id"],
2804
- additionalProperties: false,
2805
- } as const satisfies LixSchemaDefinition;
2806
-
2807
- // Store the schema
2808
- await lix.db
2809
- .insertInto("stored_schema")
2810
- .values({ value: mockSchema })
2811
- .execute();
2812
-
2813
- const activeVersion = await lix.db
2814
- .selectFrom("active_version")
2815
- .select("version_id")
2816
- .executeTakeFirstOrThrow();
2817
-
2818
- // First create a key-value entity to generate a real change
2819
- await lix.db
2820
- .insertInto("key_value")
2821
- .values({
2822
- key: "test_key_for_change_ref",
2823
- value: "test_value",
2824
- })
2825
- .execute();
2826
-
2827
- // Get the change that was created
2828
- const changes = await lix.db
2829
- .selectFrom("change")
2830
- .where("entity_id", "=", "test_key_for_change_ref")
2831
- .where("schema_key", "=", "lix_key_value")
2832
- .selectAll()
2833
- .execute();
2834
-
2835
- expect(changes).toHaveLength(1);
2836
- const realChangeId = changes[0]!.id;
2837
-
2838
- // This should PASS because changes are versionless and can be referenced from global version
2839
- expect(() =>
2840
- validateStateMutation({
2841
- lix,
2842
- schema: mockSchema,
2843
- snapshot_content: {
2844
- change_id: realChangeId,
2845
- },
2846
- operation: "insert",
2847
- version_id: "global",
2848
- })
2849
- ).not.toThrowError();
2850
-
2851
- // This should ALSO PASS because changes are versionless and can be referenced from any version
2852
- expect(() =>
2853
- validateStateMutation({
2854
- lix,
2855
- schema: mockSchema,
2856
- snapshot_content: {
2857
- change_id: realChangeId,
2858
- },
2859
- operation: "insert",
2860
- version_id: activeVersion.version_id,
2861
- })
2862
- ).not.toThrowError();
2863
- });
2864
-
2865
- // State table foreign key tests
2866
- test("should validate composite foreign keys referencing state table", async () => {
2867
- const lix = await openLix({});
2868
-
2869
- // Create a schema that references state table with composite key (like entity_label does)
2870
- const mockStateReferenceSchema = {
2871
- type: "object",
2872
- "x-lix-version": "1.0",
2873
- "x-lix-key": "mock_state_reference",
2874
- "x-lix-primary-key": ["entity_id", "schema_key", "file_id", "tag"],
2875
- "x-lix-foreign-keys": [
2876
- {
2877
- properties: ["entity_id", "schema_key", "file_id"],
2878
- references: {
2879
- schemaKey: "state",
2880
- properties: ["entity_id", "schema_key", "file_id"],
2881
- },
2882
- },
2883
- ],
2884
- properties: {
2885
- entity_id: { type: "string" },
2886
- schema_key: { type: "string" },
2887
- file_id: { type: "string" },
2888
- tag: { type: "string" },
2889
- },
2890
- required: ["entity_id", "schema_key", "file_id", "tag"],
2891
- additionalProperties: false,
2892
- } as const satisfies LixSchemaDefinition;
2893
-
2894
- // Store the schema
2895
- await lix.db
2896
- .insertInto("stored_schema")
2897
- .values({ value: mockStateReferenceSchema })
2898
- .execute();
2899
-
2900
- const activeVersion = await lix.db
2901
- .selectFrom("active_version")
2902
- .select("version_id")
2903
- .executeTakeFirstOrThrow();
2904
-
2905
- // First create a state entity that can be referenced
2906
- await lix.db
2907
- .insertInto("state_all")
2908
- .values({
2909
- entity_id: "test_entity",
2910
- schema_key: "test_schema",
2911
- file_id: "test_file.json",
2912
- plugin_key: "test_plugin",
2913
- version_id: activeVersion.version_id,
2914
- snapshot_content: { id: "test_entity" },
2915
- schema_version: "1.0",
2916
- })
2917
- .execute();
2918
-
2919
- // This should PASS - entity exists in state table
2920
- expect(() =>
2921
- validateStateMutation({
2922
- lix,
2923
- schema: mockStateReferenceSchema,
2924
- snapshot_content: {
2925
- entity_id: "test_entity",
2926
- schema_key: "test_schema",
2927
- file_id: "test_file.json",
2928
- tag: "important",
2929
- },
2930
- operation: "insert",
2931
- version_id: activeVersion.version_id,
2932
- })
2933
- ).not.toThrowError();
2934
-
2935
- // This should FAIL - entity doesn't exist in state table
2936
- expect(() =>
2937
- validateStateMutation({
2938
- lix,
2939
- schema: mockStateReferenceSchema,
2940
- snapshot_content: {
2941
- entity_id: "nonexistent_entity",
2942
- schema_key: "test_schema",
2943
- file_id: "test_file.json",
2944
- tag: "important",
2945
- },
2946
- operation: "insert",
2947
- version_id: activeVersion.version_id,
2948
- })
2949
- ).toThrow(
2950
- /Foreign key constraint violation.*mock_state_reference.*\(entity_id, schema_key, file_id\).*state\.\(entity_id, schema_key, file_id\).*no matching record exists/
2951
- );
2952
- });
2953
-
2954
- test("state foreign key references should respect version context", async () => {
2955
- const lix = await openLix({});
2956
-
2957
- // Create a schema that references state table
2958
- const mockStateReferenceSchema = {
2959
- type: "object",
2960
- "x-lix-version": "1.0",
2961
- "x-lix-key": "mock_state_reference",
2962
- "x-lix-primary-key": ["entity_id", "schema_key", "file_id", "tag"],
2963
- "x-lix-foreign-keys": [
2964
- {
2965
- properties: ["entity_id", "schema_key", "file_id"],
2966
- references: {
2967
- schemaKey: "state",
2968
- properties: ["entity_id", "schema_key", "file_id"],
2969
- },
2970
- },
2971
- ],
2972
- properties: {
2973
- entity_id: { type: "string" },
2974
- schema_key: { type: "string" },
2975
- file_id: { type: "string" },
2976
- tag: { type: "string" },
2977
- },
2978
- required: ["entity_id", "schema_key", "file_id", "tag"],
2979
- additionalProperties: false,
2980
- } as const satisfies LixSchemaDefinition;
2981
-
2982
- // Store the schema
2983
- await lix.db
2984
- .insertInto("stored_schema")
2985
- .values({ value: mockStateReferenceSchema })
2986
- .execute();
2987
-
2988
- // Create a second version
2989
- const version2 = await createVersion({
2990
- lix,
2991
- name: "version2",
2992
- });
2993
-
2994
- // Get the main version
2995
- const mainVersion = await lix.db
2996
- .selectFrom("version")
2997
- .select("id")
2998
- .where("name", "=", "main")
2999
- .executeTakeFirstOrThrow();
3000
-
3001
- // Create state entity in main version only
3002
- await lix.db
3003
- .insertInto("state_all")
3004
- .values({
3005
- entity_id: "main_only_entity",
3006
- schema_key: "test_schema",
3007
- file_id: "test.json",
3008
- plugin_key: "test_plugin",
3009
- version_id: mainVersion.id,
3010
- snapshot_content: { id: "main_only_entity" },
3011
- schema_version: "1.0",
3012
- })
3013
- .execute();
3014
-
3015
- // Create state entity in version2 only
3016
- await lix.db
3017
- .insertInto("state_all")
3018
- .values({
3019
- entity_id: "version2_only_entity",
3020
- schema_key: "test_schema",
3021
- file_id: "test.json",
3022
- plugin_key: "test_plugin",
3023
- version_id: version2.id,
3024
- snapshot_content: { id: "version2_only_entity" },
3025
- schema_version: "1.0",
3026
- })
3027
- .execute();
3028
-
3029
- // Reference from main version should only see main entities
3030
- expect(() =>
3031
- validateStateMutation({
3032
- lix,
3033
- schema: mockStateReferenceSchema,
3034
- snapshot_content: {
3035
- entity_id: "main_only_entity",
3036
- schema_key: "test_schema",
3037
- file_id: "test.json",
3038
- tag: "tag1",
3039
- },
3040
- operation: "insert",
3041
- version_id: mainVersion.id,
3042
- })
3043
- ).not.toThrowError();
3044
-
3045
- // Reference from main version to version2 entity should fail
3046
- expect(() =>
3047
- validateStateMutation({
3048
- lix,
3049
- schema: mockStateReferenceSchema,
3050
- snapshot_content: {
3051
- entity_id: "version2_only_entity",
3052
- schema_key: "test_schema",
3053
- file_id: "test.json",
3054
- tag: "tag2",
3055
- },
3056
- operation: "insert",
3057
- version_id: mainVersion.id,
3058
- })
3059
- ).toThrow(/Foreign key constraint violation/);
3060
-
3061
- // Reference from version2 should only see version2 entities
3062
- expect(() =>
3063
- validateStateMutation({
3064
- lix,
3065
- schema: mockStateReferenceSchema,
3066
- snapshot_content: {
3067
- entity_id: "version2_only_entity",
3068
- schema_key: "test_schema",
3069
- file_id: "test.json",
3070
- tag: "tag3",
3071
- },
3072
- operation: "insert",
3073
- version_id: version2.id,
3074
- })
3075
- ).not.toThrowError();
3076
-
3077
- // Reference from version2 to main entity should fail
3078
- expect(() =>
3079
- validateStateMutation({
3080
- lix,
3081
- schema: mockStateReferenceSchema,
3082
- snapshot_content: {
3083
- entity_id: "main_only_entity",
3084
- schema_key: "test_schema",
3085
- file_id: "test.json",
3086
- tag: "tag4",
3087
- },
3088
- operation: "insert",
3089
- version_id: version2.id,
3090
- })
3091
- ).toThrow(/Foreign key constraint violation/);
3092
- });
3093
-
3094
- test("state foreign key references should handle inherited entities", async () => {
3095
- const lix = await openLix({});
3096
-
3097
- // Create a schema that references state table
3098
- const mockStateReferenceSchema = {
3099
- type: "object",
3100
- "x-lix-version": "1.0",
3101
- "x-lix-key": "mock_state_reference",
3102
- "x-lix-primary-key": ["entity_id", "schema_key", "file_id", "tag"],
3103
- "x-lix-foreign-keys": [
3104
- {
3105
- properties: ["entity_id", "schema_key", "file_id"],
3106
- references: {
3107
- schemaKey: "state",
3108
- properties: ["entity_id", "schema_key", "file_id"],
3109
- },
3110
- },
3111
- ],
3112
- properties: {
3113
- entity_id: { type: "string" },
3114
- schema_key: { type: "string" },
3115
- file_id: { type: "string" },
3116
- tag: { type: "string" },
3117
- },
3118
- required: ["entity_id", "schema_key", "file_id", "tag"],
3119
- additionalProperties: false,
3120
- } as const satisfies LixSchemaDefinition;
3121
-
3122
- // Store the schema
3123
- await lix.db
3124
- .insertInto("stored_schema")
3125
- .values({ value: mockStateReferenceSchema })
3126
- .execute();
3127
-
3128
- // Get the main version
3129
- const mainVersion = await lix.db
3130
- .selectFrom("version")
3131
- .select("id")
3132
- .where("name", "=", "main")
3133
- .executeTakeFirstOrThrow();
3134
-
3135
- // Create a state entity in main version
3136
- await lix.db
3137
- .insertInto("state_all")
3138
- .values({
3139
- entity_id: "shared_entity",
3140
- schema_key: "test_schema",
3141
- file_id: "test.json",
3142
- plugin_key: "test_plugin",
3143
- version_id: mainVersion.id,
3144
- snapshot_content: { id: "shared_entity", value: "original" },
3145
- schema_version: "1.0",
3146
- })
3147
- .execute();
3148
-
3149
- // Create a child version that inherits from main
3150
- const childVersion = await createVersion({
3151
- lix,
3152
- name: "child_version",
3153
- inherits_from_version_id: mainVersion.id,
3154
- });
3155
-
3156
- // The inherited entity should NOT be visible for foreign key validation
3157
- // because foreign keys only validate entities in the same version (not inherited)
3158
- expect(() =>
3159
- validateStateMutation({
3160
- lix,
3161
- schema: mockStateReferenceSchema,
3162
- snapshot_content: {
3163
- entity_id: "shared_entity",
3164
- schema_key: "test_schema",
3165
- file_id: "test.json",
3166
- tag: "from_child",
3167
- },
3168
- operation: "insert",
3169
- version_id: childVersion.id,
3170
- })
3171
- ).toThrow(
3172
- /Foreign key constraint violation.*no matching record exists.*Note: Foreign key constraints only validate entities that exist in the version context/s
3173
- );
3174
- });
3175
-
3176
- test("state foreign key with mixed single and composite properties", async () => {
3177
- const lix = await openLix({});
3178
-
3179
- // Create a complex schema with multiple foreign keys
3180
- const complexSchema = {
3181
- type: "object",
3182
- "x-lix-version": "1.0",
3183
- "x-lix-key": "complex_reference",
3184
- "x-lix-primary-key": ["id"],
3185
- "x-lix-foreign-keys": [
3186
- {
3187
- // Composite foreign key to state
3188
- properties: ["entity_id", "schema_key", "file_id"],
3189
- references: {
3190
- schemaKey: "state",
3191
- properties: ["entity_id", "schema_key", "file_id"],
3192
- },
3193
- },
3194
- {
3195
- // Single property foreign key to change
3196
- properties: ["change_id"],
3197
- references: {
3198
- schemaKey: "lix_change",
3199
- properties: ["id"],
3200
- },
3201
- },
3202
- ],
3203
- properties: {
3204
- id: { type: "string" },
3205
- entity_id: { type: "string" },
3206
- schema_key: { type: "string" },
3207
- file_id: { type: "string" },
3208
- change_id: { type: "string" },
3209
- },
3210
- required: ["id", "entity_id", "schema_key", "file_id", "change_id"],
3211
- additionalProperties: false,
3212
- } as const satisfies LixSchemaDefinition;
3213
-
3214
- // Store the schema
3215
- await lix.db
3216
- .insertInto("stored_schema")
3217
- .values({ value: complexSchema })
3218
- .execute();
3219
-
3220
- const activeVersion = await lix.db
3221
- .selectFrom("active_version")
3222
- .select("version_id")
3223
- .executeTakeFirstOrThrow();
3224
-
3225
- // Create a state entity
3226
- await lix.db
3227
- .insertInto("state_all")
3228
- .values({
3229
- entity_id: "test_entity",
3230
- schema_key: "test_schema",
3231
- file_id: "test.json",
3232
- plugin_key: "test_plugin",
3233
- version_id: activeVersion.version_id,
3234
- snapshot_content: { id: "test_entity" },
3235
- schema_version: "1.0",
3236
- })
3237
- .execute();
3238
-
3239
- // Create a key-value to generate a change
3240
- await lix.db
3241
- .insertInto("key_value")
3242
- .values({
3243
- key: "test_key",
3244
- value: "test_value",
3245
- })
3246
- .execute();
3247
-
3248
- // Get the created change
3249
- const changes = await lix.db
3250
- .selectFrom("change")
3251
- .select("id")
3252
- .where("entity_id", "=", "test_key")
3253
- .execute();
3254
-
3255
- expect(changes).toHaveLength(1);
3256
- const changeId = changes[0]!.id;
3257
-
3258
- // This should PASS - both foreign keys are satisfied
3259
- expect(() =>
3260
- validateStateMutation({
3261
- lix,
3262
- schema: complexSchema,
3263
- snapshot_content: {
3264
- id: "complex1",
3265
- entity_id: "test_entity",
3266
- schema_key: "test_schema",
3267
- file_id: "test.json",
3268
- change_id: changeId,
3269
- },
3270
- operation: "insert",
3271
- version_id: activeVersion.version_id,
3272
- })
3273
- ).not.toThrowError();
3274
-
3275
- // This should FAIL - state foreign key not satisfied
3276
- expect(() =>
3277
- validateStateMutation({
3278
- lix,
3279
- schema: complexSchema,
3280
- snapshot_content: {
3281
- id: "complex2",
3282
- entity_id: "nonexistent",
3283
- schema_key: "test_schema",
3284
- file_id: "test.json",
3285
- change_id: changeId,
3286
- },
3287
- operation: "insert",
3288
- version_id: activeVersion.version_id,
3289
- })
3290
- ).toThrow(/Foreign key constraint violation.*state/);
3291
-
3292
- // This should FAIL - change foreign key not satisfied
3293
- expect(() =>
3294
- validateStateMutation({
3295
- lix,
3296
- schema: complexSchema,
3297
- snapshot_content: {
3298
- id: "complex3",
3299
- entity_id: "test_entity",
3300
- schema_key: "test_schema",
3301
- file_id: "test.json",
3302
- change_id: "nonexistent_change",
3303
- },
3304
- operation: "insert",
3305
- version_id: activeVersion.version_id,
3306
- })
3307
- ).toThrow(/Foreign key constraint violation.*lix_change/);
3308
- });