@lix-js/sdk 0.0.1 → 0.2.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 (359) hide show
  1. package/LICENSE +21 -0
  2. package/dist/account/database-schema.d.ts.map +1 -1
  3. package/dist/account/database-schema.js +2 -6
  4. package/dist/account/database-schema.js.map +1 -1
  5. package/dist/account/database-schema.test.js +4 -8
  6. package/dist/account/database-schema.test.js.map +1 -1
  7. package/dist/change/apply-changes.js +9 -9
  8. package/dist/change/apply-changes.js.map +1 -1
  9. package/dist/change/apply-changes.test.js +5 -5
  10. package/dist/change/apply-changes.test.js.map +1 -1
  11. package/dist/database/apply-schema.d.ts.map +1 -1
  12. package/dist/database/apply-schema.js +20 -72
  13. package/dist/database/apply-schema.js.map +1 -1
  14. package/dist/database/execute-sync.test.js +3 -3
  15. package/dist/database/execute-sync.test.js.map +1 -1
  16. package/dist/database/init-db.d.ts.map +1 -1
  17. package/dist/database/init-db.js +18 -3
  18. package/dist/database/init-db.js.map +1 -1
  19. package/dist/database/init-db.test.js +128 -17
  20. package/dist/database/init-db.test.js.map +1 -1
  21. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.d.ts.map +1 -1
  22. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js +5 -2
  23. package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js.map +1 -1
  24. package/dist/database/mutation-log/database-schema.d.ts.map +1 -1
  25. package/dist/database/mutation-log/database-schema.js +1 -3
  26. package/dist/database/mutation-log/database-schema.js.map +1 -1
  27. package/dist/database/nano-id.d.ts +21 -0
  28. package/dist/database/nano-id.d.ts.map +1 -0
  29. package/dist/database/nano-id.js +58 -0
  30. package/dist/database/nano-id.js.map +1 -0
  31. package/dist/database/nano-id.test.d.ts +2 -0
  32. package/dist/database/nano-id.test.d.ts.map +1 -0
  33. package/dist/database/nano-id.test.js +13 -0
  34. package/dist/database/nano-id.test.js.map +1 -0
  35. package/dist/database/schema.d.ts +15 -23
  36. package/dist/database/schema.d.ts.map +1 -1
  37. package/dist/discussion/create-comment.d.ts +0 -2
  38. package/dist/discussion/create-comment.d.ts.map +1 -1
  39. package/dist/discussion/create-comment.js +0 -1
  40. package/dist/discussion/create-comment.js.map +1 -1
  41. package/dist/discussion/create-discussion.d.ts +3 -5
  42. package/dist/discussion/create-discussion.d.ts.map +1 -1
  43. package/dist/discussion/create-discussion.js +4 -5
  44. package/dist/discussion/create-discussion.js.map +1 -1
  45. package/dist/discussion/create-discussion.test.js +8 -34
  46. package/dist/discussion/create-discussion.test.js.map +1 -1
  47. package/dist/file-queue/file-handlers.d.ts +24 -0
  48. package/dist/file-queue/file-handlers.d.ts.map +1 -0
  49. package/dist/file-queue/file-handlers.js +209 -0
  50. package/dist/file-queue/file-handlers.js.map +1 -0
  51. package/dist/file-queue/file-queue-process.d.ts +5 -0
  52. package/dist/file-queue/file-queue-process.d.ts.map +1 -0
  53. package/dist/file-queue/file-queue-process.js +88 -0
  54. package/dist/file-queue/file-queue-process.js.map +1 -0
  55. package/dist/file-queue/file-queue-process.test.d.ts +2 -0
  56. package/dist/file-queue/file-queue-process.test.d.ts.map +1 -0
  57. package/dist/file-queue/file-queue-process.test.js +372 -0
  58. package/dist/file-queue/file-queue-process.test.js.map +1 -0
  59. package/dist/file-queue/file-queue-settled.d.ts +13 -0
  60. package/dist/file-queue/file-queue-settled.d.ts.map +1 -0
  61. package/dist/file-queue/file-queue-settled.js +25 -0
  62. package/dist/file-queue/file-queue-settled.js.map +1 -0
  63. package/dist/file-queue/file-queue-settled.test.d.ts +2 -0
  64. package/dist/file-queue/file-queue-settled.test.d.ts.map +1 -0
  65. package/dist/file-queue/file-queue-settled.test.js +47 -0
  66. package/dist/file-queue/file-queue-settled.test.js.map +1 -0
  67. package/dist/file-queue/index.d.ts +2 -0
  68. package/dist/file-queue/index.d.ts.map +1 -0
  69. package/dist/file-queue/index.js +2 -0
  70. package/dist/file-queue/index.js.map +1 -0
  71. package/dist/file-queue/with-skip-file-queue.d.ts +3 -0
  72. package/dist/file-queue/with-skip-file-queue.d.ts.map +1 -0
  73. package/dist/file-queue/with-skip-file-queue.js +26 -0
  74. package/dist/file-queue/with-skip-file-queue.js.map +1 -0
  75. package/dist/file-queue/with-skip-file-queue.test.d.ts +2 -0
  76. package/dist/file-queue/with-skip-file-queue.test.d.ts.map +1 -0
  77. package/dist/file-queue/with-skip-file-queue.test.js +138 -0
  78. package/dist/file-queue/with-skip-file-queue.test.js.map +1 -0
  79. package/dist/index.d.ts +2 -2
  80. package/dist/index.d.ts.map +1 -1
  81. package/dist/index.js +2 -2
  82. package/dist/index.js.map +1 -1
  83. package/dist/key-value/database-schema.d.ts +11 -2
  84. package/dist/key-value/database-schema.d.ts.map +1 -1
  85. package/dist/key-value/database-schema.js +7 -4
  86. package/dist/key-value/database-schema.js.map +1 -1
  87. package/dist/key-value/database-schema.test.js +21 -5
  88. package/dist/key-value/database-schema.test.js.map +1 -1
  89. package/dist/lix/close-lix.d.ts +8 -0
  90. package/dist/lix/close-lix.d.ts.map +1 -0
  91. package/dist/lix/close-lix.js +7 -0
  92. package/dist/lix/close-lix.js.map +1 -0
  93. package/dist/lix/index.d.ts +1 -0
  94. package/dist/lix/index.d.ts.map +1 -1
  95. package/dist/lix/index.js +1 -0
  96. package/dist/lix/index.js.map +1 -1
  97. package/dist/lix/merge.js +3 -3
  98. package/dist/lix/merge.js.map +1 -1
  99. package/dist/lix/merge.test.js +7 -18
  100. package/dist/lix/merge.test.js.map +1 -1
  101. package/dist/lix/new-lix.d.ts.map +1 -1
  102. package/dist/lix/new-lix.js +2 -3
  103. package/dist/lix/new-lix.js.map +1 -1
  104. package/dist/lix/open-lix-in-memory.test.js +2 -1
  105. package/dist/lix/open-lix-in-memory.test.js.map +1 -1
  106. package/dist/lix/open-lix.d.ts +19 -6
  107. package/dist/lix/open-lix.d.ts.map +1 -1
  108. package/dist/lix/open-lix.js +80 -18
  109. package/dist/lix/open-lix.js.map +1 -1
  110. package/dist/lix/open-lix.test.js +70 -7
  111. package/dist/lix/open-lix.test.js.map +1 -1
  112. package/dist/lix/to-blob.d.ts +11 -0
  113. package/dist/lix/to-blob.d.ts.map +1 -0
  114. package/dist/lix/to-blob.js +11 -0
  115. package/dist/lix/to-blob.js.map +1 -0
  116. package/dist/own-change-control/apply-own-change.d.ts +10 -0
  117. package/dist/own-change-control/apply-own-change.d.ts.map +1 -0
  118. package/dist/own-change-control/apply-own-change.js +69 -0
  119. package/dist/own-change-control/apply-own-change.js.map +1 -0
  120. package/dist/own-change-control/apply-own-change.test.d.ts +2 -0
  121. package/dist/own-change-control/apply-own-change.test.d.ts.map +1 -0
  122. package/dist/own-change-control/apply-own-change.test.js +297 -0
  123. package/dist/own-change-control/apply-own-change.test.js.map +1 -0
  124. package/dist/own-change-control/change-controlled-tables.d.ts +60 -0
  125. package/dist/own-change-control/change-controlled-tables.d.ts.map +1 -0
  126. package/dist/own-change-control/change-controlled-tables.js +70 -0
  127. package/dist/own-change-control/change-controlled-tables.js.map +1 -0
  128. package/dist/own-change-control/change-controlled-tables.test.d.ts +2 -0
  129. package/dist/own-change-control/change-controlled-tables.test.d.ts.map +1 -0
  130. package/dist/own-change-control/change-controlled-tables.test.js +48 -0
  131. package/dist/own-change-control/change-controlled-tables.test.js.map +1 -0
  132. package/dist/own-change-control/database-triggers.d.ts +5 -0
  133. package/dist/own-change-control/database-triggers.d.ts.map +1 -0
  134. package/dist/own-change-control/database-triggers.js +135 -0
  135. package/dist/own-change-control/database-triggers.js.map +1 -0
  136. package/dist/own-change-control/database-triggers.test.d.ts +2 -0
  137. package/dist/own-change-control/database-triggers.test.d.ts.map +1 -0
  138. package/dist/own-change-control/database-triggers.test.js +214 -0
  139. package/dist/own-change-control/database-triggers.test.js.map +1 -0
  140. package/dist/own-change-control/index.d.ts +2 -0
  141. package/dist/own-change-control/index.d.ts.map +1 -0
  142. package/dist/own-change-control/index.js +2 -0
  143. package/dist/own-change-control/index.js.map +1 -0
  144. package/dist/own-change-control/with-skip-own-change-control.d.ts +3 -0
  145. package/dist/own-change-control/with-skip-own-change-control.d.ts.map +1 -0
  146. package/dist/own-change-control/with-skip-own-change-control.js +28 -0
  147. package/dist/own-change-control/with-skip-own-change-control.js.map +1 -0
  148. package/dist/own-change-control/with-skip-own-change-control.test.d.ts +2 -0
  149. package/dist/own-change-control/with-skip-own-change-control.test.d.ts.map +1 -0
  150. package/dist/own-change-control/with-skip-own-change-control.test.js +49 -0
  151. package/dist/own-change-control/with-skip-own-change-control.test.js.map +1 -0
  152. package/dist/own-entity-change-control/apply-own-entity-change.js +2 -2
  153. package/dist/own-entity-change-control/apply-own-entity-change.js.map +1 -1
  154. package/dist/own-entity-change-control/apply-own-entity-change.test.js +9 -9
  155. package/dist/own-entity-change-control/apply-own-entity-change.test.js.map +1 -1
  156. package/dist/own-entity-change-control/database-triggers.js +6 -6
  157. package/dist/own-entity-change-control/database-triggers.js.map +1 -1
  158. package/dist/own-entity-change-control/database-triggers.test.js +1 -1
  159. package/dist/own-entity-change-control/database-triggers.test.js.map +1 -1
  160. package/dist/query-filter/version-change-in-difference.test.js +37 -29
  161. package/dist/query-filter/version-change-in-difference.test.js.map +1 -1
  162. package/dist/query-filter/version-change-in-symmetric-difference.test.js +37 -39
  163. package/dist/query-filter/version-change-in-symmetric-difference.test.js.map +1 -1
  164. package/dist/server-api-handler/environment/create-in-memory-environment.d.ts.map +1 -1
  165. package/dist/server-api-handler/environment/create-in-memory-environment.js +7 -3
  166. package/dist/server-api-handler/environment/create-in-memory-environment.js.map +1 -1
  167. package/dist/server-api-handler/environment/create-in-memory-environment.test.js +8 -7
  168. package/dist/server-api-handler/environment/create-in-memory-environment.test.js.map +1 -1
  169. package/dist/server-api-handler/routes/get-v1.d.ts.map +1 -1
  170. package/dist/server-api-handler/routes/get-v1.js +1 -2
  171. package/dist/server-api-handler/routes/get-v1.js.map +1 -1
  172. package/dist/server-api-handler/routes/get-v1.test.js +6 -5
  173. package/dist/server-api-handler/routes/get-v1.test.js.map +1 -1
  174. package/dist/server-api-handler/routes/new-v1.d.ts.map +1 -1
  175. package/dist/server-api-handler/routes/new-v1.js +3 -1
  176. package/dist/server-api-handler/routes/new-v1.js.map +1 -1
  177. package/dist/server-api-handler/routes/new-v1.test.js +2 -1
  178. package/dist/server-api-handler/routes/new-v1.test.js.map +1 -1
  179. package/dist/server-api-handler/routes/pull-v1.test.js +4 -3
  180. package/dist/server-api-handler/routes/pull-v1.test.js.map +1 -1
  181. package/dist/server-api-handler/routes/push-v1.test.js +5 -4
  182. package/dist/server-api-handler/routes/push-v1.test.js.map +1 -1
  183. package/dist/services/env-variables/index.d.ts +5 -0
  184. package/dist/services/env-variables/index.d.ts.map +1 -0
  185. package/dist/services/env-variables/index.js +5 -0
  186. package/dist/services/env-variables/index.js.map +1 -0
  187. package/dist/services/telemetry/capture.d.ts +30 -0
  188. package/dist/services/telemetry/capture.d.ts.map +1 -0
  189. package/dist/services/telemetry/capture.js +71 -0
  190. package/dist/services/telemetry/capture.js.map +1 -0
  191. package/dist/services/telemetry/capture.test.d.ts +2 -0
  192. package/dist/services/telemetry/capture.test.d.ts.map +1 -0
  193. package/dist/services/telemetry/capture.test.js +37 -0
  194. package/dist/services/telemetry/capture.test.js.map +1 -0
  195. package/dist/sync/pull-from-server.d.ts.map +1 -1
  196. package/dist/sync/pull-from-server.js +0 -2
  197. package/dist/sync/pull-from-server.js.map +1 -1
  198. package/dist/sync/pull-from-server.test.js +29 -14
  199. package/dist/sync/pull-from-server.test.js.map +1 -1
  200. package/dist/sync/push-to-server.test.js +17 -13
  201. package/dist/sync/push-to-server.test.js.map +1 -1
  202. package/dist/sync/sync-process.d.ts +2 -4
  203. package/dist/sync/sync-process.d.ts.map +1 -1
  204. package/dist/sync/sync-process.js +14 -13
  205. package/dist/sync/sync-process.js.map +1 -1
  206. package/dist/sync/sync-process.test.js +26 -38
  207. package/dist/sync/sync-process.test.js.map +1 -1
  208. package/dist/version/create-version.d.ts +5 -5
  209. package/dist/version/create-version.d.ts.map +1 -1
  210. package/dist/version/create-version.js +23 -11
  211. package/dist/version/create-version.js.map +1 -1
  212. package/dist/version/create-version.test.js +2 -2
  213. package/dist/version/create-version.test.js.map +1 -1
  214. package/dist/version/merge-version.d.ts.map +1 -1
  215. package/dist/version/merge-version.js +16 -26
  216. package/dist/version/merge-version.js.map +1 -1
  217. package/dist/version/switch-version.js +3 -3
  218. package/dist/version/switch-version.js.map +1 -1
  219. package/dist/version/switch-version.test.js +12 -15
  220. package/dist/version/switch-version.test.js.map +1 -1
  221. package/dist/version/update-changes-in-version.d.ts.map +1 -1
  222. package/dist/version/update-changes-in-version.js +11 -31
  223. package/dist/version/update-changes-in-version.js.map +1 -1
  224. package/package.json +7 -9
  225. package/src/account/database-schema.test.ts +6 -9
  226. package/src/account/database-schema.ts +2 -6
  227. package/src/change/apply-changes.test.ts +7 -7
  228. package/src/change/apply-changes.ts +9 -9
  229. package/src/database/apply-schema.ts +20 -73
  230. package/src/database/execute-sync.test.ts +3 -3
  231. package/src/database/init-db.test.ts +163 -19
  232. package/src/database/init-db.ts +20 -3
  233. package/src/database/kysely-plugin/parse-jsonb-plugin-v1.ts +9 -2
  234. package/src/database/mutation-log/database-schema.ts +1 -3
  235. package/src/database/nano-id.test.ts +15 -0
  236. package/src/database/nano-id.ts +72 -0
  237. package/src/database/schema.ts +15 -24
  238. package/src/discussion/create-comment.ts +0 -3
  239. package/src/discussion/create-discussion.test.ts +8 -39
  240. package/src/discussion/create-discussion.ts +6 -9
  241. package/src/{change-queue → file-queue}/file-handlers.ts +27 -27
  242. package/src/{change-queue/init-change-queue.test.ts → file-queue/file-queue-process.test.ts} +28 -29
  243. package/src/{change-queue/init-change-queue.ts → file-queue/file-queue-process.ts} +21 -16
  244. package/src/{change-queue/change-queue-settled.test.ts → file-queue/file-queue-settled.test.ts} +12 -12
  245. package/src/{change-queue/change-queue-settled.ts → file-queue/file-queue-settled.ts} +4 -4
  246. package/src/file-queue/index.ts +1 -0
  247. package/src/{change-queue/with-skip-change-queue.test.ts → file-queue/with-skip-file-queue.test.ts} +9 -9
  248. package/src/{change-queue/with-skip-change-queue.ts → file-queue/with-skip-file-queue.ts} +3 -3
  249. package/src/index.ts +2 -2
  250. package/src/key-value/database-schema.test.ts +26 -5
  251. package/src/key-value/database-schema.ts +18 -6
  252. package/src/lix/close-lix.ts +8 -0
  253. package/src/lix/index.ts +1 -0
  254. package/src/lix/merge.test.ts +7 -19
  255. package/src/lix/merge.ts +4 -4
  256. package/src/lix/new-lix.ts +2 -3
  257. package/src/lix/open-lix-in-memory.test.ts +5 -1
  258. package/src/lix/open-lix.test.ts +82 -7
  259. package/src/lix/open-lix.ts +104 -24
  260. package/src/lix/to-blob.ts +14 -0
  261. package/src/{own-entity-change-control/apply-own-entity-change.test.ts → own-change-control/apply-own-change.test.ts} +27 -31
  262. package/src/{own-entity-change-control/apply-own-entity-change.ts → own-change-control/apply-own-change.ts} +3 -3
  263. package/src/{own-entity-change-control → own-change-control}/change-controlled-tables.ts +0 -1
  264. package/src/{own-entity-change-control → own-change-control}/database-triggers.test.ts +7 -7
  265. package/src/{own-entity-change-control → own-change-control}/database-triggers.ts +11 -11
  266. package/src/{own-entity-change-control → own-change-control}/with-skip-own-change-control.ts +6 -2
  267. package/src/query-filter/version-change-in-difference.test.ts +41 -32
  268. package/src/query-filter/version-change-in-symmetric-difference.test.ts +41 -42
  269. package/src/server-api-handler/environment/create-in-memory-environment.test.ts +8 -7
  270. package/src/server-api-handler/environment/create-in-memory-environment.ts +7 -3
  271. package/src/server-api-handler/routes/get-v1.test.ts +6 -5
  272. package/src/server-api-handler/routes/get-v1.ts +1 -3
  273. package/src/server-api-handler/routes/new-v1.test.ts +2 -1
  274. package/src/server-api-handler/routes/new-v1.ts +3 -1
  275. package/src/server-api-handler/routes/pull-v1.test.ts +4 -3
  276. package/src/server-api-handler/routes/push-v1.test.ts +5 -4
  277. package/src/services/env-variables/create-index-file.js +35 -0
  278. package/src/services/env-variables/index.d.ts +15 -0
  279. package/src/services/telemetry/capture.test.ts +44 -0
  280. package/src/services/telemetry/capture.ts +99 -0
  281. package/src/sync/pull-from-server.test.ts +29 -14
  282. package/src/sync/pull-from-server.ts +0 -2
  283. package/src/sync/push-to-server.test.ts +19 -15
  284. package/src/sync/sync-process.test.ts +37 -43
  285. package/src/sync/sync-process.ts +16 -23
  286. package/src/version/create-version.test.ts +2 -2
  287. package/src/version/create-version.ts +24 -12
  288. package/src/version/merge-version.ts +18 -26
  289. package/src/version/switch-version.test.ts +12 -15
  290. package/src/version/switch-version.ts +3 -3
  291. package/src/version/update-changes-in-version.ts +11 -30
  292. package/node_modules/@lix-js/server-api-schema/.prettierrc.json +0 -3
  293. package/node_modules/@lix-js/server-api-schema/.vscode/extensions.json +0 -3
  294. package/node_modules/@lix-js/server-api-schema/dist/schema.d.ts +0 -384
  295. package/node_modules/@lix-js/server-api-schema/package.json +0 -21
  296. package/node_modules/@lix-js/server-api-schema/src/schema.yaml +0 -290
  297. package/node_modules/@lix-js/server-api-schema/tsconfig.json +0 -20
  298. package/node_modules/sqlite-wasm-kysely/README.md +0 -11
  299. package/node_modules/sqlite-wasm-kysely/dist/dialect.d.ts +0 -11
  300. package/node_modules/sqlite-wasm-kysely/dist/dialect.js +0 -13
  301. package/node_modules/sqlite-wasm-kysely/dist/dialect.js.map +0 -1
  302. package/node_modules/sqlite-wasm-kysely/dist/index.d.ts +0 -2
  303. package/node_modules/sqlite-wasm-kysely/dist/index.js +0 -3
  304. package/node_modules/sqlite-wasm-kysely/dist/index.js.map +0 -1
  305. package/node_modules/sqlite-wasm-kysely/dist/kysely/ConnectionMutex.d.ts +0 -5
  306. package/node_modules/sqlite-wasm-kysely/dist/kysely/ConnectionMutex.js +0 -34
  307. package/node_modules/sqlite-wasm-kysely/dist/kysely/ConnectionMutex.js.map +0 -1
  308. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmConnection.d.ts +0 -8
  309. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmConnection.js +0 -57
  310. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmConnection.js.map +0 -1
  311. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmDialectConfig.d.ts +0 -18
  312. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmDialectConfig.js +0 -2
  313. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmDialectConfig.js.map +0 -1
  314. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmDriver.d.ts +0 -13
  315. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmDriver.js +0 -57
  316. package/node_modules/sqlite-wasm-kysely/dist/kysely/SqliteWasmDriver.js.map +0 -1
  317. package/node_modules/sqlite-wasm-kysely/dist/kysely/index.d.ts +0 -4
  318. package/node_modules/sqlite-wasm-kysely/dist/kysely/index.js +0 -4
  319. package/node_modules/sqlite-wasm-kysely/dist/kysely/index.js.map +0 -1
  320. package/node_modules/sqlite-wasm-kysely/dist/kysely/sqliteModule.d.ts +0 -3
  321. package/node_modules/sqlite-wasm-kysely/dist/kysely/sqliteModule.js +0 -5
  322. package/node_modules/sqlite-wasm-kysely/dist/kysely/sqliteModule.js.map +0 -1
  323. package/node_modules/sqlite-wasm-kysely/dist/util/contentFromDatabase.d.ts +0 -9
  324. package/node_modules/sqlite-wasm-kysely/dist/util/contentFromDatabase.js +0 -12
  325. package/node_modules/sqlite-wasm-kysely/dist/util/contentFromDatabase.js.map +0 -1
  326. package/node_modules/sqlite-wasm-kysely/dist/util/createInMemoryDatabase.d.ts +0 -3
  327. package/node_modules/sqlite-wasm-kysely/dist/util/createInMemoryDatabase.js +0 -22
  328. package/node_modules/sqlite-wasm-kysely/dist/util/createInMemoryDatabase.js.map +0 -1
  329. package/node_modules/sqlite-wasm-kysely/dist/util/importDatabase.d.ts +0 -7
  330. package/node_modules/sqlite-wasm-kysely/dist/util/importDatabase.js +0 -15
  331. package/node_modules/sqlite-wasm-kysely/dist/util/importDatabase.js.map +0 -1
  332. package/node_modules/sqlite-wasm-kysely/dist/util/index.d.ts +0 -5
  333. package/node_modules/sqlite-wasm-kysely/dist/util/index.js +0 -5
  334. package/node_modules/sqlite-wasm-kysely/dist/util/index.js.map +0 -1
  335. package/node_modules/sqlite-wasm-kysely/dist/util/loadDatabaseInMemory.d.ts +0 -1
  336. package/node_modules/sqlite-wasm-kysely/dist/util/loadDatabaseInMemory.js +0 -13
  337. package/node_modules/sqlite-wasm-kysely/dist/util/loadDatabaseInMemory.js.map +0 -1
  338. package/node_modules/sqlite-wasm-kysely/dist/util/sqliteWasmBinary.d.ts +0 -7
  339. package/node_modules/sqlite-wasm-kysely/dist/util/sqliteWasmBinary.js +0 -17
  340. package/node_modules/sqlite-wasm-kysely/dist/util/sqliteWasmBinary.js.map +0 -1
  341. package/node_modules/sqlite-wasm-kysely/package.json +0 -34
  342. package/node_modules/sqlite-wasm-kysely/src/dialect.ts +0 -15
  343. package/node_modules/sqlite-wasm-kysely/src/index.ts +0 -2
  344. package/node_modules/sqlite-wasm-kysely/src/kysely/ConnectionMutex.ts +0 -23
  345. package/node_modules/sqlite-wasm-kysely/src/kysely/SqliteWasmConnection.ts +0 -57
  346. package/node_modules/sqlite-wasm-kysely/src/kysely/SqliteWasmDialectConfig.ts +0 -19
  347. package/node_modules/sqlite-wasm-kysely/src/kysely/SqliteWasmDriver.ts +0 -58
  348. package/node_modules/sqlite-wasm-kysely/src/kysely/index.ts +0 -4
  349. package/node_modules/sqlite-wasm-kysely/src/kysely/sqliteModule.ts +0 -7
  350. package/node_modules/sqlite-wasm-kysely/src/util/contentFromDatabase.ts +0 -13
  351. package/node_modules/sqlite-wasm-kysely/src/util/createInMemoryDatabase.ts +0 -30
  352. package/node_modules/sqlite-wasm-kysely/src/util/importDatabase.ts +0 -34
  353. package/node_modules/sqlite-wasm-kysely/src/util/index.ts +0 -5
  354. package/node_modules/sqlite-wasm-kysely/src/util/loadDatabaseInMemory.ts +0 -13
  355. package/node_modules/sqlite-wasm-kysely/src/util/sqliteWasmBinary.ts +0 -20
  356. package/src/change-queue/index.ts +0 -1
  357. /package/src/{own-entity-change-control → own-change-control}/change-controlled-tables.test.ts +0 -0
  358. /package/src/{own-entity-change-control → own-change-control}/index.ts +0 -0
  359. /package/src/{own-entity-change-control → own-change-control}/with-skip-own-change-control.test.ts +0 -0
@@ -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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"}
@@ -0,0 +1,60 @@
1
+ export declare const changeControlledTableIds: {
2
+ readonly account: readonly ["id"];
3
+ readonly comment: readonly ["id"];
4
+ readonly change_set: readonly ["id"];
5
+ readonly change_author: readonly ["change_id", "account_id"];
6
+ readonly change_set_element: readonly ["change_set_id", "change_id"];
7
+ readonly change_set_label: readonly ["label_id", "change_set_id"];
8
+ readonly discussion: readonly ["id"];
9
+ readonly file: readonly ["id"];
10
+ readonly key_value: readonly ["key"];
11
+ readonly version: readonly ["id"];
12
+ readonly version_change: readonly ["version_id", "change_id"];
13
+ };
14
+ /**
15
+ * The result of a PRAGMA table_info call.
16
+ *
17
+ * @example
18
+ * const tableInfo = sqlite.exec({
19
+ * sql: `PRAGMA table_info(change_author);`,
20
+ * returnValue: "resultRows",
21
+ * rowMode: "object",
22
+ * }) as PragmaTableInfo;
23
+ */
24
+ export type PragmaTableInfo = Array<{
25
+ /**
26
+ * The column name
27
+ */
28
+ name: string;
29
+ /**
30
+ * 0 if not a primary key
31
+ * 1 if primary key
32
+ * 2... if part of a multi-column primary key
33
+ */
34
+ pk: number;
35
+ }>;
36
+ /**
37
+ * Returns the entity id for a row in a change controlled table.
38
+ */
39
+ export declare function entityIdForRow(
40
+ /**
41
+ * The name of the table.
42
+ */
43
+ tableName: keyof typeof changeControlledTableIds,
44
+ /**
45
+ * The values of the row.
46
+ */
47
+ ...values: any[]): string;
48
+ /**
49
+ * Returns the primary keys for a row in a change controlled table.
50
+ */
51
+ export declare function primaryKeysForEntityId(
52
+ /**
53
+ * The name of the table.
54
+ */
55
+ tableName: keyof typeof changeControlledTableIds,
56
+ /**
57
+ * The values of the row.
58
+ */
59
+ entitiyId: string): [string, any][];
60
+ //# sourceMappingURL=change-controlled-tables.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"change-controlled-tables.d.ts","sourceRoot":"","sources":["../../src/own-change-control/change-controlled-tables.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,wBAAwB;;;;;;;;;;;;CAY3B,CAAC;AAKX;;;;;;;;;GASG;AACH,MAAM,MAAM,eAAe,GAAG,KAAK,CAAC;IACnC;;OAEG;IACH,IAAI,EAAE,MAAM,CAAC;IACb;;;;OAIG;IACH,EAAE,EAAE,MAAM,CAAC;CACX,CAAC,CAAC;AAEH;;GAEG;AACH,wBAAgB,cAAc;AAC7B;;GAEG;AACH,SAAS,EAAE,MAAM,OAAO,wBAAwB;AAChD;;GAEG;AACH,GAAG,MAAM,EAAE,GAAG,EAAE,GACd,MAAM,CA2BR;AAED;;GAEG;AACH,wBAAgB,sBAAsB;AACrC;;GAEG;AACH,SAAS,EAAE,MAAM,OAAO,wBAAwB;AAChD;;GAEG;AACH,SAAS,EAAE,MAAM,GACf,CAAC,MAAM,EAAE,GAAG,CAAC,EAAE,CAQjB"}
@@ -0,0 +1,70 @@
1
+ export const changeControlledTableIds = {
2
+ account: ["id"],
3
+ comment: ["id"],
4
+ change_set: ["id"],
5
+ change_author: ["change_id", "account_id"],
6
+ change_set_element: ["change_set_id", "change_id"],
7
+ change_set_label: ["label_id", "change_set_id"],
8
+ discussion: ["id"],
9
+ file: ["id"],
10
+ key_value: ["key"],
11
+ version: ["id"],
12
+ version_change: ["version_id", "change_id"],
13
+ };
14
+ /**
15
+ * Returns the entity id for a row in a change controlled table.
16
+ */
17
+ export function entityIdForRow(
18
+ /**
19
+ * The name of the table.
20
+ */
21
+ tableName,
22
+ /**
23
+ * The values of the row.
24
+ */
25
+ ...values) {
26
+ let entityId = "";
27
+ // only has one primary key
28
+ if (changeControlledTableIds[tableName].length === 1) {
29
+ const index = changeControlledTableIds[tableName].indexOf(
30
+ // @ts-expect-error - no clue why
31
+ changeControlledTableIds[tableName][0]);
32
+ entityId = values[index];
33
+ }
34
+ // has compound primary key that are joined with a comma.
35
+ else {
36
+ for (const column of changeControlledTableIds[tableName]) {
37
+ const index = changeControlledTableIds[tableName].indexOf(
38
+ // @ts-expect-error - no clue why
39
+ column);
40
+ if (entityId === "") {
41
+ entityId = values[index];
42
+ }
43
+ else {
44
+ entityId = [entityId, values[index]].join(",");
45
+ }
46
+ }
47
+ }
48
+ return entityId;
49
+ }
50
+ /**
51
+ * Returns the primary keys for a row in a change controlled table.
52
+ */
53
+ export function primaryKeysForEntityId(
54
+ /**
55
+ * The name of the table.
56
+ */
57
+ tableName,
58
+ /**
59
+ * The values of the row.
60
+ */
61
+ entitiyId) {
62
+ const primaryKeys = changeControlledTableIds[tableName];
63
+ if (primaryKeys.length === 1) {
64
+ return [[primaryKeys[0], entitiyId]];
65
+ }
66
+ else {
67
+ return entitiyId.split(",").map((id, index) => [primaryKeys[index], id]);
68
+ }
69
+ }
70
+ //# sourceMappingURL=change-controlled-tables.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"change-controlled-tables.js","sourceRoot":"","sources":["../../src/own-change-control/change-controlled-tables.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,wBAAwB,GAAG;IACvC,OAAO,EAAE,CAAC,IAAI,CAAC;IACf,OAAO,EAAE,CAAC,IAAI,CAAC;IACf,UAAU,EAAE,CAAC,IAAI,CAAC;IAClB,aAAa,EAAE,CAAC,WAAW,EAAE,YAAY,CAAC;IAC1C,kBAAkB,EAAE,CAAC,eAAe,EAAE,WAAW,CAAC;IAClD,gBAAgB,EAAE,CAAC,UAAU,EAAE,eAAe,CAAC;IAC/C,UAAU,EAAE,CAAC,IAAI,CAAC;IAClB,IAAI,EAAE,CAAC,IAAI,CAAC;IACZ,SAAS,EAAE,CAAC,KAAK,CAAC;IAClB,OAAO,EAAE,CAAC,IAAI,CAAC;IACf,cAAc,EAAE,CAAC,YAAY,EAAE,WAAW,CAAC;CAClC,CAAC;AA4BX;;GAEG;AACH,MAAM,UAAU,cAAc;AAC7B;;GAEG;AACH,SAAgD;AAChD;;GAEG;AACH,GAAG,MAAa;IAEhB,IAAI,QAAQ,GAAG,EAAE,CAAC;IAElB,2BAA2B;IAC3B,IAAI,wBAAwB,CAAC,SAAS,CAAE,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACvD,MAAM,KAAK,GAAG,wBAAwB,CAAC,SAAS,CAAE,CAAC,OAAO;QACzD,iCAAiC;QACjC,wBAAwB,CAAC,SAAS,CAAE,CAAC,CAAC,CAAC,CACvC,CAAC;QACF,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;IACD,yDAAyD;SACpD,CAAC;QACL,KAAK,MAAM,MAAM,IAAI,wBAAwB,CAAC,SAAS,CAAE,EAAE,CAAC;YAC3D,MAAM,KAAK,GAAG,wBAAwB,CAAC,SAAS,CAAE,CAAC,OAAO;YACzD,iCAAiC;YACjC,MAAM,CACN,CAAC;YACF,IAAI,QAAQ,KAAK,EAAE,EAAE,CAAC;gBACrB,QAAQ,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;YAC1B,CAAC;iBAAM,CAAC;gBACP,QAAQ,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAChD,CAAC;QACF,CAAC;IACF,CAAC;IAED,OAAO,QAAQ,CAAC;AACjB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,sBAAsB;AACrC;;GAEG;AACH,SAAgD;AAChD;;GAEG;AACH,SAAiB;IAEjB,MAAM,WAAW,GAAG,wBAAwB,CAAC,SAAS,CAAE,CAAC;IAEzD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC9B,OAAO,CAAC,CAAC,WAAW,CAAC,CAAC,CAAE,EAAE,SAAS,CAAC,CAAC,CAAC;IACvC,CAAC;SAAM,CAAC;QACP,OAAO,SAAS,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,WAAW,CAAC,KAAK,CAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IAC3E,CAAC;AACF,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=change-controlled-tables.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"change-controlled-tables.test.d.ts","sourceRoot":"","sources":["../../src/own-change-control/change-controlled-tables.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,48 @@
1
+ import { test, expect } from "vitest";
2
+ import { changeControlledTableIds, entityIdForRow, primaryKeysForEntityId, } from "./change-controlled-tables.js";
3
+ import { loadDatabaseInMemory } from "sqlite-wasm-kysely";
4
+ import { newLixFile } from "../lix/new-lix.js";
5
+ test("roundtrip entity_id test for single primary key", () => {
6
+ const tableName = "key_value";
7
+ const row = ["lix_mock_key", "value1"];
8
+ const entityId = entityIdForRow(tableName, ...row);
9
+ const primaryKeys = primaryKeysForEntityId(tableName, entityId);
10
+ expect(entityId).toBe("lix_mock_key");
11
+ expect(primaryKeys).toEqual([["key", "lix_mock_key"]]);
12
+ });
13
+ test("roundtrip entity_id test for compound primary keys", () => {
14
+ const tableName = "change_author";
15
+ const row = ["294u-2345", "0128-34928"];
16
+ const entityId = entityIdForRow(tableName, ...row);
17
+ const primaryKeys = primaryKeysForEntityId(tableName, entityId);
18
+ expect(entityId).toBe("294u-2345,0128-34928");
19
+ expect(primaryKeys).toEqual([
20
+ ["change_id", "294u-2345"],
21
+ ["account_id", "0128-34928"],
22
+ ]);
23
+ });
24
+ // otherwise the change controlled entity_id will be wrong.
25
+ //* if this tests fails, someone did a db schema change
26
+ //* on the primary key order that should not have been done.
27
+ test("the primary key order matches the order the primary keys in the database schema", async () => {
28
+ const sqlite = await loadDatabaseInMemory(await (await newLixFile()).arrayBuffer());
29
+ const tableInfos = {};
30
+ for (const table of Object.keys(changeControlledTableIds)) {
31
+ tableInfos[table] = sqlite.exec({
32
+ sql: `PRAGMA table_info(${table});`,
33
+ returnValue: "resultRows",
34
+ rowMode: "object",
35
+ });
36
+ }
37
+ for (const table of Object.keys(changeControlledTableIds)) {
38
+ const tableInfo = tableInfos[table];
39
+ const primaryKeys = tableInfo
40
+ .filter((column) => column.pk)
41
+ .sort((a, b) => a.pk - b.pk)
42
+ .map((c) => c.name);
43
+ expect(primaryKeys).toEqual(
44
+ // @ts-expect-error - some type narrowing problem. not important
45
+ changeControlledTableIds[table]);
46
+ }
47
+ });
48
+ //# sourceMappingURL=change-controlled-tables.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"change-controlled-tables.test.js","sourceRoot":"","sources":["../../src/own-change-control/change-controlled-tables.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EACN,wBAAwB,EACxB,cAAc,EACd,sBAAsB,GAEtB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAC;AAE/C,IAAI,CAAC,iDAAiD,EAAE,GAAG,EAAE;IAC5D,MAAM,SAAS,GAA4B,WAAW,CAAC;IACvD,MAAM,GAAG,GAAG,CAAC,cAAc,EAAE,QAAQ,CAAC,CAAC;IAEvC,MAAM,QAAQ,GAAG,cAAc,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,CAAC;IACnD,MAAM,WAAW,GAAG,sBAAsB,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;IAEhE,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACtC,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,CAAC;AACxD,CAAC,CAAC,CAAC;AAEH,IAAI,CAAC,oDAAoD,EAAE,GAAG,EAAE;IAC/D,MAAM,SAAS,GAA4B,eAAe,CAAC;IAE3D,MAAM,GAAG,GAAG,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;IAExC,MAAM,QAAQ,GAAG,cAAc,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,CAAC;IACnD,MAAM,WAAW,GAAG,sBAAsB,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;IAEhE,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,sBAAsB,CAAC,CAAC;IAC9C,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC;QAC3B,CAAC,WAAW,EAAE,WAAW,CAAC;QAC1B,CAAC,YAAY,EAAE,YAAY,CAAC;KAC5B,CAAC,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,2DAA2D;AAC3D,uDAAuD;AACvD,4DAA4D;AAC5D,IAAI,CAAC,iFAAiF,EAAE,KAAK,IAAI,EAAE;IAClG,MAAM,MAAM,GAAG,MAAM,oBAAoB,CACxC,MAAM,CAAC,MAAM,UAAU,EAAE,CAAC,CAAC,WAAW,EAAE,CACxC,CAAC;IAEF,MAAM,UAAU,GAAoC,EAAE,CAAC;IAEvD,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,EAAE,CAAC;QAC3D,UAAU,CAAC,KAAK,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC;YAC/B,GAAG,EAAE,qBAAqB,KAAK,IAAI;YACnC,WAAW,EAAE,YAAY;YACzB,OAAO,EAAE,QAAQ;SACjB,CAAoB,CAAC;IACvB,CAAC;IAED,KAAK,MAAM,KAAK,IAAI,MAAM,CAAC,IAAI,CAAC,wBAAwB,CAAC,EAAE,CAAC;QAC3D,MAAM,SAAS,GAAG,UAAU,CAAC,KAAK,CAAE,CAAC;QAErC,MAAM,WAAW,GAAG,SAAS;aAC3B,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC;aAC7B,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,EAAE,CAAC;aAC3B,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAErB,MAAM,CAAC,WAAW,CAAC,CAAC,OAAO;QAC1B,gEAAgE;QAChE,wBAAwB,CAAC,KAAK,CAAC,CAC/B,CAAC;IACH,CAAC;AACF,CAAC,CAAC,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { SqliteDatabase } from "sqlite-wasm-kysely";
2
+ import type { LixDatabaseSchema } from "../database/schema.js";
3
+ import type { Kysely } from "kysely";
4
+ export declare function applyOwnChangeControlTriggers(sqlite: SqliteDatabase, db: Kysely<LixDatabaseSchema>): void;
5
+ //# sourceMappingURL=database-triggers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"database-triggers.d.ts","sourceRoot":"","sources":["../../src/own-change-control/database-triggers.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,KAAK,EAAE,iBAAiB,EAAY,MAAM,uBAAuB,CAAC;AACzE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AASrC,wBAAgB,6BAA6B,CAC5C,MAAM,EAAE,cAAc,EACtB,EAAE,EAAE,MAAM,CAAC,iBAAiB,CAAC,GAC3B,IAAI,CAqEN"}
@@ -0,0 +1,135 @@
1
+ import { changeControlledTableIds, entityIdForRow, } from "./change-controlled-tables.js";
2
+ import { createChange } from "../change/create-change.js";
3
+ import { executeSync } from "../database/execute-sync.js";
4
+ export function applyOwnChangeControlTriggers(sqlite, db) {
5
+ const tableInfos = {};
6
+ for (const table of Object.keys(changeControlledTableIds)) {
7
+ tableInfos[table] = sqlite.exec({
8
+ sql: `PRAGMA table_info(${table});`,
9
+ returnValue: "resultRows",
10
+ rowMode: "object",
11
+ });
12
+ }
13
+ sqlite.createFunction({
14
+ name: "handle_lix_own_change_control",
15
+ arity: -1,
16
+ // @ts-expect-error - dynamic function
17
+ xFunc: (_ctx, tableName, operation, ...value) => {
18
+ return handleLixOwnEntityChange(db, sqlite, tableName, tableInfos, operation, ...value);
19
+ },
20
+ });
21
+ for (const table of Object.keys(changeControlledTableIds)) {
22
+ const tableInfo = tableInfos[table];
23
+ const sql = `
24
+ CREATE TEMP TRIGGER IF NOT EXISTS ${table}_change_control_insert
25
+ AFTER INSERT ON ${table}
26
+ BEGIN
27
+ SELECT handle_lix_own_change_control('${table}', 'insert', ${tableInfo.map((c) => "NEW." + c.name).join(", ")});
28
+ END;
29
+
30
+ CREATE TEMP TRIGGER IF NOT EXISTS ${table}_change_control_update
31
+ AFTER UPDATE ON ${table}
32
+ ${
33
+ // ignore update trigger if the change controlled properties
34
+ // did not change (a plugin likely called apply changes on the file.data)
35
+ table === "file"
36
+ ? `
37
+ WHEN (
38
+ OLD.id IS NOT NEW.id OR
39
+ OLD.path IS NOT NEW.path OR
40
+ OLD.metadata IS NOT NEW.metadata
41
+ )`
42
+ : ""}
43
+ BEGIN
44
+ SELECT handle_lix_own_change_control('${table}', 'update', ${tableInfo.map((c) => "NEW." + c.name).join(", ")});
45
+ END;
46
+
47
+ CREATE TEMP TRIGGER IF NOT EXISTS ${table}_change_control_delete
48
+ AFTER DELETE ON ${table}
49
+ BEGIN
50
+ SELECT handle_lix_own_change_control('${table}', 'delete', ${tableInfo.map((c) => "OLD." + c.name).join(", ")});
51
+ END;
52
+ `;
53
+ sqlite.exec(sql);
54
+ }
55
+ }
56
+ function handleLixOwnEntityChange(db, sqlite, tableName, tableInfos, operation, ...values) {
57
+ const lix = { db, sqlite };
58
+ // key values that have skip_change_control set to true should not be change controlled
59
+ if (tableName === "key_value" && values[2]) {
60
+ return;
61
+ }
62
+ const shouldSkip = executeSync({
63
+ lix,
64
+ query: db
65
+ .selectFrom("key_value")
66
+ .where("key", "=", "lix_skip_own_change_control")
67
+ .select("value"),
68
+ })[0]?.value === "true";
69
+ if (shouldSkip) {
70
+ return;
71
+ }
72
+ // need to break the loop if own changes are detected
73
+ const change = executeSync({
74
+ lix,
75
+ query: db
76
+ .selectFrom("change")
77
+ .where("id", "=", values[0])
78
+ .select("plugin_key"),
79
+ })[0];
80
+ if (change?.plugin_key === "lix_own_change_control") {
81
+ return;
82
+ }
83
+ const currentVersion = executeSync({
84
+ lix,
85
+ query: db
86
+ .selectFrom("current_version")
87
+ .innerJoin("version", "current_version.id", "version.id")
88
+ .selectAll("version"),
89
+ })[0];
90
+ const authors = executeSync({
91
+ lix,
92
+ query: db.selectFrom("active_account").selectAll(),
93
+ });
94
+ if (authors.length === 0) {
95
+ console.error(tableName, change);
96
+ throw new Error("At least one author is required");
97
+ }
98
+ let snapshotContent;
99
+ if (operation === "delete") {
100
+ snapshotContent = null;
101
+ }
102
+ else {
103
+ snapshotContent = {};
104
+ // construct the values as json for the snapshot
105
+ for (const [index, column] of tableInfos[tableName].entries()) {
106
+ snapshotContent[column.name] = values[index];
107
+ }
108
+ }
109
+ if (tableName === "file" && snapshotContent) {
110
+ // sqlite has it's own jsonb format
111
+ // hence, need to query sqlite to convert
112
+ // to json
113
+ const json = sqlite.exec("SELECT json(?)", {
114
+ bind: [snapshotContent.metadata],
115
+ returnValue: "resultRows",
116
+ })[0][0];
117
+ snapshotContent["metadata"] = JSON.parse(json);
118
+ // remove the data field which is change controlled by plugins, not lix itself
119
+ delete snapshotContent.data;
120
+ }
121
+ const entityId = entityIdForRow(tableName, ...values);
122
+ createChange({
123
+ lix,
124
+ authors: authors,
125
+ version: currentVersion,
126
+ entityId,
127
+ fileId: "lix_own_change_control",
128
+ pluginKey: "lix_own_change_control",
129
+ schemaKey: `lix_${tableName}_table`,
130
+ snapshotContent,
131
+ }, {
132
+ updateVersionChanges: tableName === "version_change" ? false : true,
133
+ });
134
+ }
135
+ //# sourceMappingURL=database-triggers.js.map