@lix-js/sdk 0.0.1 → 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (278) hide show
  1. package/LICENSE +21 -0
  2. package/dist/change/apply-changes.js +9 -9
  3. package/dist/change/apply-changes.js.map +1 -1
  4. package/dist/change/apply-changes.test.js +5 -5
  5. package/dist/change/apply-changes.test.js.map +1 -1
  6. package/dist/database/apply-schema.d.ts.map +1 -1
  7. package/dist/database/apply-schema.js +20 -72
  8. package/dist/database/apply-schema.js.map +1 -1
  9. package/dist/database/execute-sync.test.js +3 -3
  10. package/dist/database/execute-sync.test.js.map +1 -1
  11. package/dist/database/init-db.d.ts.map +1 -1
  12. package/dist/database/init-db.js +18 -3
  13. package/dist/database/init-db.js.map +1 -1
  14. package/dist/database/init-db.test.js +128 -17
  15. package/dist/database/init-db.test.js.map +1 -1
  16. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.d.ts.map +1 -1
  17. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js +5 -2
  18. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js.map +1 -1
  19. package/dist/database/mutation-log/database-schema.d.ts.map +1 -1
  20. package/dist/database/mutation-log/database-schema.js +1 -3
  21. package/dist/database/mutation-log/database-schema.js.map +1 -1
  22. package/dist/database/nano-id.d.ts +21 -0
  23. package/dist/database/nano-id.d.ts.map +1 -0
  24. package/dist/database/nano-id.js +58 -0
  25. package/dist/database/nano-id.js.map +1 -0
  26. package/dist/database/nano-id.test.d.ts +2 -0
  27. package/dist/database/nano-id.test.d.ts.map +1 -0
  28. package/dist/database/nano-id.test.js +13 -0
  29. package/dist/database/nano-id.test.js.map +1 -0
  30. package/dist/database/schema.d.ts +15 -23
  31. package/dist/database/schema.d.ts.map +1 -1
  32. package/dist/discussion/create-comment.d.ts +0 -2
  33. package/dist/discussion/create-comment.d.ts.map +1 -1
  34. package/dist/discussion/create-comment.js +0 -1
  35. package/dist/discussion/create-comment.js.map +1 -1
  36. package/dist/discussion/create-discussion.d.ts +3 -5
  37. package/dist/discussion/create-discussion.d.ts.map +1 -1
  38. package/dist/discussion/create-discussion.js +4 -5
  39. package/dist/discussion/create-discussion.js.map +1 -1
  40. package/dist/discussion/create-discussion.test.js +8 -34
  41. package/dist/discussion/create-discussion.test.js.map +1 -1
  42. package/dist/file-queue/file-handlers.d.ts +24 -0
  43. package/dist/file-queue/file-handlers.d.ts.map +1 -0
  44. package/dist/file-queue/file-handlers.js +209 -0
  45. package/dist/file-queue/file-handlers.js.map +1 -0
  46. package/dist/file-queue/file-queue-process.d.ts +5 -0
  47. package/dist/file-queue/file-queue-process.d.ts.map +1 -0
  48. package/dist/file-queue/file-queue-process.js +85 -0
  49. package/dist/file-queue/file-queue-process.js.map +1 -0
  50. package/dist/file-queue/file-queue-process.test.d.ts +2 -0
  51. package/dist/file-queue/file-queue-process.test.d.ts.map +1 -0
  52. package/dist/file-queue/file-queue-process.test.js +373 -0
  53. package/dist/file-queue/file-queue-process.test.js.map +1 -0
  54. package/dist/file-queue/file-queue-settled.d.ts +13 -0
  55. package/dist/file-queue/file-queue-settled.d.ts.map +1 -0
  56. package/dist/file-queue/file-queue-settled.js +25 -0
  57. package/dist/file-queue/file-queue-settled.js.map +1 -0
  58. package/dist/file-queue/file-queue-settled.test.d.ts +2 -0
  59. package/dist/file-queue/file-queue-settled.test.d.ts.map +1 -0
  60. package/dist/file-queue/file-queue-settled.test.js +47 -0
  61. package/dist/file-queue/file-queue-settled.test.js.map +1 -0
  62. package/dist/file-queue/index.d.ts +2 -0
  63. package/dist/file-queue/index.d.ts.map +1 -0
  64. package/dist/file-queue/index.js +2 -0
  65. package/dist/file-queue/index.js.map +1 -0
  66. package/dist/file-queue/with-skip-file-queue.d.ts +3 -0
  67. package/dist/file-queue/with-skip-file-queue.d.ts.map +1 -0
  68. package/dist/file-queue/with-skip-file-queue.js +26 -0
  69. package/dist/file-queue/with-skip-file-queue.js.map +1 -0
  70. package/dist/file-queue/with-skip-file-queue.test.d.ts +2 -0
  71. package/dist/file-queue/with-skip-file-queue.test.d.ts.map +1 -0
  72. package/dist/file-queue/with-skip-file-queue.test.js +138 -0
  73. package/dist/file-queue/with-skip-file-queue.test.js.map +1 -0
  74. package/dist/index.d.ts +2 -2
  75. package/dist/index.d.ts.map +1 -1
  76. package/dist/index.js +2 -2
  77. package/dist/index.js.map +1 -1
  78. package/dist/key-value/database-schema.d.ts +11 -2
  79. package/dist/key-value/database-schema.d.ts.map +1 -1
  80. package/dist/key-value/database-schema.js +7 -4
  81. package/dist/key-value/database-schema.js.map +1 -1
  82. package/dist/key-value/database-schema.test.js +21 -5
  83. package/dist/key-value/database-schema.test.js.map +1 -1
  84. package/dist/lix/close-lix.d.ts +8 -0
  85. package/dist/lix/close-lix.d.ts.map +1 -0
  86. package/dist/lix/close-lix.js +7 -0
  87. package/dist/lix/close-lix.js.map +1 -0
  88. package/dist/lix/index.d.ts +1 -0
  89. package/dist/lix/index.d.ts.map +1 -1
  90. package/dist/lix/index.js +1 -0
  91. package/dist/lix/index.js.map +1 -1
  92. package/dist/lix/merge.js +3 -3
  93. package/dist/lix/merge.js.map +1 -1
  94. package/dist/lix/merge.test.js +7 -18
  95. package/dist/lix/merge.test.js.map +1 -1
  96. package/dist/lix/new-lix.d.ts.map +1 -1
  97. package/dist/lix/new-lix.js +2 -3
  98. package/dist/lix/new-lix.js.map +1 -1
  99. package/dist/lix/open-lix-in-memory.test.js +2 -1
  100. package/dist/lix/open-lix-in-memory.test.js.map +1 -1
  101. package/dist/lix/open-lix.d.ts +3 -5
  102. package/dist/lix/open-lix.d.ts.map +1 -1
  103. package/dist/lix/open-lix.js +4 -18
  104. package/dist/lix/open-lix.js.map +1 -1
  105. package/dist/lix/open-lix.test.js +16 -7
  106. package/dist/lix/open-lix.test.js.map +1 -1
  107. package/dist/lix/to-blob.d.ts +11 -0
  108. package/dist/lix/to-blob.d.ts.map +1 -0
  109. package/dist/lix/to-blob.js +11 -0
  110. package/dist/lix/to-blob.js.map +1 -0
  111. package/dist/own-change-control/apply-own-change.d.ts +10 -0
  112. package/dist/own-change-control/apply-own-change.d.ts.map +1 -0
  113. package/dist/own-change-control/apply-own-change.js +69 -0
  114. package/dist/own-change-control/apply-own-change.js.map +1 -0
  115. package/dist/own-change-control/apply-own-change.test.d.ts +2 -0
  116. package/dist/own-change-control/apply-own-change.test.d.ts.map +1 -0
  117. package/dist/own-change-control/apply-own-change.test.js +297 -0
  118. package/dist/own-change-control/apply-own-change.test.js.map +1 -0
  119. package/dist/own-change-control/change-controlled-tables.d.ts +60 -0
  120. package/dist/own-change-control/change-controlled-tables.d.ts.map +1 -0
  121. package/dist/own-change-control/change-controlled-tables.js +70 -0
  122. package/dist/own-change-control/change-controlled-tables.js.map +1 -0
  123. package/dist/own-change-control/change-controlled-tables.test.d.ts +2 -0
  124. package/dist/own-change-control/change-controlled-tables.test.d.ts.map +1 -0
  125. package/dist/own-change-control/change-controlled-tables.test.js +48 -0
  126. package/dist/own-change-control/change-controlled-tables.test.js.map +1 -0
  127. package/dist/own-change-control/database-triggers.d.ts +5 -0
  128. package/dist/own-change-control/database-triggers.d.ts.map +1 -0
  129. package/dist/own-change-control/database-triggers.js +135 -0
  130. package/dist/own-change-control/database-triggers.js.map +1 -0
  131. package/dist/own-change-control/database-triggers.test.d.ts +2 -0
  132. package/dist/own-change-control/database-triggers.test.d.ts.map +1 -0
  133. package/dist/own-change-control/database-triggers.test.js +214 -0
  134. package/dist/own-change-control/database-triggers.test.js.map +1 -0
  135. package/dist/own-change-control/index.d.ts +2 -0
  136. package/dist/own-change-control/index.d.ts.map +1 -0
  137. package/dist/own-change-control/index.js +2 -0
  138. package/dist/own-change-control/index.js.map +1 -0
  139. package/dist/own-change-control/with-skip-own-change-control.d.ts +3 -0
  140. package/dist/own-change-control/with-skip-own-change-control.d.ts.map +1 -0
  141. package/dist/own-change-control/with-skip-own-change-control.js +28 -0
  142. package/dist/own-change-control/with-skip-own-change-control.js.map +1 -0
  143. package/dist/own-change-control/with-skip-own-change-control.test.d.ts +2 -0
  144. package/dist/own-change-control/with-skip-own-change-control.test.d.ts.map +1 -0
  145. package/dist/own-change-control/with-skip-own-change-control.test.js +49 -0
  146. package/dist/own-change-control/with-skip-own-change-control.test.js.map +1 -0
  147. package/dist/own-entity-change-control/apply-own-entity-change.js +2 -2
  148. package/dist/own-entity-change-control/apply-own-entity-change.js.map +1 -1
  149. package/dist/own-entity-change-control/apply-own-entity-change.test.js +9 -9
  150. package/dist/own-entity-change-control/apply-own-entity-change.test.js.map +1 -1
  151. package/dist/own-entity-change-control/database-triggers.js +6 -6
  152. package/dist/own-entity-change-control/database-triggers.js.map +1 -1
  153. package/dist/own-entity-change-control/database-triggers.test.js +1 -1
  154. package/dist/own-entity-change-control/database-triggers.test.js.map +1 -1
  155. package/dist/query-filter/version-change-in-difference.test.js +37 -29
  156. package/dist/query-filter/version-change-in-difference.test.js.map +1 -1
  157. package/dist/query-filter/version-change-in-symmetric-difference.test.js +37 -39
  158. package/dist/query-filter/version-change-in-symmetric-difference.test.js.map +1 -1
  159. package/dist/server-api-handler/environment/create-in-memory-environment.d.ts.map +1 -1
  160. package/dist/server-api-handler/environment/create-in-memory-environment.js +7 -3
  161. package/dist/server-api-handler/environment/create-in-memory-environment.js.map +1 -1
  162. package/dist/server-api-handler/environment/create-in-memory-environment.test.js +8 -7
  163. package/dist/server-api-handler/environment/create-in-memory-environment.test.js.map +1 -1
  164. package/dist/server-api-handler/routes/get-v1.d.ts.map +1 -1
  165. package/dist/server-api-handler/routes/get-v1.js +1 -2
  166. package/dist/server-api-handler/routes/get-v1.js.map +1 -1
  167. package/dist/server-api-handler/routes/get-v1.test.js +6 -5
  168. package/dist/server-api-handler/routes/get-v1.test.js.map +1 -1
  169. package/dist/server-api-handler/routes/new-v1.d.ts.map +1 -1
  170. package/dist/server-api-handler/routes/new-v1.js +3 -1
  171. package/dist/server-api-handler/routes/new-v1.js.map +1 -1
  172. package/dist/server-api-handler/routes/new-v1.test.js +2 -1
  173. package/dist/server-api-handler/routes/new-v1.test.js.map +1 -1
  174. package/dist/server-api-handler/routes/pull-v1.test.js +4 -3
  175. package/dist/server-api-handler/routes/pull-v1.test.js.map +1 -1
  176. package/dist/server-api-handler/routes/push-v1.test.js +5 -4
  177. package/dist/server-api-handler/routes/push-v1.test.js.map +1 -1
  178. package/dist/sync/pull-from-server.d.ts.map +1 -1
  179. package/dist/sync/pull-from-server.js +0 -2
  180. package/dist/sync/pull-from-server.js.map +1 -1
  181. package/dist/sync/pull-from-server.test.js +29 -14
  182. package/dist/sync/pull-from-server.test.js.map +1 -1
  183. package/dist/sync/push-to-server.test.js +17 -13
  184. package/dist/sync/push-to-server.test.js.map +1 -1
  185. package/dist/sync/sync-process.d.ts +2 -4
  186. package/dist/sync/sync-process.d.ts.map +1 -1
  187. package/dist/sync/sync-process.js +4 -9
  188. package/dist/sync/sync-process.js.map +1 -1
  189. package/dist/sync/sync-process.test.js +26 -38
  190. package/dist/sync/sync-process.test.js.map +1 -1
  191. package/dist/version/create-version.d.ts +5 -5
  192. package/dist/version/create-version.d.ts.map +1 -1
  193. package/dist/version/create-version.js +23 -11
  194. package/dist/version/create-version.js.map +1 -1
  195. package/dist/version/create-version.test.js +2 -2
  196. package/dist/version/create-version.test.js.map +1 -1
  197. package/dist/version/merge-version.d.ts.map +1 -1
  198. package/dist/version/merge-version.js +16 -26
  199. package/dist/version/merge-version.js.map +1 -1
  200. package/dist/version/switch-version.js +3 -3
  201. package/dist/version/switch-version.js.map +1 -1
  202. package/dist/version/switch-version.test.js +12 -15
  203. package/dist/version/switch-version.test.js.map +1 -1
  204. package/dist/version/update-changes-in-version.d.ts.map +1 -1
  205. package/dist/version/update-changes-in-version.js +11 -31
  206. package/dist/version/update-changes-in-version.js.map +1 -1
  207. package/node_modules/@lix-js/server-api-schema/CHANGELOG.md +9 -0
  208. package/node_modules/@lix-js/server-api-schema/LICENSE +21 -0
  209. package/node_modules/@lix-js/server-api-schema/dist/schema.js +0 -0
  210. package/node_modules/@lix-js/server-api-schema/package.json +2 -2
  211. package/node_modules/sqlite-wasm-kysely/LICENSE +21 -0
  212. package/package.json +4 -4
  213. package/src/change/apply-changes.test.ts +7 -7
  214. package/src/change/apply-changes.ts +9 -9
  215. package/src/database/apply-schema.ts +20 -73
  216. package/src/database/execute-sync.test.ts +3 -3
  217. package/src/database/init-db.test.ts +163 -19
  218. package/src/database/init-db.ts +20 -3
  219. package/src/database/kysely-plugin/parse-jsonb-plugin-v1.ts +9 -2
  220. package/src/database/mutation-log/database-schema.ts +1 -3
  221. package/src/database/nano-id.test.ts +15 -0
  222. package/src/database/nano-id.ts +72 -0
  223. package/src/database/schema.ts +15 -24
  224. package/src/discussion/create-comment.ts +0 -3
  225. package/src/discussion/create-discussion.test.ts +8 -39
  226. package/src/discussion/create-discussion.ts +6 -9
  227. package/src/{change-queue → file-queue}/file-handlers.ts +27 -27
  228. package/src/{change-queue/init-change-queue.test.ts → file-queue/file-queue-process.test.ts} +24 -24
  229. package/src/{change-queue/init-change-queue.ts → file-queue/file-queue-process.ts} +18 -16
  230. package/src/{change-queue/change-queue-settled.test.ts → file-queue/file-queue-settled.test.ts} +12 -12
  231. package/src/{change-queue/change-queue-settled.ts → file-queue/file-queue-settled.ts} +4 -4
  232. package/src/file-queue/index.ts +1 -0
  233. package/src/{change-queue/with-skip-change-queue.test.ts → file-queue/with-skip-file-queue.test.ts} +9 -9
  234. package/src/{change-queue/with-skip-change-queue.ts → file-queue/with-skip-file-queue.ts} +3 -3
  235. package/src/index.ts +2 -2
  236. package/src/key-value/database-schema.test.ts +26 -5
  237. package/src/key-value/database-schema.ts +18 -6
  238. package/src/lix/close-lix.ts +8 -0
  239. package/src/lix/index.ts +1 -0
  240. package/src/lix/merge.test.ts +7 -19
  241. package/src/lix/merge.ts +4 -4
  242. package/src/lix/new-lix.ts +2 -3
  243. package/src/lix/open-lix-in-memory.test.ts +5 -1
  244. package/src/lix/open-lix.test.ts +19 -7
  245. package/src/lix/open-lix.ts +7 -24
  246. package/src/lix/to-blob.ts +14 -0
  247. package/src/{own-entity-change-control/apply-own-entity-change.test.ts → own-change-control/apply-own-change.test.ts} +27 -31
  248. package/src/{own-entity-change-control/apply-own-entity-change.ts → own-change-control/apply-own-change.ts} +3 -3
  249. package/src/{own-entity-change-control → own-change-control}/change-controlled-tables.ts +0 -1
  250. package/src/{own-entity-change-control → own-change-control}/database-triggers.test.ts +7 -7
  251. package/src/{own-entity-change-control → own-change-control}/database-triggers.ts +11 -11
  252. package/src/{own-entity-change-control → own-change-control}/with-skip-own-change-control.ts +6 -2
  253. package/src/query-filter/version-change-in-difference.test.ts +41 -32
  254. package/src/query-filter/version-change-in-symmetric-difference.test.ts +41 -42
  255. package/src/server-api-handler/environment/create-in-memory-environment.test.ts +8 -7
  256. package/src/server-api-handler/environment/create-in-memory-environment.ts +7 -3
  257. package/src/server-api-handler/routes/get-v1.test.ts +6 -5
  258. package/src/server-api-handler/routes/get-v1.ts +1 -3
  259. package/src/server-api-handler/routes/new-v1.test.ts +2 -1
  260. package/src/server-api-handler/routes/new-v1.ts +3 -1
  261. package/src/server-api-handler/routes/pull-v1.test.ts +4 -3
  262. package/src/server-api-handler/routes/push-v1.test.ts +5 -4
  263. package/src/sync/pull-from-server.test.ts +29 -14
  264. package/src/sync/pull-from-server.ts +0 -2
  265. package/src/sync/push-to-server.test.ts +19 -15
  266. package/src/sync/sync-process.test.ts +37 -43
  267. package/src/sync/sync-process.ts +6 -18
  268. package/src/version/create-version.test.ts +2 -2
  269. package/src/version/create-version.ts +24 -12
  270. package/src/version/merge-version.ts +18 -26
  271. package/src/version/switch-version.test.ts +12 -15
  272. package/src/version/switch-version.ts +3 -3
  273. package/src/version/update-changes-in-version.ts +11 -30
  274. package/node_modules/@lix-js/server-api-schema/dist/schema.d.ts +0 -384
  275. package/src/change-queue/index.ts +0 -1
  276. /package/src/{own-entity-change-control → own-change-control}/change-controlled-tables.test.ts +0 -0
  277. /package/src/{own-entity-change-control → own-change-control}/index.ts +0 -0
  278. /package/src/{own-entity-change-control → own-change-control}/with-skip-own-change-control.test.ts +0 -0
@@ -1,5 +1,6 @@
1
1
  import { createInMemoryDatabase, contentFromDatabase, } from "sqlite-wasm-kysely";
2
2
  import { initDb } from "../database/init-db.js";
3
+ import { closeLix } from "./close-lix.js";
3
4
  /**
4
5
  * Creates a new lix file.
5
6
  *
@@ -19,9 +20,7 @@ export async function newLixFile() {
19
20
  throw new Error(`Failed to create new Lix file: ${e}`, { cause: e });
20
21
  }
21
22
  finally {
22
- // in any case destroy the memory db
23
- sqlite.close();
24
- await db.destroy();
23
+ closeLix({ lix: { db } });
25
24
  }
26
25
  }
27
26
  //# sourceMappingURL=new-lix.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"new-lix.js","sourceRoot":"","sources":["../../src/lix/new-lix.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,sBAAsB,EACtB,mBAAmB,GACnB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,UAAU;IAC/B,MAAM,MAAM,GAAG,MAAM,sBAAsB,CAAC;QAC3C,QAAQ,EAAE,KAAK;KACf,CAAC,CAAC;IAEH,2BAA2B;IAC3B,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAE9B,IAAI,CAAC;QACJ,OAAO,IAAI,IAAI,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACZ,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;IACtE,CAAC;YAAS,CAAC;QACV,oCAAoC;QACpC,MAAM,CAAC,KAAK,EAAE,CAAC;QACf,MAAM,EAAE,CAAC,OAAO,EAAE,CAAC;IACpB,CAAC;AACF,CAAC"}
1
+ {"version":3,"file":"new-lix.js","sourceRoot":"","sources":["../../src/lix/new-lix.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,sBAAsB,EACtB,mBAAmB,GACnB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAE1C;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,UAAU;IAC/B,MAAM,MAAM,GAAG,MAAM,sBAAsB,CAAC;QAC3C,QAAQ,EAAE,KAAK;KACf,CAAC,CAAC;IAEH,2BAA2B;IAC3B,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC,CAAC;IAE9B,IAAI,CAAC;QACJ,OAAO,IAAI,IAAI,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;IAChD,CAAC;IAAC,OAAO,CAAC,EAAE,CAAC;QACZ,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,EAAE,EAAE,EAAE,KAAK,EAAE,CAAC,EAAE,CAAC,CAAC;IACtE,CAAC;YAAS,CAAC;QACV,QAAQ,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;IAC3B,CAAC;AACF,CAAC"}
@@ -1,5 +1,6 @@
1
1
  import { test, expect } from "vitest";
2
2
  import { openLixInMemory } from "./open-lix-in-memory.js";
3
+ import { toBlob } from "./to-blob.js";
3
4
  test("it should open a lix in memory", async () => {
4
5
  const lix = await openLixInMemory({});
5
6
  // querying a table to see if the schema is applied
@@ -16,7 +17,7 @@ test("it should open a lix in memory from a blob", async () => {
16
17
  data: new TextEncoder().encode("hello"),
17
18
  })
18
19
  .execute();
19
- const lix2 = await openLixInMemory({ blob: await lix1.toBlob() });
20
+ const lix2 = await openLixInMemory({ blob: await toBlob({ lix: lix1 }) });
20
21
  const files = await lix2.db.selectFrom("file").selectAll().execute();
21
22
  expect(files).toEqual([
22
23
  expect.objectContaining({
@@ -1 +1 @@
1
- {"version":3,"file":"open-lix-in-memory.test.js","sourceRoot":"","sources":["../../src/lix/open-lix-in-memory.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE1D,IAAI,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;IACjD,MAAM,GAAG,GAAG,MAAM,eAAe,CAAC,EAAE,CAAC,CAAC;IACtC,mDAAmD;IACnD,MAAM,OAAO,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAC;IACxE,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;AAC7B,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;IAC7D,MAAM,IAAI,GAAG,MAAM,eAAe,CAAC,EAAE,CAAC,CAAC;IACvC,MAAM,IAAI,CAAC,EAAE;SACX,UAAU,CAAC,MAAM,CAAC;SAClB,MAAM,CAAC;QACP,EAAE,EAAE,GAAG;QACP,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC;KACvC,CAAC;SACD,OAAO,EAAE,CAAC;IACZ,MAAM,IAAI,GAAG,MAAM,eAAe,CAAC,EAAE,IAAI,EAAE,MAAM,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IAClE,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAC;IACrE,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;QACrB,MAAM,CAAC,gBAAgB,CAAC;YACvB,EAAE,EAAE,GAAG;YACP,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC;SACvC,CAAC;KACF,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"open-lix-in-memory.test.js","sourceRoot":"","sources":["../../src/lix/open-lix-in-memory.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAEtC,IAAI,CAAC,gCAAgC,EAAE,KAAK,IAAI,EAAE;IACjD,MAAM,GAAG,GAAG,MAAM,eAAe,CAAC,EAAE,CAAC,CAAC;IACtC,mDAAmD;IACnD,MAAM,OAAO,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAC;IACxE,MAAM,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;AAC7B,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,4CAA4C,EAAE,KAAK,IAAI,EAAE;IAC7D,MAAM,IAAI,GAAG,MAAM,eAAe,CAAC,EAAE,CAAC,CAAC;IAEvC,MAAM,IAAI,CAAC,EAAE;SACX,UAAU,CAAC,MAAM,CAAC;SAClB,MAAM,CAAC;QACP,EAAE,EAAE,GAAG;QACP,IAAI,EAAE,QAAQ;QACd,IAAI,EAAE,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC;KACvC,CAAC;SACD,OAAO,EAAE,CAAC;IAEZ,MAAM,IAAI,GAAG,MAAM,eAAe,CAAC,EAAE,IAAI,EAAE,MAAM,MAAM,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;IAC1E,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAC;IAErE,MAAM,CAAC,KAAK,CAAC,CAAC,OAAO,CAAC;QACrB,MAAM,CAAC,gBAAgB,CAAC;YACvB,EAAE,EAAE,GAAG;YACP,IAAI,EAAE,QAAQ;YACd,IAAI,EAAE,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC;SACvC,CAAC;KACF,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC"}
@@ -2,7 +2,7 @@ import type { LixPlugin } from "../plugin/lix-plugin.js";
2
2
  import { type SqliteDatabase } from "sqlite-wasm-kysely";
3
3
  import type { Kysely } from "kysely";
4
4
  import type { LixDatabaseSchema } from "../database/schema.js";
5
- import type { KeyValue } from "../key-value/database-schema.js";
5
+ import type { NewKeyValue } from "../key-value/database-schema.js";
6
6
  export type Lix = {
7
7
  /**
8
8
  * The raw SQLite instance.
@@ -16,11 +16,9 @@ export type Lix = {
16
16
  */
17
17
  sqlite: SqliteDatabase;
18
18
  db: Kysely<LixDatabaseSchema>;
19
- toBlob: () => Promise<Blob>;
20
19
  plugin: {
21
20
  getAll: () => Promise<LixPlugin[]>;
22
21
  };
23
- close: () => Promise<void>;
24
22
  };
25
23
  /**
26
24
  * Common setup between different lix environments.
@@ -45,8 +43,8 @@ export declare function openLix(args: {
45
43
  * Set the key values when opening the lix.
46
44
  *
47
45
  * @example
48
- * const lix = await openLix({ keyValues: [{ key: "#lix_sync", value: "false" }] })
46
+ * const lix = await openLix({ keyValues: [{ key: "lix_sync", value: "false" }] })
49
47
  */
50
- keyValues?: KeyValue[];
48
+ keyValues?: NewKeyValue[];
51
49
  }): Promise<Lix>;
52
50
  //# sourceMappingURL=open-lix.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"open-lix.d.ts","sourceRoot":"","sources":["../../src/lix/open-lix.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,EAAuB,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAI9E,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAEhE,MAAM,MAAM,GAAG,GAAG;IACjB;;;;;;;;;OASG;IACH,MAAM,EAAE,cAAc,CAAC;IACvB,EAAE,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAC9B,MAAM,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,MAAM,EAAE;QACP,MAAM,EAAE,MAAM,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;KACnC,CAAC;IACF,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;CAC3B,CAAC;AAEF;;GAEG;AACH,wBAAsB,OAAO,CAAC,IAAI,EAAE;IACnC,QAAQ,EAAE,cAAc,CAAC;IACzB;;;;;;;;;;;;OAYG;IACH,cAAc,CAAC,EAAE,SAAS,EAAE,CAAC;IAC7B;;;;;OAKG;IACH,SAAS,CAAC,EAAE,QAAQ,EAAE,CAAC;CACvB,GAAG,OAAO,CAAC,GAAG,CAAC,CA6Cf"}
1
+ {"version":3,"file":"open-lix.d.ts","sourceRoot":"","sources":["../../src/lix/open-lix.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,yBAAyB,CAAC;AAEzD,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAGzD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AACrC,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAC;AAE/D,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAEnE,MAAM,MAAM,GAAG,GAAG;IACjB;;;;;;;;;OASG;IACH,MAAM,EAAE,cAAc,CAAC;IACvB,EAAE,EAAE,MAAM,CAAC,iBAAiB,CAAC,CAAC;IAC9B,MAAM,EAAE;QACP,MAAM,EAAE,MAAM,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC;KACnC,CAAC;CACF,CAAC;AAEF;;GAEG;AACH,wBAAsB,OAAO,CAAC,IAAI,EAAE;IACnC,QAAQ,EAAE,cAAc,CAAC;IACzB;;;;;;;;;;;;OAYG;IACH,cAAc,CAAC,EAAE,SAAS,EAAE,CAAC;IAC7B;;;;;OAKG;IACH,SAAS,CAAC,EAAE,WAAW,EAAE,CAAC;CAC1B,GAAG,OAAO,CAAC,GAAG,CAAC,CA+Bf"}
@@ -1,8 +1,7 @@
1
1
  import { loadPlugins } from "../plugin/load-plugin.js";
2
- import { contentFromDatabase } from "sqlite-wasm-kysely";
2
+ import {} from "sqlite-wasm-kysely";
3
3
  import { initDb } from "../database/init-db.js";
4
- import { initChangeQueue } from "../change-queue/init-change-queue.js";
5
- import { changeQueueSettled } from "../change-queue/change-queue-settled.js";
4
+ import { initFileQueueProcess } from "../file-queue/file-queue-process.js";
6
5
  import { initSyncProcess } from "../sync/sync-process.js";
7
6
  /**
8
7
  * Common setup between different lix environments.
@@ -23,25 +22,12 @@ export async function openLix(args) {
23
22
  const plugin = {
24
23
  getAll: async () => plugins,
25
24
  };
26
- const toBlob = async () => {
27
- await changeQueueSettled({ lix: { db } });
28
- return new Blob([contentFromDatabase(args.database)]);
29
- };
30
- initChangeQueue({
31
- lix: { db, plugin, sqlite: args.database },
32
- rawDatabase: args.database,
33
- });
34
- initSyncProcess({ lix: { db, plugin, toBlob } });
25
+ initFileQueueProcess({ lix: { db, plugin, sqlite: args.database } });
26
+ initSyncProcess({ lix: { db, plugin, sqlite: args.database } });
35
27
  return {
36
28
  db,
37
29
  sqlite: args.database,
38
- toBlob,
39
30
  plugin,
40
- close: async () => {
41
- await changeQueueSettled({ lix: { db } });
42
- // args.database.close();
43
- // await db.destroy();
44
- },
45
31
  };
46
32
  }
47
33
  //# sourceMappingURL=open-lix.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"open-lix.js","sourceRoot":"","sources":["../../src/lix/open-lix.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAE,mBAAmB,EAAuB,MAAM,oBAAoB,CAAC;AAC9E,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,eAAe,EAAE,MAAM,sCAAsC,CAAC;AACvE,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAG7E,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAuB1D;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,IAuB7B;IACA,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;IAE7C,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACjD,MAAM,EAAE;aACN,UAAU,CAAC,WAAW,CAAC;aACvB,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;aACtB,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,CAClB,EAAE,CAAC,WAAW,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAC7D;aACA,OAAO,EAAE,CAAC;IACb,CAAC;IAED,MAAM,OAAO,GAAG,MAAM,WAAW,CAAC,EAAE,CAAC,CAAC;IACtC,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3D,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;IACtC,CAAC;IAED,MAAM,MAAM,GAAG;QACd,MAAM,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO;KAC3B,CAAC;IAEF,MAAM,MAAM,GAAG,KAAK,IAAI,EAAE;QACzB,MAAM,kBAAkB,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAC1C,OAAO,IAAI,IAAI,CAAC,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IACvD,CAAC,CAAC;IAEF,eAAe,CAAC;QACf,GAAG,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE;QAC1C,WAAW,EAAE,IAAI,CAAC,QAAQ;KAC1B,CAAC,CAAC;IAEH,eAAe,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;IAEjD,OAAO;QACN,EAAE;QACF,MAAM,EAAE,IAAI,CAAC,QAAQ;QACrB,MAAM;QACN,MAAM;QACN,KAAK,EAAE,KAAK,IAAI,EAAE;YACjB,MAAM,kBAAkB,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;YAC1C,yBAAyB;YACzB,sBAAsB;QACvB,CAAC;KACD,CAAC;AACH,CAAC"}
1
+ {"version":3,"file":"open-lix.js","sourceRoot":"","sources":["../../src/lix/open-lix.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,EAAuB,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qCAAqC,CAAC;AAG3E,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAqB1D;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,OAAO,CAAC,IAuB7B;IACA,MAAM,EAAE,GAAG,MAAM,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;IAE7C,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACjD,MAAM,EAAE;aACN,UAAU,CAAC,WAAW,CAAC;aACvB,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC;aACtB,UAAU,CAAC,CAAC,EAAE,EAAE,EAAE,CAClB,EAAE,CAAC,WAAW,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC,CAC7D;aACA,OAAO,EAAE,CAAC;IACb,CAAC;IAED,MAAM,OAAO,GAAG,MAAM,WAAW,CAAC,EAAE,CAAC,CAAC;IACtC,IAAI,IAAI,CAAC,cAAc,IAAI,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC3D,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,cAAc,CAAC,CAAC;IACtC,CAAC;IAED,MAAM,MAAM,GAAG;QACd,MAAM,EAAE,KAAK,IAAI,EAAE,CAAC,OAAO;KAC3B,CAAC;IAEF,oBAAoB,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAErE,eAAe,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC;IAEhE,OAAO;QACN,EAAE;QACF,MAAM,EAAE,IAAI,CAAC,QAAQ;QACrB,MAAM;KACN,CAAC;AACH,CAAC"}
@@ -1,6 +1,7 @@
1
1
  import { expect, test } from "vitest";
2
2
  import { openLixInMemory } from "./open-lix-in-memory.js";
3
3
  import { newLixFile } from "./new-lix.js";
4
+ import { toBlob } from "./to-blob.js";
4
5
  test("providing plugins should be possible", async () => {
5
6
  const mockPlugin = {
6
7
  key: "mock-plugin",
@@ -14,16 +15,24 @@ test("providing plugins should be possible", async () => {
14
15
  test("providing key values should be possible", async () => {
15
16
  const lix = await openLixInMemory({
16
17
  blob: await newLixFile(),
17
- keyValues: [{ key: "key", value: "value" }],
18
+ keyValues: [{ key: "mock_key", value: "value" }],
18
19
  });
19
- const value = await lix.db.selectFrom("key_value").selectAll().execute();
20
- expect(value).toContainEqual({ key: "key", value: "value" });
20
+ const value = await lix.db
21
+ .selectFrom("key_value")
22
+ .selectAll()
23
+ .where("key", "=", "mock_key")
24
+ .executeTakeFirstOrThrow();
25
+ expect(value).toMatchObject({ key: "mock_key", value: "value" });
21
26
  // testing overwriting key values
22
27
  const lix1 = await openLixInMemory({
23
- blob: await lix.toBlob(),
24
- keyValues: [{ key: "key", value: "value2" }],
28
+ blob: await toBlob({ lix }),
29
+ keyValues: [{ key: "mock_key", value: "value2" }],
25
30
  });
26
- const value1 = await lix1.db.selectFrom("key_value").selectAll().execute();
27
- expect(value1).toContainEqual({ key: "key", value: "value2" });
31
+ const value1 = await lix1.db
32
+ .selectFrom("key_value")
33
+ .selectAll()
34
+ .where("key", "=", "mock_key")
35
+ .executeTakeFirstOrThrow();
36
+ expect(value1).toMatchObject({ key: "mock_key", value: "value2" });
28
37
  });
29
38
  //# sourceMappingURL=open-lix.test.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"open-lix.test.js","sourceRoot":"","sources":["../../src/lix/open-lix.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAG1C,IAAI,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;IACvD,MAAM,UAAU,GAAc;QAC7B,GAAG,EAAE,aAAa;KAClB,CAAC;IACF,MAAM,GAAG,GAAG,MAAM,eAAe,CAAC;QACjC,IAAI,EAAE,MAAM,UAAU,EAAE;QACxB,cAAc,EAAE,CAAC,UAAU,CAAC;KAC5B,CAAC,CAAC;IACH,MAAM,CAAC,MAAM,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;AACzD,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;IAC1D,MAAM,GAAG,GAAG,MAAM,eAAe,CAAC;QACjC,IAAI,EAAE,MAAM,UAAU,EAAE;QACxB,SAAS,EAAE,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;KAC3C,CAAC,CAAC;IACH,MAAM,KAAK,GAAG,MAAM,GAAG,CAAC,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAC;IACzE,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;IAE7D,iCAAiC;IACjC,MAAM,IAAI,GAAG,MAAM,eAAe,CAAC;QAClC,IAAI,EAAE,MAAM,GAAG,CAAC,MAAM,EAAE;QACxB,SAAS,EAAE,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;KAC5C,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAC;IAC3E,MAAM,CAAC,MAAM,CAAC,CAAC,cAAc,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;AAChE,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"open-lix.test.js","sourceRoot":"","sources":["../../src/lix/open-lix.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAEtC,IAAI,CAAC,sCAAsC,EAAE,KAAK,IAAI,EAAE;IACvD,MAAM,UAAU,GAAc;QAC7B,GAAG,EAAE,aAAa;KAClB,CAAC;IACF,MAAM,GAAG,GAAG,MAAM,eAAe,CAAC;QACjC,IAAI,EAAE,MAAM,UAAU,EAAE;QACxB,cAAc,EAAE,CAAC,UAAU,CAAC;KAC5B,CAAC,CAAC;IACH,MAAM,CAAC,MAAM,GAAG,CAAC,MAAM,CAAC,MAAM,EAAE,CAAC,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC;AACzD,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,yCAAyC,EAAE,KAAK,IAAI,EAAE;IAC1D,MAAM,GAAG,GAAG,MAAM,eAAe,CAAC;QACjC,IAAI,EAAE,MAAM,UAAU,EAAE;QACxB,SAAS,EAAE,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC;KAChD,CAAC,CAAC;IAEH,MAAM,KAAK,GAAG,MAAM,GAAG,CAAC,EAAE;SACxB,UAAU,CAAC,WAAW,CAAC;SACvB,SAAS,EAAE;SACX,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,UAAU,CAAC;SAC7B,uBAAuB,EAAE,CAAC;IAE5B,MAAM,CAAC,KAAK,CAAC,CAAC,aAAa,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;IAEjE,iCAAiC;IACjC,MAAM,IAAI,GAAG,MAAM,eAAe,CAAC;QAClC,IAAI,EAAE,MAAM,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC;QAC3B,SAAS,EAAE,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC;KACjD,CAAC,CAAC;IAEH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,EAAE;SAC1B,UAAU,CAAC,WAAW,CAAC;SACvB,SAAS,EAAE;SACX,KAAK,CAAC,KAAK,EAAE,GAAG,EAAE,UAAU,CAAC;SAE7B,uBAAuB,EAAE,CAAC;IAC5B,MAAM,CAAC,MAAM,CAAC,CAAC,aAAa,CAAC,EAAE,GAAG,EAAE,UAAU,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC;AACpE,CAAC,CAAC,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type { Lix } from "./open-lix.js";
2
+ /**
3
+ * Convert the lix to a blob.
4
+ *
5
+ * @example
6
+ * const blob = await toBlob({ lix })
7
+ */
8
+ export declare function toBlob(args: {
9
+ lix: Pick<Lix, "db" | "sqlite">;
10
+ }): Promise<Blob>;
11
+ //# sourceMappingURL=to-blob.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"to-blob.d.ts","sourceRoot":"","sources":["../../src/lix/to-blob.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,eAAe,CAAC;AAEzC;;;;;GAKG;AACH,wBAAsB,MAAM,CAAC,IAAI,EAAE;IAClC,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,QAAQ,CAAC,CAAC;CAChC,GAAG,OAAO,CAAC,IAAI,CAAC,CAEhB"}
@@ -0,0 +1,11 @@
1
+ import { contentFromDatabase } from "sqlite-wasm-kysely";
2
+ /**
3
+ * Convert the lix to a blob.
4
+ *
5
+ * @example
6
+ * const blob = await toBlob({ lix })
7
+ */
8
+ export async function toBlob(args) {
9
+ return new Blob([contentFromDatabase(args.lix.sqlite)]);
10
+ }
11
+ //# sourceMappingURL=to-blob.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"to-blob.js","sourceRoot":"","sources":["../../src/lix/to-blob.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAGzD;;;;;GAKG;AACH,MAAM,CAAC,KAAK,UAAU,MAAM,CAAC,IAE5B;IACA,OAAO,IAAI,IAAI,CAAC,CAAC,mBAAmB,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;AACzD,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type { Change } from "../database/schema.js";
2
+ import type { Lix } from "../lix/open-lix.js";
3
+ /**
4
+ * Applies own changes to lix itself.
5
+ */
6
+ export declare function applyOwnChanges(args: {
7
+ lix: Pick<Lix, "db">;
8
+ changes: Change[];
9
+ }): Promise<void>;
10
+ //# sourceMappingURL=apply-own-change.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apply-own-change.d.ts","sourceRoot":"","sources":["../../src/own-change-control/apply-own-change.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,MAAM,EAAqB,MAAM,uBAAuB,CAAC;AACvE,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAO9C;;GAEG;AACH,wBAAsB,eAAe,CAAC,IAAI,EAAE;IAC3C,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACrB,OAAO,EAAE,MAAM,EAAE,CAAC;CAClB,GAAG,OAAO,CAAC,IAAI,CAAC,CAwFhB"}
@@ -0,0 +1,69 @@
1
+ import { CompiledQuery, } from "kysely";
2
+ import { changeControlledTableIds, primaryKeysForEntityId, } from "./change-controlled-tables.js";
3
+ import { withSkipOwnChangeControl } from "./with-skip-own-change-control.js";
4
+ /**
5
+ * Applies own changes to lix itself.
6
+ */
7
+ export async function applyOwnChanges(args) {
8
+ const executeInTransaction = async (trx) => {
9
+ await withSkipOwnChangeControl(trx, async (trx) => {
10
+ // defer foreign keys to avoid constraint violations
11
+ // until the end of the transaction. otherwise, we would
12
+ // need to apply the changes in the correct order.
13
+ await trx.executeQuery(CompiledQuery.raw("PRAGMA defer_foreign_keys = ON;"));
14
+ await Promise.all(args.changes.map(async (change) => {
15
+ if (change.plugin_key !== "lix_own_change_control") {
16
+ throw new Error("Expected 'lix_own_change_control' as plugin key but received " +
17
+ change.plugin_key);
18
+ }
19
+ const snapshot = await trx
20
+ .selectFrom("snapshot")
21
+ .where("id", "=", change.snapshot_id)
22
+ .select("content")
23
+ .executeTakeFirstOrThrow();
24
+ // remove the prefix and suffix from the schema key
25
+ // `lix_key_value_table` -> `key_value`
26
+ const tableName = change.schema_key
27
+ .replace(/^lix_/, "")
28
+ .replace(/_table$/, "");
29
+ const primaryKeys = primaryKeysForEntityId(tableName, change.entity_id);
30
+ let query;
31
+ // deletion
32
+ if (snapshot.content === null) {
33
+ query = trx.deleteFrom(tableName);
34
+ for (const [key, value] of primaryKeys) {
35
+ query = query.where(key, "=", value);
36
+ }
37
+ }
38
+ // upsert
39
+ else {
40
+ // take the current file data if the table is `file`
41
+ // (can be optimized later to adjust the query instead)
42
+ if (tableName === "file") {
43
+ const data = await trx
44
+ .selectFrom("file")
45
+ .where("id", "=", change.entity_id)
46
+ .select("data")
47
+ .executeTakeFirst();
48
+ snapshot.content.data =
49
+ data?.data ??
50
+ // empty uint8array will trigger applyChanges() to pass an empty file to the plugin
51
+ new Uint8Array();
52
+ }
53
+ query = trx
54
+ .insertInto(tableName)
55
+ .values(snapshot.content)
56
+ .onConflict((oc) => oc.doUpdateSet(snapshot.content));
57
+ }
58
+ await query.execute();
59
+ }));
60
+ });
61
+ };
62
+ if (args.lix.db.isTransaction) {
63
+ return await executeInTransaction(args.lix.db);
64
+ }
65
+ else {
66
+ return await args.lix.db.transaction().execute(executeInTransaction);
67
+ }
68
+ }
69
+ //# sourceMappingURL=apply-own-change.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apply-own-change.js","sourceRoot":"","sources":["../../src/own-change-control/apply-own-change.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=apply-own-change.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apply-own-change.test.d.ts","sourceRoot":"","sources":["../../src/own-change-control/apply-own-change.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,297 @@
1
+ import { test, expect } from "vitest";
2
+ import { openLixInMemory } from "../lix/open-lix-in-memory.js";
3
+ import { applyOwnChanges } from "./apply-own-change.js";
4
+ import { mockJsonSnapshot } from "../snapshot/mock-json-snapshot.js";
5
+ import {} from "../key-value/database-schema.js";
6
+ test("it should apply insert changes correctly", async () => {
7
+ const lix = await openLixInMemory({});
8
+ const snapshot = mockJsonSnapshot({
9
+ key: "key1",
10
+ value: "value1",
11
+ });
12
+ const change = {
13
+ id: "change1",
14
+ entity_id: "key1",
15
+ schema_key: "lix_key_value_table",
16
+ plugin_key: "lix_own_change_control",
17
+ file_id: "lix_own_change_control",
18
+ snapshot_id: snapshot.id,
19
+ created_at: "2021-01-01T00:00:00.000Z",
20
+ };
21
+ await lix.db
22
+ .insertInto("snapshot")
23
+ .values({ content: snapshot.content })
24
+ .execute();
25
+ await applyOwnChanges({ lix, changes: [change] });
26
+ const result = await lix.db
27
+ .selectFrom("key_value")
28
+ .where("key", "=", "key1")
29
+ .selectAll()
30
+ .executeTakeFirst();
31
+ expect(result).toMatchObject({ key: "key1", value: "value1" });
32
+ });
33
+ test("it should apply update changes correctly", async () => {
34
+ const lix = await openLixInMemory({});
35
+ await lix.db
36
+ .insertInto("key_value")
37
+ .values({ key: "key1", value: "old_value" })
38
+ .execute();
39
+ const snapshot = mockJsonSnapshot({
40
+ key: "key1",
41
+ value: "new_value",
42
+ });
43
+ const change = {
44
+ id: "change1",
45
+ schema_key: "lix_key_value_table",
46
+ entity_id: "key1",
47
+ file_id: "lix_own_change_control",
48
+ created_at: "2021-01-01T00:00:00.000Z",
49
+ plugin_key: "lix_own_change_control",
50
+ snapshot_id: snapshot.id,
51
+ };
52
+ await lix.db
53
+ .insertInto("snapshot")
54
+ .values({
55
+ content: snapshot.content,
56
+ })
57
+ .execute();
58
+ await applyOwnChanges({ lix, changes: [change] });
59
+ const result = await lix.db
60
+ .selectFrom("key_value")
61
+ .where("key", "=", "key1")
62
+ .selectAll()
63
+ .executeTakeFirst();
64
+ expect(result).toMatchObject({ key: "key1", value: "new_value" });
65
+ });
66
+ test("it should apply delete changes correctly", async () => {
67
+ const lix = await openLixInMemory({});
68
+ await lix.db
69
+ .insertInto("key_value")
70
+ .values({ key: "key1", value: "value1" })
71
+ .execute();
72
+ const change = {
73
+ id: "change1",
74
+ schema_key: "lix_key_value_table",
75
+ file_id: "lix_own_change_control",
76
+ created_at: "2021-01-01T00:00:00.000Z",
77
+ entity_id: "key1",
78
+ plugin_key: "lix_own_change_control",
79
+ snapshot_id: "no-content",
80
+ };
81
+ await applyOwnChanges({ lix, changes: [change] });
82
+ const result = await lix.db
83
+ .selectFrom("key_value")
84
+ .where("key", "=", "key1")
85
+ .selectAll()
86
+ .executeTakeFirst();
87
+ expect(result).toBeUndefined();
88
+ });
89
+ test("it should throw an error for invalid plugin key", async () => {
90
+ const lix = await openLixInMemory({});
91
+ const change = {
92
+ id: "change1",
93
+ schema_key: "lix_key_value_table",
94
+ entity_id: "key1",
95
+ file_id: "lix_own_change_control",
96
+ created_at: "2021-01-01T00:00:00.000Z",
97
+ plugin_key: "invalid-plugin",
98
+ snapshot_id: "snapshot1",
99
+ };
100
+ const snapshot = mockJsonSnapshot({
101
+ key: "key1",
102
+ value: "value1",
103
+ });
104
+ await lix.db
105
+ .insertInto("snapshot")
106
+ .values({
107
+ content: snapshot.content,
108
+ })
109
+ .execute();
110
+ await expect(applyOwnChanges({ lix, changes: [change] })).rejects.toThrow("Expected 'lix_own_change_control' as plugin key but received invalid-plugin");
111
+ });
112
+ test("file.data is not changed by applyOwnEntityChanges", async () => {
113
+ const lix = await openLixInMemory({});
114
+ const file = await lix.db
115
+ .insertInto("file")
116
+ .values({
117
+ path: "/test.txt",
118
+ data: new TextEncoder().encode("hello"),
119
+ metadata: {
120
+ foo: "bar",
121
+ },
122
+ })
123
+ .returningAll()
124
+ .executeTakeFirstOrThrow();
125
+ const change = await lix.db
126
+ .selectFrom("change")
127
+ .innerJoin("snapshot", "snapshot.id", "change.snapshot_id")
128
+ .where("schema_key", "=", "lix_file_table")
129
+ .where("entity_id", "=", file.id)
130
+ .selectAll()
131
+ .executeTakeFirst();
132
+ expect(change).toBeDefined();
133
+ expect(change?.content?.metadata).toEqual({ foo: "bar" });
134
+ const snapshot = await lix.db
135
+ .insertInto("snapshot")
136
+ .values({
137
+ content: {
138
+ id: file.id,
139
+ path: "/test.txt",
140
+ metadata: {
141
+ foo: "baz",
142
+ },
143
+ },
144
+ })
145
+ .returningAll()
146
+ .executeTakeFirstOrThrow();
147
+ const mockChange = {
148
+ id: "change1",
149
+ entity_id: file.id,
150
+ schema_key: "lix_file_table",
151
+ plugin_key: "lix_own_change_control",
152
+ file_id: "null",
153
+ snapshot_id: snapshot.id,
154
+ created_at: "2021-01-01T00:00:00.000Z",
155
+ };
156
+ await applyOwnChanges({ lix, changes: [mockChange] });
157
+ const result = await lix.db
158
+ .selectFrom("file")
159
+ .where("id", "=", file.id)
160
+ .selectAll()
161
+ .executeTakeFirst();
162
+ expect(result).toEqual({
163
+ id: file.id,
164
+ data: new TextEncoder().encode("hello"),
165
+ path: "/test.txt",
166
+ metadata: { foo: "baz" },
167
+ });
168
+ });
169
+ test("foreign key constraints are deferred to make the order of applying changes irrelevant", async () => {
170
+ const lix = await openLixInMemory({});
171
+ const snapshots = [
172
+ mockJsonSnapshot({
173
+ id: "change-set-1",
174
+ }),
175
+ mockJsonSnapshot({
176
+ change_id: "change0",
177
+ change_set_id: "change-set-1",
178
+ }),
179
+ ];
180
+ const mockChanges = [
181
+ // applying changes in reverse order
182
+ {
183
+ id: "change2",
184
+ entity_id: "change-set-1,change0",
185
+ schema_key: "lix_change_set_element_table",
186
+ plugin_key: "lix_own_change_control",
187
+ file_id: "null",
188
+ snapshot_id: snapshots[1].id,
189
+ created_at: "2021-01-01T00:00:00.000Z",
190
+ },
191
+ {
192
+ id: "change1",
193
+ entity_id: "change-set-1",
194
+ schema_key: "lix_change_set_table",
195
+ plugin_key: "lix_own_change_control",
196
+ file_id: "null",
197
+ snapshot_id: snapshots[0].id,
198
+ created_at: "2021-01-01T00:00:00.000Z",
199
+ },
200
+ ];
201
+ for (const snapshot of snapshots) {
202
+ // @ts-expect-error - 'cannot' insert into generated column error
203
+ delete snapshot.id;
204
+ }
205
+ await lix.db
206
+ .insertInto("snapshot")
207
+ .values(snapshots.map((s) => ({ content: s.content })))
208
+ .execute();
209
+ // insert change that the change set element references
210
+ await lix.db
211
+ .insertInto("change")
212
+ .values({
213
+ id: "change0",
214
+ plugin_key: "mock",
215
+ file_id: "null",
216
+ entity_id: "mock",
217
+ schema_key: "mock",
218
+ snapshot_id: "no-content",
219
+ })
220
+ .execute();
221
+ await expect(applyOwnChanges({ lix, changes: mockChanges })).resolves.toBeUndefined();
222
+ });
223
+ test("foreign key constraints are obeyed", async () => {
224
+ const lix = await openLixInMemory({});
225
+ const snapshots = [
226
+ mockJsonSnapshot({
227
+ // both change 0 and the change set are missing
228
+ change_id: "change0",
229
+ change_set_id: "change-set-1",
230
+ }),
231
+ ];
232
+ const mockChanges = [
233
+ {
234
+ id: "change2",
235
+ // the change set for this change does not exist
236
+ entity_id: "change-set-1,change0",
237
+ schema_key: "lix_change_set_element_table",
238
+ plugin_key: "lix_own_change_control",
239
+ file_id: "lix_own_change_control",
240
+ snapshot_id: snapshots[0].id,
241
+ created_at: "2021-01-01T00:00:00.000Z",
242
+ },
243
+ ];
244
+ for (const snapshot of snapshots) {
245
+ // @ts-expect-error - 'cannot' insert into generated column error
246
+ delete snapshot.id;
247
+ }
248
+ await lix.db
249
+ .insertInto("snapshot")
250
+ .values(snapshots.map((s) => ({ content: s.content })))
251
+ .execute();
252
+ // insert change that the change set element references
253
+ await lix.db
254
+ .insertInto("change")
255
+ .values({
256
+ id: "change0",
257
+ plugin_key: "mock",
258
+ file_id: "null",
259
+ entity_id: "mock",
260
+ schema_key: "mock",
261
+ snapshot_id: "no-content",
262
+ })
263
+ .execute();
264
+ expect(applyOwnChanges({ lix, changes: mockChanges })).rejects.toThrow();
265
+ });
266
+ // https://github.com/opral/lix-sdk/issues/185
267
+ test("applying own entity changes doesn't lead to the creation of new changes", async () => {
268
+ const lix = await openLixInMemory({});
269
+ const snapshot = mockJsonSnapshot({
270
+ key: "mock-key",
271
+ value: "1+1=2",
272
+ });
273
+ await lix.db
274
+ .insertInto("snapshot")
275
+ .values({
276
+ content: snapshot.content,
277
+ })
278
+ .execute();
279
+ const changesBefore = await lix.db.selectFrom("change").selectAll().execute();
280
+ await applyOwnChanges({
281
+ lix,
282
+ changes: [
283
+ {
284
+ id: "change0",
285
+ entity_id: "mock-key",
286
+ file_id: "null",
287
+ plugin_key: "lix_own_change_control",
288
+ schema_key: "lix_key_value_table",
289
+ snapshot_id: snapshot.id,
290
+ created_at: "2021-01-01T00:00:00Z",
291
+ },
292
+ ],
293
+ });
294
+ const changesAfter = await lix.db.selectFrom("change").selectAll().execute();
295
+ expect(changesBefore).toEqual(changesAfter);
296
+ });
297
+ //# sourceMappingURL=apply-own-change.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apply-own-change.test.js","sourceRoot":"","sources":["../../src/own-change-control/apply-own-change.test.ts"],"names":[],"mappings":"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"}