@lix-js/sdk 0.5.0-preview.1 → 0.5.1

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