@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,1313 @@
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
+ test("insert, update, delete on the file view", async () => {
8
+ const lix = await openLix({
9
+ providePlugins: [mockJsonPlugin],
10
+ });
11
+ await lix.db
12
+ .insertInto("file")
13
+ .values([
14
+ {
15
+ id: "file0",
16
+ path: "/path/to/file.json",
17
+ data: new TextEncoder().encode(JSON.stringify({
18
+ prop0: "file0-value0",
19
+ })),
20
+ },
21
+ ])
22
+ .execute();
23
+ let viewAfterInsert = await lix.db.selectFrom("file").selectAll().execute();
24
+ viewAfterInsert = viewAfterInsert.map((row) => ({
25
+ ...row,
26
+ data: JSON.parse(new TextDecoder().decode(row.data)),
27
+ }));
28
+ expect(viewAfterInsert).toMatchObject([
29
+ {
30
+ id: "file0",
31
+ path: "/path/to/file.json",
32
+ lixcol_inherited_from_version_id: null,
33
+ lixcol_created_at: expect.any(String),
34
+ lixcol_updated_at: expect.any(String),
35
+ lixcol_change_id: expect.any(String),
36
+ lixcol_untracked: 0,
37
+ data: { prop0: "file0-value0" },
38
+ metadata: null,
39
+ },
40
+ ]);
41
+ await lix.db
42
+ .updateTable("file")
43
+ .where("id", "=", "file0")
44
+ .set({
45
+ path: "/path/to/renamed_file.json",
46
+ data: new TextEncoder().encode(JSON.stringify({ prop0: "file0-value1" })),
47
+ })
48
+ .execute();
49
+ let viewAfterUpdate = await lix.db
50
+ .selectFrom("file")
51
+ .orderBy("id")
52
+ .selectAll()
53
+ .execute();
54
+ viewAfterUpdate = viewAfterUpdate.map((row) => ({
55
+ ...row,
56
+ data: JSON.parse(new TextDecoder().decode(row.data)),
57
+ }));
58
+ expect(viewAfterUpdate).toMatchObject([
59
+ {
60
+ id: "file0",
61
+ path: "/path/to/renamed_file.json",
62
+ lixcol_inherited_from_version_id: null,
63
+ lixcol_created_at: expect.any(String),
64
+ lixcol_updated_at: expect.any(String),
65
+ lixcol_change_id: expect.any(String),
66
+ lixcol_untracked: 0,
67
+ data: { prop0: "file0-value1" },
68
+ metadata: null,
69
+ },
70
+ ]);
71
+ await lix.db.deleteFrom("file").where("id", "=", "file0").execute();
72
+ const viewAfterDelete = await lix.db
73
+ .selectFrom("file")
74
+ .orderBy("id")
75
+ .select(["id", "path"])
76
+ .execute();
77
+ expect(viewAfterDelete).toEqual([]);
78
+ const changes = await lix.db
79
+ .selectFrom("change")
80
+ .where("file_id", "in", ["file0", "file1"])
81
+ .select(["entity_id", "snapshot_content", "schema_key"])
82
+ .execute();
83
+ expect(changes).toEqual(expect.arrayContaining([
84
+ // insert
85
+ expect.objectContaining({
86
+ schema_key: "lix_file_descriptor",
87
+ entity_id: "file0",
88
+ snapshot_content: expect.any(Object),
89
+ }),
90
+ expect.objectContaining({
91
+ schema_key: "mock_json_property",
92
+ entity_id: "prop0",
93
+ snapshot_content: {
94
+ value: "file0-value0",
95
+ },
96
+ }),
97
+ // update
98
+ expect.objectContaining({
99
+ schema_key: "lix_file_descriptor",
100
+ entity_id: "file0",
101
+ snapshot_content: expect.any(Object),
102
+ }),
103
+ expect.objectContaining({
104
+ schema_key: "mock_json_property",
105
+ entity_id: "prop0",
106
+ snapshot_content: {
107
+ value: "file0-value1",
108
+ },
109
+ }),
110
+ // delete (file‑level)
111
+ expect.objectContaining({
112
+ schema_key: "lix_file_descriptor",
113
+ entity_id: "file0",
114
+ snapshot_content: null,
115
+ }),
116
+ // delete (all plugin entities that existed in the file)
117
+ expect.objectContaining({
118
+ schema_key: "mock_json_property",
119
+ entity_id: "prop0",
120
+ snapshot_content: null,
121
+ }),
122
+ ]));
123
+ expect(changes).toHaveLength(6);
124
+ });
125
+ test("file insert data materialization", async () => {
126
+ const lix = await openLix({
127
+ providePlugins: [mockJsonPlugin],
128
+ });
129
+ await lix.db
130
+ .insertInto("file")
131
+ .values({
132
+ id: "file0",
133
+ path: "/path/to/file.json",
134
+ data: new TextEncoder().encode(JSON.stringify({
135
+ prop0: "file0-value0",
136
+ })),
137
+ })
138
+ .execute();
139
+ let viewAfterInsert = await lix.db.selectFrom("file").selectAll().execute();
140
+ viewAfterInsert = viewAfterInsert.map((row) => ({
141
+ ...row,
142
+ data: JSON.parse(new TextDecoder().decode(row.data)),
143
+ }));
144
+ expect(viewAfterInsert).toMatchObject([
145
+ {
146
+ id: "file0",
147
+ path: "/path/to/file.json",
148
+ lixcol_inherited_from_version_id: null,
149
+ lixcol_created_at: expect.any(String),
150
+ lixcol_updated_at: expect.any(String),
151
+ lixcol_change_id: expect.any(String),
152
+ lixcol_untracked: 0,
153
+ data: { prop0: "file0-value0" },
154
+ metadata: null,
155
+ },
156
+ ]);
157
+ });
158
+ test("file ids should have a default", async () => {
159
+ const lix = await openLix({
160
+ providePlugins: [mockJsonPlugin],
161
+ });
162
+ await lix.db
163
+ .insertInto("file")
164
+ .values({
165
+ path: "/mock.json",
166
+ data: new Uint8Array(),
167
+ })
168
+ .execute();
169
+ const file = await lix.db
170
+ .selectFrom("file")
171
+ .where("path", "=", "/mock.json")
172
+ .selectAll()
173
+ .executeTakeFirstOrThrow();
174
+ expect(file.id).toBeDefined();
175
+ });
176
+ test("files should be able to have metadata", async () => {
177
+ const lix = await openLix({
178
+ providePlugins: [mockJsonPlugin],
179
+ });
180
+ await lix.db
181
+ .insertInto("file")
182
+ .values({
183
+ path: "/mock.json",
184
+ data: new Uint8Array(),
185
+ metadata: {
186
+ primary_key: "email",
187
+ },
188
+ })
189
+ .execute();
190
+ const file = await lix.db
191
+ .selectFrom("file")
192
+ .where("path", "=", "/mock.json")
193
+ .selectAll()
194
+ .executeTakeFirstOrThrow();
195
+ expect(file.metadata?.primary_key).toBe("email");
196
+ const updatedFile = await lix.db
197
+ .updateTable("file")
198
+ .where("path", "=", "/mock.json")
199
+ .set({
200
+ metadata: {
201
+ primary_key: "something-else",
202
+ },
203
+ })
204
+ .returningAll()
205
+ .executeTakeFirstOrThrow();
206
+ expect(updatedFile.metadata?.primary_key).toBe("something-else");
207
+ });
208
+ test("invalid file paths should be rejected", async () => {
209
+ const lix = await openLix({
210
+ providePlugins: [mockJsonPlugin],
211
+ });
212
+ await expect(lix.db
213
+ .insertInto("file")
214
+ .values({
215
+ path: "invalid-path",
216
+ data: new Uint8Array(),
217
+ })
218
+ .execute()).rejects.toThrowError("path must match pattern");
219
+ });
220
+ test("files should have hidden property defaulting to false", async () => {
221
+ const lix = await openLix({
222
+ providePlugins: [mockJsonPlugin],
223
+ });
224
+ await lix.db
225
+ .insertInto("file")
226
+ .values({
227
+ path: "/hidden-default.json",
228
+ data: new Uint8Array(),
229
+ })
230
+ .execute();
231
+ const file = await lix.db
232
+ .selectFrom("file")
233
+ .where("path", "=", "/hidden-default.json")
234
+ .selectAll()
235
+ .executeTakeFirstOrThrow();
236
+ expect(file.hidden).toBe(0);
237
+ });
238
+ test("can explicitly set hidden to true", async () => {
239
+ const lix = await openLix({
240
+ providePlugins: [mockJsonPlugin],
241
+ });
242
+ await lix.db
243
+ .insertInto("file")
244
+ .values({
245
+ path: "/hidden.json",
246
+ data: new Uint8Array(),
247
+ hidden: true,
248
+ })
249
+ .execute();
250
+ const file = await lix.db
251
+ .selectFrom("file")
252
+ .where("path", "=", "/hidden.json")
253
+ .selectAll()
254
+ .executeTakeFirstOrThrow();
255
+ expect(file.hidden).toBe(1);
256
+ });
257
+ test("file_all operations are version specific and isolated", async () => {
258
+ const lix = await openLix({
259
+ providePlugins: [mockJsonPlugin],
260
+ });
261
+ const versionA = await createVersion({
262
+ lix,
263
+ id: "versionA",
264
+ });
265
+ const versionB = await createVersion({
266
+ lix,
267
+ id: "versionB",
268
+ });
269
+ // Insert file in version A
270
+ await lix.db
271
+ .insertInto("file_all")
272
+ .values({
273
+ id: "fileA",
274
+ path: "/shared/file.json",
275
+ data: new TextEncoder().encode(JSON.stringify({ content: "versionA" })),
276
+ lixcol_version_id: versionA.id,
277
+ })
278
+ .execute();
279
+ // Insert file in version B with same path but different content
280
+ await lix.db
281
+ .insertInto("file_all")
282
+ .values({
283
+ id: "fileB",
284
+ path: "/shared/file.json",
285
+ data: new TextEncoder().encode(JSON.stringify({ content: "versionB" })),
286
+ lixcol_version_id: versionB.id,
287
+ })
288
+ .execute();
289
+ // Verify both versions have their own files
290
+ const filesInVersionA = await lix.db
291
+ .selectFrom("file_all")
292
+ .where("lixcol_version_id", "=", versionA.id)
293
+ .selectAll()
294
+ .execute();
295
+ const filesInVersionB = await lix.db
296
+ .selectFrom("file_all")
297
+ .where("lixcol_version_id", "=", versionB.id)
298
+ .selectAll()
299
+ .execute();
300
+ expect(filesInVersionA).toHaveLength(1);
301
+ expect(filesInVersionB).toHaveLength(1);
302
+ expect(JSON.parse(new TextDecoder().decode(filesInVersionA[0]?.data))).toEqual({ content: "versionA" });
303
+ expect(JSON.parse(new TextDecoder().decode(filesInVersionB[0]?.data))).toEqual({ content: "versionB" });
304
+ // Update file in version A
305
+ await lix.db
306
+ .updateTable("file_all")
307
+ .where("id", "=", "fileA")
308
+ .where("lixcol_version_id", "=", versionA.id)
309
+ .set({
310
+ data: new TextEncoder().encode(JSON.stringify({ content: "versionA-updated" })),
311
+ })
312
+ .execute();
313
+ // Verify update only affected version A
314
+ const updatedFilesA = await lix.db
315
+ .selectFrom("file_all")
316
+ .where("lixcol_version_id", "=", versionA.id)
317
+ .selectAll()
318
+ .execute();
319
+ const unchangedFilesB = await lix.db
320
+ .selectFrom("file_all")
321
+ .where("lixcol_version_id", "=", versionB.id)
322
+ .selectAll()
323
+ .execute();
324
+ expect(JSON.parse(new TextDecoder().decode(updatedFilesA[0]?.data))).toEqual({
325
+ content: "versionA-updated",
326
+ });
327
+ expect(JSON.parse(new TextDecoder().decode(unchangedFilesB[0]?.data))).toEqual({ content: "versionB" });
328
+ // Delete file from version A
329
+ await lix.db
330
+ .deleteFrom("file_all")
331
+ .where("id", "=", "fileA")
332
+ .where("lixcol_version_id", "=", versionA.id)
333
+ .execute();
334
+ // Verify deletion only affected version A
335
+ const remainingFilesA = await lix.db
336
+ .selectFrom("file_all")
337
+ .where("lixcol_version_id", "=", versionA.id)
338
+ .selectAll()
339
+ .execute();
340
+ const remainingFilesB = await lix.db
341
+ .selectFrom("file_all")
342
+ .where("lixcol_version_id", "=", versionB.id)
343
+ .selectAll()
344
+ .execute();
345
+ expect(remainingFilesA).toHaveLength(0);
346
+ expect(remainingFilesB).toHaveLength(1);
347
+ expect(JSON.parse(new TextDecoder().decode(remainingFilesB[0]?.data))).toEqual({ content: "versionB" });
348
+ });
349
+ test("the plugin is the source of truth. the fallback plugin is not invoked if a plugin is configured for the file type", async () => {
350
+ const mockTxtPlugin = {
351
+ key: "mock-txt",
352
+ detectChanges: () => {
353
+ return [];
354
+ },
355
+ applyChanges: () => ({ fileData: new Uint8Array() }),
356
+ detectChangesGlob: "*.txt",
357
+ };
358
+ const lix = await openLix({
359
+ providePlugins: [mockTxtPlugin],
360
+ });
361
+ await lix.db
362
+ .insertInto("file")
363
+ .values({
364
+ id: "mock-file",
365
+ path: "/mock.txt",
366
+ data: new TextEncoder().encode("some content"),
367
+ })
368
+ .execute();
369
+ const fileAfterInsert = await lix.db
370
+ .selectFrom("file")
371
+ .where("id", "=", "mock-file")
372
+ .select("data")
373
+ .executeTakeFirstOrThrow();
374
+ expect(fileAfterInsert.data).toEqual(new Uint8Array());
375
+ await lix.db
376
+ .updateTable("file")
377
+ .set({ data: new TextEncoder().encode("some other content") })
378
+ .where("id", "=", "mock-file")
379
+ .execute();
380
+ const fileAfterUpdate = await lix.db
381
+ .selectFrom("file")
382
+ .where("id", "=", "mock-file")
383
+ .select("data")
384
+ .executeTakeFirstOrThrow();
385
+ expect(fileAfterUpdate.data).toEqual(new Uint8Array());
386
+ await lix.db.deleteFrom("file").where("id", "=", "mock-file").execute();
387
+ const fileAfterDelete = await lix.db
388
+ .selectFrom("file")
389
+ .where("id", "=", "mock-file")
390
+ .select("data")
391
+ .executeTakeFirst();
392
+ expect(fileAfterDelete).toBeUndefined();
393
+ });
394
+ test("file_history provides access to historical file data", async () => {
395
+ const lix = await openLix({
396
+ providePlugins: [mockJsonPlugin],
397
+ });
398
+ // 1. Insert file
399
+ const initialData = { prop0: "initial-value" };
400
+ await lix.db
401
+ .insertInto("file")
402
+ .values({
403
+ id: "test-file",
404
+ path: "/test.json",
405
+ data: new TextEncoder().encode(JSON.stringify(initialData)),
406
+ })
407
+ .execute();
408
+ // 2. Create checkpoint
409
+ const insertCheckpoint = await createCheckpoint({
410
+ lix,
411
+ });
412
+ // 3. Update file
413
+ const updatedData = { prop0: "updated-value" };
414
+ await lix.db
415
+ .updateTable("file")
416
+ .where("id", "=", "test-file")
417
+ .set({
418
+ data: new TextEncoder().encode(JSON.stringify(updatedData)),
419
+ })
420
+ .execute();
421
+ const updateCheckpoint = await createCheckpoint({
422
+ lix,
423
+ });
424
+ // 4. Query file, assert that file equals update
425
+ const currentFile = await lix.db
426
+ .selectFrom("file")
427
+ .where("id", "=", "test-file")
428
+ .selectAll()
429
+ .executeTakeFirstOrThrow();
430
+ const currentFileData = JSON.parse(new TextDecoder().decode(currentFile.data));
431
+ expect(currentFileData).toEqual(updatedData);
432
+ // 5. Query history at checkpoint and assert is initial
433
+ const fileHistoryAtInsert = await lix.db
434
+ .selectFrom("file_history")
435
+ .where("id", "=", "test-file")
436
+ .where("lixcol_root_commit_id", "=", insertCheckpoint.id)
437
+ .where("lixcol_depth", "=", 0)
438
+ .selectAll()
439
+ .execute();
440
+ expect(fileHistoryAtInsert).toHaveLength(1);
441
+ const historicalFileAtInsert = fileHistoryAtInsert[0];
442
+ const historicalFileAtInsertData = JSON.parse(new TextDecoder().decode(historicalFileAtInsert.data));
443
+ expect(historicalFileAtInsertData).toEqual(initialData);
444
+ expect(historicalFileAtInsert.id).toBe("test-file");
445
+ expect(historicalFileAtInsert.path).toBe("/test.json");
446
+ expect(historicalFileAtInsert.lixcol_commit_id).toBe(insertCheckpoint.id);
447
+ // 6. Query history at update checkpoint and assert is updated
448
+ const fileHistoryAtUpdate = await lix.db
449
+ .selectFrom("file_history")
450
+ .where("id", "=", "test-file")
451
+ .where("lixcol_root_commit_id", "=", updateCheckpoint.id)
452
+ .where("lixcol_depth", "=", 0)
453
+ .selectAll()
454
+ .execute();
455
+ expect(fileHistoryAtUpdate).toHaveLength(1);
456
+ const historicalFileAtUpdate = fileHistoryAtUpdate[0];
457
+ const historicalFileAtUpdateData = JSON.parse(new TextDecoder().decode(historicalFileAtUpdate.data));
458
+ expect(historicalFileAtUpdateData).toEqual(updatedData);
459
+ expect(historicalFileAtUpdate.id).toBe("test-file");
460
+ expect(historicalFileAtUpdate.path).toBe("/test.json");
461
+ expect(historicalFileAtUpdate.lixcol_commit_id).toBe(updateCheckpoint.id);
462
+ });
463
+ // its super annoying to work with metadata otherwise
464
+ test("file metadata is Record<string, any>", async () => {
465
+ const mockFile = {
466
+ id: "test-file",
467
+ path: "/test.json",
468
+ data: new TextEncoder().encode(JSON.stringify({ prop0: "value0" })),
469
+ metadata: {
470
+ author: "test-user",
471
+ created_at: new Date().toISOString(),
472
+ },
473
+ };
474
+ expectTypeOf(mockFile.metadata).toEqualTypeOf();
475
+ });
476
+ test("file and file_all views expose change_id for blame and diff functionality", async () => {
477
+ const lix = await openLix({
478
+ providePlugins: [mockJsonPlugin],
479
+ keyValues: [
480
+ {
481
+ key: "lix_deterministic_mode",
482
+ value: {
483
+ enabled: true,
484
+ bootstrap: true,
485
+ },
486
+ lixcol_version_id: "global",
487
+ },
488
+ ],
489
+ });
490
+ // Insert initial file using file view to ensure triggers are executed
491
+ await lix.db
492
+ .insertInto("file")
493
+ .values({
494
+ id: "change-id-test-file",
495
+ path: "/test-change-id.json",
496
+ data: new TextEncoder().encode(JSON.stringify({ prop: "initial value" })),
497
+ })
498
+ .execute();
499
+ // Query file_all view to verify change_id is exposed
500
+ const fileAllResult = await lix.db
501
+ .selectFrom("file_all")
502
+ .where("id", "=", "change-id-test-file")
503
+ .selectAll()
504
+ .execute();
505
+ expect(fileAllResult).toHaveLength(1);
506
+ expect(fileAllResult[0]?.lixcol_change_id).toBeDefined();
507
+ expect(typeof fileAllResult[0]?.lixcol_change_id).toBe("string");
508
+ // Query file view (filtered by active version) to verify change_id is exposed
509
+ const fileResult = await lix.db
510
+ .selectFrom("file")
511
+ .where("id", "=", "change-id-test-file")
512
+ .selectAll()
513
+ .execute();
514
+ expect(fileResult).toHaveLength(1);
515
+ expect(fileResult[0]?.lixcol_change_id).toBeDefined();
516
+ expect(typeof fileResult[0]?.lixcol_change_id).toBe("string");
517
+ // Verify that change_id matches between file and file_all views
518
+ expect(fileResult[0]?.lixcol_change_id).toBe(fileAllResult[0]?.lixcol_change_id);
519
+ // Get the latest change for this file (could be descriptor or content)
520
+ const latestChange = await lix.db
521
+ .selectFrom("change")
522
+ .where("file_id", "=", "change-id-test-file")
523
+ .orderBy("created_at", "desc")
524
+ .select(["id", "schema_key", "snapshot_content"])
525
+ .executeTakeFirstOrThrow();
526
+ // Verify that the change_id in the views matches the latest change
527
+ expect(fileResult[0]?.lixcol_change_id).toBe(latestChange.id);
528
+ expect(fileAllResult[0]?.lixcol_change_id).toBe(latestChange.id);
529
+ // Verify that the file view shows correct file info
530
+ expect(fileResult[0]?.id).toBe("change-id-test-file");
531
+ expect(fileResult[0]?.path).toBe("/test-change-id.json");
532
+ // Update the file to create a new change
533
+ await lix.db
534
+ .updateTable("file")
535
+ .set({
536
+ path: "/test-change-id-updated.json",
537
+ })
538
+ .where("id", "=", "change-id-test-file")
539
+ .execute();
540
+ // Query again to verify change_id updated after modification
541
+ const updatedFileResult = await lix.db
542
+ .selectFrom("file_all")
543
+ .where("id", "=", "change-id-test-file")
544
+ .selectAll()
545
+ .execute();
546
+ expect(updatedFileResult).toHaveLength(1);
547
+ expect(updatedFileResult[0]?.lixcol_change_id).toBeDefined();
548
+ // The change_id should be different after the update (new change created)
549
+ expect(updatedFileResult[0]?.lixcol_change_id).not.toBe(fileResult[0]?.lixcol_change_id);
550
+ // Get the new file entity change record
551
+ const newFileChangeRecord = await lix.db
552
+ .selectFrom("change")
553
+ .where("file_id", "=", "change-id-test-file")
554
+ .where("schema_key", "=", "lix_file_descriptor")
555
+ .orderBy("created_at", "desc")
556
+ .select(["id", "snapshot_content"])
557
+ .executeTakeFirstOrThrow();
558
+ // Verify the new change_id matches the latest file change
559
+ expect(updatedFileResult[0]?.lixcol_change_id).toBe(newFileChangeRecord.id);
560
+ // Verify that the updated snapshot content in the change matches the file view
561
+ expect(newFileChangeRecord.snapshot_content).toMatchObject({
562
+ id: "change-id-test-file",
563
+ path: "/test-change-id-updated.json",
564
+ });
565
+ expect(updatedFileResult[0]?.path).toBe("/test-change-id-updated.json");
566
+ });
567
+ test("file data updates create new change_id", async () => {
568
+ const lix = await openLix({
569
+ providePlugins: [mockJsonPlugin],
570
+ });
571
+ // Insert initial file
572
+ await lix.db
573
+ .insertInto("file")
574
+ .values({
575
+ id: "data-change-test",
576
+ path: "/data-test.json",
577
+ data: new TextEncoder().encode(JSON.stringify({ content: "initial" })),
578
+ })
579
+ .execute();
580
+ // Get initial change_id
581
+ const initialFile = await lix.db
582
+ .selectFrom("file")
583
+ .where("id", "=", "data-change-test")
584
+ .select(["lixcol_change_id"])
585
+ .executeTakeFirstOrThrow();
586
+ expect(initialFile.lixcol_change_id).toBeDefined();
587
+ // Update only the file data
588
+ await lix.db
589
+ .updateTable("file")
590
+ .set({
591
+ data: new TextEncoder().encode(JSON.stringify({ content: "updated data" })),
592
+ })
593
+ .where("id", "=", "data-change-test")
594
+ .execute();
595
+ // Get updated change_id
596
+ const updatedFile = await lix.db
597
+ .selectFrom("file")
598
+ .where("id", "=", "data-change-test")
599
+ .select(["lixcol_change_id"])
600
+ .executeTakeFirstOrThrow();
601
+ // Verify that updating file data created a new change_id
602
+ expect(updatedFile.lixcol_change_id).toBeDefined();
603
+ expect(updatedFile.lixcol_change_id).not.toBe(initialFile.lixcol_change_id);
604
+ // Verify the change record exists - this should be for the content entity, not the file entity
605
+ // When file data changes, it creates changes for the plugin-managed entities within the file
606
+ const contentChangeRecord = await lix.db
607
+ .selectFrom("change")
608
+ .where("file_id", "=", "data-change-test")
609
+ .where("schema_key", "=", "mock_json_property")
610
+ .where("entity_id", "=", "content")
611
+ .orderBy("created_at", "desc")
612
+ .select(["id", "entity_id", "schema_key", "snapshot_content"])
613
+ .executeTakeFirst();
614
+ expect(contentChangeRecord).toBeDefined();
615
+ expect(contentChangeRecord?.entity_id).toBe("content");
616
+ expect(contentChangeRecord?.schema_key).toBe("mock_json_property");
617
+ expect(contentChangeRecord?.snapshot_content).toEqual({
618
+ value: "updated data",
619
+ });
620
+ });
621
+ test("file metadata updates create new change_id", async () => {
622
+ const lix = await openLix({
623
+ providePlugins: [mockJsonPlugin],
624
+ });
625
+ // Insert initial file with metadata
626
+ await lix.db
627
+ .insertInto("file")
628
+ .values({
629
+ id: "metadata-change-test",
630
+ path: "/metadata-test.json",
631
+ data: new TextEncoder().encode(JSON.stringify({ content: "test" })),
632
+ metadata: { author: "initial author" },
633
+ })
634
+ .execute();
635
+ // Get initial change_id
636
+ const initialFile = await lix.db
637
+ .selectFrom("file")
638
+ .where("id", "=", "metadata-change-test")
639
+ .select(["lixcol_change_id", "path", "metadata"])
640
+ .executeTakeFirstOrThrow();
641
+ expect(initialFile.lixcol_change_id).toBeDefined();
642
+ expect(initialFile.path).toBe("/metadata-test.json");
643
+ expect(initialFile.metadata).toEqual({ author: "initial author" });
644
+ // Update the file path (which is part of the file entity metadata)
645
+ await lix.db
646
+ .updateTable("file")
647
+ .set({
648
+ path: "/updated-metadata-test.json",
649
+ })
650
+ .where("id", "=", "metadata-change-test")
651
+ .execute();
652
+ // Get updated change_id after path change
653
+ const updatedPathFile = await lix.db
654
+ .selectFrom("file")
655
+ .where("id", "=", "metadata-change-test")
656
+ .select(["lixcol_change_id", "path"])
657
+ .executeTakeFirstOrThrow();
658
+ // Verify that updating file path created a new change_id
659
+ expect(updatedPathFile.lixcol_change_id).toBeDefined();
660
+ expect(updatedPathFile.lixcol_change_id).not.toBe(initialFile.lixcol_change_id);
661
+ expect(updatedPathFile.path).toBe("/updated-metadata-test.json");
662
+ // Update the file metadata
663
+ await lix.db
664
+ .updateTable("file")
665
+ .set({
666
+ metadata: { author: "updated author", version: "2.0" },
667
+ })
668
+ .where("id", "=", "metadata-change-test")
669
+ .execute();
670
+ // Get updated change_id after metadata change
671
+ const updatedMetadataFile = await lix.db
672
+ .selectFrom("file")
673
+ .where("id", "=", "metadata-change-test")
674
+ .select(["lixcol_change_id", "metadata"])
675
+ .executeTakeFirstOrThrow();
676
+ // Verify that updating file metadata created another new change_id
677
+ expect(updatedMetadataFile.lixcol_change_id).toBeDefined();
678
+ expect(updatedMetadataFile.lixcol_change_id).not.toBe(updatedPathFile.lixcol_change_id);
679
+ expect(updatedMetadataFile.metadata).toEqual({
680
+ author: "updated author",
681
+ version: "2.0",
682
+ });
683
+ // Verify the final file entity change record exists and is correct
684
+ const finalFileChangeRecord = await lix.db
685
+ .selectFrom("change")
686
+ .where("id", "=", updatedMetadataFile.lixcol_change_id)
687
+ .where("entity_id", "=", "metadata-change-test")
688
+ .where("schema_key", "=", "lix_file_descriptor")
689
+ .selectAll()
690
+ .executeTakeFirst();
691
+ expect(finalFileChangeRecord).toBeDefined();
692
+ expect(finalFileChangeRecord?.entity_id).toBe("metadata-change-test");
693
+ expect(finalFileChangeRecord?.schema_key).toBe("lix_file_descriptor");
694
+ });
695
+ test("file descriptor updates with untracked state", async () => {
696
+ const lix = await openLix({
697
+ providePlugins: [mockJsonPlugin],
698
+ });
699
+ // Count changes before untracked insert
700
+ const changesBefore = await lix.db.selectFrom("change").selectAll().execute();
701
+ // Insert file with untracked=true
702
+ await lix.db
703
+ .insertInto("file")
704
+ .values({
705
+ id: "untracked-file",
706
+ path: "/untracked-test.json",
707
+ data: new TextEncoder().encode(JSON.stringify({ prop: "value" })),
708
+ lixcol_untracked: true,
709
+ })
710
+ .execute();
711
+ // Count changes after untracked insert
712
+ const changesAfterInsert = await lix.db
713
+ .selectFrom("change")
714
+ .selectAll()
715
+ .execute();
716
+ // Verify no changes were created (untracked bypasses change control)
717
+ expect(changesAfterInsert.length).toBe(changesBefore.length);
718
+ // Verify file exists in view
719
+ const fileResult = await lix.db
720
+ .selectFrom("file")
721
+ .where("id", "=", "untracked-file")
722
+ .selectAll()
723
+ .execute();
724
+ expect(fileResult).toHaveLength(1);
725
+ expect(fileResult[0]?.lixcol_untracked).toBe(1);
726
+ expect(fileResult[0]?.path).toBe("/untracked-test.json");
727
+ // Verify file data was processed by plugin
728
+ const decodedData = JSON.parse(new TextDecoder().decode(fileResult[0]?.data));
729
+ expect(decodedData).toEqual({ prop: "value" });
730
+ // Update file with untracked=true
731
+ await lix.db
732
+ .updateTable("file")
733
+ .where("id", "=", "untracked-file")
734
+ .set({
735
+ path: "/updated-untracked-test.json",
736
+ data: new TextEncoder().encode(JSON.stringify({ prop: "updated" })),
737
+ lixcol_untracked: true,
738
+ })
739
+ .execute();
740
+ // Count changes after untracked update
741
+ const changesAfterUpdate = await lix.db
742
+ .selectFrom("change")
743
+ .selectAll()
744
+ .execute();
745
+ // Verify no new changes were created (untracked bypasses change control)
746
+ expect(changesAfterUpdate.length).toBe(changesBefore.length);
747
+ // Verify file was updated
748
+ const updatedFile = await lix.db
749
+ .selectFrom("file")
750
+ .where("id", "=", "untracked-file")
751
+ .selectAll()
752
+ .execute();
753
+ expect(updatedFile).toHaveLength(1);
754
+ expect(updatedFile[0]?.lixcol_untracked).toBe(1);
755
+ expect(updatedFile[0]?.path).toBe("/updated-untracked-test.json");
756
+ // Verify updated file data was processed by plugin
757
+ const updatedData = JSON.parse(new TextDecoder().decode(updatedFile[0]?.data));
758
+ expect(updatedData).toEqual({ prop: "updated" });
759
+ // Delete the untracked file
760
+ await lix.db.deleteFrom("file").where("id", "=", "untracked-file").execute();
761
+ // Count changes after untracked delete
762
+ const changesAfterDelete = await lix.db
763
+ .selectFrom("change")
764
+ .selectAll()
765
+ .execute();
766
+ // Verify no new changes were created (untracked bypasses change control)
767
+ expect(changesAfterDelete.length).toBe(changesBefore.length);
768
+ // Verify file was deleted
769
+ const deletedFile = await lix.db
770
+ .selectFrom("file")
771
+ .where("id", "=", "untracked-file")
772
+ .selectAll()
773
+ .execute();
774
+ expect(deletedFile).toHaveLength(0);
775
+ });
776
+ test("file data updates with untracked state", async () => {
777
+ const lix = await openLix({
778
+ providePlugins: [mockJsonPlugin],
779
+ });
780
+ // Count changes before any operations
781
+ const changesInitial = await lix.db
782
+ .selectFrom("change")
783
+ .selectAll()
784
+ .execute();
785
+ // Insert file with untracked=true from the start
786
+ await lix.db
787
+ .insertInto("file")
788
+ .values({
789
+ id: "untracked-data-file",
790
+ path: "/untracked-data.json",
791
+ data: new TextEncoder().encode(JSON.stringify({ content: "initial" })),
792
+ lixcol_untracked: true,
793
+ })
794
+ .execute();
795
+ // Count changes after untracked insert
796
+ const changesAfterInsert = await lix.db
797
+ .selectFrom("change")
798
+ .selectAll()
799
+ .execute();
800
+ // Verify no changes were created (untracked bypasses change control)
801
+ expect(changesAfterInsert.length).toBe(changesInitial.length);
802
+ // Verify file was inserted and is untracked
803
+ const insertedFile = await lix.db
804
+ .selectFrom("file")
805
+ .where("id", "=", "untracked-data-file")
806
+ .selectAll()
807
+ .execute();
808
+ expect(insertedFile).toHaveLength(1);
809
+ expect(insertedFile[0]?.lixcol_untracked).toBe(1);
810
+ // Verify file data was processed by plugin
811
+ const initialData = JSON.parse(new TextDecoder().decode(insertedFile[0]?.data));
812
+ expect(initialData).toEqual({ content: "initial" });
813
+ // Update file data with untracked=true
814
+ await lix.db
815
+ .updateTable("file")
816
+ .where("id", "=", "untracked-data-file")
817
+ .set({
818
+ data: new TextEncoder().encode(JSON.stringify({ content: "updated" })),
819
+ lixcol_untracked: true,
820
+ })
821
+ .execute();
822
+ // Count changes after untracked update
823
+ const changesAfterUpdate = await lix.db
824
+ .selectFrom("change")
825
+ .selectAll()
826
+ .execute();
827
+ // Verify no new changes were created (untracked bypasses change control)
828
+ expect(changesAfterUpdate.length).toBe(changesInitial.length);
829
+ // Verify file data was updated and is still untracked
830
+ const updatedFile = await lix.db
831
+ .selectFrom("file")
832
+ .where("id", "=", "untracked-data-file")
833
+ .selectAll()
834
+ .execute();
835
+ expect(updatedFile).toHaveLength(1);
836
+ expect(updatedFile[0]?.lixcol_untracked).toBe(1);
837
+ // Verify file data was updated and processed by plugin
838
+ const updatedData = JSON.parse(new TextDecoder().decode(updatedFile[0]?.data));
839
+ expect(updatedData).toEqual({ content: "updated" });
840
+ // Delete the untracked file
841
+ await lix.db
842
+ .deleteFrom("file")
843
+ .where("id", "=", "untracked-data-file")
844
+ .execute();
845
+ // Count changes after untracked delete
846
+ const changesAfterDelete = await lix.db
847
+ .selectFrom("change")
848
+ .selectAll()
849
+ .execute();
850
+ // Verify no new changes were created (untracked bypasses change control)
851
+ expect(changesAfterDelete.length).toBe(changesInitial.length);
852
+ // Verify file was deleted
853
+ const deletedFile = await lix.db
854
+ .selectFrom("file")
855
+ .where("id", "=", "untracked-data-file")
856
+ .selectAll()
857
+ .execute();
858
+ expect(deletedFile).toHaveLength(0);
859
+ });
860
+ test("file history", async () => {
861
+ const lix = await openLix({
862
+ providePlugins: [mockJsonPlugin],
863
+ });
864
+ // Insert a JSON file
865
+ const data = {
866
+ name: "My Project",
867
+ version: "1.0.0",
868
+ };
869
+ await lix.db
870
+ .insertInto("file")
871
+ .values({
872
+ path: "/config.json",
873
+ data: new TextEncoder().encode(JSON.stringify(data)),
874
+ })
875
+ .execute();
876
+ // Make a change
877
+ data.name = "My Cool Project";
878
+ data.version = "1.1.0";
879
+ await lix.db
880
+ .updateTable("file")
881
+ .where("path", "=", "/config.json")
882
+ .set({
883
+ data: new TextEncoder().encode(JSON.stringify(data)),
884
+ })
885
+ .execute();
886
+ // 1. Get the last two versions of the JSON file from history
887
+ const fileHistory = await lix.db
888
+ .selectFrom("file_history")
889
+ .where("file_history.path", "=", "/config.json")
890
+ .where("lixcol_root_commit_id", "=", lix.db
891
+ .selectFrom("version")
892
+ .select("commit_id")
893
+ .where("version.name", "=", "main"))
894
+ .orderBy("lixcol_depth", "asc")
895
+ .selectAll()
896
+ .execute();
897
+ expect(fileHistory).toHaveLength(2);
898
+ const afterState = JSON.parse(new TextDecoder().decode(fileHistory[0].data));
899
+ const beforeState = JSON.parse(new TextDecoder().decode(fileHistory[1].data));
900
+ expect(afterState).toEqual({
901
+ name: "My Cool Project",
902
+ version: "1.1.0",
903
+ });
904
+ expect(beforeState).toEqual({
905
+ name: "My Project",
906
+ version: "1.0.0",
907
+ });
908
+ });
909
+ // This test verifies that file_history correctly reconstructs files when only some properties change.
910
+ // The bug occurred when querying file_history at depth=0 after a partial update:
911
+ // - Changed entities appeared at depth=0
912
+ // - Unchanged entities remained at depth=1+
913
+ // The old implementation only returned entities at the exact depth, missing unchanged properties.
914
+ test("file_history handles partial updates correctly", async () => {
915
+ const lix = await openLix({
916
+ providePlugins: [mockJsonPlugin],
917
+ });
918
+ await lix.db
919
+ .insertInto("file")
920
+ .values({
921
+ id: "abcdefg",
922
+ path: "/test.json",
923
+ data: new TextEncoder().encode(JSON.stringify({
924
+ name: "test-item",
925
+ value: 100,
926
+ })),
927
+ })
928
+ .execute();
929
+ const checkpoint0 = await createCheckpoint({ lix });
930
+ await lix.db
931
+ .updateTable("file")
932
+ .where("path", "=", "/test.json")
933
+ .set({
934
+ data: new TextEncoder().encode(JSON.stringify({
935
+ name: "test-item",
936
+ value: 105,
937
+ })),
938
+ })
939
+ .execute();
940
+ const checkpoint1 = await createCheckpoint({ lix });
941
+ const beforeFile = await lix.db
942
+ .selectFrom("file_history")
943
+ .where("path", "=", "/test.json")
944
+ .where("lixcol_root_commit_id", "=", checkpoint0.id)
945
+ .where("lixcol_depth", "=", 0)
946
+ .select("data")
947
+ .executeTakeFirstOrThrow();
948
+ const afterFile = await lix.db
949
+ .selectFrom("file_history")
950
+ .where("path", "=", "/test.json")
951
+ .where("lixcol_root_commit_id", "=", checkpoint1.id)
952
+ .where("lixcol_depth", "=", 0)
953
+ .select("data")
954
+ .executeTakeFirstOrThrow();
955
+ const beforeData = new TextDecoder().decode(beforeFile.data);
956
+ const afterData = new TextDecoder().decode(afterFile.data);
957
+ const beforeDoc = JSON.parse(beforeData);
958
+ const afterDoc = JSON.parse(afterData);
959
+ expect(beforeDoc).toEqual({
960
+ name: "test-item",
961
+ value: 100,
962
+ });
963
+ expect(afterDoc).toEqual({
964
+ name: "test-item",
965
+ value: 105,
966
+ });
967
+ });
968
+ test("file views should expose same relevant lixcol_* columns as key_value view", async () => {
969
+ const lix = await openLix({
970
+ providePlugins: [mockJsonPlugin],
971
+ });
972
+ // Create a file that will be available in all file views
973
+ await lix.db
974
+ .insertInto("file")
975
+ .values({
976
+ id: "lixcol-test-file",
977
+ path: "/lixcol-test.json",
978
+ data: new TextEncoder().encode(JSON.stringify({ test: "data" })),
979
+ })
980
+ .execute();
981
+ // Create a key_value entry for comparison baseline
982
+ await lix.db
983
+ .insertInto("key_value")
984
+ .values({ key: "lixcol-test-kv", value: "test_value" })
985
+ .execute();
986
+ // Create a checkpoint for view queries
987
+ const checkpoint = await createCheckpoint({ lix });
988
+ // Extract lixcol_* columns helper function
989
+ const extractLixcols = (obj) => {
990
+ const lixcols = {};
991
+ for (const [key, value] of Object.entries(obj)) {
992
+ if (key.startsWith("lixcol_")) {
993
+ lixcols[key] = value;
994
+ }
995
+ }
996
+ return lixcols;
997
+ };
998
+ // Filter out columns that don't make sense for file views (files are themselves entities)
999
+ const blacklist = ["lixcol_file_id", "lixcol_plugin_key", "lixcol_entity_id"];
1000
+ const filterColumns = (lixcols) => {
1001
+ const filtered = {};
1002
+ for (const [key, value] of Object.entries(lixcols)) {
1003
+ if (!blacklist.includes(key)) {
1004
+ filtered[key] = value;
1005
+ }
1006
+ }
1007
+ return filtered;
1008
+ };
1009
+ // Test each file view type against corresponding key_value view
1010
+ const views = [
1011
+ {
1012
+ name: "file",
1013
+ fileQuery: () => lix.db
1014
+ .selectFrom("file")
1015
+ .selectAll()
1016
+ .where("id", "=", "lixcol-test-file"),
1017
+ keyValueQuery: () => lix.db
1018
+ .selectFrom("key_value")
1019
+ .selectAll()
1020
+ .where("key", "=", "lixcol-test-kv"),
1021
+ },
1022
+ {
1023
+ name: "file_all",
1024
+ fileQuery: () => lix.db
1025
+ .selectFrom("file_all")
1026
+ .selectAll()
1027
+ .where("id", "=", "lixcol-test-file"),
1028
+ keyValueQuery: () => lix.db
1029
+ .selectFrom("key_value_all")
1030
+ .selectAll()
1031
+ .where("key", "=", "lixcol-test-kv"),
1032
+ },
1033
+ {
1034
+ name: "file_history",
1035
+ fileQuery: () => lix.db
1036
+ .selectFrom("file_history")
1037
+ .selectAll()
1038
+ .where("id", "=", "lixcol-test-file")
1039
+ .where("lixcol_root_commit_id", "=", checkpoint.id)
1040
+ .where("lixcol_depth", "=", 0),
1041
+ keyValueQuery: () => lix.db
1042
+ .selectFrom("key_value_history")
1043
+ .selectAll()
1044
+ .where("key", "=", "lixcol-test-kv")
1045
+ .where("lixcol_root_commit_id", "=", checkpoint.id)
1046
+ .where("lixcol_depth", "=", 0),
1047
+ },
1048
+ ];
1049
+ for (const view of views) {
1050
+ // Query both the file view and corresponding key_value view
1051
+ const fileResult = await view.fileQuery().executeTakeFirstOrThrow();
1052
+ const keyValueResult = await view.keyValueQuery().executeTakeFirstOrThrow();
1053
+ // Extract and filter lixcol_* columns from both
1054
+ const fileLixcols = extractLixcols(fileResult);
1055
+ const keyValueLixcols = extractLixcols(keyValueResult);
1056
+ const fileFilteredLixcols = filterColumns(fileLixcols);
1057
+ const keyValueFilteredLixcols = filterColumns(keyValueLixcols);
1058
+ const fileFilteredKeys = Object.keys(fileFilteredLixcols).sort();
1059
+ const keyValueFilteredKeys = Object.keys(keyValueFilteredLixcols).sort();
1060
+ // File view should expose the same relevant lixcol_* columns as corresponding key_value view (excluding blacklisted ones)
1061
+ expect(fileFilteredKeys).toEqual(keyValueFilteredKeys);
1062
+ // Both should have the same number of relevant lixcol_* columns
1063
+ expect(fileFilteredKeys.length).toBe(keyValueFilteredKeys.length);
1064
+ // All lixcol_* values should be defined (can be null, but not undefined)
1065
+ const fileLixcolKeys = Object.keys(fileLixcols).sort();
1066
+ for (const key of fileLixcolKeys) {
1067
+ expect(fileLixcols[key]).toBeDefined();
1068
+ }
1069
+ // Verify that file views expose lix_file_descriptor as schema key
1070
+ expect(fileResult.lixcol_schema_key).toBe("lix_file_descriptor");
1071
+ }
1072
+ });
1073
+ test("file should expose lixcol columns based on file data AND the descriptor", async () => {
1074
+ const lix = await openLix({
1075
+ providePlugins: [mockJsonPlugin],
1076
+ keyValues: [
1077
+ {
1078
+ key: "lix_deterministic_mode",
1079
+ value: {
1080
+ enabled: true,
1081
+ },
1082
+ lixcol_version_id: "global",
1083
+ },
1084
+ ],
1085
+ });
1086
+ // Create a file with JSON content
1087
+ await lix.db
1088
+ .insertInto("file")
1089
+ .values({
1090
+ id: "aggregate-info-test",
1091
+ path: "/document.json",
1092
+ data: new TextEncoder().encode(JSON.stringify({
1093
+ title: "Original Title",
1094
+ content: "Original content",
1095
+ })),
1096
+ })
1097
+ .execute();
1098
+ // Get initial file info
1099
+ const fileAfterCreate = await lix.db
1100
+ .selectFrom("file")
1101
+ .where("id", "=", "aggregate-info-test")
1102
+ .selectAll()
1103
+ .executeTakeFirstOrThrow();
1104
+ const initialChangeId = fileAfterCreate.lixcol_change_id;
1105
+ const initialUpdatedAt = fileAfterCreate.lixcol_updated_at;
1106
+ // Verify that file view exposes lix_file_descriptor as schema key
1107
+ expect(fileAfterCreate.lixcol_schema_key).toBe("lix_file_descriptor");
1108
+ // Verify the initial change is either for the file descriptor or a content entity
1109
+ const initialChange = await lix.db
1110
+ .selectFrom("change")
1111
+ .where("id", "=", initialChangeId)
1112
+ .selectAll()
1113
+ .executeTakeFirstOrThrow();
1114
+ // When creating a file with content, the latest change could be either:
1115
+ // - The file descriptor change
1116
+ // - A content entity change (e.g., mock_json_property)
1117
+ expect(["lix_file_descriptor", "mock_json_property"]).toContain(initialChange.schema_key);
1118
+ // If it's a content change, verify it belongs to this file
1119
+ if (initialChange.schema_key !== "lix_file_descriptor") {
1120
+ expect(initialChange.file_id).toBe("aggregate-info-test");
1121
+ }
1122
+ // Update only the JSON content (not path or metadata)
1123
+ await lix.db
1124
+ .updateTable("file")
1125
+ .where("id", "=", "aggregate-info-test")
1126
+ .set({
1127
+ data: new TextEncoder().encode(JSON.stringify({
1128
+ title: "Updated Title", // Changed
1129
+ content: "Updated content", // Changed
1130
+ })),
1131
+ })
1132
+ .execute();
1133
+ // Get file info after content update
1134
+ const fileAfterContentUpdate = await lix.db
1135
+ .selectFrom("file")
1136
+ .where("id", "=", "aggregate-info-test")
1137
+ .selectAll()
1138
+ .executeTakeFirstOrThrow();
1139
+ // Get all changes related to this file (descriptor + content)
1140
+ const allFileChanges = await lix.db
1141
+ .selectFrom("change")
1142
+ .where((eb) => eb.or([
1143
+ // File descriptor changes
1144
+ eb("entity_id", "=", "aggregate-info-test").and("schema_key", "=", "lix_file_descriptor"),
1145
+ // Content changes (any entity within this file)
1146
+ eb("file_id", "=", "aggregate-info-test"),
1147
+ ]))
1148
+ .orderBy("created_at", "desc")
1149
+ .selectAll()
1150
+ .execute();
1151
+ // There should be multiple changes (descriptor + content properties)
1152
+ expect(allFileChanges.length).toBeGreaterThan(1);
1153
+ const latestContentChange = allFileChanges[0];
1154
+ // The actual latest change is a content change, not the descriptor
1155
+ expect(latestContentChange.schema_key).not.toBe("lix_file_descriptor");
1156
+ // The file view should show the latest change across ALL entities in the file
1157
+ expect(fileAfterContentUpdate.lixcol_change_id).toBe(latestContentChange.id);
1158
+ // The updated_at should reflect when the file was last modified (including content)
1159
+ expect(fileAfterContentUpdate.lixcol_updated_at).toBe(latestContentChange.created_at);
1160
+ // The file's change_set_id should contain the latest content change
1161
+ // Get all changes in the file's current change_set
1162
+ const changesInFileChangeSet = await lix.db
1163
+ .selectFrom("change_set_element")
1164
+ .where("change_set_id", "=", fileAfterContentUpdate.lixcol_commit_id)
1165
+ .selectAll()
1166
+ .execute();
1167
+ const changeIdsInSet = changesInFileChangeSet.map((el) => el.change_id);
1168
+ // The file's change_set_id should contain the latest content change
1169
+ expect(changeIdsInSet).toContain(latestContentChange.id);
1170
+ // Test file_all view shows the same aggregated behavior AT THIS POINT (before path update)
1171
+ // Re-query file_all after content update to verify it shows latest change
1172
+ const fileAllAfterContentUpdate = await lix.db
1173
+ .selectFrom("file_all")
1174
+ .where("id", "=", "aggregate-info-test")
1175
+ .selectAll()
1176
+ .executeTakeFirstOrThrow();
1177
+ // file_all should show the same change_id as the file view at this point
1178
+ expect(fileAllAfterContentUpdate.lixcol_change_id).toBe(fileAfterContentUpdate.lixcol_change_id);
1179
+ expect(fileAllAfterContentUpdate.lixcol_updated_at).toBe(fileAfterContentUpdate.lixcol_updated_at);
1180
+ // Verify that file_all view also exposes lix_file_descriptor as schema key
1181
+ expect(fileAllAfterContentUpdate.lixcol_schema_key).toBe("lix_file_descriptor");
1182
+ // Additional verification that descriptor changes DO work
1183
+ await lix.db
1184
+ .updateTable("file")
1185
+ .where("id", "=", "aggregate-info-test")
1186
+ .set({
1187
+ path: "/renamed-document.json", // This updates the descriptor
1188
+ })
1189
+ .execute();
1190
+ const fileAfterPathUpdate = await lix.db
1191
+ .selectFrom("file")
1192
+ .where("id", "=", "aggregate-info-test")
1193
+ .selectAll()
1194
+ .executeTakeFirstOrThrow();
1195
+ // Descriptor changes ARE reflected (this part works correctly)
1196
+ expect(fileAfterPathUpdate.lixcol_change_id).not.toBe(initialChangeId);
1197
+ // For string timestamps, use string comparison
1198
+ expect(fileAfterPathUpdate.lixcol_updated_at > initialUpdatedAt).toBe(true);
1199
+ // After path update, file_all should show the descriptor change
1200
+ const fileAllAfterPathUpdate = await lix.db
1201
+ .selectFrom("file_all")
1202
+ .where("id", "=", "aggregate-info-test")
1203
+ .selectAll()
1204
+ .executeTakeFirstOrThrow();
1205
+ expect(fileAllAfterPathUpdate.lixcol_change_id).toBe(fileAfterPathUpdate.lixcol_change_id);
1206
+ expect(fileAllAfterPathUpdate.path).toBe("/renamed-document.json");
1207
+ // Create a checkpoint to test file_history
1208
+ const checkpoint = await createCheckpoint({ lix });
1209
+ // Test file_history view also aggregates changes correctly
1210
+ const fileHistoryAtCheckpoint = await lix.db
1211
+ .selectFrom("file_history")
1212
+ .where("id", "=", "aggregate-info-test")
1213
+ .where("lixcol_root_commit_id", "=", checkpoint.id)
1214
+ .where("lixcol_depth", "=", 0)
1215
+ .selectAll()
1216
+ .executeTakeFirstOrThrow();
1217
+ // file_history should show the latest state including the path update
1218
+ expect(fileHistoryAtCheckpoint.path).toBe("/renamed-document.json");
1219
+ expect(fileHistoryAtCheckpoint.lixcol_change_id).toBe(fileAfterPathUpdate.lixcol_change_id);
1220
+ // Verify that file_history view also exposes lix_file_descriptor as schema key
1221
+ expect(fileHistoryAtCheckpoint.lixcol_schema_key).toBe("lix_file_descriptor");
1222
+ // The materialized data should reflect the content updates
1223
+ const historicalData = JSON.parse(new TextDecoder().decode(fileHistoryAtCheckpoint.data));
1224
+ expect(historicalData).toEqual({
1225
+ title: "Updated Title",
1226
+ content: "Updated content",
1227
+ });
1228
+ });
1229
+ test("files should be identical across versions when versions have the same commit", async () => {
1230
+ const lix = await openLix({
1231
+ providePlugins: [mockJsonPlugin],
1232
+ });
1233
+ const initialFile = new TextEncoder().encode(JSON.stringify({
1234
+ items: [{ id: 1, name: "T-Shirt", price: 29.99, stock: 100 }],
1235
+ }));
1236
+ // Create a file in the main version
1237
+ await lix.db
1238
+ .insertInto("file")
1239
+ .values({
1240
+ path: "/products.json",
1241
+ data: initialFile,
1242
+ })
1243
+ .execute();
1244
+ // Verify the file exists in main version
1245
+ const fileInMain = await lix.db
1246
+ .selectFrom("file")
1247
+ .where("path", "=", "/products.json")
1248
+ .selectAll()
1249
+ .executeTakeFirst();
1250
+ expect(fileInMain?.data).toEqual(initialFile);
1251
+ // Create a new version (should inherit from active version)
1252
+ const newVersion = await createVersion({
1253
+ lix,
1254
+ name: "price-update",
1255
+ });
1256
+ // Switch to the new version
1257
+ await switchVersion({ lix, to: newVersion });
1258
+ // Check if the file is inherited in the new version
1259
+ const fileInNewVersion = await lix.db
1260
+ .selectFrom("file")
1261
+ .where("path", "=", "/products.json")
1262
+ .selectAll()
1263
+ .executeTakeFirst();
1264
+ expect(fileInNewVersion?.data).toEqual(initialFile);
1265
+ // Update the file in the new version
1266
+ await lix.db
1267
+ .updateTable("file")
1268
+ .set({
1269
+ data: new TextEncoder().encode(JSON.stringify({
1270
+ items: [
1271
+ { id: 1, name: "T-Shirt", price: 34.99, stock: 100 }, // Price changed
1272
+ ],
1273
+ })),
1274
+ })
1275
+ .where("path", "=", "/products.json")
1276
+ .execute();
1277
+ // Verify the update worked
1278
+ const updatedFile = await lix.db
1279
+ .selectFrom("file")
1280
+ .where("path", "=", "/products.json")
1281
+ .selectAll()
1282
+ .executeTakeFirstOrThrow();
1283
+ const updatedData = JSON.parse(new TextDecoder().decode(updatedFile.data));
1284
+ expect(updatedData.items[0].price).toBe(34.99);
1285
+ // Query file_all to see both versions
1286
+ const filesAcrossVersions = await lix.db
1287
+ .selectFrom("file_all")
1288
+ .where("path", "=", "/products.json")
1289
+ .select(["lixcol_version_id", "data"])
1290
+ .execute();
1291
+ expect(filesAcrossVersions).toHaveLength(2);
1292
+ // Get version info for verification
1293
+ const versions = await lix.db
1294
+ .selectFrom("version")
1295
+ .select(["id", "name"])
1296
+ .execute();
1297
+ const mainVersionData = filesAcrossVersions.find((f) => {
1298
+ const version = versions.find((v) => v.id === f.lixcol_version_id);
1299
+ return version?.name === "main";
1300
+ });
1301
+ const newVersionData = filesAcrossVersions.find((f) => {
1302
+ const version = versions.find((v) => v.id === f.lixcol_version_id);
1303
+ return version?.name === "price-update";
1304
+ });
1305
+ expect(mainVersionData).toBeDefined();
1306
+ expect(newVersionData).toBeDefined();
1307
+ // Verify the prices are different
1308
+ const mainData = JSON.parse(new TextDecoder().decode(mainVersionData.data));
1309
+ const updatedVersionData = JSON.parse(new TextDecoder().decode(newVersionData.data));
1310
+ expect(mainData.items[0].price).toBe(29.99); // Original price
1311
+ expect(updatedVersionData.items[0].price).toBe(34.99); // Updated price
1312
+ });
1313
+ //# sourceMappingURL=schema.test.js.map