@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.
- package/LICENSE +21 -0
- package/dist/change/apply-changes.js +9 -9
- package/dist/change/apply-changes.js.map +1 -1
- package/dist/change/apply-changes.test.js +5 -5
- package/dist/change/apply-changes.test.js.map +1 -1
- package/dist/database/apply-schema.d.ts.map +1 -1
- package/dist/database/apply-schema.js +20 -72
- package/dist/database/apply-schema.js.map +1 -1
- package/dist/database/execute-sync.test.js +3 -3
- package/dist/database/execute-sync.test.js.map +1 -1
- package/dist/database/init-db.d.ts.map +1 -1
- package/dist/database/init-db.js +18 -3
- package/dist/database/init-db.js.map +1 -1
- package/dist/database/init-db.test.js +128 -17
- package/dist/database/init-db.test.js.map +1 -1
- package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.d.ts.map +1 -1
- package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js +5 -2
- package/dist/database/kysely-plugin/parse-jsonb-plugin-v1.js.map +1 -1
- package/dist/database/mutation-log/database-schema.d.ts.map +1 -1
- package/dist/database/mutation-log/database-schema.js +1 -3
- package/dist/database/mutation-log/database-schema.js.map +1 -1
- package/dist/database/nano-id.d.ts +21 -0
- package/dist/database/nano-id.d.ts.map +1 -0
- package/dist/database/nano-id.js +58 -0
- package/dist/database/nano-id.js.map +1 -0
- package/dist/database/nano-id.test.d.ts +2 -0
- package/dist/database/nano-id.test.d.ts.map +1 -0
- package/dist/database/nano-id.test.js +13 -0
- package/dist/database/nano-id.test.js.map +1 -0
- package/dist/database/schema.d.ts +15 -23
- package/dist/database/schema.d.ts.map +1 -1
- package/dist/discussion/create-comment.d.ts +0 -2
- package/dist/discussion/create-comment.d.ts.map +1 -1
- package/dist/discussion/create-comment.js +0 -1
- package/dist/discussion/create-comment.js.map +1 -1
- package/dist/discussion/create-discussion.d.ts +3 -5
- package/dist/discussion/create-discussion.d.ts.map +1 -1
- package/dist/discussion/create-discussion.js +4 -5
- package/dist/discussion/create-discussion.js.map +1 -1
- package/dist/discussion/create-discussion.test.js +8 -34
- package/dist/discussion/create-discussion.test.js.map +1 -1
- package/dist/file-queue/file-handlers.d.ts +24 -0
- package/dist/file-queue/file-handlers.d.ts.map +1 -0
- package/dist/file-queue/file-handlers.js +209 -0
- package/dist/file-queue/file-handlers.js.map +1 -0
- package/dist/file-queue/file-queue-process.d.ts +5 -0
- package/dist/file-queue/file-queue-process.d.ts.map +1 -0
- package/dist/file-queue/file-queue-process.js +85 -0
- package/dist/file-queue/file-queue-process.js.map +1 -0
- package/dist/file-queue/file-queue-process.test.d.ts +2 -0
- package/dist/file-queue/file-queue-process.test.d.ts.map +1 -0
- package/dist/file-queue/file-queue-process.test.js +373 -0
- package/dist/file-queue/file-queue-process.test.js.map +1 -0
- package/dist/file-queue/file-queue-settled.d.ts +13 -0
- package/dist/file-queue/file-queue-settled.d.ts.map +1 -0
- package/dist/file-queue/file-queue-settled.js +25 -0
- package/dist/file-queue/file-queue-settled.js.map +1 -0
- package/dist/file-queue/file-queue-settled.test.d.ts +2 -0
- package/dist/file-queue/file-queue-settled.test.d.ts.map +1 -0
- package/dist/file-queue/file-queue-settled.test.js +47 -0
- package/dist/file-queue/file-queue-settled.test.js.map +1 -0
- package/dist/file-queue/index.d.ts +2 -0
- package/dist/file-queue/index.d.ts.map +1 -0
- package/dist/file-queue/index.js +2 -0
- package/dist/file-queue/index.js.map +1 -0
- package/dist/file-queue/with-skip-file-queue.d.ts +3 -0
- package/dist/file-queue/with-skip-file-queue.d.ts.map +1 -0
- package/dist/file-queue/with-skip-file-queue.js +26 -0
- package/dist/file-queue/with-skip-file-queue.js.map +1 -0
- package/dist/file-queue/with-skip-file-queue.test.d.ts +2 -0
- package/dist/file-queue/with-skip-file-queue.test.d.ts.map +1 -0
- package/dist/file-queue/with-skip-file-queue.test.js +138 -0
- package/dist/file-queue/with-skip-file-queue.test.js.map +1 -0
- package/dist/index.d.ts +2 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -2
- package/dist/index.js.map +1 -1
- package/dist/key-value/database-schema.d.ts +11 -2
- package/dist/key-value/database-schema.d.ts.map +1 -1
- package/dist/key-value/database-schema.js +7 -4
- package/dist/key-value/database-schema.js.map +1 -1
- package/dist/key-value/database-schema.test.js +21 -5
- package/dist/key-value/database-schema.test.js.map +1 -1
- package/dist/lix/close-lix.d.ts +8 -0
- package/dist/lix/close-lix.d.ts.map +1 -0
- package/dist/lix/close-lix.js +7 -0
- package/dist/lix/close-lix.js.map +1 -0
- package/dist/lix/index.d.ts +1 -0
- package/dist/lix/index.d.ts.map +1 -1
- package/dist/lix/index.js +1 -0
- package/dist/lix/index.js.map +1 -1
- package/dist/lix/merge.js +3 -3
- package/dist/lix/merge.js.map +1 -1
- package/dist/lix/merge.test.js +7 -18
- package/dist/lix/merge.test.js.map +1 -1
- package/dist/lix/new-lix.d.ts.map +1 -1
- package/dist/lix/new-lix.js +2 -3
- package/dist/lix/new-lix.js.map +1 -1
- package/dist/lix/open-lix-in-memory.test.js +2 -1
- package/dist/lix/open-lix-in-memory.test.js.map +1 -1
- package/dist/lix/open-lix.d.ts +3 -5
- package/dist/lix/open-lix.d.ts.map +1 -1
- package/dist/lix/open-lix.js +4 -18
- package/dist/lix/open-lix.js.map +1 -1
- package/dist/lix/open-lix.test.js +16 -7
- package/dist/lix/open-lix.test.js.map +1 -1
- package/dist/lix/to-blob.d.ts +11 -0
- package/dist/lix/to-blob.d.ts.map +1 -0
- package/dist/lix/to-blob.js +11 -0
- package/dist/lix/to-blob.js.map +1 -0
- package/dist/own-change-control/apply-own-change.d.ts +10 -0
- package/dist/own-change-control/apply-own-change.d.ts.map +1 -0
- package/dist/own-change-control/apply-own-change.js +69 -0
- package/dist/own-change-control/apply-own-change.js.map +1 -0
- package/dist/own-change-control/apply-own-change.test.d.ts +2 -0
- package/dist/own-change-control/apply-own-change.test.d.ts.map +1 -0
- package/dist/own-change-control/apply-own-change.test.js +297 -0
- package/dist/own-change-control/apply-own-change.test.js.map +1 -0
- package/dist/own-change-control/change-controlled-tables.d.ts +60 -0
- package/dist/own-change-control/change-controlled-tables.d.ts.map +1 -0
- package/dist/own-change-control/change-controlled-tables.js +70 -0
- package/dist/own-change-control/change-controlled-tables.js.map +1 -0
- package/dist/own-change-control/change-controlled-tables.test.d.ts +2 -0
- package/dist/own-change-control/change-controlled-tables.test.d.ts.map +1 -0
- package/dist/own-change-control/change-controlled-tables.test.js +48 -0
- package/dist/own-change-control/change-controlled-tables.test.js.map +1 -0
- package/dist/own-change-control/database-triggers.d.ts +5 -0
- package/dist/own-change-control/database-triggers.d.ts.map +1 -0
- package/dist/own-change-control/database-triggers.js +135 -0
- package/dist/own-change-control/database-triggers.js.map +1 -0
- package/dist/own-change-control/database-triggers.test.d.ts +2 -0
- package/dist/own-change-control/database-triggers.test.d.ts.map +1 -0
- package/dist/own-change-control/database-triggers.test.js +214 -0
- package/dist/own-change-control/database-triggers.test.js.map +1 -0
- package/dist/own-change-control/index.d.ts +2 -0
- package/dist/own-change-control/index.d.ts.map +1 -0
- package/dist/own-change-control/index.js +2 -0
- package/dist/own-change-control/index.js.map +1 -0
- package/dist/own-change-control/with-skip-own-change-control.d.ts +3 -0
- package/dist/own-change-control/with-skip-own-change-control.d.ts.map +1 -0
- package/dist/own-change-control/with-skip-own-change-control.js +28 -0
- package/dist/own-change-control/with-skip-own-change-control.js.map +1 -0
- package/dist/own-change-control/with-skip-own-change-control.test.d.ts +2 -0
- package/dist/own-change-control/with-skip-own-change-control.test.d.ts.map +1 -0
- package/dist/own-change-control/with-skip-own-change-control.test.js +49 -0
- package/dist/own-change-control/with-skip-own-change-control.test.js.map +1 -0
- package/dist/own-entity-change-control/apply-own-entity-change.js +2 -2
- package/dist/own-entity-change-control/apply-own-entity-change.js.map +1 -1
- package/dist/own-entity-change-control/apply-own-entity-change.test.js +9 -9
- package/dist/own-entity-change-control/apply-own-entity-change.test.js.map +1 -1
- package/dist/own-entity-change-control/database-triggers.js +6 -6
- package/dist/own-entity-change-control/database-triggers.js.map +1 -1
- package/dist/own-entity-change-control/database-triggers.test.js +1 -1
- package/dist/own-entity-change-control/database-triggers.test.js.map +1 -1
- package/dist/query-filter/version-change-in-difference.test.js +37 -29
- package/dist/query-filter/version-change-in-difference.test.js.map +1 -1
- package/dist/query-filter/version-change-in-symmetric-difference.test.js +37 -39
- package/dist/query-filter/version-change-in-symmetric-difference.test.js.map +1 -1
- package/dist/server-api-handler/environment/create-in-memory-environment.d.ts.map +1 -1
- package/dist/server-api-handler/environment/create-in-memory-environment.js +7 -3
- package/dist/server-api-handler/environment/create-in-memory-environment.js.map +1 -1
- package/dist/server-api-handler/environment/create-in-memory-environment.test.js +8 -7
- package/dist/server-api-handler/environment/create-in-memory-environment.test.js.map +1 -1
- package/dist/server-api-handler/routes/get-v1.d.ts.map +1 -1
- package/dist/server-api-handler/routes/get-v1.js +1 -2
- package/dist/server-api-handler/routes/get-v1.js.map +1 -1
- package/dist/server-api-handler/routes/get-v1.test.js +6 -5
- package/dist/server-api-handler/routes/get-v1.test.js.map +1 -1
- package/dist/server-api-handler/routes/new-v1.d.ts.map +1 -1
- package/dist/server-api-handler/routes/new-v1.js +3 -1
- package/dist/server-api-handler/routes/new-v1.js.map +1 -1
- package/dist/server-api-handler/routes/new-v1.test.js +2 -1
- package/dist/server-api-handler/routes/new-v1.test.js.map +1 -1
- package/dist/server-api-handler/routes/pull-v1.test.js +4 -3
- package/dist/server-api-handler/routes/pull-v1.test.js.map +1 -1
- package/dist/server-api-handler/routes/push-v1.test.js +5 -4
- package/dist/server-api-handler/routes/push-v1.test.js.map +1 -1
- package/dist/sync/pull-from-server.d.ts.map +1 -1
- package/dist/sync/pull-from-server.js +0 -2
- package/dist/sync/pull-from-server.js.map +1 -1
- package/dist/sync/pull-from-server.test.js +29 -14
- package/dist/sync/pull-from-server.test.js.map +1 -1
- package/dist/sync/push-to-server.test.js +17 -13
- package/dist/sync/push-to-server.test.js.map +1 -1
- package/dist/sync/sync-process.d.ts +2 -4
- package/dist/sync/sync-process.d.ts.map +1 -1
- package/dist/sync/sync-process.js +4 -9
- package/dist/sync/sync-process.js.map +1 -1
- package/dist/sync/sync-process.test.js +26 -38
- package/dist/sync/sync-process.test.js.map +1 -1
- package/dist/version/create-version.d.ts +5 -5
- package/dist/version/create-version.d.ts.map +1 -1
- package/dist/version/create-version.js +23 -11
- package/dist/version/create-version.js.map +1 -1
- package/dist/version/create-version.test.js +2 -2
- package/dist/version/create-version.test.js.map +1 -1
- package/dist/version/merge-version.d.ts.map +1 -1
- package/dist/version/merge-version.js +16 -26
- package/dist/version/merge-version.js.map +1 -1
- package/dist/version/switch-version.js +3 -3
- package/dist/version/switch-version.js.map +1 -1
- package/dist/version/switch-version.test.js +12 -15
- package/dist/version/switch-version.test.js.map +1 -1
- package/dist/version/update-changes-in-version.d.ts.map +1 -1
- package/dist/version/update-changes-in-version.js +11 -31
- package/dist/version/update-changes-in-version.js.map +1 -1
- package/node_modules/@lix-js/server-api-schema/CHANGELOG.md +9 -0
- package/node_modules/@lix-js/server-api-schema/LICENSE +21 -0
- package/node_modules/@lix-js/server-api-schema/dist/schema.js +0 -0
- package/node_modules/@lix-js/server-api-schema/package.json +2 -2
- package/node_modules/sqlite-wasm-kysely/LICENSE +21 -0
- package/package.json +4 -4
- package/src/change/apply-changes.test.ts +7 -7
- package/src/change/apply-changes.ts +9 -9
- package/src/database/apply-schema.ts +20 -73
- package/src/database/execute-sync.test.ts +3 -3
- package/src/database/init-db.test.ts +163 -19
- package/src/database/init-db.ts +20 -3
- package/src/database/kysely-plugin/parse-jsonb-plugin-v1.ts +9 -2
- package/src/database/mutation-log/database-schema.ts +1 -3
- package/src/database/nano-id.test.ts +15 -0
- package/src/database/nano-id.ts +72 -0
- package/src/database/schema.ts +15 -24
- package/src/discussion/create-comment.ts +0 -3
- package/src/discussion/create-discussion.test.ts +8 -39
- package/src/discussion/create-discussion.ts +6 -9
- package/src/{change-queue → file-queue}/file-handlers.ts +27 -27
- package/src/{change-queue/init-change-queue.test.ts → file-queue/file-queue-process.test.ts} +24 -24
- package/src/{change-queue/init-change-queue.ts → file-queue/file-queue-process.ts} +18 -16
- package/src/{change-queue/change-queue-settled.test.ts → file-queue/file-queue-settled.test.ts} +12 -12
- package/src/{change-queue/change-queue-settled.ts → file-queue/file-queue-settled.ts} +4 -4
- package/src/file-queue/index.ts +1 -0
- package/src/{change-queue/with-skip-change-queue.test.ts → file-queue/with-skip-file-queue.test.ts} +9 -9
- package/src/{change-queue/with-skip-change-queue.ts → file-queue/with-skip-file-queue.ts} +3 -3
- package/src/index.ts +2 -2
- package/src/key-value/database-schema.test.ts +26 -5
- package/src/key-value/database-schema.ts +18 -6
- package/src/lix/close-lix.ts +8 -0
- package/src/lix/index.ts +1 -0
- package/src/lix/merge.test.ts +7 -19
- package/src/lix/merge.ts +4 -4
- package/src/lix/new-lix.ts +2 -3
- package/src/lix/open-lix-in-memory.test.ts +5 -1
- package/src/lix/open-lix.test.ts +19 -7
- package/src/lix/open-lix.ts +7 -24
- package/src/lix/to-blob.ts +14 -0
- package/src/{own-entity-change-control/apply-own-entity-change.test.ts → own-change-control/apply-own-change.test.ts} +27 -31
- package/src/{own-entity-change-control/apply-own-entity-change.ts → own-change-control/apply-own-change.ts} +3 -3
- package/src/{own-entity-change-control → own-change-control}/change-controlled-tables.ts +0 -1
- package/src/{own-entity-change-control → own-change-control}/database-triggers.test.ts +7 -7
- package/src/{own-entity-change-control → own-change-control}/database-triggers.ts +11 -11
- package/src/{own-entity-change-control → own-change-control}/with-skip-own-change-control.ts +6 -2
- package/src/query-filter/version-change-in-difference.test.ts +41 -32
- package/src/query-filter/version-change-in-symmetric-difference.test.ts +41 -42
- package/src/server-api-handler/environment/create-in-memory-environment.test.ts +8 -7
- package/src/server-api-handler/environment/create-in-memory-environment.ts +7 -3
- package/src/server-api-handler/routes/get-v1.test.ts +6 -5
- package/src/server-api-handler/routes/get-v1.ts +1 -3
- package/src/server-api-handler/routes/new-v1.test.ts +2 -1
- package/src/server-api-handler/routes/new-v1.ts +3 -1
- package/src/server-api-handler/routes/pull-v1.test.ts +4 -3
- package/src/server-api-handler/routes/push-v1.test.ts +5 -4
- package/src/sync/pull-from-server.test.ts +29 -14
- package/src/sync/pull-from-server.ts +0 -2
- package/src/sync/push-to-server.test.ts +19 -15
- package/src/sync/sync-process.test.ts +37 -43
- package/src/sync/sync-process.ts +6 -18
- package/src/version/create-version.test.ts +2 -2
- package/src/version/create-version.ts +24 -12
- package/src/version/merge-version.ts +18 -26
- package/src/version/switch-version.test.ts +12 -15
- package/src/version/switch-version.ts +3 -3
- package/src/version/update-changes-in-version.ts +11 -30
- package/node_modules/@lix-js/server-api-schema/dist/schema.d.ts +0 -384
- package/src/change-queue/index.ts +0 -1
- /package/src/{own-entity-change-control → own-change-control}/change-controlled-tables.test.ts +0 -0
- /package/src/{own-entity-change-control → own-change-control}/index.ts +0 -0
- /package/src/{own-entity-change-control → own-change-control}/with-skip-own-change-control.test.ts +0 -0
package/dist/lix/new-lix.js
CHANGED
|
@@ -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
|
-
|
|
23
|
-
sqlite.close();
|
|
24
|
-
await db.destroy();
|
|
23
|
+
closeLix({ lix: { db } });
|
|
25
24
|
}
|
|
26
25
|
}
|
|
27
26
|
//# sourceMappingURL=new-lix.js.map
|
package/dist/lix/new-lix.js.map
CHANGED
|
@@ -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;
|
|
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
|
|
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;
|
|
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"}
|
package/dist/lix/open-lix.d.ts
CHANGED
|
@@ -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 {
|
|
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: "
|
|
46
|
+
* const lix = await openLix({ keyValues: [{ key: "lix_sync", value: "false" }] })
|
|
49
47
|
*/
|
|
50
|
-
keyValues?:
|
|
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,
|
|
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"}
|
package/dist/lix/open-lix.js
CHANGED
|
@@ -1,8 +1,7 @@
|
|
|
1
1
|
import { loadPlugins } from "../plugin/load-plugin.js";
|
|
2
|
-
import {
|
|
2
|
+
import {} from "sqlite-wasm-kysely";
|
|
3
3
|
import { initDb } from "../database/init-db.js";
|
|
4
|
-
import {
|
|
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
|
-
|
|
27
|
-
|
|
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
|
package/dist/lix/open-lix.js.map
CHANGED
|
@@ -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,
|
|
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: "
|
|
18
|
+
keyValues: [{ key: "mock_key", value: "value" }],
|
|
18
19
|
});
|
|
19
|
-
const value = await lix.db
|
|
20
|
-
|
|
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
|
|
24
|
-
keyValues: [{ key: "
|
|
28
|
+
blob: await toBlob({ lix }),
|
|
29
|
+
keyValues: [{ key: "mock_key", value: "value2" }],
|
|
25
30
|
});
|
|
26
|
-
const value1 = await lix1.db
|
|
27
|
-
|
|
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;
|
|
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 @@
|
|
|
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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"}
|