@lix-js/sdk 0.4.7 → 0.5.0-preview.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 (1812) hide show
  1. package/dist/account/create-account.d.ts +18 -4
  2. package/dist/account/create-account.d.ts.map +1 -1
  3. package/dist/account/create-account.js +27 -3
  4. package/dist/account/create-account.js.map +1 -1
  5. package/dist/account/create-account.test.js +42 -4
  6. package/dist/account/create-account.test.js.map +1 -1
  7. package/dist/account/index.d.ts +1 -1
  8. package/dist/account/index.d.ts.map +1 -1
  9. package/dist/account/index.js +1 -1
  10. package/dist/account/index.js.map +1 -1
  11. package/dist/account/schema.d.ts +44 -0
  12. package/dist/account/schema.d.ts.map +1 -0
  13. package/dist/account/schema.js +112 -0
  14. package/dist/account/schema.js.map +1 -0
  15. package/dist/account/schema.test.d.ts +2 -0
  16. package/dist/account/schema.test.d.ts.map +1 -0
  17. package/dist/account/schema.test.js +310 -0
  18. package/dist/account/schema.test.js.map +1 -0
  19. package/dist/account/switch-account.d.ts +2 -2
  20. package/dist/account/switch-account.d.ts.map +1 -1
  21. package/dist/account/switch-account.js +8 -2
  22. package/dist/account/switch-account.js.map +1 -1
  23. package/dist/account/switch-account.test.js +31 -10
  24. package/dist/account/switch-account.test.js.map +1 -1
  25. package/dist/change/apply-changes.d.ts +13 -0
  26. package/dist/change/apply-changes.d.ts.map +1 -1
  27. package/dist/change/apply-changes.js +14 -4
  28. package/dist/change/apply-changes.js.map +1 -1
  29. package/dist/change/apply-changes.test.js +91 -1
  30. package/dist/change/apply-changes.test.js.map +1 -1
  31. package/dist/change/create-change-v2.d.ts +11 -0
  32. package/dist/change/create-change-v2.d.ts.map +1 -0
  33. package/dist/change/create-change-v2.js +31 -0
  34. package/dist/change/create-change-v2.js.map +1 -0
  35. package/dist/change/create-change-v2.test.d.ts +2 -0
  36. package/dist/change/create-change-v2.test.d.ts.map +1 -0
  37. package/dist/change/create-change-v2.test.js +39 -0
  38. package/dist/change/create-change-v2.test.js.map +1 -0
  39. package/dist/change/create-change.d.ts +11 -22
  40. package/dist/change/create-change.d.ts.map +1 -1
  41. package/dist/change/create-change.js +31 -83
  42. package/dist/change/create-change.js.map +1 -1
  43. package/dist/change/create-change.test.js +127 -176
  44. package/dist/change/create-change.test.js.map +1 -1
  45. package/dist/change/index.d.ts +1 -2
  46. package/dist/change/index.d.ts.map +1 -1
  47. package/dist/change/index.js +1 -2
  48. package/dist/change/index.js.map +1 -1
  49. package/dist/change/mock-change.d.ts +1 -1
  50. package/dist/change/mock-change.d.ts.map +1 -1
  51. package/dist/change/mock-change.js +1 -0
  52. package/dist/change/mock-change.js.map +1 -1
  53. package/dist/change/schema.d.ts +66 -0
  54. package/dist/change/schema.d.ts.map +1 -0
  55. package/dist/change/schema.js +103 -0
  56. package/dist/change/schema.js.map +1 -0
  57. package/dist/change/schema.test.d.ts +2 -0
  58. package/dist/change/schema.test.d.ts.map +1 -0
  59. package/dist/change/schema.test.js +268 -0
  60. package/dist/change/schema.test.js.map +1 -0
  61. package/dist/change-author/index.d.ts +2 -0
  62. package/dist/change-author/index.d.ts.map +1 -0
  63. package/dist/change-author/index.js +2 -0
  64. package/dist/change-author/index.js.map +1 -0
  65. package/dist/change-author/schema.d.ts +34 -0
  66. package/dist/change-author/schema.d.ts.map +1 -0
  67. package/dist/change-author/schema.js +41 -0
  68. package/dist/change-author/schema.js.map +1 -0
  69. package/dist/change-author/schema.test.d.ts +2 -0
  70. package/dist/change-author/schema.test.d.ts.map +1 -0
  71. package/dist/change-author/schema.test.js +310 -0
  72. package/dist/change-author/schema.test.js.map +1 -0
  73. package/dist/change-conflict/create-change-conflict.d.ts.map +1 -1
  74. package/dist/change-conflict/create-change-conflict.js +24 -6
  75. package/dist/change-conflict/create-change-conflict.js.map +1 -1
  76. package/dist/change-conflict/create-change-conflict.test.js +13 -11
  77. package/dist/change-conflict/create-change-conflict.test.js.map +1 -1
  78. package/dist/change-conflict/detect-change-conflicts.d.ts.map +1 -1
  79. package/dist/change-conflict/detect-change-conflicts.js +2 -0
  80. package/dist/change-conflict/detect-change-conflicts.js.map +1 -1
  81. package/dist/change-conflict/detect-change-conflicts.test.js +17 -13
  82. package/dist/change-conflict/detect-change-conflicts.test.js.map +1 -1
  83. package/dist/change-conflict/detect-diverging-entity-conflict.d.ts.map +1 -1
  84. package/dist/change-conflict/detect-diverging-entity-conflict.js +3 -1
  85. package/dist/change-conflict/detect-diverging-entity-conflict.js.map +1 -1
  86. package/dist/change-conflict/detect-diverging-entity-conflict.test.js +23 -21
  87. package/dist/change-conflict/detect-diverging-entity-conflict.test.js.map +1 -1
  88. package/dist/change-conflict/garbage-collect-change-conflicts.d.ts.map +1 -1
  89. package/dist/change-conflict/garbage-collect-change-conflicts.js +2 -0
  90. package/dist/change-conflict/garbage-collect-change-conflicts.js.map +1 -1
  91. package/dist/change-conflict/garbage-collect-change-conflicts.test.js +15 -15
  92. package/dist/change-conflict/garbage-collect-change-conflicts.test.js.map +1 -1
  93. package/dist/change-conflict/resolve-conflict-by-selecting.d.ts.map +1 -1
  94. package/dist/change-conflict/resolve-conflict-by-selecting.js +2 -2
  95. package/dist/change-conflict/resolve-conflict-by-selecting.js.map +1 -1
  96. package/dist/change-conflict/resolve-conflict-by-selecting.test.js +17 -8
  97. package/dist/change-conflict/resolve-conflict-by-selecting.test.js.map +1 -1
  98. package/dist/change-proposal/create-change-proposal.d.ts +16 -0
  99. package/dist/change-proposal/create-change-proposal.d.ts.map +1 -0
  100. package/dist/change-proposal/create-change-proposal.js +52 -0
  101. package/dist/change-proposal/create-change-proposal.js.map +1 -0
  102. package/dist/change-proposal/create-change-proposal.test.d.ts +2 -0
  103. package/dist/change-proposal/create-change-proposal.test.d.ts.map +1 -0
  104. package/dist/change-proposal/create-change-proposal.test.js +91 -0
  105. package/dist/change-proposal/create-change-proposal.test.js.map +1 -0
  106. package/dist/change-proposal/database-schema.d.ts +13 -0
  107. package/dist/change-proposal/database-schema.d.ts.map +1 -0
  108. package/dist/change-proposal/database-schema.js +17 -0
  109. package/dist/change-proposal/database-schema.js.map +1 -0
  110. package/dist/change-proposal/database-schema.test.d.ts +2 -0
  111. package/dist/change-proposal/database-schema.test.d.ts.map +1 -0
  112. package/dist/change-proposal/database-schema.test.js +159 -0
  113. package/dist/change-proposal/database-schema.test.js.map +1 -0
  114. package/dist/change-proposal/index.d.ts +3 -0
  115. package/dist/change-proposal/index.d.ts.map +1 -0
  116. package/dist/change-proposal/index.js +3 -0
  117. package/dist/change-proposal/index.js.map +1 -0
  118. package/dist/change-set/apply-change-set.d.ts +10 -0
  119. package/dist/change-set/apply-change-set.d.ts.map +1 -0
  120. package/dist/change-set/apply-change-set.js +139 -0
  121. package/dist/change-set/apply-change-set.js.map +1 -0
  122. package/dist/change-set/apply-change-set.test.d.ts +2 -0
  123. package/dist/change-set/apply-change-set.test.d.ts.map +1 -0
  124. package/dist/change-set/apply-change-set.test.js +393 -0
  125. package/dist/change-set/apply-change-set.test.js.map +1 -0
  126. package/dist/change-set/before-after-of-file.d.ts +31 -0
  127. package/dist/change-set/before-after-of-file.d.ts.map +1 -0
  128. package/dist/change-set/before-after-of-file.js +191 -0
  129. package/dist/change-set/before-after-of-file.js.map +1 -0
  130. package/dist/change-set/before-after-of-file.test.d.ts +2 -0
  131. package/dist/change-set/before-after-of-file.test.d.ts.map +1 -0
  132. package/dist/change-set/before-after-of-file.test.js +221 -0
  133. package/dist/change-set/before-after-of-file.test.js.map +1 -0
  134. package/dist/change-set/change-set-element-in-symmetric-difference.d.ts +2 -1
  135. package/dist/change-set/change-set-element-in-symmetric-difference.d.ts.map +1 -1
  136. package/dist/change-set/change-set-element-in-symmetric-difference.js.map +1 -1
  137. package/dist/change-set/change-set-element-in-symmetric-difference.test.js +204 -34
  138. package/dist/change-set/change-set-element-in-symmetric-difference.test.js.map +1 -1
  139. package/dist/change-set/checkout-change-set.d.ts +15 -0
  140. package/dist/change-set/checkout-change-set.d.ts.map +1 -0
  141. package/dist/change-set/checkout-change-set.js +64 -0
  142. package/dist/change-set/checkout-change-set.js.map +1 -0
  143. package/dist/change-set/checkout-change-set.test.d.ts +2 -0
  144. package/dist/change-set/checkout-change-set.test.d.ts.map +1 -0
  145. package/dist/change-set/checkout-change-set.test.js +127 -0
  146. package/dist/change-set/checkout-change-set.test.js.map +1 -0
  147. package/dist/change-set/create-change-set.d.ts +19 -20
  148. package/dist/change-set/create-change-set.d.ts.map +1 -1
  149. package/dist/change-set/create-change-set.js +73 -34
  150. package/dist/change-set/create-change-set.js.map +1 -1
  151. package/dist/change-set/create-change-set.test.js +78 -27
  152. package/dist/change-set/create-change-set.test.js.map +1 -1
  153. package/dist/change-set/create-checkpoint.d.ts +19 -0
  154. package/dist/change-set/create-checkpoint.d.ts.map +1 -0
  155. package/dist/change-set/create-checkpoint.js +95 -0
  156. package/dist/change-set/create-checkpoint.js.map +1 -0
  157. package/dist/change-set/create-checkpoint.test.d.ts +2 -0
  158. package/dist/change-set/create-checkpoint.test.d.ts.map +1 -0
  159. package/dist/change-set/create-checkpoint.test.js +347 -0
  160. package/dist/change-set/create-checkpoint.test.js.map +1 -0
  161. package/dist/change-set/create-merge-change-set.d.ts +23 -0
  162. package/dist/change-set/create-merge-change-set.d.ts.map +1 -0
  163. package/dist/change-set/create-merge-change-set.js +68 -0
  164. package/dist/change-set/create-merge-change-set.js.map +1 -0
  165. package/dist/change-set/create-merge-change-set.test.d.ts +2 -0
  166. package/dist/change-set/create-merge-change-set.test.d.ts.map +1 -0
  167. package/dist/change-set/create-merge-change-set.test.js +211 -0
  168. package/dist/change-set/create-merge-change-set.test.js.map +1 -0
  169. package/dist/change-set/create-transition-change-set.d.ts +18 -0
  170. package/dist/change-set/create-transition-change-set.d.ts.map +1 -0
  171. package/dist/change-set/create-transition-change-set.js +102 -0
  172. package/dist/change-set/create-transition-change-set.js.map +1 -0
  173. package/dist/change-set/create-transition-change-set.test.d.ts +2 -0
  174. package/dist/change-set/create-transition-change-set.test.d.ts.map +1 -0
  175. package/dist/change-set/create-transition-change-set.test.js +211 -0
  176. package/dist/change-set/create-transition-change-set.test.js.map +1 -0
  177. package/dist/change-set/create-undo-change-set.d.ts +27 -0
  178. package/dist/change-set/create-undo-change-set.d.ts.map +1 -0
  179. package/dist/change-set/create-undo-change-set.js +122 -0
  180. package/dist/change-set/create-undo-change-set.js.map +1 -0
  181. package/dist/change-set/create-undo-change-set.test.d.ts +2 -0
  182. package/dist/change-set/create-undo-change-set.test.d.ts.map +1 -0
  183. package/dist/change-set/create-undo-change-set.test.js +273 -0
  184. package/dist/change-set/create-undo-change-set.test.js.map +1 -0
  185. package/dist/change-set/database-schema.d.ts +39 -0
  186. package/dist/change-set/database-schema.d.ts.map +1 -0
  187. package/dist/change-set/database-schema.js +86 -0
  188. package/dist/change-set/database-schema.js.map +1 -0
  189. package/dist/change-set/database-schema.test.d.ts +2 -0
  190. package/dist/change-set/database-schema.test.d.ts.map +1 -0
  191. package/dist/change-set/database-schema.test.js +547 -0
  192. package/dist/change-set/database-schema.test.js.map +1 -0
  193. package/dist/change-set/diff-for-file.d.ts +29 -0
  194. package/dist/change-set/diff-for-file.d.ts.map +1 -0
  195. package/dist/change-set/diff-for-file.js +19 -0
  196. package/dist/change-set/diff-for-file.js.map +1 -0
  197. package/dist/change-set/get-before-after-of-file.d.ts +31 -0
  198. package/dist/change-set/get-before-after-of-file.d.ts.map +1 -0
  199. package/dist/change-set/get-before-after-of-file.js +189 -0
  200. package/dist/change-set/get-before-after-of-file.js.map +1 -0
  201. package/dist/change-set/get-before-after-of-file.test.d.ts +2 -0
  202. package/dist/change-set/get-before-after-of-file.test.d.ts.map +1 -0
  203. package/dist/change-set/get-before-after-of-file.test.js +220 -0
  204. package/dist/change-set/get-before-after-of-file.test.js.map +1 -0
  205. package/dist/change-set/index.d.ts +2 -1
  206. package/dist/change-set/index.d.ts.map +1 -1
  207. package/dist/change-set/index.js +2 -1
  208. package/dist/change-set/index.js.map +1 -1
  209. package/dist/change-set/merge-change-sets.d.ts +23 -0
  210. package/dist/change-set/merge-change-sets.d.ts.map +1 -0
  211. package/dist/change-set/merge-change-sets.js +69 -0
  212. package/dist/change-set/merge-change-sets.js.map +1 -0
  213. package/dist/change-set/merge-change-sets.test.d.ts +2 -0
  214. package/dist/change-set/merge-change-sets.test.d.ts.map +1 -0
  215. package/dist/change-set/merge-change-sets.test.js +184 -0
  216. package/dist/change-set/merge-change-sets.test.js.map +1 -0
  217. package/dist/change-set/restore-change-set.d.ts +14 -0
  218. package/dist/change-set/restore-change-set.d.ts.map +1 -0
  219. package/dist/change-set/restore-change-set.js +98 -0
  220. package/dist/change-set/restore-change-set.js.map +1 -0
  221. package/dist/change-set/restore-change-set.test.d.ts +2 -0
  222. package/dist/change-set/restore-change-set.test.d.ts.map +1 -0
  223. package/dist/change-set/restore-change-set.test.js +238 -0
  224. package/dist/change-set/restore-change-set.test.js.map +1 -0
  225. package/dist/change-set/schema.d.ts +105 -0
  226. package/dist/change-set/schema.d.ts.map +1 -0
  227. package/dist/change-set/schema.js +122 -0
  228. package/dist/change-set/schema.js.map +1 -0
  229. package/dist/change-set/schema.test.d.ts +2 -0
  230. package/dist/change-set/schema.test.d.ts.map +1 -0
  231. package/dist/change-set/schema.test.js +574 -0
  232. package/dist/change-set/schema.test.js.map +1 -0
  233. package/dist/change-set-edge/database-schema.d.ts +11 -0
  234. package/dist/change-set-edge/database-schema.d.ts.map +1 -0
  235. package/dist/change-set-edge/database-schema.js +29 -0
  236. package/dist/change-set-edge/database-schema.js.map +1 -0
  237. package/dist/change-set-edge/database-schema.test.d.ts +2 -0
  238. package/dist/change-set-edge/database-schema.test.d.ts.map +1 -0
  239. package/dist/change-set-edge/database-schema.test.js +166 -0
  240. package/dist/change-set-edge/database-schema.test.js.map +1 -0
  241. package/dist/change-set-edge/index.d.ts +2 -0
  242. package/dist/change-set-edge/index.d.ts.map +1 -0
  243. package/dist/change-set-edge/index.js +2 -0
  244. package/dist/change-set-edge/index.js.map +1 -0
  245. package/dist/change-set-v2/apply-change-set.d.ts +10 -0
  246. package/dist/change-set-v2/apply-change-set.d.ts.map +1 -0
  247. package/dist/change-set-v2/apply-change-set.js +147 -0
  248. package/dist/change-set-v2/apply-change-set.js.map +1 -0
  249. package/dist/change-set-v2/apply-change-set.test.d.ts +2 -0
  250. package/dist/change-set-v2/apply-change-set.test.d.ts.map +1 -0
  251. package/dist/change-set-v2/apply-change-set.test.js +270 -0
  252. package/dist/change-set-v2/apply-change-set.test.js.map +1 -0
  253. package/dist/change-set-v2/create-change-set.d.ts +10 -0
  254. package/dist/change-set-v2/create-change-set.d.ts.map +1 -0
  255. package/dist/change-set-v2/create-change-set.js +57 -0
  256. package/dist/change-set-v2/create-change-set.js.map +1 -0
  257. package/dist/change-set-v2/create-change-set.test.d.ts +2 -0
  258. package/dist/change-set-v2/create-change-set.test.d.ts.map +1 -0
  259. package/dist/change-set-v2/create-change-set.test.js +59 -0
  260. package/dist/change-set-v2/create-change-set.test.js.map +1 -0
  261. package/dist/change-set-v2/create-checkpoint.d.ts +7 -0
  262. package/dist/change-set-v2/create-checkpoint.d.ts.map +1 -0
  263. package/dist/change-set-v2/create-checkpoint.js +79 -0
  264. package/dist/change-set-v2/create-checkpoint.js.map +1 -0
  265. package/dist/change-set-v2/create-checkpoint.test.d.ts +2 -0
  266. package/dist/change-set-v2/create-checkpoint.test.d.ts.map +1 -0
  267. package/dist/change-set-v2/create-checkpoint.test.js +289 -0
  268. package/dist/change-set-v2/create-checkpoint.test.js.map +1 -0
  269. package/dist/change-set-v2/create-merge-change-set.d.ts +23 -0
  270. package/dist/change-set-v2/create-merge-change-set.d.ts.map +1 -0
  271. package/dist/change-set-v2/create-merge-change-set.js +68 -0
  272. package/dist/change-set-v2/create-merge-change-set.js.map +1 -0
  273. package/dist/change-set-v2/create-merge-change-set.test.d.ts +2 -0
  274. package/dist/change-set-v2/create-merge-change-set.test.d.ts.map +1 -0
  275. package/dist/change-set-v2/create-merge-change-set.test.js +223 -0
  276. package/dist/change-set-v2/create-merge-change-set.test.js.map +1 -0
  277. package/dist/change-set-v2/index.d.ts +5 -0
  278. package/dist/change-set-v2/index.d.ts.map +1 -0
  279. package/dist/change-set-v2/index.js +5 -0
  280. package/dist/change-set-v2/index.js.map +1 -0
  281. package/dist/change-set-v2/schema.d.ts +50 -0
  282. package/dist/change-set-v2/schema.d.ts.map +1 -0
  283. package/dist/change-set-v2/schema.js +347 -0
  284. package/dist/change-set-v2/schema.js.map +1 -0
  285. package/dist/change-set-v2/schema.test.d.ts +2 -0
  286. package/dist/change-set-v2/schema.test.d.ts.map +1 -0
  287. package/dist/change-set-v2/schema.test.js +713 -0
  288. package/dist/change-set-v2/schema.test.js.map +1 -0
  289. package/dist/commit/apply-commit.d.ts +32 -0
  290. package/dist/commit/apply-commit.d.ts.map +1 -0
  291. package/dist/commit/apply-commit.js +63 -0
  292. package/dist/commit/apply-commit.js.map +1 -0
  293. package/dist/commit/apply-commit.test.d.ts +2 -0
  294. package/dist/commit/apply-commit.test.d.ts.map +1 -0
  295. package/dist/commit/apply-commit.test.js +367 -0
  296. package/dist/commit/apply-commit.test.js.map +1 -0
  297. package/dist/commit/create-checkpoint.d.ts +19 -0
  298. package/dist/commit/create-checkpoint.d.ts.map +1 -0
  299. package/dist/commit/create-checkpoint.js +118 -0
  300. package/dist/commit/create-checkpoint.js.map +1 -0
  301. package/dist/commit/create-checkpoint.test.d.ts +2 -0
  302. package/dist/commit/create-checkpoint.test.d.ts.map +1 -0
  303. package/dist/commit/create-checkpoint.test.js +472 -0
  304. package/dist/commit/create-checkpoint.test.js.map +1 -0
  305. package/dist/commit/create-commit.d.ts +38 -0
  306. package/dist/commit/create-commit.d.ts.map +1 -0
  307. package/dist/commit/create-commit.js +68 -0
  308. package/dist/commit/create-commit.js.map +1 -0
  309. package/dist/commit/create-merge-commit.d.ts +24 -0
  310. package/dist/commit/create-merge-commit.d.ts.map +1 -0
  311. package/dist/commit/create-merge-commit.js +103 -0
  312. package/dist/commit/create-merge-commit.js.map +1 -0
  313. package/dist/commit/create-merge-commit.test.d.ts +2 -0
  314. package/dist/commit/create-merge-commit.test.d.ts.map +1 -0
  315. package/dist/commit/create-merge-commit.test.js +242 -0
  316. package/dist/commit/create-merge-commit.test.js.map +1 -0
  317. package/dist/commit/create-transition-commit.d.ts +18 -0
  318. package/dist/commit/create-transition-commit.d.ts.map +1 -0
  319. package/dist/commit/create-transition-commit.js +136 -0
  320. package/dist/commit/create-transition-commit.js.map +1 -0
  321. package/dist/commit/create-transition-commit.test.d.ts +2 -0
  322. package/dist/commit/create-transition-commit.test.d.ts.map +1 -0
  323. package/dist/commit/create-transition-commit.test.js +221 -0
  324. package/dist/commit/create-transition-commit.test.js.map +1 -0
  325. package/dist/commit/create-undo-commit.d.ts +27 -0
  326. package/dist/commit/create-undo-commit.d.ts.map +1 -0
  327. package/dist/commit/create-undo-commit.js +143 -0
  328. package/dist/commit/create-undo-commit.js.map +1 -0
  329. package/dist/commit/create-undo-commit.test.d.ts +2 -0
  330. package/dist/commit/create-undo-commit.test.d.ts.map +1 -0
  331. package/dist/commit/create-undo-commit.test.js +298 -0
  332. package/dist/commit/create-undo-commit.test.js.map +1 -0
  333. package/dist/commit/index.d.ts +6 -0
  334. package/dist/commit/index.d.ts.map +1 -0
  335. package/dist/commit/index.js +6 -0
  336. package/dist/commit/index.js.map +1 -0
  337. package/dist/commit/schema.d.ts +73 -0
  338. package/dist/commit/schema.d.ts.map +1 -0
  339. package/dist/commit/schema.js +90 -0
  340. package/dist/commit/schema.js.map +1 -0
  341. package/dist/commit/schema.test.d.ts +2 -0
  342. package/dist/commit/schema.test.d.ts.map +1 -0
  343. package/dist/commit/schema.test.js +216 -0
  344. package/dist/commit/schema.test.js.map +1 -0
  345. package/dist/database/apply-schema.d.ts +3 -0
  346. package/dist/database/apply-schema.d.ts.map +1 -1
  347. package/dist/database/apply-schema.js +91 -258
  348. package/dist/database/apply-schema.js.map +1 -1
  349. package/dist/database/execute-sync.d.ts +12 -6
  350. package/dist/database/execute-sync.d.ts.map +1 -1
  351. package/dist/database/execute-sync.js +25 -24
  352. package/dist/database/execute-sync.js.map +1 -1
  353. package/dist/database/execute-sync.test.js +53 -60
  354. package/dist/database/execute-sync.test.js.map +1 -1
  355. package/dist/database/graph-traversal-mode.d.ts +72 -0
  356. package/dist/database/graph-traversal-mode.d.ts.map +1 -0
  357. package/dist/database/graph-traversal-mode.js +2 -0
  358. package/dist/database/graph-traversal-mode.js.map +1 -0
  359. package/dist/database/index.d.ts +1 -2
  360. package/dist/database/index.d.ts.map +1 -1
  361. package/dist/database/index.js +1 -2
  362. package/dist/database/index.js.map +1 -1
  363. package/dist/database/init-db.d.ts +2 -0
  364. package/dist/database/init-db.d.ts.map +1 -1
  365. package/dist/database/init-db.js +119 -67
  366. package/dist/database/init-db.js.map +1 -1
  367. package/dist/database/init-db.test.js +2 -480
  368. package/dist/database/init-db.test.js.map +1 -1
  369. package/dist/database/kysely-plugin/json-column-plugin.d.ts +7 -0
  370. package/dist/database/kysely-plugin/json-column-plugin.d.ts.map +1 -0
  371. package/dist/database/kysely-plugin/json-column-plugin.js +210 -0
  372. package/dist/database/kysely-plugin/json-column-plugin.js.map +1 -0
  373. package/dist/database/kysely-plugin/json-column-plugin.test.d.ts +2 -0
  374. package/dist/database/kysely-plugin/json-column-plugin.test.d.ts.map +1 -0
  375. package/dist/database/kysely-plugin/json-column-plugin.test.js +329 -0
  376. package/dist/database/kysely-plugin/json-column-plugin.test.js.map +1 -0
  377. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.d.ts.map +1 -1
  378. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js +5 -10
  379. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js.map +1 -1
  380. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.js +1 -1
  381. package/dist/database/kysely-plugin/parse-jsonb-plugin-v2.js.map +1 -1
  382. package/dist/database/kysely-plugin/serialize-jsonb-plugin.d.ts +14 -2
  383. package/dist/database/kysely-plugin/serialize-jsonb-plugin.d.ts.map +1 -1
  384. package/dist/database/kysely-plugin/serialize-jsonb-plugin.js +145 -74
  385. package/dist/database/kysely-plugin/serialize-jsonb-plugin.js.map +1 -1
  386. package/dist/database/kysely-plugin/serialize-jsonb-plugin.test.js +145 -1
  387. package/dist/database/kysely-plugin/serialize-jsonb-plugin.test.js.map +1 -1
  388. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.d.ts +15 -0
  389. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.d.ts.map +1 -0
  390. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.js +31 -0
  391. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.js.map +1 -0
  392. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.test.d.ts +2 -0
  393. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.test.d.ts.map +1 -0
  394. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.test.js +51 -0
  395. package/dist/database/kysely-plugin/view-insert-returning-error-plugin.test.js.map +1 -0
  396. package/dist/database/mutation-log/database-schema.d.ts.map +1 -1
  397. package/dist/database/mutation-log/database-schema.js +0 -4
  398. package/dist/database/mutation-log/database-schema.js.map +1 -1
  399. package/dist/database/nano-id.d.ts +4 -1
  400. package/dist/database/nano-id.d.ts.map +1 -1
  401. package/dist/database/nano-id.js +4 -1
  402. package/dist/database/nano-id.js.map +1 -1
  403. package/dist/database/nano-id.test.js +3 -3
  404. package/dist/database/nano-id.test.js.map +1 -1
  405. package/dist/database/schema.d.ts +50 -209
  406. package/dist/database/schema.d.ts.map +1 -1
  407. package/dist/database/schema.js +39 -1
  408. package/dist/database/schema.js.map +1 -1
  409. package/dist/deterministic/generate-human-id.d.ts +20 -0
  410. package/dist/deterministic/generate-human-id.d.ts.map +1 -0
  411. package/dist/deterministic/generate-human-id.js +86 -0
  412. package/dist/deterministic/generate-human-id.js.map +1 -0
  413. package/dist/deterministic/generate-human-id.test.d.ts +2 -0
  414. package/dist/deterministic/generate-human-id.test.d.ts.map +1 -0
  415. package/dist/deterministic/generate-human-id.test.js +123 -0
  416. package/dist/deterministic/generate-human-id.test.js.map +1 -0
  417. package/dist/deterministic/index.d.ts +8 -0
  418. package/dist/deterministic/index.d.ts.map +1 -0
  419. package/dist/deterministic/index.js +8 -0
  420. package/dist/deterministic/index.js.map +1 -0
  421. package/dist/deterministic/is-deterministic-mode.d.ts +14 -0
  422. package/dist/deterministic/is-deterministic-mode.d.ts.map +1 -0
  423. package/dist/deterministic/is-deterministic-mode.js +25 -0
  424. package/dist/deterministic/is-deterministic-mode.js.map +1 -0
  425. package/dist/deterministic/is-deterministic-mode.test.d.ts +2 -0
  426. package/dist/deterministic/is-deterministic-mode.test.d.ts.map +1 -0
  427. package/dist/deterministic/is-deterministic-mode.test.js +103 -0
  428. package/dist/deterministic/is-deterministic-mode.test.js.map +1 -0
  429. package/dist/deterministic/nano-id.d.ts +61 -0
  430. package/dist/deterministic/nano-id.d.ts.map +1 -0
  431. package/dist/deterministic/nano-id.js +161 -0
  432. package/dist/deterministic/nano-id.js.map +1 -0
  433. package/dist/deterministic/nano-id.test.d.ts +2 -0
  434. package/dist/deterministic/nano-id.test.d.ts.map +1 -0
  435. package/dist/deterministic/nano-id.test.js +163 -0
  436. package/dist/deterministic/nano-id.test.js.map +1 -0
  437. package/dist/deterministic/options.d.ts +53 -0
  438. package/dist/deterministic/options.d.ts.map +1 -0
  439. package/dist/deterministic/options.js +52 -0
  440. package/dist/deterministic/options.js.map +1 -0
  441. package/dist/deterministic/options.test.d.ts +2 -0
  442. package/dist/deterministic/options.test.d.ts.map +1 -0
  443. package/dist/deterministic/options.test.js +111 -0
  444. package/dist/deterministic/options.test.js.map +1 -0
  445. package/dist/deterministic/random.d.ts +68 -0
  446. package/dist/deterministic/random.d.ts.map +1 -0
  447. package/dist/deterministic/random.js +225 -0
  448. package/dist/deterministic/random.js.map +1 -0
  449. package/dist/deterministic/random.test.d.ts +2 -0
  450. package/dist/deterministic/random.test.d.ts.map +1 -0
  451. package/dist/deterministic/random.test.js +244 -0
  452. package/dist/deterministic/random.test.js.map +1 -0
  453. package/dist/deterministic/sequence.d.ts +56 -0
  454. package/dist/deterministic/sequence.d.ts.map +1 -0
  455. package/dist/deterministic/sequence.js +107 -0
  456. package/dist/deterministic/sequence.js.map +1 -0
  457. package/dist/deterministic/sequence.test.d.ts +2 -0
  458. package/dist/deterministic/sequence.test.d.ts.map +1 -0
  459. package/dist/deterministic/sequence.test.js +71 -0
  460. package/dist/deterministic/sequence.test.js.map +1 -0
  461. package/dist/deterministic/timestamp.d.ts +47 -0
  462. package/dist/deterministic/timestamp.d.ts.map +1 -0
  463. package/dist/deterministic/timestamp.js +74 -0
  464. package/dist/deterministic/timestamp.js.map +1 -0
  465. package/dist/deterministic/timestamp.test.d.ts +2 -0
  466. package/dist/deterministic/timestamp.test.d.ts.map +1 -0
  467. package/dist/deterministic/timestamp.test.js +145 -0
  468. package/dist/deterministic/timestamp.test.js.map +1 -0
  469. package/dist/deterministic/uuid-v7.d.ts +49 -0
  470. package/dist/deterministic/uuid-v7.d.ts.map +1 -0
  471. package/dist/deterministic/uuid-v7.js +75 -0
  472. package/dist/deterministic/uuid-v7.js.map +1 -0
  473. package/dist/deterministic/uuid-v7.test.d.ts +2 -0
  474. package/dist/deterministic/uuid-v7.test.d.ts.map +1 -0
  475. package/dist/deterministic/uuid-v7.test.js +114 -0
  476. package/dist/deterministic/uuid-v7.test.js.map +1 -0
  477. package/dist/discussion/create-discussion.d.ts +2 -1
  478. package/dist/discussion/create-discussion.d.ts.map +1 -1
  479. package/dist/discussion/create-discussion.js.map +1 -1
  480. package/dist/discussion/create-discussion.test.js +13 -2
  481. package/dist/discussion/create-discussion.test.js.map +1 -1
  482. package/dist/entity/eb-entity.d.ts +76 -0
  483. package/dist/entity/eb-entity.d.ts.map +1 -0
  484. package/dist/entity/eb-entity.js +156 -0
  485. package/dist/entity/eb-entity.js.map +1 -0
  486. package/dist/entity/eb-entity.test.d.ts +2 -0
  487. package/dist/entity/eb-entity.test.d.ts.map +1 -0
  488. package/dist/entity/eb-entity.test.js +573 -0
  489. package/dist/entity/eb-entity.test.js.map +1 -0
  490. package/dist/entity/index.d.ts +7 -0
  491. package/dist/entity/index.d.ts.map +1 -0
  492. package/dist/entity/index.js +4 -0
  493. package/dist/entity/index.js.map +1 -0
  494. package/dist/entity/label/create-entity-label.d.ts +61 -0
  495. package/dist/entity/label/create-entity-label.d.ts.map +1 -0
  496. package/dist/entity/label/create-entity-label.js +92 -0
  497. package/dist/entity/label/create-entity-label.js.map +1 -0
  498. package/dist/entity/label/create-entity-label.test.d.ts +2 -0
  499. package/dist/entity/label/create-entity-label.test.d.ts.map +1 -0
  500. package/dist/entity/label/create-entity-label.test.js +261 -0
  501. package/dist/entity/label/create-entity-label.test.js.map +1 -0
  502. package/dist/entity/label/schema.d.ts +40 -0
  503. package/dist/entity/label/schema.d.ts.map +1 -0
  504. package/dist/entity/label/schema.js +42 -0
  505. package/dist/entity/label/schema.js.map +1 -0
  506. package/dist/entity/label/schema.test.d.ts +2 -0
  507. package/dist/entity/label/schema.test.d.ts.map +1 -0
  508. package/dist/entity/label/schema.test.js +596 -0
  509. package/dist/entity/label/schema.test.js.map +1 -0
  510. package/dist/entity/schema.d.ts +13 -0
  511. package/dist/entity/schema.d.ts.map +1 -0
  512. package/dist/entity/schema.js +5 -0
  513. package/dist/entity/schema.js.map +1 -0
  514. package/dist/entity/thread/create-entity-thread.d.ts +75 -0
  515. package/dist/entity/thread/create-entity-thread.d.ts.map +1 -0
  516. package/dist/entity/thread/create-entity-thread.js +109 -0
  517. package/dist/entity/thread/create-entity-thread.js.map +1 -0
  518. package/dist/entity/thread/create-entity-thread.test.d.ts +2 -0
  519. package/dist/entity/thread/create-entity-thread.test.d.ts.map +1 -0
  520. package/dist/entity/thread/create-entity-thread.test.js +240 -0
  521. package/dist/entity/thread/create-entity-thread.test.js.map +1 -0
  522. package/dist/entity/thread/query-threads.test.d.ts +2 -0
  523. package/dist/entity/thread/query-threads.test.d.ts.map +1 -0
  524. package/dist/entity/thread/query-threads.test.js +330 -0
  525. package/dist/entity/thread/query-threads.test.js.map +1 -0
  526. package/dist/entity/thread/schema.d.ts +40 -0
  527. package/dist/entity/thread/schema.d.ts.map +1 -0
  528. package/dist/entity/thread/schema.js +42 -0
  529. package/dist/entity/thread/schema.js.map +1 -0
  530. package/dist/entity/thread/schema.test.d.ts +2 -0
  531. package/dist/entity/thread/schema.test.d.ts.map +1 -0
  532. package/dist/entity/thread/schema.test.js +144 -0
  533. package/dist/entity/thread/schema.test.js.map +1 -0
  534. package/dist/entity-views/entity-state-all.d.ts +269 -0
  535. package/dist/entity-views/entity-state-all.d.ts.map +1 -0
  536. package/dist/entity-views/entity-state-all.js +254 -0
  537. package/dist/entity-views/entity-state-all.js.map +1 -0
  538. package/dist/entity-views/entity-state-all.test.d.ts +2 -0
  539. package/dist/entity-views/entity-state-all.test.d.ts.map +1 -0
  540. package/dist/entity-views/entity-state-all.test.js +544 -0
  541. package/dist/entity-views/entity-state-all.test.js.map +1 -0
  542. package/dist/entity-views/entity-state-history.d.ts +218 -0
  543. package/dist/entity-views/entity-state-history.d.ts.map +1 -0
  544. package/dist/entity-views/entity-state-history.js +61 -0
  545. package/dist/entity-views/entity-state-history.js.map +1 -0
  546. package/dist/entity-views/entity-state-history.test.d.ts +2 -0
  547. package/dist/entity-views/entity-state-history.test.d.ts.map +1 -0
  548. package/dist/entity-views/entity-state-history.test.js +329 -0
  549. package/dist/entity-views/entity-state-history.test.js.map +1 -0
  550. package/dist/entity-views/entity-state.d.ts +269 -0
  551. package/dist/entity-views/entity-state.d.ts.map +1 -0
  552. package/dist/entity-views/entity-state.js +251 -0
  553. package/dist/entity-views/entity-state.js.map +1 -0
  554. package/dist/entity-views/entity-state.test.d.ts +2 -0
  555. package/dist/entity-views/entity-state.test.d.ts.map +1 -0
  556. package/dist/entity-views/entity-state.test.js +616 -0
  557. package/dist/entity-views/entity-state.test.js.map +1 -0
  558. package/dist/entity-views/entity-view-builder.d.ts +92 -0
  559. package/dist/entity-views/entity-view-builder.d.ts.map +1 -0
  560. package/dist/entity-views/entity-view-builder.js +63 -0
  561. package/dist/entity-views/entity-view-builder.js.map +1 -0
  562. package/dist/entity-views/entity-view-builder.test.d.ts +2 -0
  563. package/dist/entity-views/entity-view-builder.test.d.ts.map +1 -0
  564. package/dist/entity-views/entity-view-builder.test.js +247 -0
  565. package/dist/entity-views/entity-view-builder.test.js.map +1 -0
  566. package/dist/entity-views/index.d.ts +2 -0
  567. package/dist/entity-views/index.d.ts.map +1 -0
  568. package/dist/entity-views/index.js +2 -0
  569. package/dist/entity-views/index.js.map +1 -0
  570. package/dist/entity-views/types.d.ts +309 -0
  571. package/dist/entity-views/types.d.ts.map +1 -0
  572. package/dist/entity-views/types.js +2 -0
  573. package/dist/entity-views/types.js.map +1 -0
  574. package/dist/entity-views/types.test.d.ts +2 -0
  575. package/dist/entity-views/types.test.d.ts.map +1 -0
  576. package/dist/entity-views/types.test.js +62 -0
  577. package/dist/entity-views/types.test.js.map +1 -0
  578. package/dist/file/database-schema.d.ts +25 -0
  579. package/dist/file/database-schema.d.ts.map +1 -0
  580. package/dist/file/database-schema.js +26 -0
  581. package/dist/file/database-schema.js.map +1 -0
  582. package/dist/file/database-schema.test.d.ts +2 -0
  583. package/dist/file/database-schema.test.d.ts.map +1 -0
  584. package/dist/file/database-schema.test.js +60 -0
  585. package/dist/file/database-schema.test.js.map +1 -0
  586. package/dist/file/file-handlers.d.ts +15 -0
  587. package/dist/file/file-handlers.d.ts.map +1 -0
  588. package/dist/file/file-handlers.js +354 -0
  589. package/dist/file/file-handlers.js.map +1 -0
  590. package/dist/file/file-handlers.test.d.ts +2 -0
  591. package/dist/file/file-handlers.test.d.ts.map +1 -0
  592. package/dist/file/file-handlers.test.js +151 -0
  593. package/dist/file/file-handlers.test.js.map +1 -0
  594. package/dist/file/index.d.ts +1 -1
  595. package/dist/file/index.d.ts.map +1 -1
  596. package/dist/file/index.js +1 -1
  597. package/dist/file/index.js.map +1 -1
  598. package/dist/file/materialize-file-data-at-changeset.d.ts +9 -0
  599. package/dist/file/materialize-file-data-at-changeset.d.ts.map +1 -0
  600. package/dist/file/materialize-file-data-at-changeset.js +119 -0
  601. package/dist/file/materialize-file-data-at-changeset.js.map +1 -0
  602. package/dist/file/materialize-file-data-at-commit.d.ts +9 -0
  603. package/dist/file/materialize-file-data-at-commit.d.ts.map +1 -0
  604. package/dist/file/materialize-file-data-at-commit.js +119 -0
  605. package/dist/file/materialize-file-data-at-commit.js.map +1 -0
  606. package/dist/file/materialize-file-data.d.ts +8 -0
  607. package/dist/file/materialize-file-data.d.ts.map +1 -0
  608. package/dist/file/materialize-file-data.js +91 -0
  609. package/dist/file/materialize-file-data.js.map +1 -0
  610. package/dist/file/materialize-file-data.test.d.ts +2 -0
  611. package/dist/file/materialize-file-data.test.d.ts.map +1 -0
  612. package/dist/file/materialize-file-data.test.js +90 -0
  613. package/dist/file/materialize-file-data.test.js.map +1 -0
  614. package/dist/file/schema.d.ts +109 -0
  615. package/dist/file/schema.d.ts.map +1 -0
  616. package/dist/file/schema.js +333 -0
  617. package/dist/file/schema.js.map +1 -0
  618. package/dist/file/schema.test.d.ts +2 -0
  619. package/dist/file/schema.test.d.ts.map +1 -0
  620. package/dist/file/schema.test.js +1313 -0
  621. package/dist/file/schema.test.js.map +1 -0
  622. package/dist/file/store-detected-change-schema.d.ts +8 -0
  623. package/dist/file/store-detected-change-schema.d.ts.map +1 -0
  624. package/dist/file/store-detected-change-schema.js +41 -0
  625. package/dist/file/store-detected-change-schema.js.map +1 -0
  626. package/dist/file/store-detected-change-schema.test.d.ts +2 -0
  627. package/dist/file/store-detected-change-schema.test.d.ts.map +1 -0
  628. package/dist/file/store-detected-change-schema.test.js +211 -0
  629. package/dist/file/store-detected-change-schema.test.js.map +1 -0
  630. package/dist/file/unknown-file-fallback-plugin.d.ts +22 -0
  631. package/dist/file/unknown-file-fallback-plugin.d.ts.map +1 -0
  632. package/dist/file/unknown-file-fallback-plugin.js +73 -0
  633. package/dist/file/unknown-file-fallback-plugin.js.map +1 -0
  634. package/dist/file/unknown-file-fallback-plugin.test.d.ts +2 -0
  635. package/dist/file/unknown-file-fallback-plugin.test.d.ts.map +1 -0
  636. package/dist/file/unknown-file-fallback-plugin.test.js +305 -0
  637. package/dist/file/unknown-file-fallback-plugin.test.js.map +1 -0
  638. package/dist/file-queue/database-schema.d.ts +17 -0
  639. package/dist/file-queue/database-schema.d.ts.map +1 -0
  640. package/dist/file-queue/database-schema.js +53 -0
  641. package/dist/file-queue/database-schema.js.map +1 -0
  642. package/dist/file-queue/file-handlers.d.ts +1 -1
  643. package/dist/file-queue/file-handlers.d.ts.map +1 -1
  644. package/dist/file-queue/file-handlers.js +60 -29
  645. package/dist/file-queue/file-handlers.js.map +1 -1
  646. package/dist/file-queue/file-queue-process.d.ts.map +1 -1
  647. package/dist/file-queue/file-queue-process.js +26 -17
  648. package/dist/file-queue/file-queue-process.js.map +1 -1
  649. package/dist/file-queue/file-queue-process.test.js +133 -43
  650. package/dist/file-queue/file-queue-process.test.js.map +1 -1
  651. package/dist/file-queue/with-skip-file-queue.d.ts +18 -0
  652. package/dist/file-queue/with-skip-file-queue.d.ts.map +1 -1
  653. package/dist/file-queue/with-skip-file-queue.js +56 -10
  654. package/dist/file-queue/with-skip-file-queue.js.map +1 -1
  655. package/dist/file-queue/with-skip-file-queue.test.js +28 -12
  656. package/dist/file-queue/with-skip-file-queue.test.js.map +1 -1
  657. package/dist/hooks/create-hooks.d.ts +50 -0
  658. package/dist/hooks/create-hooks.d.ts.map +1 -0
  659. package/dist/hooks/create-hooks.js +25 -0
  660. package/dist/hooks/create-hooks.js.map +1 -0
  661. package/dist/hooks/create-hooks.test.d.ts +2 -0
  662. package/dist/hooks/create-hooks.test.d.ts.map +1 -0
  663. package/dist/hooks/create-hooks.test.js +98 -0
  664. package/dist/hooks/create-hooks.test.js.map +1 -0
  665. package/dist/hooks/index.d.ts +2 -0
  666. package/dist/hooks/index.d.ts.map +1 -0
  667. package/dist/hooks/index.js +2 -0
  668. package/dist/hooks/index.js.map +1 -0
  669. package/dist/index.d.ts +13 -6
  670. package/dist/index.d.ts.map +1 -1
  671. package/dist/index.js +13 -6
  672. package/dist/index.js.map +1 -1
  673. package/dist/key-value/database-schema.d.ts +3 -2
  674. package/dist/key-value/database-schema.d.ts.map +1 -1
  675. package/dist/key-value/database-schema.js +3 -3
  676. package/dist/key-value/database-schema.test.js +13 -4
  677. package/dist/key-value/database-schema.test.js.map +1 -1
  678. package/dist/key-value/index.d.ts +2 -0
  679. package/dist/key-value/index.d.ts.map +1 -0
  680. package/dist/key-value/index.js +2 -0
  681. package/dist/key-value/index.js.map +1 -0
  682. package/dist/key-value/schema.d.ts +81 -0
  683. package/dist/key-value/schema.d.ts.map +1 -0
  684. package/dist/key-value/schema.js +31 -0
  685. package/dist/key-value/schema.js.map +1 -0
  686. package/dist/key-value/schema.test.d.ts +2 -0
  687. package/dist/key-value/schema.test.d.ts.map +1 -0
  688. package/dist/key-value/schema.test.js +237 -0
  689. package/dist/key-value/schema.test.js.map +1 -0
  690. package/dist/key-value-v2/schema.d.ts +27 -0
  691. package/dist/key-value-v2/schema.d.ts.map +1 -0
  692. package/dist/key-value-v2/schema.js +73 -0
  693. package/dist/key-value-v2/schema.js.map +1 -0
  694. package/dist/key-value-v2/schema.test.d.ts +2 -0
  695. package/dist/key-value-v2/schema.test.d.ts.map +1 -0
  696. package/dist/key-value-v2/schema.test.js +144 -0
  697. package/dist/key-value-v2/schema.test.js.map +1 -0
  698. package/dist/label/create-label.d.ts +20 -0
  699. package/dist/label/create-label.d.ts.map +1 -0
  700. package/dist/label/create-label.js +45 -0
  701. package/dist/label/create-label.js.map +1 -0
  702. package/dist/label/create-label.test.d.ts +2 -0
  703. package/dist/label/create-label.test.d.ts.map +1 -0
  704. package/dist/label/create-label.test.js +191 -0
  705. package/dist/label/create-label.test.js.map +1 -0
  706. package/dist/label/index.d.ts +3 -0
  707. package/dist/label/index.d.ts.map +1 -0
  708. package/dist/label/index.js +3 -0
  709. package/dist/label/index.js.map +1 -0
  710. package/dist/label/schema.d.ts +22 -0
  711. package/dist/label/schema.d.ts.map +1 -0
  712. package/dist/label/schema.js +26 -0
  713. package/dist/label/schema.js.map +1 -0
  714. package/dist/label/schema.test.d.ts +2 -0
  715. package/dist/label/schema.test.d.ts.map +1 -0
  716. package/dist/label/schema.test.js +76 -0
  717. package/dist/label/schema.test.js.map +1 -0
  718. package/dist/lix/index.d.ts +3 -3
  719. package/dist/lix/index.d.ts.map +1 -1
  720. package/dist/lix/index.js +3 -6
  721. package/dist/lix/index.js.map +1 -1
  722. package/dist/lix/merge.test.js +4 -1
  723. package/dist/lix/merge.test.js.map +1 -1
  724. package/dist/lix/new-lix.d.ts +79 -4
  725. package/dist/lix/new-lix.d.ts.map +1 -1
  726. package/dist/lix/new-lix.js +487 -8
  727. package/dist/lix/new-lix.js.map +1 -1
  728. package/dist/lix/new-lix.test.js +346 -17
  729. package/dist/lix/new-lix.test.js.map +1 -1
  730. package/dist/lix/open-lix-in-memory.test.js +2 -7
  731. package/dist/lix/open-lix-in-memory.test.js.map +1 -1
  732. package/dist/lix/open-lix.d.ts +68 -7
  733. package/dist/lix/open-lix.d.ts.map +1 -1
  734. package/dist/lix/open-lix.js +190 -32
  735. package/dist/lix/open-lix.js.map +1 -1
  736. package/dist/lix/open-lix.test.js +296 -25
  737. package/dist/lix/open-lix.test.js.map +1 -1
  738. package/dist/lix/storage/in-memory.d.ts +35 -0
  739. package/dist/lix/storage/in-memory.d.ts.map +1 -0
  740. package/dist/lix/storage/in-memory.js +50 -0
  741. package/dist/lix/storage/in-memory.js.map +1 -0
  742. package/dist/lix/storage/in-memory.test.d.ts +2 -0
  743. package/dist/lix/storage/in-memory.test.d.ts.map +1 -0
  744. package/dist/lix/storage/in-memory.test.js +85 -0
  745. package/dist/lix/storage/in-memory.test.js.map +1 -0
  746. package/dist/lix/storage/lix-storage-adapter.d.ts +46 -0
  747. package/dist/lix/storage/lix-storage-adapter.d.ts.map +1 -0
  748. package/dist/lix/storage/lix-storage-adapter.js +2 -0
  749. package/dist/lix/storage/lix-storage-adapter.js.map +1 -0
  750. package/dist/lix/storage/opfs.d.ts +95 -0
  751. package/dist/lix/storage/opfs.d.ts.map +1 -0
  752. package/dist/lix/storage/opfs.js +263 -0
  753. package/dist/lix/storage/opfs.js.map +1 -0
  754. package/dist/lix/storage/opfs.test.d.ts +2 -0
  755. package/dist/lix/storage/opfs.test.d.ts.map +1 -0
  756. package/dist/lix/storage/opfs.test.js +350 -0
  757. package/dist/lix/storage/opfs.test.js.map +1 -0
  758. package/dist/log/create-lix-own-log.d.ts +74 -0
  759. package/dist/log/create-lix-own-log.d.ts.map +1 -0
  760. package/dist/log/create-lix-own-log.js +92 -0
  761. package/dist/log/create-lix-own-log.js.map +1 -0
  762. package/dist/log/create-lix-own-log.test.d.ts +2 -0
  763. package/dist/log/create-lix-own-log.test.d.ts.map +1 -0
  764. package/dist/log/create-lix-own-log.test.js +85 -0
  765. package/dist/log/create-lix-own-log.test.js.map +1 -0
  766. package/dist/log/create-log.d.ts +32 -0
  767. package/dist/log/create-log.d.ts.map +1 -0
  768. package/dist/log/create-log.js +43 -0
  769. package/dist/log/create-log.js.map +1 -0
  770. package/dist/log/database-schema.d.ts +33 -0
  771. package/dist/log/database-schema.d.ts.map +1 -0
  772. package/dist/log/database-schema.js +14 -0
  773. package/dist/log/database-schema.js.map +1 -0
  774. package/dist/log/database-schema.test.d.ts +2 -0
  775. package/dist/log/database-schema.test.d.ts.map +1 -0
  776. package/dist/log/database-schema.test.js +22 -0
  777. package/dist/log/database-schema.test.js.map +1 -0
  778. package/dist/log/index.d.ts +3 -0
  779. package/dist/log/index.d.ts.map +1 -0
  780. package/dist/log/index.js +3 -0
  781. package/dist/log/index.js.map +1 -0
  782. package/dist/log/schema.d.ts +32 -0
  783. package/dist/log/schema.d.ts.map +1 -0
  784. package/dist/log/schema.js +42 -0
  785. package/dist/log/schema.js.map +1 -0
  786. package/dist/log/schema.test.d.ts +2 -0
  787. package/dist/log/schema.test.d.ts.map +1 -0
  788. package/dist/log/schema.test.js +119 -0
  789. package/dist/log/schema.test.js.map +1 -0
  790. package/dist/observe/create-observe.d.ts +17 -0
  791. package/dist/observe/create-observe.d.ts.map +1 -0
  792. package/dist/observe/create-observe.js +147 -0
  793. package/dist/observe/create-observe.js.map +1 -0
  794. package/dist/observe/create-observe.test.d.ts +2 -0
  795. package/dist/observe/create-observe.test.d.ts.map +1 -0
  796. package/dist/observe/create-observe.test.js +638 -0
  797. package/dist/observe/create-observe.test.js.map +1 -0
  798. package/dist/observe/determine-schema-keys.d.ts +6 -0
  799. package/dist/observe/determine-schema-keys.d.ts.map +1 -0
  800. package/dist/observe/determine-schema-keys.js +145 -0
  801. package/dist/observe/determine-schema-keys.js.map +1 -0
  802. package/dist/observe/determine-schema-keys.test.d.ts +2 -0
  803. package/dist/observe/determine-schema-keys.test.d.ts.map +1 -0
  804. package/dist/observe/determine-schema-keys.test.js +266 -0
  805. package/dist/observe/determine-schema-keys.test.js.map +1 -0
  806. package/dist/observe/index.d.ts +2 -0
  807. package/dist/observe/index.d.ts.map +1 -0
  808. package/dist/observe/index.js +2 -0
  809. package/dist/observe/index.js.map +1 -0
  810. package/dist/observe/lix-observable.d.ts +31 -0
  811. package/dist/observe/lix-observable.d.ts.map +1 -0
  812. package/dist/observe/lix-observable.js +65 -0
  813. package/dist/observe/lix-observable.js.map +1 -0
  814. package/dist/observe/lix-observable.test.d.ts +2 -0
  815. package/dist/observe/lix-observable.test.d.ts.map +1 -0
  816. package/dist/observe/lix-observable.test.js +187 -0
  817. package/dist/observe/lix-observable.test.js.map +1 -0
  818. package/dist/own-change-control/apply-own-change.d.ts +5 -1
  819. package/dist/own-change-control/apply-own-change.d.ts.map +1 -1
  820. package/dist/own-change-control/apply-own-change.js +26 -12
  821. package/dist/own-change-control/apply-own-change.js.map +1 -1
  822. package/dist/own-change-control/apply-own-change.test.js +86 -48
  823. package/dist/own-change-control/apply-own-change.test.js.map +1 -1
  824. package/dist/own-change-control/change-controlled-tables.d.ts +5 -7
  825. package/dist/own-change-control/change-controlled-tables.d.ts.map +1 -1
  826. package/dist/own-change-control/change-controlled-tables.js +27 -21
  827. package/dist/own-change-control/change-controlled-tables.js.map +1 -1
  828. package/dist/own-change-control/change-controlled-tables.test.js +35 -5
  829. package/dist/own-change-control/change-controlled-tables.test.js.map +1 -1
  830. package/dist/own-change-control/database-triggers.d.ts +2 -1
  831. package/dist/own-change-control/database-triggers.d.ts.map +1 -1
  832. package/dist/own-change-control/database-triggers.js +209 -67
  833. package/dist/own-change-control/database-triggers.js.map +1 -1
  834. package/dist/own-change-control/database-triggers.test.js +139 -8
  835. package/dist/own-change-control/database-triggers.test.js.map +1 -1
  836. package/dist/own-change-control/with-skip-own-change-control.d.ts.map +1 -1
  837. package/dist/own-change-control/with-skip-own-change-control.js +28 -6
  838. package/dist/own-change-control/with-skip-own-change-control.js.map +1 -1
  839. package/dist/own-change-control/with-skip-own-change-control.test.js +38 -1
  840. package/dist/own-change-control/with-skip-own-change-control.test.js.map +1 -1
  841. package/dist/plugin/index.d.ts +2 -1
  842. package/dist/plugin/index.d.ts.map +1 -1
  843. package/dist/plugin/index.js +1 -1
  844. package/dist/plugin/index.js.map +1 -1
  845. package/dist/plugin/lix-plugin.d.ts +26 -47
  846. package/dist/plugin/lix-plugin.d.ts.map +1 -1
  847. package/dist/plugin/lix-plugin.js +1 -1
  848. package/dist/plugin/lix-plugin.js.map +1 -1
  849. package/dist/plugin/lix-plugin.test-d.js +17 -11
  850. package/dist/plugin/lix-plugin.test-d.js.map +1 -1
  851. package/dist/plugin/load-plugin.d.ts.map +1 -1
  852. package/dist/plugin/load-plugin.js.map +1 -1
  853. package/dist/plugin/mock-json-plugin.d.ts +17 -0
  854. package/dist/plugin/mock-json-plugin.d.ts.map +1 -0
  855. package/dist/plugin/mock-json-plugin.flatten.d.ts +3 -0
  856. package/dist/plugin/mock-json-plugin.flatten.d.ts.map +1 -0
  857. package/dist/plugin/mock-json-plugin.flatten.js +124 -0
  858. package/dist/plugin/mock-json-plugin.flatten.js.map +1 -0
  859. package/dist/plugin/mock-json-plugin.js +101 -0
  860. package/dist/plugin/mock-json-plugin.js.map +1 -0
  861. package/dist/plugin/mock-json-plugin.test.d.ts +2 -0
  862. package/dist/plugin/mock-json-plugin.test.d.ts.map +1 -0
  863. package/dist/plugin/mock-json-plugin.test.js +164 -0
  864. package/dist/plugin/mock-json-plugin.test.js.map +1 -0
  865. package/dist/prototype/database-schema.d.ts +43 -0
  866. package/dist/prototype/database-schema.d.ts.map +1 -0
  867. package/dist/prototype/database-schema.js +72 -0
  868. package/dist/prototype/database-schema.js.map +1 -0
  869. package/dist/prototype/file-handlers.d.ts +24 -0
  870. package/dist/prototype/file-handlers.d.ts.map +1 -0
  871. package/dist/prototype/file-handlers.js +129 -0
  872. package/dist/prototype/file-handlers.js.map +1 -0
  873. package/dist/prototype/file-schema.d.ts +47 -0
  874. package/dist/prototype/file-schema.d.ts.map +1 -0
  875. package/dist/prototype/file-schema.js +135 -0
  876. package/dist/prototype/file-schema.js.map +1 -0
  877. package/dist/prototype/file-schema.test.d.ts +2 -0
  878. package/dist/prototype/file-schema.test.d.ts.map +1 -0
  879. package/dist/prototype/file-schema.test.js +146 -0
  880. package/dist/prototype/file-schema.test.js.map +1 -0
  881. package/dist/prototype/get-and-materialize-row.d.ts +5 -0
  882. package/dist/prototype/get-and-materialize-row.d.ts.map +1 -0
  883. package/dist/prototype/get-and-materialize-row.js +99 -0
  884. package/dist/prototype/get-and-materialize-row.js.map +1 -0
  885. package/dist/prototype/json-plugin.d.ts +49 -0
  886. package/dist/prototype/json-plugin.d.ts.map +1 -0
  887. package/dist/prototype/json-plugin.js +104 -0
  888. package/dist/prototype/json-plugin.js.map +1 -0
  889. package/dist/prototype/validate-file-path.d.ts +16 -0
  890. package/dist/prototype/validate-file-path.d.ts.map +1 -0
  891. package/dist/prototype/validate-file-path.js +44 -0
  892. package/dist/prototype/validate-file-path.js.map +1 -0
  893. package/dist/prototype/validate-file-path.test.d.ts +2 -0
  894. package/dist/prototype/validate-file-path.test.d.ts.map +1 -0
  895. package/dist/prototype/validate-file-path.test.js +36 -0
  896. package/dist/prototype/validate-file-path.test.js.map +1 -0
  897. package/dist/prototype/version-schema.d.ts +34 -0
  898. package/dist/prototype/version-schema.d.ts.map +1 -0
  899. package/dist/prototype/version-schema.js +86 -0
  900. package/dist/prototype/version-schema.js.map +1 -0
  901. package/dist/prototype/version-schema.test.d.ts +2 -0
  902. package/dist/prototype/version-schema.test.d.ts.map +1 -0
  903. package/dist/prototype/version-schema.test.js +114 -0
  904. package/dist/prototype/version-schema.test.js.map +1 -0
  905. package/dist/query-filter/change-conflict-in-version.d.ts +2 -0
  906. package/dist/query-filter/change-conflict-in-version.d.ts.map +1 -1
  907. package/dist/query-filter/change-conflict-in-version.js +2 -0
  908. package/dist/query-filter/change-conflict-in-version.js.map +1 -1
  909. package/dist/query-filter/change-has-label.d.ts +9 -3
  910. package/dist/query-filter/change-has-label.d.ts.map +1 -1
  911. package/dist/query-filter/change-has-label.js +7 -4
  912. package/dist/query-filter/change-has-label.js.map +1 -1
  913. package/dist/query-filter/change-has-label.test.js +36 -11
  914. package/dist/query-filter/change-has-label.test.js.map +1 -1
  915. package/dist/query-filter/change-in-version.d.ts +2 -0
  916. package/dist/query-filter/change-in-version.d.ts.map +1 -1
  917. package/dist/query-filter/change-in-version.js +2 -0
  918. package/dist/query-filter/change-in-version.js.map +1 -1
  919. package/dist/query-filter/change-is-leaf-in-version.d.ts +1 -0
  920. package/dist/query-filter/change-is-leaf-in-version.d.ts.map +1 -1
  921. package/dist/query-filter/change-is-leaf-in-version.js +1 -0
  922. package/dist/query-filter/change-is-leaf-in-version.js.map +1 -1
  923. package/dist/query-filter/change-is-leaf-of.d.ts +2 -0
  924. package/dist/query-filter/change-is-leaf-of.d.ts.map +1 -1
  925. package/dist/query-filter/change-is-leaf-of.js +2 -0
  926. package/dist/query-filter/change-is-leaf-of.js.map +1 -1
  927. package/dist/query-filter/change-is-leaf-v2.d.ts +69 -0
  928. package/dist/query-filter/change-is-leaf-v2.d.ts.map +1 -0
  929. package/dist/query-filter/change-is-leaf-v2.js +116 -0
  930. package/dist/query-filter/change-is-leaf-v2.js.map +1 -0
  931. package/dist/query-filter/change-is-leaf-v2.test.d.ts +2 -0
  932. package/dist/query-filter/change-is-leaf-v2.test.d.ts.map +1 -0
  933. package/dist/query-filter/change-is-leaf-v2.test.js +237 -0
  934. package/dist/query-filter/change-is-leaf-v2.test.js.map +1 -0
  935. package/dist/query-filter/change-is-leaf.d.ts +2 -0
  936. package/dist/query-filter/change-is-leaf.d.ts.map +1 -1
  937. package/dist/query-filter/change-is-leaf.js +2 -0
  938. package/dist/query-filter/change-is-leaf.js.map +1 -1
  939. package/dist/query-filter/change-is-lowest-common-ancestor-of.d.ts +2 -0
  940. package/dist/query-filter/change-is-lowest-common-ancestor-of.d.ts.map +1 -1
  941. package/dist/query-filter/change-is-lowest-common-ancestor-of.js +4 -0
  942. package/dist/query-filter/change-is-lowest-common-ancestor-of.js.map +1 -1
  943. package/dist/query-filter/change-is-lowest-common-ancestor-of.test.js +5 -3
  944. package/dist/query-filter/change-is-lowest-common-ancestor-of.test.js.map +1 -1
  945. package/dist/query-filter/change-set-element-in-ancestry-of.d.ts +30 -0
  946. package/dist/query-filter/change-set-element-in-ancestry-of.d.ts.map +1 -0
  947. package/dist/query-filter/change-set-element-in-ancestry-of.js +51 -0
  948. package/dist/query-filter/change-set-element-in-ancestry-of.js.map +1 -0
  949. package/dist/query-filter/change-set-element-in-ancestry-of.test.d.ts +2 -0
  950. package/dist/query-filter/change-set-element-in-ancestry-of.test.d.ts.map +1 -0
  951. package/dist/query-filter/change-set-element-in-ancestry-of.test.js +396 -0
  952. package/dist/query-filter/change-set-element-in-ancestry-of.test.js.map +1 -0
  953. package/dist/query-filter/change-set-element-in-symmetric-difference-of.d.ts +21 -0
  954. package/dist/query-filter/change-set-element-in-symmetric-difference-of.d.ts.map +1 -0
  955. package/dist/query-filter/change-set-element-in-symmetric-difference-of.js +37 -0
  956. package/dist/query-filter/change-set-element-in-symmetric-difference-of.js.map +1 -0
  957. package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.d.ts +2 -0
  958. package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.d.ts.map +1 -0
  959. package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.js +276 -0
  960. package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.js.map +1 -0
  961. package/dist/query-filter/change-set-element-in-symmetric-difference.d.ts +20 -0
  962. package/dist/query-filter/change-set-element-in-symmetric-difference.d.ts.map +1 -0
  963. package/dist/query-filter/change-set-element-in-symmetric-difference.js +36 -0
  964. package/dist/query-filter/change-set-element-in-symmetric-difference.js.map +1 -0
  965. package/dist/query-filter/change-set-element-in-symmetric-difference.test.d.ts +2 -0
  966. package/dist/query-filter/change-set-element-in-symmetric-difference.test.d.ts.map +1 -0
  967. package/dist/query-filter/change-set-element-in-symmetric-difference.test.js +369 -0
  968. package/dist/query-filter/change-set-element-in-symmetric-difference.test.js.map +1 -0
  969. package/dist/query-filter/change-set-element-is-leaf-of.d.ts +29 -0
  970. package/dist/query-filter/change-set-element-is-leaf-of.d.ts.map +1 -0
  971. package/dist/query-filter/change-set-element-is-leaf-of.js +113 -0
  972. package/dist/query-filter/change-set-element-is-leaf-of.js.map +1 -0
  973. package/dist/query-filter/change-set-element-is-leaf-of.test.d.ts +2 -0
  974. package/dist/query-filter/change-set-element-is-leaf-of.test.d.ts.map +1 -0
  975. package/dist/query-filter/change-set-element-is-leaf-of.test.js +574 -0
  976. package/dist/query-filter/change-set-element-is-leaf-of.test.js.map +1 -0
  977. package/dist/query-filter/change-set-has-label.d.ts +19 -3
  978. package/dist/query-filter/change-set-has-label.d.ts.map +1 -1
  979. package/dist/query-filter/change-set-has-label.js +17 -4
  980. package/dist/query-filter/change-set-has-label.js.map +1 -1
  981. package/dist/query-filter/change-set-has-label.test.js +13 -20
  982. package/dist/query-filter/change-set-has-label.test.js.map +1 -1
  983. package/dist/query-filter/change-set-is-ancestor-of.d.ts +51 -0
  984. package/dist/query-filter/change-set-is-ancestor-of.d.ts.map +1 -0
  985. package/dist/query-filter/change-set-is-ancestor-of.js +63 -0
  986. package/dist/query-filter/change-set-is-ancestor-of.js.map +1 -0
  987. package/dist/query-filter/change-set-is-ancestor-of.test.d.ts +2 -0
  988. package/dist/query-filter/change-set-is-ancestor-of.test.d.ts.map +1 -0
  989. package/dist/query-filter/change-set-is-ancestor-of.test.js +153 -0
  990. package/dist/query-filter/change-set-is-ancestor-of.test.js.map +1 -0
  991. package/dist/query-filter/change-set-is-descendant-of.d.ts +44 -0
  992. package/dist/query-filter/change-set-is-descendant-of.d.ts.map +1 -0
  993. package/dist/query-filter/change-set-is-descendant-of.js +56 -0
  994. package/dist/query-filter/change-set-is-descendant-of.js.map +1 -0
  995. package/dist/query-filter/change-set-is-descendant-of.test.d.ts +2 -0
  996. package/dist/query-filter/change-set-is-descendant-of.test.d.ts.map +1 -0
  997. package/dist/query-filter/change-set-is-descendant-of.test.js +137 -0
  998. package/dist/query-filter/change-set-is-descendant-of.test.js.map +1 -0
  999. package/dist/query-filter/commit-is-ancestor-of.d.ts +51 -0
  1000. package/dist/query-filter/commit-is-ancestor-of.d.ts.map +1 -0
  1001. package/dist/query-filter/commit-is-ancestor-of.js +63 -0
  1002. package/dist/query-filter/commit-is-ancestor-of.js.map +1 -0
  1003. package/dist/query-filter/commit-is-ancestor-of.test.d.ts +2 -0
  1004. package/dist/query-filter/commit-is-ancestor-of.test.d.ts.map +1 -0
  1005. package/dist/query-filter/commit-is-ancestor-of.test.js +292 -0
  1006. package/dist/query-filter/commit-is-ancestor-of.test.js.map +1 -0
  1007. package/dist/query-filter/commit-is-descendant-of.d.ts +44 -0
  1008. package/dist/query-filter/commit-is-descendant-of.d.ts.map +1 -0
  1009. package/dist/query-filter/commit-is-descendant-of.js +56 -0
  1010. package/dist/query-filter/commit-is-descendant-of.js.map +1 -0
  1011. package/dist/query-filter/commit-is-descendant-of.test.d.ts +2 -0
  1012. package/dist/query-filter/commit-is-descendant-of.test.d.ts.map +1 -0
  1013. package/dist/query-filter/commit-is-descendant-of.test.js +325 -0
  1014. package/dist/query-filter/commit-is-descendant-of.test.js.map +1 -0
  1015. package/dist/query-filter/index.d.ts +5 -8
  1016. package/dist/query-filter/index.d.ts.map +1 -1
  1017. package/dist/query-filter/index.js +5 -8
  1018. package/dist/query-filter/index.js.map +1 -1
  1019. package/dist/query-filter/version-change-in-difference.d.ts +2 -0
  1020. package/dist/query-filter/version-change-in-difference.d.ts.map +1 -1
  1021. package/dist/query-filter/version-change-in-difference.js +2 -0
  1022. package/dist/query-filter/version-change-in-difference.js.map +1 -1
  1023. package/dist/query-filter/version-change-in-symmetric-difference.d.ts +2 -0
  1024. package/dist/query-filter/version-change-in-symmetric-difference.d.ts.map +1 -1
  1025. package/dist/query-filter/version-change-in-symmetric-difference.js +2 -0
  1026. package/dist/query-filter/version-change-in-symmetric-difference.js.map +1 -1
  1027. package/dist/schema-definition/definition.d.ts +449 -0
  1028. package/dist/schema-definition/definition.d.ts.map +1 -0
  1029. package/dist/schema-definition/definition.js +106 -0
  1030. package/dist/schema-definition/definition.js.map +1 -0
  1031. package/dist/schema-definition/definition.test-d.d.ts +2 -0
  1032. package/dist/schema-definition/definition.test-d.d.ts.map +1 -0
  1033. package/dist/schema-definition/definition.test-d.js +177 -0
  1034. package/dist/schema-definition/definition.test-d.js.map +1 -0
  1035. package/dist/schema-definition/definition.test.d.ts +2 -0
  1036. package/dist/schema-definition/definition.test.d.ts.map +1 -0
  1037. package/dist/schema-definition/definition.test.js +369 -0
  1038. package/dist/schema-definition/definition.test.js.map +1 -0
  1039. package/dist/schema-definition/index.d.ts +4 -0
  1040. package/dist/schema-definition/index.d.ts.map +1 -0
  1041. package/dist/schema-definition/index.js +4 -0
  1042. package/dist/schema-definition/index.js.map +1 -0
  1043. package/dist/schema-definition/json-type.d.ts +24 -0
  1044. package/dist/schema-definition/json-type.d.ts.map +1 -0
  1045. package/dist/schema-definition/json-type.js +42 -0
  1046. package/dist/schema-definition/json-type.js.map +1 -0
  1047. package/dist/schema-definition/json-type.test.d.ts +2 -0
  1048. package/dist/schema-definition/json-type.test.d.ts.map +1 -0
  1049. package/dist/schema-definition/json-type.test.js +21 -0
  1050. package/dist/schema-definition/json-type.test.js.map +1 -0
  1051. package/dist/schema-definition/validate-lix-schema.d.ts +65 -0
  1052. package/dist/schema-definition/validate-lix-schema.d.ts.map +1 -0
  1053. package/dist/schema-definition/validate-lix-schema.js +93 -0
  1054. package/dist/schema-definition/validate-lix-schema.js.map +1 -0
  1055. package/dist/schema-definition/validate-lix-schema.test.d.ts +2 -0
  1056. package/dist/schema-definition/validate-lix-schema.test.d.ts.map +1 -0
  1057. package/dist/schema-definition/validate-lix-schema.test.js +73 -0
  1058. package/dist/schema-definition/validate-lix-schema.test.js.map +1 -0
  1059. package/dist/server-protocol-handler/create-server-protocol-handler.d.ts +0 -1
  1060. package/dist/server-protocol-handler/create-server-protocol-handler.d.ts.map +1 -1
  1061. package/dist/server-protocol-handler/create-server-protocol-handler.js +0 -2
  1062. package/dist/server-protocol-handler/create-server-protocol-handler.js.map +1 -1
  1063. package/dist/server-protocol-handler/environment/create-in-memory-environment.d.ts.map +1 -1
  1064. package/dist/server-protocol-handler/environment/create-in-memory-environment.js +5 -20
  1065. package/dist/server-protocol-handler/environment/create-in-memory-environment.js.map +1 -1
  1066. package/dist/server-protocol-handler/environment/create-in-memory-environment.test.js +13 -14
  1067. package/dist/server-protocol-handler/environment/create-in-memory-environment.test.js.map +1 -1
  1068. package/dist/server-protocol-handler/environment/environment.d.ts +0 -4
  1069. package/dist/server-protocol-handler/environment/environment.d.ts.map +1 -1
  1070. package/dist/server-protocol-handler/routes/get-v1.d.ts.map +1 -1
  1071. package/dist/server-protocol-handler/routes/get-v1.js +1 -1
  1072. package/dist/server-protocol-handler/routes/get-v1.js.map +1 -1
  1073. package/dist/server-protocol-handler/routes/get-v1.test.js +11 -12
  1074. package/dist/server-protocol-handler/routes/get-v1.test.js.map +1 -1
  1075. package/dist/server-protocol-handler/routes/new-v1.d.ts.map +1 -1
  1076. package/dist/server-protocol-handler/routes/new-v1.js +3 -5
  1077. package/dist/server-protocol-handler/routes/new-v1.js.map +1 -1
  1078. package/dist/server-protocol-handler/routes/new-v1.test.js +7 -8
  1079. package/dist/server-protocol-handler/routes/new-v1.test.js.map +1 -1
  1080. package/dist/server-protocol-handler/routes/pull-v1.test.js +48 -32
  1081. package/dist/server-protocol-handler/routes/pull-v1.test.js.map +1 -1
  1082. package/dist/server-protocol-handler/routes/push-v1.d.ts.map +1 -1
  1083. package/dist/server-protocol-handler/routes/push-v1.js +2 -0
  1084. package/dist/server-protocol-handler/routes/push-v1.js.map +1 -1
  1085. package/dist/server-protocol-handler/routes/push-v1.test.js +22 -26
  1086. package/dist/server-protocol-handler/routes/push-v1.test.js.map +1 -1
  1087. package/dist/services/env-variables/index.d.ts +1 -1
  1088. package/dist/services/env-variables/index.js +2 -2
  1089. package/dist/services/env-variables/index.js.map +1 -1
  1090. package/dist/services/telemetry/capture.d.ts.map +1 -1
  1091. package/dist/snapshot/create-snapshot.d.ts +3 -14
  1092. package/dist/snapshot/create-snapshot.d.ts.map +1 -1
  1093. package/dist/snapshot/create-snapshot.js +14 -19
  1094. package/dist/snapshot/create-snapshot.js.map +1 -1
  1095. package/dist/snapshot/create-snapshot.test.js +48 -19
  1096. package/dist/snapshot/create-snapshot.test.js.map +1 -1
  1097. package/dist/snapshot/database-schema.d.ts +19 -0
  1098. package/dist/snapshot/database-schema.d.ts.map +1 -0
  1099. package/dist/snapshot/database-schema.js +33 -0
  1100. package/dist/snapshot/database-schema.js.map +1 -0
  1101. package/dist/snapshot/database-schema.test.d.ts +2 -0
  1102. package/dist/snapshot/database-schema.test.d.ts.map +1 -0
  1103. package/dist/snapshot/database-schema.test.js +58 -0
  1104. package/dist/snapshot/database-schema.test.js.map +1 -0
  1105. package/dist/snapshot/index.d.ts +1 -0
  1106. package/dist/snapshot/index.d.ts.map +1 -1
  1107. package/dist/snapshot/index.js +1 -0
  1108. package/dist/snapshot/index.js.map +1 -1
  1109. package/dist/snapshot/json-sha-256.d.ts +2 -1
  1110. package/dist/snapshot/json-sha-256.d.ts.map +1 -1
  1111. package/dist/snapshot/json-sha-256.js +1 -3
  1112. package/dist/snapshot/json-sha-256.js.map +1 -1
  1113. package/dist/snapshot/json-sha-256.test.js +40 -2
  1114. package/dist/snapshot/json-sha-256.test.js.map +1 -1
  1115. package/dist/snapshot/mock-json-snapshot.d.ts +1 -1
  1116. package/dist/snapshot/mock-json-snapshot.d.ts.map +1 -1
  1117. package/dist/snapshot/schema.d.ts +8 -0
  1118. package/dist/snapshot/schema.d.ts.map +1 -0
  1119. package/dist/snapshot/schema.js +20 -0
  1120. package/dist/snapshot/schema.js.map +1 -0
  1121. package/dist/snapshot/schema.test.d.ts +2 -0
  1122. package/dist/snapshot/schema.test.d.ts.map +1 -0
  1123. package/dist/snapshot/schema.test.js +202 -0
  1124. package/dist/snapshot/schema.test.js.map +1 -0
  1125. package/dist/state/cache/clear-state-cache.d.ts +8 -0
  1126. package/dist/state/cache/clear-state-cache.d.ts.map +1 -0
  1127. package/dist/state/cache/clear-state-cache.js +14 -0
  1128. package/dist/state/cache/clear-state-cache.js.map +1 -0
  1129. package/dist/state/cache/clear-state-cache.test.d.ts +2 -0
  1130. package/dist/state/cache/clear-state-cache.test.d.ts.map +1 -0
  1131. package/dist/state/cache/clear-state-cache.test.js +34 -0
  1132. package/dist/state/cache/clear-state-cache.test.js.map +1 -0
  1133. package/dist/state/cache/is-stale-state-cache.d.ts +5 -0
  1134. package/dist/state/cache/is-stale-state-cache.d.ts.map +1 -0
  1135. package/dist/state/cache/is-stale-state-cache.js +22 -0
  1136. package/dist/state/cache/is-stale-state-cache.js.map +1 -0
  1137. package/dist/state/cache/is-stale-state-cache.test.d.ts +2 -0
  1138. package/dist/state/cache/is-stale-state-cache.test.d.ts.map +1 -0
  1139. package/dist/state/cache/is-stale-state-cache.test.js +27 -0
  1140. package/dist/state/cache/is-stale-state-cache.test.js.map +1 -0
  1141. package/dist/state/cache/mark-state-cache-as-stale.d.ts +10 -0
  1142. package/dist/state/cache/mark-state-cache-as-stale.d.ts.map +1 -0
  1143. package/dist/state/cache/mark-state-cache-as-stale.js +42 -0
  1144. package/dist/state/cache/mark-state-cache-as-stale.js.map +1 -0
  1145. package/dist/state/cache/populate-state-cache.d.ts +9 -0
  1146. package/dist/state/cache/populate-state-cache.d.ts.map +1 -0
  1147. package/dist/state/cache/populate-state-cache.js +106 -0
  1148. package/dist/state/cache/populate-state-cache.js.map +1 -0
  1149. package/dist/state/cache/populate-state-cache.test.d.ts +2 -0
  1150. package/dist/state/cache/populate-state-cache.test.d.ts.map +1 -0
  1151. package/dist/state/cache/populate-state-cache.test.js +204 -0
  1152. package/dist/state/cache/populate-state-cache.test.js.map +1 -0
  1153. package/dist/state/cache/schema.d.ts +20 -0
  1154. package/dist/state/cache/schema.d.ts.map +1 -0
  1155. package/dist/state/cache/schema.js +21 -0
  1156. package/dist/state/cache/schema.js.map +1 -0
  1157. package/dist/state/cache/update-state-cache.d.ts +21 -0
  1158. package/dist/state/cache/update-state-cache.d.ts.map +1 -0
  1159. package/dist/state/cache/update-state-cache.js +294 -0
  1160. package/dist/state/cache/update-state-cache.js.map +1 -0
  1161. package/dist/state/cache/update-state-cache.test.d.ts +2 -0
  1162. package/dist/state/cache/update-state-cache.test.d.ts.map +1 -0
  1163. package/dist/state/cache/update-state-cache.test.js +440 -0
  1164. package/dist/state/cache/update-state-cache.test.js.map +1 -0
  1165. package/dist/state/commit.d.ts +18 -0
  1166. package/dist/state/commit.d.ts.map +1 -0
  1167. package/dist/state/commit.js +457 -0
  1168. package/dist/state/commit.js.map +1 -0
  1169. package/dist/state/commit.test.d.ts +2 -0
  1170. package/dist/state/commit.test.d.ts.map +1 -0
  1171. package/dist/state/commit.test.js +1173 -0
  1172. package/dist/state/commit.test.js.map +1 -0
  1173. package/dist/state/create-changeset-for-transaction.d.ts +15 -0
  1174. package/dist/state/create-changeset-for-transaction.d.ts.map +1 -0
  1175. package/dist/state/create-changeset-for-transaction.js +237 -0
  1176. package/dist/state/create-changeset-for-transaction.js.map +1 -0
  1177. package/dist/state/get-version-record-by-id-or-throw.d.ts +6 -0
  1178. package/dist/state/get-version-record-by-id-or-throw.d.ts.map +1 -0
  1179. package/dist/state/get-version-record-by-id-or-throw.js +36 -0
  1180. package/dist/state/get-version-record-by-id-or-throw.js.map +1 -0
  1181. package/dist/state/handle-state-mutation.d.ts +6 -0
  1182. package/dist/state/handle-state-mutation.d.ts.map +1 -0
  1183. package/dist/state/handle-state-mutation.js +157 -0
  1184. package/dist/state/handle-state-mutation.js.map +1 -0
  1185. package/dist/state/handle-state-mutation.test.d.ts +2 -0
  1186. package/dist/state/handle-state-mutation.test.d.ts.map +1 -0
  1187. package/dist/state/handle-state-mutation.test.js +686 -0
  1188. package/dist/state/handle-state-mutation.test.js.map +1 -0
  1189. package/dist/state/insert-transaction-state.d.ts +71 -0
  1190. package/dist/state/insert-transaction-state.d.ts.map +1 -0
  1191. package/dist/state/insert-transaction-state.js +272 -0
  1192. package/dist/state/insert-transaction-state.js.map +1 -0
  1193. package/dist/state/insert-transaction-state.test.d.ts +2 -0
  1194. package/dist/state/insert-transaction-state.test.d.ts.map +1 -0
  1195. package/dist/state/insert-transaction-state.test.js +789 -0
  1196. package/dist/state/insert-transaction-state.test.js.map +1 -0
  1197. package/dist/state/materialize-state.d.ts +3 -0
  1198. package/dist/state/materialize-state.d.ts.map +1 -0
  1199. package/dist/state/materialize-state.js +230 -0
  1200. package/dist/state/materialize-state.js.map +1 -0
  1201. package/dist/state/materialize-state.test.d.ts +2 -0
  1202. package/dist/state/materialize-state.test.d.ts.map +1 -0
  1203. package/dist/state/materialize-state.test.js +1934 -0
  1204. package/dist/state/materialize-state.test.js.map +1 -0
  1205. package/dist/state/primary-key.d.ts +39 -0
  1206. package/dist/state/primary-key.d.ts.map +1 -0
  1207. package/dist/state/primary-key.js +62 -0
  1208. package/dist/state/primary-key.js.map +1 -0
  1209. package/dist/state/primary-key.test.d.ts +2 -0
  1210. package/dist/state/primary-key.test.d.ts.map +1 -0
  1211. package/dist/state/primary-key.test.js +114 -0
  1212. package/dist/state/primary-key.test.js.map +1 -0
  1213. package/dist/state/resolved-state-view.d.ts +33 -0
  1214. package/dist/state/resolved-state-view.d.ts.map +1 -0
  1215. package/dist/state/resolved-state-view.js +182 -0
  1216. package/dist/state/resolved-state-view.js.map +1 -0
  1217. package/dist/state/resolved-state-view.test.d.ts +2 -0
  1218. package/dist/state/resolved-state-view.test.d.ts.map +1 -0
  1219. package/dist/state/resolved-state-view.test.js +433 -0
  1220. package/dist/state/resolved-state-view.test.js.map +1 -0
  1221. package/dist/state/schema.bench.d.ts +2 -0
  1222. package/dist/state/schema.bench.d.ts.map +1 -0
  1223. package/dist/state/schema.bench.js +36 -0
  1224. package/dist/state/schema.bench.js.map +1 -0
  1225. package/dist/state/schema.d.ts +43 -0
  1226. package/dist/state/schema.d.ts.map +1 -0
  1227. package/dist/state/schema.js +789 -0
  1228. package/dist/state/schema.js.map +1 -0
  1229. package/dist/state/schema.test.d.ts +2 -0
  1230. package/dist/state/schema.test.d.ts.map +1 -0
  1231. package/dist/state/schema.test.js +2701 -0
  1232. package/dist/state/schema.test.js.map +1 -0
  1233. package/dist/state/untracked/schema.d.ts +25 -0
  1234. package/dist/state/untracked/schema.d.ts.map +1 -0
  1235. package/dist/state/untracked/schema.js +38 -0
  1236. package/dist/state/untracked/schema.js.map +1 -0
  1237. package/dist/state/untracked/schema.test.d.ts +2 -0
  1238. package/dist/state/untracked/schema.test.d.ts.map +1 -0
  1239. package/dist/state/untracked/schema.test.js +275 -0
  1240. package/dist/state/untracked/schema.test.js.map +1 -0
  1241. package/dist/state/untracked/update-untracked-state.d.ts +36 -0
  1242. package/dist/state/untracked/update-untracked-state.d.ts.map +1 -0
  1243. package/dist/state/untracked/update-untracked-state.js +113 -0
  1244. package/dist/state/untracked/update-untracked-state.js.map +1 -0
  1245. package/dist/state/untracked/update-untracked-state.test.d.ts +2 -0
  1246. package/dist/state/untracked/update-untracked-state.test.d.ts.map +1 -0
  1247. package/dist/state/untracked/update-untracked-state.test.js +417 -0
  1248. package/dist/state/untracked/update-untracked-state.test.js.map +1 -0
  1249. package/dist/state/validate-snapshot-content.d.ts +9 -0
  1250. package/dist/state/validate-snapshot-content.d.ts.map +1 -0
  1251. package/dist/state/validate-snapshot-content.js +42 -0
  1252. package/dist/state/validate-snapshot-content.js.map +1 -0
  1253. package/dist/state/validate-snapshot-content.test.d.ts +2 -0
  1254. package/dist/state/validate-snapshot-content.test.d.ts.map +1 -0
  1255. package/dist/state/validate-snapshot-content.test.js +67 -0
  1256. package/dist/state/validate-snapshot-content.test.js.map +1 -0
  1257. package/dist/state/validate-state-mutation.d.ts +13 -0
  1258. package/dist/state/validate-state-mutation.d.ts.map +1 -0
  1259. package/dist/state/validate-state-mutation.js +645 -0
  1260. package/dist/state/validate-state-mutation.js.map +1 -0
  1261. package/dist/state/validate-state-mutation.test.d.ts +2 -0
  1262. package/dist/state/validate-state-mutation.test.d.ts.map +1 -0
  1263. package/dist/state/validate-state-mutation.test.js +2859 -0
  1264. package/dist/state/validate-state-mutation.test.js.map +1 -0
  1265. package/dist/state-history/schema.d.ts +68 -0
  1266. package/dist/state-history/schema.d.ts.map +1 -0
  1267. package/dist/state-history/schema.js +116 -0
  1268. package/dist/state-history/schema.js.map +1 -0
  1269. package/dist/state-history/schema.test.d.ts +2 -0
  1270. package/dist/state-history/schema.test.d.ts.map +1 -0
  1271. package/dist/state-history/schema.test.js +855 -0
  1272. package/dist/state-history/schema.test.js.map +1 -0
  1273. package/dist/stored-schema/index.d.ts +2 -0
  1274. package/dist/stored-schema/index.d.ts.map +1 -0
  1275. package/dist/stored-schema/index.js +2 -0
  1276. package/dist/stored-schema/index.js.map +1 -0
  1277. package/dist/stored-schema/schema.d.ts +25 -0
  1278. package/dist/stored-schema/schema.d.ts.map +1 -0
  1279. package/dist/stored-schema/schema.js +48 -0
  1280. package/dist/stored-schema/schema.js.map +1 -0
  1281. package/dist/stored-schema/schema.test.d.ts +2 -0
  1282. package/dist/stored-schema/schema.test.d.ts.map +1 -0
  1283. package/dist/stored-schema/schema.test.js +192 -0
  1284. package/dist/stored-schema/schema.test.js.map +1 -0
  1285. package/dist/sync/get-diffing-rows.d.ts +12 -0
  1286. package/dist/sync/get-diffing-rows.d.ts.map +1 -1
  1287. package/dist/sync/get-diffing-rows.js +14 -0
  1288. package/dist/sync/get-diffing-rows.js.map +1 -1
  1289. package/dist/sync/merge-state.d.ts.map +1 -1
  1290. package/dist/sync/merge-state.js +2 -1
  1291. package/dist/sync/merge-state.js.map +1 -1
  1292. package/dist/sync/pull-from-server.d.ts.map +1 -1
  1293. package/dist/sync/pull-from-server.js +2 -1
  1294. package/dist/sync/pull-from-server.js.map +1 -1
  1295. package/dist/sync/pull-from-server.test.js +32 -28
  1296. package/dist/sync/pull-from-server.test.js.map +1 -1
  1297. package/dist/sync/push-to-server.d.ts +10 -1
  1298. package/dist/sync/push-to-server.d.ts.map +1 -1
  1299. package/dist/sync/push-to-server.js +10 -1
  1300. package/dist/sync/push-to-server.js.map +1 -1
  1301. package/dist/sync/push-to-server.test.js +62 -63
  1302. package/dist/sync/push-to-server.test.js.map +1 -1
  1303. package/dist/sync/sync-process.d.ts +1 -1
  1304. package/dist/sync/sync-process.d.ts.map +1 -1
  1305. package/dist/sync/sync-process.js +1 -2
  1306. package/dist/sync/sync-process.js.map +1 -1
  1307. package/dist/sync/sync-process.test.js +20 -17
  1308. package/dist/sync/sync-process.test.js.map +1 -1
  1309. package/dist/test-utilities/simulation-test/cache-miss-simulation.d.ts +8 -0
  1310. package/dist/test-utilities/simulation-test/cache-miss-simulation.d.ts.map +1 -0
  1311. package/dist/test-utilities/simulation-test/cache-miss-simulation.js +79 -0
  1312. package/dist/test-utilities/simulation-test/cache-miss-simulation.js.map +1 -0
  1313. package/dist/test-utilities/simulation-test/cache-miss-simulation.test.d.ts +2 -0
  1314. package/dist/test-utilities/simulation-test/cache-miss-simulation.test.d.ts.map +1 -0
  1315. package/dist/test-utilities/simulation-test/cache-miss-simulation.test.js +127 -0
  1316. package/dist/test-utilities/simulation-test/cache-miss-simulation.test.js.map +1 -0
  1317. package/dist/test-utilities/simulation-test/chaotic-timestamp-simulation.d.ts +2 -0
  1318. package/dist/test-utilities/simulation-test/chaotic-timestamp-simulation.d.ts.map +1 -0
  1319. package/dist/test-utilities/simulation-test/chaotic-timestamp-simulation.js +2 -0
  1320. package/dist/test-utilities/simulation-test/chaotic-timestamp-simulation.js.map +1 -0
  1321. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.d.ts +10 -0
  1322. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.d.ts.map +1 -0
  1323. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.js +52 -0
  1324. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.js.map +1 -0
  1325. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.d.ts +2 -0
  1326. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.d.ts.map +1 -0
  1327. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.js +71 -0
  1328. package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.js.map +1 -0
  1329. package/dist/test-utilities/simulation-test/simulation-test.d.ts +82 -0
  1330. package/dist/test-utilities/simulation-test/simulation-test.d.ts.map +1 -0
  1331. package/dist/test-utilities/simulation-test/simulation-test.js +85 -0
  1332. package/dist/test-utilities/simulation-test/simulation-test.js.map +1 -0
  1333. package/dist/test-utilities/simulation-test/simulation-test.test.d.ts +2 -0
  1334. package/dist/test-utilities/simulation-test/simulation-test.test.d.ts.map +1 -0
  1335. package/dist/test-utilities/simulation-test/simulation-test.test.js +310 -0
  1336. package/dist/test-utilities/simulation-test/simulation-test.test.js.map +1 -0
  1337. package/dist/thread/comment-utils.d.ts +2 -0
  1338. package/dist/thread/comment-utils.d.ts.map +1 -0
  1339. package/dist/thread/comment-utils.js +2 -0
  1340. package/dist/thread/comment-utils.js.map +1 -0
  1341. package/dist/thread/comment.d.ts +24 -0
  1342. package/dist/thread/comment.d.ts.map +1 -0
  1343. package/dist/thread/comment.js +43 -0
  1344. package/dist/thread/comment.js.map +1 -0
  1345. package/dist/thread/create-thread-comment.d.ts +18 -0
  1346. package/dist/thread/create-thread-comment.d.ts.map +1 -0
  1347. package/dist/thread/create-thread-comment.js +64 -0
  1348. package/dist/thread/create-thread-comment.js.map +1 -0
  1349. package/dist/thread/create-thread-comment.test.d.ts +2 -0
  1350. package/dist/thread/create-thread-comment.test.d.ts.map +1 -0
  1351. package/dist/thread/create-thread-comment.test.js +97 -0
  1352. package/dist/thread/create-thread-comment.test.js.map +1 -0
  1353. package/dist/thread/create-thread.d.ts +42 -0
  1354. package/dist/thread/create-thread.d.ts.map +1 -0
  1355. package/dist/thread/create-thread.js +79 -0
  1356. package/dist/thread/create-thread.js.map +1 -0
  1357. package/dist/thread/create-thread.test.d.ts +2 -0
  1358. package/dist/thread/create-thread.test.d.ts.map +1 -0
  1359. package/dist/thread/create-thread.test.js +175 -0
  1360. package/dist/thread/create-thread.test.js.map +1 -0
  1361. package/dist/thread/database-schema.d.ts +20 -0
  1362. package/dist/thread/database-schema.d.ts.map +1 -0
  1363. package/dist/thread/database-schema.js +57 -0
  1364. package/dist/thread/database-schema.js.map +1 -0
  1365. package/dist/thread/database-schema.test.d.ts +2 -0
  1366. package/dist/thread/database-schema.test.d.ts.map +1 -0
  1367. package/dist/thread/database-schema.test.js +59 -0
  1368. package/dist/thread/database-schema.test.js.map +1 -0
  1369. package/dist/thread/index.d.ts +5 -0
  1370. package/dist/thread/index.d.ts.map +1 -0
  1371. package/dist/thread/index.js +4 -0
  1372. package/dist/thread/index.js.map +1 -0
  1373. package/dist/thread/schema.d.ts +62 -0
  1374. package/dist/thread/schema.d.ts.map +1 -0
  1375. package/dist/thread/schema.js +72 -0
  1376. package/dist/thread/schema.js.map +1 -0
  1377. package/dist/thread/schema.test.d.ts +2 -0
  1378. package/dist/thread/schema.test.d.ts.map +1 -0
  1379. package/dist/thread/schema.test.js +125 -0
  1380. package/dist/thread/schema.test.js.map +1 -0
  1381. package/dist/version/create-version.d.ts +14 -17
  1382. package/dist/version/create-version.d.ts.map +1 -1
  1383. package/dist/version/create-version.js +53 -52
  1384. package/dist/version/create-version.js.map +1 -1
  1385. package/dist/version/create-version.test.js +121 -109
  1386. package/dist/version/create-version.test.js.map +1 -1
  1387. package/dist/version/database-schema.d.ts +21 -0
  1388. package/dist/version/database-schema.d.ts.map +1 -0
  1389. package/dist/version/database-schema.js +169 -0
  1390. package/dist/version/database-schema.js.map +1 -0
  1391. package/dist/version/database-schema.test.d.ts +2 -0
  1392. package/dist/version/database-schema.test.d.ts.map +1 -0
  1393. package/dist/version/database-schema.test.js +625 -0
  1394. package/dist/version/database-schema.test.js.map +1 -0
  1395. package/dist/version/index.d.ts +1 -5
  1396. package/dist/version/index.d.ts.map +1 -1
  1397. package/dist/version/index.js +1 -5
  1398. package/dist/version/index.js.map +1 -1
  1399. package/dist/version/merge-version.d.ts +3 -0
  1400. package/dist/version/merge-version.d.ts.map +1 -1
  1401. package/dist/version/merge-version.js +3 -0
  1402. package/dist/version/merge-version.js.map +1 -1
  1403. package/dist/version/merge-version.test.js +10 -5
  1404. package/dist/version/merge-version.test.js.map +1 -1
  1405. package/dist/version/schema.d.ts +78 -0
  1406. package/dist/version/schema.d.ts.map +1 -0
  1407. package/dist/version/schema.js +147 -0
  1408. package/dist/version/schema.js.map +1 -0
  1409. package/dist/version/schema.test.d.ts +2 -0
  1410. package/dist/version/schema.test.d.ts.map +1 -0
  1411. package/dist/version/schema.test.js +884 -0
  1412. package/dist/version/schema.test.js.map +1 -0
  1413. package/dist/version/select-active-version.d.ts +7 -0
  1414. package/dist/version/select-active-version.d.ts.map +1 -0
  1415. package/dist/version/select-active-version.js +7 -0
  1416. package/dist/version/select-active-version.js.map +1 -0
  1417. package/dist/version/switch-version.d.ts +5 -5
  1418. package/dist/version/switch-version.d.ts.map +1 -1
  1419. package/dist/version/switch-version.js +6 -62
  1420. package/dist/version/switch-version.js.map +1 -1
  1421. package/dist/version/switch-version.test.js +14 -214
  1422. package/dist/version/switch-version.test.js.map +1 -1
  1423. package/dist/version/update-changes-in-version.d.ts +2 -0
  1424. package/dist/version/update-changes-in-version.d.ts.map +1 -1
  1425. package/dist/version/update-changes-in-version.js +2 -0
  1426. package/dist/version/update-changes-in-version.js.map +1 -1
  1427. package/dist/version-v2/create-version.d.ts +18 -0
  1428. package/dist/version-v2/create-version.d.ts.map +1 -0
  1429. package/dist/version-v2/create-version.js +35 -0
  1430. package/dist/version-v2/create-version.js.map +1 -0
  1431. package/dist/version-v2/create-version.test.d.ts +2 -0
  1432. package/dist/version-v2/create-version.test.d.ts.map +1 -0
  1433. package/dist/version-v2/create-version.test.js +88 -0
  1434. package/dist/version-v2/create-version.test.js.map +1 -0
  1435. package/dist/version-v2/database-schema.d.ts +21 -0
  1436. package/dist/version-v2/database-schema.d.ts.map +1 -0
  1437. package/dist/version-v2/database-schema.js +169 -0
  1438. package/dist/version-v2/database-schema.js.map +1 -0
  1439. package/dist/version-v2/database-schema.test.d.ts +2 -0
  1440. package/dist/version-v2/database-schema.test.d.ts.map +1 -0
  1441. package/dist/version-v2/database-schema.test.js +625 -0
  1442. package/dist/version-v2/database-schema.test.js.map +1 -0
  1443. package/dist/version-v2/index.d.ts +2 -0
  1444. package/dist/version-v2/index.d.ts.map +1 -0
  1445. package/dist/version-v2/index.js +2 -0
  1446. package/dist/version-v2/index.js.map +1 -0
  1447. package/dist/version-v2/swich-version.d.ts +27 -0
  1448. package/dist/version-v2/swich-version.d.ts.map +1 -0
  1449. package/dist/version-v2/swich-version.js +46 -0
  1450. package/dist/version-v2/swich-version.js.map +1 -0
  1451. package/dist/version-v2/switch-version.d.ts +27 -0
  1452. package/dist/version-v2/switch-version.d.ts.map +1 -0
  1453. package/dist/version-v2/switch-version.js +91 -0
  1454. package/dist/version-v2/switch-version.js.map +1 -0
  1455. package/dist/version-v2/switch-version.test.d.ts +2 -0
  1456. package/dist/version-v2/switch-version.test.d.ts.map +1 -0
  1457. package/dist/version-v2/switch-version.test.js +110 -0
  1458. package/dist/version-v2/switch-version.test.js.map +1 -0
  1459. package/dist/version-v2/with-skip-update-working-change-set.d.ts +3 -0
  1460. package/dist/version-v2/with-skip-update-working-change-set.d.ts.map +1 -0
  1461. package/dist/version-v2/with-skip-update-working-change-set.js +50 -0
  1462. package/dist/version-v2/with-skip-update-working-change-set.js.map +1 -0
  1463. package/dist/version-v2/with-skip-update-working-change-set.test.d.ts +2 -0
  1464. package/dist/version-v2/with-skip-update-working-change-set.test.d.ts.map +1 -0
  1465. package/dist/version-v2/with-skip-update-working-change-set.test.js +49 -0
  1466. package/dist/version-v2/with-skip-update-working-change-set.test.js.map +1 -0
  1467. package/dist/zettel-ast/index.d.ts +11 -0
  1468. package/dist/zettel-ast/index.d.ts.map +1 -0
  1469. package/dist/zettel-ast/index.js +11 -0
  1470. package/dist/zettel-ast/index.js.map +1 -0
  1471. package/package.json +12 -11
  1472. package/src/account/create-account.test.ts +49 -4
  1473. package/src/account/create-account.ts +37 -7
  1474. package/src/account/index.ts +5 -1
  1475. package/src/account/schema.test.ts +370 -0
  1476. package/src/account/schema.ts +132 -0
  1477. package/src/account/switch-account.test.ts +33 -10
  1478. package/src/account/switch-account.ts +13 -4
  1479. package/src/change/index.ts +4 -2
  1480. package/src/change/schema.test.ts +322 -0
  1481. package/src/change/schema.ts +173 -0
  1482. package/src/change-author/index.ts +4 -0
  1483. package/src/change-author/schema.test.ts +364 -0
  1484. package/src/change-author/schema.ts +54 -0
  1485. package/src/change-conflict/create-change-conflict.test.ts +14 -11
  1486. package/src/change-conflict/create-change-conflict.ts +29 -6
  1487. package/src/change-conflict/detect-change-conflicts.test.ts +18 -15
  1488. package/src/change-conflict/detect-change-conflicts.ts +3 -0
  1489. package/src/change-conflict/detect-diverging-entity-conflict.test.ts +24 -21
  1490. package/src/change-conflict/detect-diverging-entity-conflict.ts +4 -1
  1491. package/src/change-conflict/garbage-collect-change-conflicts.test.ts +16 -15
  1492. package/src/change-conflict/garbage-collect-change-conflicts.ts +3 -0
  1493. package/src/change-conflict/resolve-conflict-by-selecting.test.ts +18 -8
  1494. package/src/change-conflict/resolve-conflict-by-selecting.ts +3 -2
  1495. package/src/change-proposal/create-change-proposal.test.ts +106 -0
  1496. package/src/change-proposal/create-change-proposal.ts +71 -0
  1497. package/src/change-proposal/database-schema.test.ts +180 -0
  1498. package/src/change-proposal/database-schema.ts +32 -0
  1499. package/src/change-proposal/index.ts +2 -0
  1500. package/src/change-set/apply-change-set.test.ts +472 -0
  1501. package/src/change-set/apply-change-set.ts +174 -0
  1502. package/src/change-set/create-change-set.test.ts +87 -27
  1503. package/src/change-set/create-change-set.ts +95 -43
  1504. package/src/change-set/index.ts +9 -1
  1505. package/src/change-set/schema.test.ts +671 -0
  1506. package/src/change-set/schema.ts +150 -0
  1507. package/src/commit/apply-commit.test.ts +426 -0
  1508. package/src/commit/apply-commit.ts +74 -0
  1509. package/src/commit/create-checkpoint.test.ts +605 -0
  1510. package/src/commit/create-checkpoint.ts +140 -0
  1511. package/src/commit/create-commit.ts +80 -0
  1512. package/src/commit/create-merge-commit.test.ts +268 -0
  1513. package/src/commit/create-merge-commit.ts +138 -0
  1514. package/src/commit/create-transition-commit.test.ts +256 -0
  1515. package/src/commit/create-transition-commit.ts +187 -0
  1516. package/src/commit/create-undo-commit.test.ts +358 -0
  1517. package/src/commit/create-undo-commit.ts +180 -0
  1518. package/src/commit/index.ts +11 -0
  1519. package/src/commit/schema.test.ts +257 -0
  1520. package/src/commit/schema.ts +104 -0
  1521. package/src/database/execute-sync.test.ts +60 -72
  1522. package/src/database/execute-sync.ts +26 -27
  1523. package/src/database/graph-traversal-mode.ts +75 -0
  1524. package/src/database/index.ts +1 -2
  1525. package/src/database/init-db.ts +158 -74
  1526. package/src/database/kysely-plugin/json-column-plugin.test.ts +404 -0
  1527. package/src/database/kysely-plugin/json-column-plugin.ts +280 -0
  1528. package/src/database/kysely-plugin/parse-jsonb-plugin-v1.ts +5 -10
  1529. package/src/database/kysely-plugin/parse-jsonb-plugin-v2.ts +1 -1
  1530. package/src/database/kysely-plugin/serialize-jsonb-plugin.test.ts +177 -2
  1531. package/src/database/kysely-plugin/serialize-jsonb-plugin.ts +186 -87
  1532. package/src/database/kysely-plugin/view-insert-returning-error-plugin.test.ts +62 -0
  1533. package/src/database/kysely-plugin/view-insert-returning-error-plugin.ts +49 -0
  1534. package/src/database/nano-id.test.ts +3 -3
  1535. package/src/database/nano-id.ts +4 -1
  1536. package/src/database/schema.ts +105 -270
  1537. package/src/deterministic/generate-human-id.test.ts +154 -0
  1538. package/src/deterministic/generate-human-id.ts +94 -0
  1539. package/src/deterministic/index.ts +7 -0
  1540. package/src/deterministic/is-deterministic-mode.test.ts +133 -0
  1541. package/src/deterministic/is-deterministic-mode.ts +32 -0
  1542. package/src/deterministic/nano-id.test.ts +200 -0
  1543. package/src/deterministic/nano-id.ts +188 -0
  1544. package/src/deterministic/options.test.ts +157 -0
  1545. package/src/deterministic/options.ts +62 -0
  1546. package/src/deterministic/random.test.ts +293 -0
  1547. package/src/deterministic/random.ts +261 -0
  1548. package/src/deterministic/sequence.test.ts +93 -0
  1549. package/src/deterministic/sequence.ts +132 -0
  1550. package/src/deterministic/timestamp.test.ts +170 -0
  1551. package/src/deterministic/timestamp.ts +83 -0
  1552. package/src/deterministic/uuid-v7.test.ts +144 -0
  1553. package/src/deterministic/uuid-v7.ts +82 -0
  1554. package/src/entity/eb-entity.test.ts +687 -0
  1555. package/src/entity/eb-entity.ts +203 -0
  1556. package/src/entity/index.ts +12 -0
  1557. package/src/entity/label/create-entity-label.test.ts +316 -0
  1558. package/src/entity/label/create-entity-label.ts +113 -0
  1559. package/src/entity/label/schema.test.ts +692 -0
  1560. package/src/entity/label/schema.ts +55 -0
  1561. package/src/entity/schema.ts +22 -0
  1562. package/src/entity/thread/create-entity-thread.test.ts +282 -0
  1563. package/src/entity/thread/create-entity-thread.ts +134 -0
  1564. package/src/entity/thread/query-threads.test.ts +394 -0
  1565. package/src/entity/thread/schema.test.ts +170 -0
  1566. package/src/entity/thread/schema.ts +55 -0
  1567. package/src/entity-views/README.md +214 -0
  1568. package/src/entity-views/entity-state-all.test.ts +647 -0
  1569. package/src/entity-views/entity-state-all.ts +575 -0
  1570. package/src/entity-views/entity-state-history.test.ts +387 -0
  1571. package/src/entity-views/entity-state-history.ts +275 -0
  1572. package/src/entity-views/entity-state.test.ts +732 -0
  1573. package/src/entity-views/entity-state.ts +571 -0
  1574. package/src/entity-views/entity-view-builder.test.ts +293 -0
  1575. package/src/entity-views/entity-view-builder.ts +148 -0
  1576. package/src/entity-views/index.ts +1 -0
  1577. package/src/entity-views/types.test.ts +99 -0
  1578. package/src/entity-views/types.ts +328 -0
  1579. package/src/file/file-handlers.test.ts +174 -0
  1580. package/src/file/file-handlers.ts +404 -0
  1581. package/src/file/index.ts +5 -1
  1582. package/src/file/materialize-file-data-at-commit.ts +157 -0
  1583. package/src/file/materialize-file-data.test.ts +107 -0
  1584. package/src/file/materialize-file-data.ts +120 -0
  1585. package/src/file/schema.test.ts +1646 -0
  1586. package/src/file/schema.ts +427 -0
  1587. package/src/file/store-detected-change-schema.test.ts +248 -0
  1588. package/src/file/store-detected-change-schema.ts +52 -0
  1589. package/src/file/unknown-file-fallback-plugin.test.ts +368 -0
  1590. package/src/file/unknown-file-fallback-plugin.ts +95 -0
  1591. package/src/hooks/create-hooks.test.ts +125 -0
  1592. package/src/hooks/create-hooks.ts +68 -0
  1593. package/src/hooks/index.ts +1 -0
  1594. package/src/index.ts +13 -6
  1595. package/src/key-value/index.ts +1 -0
  1596. package/src/key-value/schema.test.ts +280 -0
  1597. package/src/key-value/schema.ts +98 -0
  1598. package/src/label/create-label.test.ts +234 -0
  1599. package/src/label/create-label.ts +61 -0
  1600. package/src/label/index.ts +2 -0
  1601. package/src/label/schema.test.ts +92 -0
  1602. package/src/label/schema.ts +37 -0
  1603. package/src/lix/index.ts +3 -6
  1604. package/src/lix/new-lix.test.ts +412 -16
  1605. package/src/lix/new-lix.ts +619 -8
  1606. package/src/lix/open-lix.test.ts +369 -27
  1607. package/src/lix/open-lix.ts +256 -46
  1608. package/src/lix/storage/in-memory.test.ts +106 -0
  1609. package/src/lix/storage/in-memory.ts +64 -0
  1610. package/src/lix/storage/lix-storage-adapter.ts +52 -0
  1611. package/src/lix/storage/opfs.test.ts +438 -0
  1612. package/src/lix/storage/opfs.ts +313 -0
  1613. package/src/log/create-lix-own-log.test.ts +123 -0
  1614. package/src/log/create-lix-own-log.ts +113 -0
  1615. package/src/log/create-log.ts +52 -0
  1616. package/src/log/index.ts +2 -0
  1617. package/src/log/schema.test.ts +140 -0
  1618. package/src/log/schema.ts +51 -0
  1619. package/src/observe/create-observe.test.ts +836 -0
  1620. package/src/observe/create-observe.ts +184 -0
  1621. package/src/observe/determine-schema-keys.test.ts +371 -0
  1622. package/src/observe/determine-schema-keys.ts +165 -0
  1623. package/src/observe/index.ts +1 -0
  1624. package/src/observe/lix-observable.test.ts +247 -0
  1625. package/src/observe/lix-observable.ts +92 -0
  1626. package/src/plugin/index.ts +2 -2
  1627. package/src/plugin/lix-plugin.test-d.ts +26 -15
  1628. package/src/plugin/lix-plugin.ts +43 -52
  1629. package/src/plugin/mock-json-plugin.flatten.ts +161 -0
  1630. package/src/plugin/mock-json-plugin.test.ts +214 -0
  1631. package/src/plugin/mock-json-plugin.ts +113 -0
  1632. package/src/query-filter/change-set-element-in-ancestry-of.test.ts +440 -0
  1633. package/src/query-filter/change-set-element-in-ancestry-of.ts +69 -0
  1634. package/src/query-filter/change-set-element-in-symmetric-difference.test.ts +410 -0
  1635. package/src/{change-set → query-filter}/change-set-element-in-symmetric-difference.ts +4 -3
  1636. package/src/query-filter/change-set-element-is-leaf-of.test.ts +623 -0
  1637. package/src/query-filter/change-set-element-is-leaf-of.ts +132 -0
  1638. package/src/query-filter/commit-is-ancestor-of.test.ts +333 -0
  1639. package/src/query-filter/commit-is-ancestor-of.ts +77 -0
  1640. package/src/query-filter/commit-is-descendant-of.test.ts +365 -0
  1641. package/src/query-filter/commit-is-descendant-of.ts +70 -0
  1642. package/src/query-filter/index.ts +5 -8
  1643. package/src/schema-definition/definition.test-d.ts +253 -0
  1644. package/src/schema-definition/definition.test.ts +425 -0
  1645. package/src/schema-definition/definition.ts +502 -0
  1646. package/src/schema-definition/index.ts +13 -0
  1647. package/src/schema-definition/json-type.test.ts +30 -0
  1648. package/src/schema-definition/json-type.ts +53 -0
  1649. package/src/schema-definition/validate-lix-schema.test.ts +94 -0
  1650. package/src/schema-definition/validate-lix-schema.ts +104 -0
  1651. package/src/server-protocol-handler/create-server-protocol-handler.ts +0 -4
  1652. package/src/server-protocol-handler/environment/create-in-memory-environment.test.ts +13 -14
  1653. package/src/server-protocol-handler/environment/create-in-memory-environment.ts +5 -24
  1654. package/src/server-protocol-handler/environment/environment.ts +0 -5
  1655. package/src/server-protocol-handler/routes/get-v1.test.ts +11 -12
  1656. package/src/server-protocol-handler/routes/get-v1.ts +3 -1
  1657. package/src/server-protocol-handler/routes/new-v1.test.ts +7 -8
  1658. package/src/server-protocol-handler/routes/new-v1.ts +3 -5
  1659. package/src/server-protocol-handler/routes/pull-v1.test.ts +49 -33
  1660. package/src/server-protocol-handler/routes/pull-v1.ts +1 -1
  1661. package/src/server-protocol-handler/routes/push-v1.test.ts +26 -27
  1662. package/src/server-protocol-handler/routes/push-v1.ts +4 -1
  1663. package/src/snapshot/schema.test.ts +268 -0
  1664. package/src/snapshot/schema.ts +29 -0
  1665. package/src/state/README.md +95 -0
  1666. package/src/state/cache/clear-state-cache.test.ts +43 -0
  1667. package/src/state/cache/clear-state-cache.ts +16 -0
  1668. package/src/state/cache/is-stale-state-cache.test.ts +35 -0
  1669. package/src/state/cache/is-stale-state-cache.ts +29 -0
  1670. package/src/state/cache/mark-state-cache-as-stale.ts +53 -0
  1671. package/src/state/cache/populate-state-cache.test.ts +259 -0
  1672. package/src/state/cache/populate-state-cache.ts +124 -0
  1673. package/src/state/cache/schema.ts +41 -0
  1674. package/src/state/cache/update-state-cache.test.ts +510 -0
  1675. package/src/state/cache/update-state-cache.ts +317 -0
  1676. package/src/state/commit.test.ts +1402 -0
  1677. package/src/state/commit.ts +587 -0
  1678. package/src/state/insert-transaction-state.test.ts +928 -0
  1679. package/src/state/insert-transaction-state.ts +306 -0
  1680. package/src/state/materialize-state.test.ts +2358 -0
  1681. package/src/state/materialize-state.ts +235 -0
  1682. package/src/state/primary-key.test.ts +158 -0
  1683. package/src/state/primary-key.ts +80 -0
  1684. package/src/state/resolved-state-view.test.ts +521 -0
  1685. package/src/state/resolved-state-view.ts +202 -0
  1686. package/src/state/schema.bench.ts +43 -0
  1687. package/src/state/schema.test.ts +3260 -0
  1688. package/src/state/schema.ts +992 -0
  1689. package/src/state/untracked/schema.test.ts +301 -0
  1690. package/src/state/untracked/schema.ts +55 -0
  1691. package/src/state/untracked/update-untracked-state.test.ts +466 -0
  1692. package/src/state/untracked/update-untracked-state.ts +133 -0
  1693. package/src/state/validate-state-mutation.test.ts +3308 -0
  1694. package/src/state/validate-state-mutation.ts +866 -0
  1695. package/src/state-history/schema.test.ts +1002 -0
  1696. package/src/state-history/schema.ts +221 -0
  1697. package/src/stored-schema/index.ts +4 -0
  1698. package/src/stored-schema/schema.test.ts +240 -0
  1699. package/src/stored-schema/schema.ts +67 -0
  1700. package/src/sync/get-diffing-rows.ts +16 -0
  1701. package/src/sync/merge-state.ts +7 -4
  1702. package/src/sync/pull-from-server.test.ts +33 -28
  1703. package/src/sync/pull-from-server.ts +4 -2
  1704. package/src/sync/push-to-server.test.ts +79 -83
  1705. package/src/sync/push-to-server.ts +11 -2
  1706. package/src/sync/sync-process.test.ts +21 -18
  1707. package/src/sync/sync-process.ts +2 -3
  1708. package/src/test-utilities/simulation-test/cache-miss-simulation.test.ts +162 -0
  1709. package/src/test-utilities/simulation-test/cache-miss-simulation.ts +99 -0
  1710. package/src/test-utilities/simulation-test/chaotic-timestamp-simulation.ts +0 -0
  1711. package/src/test-utilities/simulation-test/out-of-order-sequence-simulation.test.ts +88 -0
  1712. package/src/test-utilities/simulation-test/out-of-order-sequence-simulation.ts +69 -0
  1713. package/src/test-utilities/simulation-test/simulation-test.test.ts +400 -0
  1714. package/src/test-utilities/simulation-test/simulation-test.ts +176 -0
  1715. package/src/thread/create-thread-comment.test.ts +122 -0
  1716. package/src/thread/create-thread-comment.ts +84 -0
  1717. package/src/thread/create-thread.test.ts +212 -0
  1718. package/src/thread/create-thread.ts +108 -0
  1719. package/src/thread/index.ts +9 -0
  1720. package/src/thread/schema.test.ts +157 -0
  1721. package/src/thread/schema.ts +90 -0
  1722. package/src/version/create-version.test.ts +135 -116
  1723. package/src/version/create-version.ts +64 -61
  1724. package/src/version/index.ts +5 -6
  1725. package/src/version/schema.test.ts +1030 -0
  1726. package/src/version/schema.ts +163 -0
  1727. package/src/version/select-active-version.ts +18 -0
  1728. package/src/version/switch-version.test.ts +14 -275
  1729. package/src/version/switch-version.ts +9 -79
  1730. package/src/zettel-ast/index.ts +10 -0
  1731. package/src/account/database-schema.test.ts +0 -184
  1732. package/src/account/database-schema.ts +0 -54
  1733. package/src/change/apply-changes.test.ts +0 -268
  1734. package/src/change/apply-changes.ts +0 -114
  1735. package/src/change/create-change.test.ts +0 -296
  1736. package/src/change/create-change.ts +0 -129
  1737. package/src/change/mock-change.ts +0 -21
  1738. package/src/change-schema/README.md +0 -3
  1739. package/src/change-schema/index.ts +0 -4
  1740. package/src/change-schema/types.test-d.ts +0 -52
  1741. package/src/change-schema/types.ts +0 -53
  1742. package/src/change-set/change-set-element-in-symmetric-difference.test.ts +0 -128
  1743. package/src/database/apply-schema.ts +0 -272
  1744. package/src/database/init-db.test.ts +0 -626
  1745. package/src/database/mutation-log/database-schema.ts +0 -128
  1746. package/src/database/mutation-log/lix-session.ts +0 -19
  1747. package/src/discussion/create-comment.ts +0 -18
  1748. package/src/discussion/create-discussion.test.ts +0 -45
  1749. package/src/discussion/create-discussion.ts +0 -48
  1750. package/src/discussion/index.ts +0 -2
  1751. package/src/file/validate-file-path.test.ts +0 -44
  1752. package/src/file/validate-file-path.ts +0 -60
  1753. package/src/file-queue/file-handlers.ts +0 -267
  1754. package/src/file-queue/file-queue-process.test.ts +0 -456
  1755. package/src/file-queue/file-queue-process.ts +0 -108
  1756. package/src/file-queue/file-queue-settled.test.ts +0 -56
  1757. package/src/file-queue/file-queue-settled.ts +0 -31
  1758. package/src/file-queue/index.ts +0 -1
  1759. package/src/file-queue/with-skip-file-queue.test.ts +0 -158
  1760. package/src/file-queue/with-skip-file-queue.ts +0 -33
  1761. package/src/key-value/database-schema.test.ts +0 -140
  1762. package/src/key-value/database-schema.ts +0 -66
  1763. package/src/lix/close-lix.ts +0 -8
  1764. package/src/lix/merge.get-leaf-changes-only-in-source.test.ts +0 -143
  1765. package/src/lix/merge.get-leaf-changes-only-in-source.ts +0 -46
  1766. package/src/lix/merge.test.ts +0 -858
  1767. package/src/lix/merge.ts +0 -244
  1768. package/src/lix/open-lix-in-memory.test.ts +0 -34
  1769. package/src/lix/open-lix-in-memory.ts +0 -28
  1770. package/src/lix/to-blob.ts +0 -14
  1771. package/src/own-change-control/apply-own-change.test.ts +0 -361
  1772. package/src/own-change-control/apply-own-change.ts +0 -110
  1773. package/src/own-change-control/change-controlled-tables.test.ts +0 -69
  1774. package/src/own-change-control/change-controlled-tables.ts +0 -102
  1775. package/src/own-change-control/database-triggers.test.ts +0 -259
  1776. package/src/own-change-control/database-triggers.ts +0 -189
  1777. package/src/own-change-control/index.ts +0 -1
  1778. package/src/own-change-control/with-skip-own-change-control.test.ts +0 -57
  1779. package/src/own-change-control/with-skip-own-change-control.ts +0 -34
  1780. package/src/plugin/load-plugin.ts +0 -37
  1781. package/src/plugin/with-transaction.ts +0 -22
  1782. package/src/query-filter/change-conflict-in-version.test.ts +0 -62
  1783. package/src/query-filter/change-conflict-in-version.ts +0 -25
  1784. package/src/query-filter/change-has-label.test.ts +0 -52
  1785. package/src/query-filter/change-has-label.ts +0 -41
  1786. package/src/query-filter/change-in-version.test.ts +0 -82
  1787. package/src/query-filter/change-in-version.ts +0 -31
  1788. package/src/query-filter/change-is-leaf-in-version.test.ts +0 -77
  1789. package/src/query-filter/change-is-leaf-in-version.ts +0 -36
  1790. package/src/query-filter/change-is-leaf-of.bench.ts +0 -175
  1791. package/src/query-filter/change-is-leaf-of.test.ts +0 -84
  1792. package/src/query-filter/change-is-leaf-of.ts +0 -46
  1793. package/src/query-filter/change-is-leaf.test.ts +0 -140
  1794. package/src/query-filter/change-is-leaf.ts +0 -25
  1795. package/src/query-filter/change-is-lowest-common-ancestor-of.test.ts +0 -173
  1796. package/src/query-filter/change-is-lowest-common-ancestor-of.ts +0 -57
  1797. package/src/query-filter/change-set-has-label.test.ts +0 -50
  1798. package/src/query-filter/change-set-has-label.ts +0 -36
  1799. package/src/query-filter/version-change-in-difference.test.ts +0 -105
  1800. package/src/query-filter/version-change-in-difference.ts +0 -37
  1801. package/src/query-filter/version-change-in-symmetric-difference.test.ts +0 -104
  1802. package/src/query-filter/version-change-in-symmetric-difference.ts +0 -52
  1803. package/src/snapshot/create-snapshot.test.ts +0 -68
  1804. package/src/snapshot/create-snapshot.ts +0 -40
  1805. package/src/snapshot/index.ts +0 -2
  1806. package/src/snapshot/json-sha-256.test.ts +0 -12
  1807. package/src/snapshot/json-sha-256.ts +0 -35
  1808. package/src/snapshot/mock-json-snapshot.ts +0 -14
  1809. package/src/version/merge-version.test.ts +0 -530
  1810. package/src/version/merge-version.ts +0 -88
  1811. package/src/version/update-changes-in-version.test.ts +0 -371
  1812. package/src/version/update-changes-in-version.ts +0 -47
@@ -0,0 +1,1646 @@
1
+ import { test, expect, expectTypeOf } from "vitest";
2
+ import { openLix } from "../lix/open-lix.js";
3
+ import { createVersion } from "../version/create-version.js";
4
+ import { createCheckpoint } from "../commit/create-checkpoint.js";
5
+ import { switchVersion } from "../version/switch-version.js";
6
+ import { mockJsonPlugin } from "../plugin/mock-json-plugin.js";
7
+ import type { LixPlugin } from "../plugin/lix-plugin.js";
8
+ import type { LixFile } from "./schema.js";
9
+
10
+ test("insert, update, delete on the file view", async () => {
11
+ const lix = await openLix({
12
+ providePlugins: [mockJsonPlugin],
13
+ });
14
+
15
+ await lix.db
16
+ .insertInto("file")
17
+ .values([
18
+ {
19
+ id: "file0",
20
+ path: "/path/to/file.json",
21
+ data: new TextEncoder().encode(
22
+ JSON.stringify({
23
+ prop0: "file0-value0",
24
+ })
25
+ ),
26
+ },
27
+ ])
28
+ .execute();
29
+
30
+ let viewAfterInsert = await lix.db.selectFrom("file").selectAll().execute();
31
+ viewAfterInsert = viewAfterInsert.map((row) => ({
32
+ ...row,
33
+ data: JSON.parse(new TextDecoder().decode(row.data)),
34
+ }));
35
+
36
+ expect(viewAfterInsert).toMatchObject([
37
+ {
38
+ id: "file0",
39
+ path: "/path/to/file.json",
40
+ lixcol_inherited_from_version_id: null,
41
+ lixcol_created_at: expect.any(String),
42
+ lixcol_updated_at: expect.any(String),
43
+ lixcol_change_id: expect.any(String),
44
+ lixcol_untracked: 0,
45
+ data: { prop0: "file0-value0" },
46
+ metadata: null,
47
+ },
48
+ ]);
49
+
50
+ await lix.db
51
+ .updateTable("file")
52
+ .where("id", "=", "file0")
53
+ .set({
54
+ path: "/path/to/renamed_file.json",
55
+ data: new TextEncoder().encode(JSON.stringify({ prop0: "file0-value1" })),
56
+ })
57
+ .execute();
58
+
59
+ let viewAfterUpdate = await lix.db
60
+ .selectFrom("file")
61
+ .orderBy("id")
62
+ .selectAll()
63
+ .execute();
64
+
65
+ viewAfterUpdate = viewAfterUpdate.map((row) => ({
66
+ ...row,
67
+ data: JSON.parse(new TextDecoder().decode(row.data)),
68
+ }));
69
+
70
+ expect(viewAfterUpdate).toMatchObject([
71
+ {
72
+ id: "file0",
73
+ path: "/path/to/renamed_file.json",
74
+ lixcol_inherited_from_version_id: null,
75
+ lixcol_created_at: expect.any(String),
76
+ lixcol_updated_at: expect.any(String),
77
+ lixcol_change_id: expect.any(String),
78
+ lixcol_untracked: 0,
79
+ data: { prop0: "file0-value1" },
80
+ metadata: null,
81
+ },
82
+ ]);
83
+
84
+ await lix.db.deleteFrom("file").where("id", "=", "file0").execute();
85
+
86
+ const viewAfterDelete = await lix.db
87
+ .selectFrom("file")
88
+ .orderBy("id")
89
+ .select(["id", "path"])
90
+ .execute();
91
+
92
+ expect(viewAfterDelete).toEqual([]);
93
+
94
+ const changes = await lix.db
95
+ .selectFrom("change")
96
+ .where("file_id", "in", ["file0", "file1"])
97
+ .select(["entity_id", "snapshot_content", "schema_key"])
98
+ .execute();
99
+
100
+ expect(changes).toEqual(
101
+ expect.arrayContaining([
102
+ // insert
103
+ expect.objectContaining({
104
+ schema_key: "lix_file_descriptor",
105
+ entity_id: "file0",
106
+ snapshot_content: expect.any(Object),
107
+ }),
108
+ expect.objectContaining({
109
+ schema_key: "mock_json_property",
110
+ entity_id: "prop0",
111
+ snapshot_content: {
112
+ value: "file0-value0",
113
+ },
114
+ }),
115
+ // update
116
+ expect.objectContaining({
117
+ schema_key: "lix_file_descriptor",
118
+ entity_id: "file0",
119
+ snapshot_content: expect.any(Object),
120
+ }),
121
+ expect.objectContaining({
122
+ schema_key: "mock_json_property",
123
+ entity_id: "prop0",
124
+ snapshot_content: {
125
+ value: "file0-value1",
126
+ },
127
+ }),
128
+ // delete (file‑level)
129
+ expect.objectContaining({
130
+ schema_key: "lix_file_descriptor",
131
+ entity_id: "file0",
132
+ snapshot_content: null,
133
+ }),
134
+ // delete (all plugin entities that existed in the file)
135
+ expect.objectContaining({
136
+ schema_key: "mock_json_property",
137
+ entity_id: "prop0",
138
+ snapshot_content: null,
139
+ }),
140
+ ])
141
+ );
142
+ expect(changes).toHaveLength(6);
143
+ });
144
+
145
+ test("file insert data materialization", async () => {
146
+ const lix = await openLix({
147
+ providePlugins: [mockJsonPlugin],
148
+ });
149
+
150
+ await lix.db
151
+ .insertInto("file")
152
+ .values({
153
+ id: "file0",
154
+ path: "/path/to/file.json",
155
+ data: new TextEncoder().encode(
156
+ JSON.stringify({
157
+ prop0: "file0-value0",
158
+ })
159
+ ),
160
+ })
161
+ .execute();
162
+
163
+ let viewAfterInsert = await lix.db.selectFrom("file").selectAll().execute();
164
+ viewAfterInsert = viewAfterInsert.map((row) => ({
165
+ ...row,
166
+ data: JSON.parse(new TextDecoder().decode(row.data)),
167
+ }));
168
+
169
+ expect(viewAfterInsert).toMatchObject([
170
+ {
171
+ id: "file0",
172
+ path: "/path/to/file.json",
173
+ lixcol_inherited_from_version_id: null,
174
+ lixcol_created_at: expect.any(String),
175
+ lixcol_updated_at: expect.any(String),
176
+ lixcol_change_id: expect.any(String),
177
+ lixcol_untracked: 0,
178
+ data: { prop0: "file0-value0" },
179
+ metadata: null,
180
+ },
181
+ ]);
182
+ });
183
+
184
+ test("file ids should have a default", async () => {
185
+ const lix = await openLix({
186
+ providePlugins: [mockJsonPlugin],
187
+ });
188
+
189
+ await lix.db
190
+ .insertInto("file")
191
+ .values({
192
+ path: "/mock.json",
193
+ data: new Uint8Array(),
194
+ })
195
+ .execute();
196
+
197
+ const file = await lix.db
198
+ .selectFrom("file")
199
+ .where("path", "=", "/mock.json")
200
+ .selectAll()
201
+ .executeTakeFirstOrThrow();
202
+
203
+ expect(file.id).toBeDefined();
204
+ });
205
+
206
+ test("files should be able to have metadata", async () => {
207
+ const lix = await openLix({
208
+ providePlugins: [mockJsonPlugin],
209
+ });
210
+
211
+ await lix.db
212
+ .insertInto("file")
213
+ .values({
214
+ path: "/mock.json",
215
+ data: new Uint8Array(),
216
+ metadata: {
217
+ primary_key: "email",
218
+ },
219
+ })
220
+ .execute();
221
+
222
+ const file = await lix.db
223
+ .selectFrom("file")
224
+ .where("path", "=", "/mock.json")
225
+ .selectAll()
226
+ .executeTakeFirstOrThrow();
227
+
228
+ expect(file.metadata?.primary_key).toBe("email");
229
+
230
+ const updatedFile = await lix.db
231
+ .updateTable("file")
232
+ .where("path", "=", "/mock.json")
233
+ .set({
234
+ metadata: {
235
+ primary_key: "something-else",
236
+ },
237
+ })
238
+ .returningAll()
239
+ .executeTakeFirstOrThrow();
240
+
241
+ expect(updatedFile.metadata?.primary_key).toBe("something-else");
242
+ });
243
+
244
+ test("invalid file paths should be rejected", async () => {
245
+ const lix = await openLix({
246
+ providePlugins: [mockJsonPlugin],
247
+ });
248
+
249
+ await expect(
250
+ lix.db
251
+ .insertInto("file")
252
+ .values({
253
+ path: "invalid-path",
254
+ data: new Uint8Array(),
255
+ })
256
+ .execute()
257
+ ).rejects.toThrowError("path must match pattern");
258
+ });
259
+
260
+ test("files should have hidden property defaulting to false", async () => {
261
+ const lix = await openLix({
262
+ providePlugins: [mockJsonPlugin],
263
+ });
264
+
265
+ await lix.db
266
+ .insertInto("file")
267
+ .values({
268
+ path: "/hidden-default.json",
269
+ data: new Uint8Array(),
270
+ })
271
+ .execute();
272
+
273
+ const file = await lix.db
274
+ .selectFrom("file")
275
+ .where("path", "=", "/hidden-default.json")
276
+ .selectAll()
277
+ .executeTakeFirstOrThrow();
278
+
279
+ expect(file.hidden).toBe(0);
280
+ });
281
+
282
+ test("can explicitly set hidden to true", async () => {
283
+ const lix = await openLix({
284
+ providePlugins: [mockJsonPlugin],
285
+ });
286
+
287
+ await lix.db
288
+ .insertInto("file")
289
+ .values({
290
+ path: "/hidden.json",
291
+ data: new Uint8Array(),
292
+ hidden: true,
293
+ })
294
+ .execute();
295
+
296
+ const file = await lix.db
297
+ .selectFrom("file")
298
+ .where("path", "=", "/hidden.json")
299
+ .selectAll()
300
+ .executeTakeFirstOrThrow();
301
+
302
+ expect(file.hidden).toBe(1);
303
+ });
304
+
305
+ test("file_all operations are version specific and isolated", async () => {
306
+ const lix = await openLix({
307
+ providePlugins: [mockJsonPlugin],
308
+ });
309
+
310
+ const versionA = await createVersion({
311
+ lix,
312
+ id: "versionA",
313
+ });
314
+
315
+ const versionB = await createVersion({
316
+ lix,
317
+ id: "versionB",
318
+ });
319
+
320
+ // Insert file in version A
321
+ await lix.db
322
+ .insertInto("file_all")
323
+ .values({
324
+ id: "fileA",
325
+ path: "/shared/file.json",
326
+ data: new TextEncoder().encode(JSON.stringify({ content: "versionA" })),
327
+ lixcol_version_id: versionA.id,
328
+ })
329
+ .execute();
330
+
331
+ // Insert file in version B with same path but different content
332
+ await lix.db
333
+ .insertInto("file_all")
334
+ .values({
335
+ id: "fileB",
336
+ path: "/shared/file.json",
337
+ data: new TextEncoder().encode(JSON.stringify({ content: "versionB" })),
338
+ lixcol_version_id: versionB.id,
339
+ })
340
+ .execute();
341
+
342
+ // Verify both versions have their own files
343
+ const filesInVersionA = await lix.db
344
+ .selectFrom("file_all")
345
+ .where("lixcol_version_id", "=", versionA.id)
346
+ .selectAll()
347
+ .execute();
348
+
349
+ const filesInVersionB = await lix.db
350
+ .selectFrom("file_all")
351
+ .where("lixcol_version_id", "=", versionB.id)
352
+ .selectAll()
353
+ .execute();
354
+
355
+ expect(filesInVersionA).toHaveLength(1);
356
+ expect(filesInVersionB).toHaveLength(1);
357
+ expect(
358
+ JSON.parse(new TextDecoder().decode(filesInVersionA[0]?.data))
359
+ ).toEqual({ content: "versionA" });
360
+ expect(
361
+ JSON.parse(new TextDecoder().decode(filesInVersionB[0]?.data))
362
+ ).toEqual({ content: "versionB" });
363
+
364
+ // Update file in version A
365
+ await lix.db
366
+ .updateTable("file_all")
367
+ .where("id", "=", "fileA")
368
+ .where("lixcol_version_id", "=", versionA.id)
369
+ .set({
370
+ data: new TextEncoder().encode(
371
+ JSON.stringify({ content: "versionA-updated" })
372
+ ),
373
+ })
374
+ .execute();
375
+
376
+ // Verify update only affected version A
377
+ const updatedFilesA = await lix.db
378
+ .selectFrom("file_all")
379
+ .where("lixcol_version_id", "=", versionA.id)
380
+ .selectAll()
381
+ .execute();
382
+
383
+ const unchangedFilesB = await lix.db
384
+ .selectFrom("file_all")
385
+ .where("lixcol_version_id", "=", versionB.id)
386
+ .selectAll()
387
+ .execute();
388
+
389
+ expect(JSON.parse(new TextDecoder().decode(updatedFilesA[0]?.data))).toEqual({
390
+ content: "versionA-updated",
391
+ });
392
+ expect(
393
+ JSON.parse(new TextDecoder().decode(unchangedFilesB[0]?.data))
394
+ ).toEqual({ content: "versionB" });
395
+
396
+ // Delete file from version A
397
+ await lix.db
398
+ .deleteFrom("file_all")
399
+ .where("id", "=", "fileA")
400
+ .where("lixcol_version_id", "=", versionA.id)
401
+ .execute();
402
+
403
+ // Verify deletion only affected version A
404
+ const remainingFilesA = await lix.db
405
+ .selectFrom("file_all")
406
+ .where("lixcol_version_id", "=", versionA.id)
407
+ .selectAll()
408
+ .execute();
409
+
410
+ const remainingFilesB = await lix.db
411
+ .selectFrom("file_all")
412
+ .where("lixcol_version_id", "=", versionB.id)
413
+ .selectAll()
414
+ .execute();
415
+
416
+ expect(remainingFilesA).toHaveLength(0);
417
+ expect(remainingFilesB).toHaveLength(1);
418
+ expect(
419
+ JSON.parse(new TextDecoder().decode(remainingFilesB[0]?.data))
420
+ ).toEqual({ content: "versionB" });
421
+ });
422
+
423
+ test("the plugin is the source of truth. the fallback plugin is not invoked if a plugin is configured for the file type", async () => {
424
+ const mockTxtPlugin: LixPlugin = {
425
+ key: "mock-txt",
426
+ detectChanges: () => {
427
+ return [];
428
+ },
429
+ applyChanges: () => ({ fileData: new Uint8Array() }),
430
+ detectChangesGlob: "*.txt",
431
+ };
432
+
433
+ const lix = await openLix({
434
+ providePlugins: [mockTxtPlugin],
435
+ });
436
+
437
+ await lix.db
438
+ .insertInto("file")
439
+ .values({
440
+ id: "mock-file",
441
+ path: "/mock.txt",
442
+ data: new TextEncoder().encode("some content"),
443
+ })
444
+ .execute();
445
+
446
+ const fileAfterInsert = await lix.db
447
+ .selectFrom("file")
448
+ .where("id", "=", "mock-file")
449
+ .select("data")
450
+ .executeTakeFirstOrThrow();
451
+
452
+ expect(fileAfterInsert.data).toEqual(new Uint8Array());
453
+
454
+ await lix.db
455
+ .updateTable("file")
456
+ .set({ data: new TextEncoder().encode("some other content") })
457
+ .where("id", "=", "mock-file")
458
+ .execute();
459
+
460
+ const fileAfterUpdate = await lix.db
461
+ .selectFrom("file")
462
+ .where("id", "=", "mock-file")
463
+ .select("data")
464
+ .executeTakeFirstOrThrow();
465
+
466
+ expect(fileAfterUpdate.data).toEqual(new Uint8Array());
467
+
468
+ await lix.db.deleteFrom("file").where("id", "=", "mock-file").execute();
469
+
470
+ const fileAfterDelete = await lix.db
471
+ .selectFrom("file")
472
+ .where("id", "=", "mock-file")
473
+ .select("data")
474
+ .executeTakeFirst();
475
+
476
+ expect(fileAfterDelete).toBeUndefined();
477
+ });
478
+
479
+ test("file_history provides access to historical file data", async () => {
480
+ const lix = await openLix({
481
+ providePlugins: [mockJsonPlugin],
482
+ });
483
+
484
+ // 1. Insert file
485
+ const initialData = { prop0: "initial-value" };
486
+ await lix.db
487
+ .insertInto("file")
488
+ .values({
489
+ id: "test-file",
490
+ path: "/test.json",
491
+ data: new TextEncoder().encode(JSON.stringify(initialData)),
492
+ })
493
+ .execute();
494
+
495
+ // 2. Create checkpoint
496
+ const insertCheckpoint = await createCheckpoint({
497
+ lix,
498
+ });
499
+
500
+ // 3. Update file
501
+ const updatedData = { prop0: "updated-value" };
502
+ await lix.db
503
+ .updateTable("file")
504
+ .where("id", "=", "test-file")
505
+ .set({
506
+ data: new TextEncoder().encode(JSON.stringify(updatedData)),
507
+ })
508
+ .execute();
509
+
510
+ const updateCheckpoint = await createCheckpoint({
511
+ lix,
512
+ });
513
+
514
+ // 4. Query file, assert that file equals update
515
+ const currentFile = await lix.db
516
+ .selectFrom("file")
517
+ .where("id", "=", "test-file")
518
+ .selectAll()
519
+ .executeTakeFirstOrThrow();
520
+
521
+ const currentFileData = JSON.parse(
522
+ new TextDecoder().decode(currentFile.data)
523
+ );
524
+ expect(currentFileData).toEqual(updatedData);
525
+
526
+ // 5. Query history at checkpoint and assert is initial
527
+ const fileHistoryAtInsert = await lix.db
528
+ .selectFrom("file_history")
529
+ .where("id", "=", "test-file")
530
+ .where("lixcol_root_commit_id", "=", insertCheckpoint.id)
531
+ .where("lixcol_depth", "=", 0)
532
+ .selectAll()
533
+ .execute();
534
+
535
+ expect(fileHistoryAtInsert).toHaveLength(1);
536
+
537
+ const historicalFileAtInsert = fileHistoryAtInsert[0]!;
538
+ const historicalFileAtInsertData = JSON.parse(
539
+ new TextDecoder().decode(historicalFileAtInsert.data)
540
+ );
541
+
542
+ expect(historicalFileAtInsertData).toEqual(initialData);
543
+ expect(historicalFileAtInsert.id).toBe("test-file");
544
+ expect(historicalFileAtInsert.path).toBe("/test.json");
545
+ expect(historicalFileAtInsert.lixcol_commit_id).toBe(insertCheckpoint.id);
546
+
547
+ // 6. Query history at update checkpoint and assert is updated
548
+ const fileHistoryAtUpdate = await lix.db
549
+ .selectFrom("file_history")
550
+ .where("id", "=", "test-file")
551
+ .where("lixcol_root_commit_id", "=", updateCheckpoint.id)
552
+ .where("lixcol_depth", "=", 0)
553
+ .selectAll()
554
+ .execute();
555
+
556
+ expect(fileHistoryAtUpdate).toHaveLength(1);
557
+ const historicalFileAtUpdate = fileHistoryAtUpdate[0]!;
558
+ const historicalFileAtUpdateData = JSON.parse(
559
+ new TextDecoder().decode(historicalFileAtUpdate.data)
560
+ );
561
+ expect(historicalFileAtUpdateData).toEqual(updatedData);
562
+ expect(historicalFileAtUpdate.id).toBe("test-file");
563
+ expect(historicalFileAtUpdate.path).toBe("/test.json");
564
+ expect(historicalFileAtUpdate.lixcol_commit_id).toBe(updateCheckpoint.id);
565
+ });
566
+
567
+ // its super annoying to work with metadata otherwise
568
+ test("file metadata is Record<string, any>", async () => {
569
+ const mockFile: LixFile = {
570
+ id: "test-file",
571
+ path: "/test.json",
572
+ data: new TextEncoder().encode(JSON.stringify({ prop0: "value0" })),
573
+ metadata: {
574
+ author: "test-user",
575
+ created_at: new Date().toISOString(),
576
+ },
577
+ };
578
+
579
+ expectTypeOf(mockFile.metadata).toEqualTypeOf<
580
+ Record<string, any> | null | undefined
581
+ >();
582
+ });
583
+
584
+ test("file and file_all views expose change_id for blame and diff functionality", async () => {
585
+ const lix = await openLix({
586
+ providePlugins: [mockJsonPlugin],
587
+ keyValues: [
588
+ {
589
+ key: "lix_deterministic_mode",
590
+ value: {
591
+ enabled: true,
592
+ bootstrap: true,
593
+ },
594
+ lixcol_version_id: "global",
595
+ },
596
+ ],
597
+ });
598
+
599
+ // Insert initial file using file view to ensure triggers are executed
600
+ await lix.db
601
+ .insertInto("file")
602
+ .values({
603
+ id: "change-id-test-file",
604
+ path: "/test-change-id.json",
605
+ data: new TextEncoder().encode(JSON.stringify({ prop: "initial value" })),
606
+ })
607
+ .execute();
608
+
609
+ // Query file_all view to verify change_id is exposed
610
+ const fileAllResult = await lix.db
611
+ .selectFrom("file_all")
612
+ .where("id", "=", "change-id-test-file")
613
+ .selectAll()
614
+ .execute();
615
+
616
+ expect(fileAllResult).toHaveLength(1);
617
+ expect(fileAllResult[0]?.lixcol_change_id).toBeDefined();
618
+ expect(typeof fileAllResult[0]?.lixcol_change_id).toBe("string");
619
+
620
+ // Query file view (filtered by active version) to verify change_id is exposed
621
+ const fileResult = await lix.db
622
+ .selectFrom("file")
623
+ .where("id", "=", "change-id-test-file")
624
+ .selectAll()
625
+ .execute();
626
+
627
+ expect(fileResult).toHaveLength(1);
628
+ expect(fileResult[0]?.lixcol_change_id).toBeDefined();
629
+ expect(typeof fileResult[0]?.lixcol_change_id).toBe("string");
630
+
631
+ // Verify that change_id matches between file and file_all views
632
+ expect(fileResult[0]?.lixcol_change_id).toBe(
633
+ fileAllResult[0]?.lixcol_change_id
634
+ );
635
+
636
+ // Get the latest change for this file (could be descriptor or content)
637
+ const latestChange = await lix.db
638
+ .selectFrom("change")
639
+ .where("file_id", "=", "change-id-test-file")
640
+ .orderBy("created_at", "desc")
641
+ .select(["id", "schema_key", "snapshot_content"])
642
+ .executeTakeFirstOrThrow();
643
+
644
+ // Verify that the change_id in the views matches the latest change
645
+ expect(fileResult[0]?.lixcol_change_id).toBe(latestChange.id);
646
+ expect(fileAllResult[0]?.lixcol_change_id).toBe(latestChange.id);
647
+
648
+ // Verify that the file view shows correct file info
649
+ expect(fileResult[0]?.id).toBe("change-id-test-file");
650
+ expect(fileResult[0]?.path).toBe("/test-change-id.json");
651
+
652
+ // Update the file to create a new change
653
+ await lix.db
654
+ .updateTable("file")
655
+ .set({
656
+ path: "/test-change-id-updated.json",
657
+ })
658
+ .where("id", "=", "change-id-test-file")
659
+ .execute();
660
+
661
+ // Query again to verify change_id updated after modification
662
+ const updatedFileResult = await lix.db
663
+ .selectFrom("file_all")
664
+ .where("id", "=", "change-id-test-file")
665
+ .selectAll()
666
+ .execute();
667
+
668
+ expect(updatedFileResult).toHaveLength(1);
669
+ expect(updatedFileResult[0]?.lixcol_change_id).toBeDefined();
670
+ // The change_id should be different after the update (new change created)
671
+ expect(updatedFileResult[0]?.lixcol_change_id).not.toBe(
672
+ fileResult[0]?.lixcol_change_id
673
+ );
674
+
675
+ // Get the new file entity change record
676
+ const newFileChangeRecord = await lix.db
677
+ .selectFrom("change")
678
+ .where("file_id", "=", "change-id-test-file")
679
+ .where("schema_key", "=", "lix_file_descriptor")
680
+ .orderBy("created_at", "desc")
681
+ .select(["id", "snapshot_content"])
682
+ .executeTakeFirstOrThrow();
683
+
684
+ // Verify the new change_id matches the latest file change
685
+ expect(updatedFileResult[0]?.lixcol_change_id).toBe(newFileChangeRecord.id);
686
+
687
+ // Verify that the updated snapshot content in the change matches the file view
688
+ expect(newFileChangeRecord.snapshot_content).toMatchObject({
689
+ id: "change-id-test-file",
690
+ path: "/test-change-id-updated.json",
691
+ });
692
+ expect(updatedFileResult[0]?.path).toBe("/test-change-id-updated.json");
693
+ });
694
+
695
+ test("file data updates create new change_id", async () => {
696
+ const lix = await openLix({
697
+ providePlugins: [mockJsonPlugin],
698
+ });
699
+
700
+ // Insert initial file
701
+ await lix.db
702
+ .insertInto("file")
703
+ .values({
704
+ id: "data-change-test",
705
+ path: "/data-test.json",
706
+ data: new TextEncoder().encode(JSON.stringify({ content: "initial" })),
707
+ })
708
+ .execute();
709
+
710
+ // Get initial change_id
711
+ const initialFile = await lix.db
712
+ .selectFrom("file")
713
+ .where("id", "=", "data-change-test")
714
+ .select(["lixcol_change_id"])
715
+ .executeTakeFirstOrThrow();
716
+
717
+ expect(initialFile.lixcol_change_id).toBeDefined();
718
+
719
+ // Update only the file data
720
+ await lix.db
721
+ .updateTable("file")
722
+ .set({
723
+ data: new TextEncoder().encode(
724
+ JSON.stringify({ content: "updated data" })
725
+ ),
726
+ })
727
+ .where("id", "=", "data-change-test")
728
+ .execute();
729
+
730
+ // Get updated change_id
731
+ const updatedFile = await lix.db
732
+ .selectFrom("file")
733
+ .where("id", "=", "data-change-test")
734
+ .select(["lixcol_change_id"])
735
+ .executeTakeFirstOrThrow();
736
+
737
+ // Verify that updating file data created a new change_id
738
+ expect(updatedFile.lixcol_change_id).toBeDefined();
739
+ expect(updatedFile.lixcol_change_id).not.toBe(initialFile.lixcol_change_id);
740
+
741
+ // Verify the change record exists - this should be for the content entity, not the file entity
742
+ // When file data changes, it creates changes for the plugin-managed entities within the file
743
+ const contentChangeRecord = await lix.db
744
+ .selectFrom("change")
745
+ .where("file_id", "=", "data-change-test")
746
+ .where("schema_key", "=", "mock_json_property")
747
+ .where("entity_id", "=", "content")
748
+ .orderBy("created_at", "desc")
749
+ .select(["id", "entity_id", "schema_key", "snapshot_content"])
750
+ .executeTakeFirst();
751
+
752
+ expect(contentChangeRecord).toBeDefined();
753
+ expect(contentChangeRecord?.entity_id).toBe("content");
754
+ expect(contentChangeRecord?.schema_key).toBe("mock_json_property");
755
+ expect(contentChangeRecord?.snapshot_content).toEqual({
756
+ value: "updated data",
757
+ });
758
+ });
759
+
760
+ test("file metadata updates create new change_id", async () => {
761
+ const lix = await openLix({
762
+ providePlugins: [mockJsonPlugin],
763
+ });
764
+
765
+ // Insert initial file with metadata
766
+ await lix.db
767
+ .insertInto("file")
768
+ .values({
769
+ id: "metadata-change-test",
770
+ path: "/metadata-test.json",
771
+ data: new TextEncoder().encode(JSON.stringify({ content: "test" })),
772
+ metadata: { author: "initial author" },
773
+ })
774
+ .execute();
775
+
776
+ // Get initial change_id
777
+ const initialFile = await lix.db
778
+ .selectFrom("file")
779
+ .where("id", "=", "metadata-change-test")
780
+ .select(["lixcol_change_id", "path", "metadata"])
781
+ .executeTakeFirstOrThrow();
782
+
783
+ expect(initialFile.lixcol_change_id).toBeDefined();
784
+ expect(initialFile.path).toBe("/metadata-test.json");
785
+ expect(initialFile.metadata).toEqual({ author: "initial author" });
786
+
787
+ // Update the file path (which is part of the file entity metadata)
788
+ await lix.db
789
+ .updateTable("file")
790
+ .set({
791
+ path: "/updated-metadata-test.json",
792
+ })
793
+ .where("id", "=", "metadata-change-test")
794
+ .execute();
795
+
796
+ // Get updated change_id after path change
797
+ const updatedPathFile = await lix.db
798
+ .selectFrom("file")
799
+ .where("id", "=", "metadata-change-test")
800
+ .select(["lixcol_change_id", "path"])
801
+ .executeTakeFirstOrThrow();
802
+
803
+ // Verify that updating file path created a new change_id
804
+ expect(updatedPathFile.lixcol_change_id).toBeDefined();
805
+ expect(updatedPathFile.lixcol_change_id).not.toBe(
806
+ initialFile.lixcol_change_id
807
+ );
808
+ expect(updatedPathFile.path).toBe("/updated-metadata-test.json");
809
+
810
+ // Update the file metadata
811
+ await lix.db
812
+ .updateTable("file")
813
+ .set({
814
+ metadata: { author: "updated author", version: "2.0" },
815
+ })
816
+ .where("id", "=", "metadata-change-test")
817
+ .execute();
818
+
819
+ // Get updated change_id after metadata change
820
+ const updatedMetadataFile = await lix.db
821
+ .selectFrom("file")
822
+ .where("id", "=", "metadata-change-test")
823
+ .select(["lixcol_change_id", "metadata"])
824
+ .executeTakeFirstOrThrow();
825
+
826
+ // Verify that updating file metadata created another new change_id
827
+ expect(updatedMetadataFile.lixcol_change_id).toBeDefined();
828
+ expect(updatedMetadataFile.lixcol_change_id).not.toBe(
829
+ updatedPathFile.lixcol_change_id
830
+ );
831
+ expect(updatedMetadataFile.metadata).toEqual({
832
+ author: "updated author",
833
+ version: "2.0",
834
+ });
835
+
836
+ // Verify the final file entity change record exists and is correct
837
+ const finalFileChangeRecord = await lix.db
838
+ .selectFrom("change")
839
+ .where("id", "=", updatedMetadataFile.lixcol_change_id)
840
+ .where("entity_id", "=", "metadata-change-test")
841
+ .where("schema_key", "=", "lix_file_descriptor")
842
+ .selectAll()
843
+ .executeTakeFirst();
844
+
845
+ expect(finalFileChangeRecord).toBeDefined();
846
+ expect(finalFileChangeRecord?.entity_id).toBe("metadata-change-test");
847
+ expect(finalFileChangeRecord?.schema_key).toBe("lix_file_descriptor");
848
+ });
849
+
850
+ test("file descriptor updates with untracked state", async () => {
851
+ const lix = await openLix({
852
+ providePlugins: [mockJsonPlugin],
853
+ });
854
+
855
+ // Count changes before untracked insert
856
+ const changesBefore = await lix.db.selectFrom("change").selectAll().execute();
857
+
858
+ // Insert file with untracked=true
859
+ await lix.db
860
+ .insertInto("file")
861
+ .values({
862
+ id: "untracked-file",
863
+ path: "/untracked-test.json",
864
+ data: new TextEncoder().encode(JSON.stringify({ prop: "value" })),
865
+ lixcol_untracked: true,
866
+ })
867
+ .execute();
868
+
869
+ // Count changes after untracked insert
870
+ const changesAfterInsert = await lix.db
871
+ .selectFrom("change")
872
+ .selectAll()
873
+ .execute();
874
+
875
+ // Verify no changes were created (untracked bypasses change control)
876
+ expect(changesAfterInsert.length).toBe(changesBefore.length);
877
+
878
+ // Verify file exists in view
879
+ const fileResult = await lix.db
880
+ .selectFrom("file")
881
+ .where("id", "=", "untracked-file")
882
+ .selectAll()
883
+ .execute();
884
+
885
+ expect(fileResult).toHaveLength(1);
886
+ expect(fileResult[0]?.lixcol_untracked).toBe(1);
887
+ expect(fileResult[0]?.path).toBe("/untracked-test.json");
888
+
889
+ // Verify file data was processed by plugin
890
+ const decodedData = JSON.parse(new TextDecoder().decode(fileResult[0]?.data));
891
+ expect(decodedData).toEqual({ prop: "value" });
892
+
893
+ // Update file with untracked=true
894
+ await lix.db
895
+ .updateTable("file")
896
+ .where("id", "=", "untracked-file")
897
+ .set({
898
+ path: "/updated-untracked-test.json",
899
+ data: new TextEncoder().encode(JSON.stringify({ prop: "updated" })),
900
+ lixcol_untracked: true,
901
+ })
902
+ .execute();
903
+
904
+ // Count changes after untracked update
905
+ const changesAfterUpdate = await lix.db
906
+ .selectFrom("change")
907
+ .selectAll()
908
+ .execute();
909
+
910
+ // Verify no new changes were created (untracked bypasses change control)
911
+ expect(changesAfterUpdate.length).toBe(changesBefore.length);
912
+
913
+ // Verify file was updated
914
+ const updatedFile = await lix.db
915
+ .selectFrom("file")
916
+ .where("id", "=", "untracked-file")
917
+ .selectAll()
918
+ .execute();
919
+
920
+ expect(updatedFile).toHaveLength(1);
921
+ expect(updatedFile[0]?.lixcol_untracked).toBe(1);
922
+ expect(updatedFile[0]?.path).toBe("/updated-untracked-test.json");
923
+
924
+ // Verify updated file data was processed by plugin
925
+ const updatedData = JSON.parse(
926
+ new TextDecoder().decode(updatedFile[0]?.data)
927
+ );
928
+ expect(updatedData).toEqual({ prop: "updated" });
929
+
930
+ // Delete the untracked file
931
+ await lix.db.deleteFrom("file").where("id", "=", "untracked-file").execute();
932
+
933
+ // Count changes after untracked delete
934
+ const changesAfterDelete = await lix.db
935
+ .selectFrom("change")
936
+ .selectAll()
937
+ .execute();
938
+
939
+ // Verify no new changes were created (untracked bypasses change control)
940
+ expect(changesAfterDelete.length).toBe(changesBefore.length);
941
+
942
+ // Verify file was deleted
943
+ const deletedFile = await lix.db
944
+ .selectFrom("file")
945
+ .where("id", "=", "untracked-file")
946
+ .selectAll()
947
+ .execute();
948
+
949
+ expect(deletedFile).toHaveLength(0);
950
+ });
951
+
952
+ test("file data updates with untracked state", async () => {
953
+ const lix = await openLix({
954
+ providePlugins: [mockJsonPlugin],
955
+ });
956
+
957
+ // Count changes before any operations
958
+ const changesInitial = await lix.db
959
+ .selectFrom("change")
960
+ .selectAll()
961
+ .execute();
962
+
963
+ // Insert file with untracked=true from the start
964
+ await lix.db
965
+ .insertInto("file")
966
+ .values({
967
+ id: "untracked-data-file",
968
+ path: "/untracked-data.json",
969
+ data: new TextEncoder().encode(JSON.stringify({ content: "initial" })),
970
+ lixcol_untracked: true,
971
+ })
972
+ .execute();
973
+
974
+ // Count changes after untracked insert
975
+ const changesAfterInsert = await lix.db
976
+ .selectFrom("change")
977
+ .selectAll()
978
+ .execute();
979
+
980
+ // Verify no changes were created (untracked bypasses change control)
981
+ expect(changesAfterInsert.length).toBe(changesInitial.length);
982
+
983
+ // Verify file was inserted and is untracked
984
+ const insertedFile = await lix.db
985
+ .selectFrom("file")
986
+ .where("id", "=", "untracked-data-file")
987
+ .selectAll()
988
+ .execute();
989
+
990
+ expect(insertedFile).toHaveLength(1);
991
+ expect(insertedFile[0]?.lixcol_untracked).toBe(1);
992
+
993
+ // Verify file data was processed by plugin
994
+ const initialData = JSON.parse(
995
+ new TextDecoder().decode(insertedFile[0]?.data)
996
+ );
997
+ expect(initialData).toEqual({ content: "initial" });
998
+
999
+ // Update file data with untracked=true
1000
+ await lix.db
1001
+ .updateTable("file")
1002
+ .where("id", "=", "untracked-data-file")
1003
+ .set({
1004
+ data: new TextEncoder().encode(JSON.stringify({ content: "updated" })),
1005
+ lixcol_untracked: true,
1006
+ })
1007
+ .execute();
1008
+
1009
+ // Count changes after untracked update
1010
+ const changesAfterUpdate = await lix.db
1011
+ .selectFrom("change")
1012
+ .selectAll()
1013
+ .execute();
1014
+
1015
+ // Verify no new changes were created (untracked bypasses change control)
1016
+ expect(changesAfterUpdate.length).toBe(changesInitial.length);
1017
+
1018
+ // Verify file data was updated and is still untracked
1019
+ const updatedFile = await lix.db
1020
+ .selectFrom("file")
1021
+ .where("id", "=", "untracked-data-file")
1022
+ .selectAll()
1023
+ .execute();
1024
+
1025
+ expect(updatedFile).toHaveLength(1);
1026
+ expect(updatedFile[0]?.lixcol_untracked).toBe(1);
1027
+
1028
+ // Verify file data was updated and processed by plugin
1029
+ const updatedData = JSON.parse(
1030
+ new TextDecoder().decode(updatedFile[0]?.data)
1031
+ );
1032
+ expect(updatedData).toEqual({ content: "updated" });
1033
+
1034
+ // Delete the untracked file
1035
+ await lix.db
1036
+ .deleteFrom("file")
1037
+ .where("id", "=", "untracked-data-file")
1038
+ .execute();
1039
+
1040
+ // Count changes after untracked delete
1041
+ const changesAfterDelete = await lix.db
1042
+ .selectFrom("change")
1043
+ .selectAll()
1044
+ .execute();
1045
+
1046
+ // Verify no new changes were created (untracked bypasses change control)
1047
+ expect(changesAfterDelete.length).toBe(changesInitial.length);
1048
+
1049
+ // Verify file was deleted
1050
+ const deletedFile = await lix.db
1051
+ .selectFrom("file")
1052
+ .where("id", "=", "untracked-data-file")
1053
+ .selectAll()
1054
+ .execute();
1055
+
1056
+ expect(deletedFile).toHaveLength(0);
1057
+ });
1058
+
1059
+ test("file history", async () => {
1060
+ const lix = await openLix({
1061
+ providePlugins: [mockJsonPlugin],
1062
+ });
1063
+
1064
+ // Insert a JSON file
1065
+ const data = {
1066
+ name: "My Project",
1067
+ version: "1.0.0",
1068
+ };
1069
+
1070
+ await lix.db
1071
+ .insertInto("file")
1072
+ .values({
1073
+ path: "/config.json",
1074
+ data: new TextEncoder().encode(JSON.stringify(data)),
1075
+ })
1076
+ .execute();
1077
+
1078
+ // Make a change
1079
+ data.name = "My Cool Project";
1080
+ data.version = "1.1.0";
1081
+
1082
+ await lix.db
1083
+ .updateTable("file")
1084
+ .where("path", "=", "/config.json")
1085
+ .set({
1086
+ data: new TextEncoder().encode(JSON.stringify(data)),
1087
+ })
1088
+ .execute();
1089
+
1090
+ // 1. Get the last two versions of the JSON file from history
1091
+ const fileHistory = await lix.db
1092
+ .selectFrom("file_history")
1093
+ .where("file_history.path", "=", "/config.json")
1094
+ .where(
1095
+ "lixcol_root_commit_id",
1096
+ "=",
1097
+ lix.db
1098
+ .selectFrom("version")
1099
+ .select("commit_id")
1100
+ .where("version.name", "=", "main")
1101
+ )
1102
+ .orderBy("lixcol_depth", "asc")
1103
+ .selectAll()
1104
+ .execute();
1105
+
1106
+ expect(fileHistory).toHaveLength(2);
1107
+
1108
+ const afterState = JSON.parse(new TextDecoder().decode(fileHistory[0]!.data));
1109
+ const beforeState = JSON.parse(
1110
+ new TextDecoder().decode(fileHistory[1]!.data)
1111
+ );
1112
+
1113
+ expect(afterState).toEqual({
1114
+ name: "My Cool Project",
1115
+ version: "1.1.0",
1116
+ });
1117
+ expect(beforeState).toEqual({
1118
+ name: "My Project",
1119
+ version: "1.0.0",
1120
+ });
1121
+ });
1122
+
1123
+ // This test verifies that file_history correctly reconstructs files when only some properties change.
1124
+ // The bug occurred when querying file_history at depth=0 after a partial update:
1125
+ // - Changed entities appeared at depth=0
1126
+ // - Unchanged entities remained at depth=1+
1127
+ // The old implementation only returned entities at the exact depth, missing unchanged properties.
1128
+ test("file_history handles partial updates correctly", async () => {
1129
+ const lix = await openLix({
1130
+ providePlugins: [mockJsonPlugin],
1131
+ });
1132
+
1133
+ await lix.db
1134
+ .insertInto("file")
1135
+ .values({
1136
+ id: "abcdefg",
1137
+ path: "/test.json",
1138
+ data: new TextEncoder().encode(
1139
+ JSON.stringify({
1140
+ name: "test-item",
1141
+ value: 100,
1142
+ })
1143
+ ),
1144
+ })
1145
+ .execute();
1146
+
1147
+ const checkpoint0 = await createCheckpoint({ lix });
1148
+
1149
+ await lix.db
1150
+ .updateTable("file")
1151
+ .where("path", "=", "/test.json")
1152
+ .set({
1153
+ data: new TextEncoder().encode(
1154
+ JSON.stringify({
1155
+ name: "test-item",
1156
+ value: 105,
1157
+ })
1158
+ ),
1159
+ })
1160
+ .execute();
1161
+
1162
+ const checkpoint1 = await createCheckpoint({ lix });
1163
+
1164
+ const beforeFile = await lix.db
1165
+ .selectFrom("file_history")
1166
+ .where("path", "=", "/test.json")
1167
+ .where("lixcol_root_commit_id", "=", checkpoint0.id)
1168
+ .where("lixcol_depth", "=", 0)
1169
+ .select("data")
1170
+ .executeTakeFirstOrThrow();
1171
+
1172
+ const afterFile = await lix.db
1173
+ .selectFrom("file_history")
1174
+ .where("path", "=", "/test.json")
1175
+ .where("lixcol_root_commit_id", "=", checkpoint1.id)
1176
+ .where("lixcol_depth", "=", 0)
1177
+ .select("data")
1178
+ .executeTakeFirstOrThrow();
1179
+
1180
+ const beforeData = new TextDecoder().decode(beforeFile.data);
1181
+ const afterData = new TextDecoder().decode(afterFile.data);
1182
+
1183
+ const beforeDoc = JSON.parse(beforeData);
1184
+ const afterDoc = JSON.parse(afterData);
1185
+
1186
+ expect(beforeDoc).toEqual({
1187
+ name: "test-item",
1188
+ value: 100,
1189
+ });
1190
+
1191
+ expect(afterDoc).toEqual({
1192
+ name: "test-item",
1193
+ value: 105,
1194
+ });
1195
+ });
1196
+
1197
+ test("file views should expose same relevant lixcol_* columns as key_value view", async () => {
1198
+ const lix = await openLix({
1199
+ providePlugins: [mockJsonPlugin],
1200
+ });
1201
+
1202
+ // Create a file that will be available in all file views
1203
+ await lix.db
1204
+ .insertInto("file")
1205
+ .values({
1206
+ id: "lixcol-test-file",
1207
+ path: "/lixcol-test.json",
1208
+ data: new TextEncoder().encode(JSON.stringify({ test: "data" })),
1209
+ })
1210
+ .execute();
1211
+
1212
+ // Create a key_value entry for comparison baseline
1213
+ await lix.db
1214
+ .insertInto("key_value")
1215
+ .values({ key: "lixcol-test-kv", value: "test_value" })
1216
+ .execute();
1217
+
1218
+ // Create a checkpoint for view queries
1219
+ const checkpoint = await createCheckpoint({ lix });
1220
+
1221
+ // Extract lixcol_* columns helper function
1222
+ const extractLixcols = (obj: Record<string, any>) => {
1223
+ const lixcols: Record<string, any> = {};
1224
+ for (const [key, value] of Object.entries(obj)) {
1225
+ if (key.startsWith("lixcol_")) {
1226
+ lixcols[key] = value;
1227
+ }
1228
+ }
1229
+ return lixcols;
1230
+ };
1231
+
1232
+ // Filter out columns that don't make sense for file views (files are themselves entities)
1233
+ const blacklist = ["lixcol_file_id", "lixcol_plugin_key", "lixcol_entity_id"];
1234
+
1235
+ const filterColumns = (lixcols: Record<string, any>) => {
1236
+ const filtered: Record<string, any> = {};
1237
+ for (const [key, value] of Object.entries(lixcols)) {
1238
+ if (!blacklist.includes(key)) {
1239
+ filtered[key] = value;
1240
+ }
1241
+ }
1242
+ return filtered;
1243
+ };
1244
+
1245
+ // Test each file view type against corresponding key_value view
1246
+ const views = [
1247
+ {
1248
+ name: "file",
1249
+ fileQuery: () =>
1250
+ lix.db
1251
+ .selectFrom("file")
1252
+ .selectAll()
1253
+ .where("id", "=", "lixcol-test-file"),
1254
+ keyValueQuery: () =>
1255
+ lix.db
1256
+ .selectFrom("key_value")
1257
+ .selectAll()
1258
+ .where("key", "=", "lixcol-test-kv"),
1259
+ },
1260
+ {
1261
+ name: "file_all",
1262
+ fileQuery: () =>
1263
+ lix.db
1264
+ .selectFrom("file_all")
1265
+ .selectAll()
1266
+ .where("id", "=", "lixcol-test-file"),
1267
+ keyValueQuery: () =>
1268
+ lix.db
1269
+ .selectFrom("key_value_all")
1270
+ .selectAll()
1271
+ .where("key", "=", "lixcol-test-kv"),
1272
+ },
1273
+ {
1274
+ name: "file_history",
1275
+ fileQuery: () =>
1276
+ lix.db
1277
+ .selectFrom("file_history")
1278
+ .selectAll()
1279
+ .where("id", "=", "lixcol-test-file")
1280
+ .where("lixcol_root_commit_id", "=", checkpoint.id)
1281
+ .where("lixcol_depth", "=", 0),
1282
+ keyValueQuery: () =>
1283
+ lix.db
1284
+ .selectFrom("key_value_history")
1285
+ .selectAll()
1286
+ .where("key", "=", "lixcol-test-kv")
1287
+ .where("lixcol_root_commit_id", "=", checkpoint.id)
1288
+ .where("lixcol_depth", "=", 0),
1289
+ },
1290
+ ];
1291
+
1292
+ for (const view of views) {
1293
+ // Query both the file view and corresponding key_value view
1294
+ const fileResult = await view.fileQuery().executeTakeFirstOrThrow();
1295
+ const keyValueResult = await view.keyValueQuery().executeTakeFirstOrThrow();
1296
+
1297
+ // Extract and filter lixcol_* columns from both
1298
+ const fileLixcols = extractLixcols(fileResult);
1299
+ const keyValueLixcols = extractLixcols(keyValueResult);
1300
+
1301
+ const fileFilteredLixcols = filterColumns(fileLixcols);
1302
+ const keyValueFilteredLixcols = filterColumns(keyValueLixcols);
1303
+
1304
+ const fileFilteredKeys = Object.keys(fileFilteredLixcols).sort();
1305
+ const keyValueFilteredKeys = Object.keys(keyValueFilteredLixcols).sort();
1306
+
1307
+ // File view should expose the same relevant lixcol_* columns as corresponding key_value view (excluding blacklisted ones)
1308
+ expect(fileFilteredKeys).toEqual(keyValueFilteredKeys);
1309
+
1310
+ // Both should have the same number of relevant lixcol_* columns
1311
+ expect(fileFilteredKeys.length).toBe(keyValueFilteredKeys.length);
1312
+
1313
+ // All lixcol_* values should be defined (can be null, but not undefined)
1314
+ const fileLixcolKeys = Object.keys(fileLixcols).sort();
1315
+ for (const key of fileLixcolKeys) {
1316
+ expect(fileLixcols[key]).toBeDefined();
1317
+ }
1318
+
1319
+ // Verify that file views expose lix_file_descriptor as schema key
1320
+ expect(fileResult.lixcol_schema_key).toBe("lix_file_descriptor");
1321
+ }
1322
+ });
1323
+
1324
+ test("file should expose lixcol columns based on file data AND the descriptor", async () => {
1325
+ const lix = await openLix({
1326
+ providePlugins: [mockJsonPlugin],
1327
+ keyValues: [
1328
+ {
1329
+ key: "lix_deterministic_mode",
1330
+ value: {
1331
+ enabled: true,
1332
+ },
1333
+ lixcol_version_id: "global",
1334
+ },
1335
+ ],
1336
+ });
1337
+
1338
+ // Create a file with JSON content
1339
+ await lix.db
1340
+ .insertInto("file")
1341
+ .values({
1342
+ id: "aggregate-info-test",
1343
+ path: "/document.json",
1344
+ data: new TextEncoder().encode(
1345
+ JSON.stringify({
1346
+ title: "Original Title",
1347
+ content: "Original content",
1348
+ })
1349
+ ),
1350
+ })
1351
+ .execute();
1352
+
1353
+ // Get initial file info
1354
+ const fileAfterCreate = await lix.db
1355
+ .selectFrom("file")
1356
+ .where("id", "=", "aggregate-info-test")
1357
+ .selectAll()
1358
+ .executeTakeFirstOrThrow();
1359
+
1360
+ const initialChangeId = fileAfterCreate.lixcol_change_id;
1361
+ const initialUpdatedAt = fileAfterCreate.lixcol_updated_at;
1362
+
1363
+ // Verify that file view exposes lix_file_descriptor as schema key
1364
+ expect(fileAfterCreate.lixcol_schema_key).toBe("lix_file_descriptor");
1365
+
1366
+ // Verify the initial change is either for the file descriptor or a content entity
1367
+ const initialChange = await lix.db
1368
+ .selectFrom("change")
1369
+ .where("id", "=", initialChangeId)
1370
+ .selectAll()
1371
+ .executeTakeFirstOrThrow();
1372
+
1373
+ // When creating a file with content, the latest change could be either:
1374
+ // - The file descriptor change
1375
+ // - A content entity change (e.g., mock_json_property)
1376
+ expect(["lix_file_descriptor", "mock_json_property"]).toContain(
1377
+ initialChange.schema_key
1378
+ );
1379
+
1380
+ // If it's a content change, verify it belongs to this file
1381
+ if (initialChange.schema_key !== "lix_file_descriptor") {
1382
+ expect(initialChange.file_id).toBe("aggregate-info-test");
1383
+ }
1384
+
1385
+ // Update only the JSON content (not path or metadata)
1386
+ await lix.db
1387
+ .updateTable("file")
1388
+ .where("id", "=", "aggregate-info-test")
1389
+ .set({
1390
+ data: new TextEncoder().encode(
1391
+ JSON.stringify({
1392
+ title: "Updated Title", // Changed
1393
+ content: "Updated content", // Changed
1394
+ })
1395
+ ),
1396
+ })
1397
+ .execute();
1398
+
1399
+ // Get file info after content update
1400
+ const fileAfterContentUpdate = await lix.db
1401
+ .selectFrom("file")
1402
+ .where("id", "=", "aggregate-info-test")
1403
+ .selectAll()
1404
+ .executeTakeFirstOrThrow();
1405
+
1406
+ // Get all changes related to this file (descriptor + content)
1407
+ const allFileChanges = await lix.db
1408
+ .selectFrom("change")
1409
+ .where((eb) =>
1410
+ eb.or([
1411
+ // File descriptor changes
1412
+ eb("entity_id", "=", "aggregate-info-test").and(
1413
+ "schema_key",
1414
+ "=",
1415
+ "lix_file_descriptor"
1416
+ ),
1417
+ // Content changes (any entity within this file)
1418
+ eb("file_id", "=", "aggregate-info-test"),
1419
+ ])
1420
+ )
1421
+ .orderBy("created_at", "desc")
1422
+ .selectAll()
1423
+ .execute();
1424
+
1425
+ // There should be multiple changes (descriptor + content properties)
1426
+ expect(allFileChanges.length).toBeGreaterThan(1);
1427
+
1428
+ const latestContentChange = allFileChanges[0]!;
1429
+
1430
+ // The actual latest change is a content change, not the descriptor
1431
+ expect(latestContentChange.schema_key).not.toBe("lix_file_descriptor");
1432
+
1433
+ // The file view should show the latest change across ALL entities in the file
1434
+ expect(fileAfterContentUpdate.lixcol_change_id).toBe(latestContentChange.id);
1435
+
1436
+ // The updated_at should reflect when the file was last modified (including content)
1437
+ expect(fileAfterContentUpdate.lixcol_updated_at).toBe(
1438
+ latestContentChange.created_at
1439
+ );
1440
+
1441
+ // The file's change_set_id should contain the latest content change
1442
+ // Get all changes in the file's current change_set
1443
+ const changesInFileChangeSet = await lix.db
1444
+ .selectFrom("change_set_element")
1445
+ .where("change_set_id", "=", fileAfterContentUpdate.lixcol_commit_id)
1446
+ .selectAll()
1447
+ .execute();
1448
+
1449
+ const changeIdsInSet = changesInFileChangeSet.map((el) => el.change_id);
1450
+
1451
+ // The file's change_set_id should contain the latest content change
1452
+ expect(changeIdsInSet).toContain(latestContentChange.id);
1453
+
1454
+ // Test file_all view shows the same aggregated behavior AT THIS POINT (before path update)
1455
+ // Re-query file_all after content update to verify it shows latest change
1456
+ const fileAllAfterContentUpdate = await lix.db
1457
+ .selectFrom("file_all")
1458
+ .where("id", "=", "aggregate-info-test")
1459
+ .selectAll()
1460
+ .executeTakeFirstOrThrow();
1461
+
1462
+ // file_all should show the same change_id as the file view at this point
1463
+ expect(fileAllAfterContentUpdate.lixcol_change_id).toBe(
1464
+ fileAfterContentUpdate.lixcol_change_id
1465
+ );
1466
+ expect(fileAllAfterContentUpdate.lixcol_updated_at).toBe(
1467
+ fileAfterContentUpdate.lixcol_updated_at
1468
+ );
1469
+
1470
+ // Verify that file_all view also exposes lix_file_descriptor as schema key
1471
+ expect(fileAllAfterContentUpdate.lixcol_schema_key).toBe(
1472
+ "lix_file_descriptor"
1473
+ );
1474
+
1475
+ // Additional verification that descriptor changes DO work
1476
+ await lix.db
1477
+ .updateTable("file")
1478
+ .where("id", "=", "aggregate-info-test")
1479
+ .set({
1480
+ path: "/renamed-document.json", // This updates the descriptor
1481
+ })
1482
+ .execute();
1483
+
1484
+ const fileAfterPathUpdate = await lix.db
1485
+ .selectFrom("file")
1486
+ .where("id", "=", "aggregate-info-test")
1487
+ .selectAll()
1488
+ .executeTakeFirstOrThrow();
1489
+
1490
+ // Descriptor changes ARE reflected (this part works correctly)
1491
+ expect(fileAfterPathUpdate.lixcol_change_id).not.toBe(initialChangeId);
1492
+ // For string timestamps, use string comparison
1493
+ expect(fileAfterPathUpdate.lixcol_updated_at > initialUpdatedAt).toBe(true);
1494
+
1495
+ // After path update, file_all should show the descriptor change
1496
+ const fileAllAfterPathUpdate = await lix.db
1497
+ .selectFrom("file_all")
1498
+ .where("id", "=", "aggregate-info-test")
1499
+ .selectAll()
1500
+ .executeTakeFirstOrThrow();
1501
+
1502
+ expect(fileAllAfterPathUpdate.lixcol_change_id).toBe(
1503
+ fileAfterPathUpdate.lixcol_change_id
1504
+ );
1505
+ expect(fileAllAfterPathUpdate.path).toBe("/renamed-document.json");
1506
+
1507
+ // Create a checkpoint to test file_history
1508
+ const checkpoint = await createCheckpoint({ lix });
1509
+
1510
+ // Test file_history view also aggregates changes correctly
1511
+ const fileHistoryAtCheckpoint = await lix.db
1512
+ .selectFrom("file_history")
1513
+ .where("id", "=", "aggregate-info-test")
1514
+ .where("lixcol_root_commit_id", "=", checkpoint.id)
1515
+ .where("lixcol_depth", "=", 0)
1516
+ .selectAll()
1517
+ .executeTakeFirstOrThrow();
1518
+
1519
+ // file_history should show the latest state including the path update
1520
+ expect(fileHistoryAtCheckpoint.path).toBe("/renamed-document.json");
1521
+ expect(fileHistoryAtCheckpoint.lixcol_change_id).toBe(
1522
+ fileAfterPathUpdate.lixcol_change_id
1523
+ );
1524
+
1525
+ // Verify that file_history view also exposes lix_file_descriptor as schema key
1526
+ expect(fileHistoryAtCheckpoint.lixcol_schema_key).toBe("lix_file_descriptor");
1527
+
1528
+ // The materialized data should reflect the content updates
1529
+ const historicalData = JSON.parse(
1530
+ new TextDecoder().decode(fileHistoryAtCheckpoint.data)
1531
+ );
1532
+ expect(historicalData).toEqual({
1533
+ title: "Updated Title",
1534
+ content: "Updated content",
1535
+ });
1536
+ });
1537
+
1538
+ test("files should be identical across versions when versions have the same commit", async () => {
1539
+ const lix = await openLix({
1540
+ providePlugins: [mockJsonPlugin],
1541
+ });
1542
+
1543
+ const initialFile = new TextEncoder().encode(
1544
+ JSON.stringify({
1545
+ items: [{ id: 1, name: "T-Shirt", price: 29.99, stock: 100 }],
1546
+ })
1547
+ );
1548
+
1549
+ // Create a file in the main version
1550
+ await lix.db
1551
+ .insertInto("file")
1552
+ .values({
1553
+ path: "/products.json",
1554
+ data: initialFile,
1555
+ })
1556
+ .execute();
1557
+
1558
+ // Verify the file exists in main version
1559
+ const fileInMain = await lix.db
1560
+ .selectFrom("file")
1561
+ .where("path", "=", "/products.json")
1562
+ .selectAll()
1563
+ .executeTakeFirst();
1564
+
1565
+ expect(fileInMain?.data).toEqual(initialFile);
1566
+
1567
+ // Create a new version (should inherit from active version)
1568
+ const newVersion = await createVersion({
1569
+ lix,
1570
+ name: "price-update",
1571
+ });
1572
+
1573
+ // Switch to the new version
1574
+ await switchVersion({ lix, to: newVersion });
1575
+
1576
+ // Check if the file is inherited in the new version
1577
+ const fileInNewVersion = await lix.db
1578
+ .selectFrom("file")
1579
+ .where("path", "=", "/products.json")
1580
+ .selectAll()
1581
+ .executeTakeFirst();
1582
+
1583
+ expect(fileInNewVersion?.data).toEqual(initialFile);
1584
+
1585
+ // Update the file in the new version
1586
+ await lix.db
1587
+ .updateTable("file")
1588
+ .set({
1589
+ data: new TextEncoder().encode(
1590
+ JSON.stringify({
1591
+ items: [
1592
+ { id: 1, name: "T-Shirt", price: 34.99, stock: 100 }, // Price changed
1593
+ ],
1594
+ })
1595
+ ),
1596
+ })
1597
+ .where("path", "=", "/products.json")
1598
+ .execute();
1599
+
1600
+ // Verify the update worked
1601
+ const updatedFile = await lix.db
1602
+ .selectFrom("file")
1603
+ .where("path", "=", "/products.json")
1604
+ .selectAll()
1605
+ .executeTakeFirstOrThrow();
1606
+
1607
+ const updatedData = JSON.parse(new TextDecoder().decode(updatedFile.data));
1608
+ expect(updatedData.items[0].price).toBe(34.99);
1609
+
1610
+ // Query file_all to see both versions
1611
+ const filesAcrossVersions = await lix.db
1612
+ .selectFrom("file_all")
1613
+ .where("path", "=", "/products.json")
1614
+ .select(["lixcol_version_id", "data"])
1615
+ .execute();
1616
+
1617
+ expect(filesAcrossVersions).toHaveLength(2);
1618
+
1619
+ // Get version info for verification
1620
+ const versions = await lix.db
1621
+ .selectFrom("version")
1622
+ .select(["id", "name"])
1623
+ .execute();
1624
+
1625
+ const mainVersionData = filesAcrossVersions.find((f) => {
1626
+ const version = versions.find((v) => v.id === f.lixcol_version_id);
1627
+ return version?.name === "main";
1628
+ });
1629
+
1630
+ const newVersionData = filesAcrossVersions.find((f) => {
1631
+ const version = versions.find((v) => v.id === f.lixcol_version_id);
1632
+ return version?.name === "price-update";
1633
+ });
1634
+
1635
+ expect(mainVersionData).toBeDefined();
1636
+ expect(newVersionData).toBeDefined();
1637
+
1638
+ // Verify the prices are different
1639
+ const mainData = JSON.parse(new TextDecoder().decode(mainVersionData!.data));
1640
+ const updatedVersionData = JSON.parse(
1641
+ new TextDecoder().decode(newVersionData!.data)
1642
+ );
1643
+
1644
+ expect(mainData.items[0].price).toBe(29.99); // Original price
1645
+ expect(updatedVersionData.items[0].price).toBe(34.99); // Updated price
1646
+ });