@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 +1 @@
1
- {"version":3,"file":"create-discussion.d.ts","sourceRoot":"","sources":["../../src/discussion/create-discussion.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAC;AAC7D,OAAO,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAE9C;;;;;;;;;;GAUG;AACH,wBAAsB,gBAAgB,CAAC,IAAI,EAAE;IAC5C,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACrB,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACjC,OAAO,EAAE,OAAO,CAAC,SAAS,CAAC,CAAC;IAC5B,SAAS,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC;CAC/B,GAAG,OAAO,CAAC,UAAU,GAAG;IAAE,OAAO,EAAE,OAAO,CAAA;CAAE,CAAC,CA8B7C"}
1
+ {"version":3,"file":"create-discussion.d.ts","sourceRoot":"","sources":["../../src/discussion/create-discussion.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAE9C;;;;;;;;;;GAUG;AACH,wBAAsB,gBAAgB,CAAC,IAAI,EAAE;IAC5C,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;IACrB,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACjC,YAAY,EAAE,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;CACvC,GAAG,OAAO,CAAC,UAAU,GAAG;IAAE,YAAY,EAAE,OAAO,CAAA;CAAE,CAAC,CA6BlD"}
@@ -4,7 +4,7 @@
4
4
  * @example
5
5
  * ```ts
6
6
  * const changeSet = await createChangeSet({ lix, changes: ["change1", "change2"] });
7
- * const discussion = await createDiscussion({ lix, changeSet, body: "first comment" });
7
+ * const discussion = await createDiscussion({ lix, changeSet, firstComment: { content: "first comment" } });
8
8
  * ```
9
9
  *
10
10
  * @returns the created discussion
@@ -18,17 +18,16 @@ export async function createDiscussion(args) {
18
18
  })
19
19
  .returningAll()
20
20
  .executeTakeFirstOrThrow();
21
- const comment = await trx
21
+ const firstComment = await trx
22
22
  .insertInto("comment")
23
23
  .values({
24
24
  parent_id: null,
25
25
  discussion_id: discussion.id,
26
- content: args.content,
27
- created_by: args.createdBy.id,
26
+ content: args.firstComment.content,
28
27
  })
29
28
  .returningAll()
30
29
  .executeTakeFirstOrThrow();
31
- return { ...discussion, comment };
30
+ return { ...discussion, firstComment };
32
31
  };
33
32
  // user provided an open transaction
34
33
  if (args.lix.db.isTransaction) {
@@ -1 +1 @@
1
- {"version":3,"file":"create-discussion.js","sourceRoot":"","sources":["../../src/discussion/create-discussion.ts"],"names":[],"mappings":"AAIA;;;;;;;;;;GAUG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,IAKtC;IACA,MAAM,oBAAoB,GAAG,KAAK,EAAE,GAAc,EAAE,EAAE;QACrD,MAAM,UAAU,GAAG,MAAM,GAAG;aAC1B,UAAU,CAAC,YAAY,CAAC;aACxB,MAAM,CAAC;YACP,aAAa,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;SAChC,CAAC;aACD,YAAY,EAAE;aACd,uBAAuB,EAAE,CAAC;QAE5B,MAAM,OAAO,GAAG,MAAM,GAAG;aACvB,UAAU,CAAC,SAAS,CAAC;aACrB,MAAM,CAAC;YACP,SAAS,EAAE,IAAI;YACf,aAAa,EAAE,UAAU,CAAC,EAAE;YAC5B,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;SAC7B,CAAC;aACD,YAAY,EAAE;aACd,uBAAuB,EAAE,CAAC;QAE5B,OAAO,EAAE,GAAG,UAAU,EAAE,OAAO,EAAE,CAAC;IACnC,CAAC,CAAC;IAEF,oCAAoC;IACpC,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC/B,OAAO,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAC1C,CAAC;SAAM,CAAC;QACP,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;IAChE,CAAC;AACF,CAAC"}
1
+ {"version":3,"file":"create-discussion.js","sourceRoot":"","sources":["../../src/discussion/create-discussion.ts"],"names":[],"mappings":"AAGA;;;;;;;;;;GAUG;AACH,MAAM,CAAC,KAAK,UAAU,gBAAgB,CAAC,IAItC;IACA,MAAM,oBAAoB,GAAG,KAAK,EAAE,GAAc,EAAE,EAAE;QACrD,MAAM,UAAU,GAAG,MAAM,GAAG;aAC1B,UAAU,CAAC,YAAY,CAAC;aACxB,MAAM,CAAC;YACP,aAAa,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE;SAChC,CAAC;aACD,YAAY,EAAE;aACd,uBAAuB,EAAE,CAAC;QAE5B,MAAM,YAAY,GAAG,MAAM,GAAG;aAC5B,UAAU,CAAC,SAAS,CAAC;aACrB,MAAM,CAAC;YACP,SAAS,EAAE,IAAI;YACf,aAAa,EAAE,UAAU,CAAC,EAAE;YAC5B,OAAO,EAAE,IAAI,CAAC,YAAY,CAAC,OAAO;SAClC,CAAC;aACD,YAAY,EAAE;aACd,uBAAuB,EAAE,CAAC;QAE5B,OAAO,EAAE,GAAG,UAAU,EAAE,YAAY,EAAE,CAAC;IACxC,CAAC,CAAC;IAEF,oCAAoC;IACpC,IAAI,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,aAAa,EAAE,CAAC;QAC/B,OAAO,oBAAoB,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAC1C,CAAC;SAAM,CAAC;QACP,OAAO,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,oBAAoB,CAAC,CAAC;IAChE,CAAC;AACF,CAAC"}
@@ -1,42 +1,17 @@
1
1
  import { expect, test } from "vitest";
2
2
  import { openLixInMemory } from "../lix/open-lix-in-memory.js";
3
- import { newLixFile } from "../lix/new-lix.js";
4
3
  import { createDiscussion } from "./create-discussion.js";
5
4
  import { createChangeSet } from "../change-set/create-change-set.js";
6
- import { changeQueueSettled } from "../change-queue/change-queue-settled.js";
7
- const mockPlugin = {
8
- key: "mock-plugin",
9
- detectChangesGlob: "*",
10
- detectChanges: async ({ after }) => {
11
- return [
12
- {
13
- schema: {
14
- key: "text",
15
- type: "json",
16
- },
17
- entity_id: "test",
18
- snapshot: {
19
- text: after ? new TextDecoder().decode(after.data) : undefined,
20
- },
21
- },
22
- ];
23
- },
24
- };
25
5
  test("should be able to start a discussion on changes", async () => {
26
- const lix = await openLixInMemory({
27
- blob: await newLixFile(),
28
- providePlugins: [mockPlugin],
29
- });
30
- const enc = new TextEncoder();
6
+ const lix = await openLixInMemory({});
7
+ // produce a change
31
8
  await lix.db
32
- .insertInto("file")
33
- .values({ id: "test", path: "/test.txt", data: enc.encode("test") })
9
+ .insertInto("key_value")
10
+ .values({
11
+ key: "mock_key",
12
+ value: "mock_value",
13
+ })
34
14
  .execute();
35
- await changeQueueSettled({ lix });
36
- const current_author = await lix.db
37
- .selectFrom("active_account")
38
- .selectAll()
39
- .executeTakeFirstOrThrow();
40
15
  const changes = await lix.db
41
16
  .selectFrom("change")
42
17
  .selectAll("change")
@@ -44,9 +19,8 @@ test("should be able to start a discussion on changes", async () => {
44
19
  await lix.db.transaction().execute(async (trx) => {
45
20
  await createDiscussion({
46
21
  lix: { db: trx },
22
+ firstComment: { content: "Hello, world!" },
47
23
  changeSet: await createChangeSet({ lix: { db: trx }, changes }),
48
- content: "comment on a change",
49
- createdBy: { id: current_author.id },
50
24
  });
51
25
  });
52
26
  const discussions = await lix.db
@@ -1 +1 @@
1
- {"version":3,"file":"create-discussion.test.js","sourceRoot":"","sources":["../../src/discussion/create-discussion.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AACrE,OAAO,EAAE,kBAAkB,EAAE,MAAM,yCAAyC,CAAC;AAE7E,MAAM,UAAU,GAAc;IAC7B,GAAG,EAAE,aAAa;IAClB,iBAAiB,EAAE,GAAG;IACtB,aAAa,EAAE,KAAK,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE;QAClC,OAAO;YACN;gBACC,MAAM,EAAE;oBACP,GAAG,EAAE,MAAM;oBACX,IAAI,EAAE,MAAM;iBACZ;gBACD,SAAS,EAAE,MAAM;gBACjB,QAAQ,EAAE;oBACT,IAAI,EAAE,KAAK,CAAC,CAAC,CAAC,IAAI,WAAW,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,SAAS;iBAC9D;aACwB;SAC1B,CAAC;IACH,CAAC;CACD,CAAC;AAEF,IAAI,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;IAClE,MAAM,GAAG,GAAG,MAAM,eAAe,CAAC;QACjC,IAAI,EAAE,MAAM,UAAU,EAAE;QACxB,cAAc,EAAE,CAAC,UAAU,CAAC;KAC5B,CAAC,CAAC;IAEH,MAAM,GAAG,GAAG,IAAI,WAAW,EAAE,CAAC;IAE9B,MAAM,GAAG,CAAC,EAAE;SACV,UAAU,CAAC,MAAM,CAAC;SAClB,MAAM,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,WAAW,EAAE,IAAI,EAAE,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC;SACnE,OAAO,EAAE,CAAC;IAEZ,MAAM,kBAAkB,CAAC,EAAE,GAAG,EAAE,CAAC,CAAC;IAElC,MAAM,cAAc,GAAG,MAAM,GAAG,CAAC,EAAE;SACjC,UAAU,CAAC,gBAAgB,CAAC;SAC5B,SAAS,EAAE;SACX,uBAAuB,EAAE,CAAC;IAE5B,MAAM,OAAO,GAAG,MAAM,GAAG,CAAC,EAAE;SAC1B,UAAU,CAAC,QAAQ,CAAC;SACpB,SAAS,CAAC,QAAQ,CAAC;SACnB,OAAO,EAAE,CAAC;IAEZ,MAAM,GAAG,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QAChD,MAAM,gBAAgB,CAAC;YACtB,GAAG,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE;YAChB,SAAS,EAAE,MAAM,eAAe,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,CAAC;YAC/D,OAAO,EAAE,qBAAqB;YAC9B,SAAS,EAAE,EAAE,EAAE,EAAE,cAAc,CAAC,EAAE,EAAE;SACpC,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,EAAE;SAC9B,UAAU,CAAC,YAAY,CAAC;SACxB,SAAS,EAAE;SACX,OAAO,EAAE,CAAC;IAEZ,MAAM,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAEpC,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,EAAE;SAC3B,UAAU,CAAC,SAAS,CAAC;SACrB,SAAS,EAAE;SACX,KAAK,CAAC,eAAe,EAAE,GAAG,EAAE,WAAW,CAAC,CAAC,CAAE,CAAC,EAAE,CAAC;SAC/C,OAAO,EAAE,CAAC;IAEZ,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;AAClC,CAAC,CAAC,CAAC"}
1
+ {"version":3,"file":"create-discussion.test.js","sourceRoot":"","sources":["../../src/discussion/create-discussion.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAC1D,OAAO,EAAE,eAAe,EAAE,MAAM,oCAAoC,CAAC;AAErE,IAAI,CAAC,iDAAiD,EAAE,KAAK,IAAI,EAAE;IAClE,MAAM,GAAG,GAAG,MAAM,eAAe,CAAC,EAAE,CAAC,CAAC;IAEtC,mBAAmB;IACnB,MAAM,GAAG,CAAC,EAAE;SACV,UAAU,CAAC,WAAW,CAAC;SACvB,MAAM,CAAC;QACP,GAAG,EAAE,UAAU;QACf,KAAK,EAAE,YAAY;KACnB,CAAC;SACD,OAAO,EAAE,CAAC;IAEZ,MAAM,OAAO,GAAG,MAAM,GAAG,CAAC,EAAE;SAC1B,UAAU,CAAC,QAAQ,CAAC;SACpB,SAAS,CAAC,QAAQ,CAAC;SACnB,OAAO,EAAE,CAAC;IAEZ,MAAM,GAAG,CAAC,EAAE,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QAChD,MAAM,gBAAgB,CAAC;YACtB,GAAG,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE;YAChB,YAAY,EAAE,EAAE,OAAO,EAAE,eAAe,EAAE;YAC1C,SAAS,EAAE,MAAM,eAAe,CAAC,EAAE,GAAG,EAAE,EAAE,EAAE,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,CAAC;SAC/D,CAAC,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,MAAM,WAAW,GAAG,MAAM,GAAG,CAAC,EAAE;SAC9B,UAAU,CAAC,YAAY,CAAC;SACxB,SAAS,EAAE;SACX,OAAO,EAAE,CAAC;IAEZ,MAAM,CAAC,WAAW,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAEpC,MAAM,QAAQ,GAAG,MAAM,GAAG,CAAC,EAAE;SAC3B,UAAU,CAAC,SAAS,CAAC;SACrB,SAAS,EAAE;SACX,KAAK,CAAC,eAAe,EAAE,GAAG,EAAE,WAAW,CAAC,CAAC,CAAE,CAAC,EAAE,CAAC;SAC/C,OAAO,EAAE,CAAC;IAEZ,MAAM,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;AAClC,CAAC,CAAC,CAAC"}
@@ -0,0 +1,24 @@
1
+ import type { FileQueueEntry } from "../database/schema.js";
2
+ import type { Lix } from "../lix/open-lix.js";
3
+ export declare function handleFileInsert(args: {
4
+ lix: Pick<Lix, "db" | "plugin" | "sqlite">;
5
+ fileQueueEntry: FileQueueEntry;
6
+ }): Promise<void>;
7
+ export declare function handleFileUpdate(args: {
8
+ lix: Pick<Lix, "db" | "plugin" | "sqlite">;
9
+ fileQueueEntry: FileQueueEntry;
10
+ }): Promise<void>;
11
+ /**
12
+ * File deletions don't need to invoke a plugin to detect changes.
13
+ *
14
+ * Instead, we can simply query the database for all changes that are related to the file
15
+ * and create the corresponding deletion changes for the current version.
16
+ *
17
+ * - simpler plugin API (because deletions don't need to be accounted for)
18
+ * - faster file deletion (because we don't need to invoke plugins)
19
+ */
20
+ export declare function handleFileDelete(args: {
21
+ lix: Pick<Lix, "db" | "plugin" | "sqlite">;
22
+ fileQueueEntry: FileQueueEntry;
23
+ }): Promise<void>;
24
+ //# sourceMappingURL=file-handlers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-handlers.d.ts","sourceRoot":"","sources":["../../src/file-queue/file-handlers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAE5D,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AA6B9C,wBAAsB,gBAAgB,CAAC,IAAI,EAAE;IAC5C,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,QAAQ,GAAG,QAAQ,CAAC,CAAC;IAC3C,cAAc,EAAE,cAAc,CAAC;CAC/B,GAAG,OAAO,CAAC,IAAI,CAAC,CAwFhB;AAED,wBAAsB,gBAAgB,CAAC,IAAI,EAAE;IAC5C,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,QAAQ,GAAG,QAAQ,CAAC,CAAC;IAC3C,cAAc,EAAE,cAAc,CAAC;CAC/B,GAAG,OAAO,CAAC,IAAI,CAAC,CAyFhB;AAED;;;;;;;;GAQG;AACH,wBAAsB,gBAAgB,CAAC,IAAI,EAAE;IAC5C,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,QAAQ,GAAG,QAAQ,CAAC,CAAC;IAC3C,cAAc,EAAE,cAAc,CAAC;CAC/B,GAAG,OAAO,CAAC,IAAI,CAAC,CA0ChB"}
@@ -0,0 +1,209 @@
1
+ import { sql } from "kysely";
2
+ import { createChange } from "../change/create-change.js";
3
+ import { changeIsLeafInVersion } from "../query-filter/change-is-leaf-in-version.js";
4
+ // start a new normalize path function that has the absolute minimum implementation.
5
+ function normalizePath(path) {
6
+ if (!path.startsWith("/")) {
7
+ return "/" + path;
8
+ }
9
+ return path;
10
+ }
11
+ async function glob(args) {
12
+ const result = await sql `SELECT CASE WHEN ${args.path} GLOB ${args.glob} THEN 1 ELSE 0 END AS matches`.execute(args.lix.db);
13
+ // Extract the result from the response
14
+ return result.rows[0]?.matches === 1;
15
+ }
16
+ // creates initial changes for new files
17
+ export async function handleFileInsert(args) {
18
+ const detectedChanges = [];
19
+ const plugins = await args.lix.plugin.getAll();
20
+ // the path of the file is either the after path or the before path
21
+ // depending on whether the file was deleted, updated, or created
22
+ const path = args.fileQueueEntry.path_after ?? args.fileQueueEntry.path_before;
23
+ if (path === null) {
24
+ throw new Error("Both before and after paths are null");
25
+ }
26
+ for (const plugin of plugins) {
27
+ // glob expressions are expressed relative without leading / but path has leading /
28
+ if (!(await glob({
29
+ lix: args.lix,
30
+ path: normalizePath(path),
31
+ glob: "/" + plugin.detectChangesGlob,
32
+ }))) {
33
+ break;
34
+ }
35
+ if (plugin.detectChanges === undefined) {
36
+ const error = new Error("Plugin does not support detecting changes even though the glob matches.");
37
+ // https://linear.app/opral/issue/LIXDK-195/await-change-queue-to-log-errors
38
+ console.error(error);
39
+ throw error;
40
+ }
41
+ if (args.fileQueueEntry.data_after === null) {
42
+ throw new Error("Data after is null");
43
+ }
44
+ for (const change of await plugin.detectChanges({
45
+ lix: args.lix,
46
+ before: undefined,
47
+ after: {
48
+ id: args.fileQueueEntry.file_id,
49
+ path,
50
+ metadata: args.fileQueueEntry.metadata_after,
51
+ data: args.fileQueueEntry.data_after,
52
+ },
53
+ })) {
54
+ detectedChanges.push({
55
+ ...change,
56
+ pluginKey: plugin.key,
57
+ });
58
+ }
59
+ }
60
+ await args.lix.db.transaction().execute(async (trx) => {
61
+ const currentAuthors = await trx
62
+ .selectFrom("active_account")
63
+ .selectAll()
64
+ .execute();
65
+ const currentVersion = await trx
66
+ .selectFrom("current_version")
67
+ .innerJoin("version", "current_version.id", "version.id")
68
+ .selectAll()
69
+ .executeTakeFirstOrThrow();
70
+ await Promise.all(detectedChanges.map(async (detectedChange) => {
71
+ await createChange({
72
+ lix: { ...args.lix, db: trx },
73
+ authors: currentAuthors,
74
+ version: currentVersion,
75
+ entityId: detectedChange.entity_id,
76
+ fileId: args.fileQueueEntry.file_id,
77
+ pluginKey: detectedChange.pluginKey,
78
+ schemaKey: detectedChange.schema.key,
79
+ snapshotContent: detectedChange.snapshot,
80
+ });
81
+ }));
82
+ await trx
83
+ .deleteFrom("file_queue")
84
+ .where("id", "=", args.fileQueueEntry.id)
85
+ .execute();
86
+ });
87
+ }
88
+ export async function handleFileUpdate(args) {
89
+ const detectedChanges = [];
90
+ const plugins = await args.lix.plugin.getAll();
91
+ // the path of the file is either the after path or the before path
92
+ // depending on whether the file was deleted, updated, or created
93
+ const path = args.fileQueueEntry.path_after ?? args.fileQueueEntry.path_before;
94
+ if (path === null) {
95
+ throw new Error("Both before and after paths are null");
96
+ }
97
+ for (const plugin of plugins) {
98
+ // glob expressions are expressed relative without leading / but path has leading /
99
+ if (!(await glob({
100
+ lix: args.lix,
101
+ path: normalizePath(path),
102
+ glob: "/" + plugin.detectChangesGlob,
103
+ }))) {
104
+ break;
105
+ }
106
+ if (plugin.detectChanges === undefined) {
107
+ const error = new Error("Plugin does not support detecting changes even though the glob matches.");
108
+ // https://linear.app/opral/issue/LIXDK-195/await-change-queue-to-log-errors
109
+ console.error(error);
110
+ throw error;
111
+ }
112
+ for (const change of await plugin.detectChanges({
113
+ lix: args.lix,
114
+ before: args.fileQueueEntry.data_before
115
+ ? {
116
+ id: args.fileQueueEntry.file_id,
117
+ path: path,
118
+ metadata: args.fileQueueEntry.metadata_before,
119
+ data: args.fileQueueEntry.data_before,
120
+ }
121
+ : undefined,
122
+ after: {
123
+ id: args.fileQueueEntry.file_id,
124
+ path,
125
+ metadata: args.fileQueueEntry.metadata_after,
126
+ data: args.fileQueueEntry.data_after,
127
+ },
128
+ })) {
129
+ detectedChanges.push({
130
+ ...change,
131
+ pluginKey: plugin.key,
132
+ });
133
+ }
134
+ }
135
+ await args.lix.db.transaction().execute(async (trx) => {
136
+ const currentAuthors = await trx
137
+ .selectFrom("active_account")
138
+ .selectAll()
139
+ .execute();
140
+ const currentVersion = await trx
141
+ .selectFrom("current_version")
142
+ .innerJoin("version", "current_version.id", "version.id")
143
+ .selectAll()
144
+ .executeTakeFirstOrThrow();
145
+ await Promise.all(detectedChanges.map(async (detectedChange) => {
146
+ await createChange({
147
+ lix: { ...args.lix, db: trx },
148
+ authors: currentAuthors,
149
+ version: currentVersion,
150
+ entityId: detectedChange.entity_id,
151
+ fileId: args.fileQueueEntry.file_id,
152
+ pluginKey: detectedChange.pluginKey,
153
+ schemaKey: detectedChange.schema.key,
154
+ snapshotContent: detectedChange.snapshot,
155
+ });
156
+ }));
157
+ await trx
158
+ .deleteFrom("file_queue")
159
+ .where("id", "=", args.fileQueueEntry.id)
160
+ .execute();
161
+ });
162
+ }
163
+ /**
164
+ * File deletions don't need to invoke a plugin to detect changes.
165
+ *
166
+ * Instead, we can simply query the database for all changes that are related to the file
167
+ * and create the corresponding deletion changes for the current version.
168
+ *
169
+ * - simpler plugin API (because deletions don't need to be accounted for)
170
+ * - faster file deletion (because we don't need to invoke plugins)
171
+ */
172
+ export async function handleFileDelete(args) {
173
+ await args.lix.db.transaction().execute(async (trx) => {
174
+ const currentVersion = await trx
175
+ .selectFrom("current_version")
176
+ .innerJoin("version", "current_version.id", "version.id")
177
+ .selectAll()
178
+ .executeTakeFirstOrThrow();
179
+ const toBeDeletedEntities = await trx
180
+ .selectFrom("change")
181
+ .where("file_id", "=", args.fileQueueEntry.file_id)
182
+ .where(changeIsLeafInVersion(currentVersion))
183
+ .select("entity_id")
184
+ .select("schema_key")
185
+ .select("plugin_key")
186
+ .execute();
187
+ const currentAuthors = await trx
188
+ .selectFrom("active_account")
189
+ .selectAll()
190
+ .execute();
191
+ await Promise.all(toBeDeletedEntities.map(async (change) => {
192
+ await createChange({
193
+ lix: { ...args.lix, db: trx },
194
+ authors: currentAuthors,
195
+ version: currentVersion,
196
+ entityId: change.entity_id,
197
+ fileId: args.fileQueueEntry.file_id,
198
+ pluginKey: change.plugin_key,
199
+ schemaKey: change.schema_key,
200
+ snapshotContent: null, // Snapshot is null for deletions
201
+ });
202
+ }));
203
+ await trx
204
+ .deleteFrom("file_queue")
205
+ .where("id", "=", args.fileQueueEntry.id)
206
+ .execute();
207
+ });
208
+ }
209
+ //# sourceMappingURL=file-handlers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-handlers.js","sourceRoot":"","sources":["../../src/file-queue/file-handlers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import type { Lix } from "../lix/open-lix.js";
2
+ export declare function initFileQueueProcess(args: {
3
+ lix: Pick<Lix, "db" | "plugin" | "sqlite">;
4
+ }): Promise<void>;
5
+ //# sourceMappingURL=file-queue-process.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-queue-process.d.ts","sourceRoot":"","sources":["../../src/file-queue/file-queue-process.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,oBAAoB,CAAC;AAE9C,wBAAsB,oBAAoB,CAAC,IAAI,EAAE;IAChD,GAAG,EAAE,IAAI,CAAC,GAAG,EAAE,IAAI,GAAG,QAAQ,GAAG,QAAQ,CAAC,CAAC;CAC3C,GAAG,OAAO,CAAC,IAAI,CAAC,CA2FhB"}
@@ -0,0 +1,85 @@
1
+ import { handleFileUpdate, handleFileInsert, handleFileDelete, } from "./file-handlers.js";
2
+ export async function initFileQueueProcess(args) {
3
+ args.lix.sqlite.createFunction({
4
+ name: "triggerFileQueue",
5
+ arity: 0,
6
+ // @ts-expect-error - dynamic function
7
+ xFunc: () => {
8
+ // TODO: abort current running queue?
9
+ queueWorker();
10
+ },
11
+ });
12
+ let pending;
13
+ let resolve;
14
+ // run number counts the worker runs in a current batch and is used to prevent race conditions where a trigger is missed because a previous run is just about to reset the hasMoreEntriesSince flag
15
+ let runNumber = 1;
16
+ // If a queue trigger happens during an existing queue run we might miss updates and use hasMoreEntriesSince to make sure there is always a final immediate queue worker execution
17
+ let hasMoreEntriesSince = undefined;
18
+ async function queueWorker(trail = false) {
19
+ if (args.lix.sqlite.isOpen() === false) {
20
+ console.log("sqlite is closed");
21
+ return;
22
+ }
23
+ try {
24
+ if (pending && !trail) {
25
+ hasMoreEntriesSince = runNumber;
26
+ return;
27
+ }
28
+ runNumber++;
29
+ if (!pending) {
30
+ pending = new Promise((res) => {
31
+ resolve = res;
32
+ });
33
+ }
34
+ const entry = await args.lix.db
35
+ .selectFrom("file_queue")
36
+ .selectAll()
37
+ .orderBy("id asc")
38
+ .limit(1)
39
+ .executeTakeFirst();
40
+ if (entry) {
41
+ if (entry.data_before && entry.data_after) {
42
+ await handleFileUpdate({
43
+ fileQueueEntry: entry,
44
+ lix: args.lix,
45
+ });
46
+ }
47
+ else if (!entry.data_before && entry.data_after) {
48
+ await handleFileInsert({
49
+ fileQueueEntry: entry,
50
+ lix: args.lix,
51
+ });
52
+ }
53
+ else {
54
+ await handleFileDelete({
55
+ fileQueueEntry: entry,
56
+ lix: args.lix,
57
+ });
58
+ }
59
+ }
60
+ // console.log("getrting { numEntries }");
61
+ const { numEntries } = await args.lix.db
62
+ .selectFrom("file_queue")
63
+ .select((eb) => eb.fn.count("id").as("numEntries"))
64
+ .executeTakeFirstOrThrow();
65
+ // console.log({ numEntries });
66
+ if (!hasMoreEntriesSince ||
67
+ (numEntries === 0 && hasMoreEntriesSince < runNumber)) {
68
+ resolve();
69
+ hasMoreEntriesSince = undefined;
70
+ pending = undefined;
71
+ // console.log("resolving");
72
+ }
73
+ else {
74
+ // there are more entries to process
75
+ queueWorker(true);
76
+ }
77
+ }
78
+ catch (e) {
79
+ console.error("file queue failed ", e);
80
+ }
81
+ }
82
+ // start a worker in case there are entries
83
+ return queueWorker();
84
+ }
85
+ //# sourceMappingURL=file-queue-process.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-queue-process.js","sourceRoot":"","sources":["../../src/file-queue/file-queue-process.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=file-queue-process.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-queue-process.test.d.ts","sourceRoot":"","sources":["../../src/file-queue/file-queue-process.test.ts"],"names":[],"mappings":""}