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