@lix-js/sdk 0.5.0-preview.0 → 0.5.0-preview.1
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/dist/account/create-account.d.ts +5 -5
- package/dist/account/create-account.d.ts.map +1 -1
- package/dist/account/create-account.js +2 -2
- package/dist/account/create-account.js.map +1 -1
- package/dist/account/index.d.ts +1 -1
- package/dist/account/index.d.ts.map +1 -1
- package/dist/account/schema.d.ts +23 -7
- package/dist/account/schema.d.ts.map +1 -1
- package/dist/account/schema.js +84 -27
- package/dist/account/schema.js.map +1 -1
- package/dist/account/schema.test.js +87 -83
- package/dist/account/schema.test.js.map +1 -1
- package/dist/account/switch-account.d.ts +2 -2
- package/dist/account/switch-account.d.ts.map +1 -1
- package/dist/account/switch-account.js +3 -4
- package/dist/account/switch-account.js.map +1 -1
- package/dist/account/switch-account.test.js +4 -4
- package/dist/account/switch-account.test.js.map +1 -1
- package/dist/change/apply-changes.d.ts +13 -0
- package/dist/change/apply-changes.d.ts.map +1 -1
- package/dist/change/apply-changes.js +14 -4
- package/dist/change/apply-changes.js.map +1 -1
- package/dist/change/apply-changes.test.js +91 -1
- package/dist/change/apply-changes.test.js.map +1 -1
- package/dist/change/create-change-v2.d.ts +11 -0
- package/dist/change/create-change-v2.d.ts.map +1 -0
- package/dist/change/create-change-v2.js +31 -0
- package/dist/change/create-change-v2.js.map +1 -0
- package/dist/change/create-change-v2.test.d.ts +2 -0
- package/dist/change/create-change-v2.test.d.ts.map +1 -0
- package/dist/change/create-change-v2.test.js +39 -0
- package/dist/change/create-change-v2.test.js.map +1 -0
- package/dist/change/create-change.d.ts +2 -2
- package/dist/change/create-change.d.ts.map +1 -1
- package/dist/change/create-change.js +3 -1
- package/dist/change/create-change.js.map +1 -1
- package/dist/change/create-change.test.js +4 -6
- package/dist/change/create-change.test.js.map +1 -1
- package/dist/change/index.d.ts +1 -1
- package/dist/change/index.d.ts.map +1 -1
- package/dist/change/index.js.map +1 -1
- package/dist/change/schema.d.ts +40 -2
- package/dist/change/schema.d.ts.map +1 -1
- package/dist/change/schema.js +50 -9
- package/dist/change/schema.js.map +1 -1
- package/dist/change/schema.test.js +33 -0
- package/dist/change/schema.test.js.map +1 -1
- package/dist/change-author/index.d.ts +1 -1
- package/dist/change-author/index.d.ts.map +1 -1
- package/dist/change-author/index.js +1 -1
- package/dist/change-author/index.js.map +1 -1
- package/dist/change-author/schema.d.ts +12 -9
- package/dist/change-author/schema.d.ts.map +1 -1
- package/dist/change-author/schema.js +16 -10
- package/dist/change-author/schema.js.map +1 -1
- package/dist/change-author/schema.test.js +283 -229
- package/dist/change-author/schema.test.js.map +1 -1
- package/dist/change-proposal/create-change-proposal.d.ts +3 -3
- package/dist/change-proposal/create-change-proposal.d.ts.map +1 -1
- package/dist/change-proposal/database-schema.js +1 -1
- package/dist/change-set/apply-change-set.d.ts +2 -2
- package/dist/change-set/apply-change-set.d.ts.map +1 -1
- package/dist/change-set/apply-change-set.js +40 -51
- package/dist/change-set/apply-change-set.js.map +1 -1
- package/dist/change-set/apply-change-set.test.js +6 -3
- package/dist/change-set/apply-change-set.test.js.map +1 -1
- package/dist/change-set/before-after-of-file.d.ts +31 -0
- package/dist/change-set/before-after-of-file.d.ts.map +1 -0
- package/dist/change-set/before-after-of-file.js +191 -0
- package/dist/change-set/before-after-of-file.js.map +1 -0
- package/dist/change-set/before-after-of-file.test.d.ts +2 -0
- package/dist/change-set/before-after-of-file.test.d.ts.map +1 -0
- package/dist/change-set/before-after-of-file.test.js +221 -0
- package/dist/change-set/before-after-of-file.test.js.map +1 -0
- package/dist/change-set/change-set-element-in-symmetric-difference.d.ts +2 -1
- package/dist/change-set/change-set-element-in-symmetric-difference.d.ts.map +1 -1
- package/dist/change-set/change-set-element-in-symmetric-difference.js.map +1 -1
- package/dist/change-set/change-set-element-in-symmetric-difference.test.js +204 -34
- package/dist/change-set/change-set-element-in-symmetric-difference.test.js.map +1 -1
- package/dist/change-set/checkout-change-set.d.ts +15 -0
- package/dist/change-set/checkout-change-set.d.ts.map +1 -0
- package/dist/change-set/checkout-change-set.js +64 -0
- package/dist/change-set/checkout-change-set.js.map +1 -0
- package/dist/change-set/checkout-change-set.test.d.ts +2 -0
- package/dist/change-set/checkout-change-set.test.d.ts.map +1 -0
- package/dist/change-set/checkout-change-set.test.js +127 -0
- package/dist/change-set/checkout-change-set.test.js.map +1 -0
- package/dist/change-set/create-change-set.d.ts +7 -9
- package/dist/change-set/create-change-set.d.ts.map +1 -1
- package/dist/change-set/create-change-set.js +3 -25
- package/dist/change-set/create-change-set.js.map +1 -1
- package/dist/change-set/create-change-set.test.js +0 -31
- package/dist/change-set/create-change-set.test.js.map +1 -1
- package/dist/change-set/create-checkpoint.d.ts.map +1 -1
- package/dist/change-set/create-checkpoint.js +11 -2
- package/dist/change-set/create-checkpoint.js.map +1 -1
- package/dist/change-set/create-checkpoint.test.js +53 -0
- package/dist/change-set/create-checkpoint.test.js.map +1 -1
- package/dist/change-set/create-merge-change-set.d.ts +4 -4
- package/dist/change-set/create-merge-change-set.d.ts.map +1 -1
- package/dist/change-set/create-transition-change-set.d.ts +4 -4
- package/dist/change-set/create-transition-change-set.d.ts.map +1 -1
- package/dist/change-set/create-undo-change-set.d.ts +5 -5
- package/dist/change-set/create-undo-change-set.d.ts.map +1 -1
- package/dist/change-set/create-undo-change-set.js +4 -3
- package/dist/change-set/create-undo-change-set.js.map +1 -1
- package/dist/change-set/database-schema.d.ts +39 -0
- package/dist/change-set/database-schema.d.ts.map +1 -0
- package/dist/change-set/database-schema.js +86 -0
- package/dist/change-set/database-schema.js.map +1 -0
- package/dist/change-set/database-schema.test.d.ts +2 -0
- package/dist/change-set/database-schema.test.d.ts.map +1 -0
- package/dist/change-set/database-schema.test.js +547 -0
- package/dist/change-set/database-schema.test.js.map +1 -0
- package/dist/change-set/diff-for-file.d.ts +29 -0
- package/dist/change-set/diff-for-file.d.ts.map +1 -0
- package/dist/change-set/diff-for-file.js +19 -0
- package/dist/change-set/diff-for-file.js.map +1 -0
- package/dist/change-set/get-before-after-of-file.d.ts +31 -0
- package/dist/change-set/get-before-after-of-file.d.ts.map +1 -0
- package/dist/change-set/get-before-after-of-file.js +189 -0
- package/dist/change-set/get-before-after-of-file.js.map +1 -0
- package/dist/change-set/get-before-after-of-file.test.d.ts +2 -0
- package/dist/change-set/get-before-after-of-file.test.d.ts.map +1 -0
- package/dist/change-set/get-before-after-of-file.test.js +220 -0
- package/dist/change-set/get-before-after-of-file.test.js.map +1 -0
- package/dist/change-set/index.d.ts +1 -5
- package/dist/change-set/index.d.ts.map +1 -1
- package/dist/change-set/index.js +1 -5
- package/dist/change-set/index.js.map +1 -1
- package/dist/change-set/merge-change-sets.d.ts +23 -0
- package/dist/change-set/merge-change-sets.d.ts.map +1 -0
- package/dist/change-set/merge-change-sets.js +69 -0
- package/dist/change-set/merge-change-sets.js.map +1 -0
- package/dist/change-set/merge-change-sets.test.d.ts +2 -0
- package/dist/change-set/merge-change-sets.test.d.ts.map +1 -0
- package/dist/change-set/merge-change-sets.test.js +184 -0
- package/dist/change-set/merge-change-sets.test.js.map +1 -0
- package/dist/change-set/restore-change-set.d.ts +14 -0
- package/dist/change-set/restore-change-set.d.ts.map +1 -0
- package/dist/change-set/restore-change-set.js +98 -0
- package/dist/change-set/restore-change-set.js.map +1 -0
- package/dist/change-set/restore-change-set.test.d.ts +2 -0
- package/dist/change-set/restore-change-set.test.d.ts.map +1 -0
- package/dist/change-set/restore-change-set.test.js +238 -0
- package/dist/change-set/restore-change-set.test.js.map +1 -0
- package/dist/change-set/schema.d.ts +28 -72
- package/dist/change-set/schema.d.ts.map +1 -1
- package/dist/change-set/schema.js +37 -84
- package/dist/change-set/schema.js.map +1 -1
- package/dist/change-set/schema.test.js +0 -247
- package/dist/change-set/schema.test.js.map +1 -1
- package/dist/change-set-edge/database-schema.d.ts +11 -0
- package/dist/change-set-edge/database-schema.d.ts.map +1 -0
- package/dist/change-set-edge/database-schema.js +29 -0
- package/dist/change-set-edge/database-schema.js.map +1 -0
- package/dist/change-set-edge/database-schema.test.d.ts +2 -0
- package/dist/change-set-edge/database-schema.test.d.ts.map +1 -0
- package/dist/change-set-edge/database-schema.test.js +166 -0
- package/dist/change-set-edge/database-schema.test.js.map +1 -0
- package/dist/change-set-edge/index.d.ts +2 -0
- package/dist/change-set-edge/index.d.ts.map +1 -0
- package/dist/change-set-edge/index.js +2 -0
- package/dist/change-set-edge/index.js.map +1 -0
- package/dist/change-set-v2/apply-change-set.d.ts +10 -0
- package/dist/change-set-v2/apply-change-set.d.ts.map +1 -0
- package/dist/change-set-v2/apply-change-set.js +147 -0
- package/dist/change-set-v2/apply-change-set.js.map +1 -0
- package/dist/change-set-v2/apply-change-set.test.d.ts +2 -0
- package/dist/change-set-v2/apply-change-set.test.d.ts.map +1 -0
- package/dist/change-set-v2/apply-change-set.test.js +270 -0
- package/dist/change-set-v2/apply-change-set.test.js.map +1 -0
- package/dist/change-set-v2/create-change-set.d.ts +10 -0
- package/dist/change-set-v2/create-change-set.d.ts.map +1 -0
- package/dist/change-set-v2/create-change-set.js +57 -0
- package/dist/change-set-v2/create-change-set.js.map +1 -0
- package/dist/change-set-v2/create-change-set.test.d.ts +2 -0
- package/dist/change-set-v2/create-change-set.test.d.ts.map +1 -0
- package/dist/change-set-v2/create-change-set.test.js +59 -0
- package/dist/change-set-v2/create-change-set.test.js.map +1 -0
- package/dist/change-set-v2/create-checkpoint.d.ts +7 -0
- package/dist/change-set-v2/create-checkpoint.d.ts.map +1 -0
- package/dist/change-set-v2/create-checkpoint.js +79 -0
- package/dist/change-set-v2/create-checkpoint.js.map +1 -0
- package/dist/change-set-v2/create-checkpoint.test.d.ts +2 -0
- package/dist/change-set-v2/create-checkpoint.test.d.ts.map +1 -0
- package/dist/change-set-v2/create-checkpoint.test.js +289 -0
- package/dist/change-set-v2/create-checkpoint.test.js.map +1 -0
- package/dist/change-set-v2/create-merge-change-set.d.ts +23 -0
- package/dist/change-set-v2/create-merge-change-set.d.ts.map +1 -0
- package/dist/change-set-v2/create-merge-change-set.js +68 -0
- package/dist/change-set-v2/create-merge-change-set.js.map +1 -0
- package/dist/change-set-v2/create-merge-change-set.test.d.ts +2 -0
- package/dist/change-set-v2/create-merge-change-set.test.d.ts.map +1 -0
- package/dist/change-set-v2/create-merge-change-set.test.js +223 -0
- package/dist/change-set-v2/create-merge-change-set.test.js.map +1 -0
- package/dist/change-set-v2/index.d.ts +5 -0
- package/dist/change-set-v2/index.d.ts.map +1 -0
- package/dist/change-set-v2/index.js +5 -0
- package/dist/change-set-v2/index.js.map +1 -0
- package/dist/change-set-v2/schema.d.ts +50 -0
- package/dist/change-set-v2/schema.d.ts.map +1 -0
- package/dist/change-set-v2/schema.js +347 -0
- package/dist/change-set-v2/schema.js.map +1 -0
- package/dist/change-set-v2/schema.test.d.ts +2 -0
- package/dist/change-set-v2/schema.test.d.ts.map +1 -0
- package/dist/change-set-v2/schema.test.js +713 -0
- package/dist/change-set-v2/schema.test.js.map +1 -0
- package/dist/commit/apply-commit.d.ts +32 -0
- package/dist/commit/apply-commit.d.ts.map +1 -0
- package/dist/commit/apply-commit.js +63 -0
- package/dist/commit/apply-commit.js.map +1 -0
- package/dist/commit/apply-commit.test.d.ts +2 -0
- package/dist/commit/apply-commit.test.d.ts.map +1 -0
- package/dist/commit/apply-commit.test.js +367 -0
- package/dist/commit/apply-commit.test.js.map +1 -0
- package/dist/commit/create-checkpoint.d.ts +19 -0
- package/dist/commit/create-checkpoint.d.ts.map +1 -0
- package/dist/commit/create-checkpoint.js +118 -0
- package/dist/commit/create-checkpoint.js.map +1 -0
- package/dist/commit/create-checkpoint.test.d.ts +2 -0
- package/dist/commit/create-checkpoint.test.d.ts.map +1 -0
- package/dist/commit/create-checkpoint.test.js +472 -0
- package/dist/commit/create-checkpoint.test.js.map +1 -0
- package/dist/commit/create-commit.d.ts +38 -0
- package/dist/commit/create-commit.d.ts.map +1 -0
- package/dist/commit/create-commit.js +68 -0
- package/dist/commit/create-commit.js.map +1 -0
- package/dist/commit/create-merge-commit.d.ts +24 -0
- package/dist/commit/create-merge-commit.d.ts.map +1 -0
- package/dist/commit/create-merge-commit.js +103 -0
- package/dist/commit/create-merge-commit.js.map +1 -0
- package/dist/commit/create-merge-commit.test.d.ts +2 -0
- package/dist/commit/create-merge-commit.test.d.ts.map +1 -0
- package/dist/commit/create-merge-commit.test.js +242 -0
- package/dist/commit/create-merge-commit.test.js.map +1 -0
- package/dist/commit/create-transition-commit.d.ts +18 -0
- package/dist/commit/create-transition-commit.d.ts.map +1 -0
- package/dist/commit/create-transition-commit.js +136 -0
- package/dist/commit/create-transition-commit.js.map +1 -0
- package/dist/commit/create-transition-commit.test.d.ts +2 -0
- package/dist/commit/create-transition-commit.test.d.ts.map +1 -0
- package/dist/commit/create-transition-commit.test.js +221 -0
- package/dist/commit/create-transition-commit.test.js.map +1 -0
- package/dist/commit/create-undo-commit.d.ts +27 -0
- package/dist/commit/create-undo-commit.d.ts.map +1 -0
- package/dist/commit/create-undo-commit.js +143 -0
- package/dist/commit/create-undo-commit.js.map +1 -0
- package/dist/commit/create-undo-commit.test.d.ts +2 -0
- package/dist/commit/create-undo-commit.test.d.ts.map +1 -0
- package/dist/commit/create-undo-commit.test.js +298 -0
- package/dist/commit/create-undo-commit.test.js.map +1 -0
- package/dist/commit/index.d.ts +6 -0
- package/dist/commit/index.d.ts.map +1 -0
- package/dist/commit/index.js +6 -0
- package/dist/commit/index.js.map +1 -0
- package/dist/commit/schema.d.ts +73 -0
- package/dist/commit/schema.d.ts.map +1 -0
- package/dist/commit/schema.js +90 -0
- package/dist/commit/schema.js.map +1 -0
- package/dist/commit/schema.test.d.ts +2 -0
- package/dist/commit/schema.test.d.ts.map +1 -0
- package/dist/commit/schema.test.js +216 -0
- package/dist/commit/schema.test.js.map +1 -0
- package/dist/database/apply-schema.d.ts +3 -0
- package/dist/database/apply-schema.d.ts.map +1 -1
- package/dist/database/apply-schema.js +91 -258
- package/dist/database/apply-schema.js.map +1 -1
- package/dist/database/index.d.ts +0 -2
- package/dist/database/index.d.ts.map +1 -1
- package/dist/database/index.js +0 -2
- package/dist/database/index.js.map +1 -1
- package/dist/database/init-db.d.ts.map +1 -1
- package/dist/database/init-db.js +83 -44
- package/dist/database/init-db.js.map +1 -1
- package/dist/database/init-db.test.js +2 -480
- package/dist/database/init-db.test.js.map +1 -1
- package/dist/database/kysely-plugin/json-column-plugin.d.ts +5 -1
- package/dist/database/kysely-plugin/json-column-plugin.d.ts.map +1 -1
- package/dist/database/kysely-plugin/json-column-plugin.js +52 -10
- package/dist/database/kysely-plugin/json-column-plugin.js.map +1 -1
- package/dist/database/kysely-plugin/json-column-plugin.test.d.ts +2 -0
- package/dist/database/kysely-plugin/json-column-plugin.test.d.ts.map +1 -0
- package/dist/database/kysely-plugin/json-column-plugin.test.js +329 -0
- package/dist/database/kysely-plugin/json-column-plugin.test.js.map +1 -0
- package/dist/database/mutation-log/database-schema.d.ts.map +1 -1
- package/dist/database/mutation-log/database-schema.js +0 -4
- package/dist/database/mutation-log/database-schema.js.map +1 -1
- package/dist/database/nano-id.d.ts +4 -1
- package/dist/database/nano-id.d.ts.map +1 -1
- package/dist/database/nano-id.js +4 -1
- package/dist/database/nano-id.js.map +1 -1
- package/dist/database/nano-id.test.js +3 -3
- package/dist/database/nano-id.test.js.map +1 -1
- package/dist/database/schema.d.ts +21 -14
- package/dist/database/schema.d.ts.map +1 -1
- package/dist/database/schema.js +9 -5
- package/dist/database/schema.js.map +1 -1
- package/dist/deterministic/generate-human-id.d.ts +20 -0
- package/dist/deterministic/generate-human-id.d.ts.map +1 -0
- package/dist/deterministic/generate-human-id.js +86 -0
- package/dist/deterministic/generate-human-id.js.map +1 -0
- package/dist/deterministic/generate-human-id.test.d.ts +2 -0
- package/dist/deterministic/generate-human-id.test.d.ts.map +1 -0
- package/dist/deterministic/generate-human-id.test.js +123 -0
- package/dist/deterministic/generate-human-id.test.js.map +1 -0
- package/dist/deterministic/index.d.ts +8 -0
- package/dist/deterministic/index.d.ts.map +1 -0
- package/dist/deterministic/index.js +8 -0
- package/dist/deterministic/index.js.map +1 -0
- package/dist/deterministic/is-deterministic-mode.d.ts +14 -0
- package/dist/deterministic/is-deterministic-mode.d.ts.map +1 -0
- package/dist/deterministic/is-deterministic-mode.js +25 -0
- package/dist/deterministic/is-deterministic-mode.js.map +1 -0
- package/dist/deterministic/is-deterministic-mode.test.d.ts +2 -0
- package/dist/deterministic/is-deterministic-mode.test.d.ts.map +1 -0
- package/dist/deterministic/is-deterministic-mode.test.js +103 -0
- package/dist/deterministic/is-deterministic-mode.test.js.map +1 -0
- package/dist/deterministic/nano-id.d.ts +61 -0
- package/dist/deterministic/nano-id.d.ts.map +1 -0
- package/dist/deterministic/nano-id.js +161 -0
- package/dist/deterministic/nano-id.js.map +1 -0
- package/dist/deterministic/nano-id.test.d.ts +2 -0
- package/dist/deterministic/nano-id.test.d.ts.map +1 -0
- package/dist/deterministic/nano-id.test.js +163 -0
- package/dist/deterministic/nano-id.test.js.map +1 -0
- package/dist/deterministic/options.d.ts +53 -0
- package/dist/deterministic/options.d.ts.map +1 -0
- package/dist/deterministic/options.js +52 -0
- package/dist/deterministic/options.js.map +1 -0
- package/dist/deterministic/options.test.d.ts +2 -0
- package/dist/deterministic/options.test.d.ts.map +1 -0
- package/dist/deterministic/options.test.js +111 -0
- package/dist/deterministic/options.test.js.map +1 -0
- package/dist/deterministic/random.d.ts +68 -0
- package/dist/deterministic/random.d.ts.map +1 -0
- package/dist/deterministic/random.js +225 -0
- package/dist/deterministic/random.js.map +1 -0
- package/dist/deterministic/random.test.d.ts +2 -0
- package/dist/deterministic/random.test.d.ts.map +1 -0
- package/dist/deterministic/random.test.js +244 -0
- package/dist/deterministic/random.test.js.map +1 -0
- package/dist/deterministic/sequence.d.ts +56 -0
- package/dist/deterministic/sequence.d.ts.map +1 -0
- package/dist/deterministic/sequence.js +107 -0
- package/dist/deterministic/sequence.js.map +1 -0
- package/dist/deterministic/sequence.test.d.ts +2 -0
- package/dist/deterministic/sequence.test.d.ts.map +1 -0
- package/dist/deterministic/sequence.test.js +71 -0
- package/dist/deterministic/sequence.test.js.map +1 -0
- package/dist/deterministic/timestamp.d.ts +47 -0
- package/dist/deterministic/timestamp.d.ts.map +1 -0
- package/dist/deterministic/timestamp.js +74 -0
- package/dist/deterministic/timestamp.js.map +1 -0
- package/dist/deterministic/timestamp.test.d.ts +2 -0
- package/dist/deterministic/timestamp.test.d.ts.map +1 -0
- package/dist/deterministic/timestamp.test.js +145 -0
- package/dist/deterministic/timestamp.test.js.map +1 -0
- package/dist/deterministic/uuid-v7.d.ts +49 -0
- package/dist/deterministic/uuid-v7.d.ts.map +1 -0
- package/dist/deterministic/uuid-v7.js +75 -0
- package/dist/deterministic/uuid-v7.js.map +1 -0
- package/dist/deterministic/uuid-v7.test.d.ts +2 -0
- package/dist/deterministic/uuid-v7.test.d.ts.map +1 -0
- package/dist/deterministic/uuid-v7.test.js +114 -0
- package/dist/deterministic/uuid-v7.test.js.map +1 -0
- package/dist/discussion/create-discussion.d.ts +2 -1
- package/dist/discussion/create-discussion.d.ts.map +1 -1
- package/dist/discussion/create-discussion.js.map +1 -1
- package/dist/discussion/create-discussion.test.js +13 -2
- package/dist/discussion/create-discussion.test.js.map +1 -1
- package/dist/entity/eb-entity.d.ts +76 -0
- package/dist/entity/eb-entity.d.ts.map +1 -0
- package/dist/entity/eb-entity.js +156 -0
- package/dist/entity/eb-entity.js.map +1 -0
- package/dist/entity/eb-entity.test.d.ts +2 -0
- package/dist/entity/eb-entity.test.d.ts.map +1 -0
- package/dist/entity/eb-entity.test.js +573 -0
- package/dist/entity/eb-entity.test.js.map +1 -0
- package/dist/entity/index.d.ts +7 -0
- package/dist/entity/index.d.ts.map +1 -0
- package/dist/entity/index.js +4 -0
- package/dist/entity/index.js.map +1 -0
- package/dist/entity/label/create-entity-label.d.ts +61 -0
- package/dist/entity/label/create-entity-label.d.ts.map +1 -0
- package/dist/entity/label/create-entity-label.js +92 -0
- package/dist/entity/label/create-entity-label.js.map +1 -0
- package/dist/entity/label/create-entity-label.test.d.ts +2 -0
- package/dist/entity/label/create-entity-label.test.d.ts.map +1 -0
- package/dist/entity/label/create-entity-label.test.js +261 -0
- package/dist/entity/label/create-entity-label.test.js.map +1 -0
- package/dist/entity/label/schema.d.ts +40 -0
- package/dist/entity/label/schema.d.ts.map +1 -0
- package/dist/entity/label/schema.js +42 -0
- package/dist/entity/label/schema.js.map +1 -0
- package/dist/entity/label/schema.test.d.ts +2 -0
- package/dist/entity/label/schema.test.d.ts.map +1 -0
- package/dist/entity/label/schema.test.js +596 -0
- package/dist/entity/label/schema.test.js.map +1 -0
- package/dist/entity/schema.d.ts +13 -0
- package/dist/entity/schema.d.ts.map +1 -0
- package/dist/entity/schema.js +5 -0
- package/dist/entity/schema.js.map +1 -0
- package/dist/entity/thread/create-entity-thread.d.ts +75 -0
- package/dist/entity/thread/create-entity-thread.d.ts.map +1 -0
- package/dist/entity/thread/create-entity-thread.js +109 -0
- package/dist/entity/thread/create-entity-thread.js.map +1 -0
- package/dist/entity/thread/create-entity-thread.test.d.ts +2 -0
- package/dist/entity/thread/create-entity-thread.test.d.ts.map +1 -0
- package/dist/entity/thread/create-entity-thread.test.js +240 -0
- package/dist/entity/thread/create-entity-thread.test.js.map +1 -0
- package/dist/entity/thread/query-threads.test.d.ts +2 -0
- package/dist/entity/thread/query-threads.test.d.ts.map +1 -0
- package/dist/entity/thread/query-threads.test.js +330 -0
- package/dist/entity/thread/query-threads.test.js.map +1 -0
- package/dist/entity/thread/schema.d.ts +40 -0
- package/dist/entity/thread/schema.d.ts.map +1 -0
- package/dist/entity/thread/schema.js +42 -0
- package/dist/entity/thread/schema.js.map +1 -0
- package/dist/entity/thread/schema.test.d.ts +2 -0
- package/dist/entity/thread/schema.test.d.ts.map +1 -0
- package/dist/entity/thread/schema.test.js +144 -0
- package/dist/entity/thread/schema.test.js.map +1 -0
- package/dist/entity-views/entity-state-all.d.ts +52 -0
- package/dist/entity-views/entity-state-all.d.ts.map +1 -1
- package/dist/entity-views/entity-state-all.js +19 -11
- package/dist/entity-views/entity-state-all.js.map +1 -1
- package/dist/entity-views/entity-state-all.test.js +173 -0
- package/dist/entity-views/entity-state-all.test.js.map +1 -1
- package/dist/entity-views/entity-state-history.d.ts +55 -15
- package/dist/entity-views/entity-state-history.d.ts.map +1 -1
- package/dist/entity-views/entity-state-history.js +7 -4
- package/dist/entity-views/entity-state-history.js.map +1 -1
- package/dist/entity-views/entity-state-history.test.js +70 -15
- package/dist/entity-views/entity-state-history.test.js.map +1 -1
- package/dist/entity-views/entity-state.d.ts +52 -0
- package/dist/entity-views/entity-state.d.ts.map +1 -1
- package/dist/entity-views/entity-state.js +18 -10
- package/dist/entity-views/entity-state.js.map +1 -1
- package/dist/entity-views/entity-state.test.js +120 -1
- package/dist/entity-views/entity-state.test.js.map +1 -1
- package/dist/entity-views/entity-view-builder.test.js +6 -6
- package/dist/entity-views/entity-view-builder.test.js.map +1 -1
- package/dist/entity-views/types.d.ts +2 -2
- package/dist/file/database-schema.d.ts +25 -0
- package/dist/file/database-schema.d.ts.map +1 -0
- package/dist/file/database-schema.js +26 -0
- package/dist/file/database-schema.js.map +1 -0
- package/dist/file/database-schema.test.d.ts +2 -0
- package/dist/file/database-schema.test.d.ts.map +1 -0
- package/dist/file/database-schema.test.js +60 -0
- package/dist/file/database-schema.test.js.map +1 -0
- package/dist/file/file-handlers.d.ts.map +1 -1
- package/dist/file/file-handlers.js +36 -0
- package/dist/file/file-handlers.js.map +1 -1
- package/dist/file/file-handlers.test.js +4 -4
- package/dist/file/file-handlers.test.js.map +1 -1
- package/dist/file/materialize-file-data-at-changeset.d.ts +1 -1
- package/dist/file/materialize-file-data-at-changeset.d.ts.map +1 -1
- package/dist/file/materialize-file-data-at-changeset.js +55 -29
- package/dist/file/materialize-file-data-at-changeset.js.map +1 -1
- package/dist/file/materialize-file-data-at-commit.d.ts +9 -0
- package/dist/file/materialize-file-data-at-commit.d.ts.map +1 -0
- package/dist/file/materialize-file-data-at-commit.js +119 -0
- package/dist/file/materialize-file-data-at-commit.js.map +1 -0
- package/dist/file/schema.d.ts +68 -5
- package/dist/file/schema.d.ts.map +1 -1
- package/dist/file/schema.js +118 -50
- package/dist/file/schema.js.map +1 -1
- package/dist/file/schema.test.js +543 -35
- package/dist/file/schema.test.js.map +1 -1
- package/dist/file-queue/database-schema.d.ts +17 -0
- package/dist/file-queue/database-schema.d.ts.map +1 -0
- package/dist/file-queue/database-schema.js +53 -0
- package/dist/file-queue/database-schema.js.map +1 -0
- package/dist/file-queue/file-handlers.d.ts +1 -1
- package/dist/file-queue/file-handlers.d.ts.map +1 -1
- package/dist/file-queue/file-handlers.js +60 -29
- package/dist/file-queue/file-handlers.js.map +1 -1
- package/dist/file-queue/file-queue-process.d.ts.map +1 -1
- package/dist/file-queue/file-queue-process.js +26 -17
- package/dist/file-queue/file-queue-process.js.map +1 -1
- package/dist/file-queue/file-queue-process.test.js +133 -43
- package/dist/file-queue/file-queue-process.test.js.map +1 -1
- package/dist/file-queue/with-skip-file-queue.d.ts +18 -0
- package/dist/file-queue/with-skip-file-queue.d.ts.map +1 -1
- package/dist/file-queue/with-skip-file-queue.js +56 -10
- package/dist/file-queue/with-skip-file-queue.js.map +1 -1
- package/dist/file-queue/with-skip-file-queue.test.js +28 -12
- package/dist/file-queue/with-skip-file-queue.test.js.map +1 -1
- package/dist/hooks/create-hooks.d.ts +4 -26
- package/dist/hooks/create-hooks.d.ts.map +1 -1
- package/dist/hooks/create-hooks.js +3 -7
- package/dist/hooks/create-hooks.js.map +1 -1
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/key-value/database-schema.d.ts +3 -2
- package/dist/key-value/database-schema.d.ts.map +1 -1
- package/dist/key-value/database-schema.js +3 -3
- package/dist/key-value/database-schema.test.js +13 -4
- package/dist/key-value/database-schema.test.js.map +1 -1
- package/dist/key-value/index.d.ts +1 -1
- package/dist/key-value/index.d.ts.map +1 -1
- package/dist/key-value/index.js.map +1 -1
- package/dist/key-value/schema.d.ts +63 -3
- package/dist/key-value/schema.d.ts.map +1 -1
- package/dist/key-value/schema.js +8 -2
- package/dist/key-value/schema.js.map +1 -1
- package/dist/key-value/schema.test.js +91 -2
- package/dist/key-value/schema.test.js.map +1 -1
- package/dist/key-value-v2/schema.d.ts +27 -0
- package/dist/key-value-v2/schema.d.ts.map +1 -0
- package/dist/key-value-v2/schema.js +73 -0
- package/dist/key-value-v2/schema.js.map +1 -0
- package/dist/key-value-v2/schema.test.d.ts +2 -0
- package/dist/key-value-v2/schema.test.d.ts.map +1 -0
- package/dist/key-value-v2/schema.test.js +144 -0
- package/dist/key-value-v2/schema.test.js.map +1 -0
- package/dist/label/create-label.d.ts +5 -5
- package/dist/label/create-label.d.ts.map +1 -1
- package/dist/label/create-label.js +2 -2
- package/dist/label/create-label.js.map +1 -1
- package/dist/label/index.d.ts +1 -1
- package/dist/label/index.d.ts.map +1 -1
- package/dist/label/index.js.map +1 -1
- package/dist/label/schema.d.ts +3 -3
- package/dist/label/schema.d.ts.map +1 -1
- package/dist/label/schema.js +4 -6
- package/dist/label/schema.js.map +1 -1
- package/dist/lix/close-lix.d.ts +1 -10
- package/dist/lix/close-lix.d.ts.map +1 -1
- package/dist/lix/close-lix.js +1 -10
- package/dist/lix/close-lix.js.map +1 -1
- package/dist/lix/merge.test.js +4 -1
- package/dist/lix/merge.test.js.map +1 -1
- package/dist/lix/new-lix.d.ts +4 -2
- package/dist/lix/new-lix.d.ts.map +1 -1
- package/dist/lix/new-lix.js +244 -60
- package/dist/lix/new-lix.js.map +1 -1
- package/dist/lix/new-lix.test.js +175 -1
- package/dist/lix/new-lix.test.js.map +1 -1
- package/dist/lix/open-lix-in-memory.d.ts +1 -9
- package/dist/lix/open-lix-in-memory.d.ts.map +1 -1
- package/dist/lix/open-lix-in-memory.js +7 -15
- package/dist/lix/open-lix-in-memory.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 +12 -13
- package/dist/lix/open-lix.d.ts.map +1 -1
- package/dist/lix/open-lix.js +147 -55
- package/dist/lix/open-lix.js.map +1 -1
- package/dist/lix/open-lix.test.js +242 -3
- package/dist/lix/open-lix.test.js.map +1 -1
- package/dist/lix/storage/in-memory.d.ts +7 -6
- package/dist/lix/storage/in-memory.d.ts.map +1 -1
- package/dist/lix/storage/in-memory.js +10 -17
- package/dist/lix/storage/in-memory.js.map +1 -1
- package/dist/lix/storage/in-memory.test.js +7 -68
- package/dist/lix/storage/in-memory.test.js.map +1 -1
- package/dist/lix/storage/lix-storage-adapter.d.ts +35 -5
- package/dist/lix/storage/lix-storage-adapter.d.ts.map +1 -1
- package/dist/lix/storage/opfs.d.ts +39 -10
- package/dist/lix/storage/opfs.d.ts.map +1 -1
- package/dist/lix/storage/opfs.js +148 -37
- package/dist/lix/storage/opfs.js.map +1 -1
- package/dist/lix/storage/opfs.test.js +203 -24
- package/dist/lix/storage/opfs.test.js.map +1 -1
- package/dist/lix/to-blob.d.ts +2 -9
- package/dist/lix/to-blob.d.ts.map +1 -1
- package/dist/lix/to-blob.js +2 -9
- package/dist/lix/to-blob.js.map +1 -1
- package/dist/log/create-lix-own-log.d.ts +9 -1
- package/dist/log/create-lix-own-log.d.ts.map +1 -1
- package/dist/log/create-lix-own-log.js +14 -25
- package/dist/log/create-lix-own-log.js.map +1 -1
- package/dist/log/create-lix-own-log.test.js +9 -5
- package/dist/log/create-lix-own-log.test.js.map +1 -1
- package/dist/log/create-log.d.ts +2 -2
- package/dist/log/create-log.d.ts.map +1 -1
- package/dist/log/create-log.js +2 -2
- package/dist/log/create-log.js.map +1 -1
- package/dist/log/database-schema.d.ts +33 -0
- package/dist/log/database-schema.d.ts.map +1 -0
- package/dist/log/database-schema.js +14 -0
- package/dist/log/database-schema.js.map +1 -0
- package/dist/log/database-schema.test.d.ts +2 -0
- package/dist/log/database-schema.test.d.ts.map +1 -0
- package/dist/log/database-schema.test.js +22 -0
- package/dist/log/database-schema.test.js.map +1 -0
- package/dist/log/index.d.ts +1 -1
- package/dist/log/index.d.ts.map +1 -1
- package/dist/log/index.js.map +1 -1
- package/dist/log/schema.d.ts +3 -3
- package/dist/log/schema.d.ts.map +1 -1
- package/dist/log/schema.js +4 -5
- package/dist/log/schema.js.map +1 -1
- package/dist/observe/create-observe.d.ts.map +1 -1
- package/dist/observe/create-observe.js +32 -3
- package/dist/observe/create-observe.js.map +1 -1
- package/dist/observe/create-observe.test.js +298 -44
- package/dist/observe/create-observe.test.js.map +1 -1
- package/dist/observe/determine-schema-keys.d.ts +6 -0
- package/dist/observe/determine-schema-keys.d.ts.map +1 -0
- package/dist/observe/determine-schema-keys.js +145 -0
- package/dist/observe/determine-schema-keys.js.map +1 -0
- package/dist/observe/determine-schema-keys.test.d.ts +2 -0
- package/dist/observe/determine-schema-keys.test.d.ts.map +1 -0
- package/dist/observe/determine-schema-keys.test.js +266 -0
- package/dist/observe/determine-schema-keys.test.js.map +1 -0
- package/dist/own-change-control/apply-own-change.d.ts +5 -1
- package/dist/own-change-control/apply-own-change.d.ts.map +1 -1
- package/dist/own-change-control/apply-own-change.js +26 -12
- package/dist/own-change-control/apply-own-change.js.map +1 -1
- package/dist/own-change-control/apply-own-change.test.js +86 -48
- package/dist/own-change-control/apply-own-change.test.js.map +1 -1
- package/dist/own-change-control/change-controlled-tables.d.ts +5 -7
- package/dist/own-change-control/change-controlled-tables.d.ts.map +1 -1
- package/dist/own-change-control/change-controlled-tables.js +27 -21
- package/dist/own-change-control/change-controlled-tables.js.map +1 -1
- package/dist/own-change-control/change-controlled-tables.test.js +35 -5
- package/dist/own-change-control/change-controlled-tables.test.js.map +1 -1
- package/dist/own-change-control/database-triggers.d.ts +2 -1
- package/dist/own-change-control/database-triggers.d.ts.map +1 -1
- package/dist/own-change-control/database-triggers.js +209 -67
- package/dist/own-change-control/database-triggers.js.map +1 -1
- package/dist/own-change-control/database-triggers.test.js +139 -8
- package/dist/own-change-control/database-triggers.test.js.map +1 -1
- package/dist/own-change-control/with-skip-own-change-control.d.ts.map +1 -1
- package/dist/own-change-control/with-skip-own-change-control.js +28 -6
- package/dist/own-change-control/with-skip-own-change-control.js.map +1 -1
- package/dist/own-change-control/with-skip-own-change-control.test.js +38 -1
- package/dist/own-change-control/with-skip-own-change-control.test.js.map +1 -1
- package/dist/plugin/lix-plugin.d.ts +3 -3
- package/dist/plugin/lix-plugin.d.ts.map +1 -1
- package/dist/plugin/load-plugin.d.ts.map +1 -1
- package/dist/plugin/load-plugin.js.map +1 -1
- package/dist/prototype/database-schema.d.ts +43 -0
- package/dist/prototype/database-schema.d.ts.map +1 -0
- package/dist/prototype/database-schema.js +72 -0
- package/dist/prototype/database-schema.js.map +1 -0
- package/dist/prototype/file-handlers.d.ts +24 -0
- package/dist/prototype/file-handlers.d.ts.map +1 -0
- package/dist/prototype/file-handlers.js +129 -0
- package/dist/prototype/file-handlers.js.map +1 -0
- package/dist/prototype/file-schema.d.ts +47 -0
- package/dist/prototype/file-schema.d.ts.map +1 -0
- package/dist/prototype/file-schema.js +135 -0
- package/dist/prototype/file-schema.js.map +1 -0
- package/dist/prototype/file-schema.test.d.ts +2 -0
- package/dist/prototype/file-schema.test.d.ts.map +1 -0
- package/dist/prototype/file-schema.test.js +146 -0
- package/dist/prototype/file-schema.test.js.map +1 -0
- package/dist/prototype/get-and-materialize-row.d.ts +5 -0
- package/dist/prototype/get-and-materialize-row.d.ts.map +1 -0
- package/dist/prototype/get-and-materialize-row.js +99 -0
- package/dist/prototype/get-and-materialize-row.js.map +1 -0
- package/dist/prototype/json-plugin.d.ts +49 -0
- package/dist/prototype/json-plugin.d.ts.map +1 -0
- package/dist/prototype/json-plugin.js +104 -0
- package/dist/prototype/json-plugin.js.map +1 -0
- package/dist/prototype/validate-file-path.d.ts +16 -0
- package/dist/prototype/validate-file-path.d.ts.map +1 -0
- package/dist/prototype/validate-file-path.js +44 -0
- package/dist/prototype/validate-file-path.js.map +1 -0
- package/dist/prototype/validate-file-path.test.d.ts +2 -0
- package/dist/prototype/validate-file-path.test.d.ts.map +1 -0
- package/dist/prototype/validate-file-path.test.js +36 -0
- package/dist/prototype/validate-file-path.test.js.map +1 -0
- package/dist/prototype/version-schema.d.ts +34 -0
- package/dist/prototype/version-schema.d.ts.map +1 -0
- package/dist/prototype/version-schema.js +86 -0
- package/dist/prototype/version-schema.js.map +1 -0
- package/dist/prototype/version-schema.test.d.ts +2 -0
- package/dist/prototype/version-schema.test.d.ts.map +1 -0
- package/dist/prototype/version-schema.test.js +114 -0
- package/dist/prototype/version-schema.test.js.map +1 -0
- package/dist/query-filter/change-conflict-in-version.d.ts +2 -0
- package/dist/query-filter/change-conflict-in-version.d.ts.map +1 -1
- package/dist/query-filter/change-conflict-in-version.js +2 -0
- package/dist/query-filter/change-conflict-in-version.js.map +1 -1
- package/dist/query-filter/change-in-version.d.ts +2 -0
- package/dist/query-filter/change-in-version.d.ts.map +1 -1
- package/dist/query-filter/change-in-version.js +2 -0
- package/dist/query-filter/change-in-version.js.map +1 -1
- package/dist/query-filter/change-is-leaf-in-version.d.ts +1 -0
- package/dist/query-filter/change-is-leaf-in-version.d.ts.map +1 -1
- package/dist/query-filter/change-is-leaf-in-version.js +1 -0
- package/dist/query-filter/change-is-leaf-in-version.js.map +1 -1
- package/dist/query-filter/change-is-leaf-of.d.ts +2 -0
- package/dist/query-filter/change-is-leaf-of.d.ts.map +1 -1
- package/dist/query-filter/change-is-leaf-of.js +2 -0
- package/dist/query-filter/change-is-leaf-of.js.map +1 -1
- package/dist/query-filter/change-is-leaf-v2.d.ts +69 -0
- package/dist/query-filter/change-is-leaf-v2.d.ts.map +1 -0
- package/dist/query-filter/change-is-leaf-v2.js +116 -0
- package/dist/query-filter/change-is-leaf-v2.js.map +1 -0
- package/dist/query-filter/change-is-leaf-v2.test.d.ts +2 -0
- package/dist/query-filter/change-is-leaf-v2.test.d.ts.map +1 -0
- package/dist/query-filter/change-is-leaf-v2.test.js +237 -0
- package/dist/query-filter/change-is-leaf-v2.test.js.map +1 -0
- package/dist/query-filter/change-is-leaf.d.ts +2 -0
- package/dist/query-filter/change-is-leaf.d.ts.map +1 -1
- package/dist/query-filter/change-is-leaf.js +2 -0
- package/dist/query-filter/change-is-leaf.js.map +1 -1
- package/dist/query-filter/change-is-lowest-common-ancestor-of.d.ts +2 -0
- package/dist/query-filter/change-is-lowest-common-ancestor-of.d.ts.map +1 -1
- package/dist/query-filter/change-is-lowest-common-ancestor-of.js +4 -0
- package/dist/query-filter/change-is-lowest-common-ancestor-of.js.map +1 -1
- package/dist/query-filter/change-is-lowest-common-ancestor-of.test.js +5 -3
- package/dist/query-filter/change-is-lowest-common-ancestor-of.test.js.map +1 -1
- package/dist/query-filter/change-set-element-in-ancestry-of.d.ts +10 -10
- package/dist/query-filter/change-set-element-in-ancestry-of.d.ts.map +1 -1
- package/dist/query-filter/change-set-element-in-ancestry-of.js +22 -17
- package/dist/query-filter/change-set-element-in-ancestry-of.js.map +1 -1
- package/dist/query-filter/change-set-element-in-ancestry-of.test.js +99 -26
- package/dist/query-filter/change-set-element-in-ancestry-of.test.js.map +1 -1
- package/dist/query-filter/change-set-element-in-symmetric-difference-of.d.ts +21 -0
- package/dist/query-filter/change-set-element-in-symmetric-difference-of.d.ts.map +1 -0
- package/dist/query-filter/change-set-element-in-symmetric-difference-of.js +37 -0
- package/dist/query-filter/change-set-element-in-symmetric-difference-of.js.map +1 -0
- package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.d.ts +2 -0
- package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.d.ts.map +1 -0
- package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.js +276 -0
- package/dist/query-filter/change-set-element-in-symmetric-difference-of.test.js.map +1 -0
- package/dist/query-filter/change-set-element-in-symmetric-difference.d.ts +2 -2
- package/dist/query-filter/change-set-element-in-symmetric-difference.d.ts.map +1 -1
- package/dist/query-filter/change-set-element-in-symmetric-difference.js.map +1 -1
- package/dist/query-filter/change-set-element-in-symmetric-difference.test.js.map +1 -1
- package/dist/query-filter/change-set-element-is-leaf-of.d.ts +11 -11
- package/dist/query-filter/change-set-element-is-leaf-of.d.ts.map +1 -1
- package/dist/query-filter/change-set-element-is-leaf-of.js +58 -36
- package/dist/query-filter/change-set-element-is-leaf-of.js.map +1 -1
- package/dist/query-filter/change-set-element-is-leaf-of.test.js +83 -24
- package/dist/query-filter/change-set-element-is-leaf-of.test.js.map +1 -1
- package/dist/query-filter/change-set-is-ancestor-of.d.ts +2 -2
- package/dist/query-filter/change-set-is-ancestor-of.d.ts.map +1 -1
- package/dist/query-filter/change-set-is-ancestor-of.js.map +1 -1
- package/dist/query-filter/change-set-is-descendant-of.d.ts +2 -2
- package/dist/query-filter/change-set-is-descendant-of.d.ts.map +1 -1
- package/dist/query-filter/change-set-is-descendant-of.js.map +1 -1
- package/dist/query-filter/commit-is-ancestor-of.d.ts +51 -0
- package/dist/query-filter/commit-is-ancestor-of.d.ts.map +1 -0
- package/dist/query-filter/commit-is-ancestor-of.js +63 -0
- package/dist/query-filter/commit-is-ancestor-of.js.map +1 -0
- package/dist/query-filter/commit-is-ancestor-of.test.d.ts +2 -0
- package/dist/query-filter/commit-is-ancestor-of.test.d.ts.map +1 -0
- package/dist/query-filter/commit-is-ancestor-of.test.js +292 -0
- package/dist/query-filter/commit-is-ancestor-of.test.js.map +1 -0
- package/dist/query-filter/commit-is-descendant-of.d.ts +44 -0
- package/dist/query-filter/commit-is-descendant-of.d.ts.map +1 -0
- package/dist/query-filter/commit-is-descendant-of.js +56 -0
- package/dist/query-filter/commit-is-descendant-of.js.map +1 -0
- package/dist/query-filter/commit-is-descendant-of.test.d.ts +2 -0
- package/dist/query-filter/commit-is-descendant-of.test.d.ts.map +1 -0
- package/dist/query-filter/commit-is-descendant-of.test.js +325 -0
- package/dist/query-filter/commit-is-descendant-of.test.js.map +1 -0
- package/dist/query-filter/index.d.ts +2 -4
- package/dist/query-filter/index.d.ts.map +1 -1
- package/dist/query-filter/index.js +2 -4
- package/dist/query-filter/index.js.map +1 -1
- package/dist/query-filter/version-change-in-difference.d.ts +2 -0
- package/dist/query-filter/version-change-in-difference.d.ts.map +1 -1
- package/dist/query-filter/version-change-in-difference.js +2 -0
- package/dist/query-filter/version-change-in-difference.js.map +1 -1
- package/dist/query-filter/version-change-in-symmetric-difference.d.ts +2 -0
- package/dist/query-filter/version-change-in-symmetric-difference.d.ts.map +1 -1
- package/dist/query-filter/version-change-in-symmetric-difference.js +2 -0
- package/dist/query-filter/version-change-in-symmetric-difference.js.map +1 -1
- package/dist/schema-definition/definition.d.ts +73 -30
- package/dist/schema-definition/definition.d.ts.map +1 -1
- package/dist/schema-definition/definition.js +38 -14
- package/dist/schema-definition/definition.js.map +1 -1
- package/dist/schema-definition/definition.test.js +70 -25
- package/dist/schema-definition/definition.test.js.map +1 -1
- package/dist/schema-definition/validate-lix-schema.d.ts.map +1 -1
- package/dist/schema-definition/validate-lix-schema.js.map +1 -1
- package/dist/schema-definition/validate-lix-schema.test.js +1 -1
- package/dist/schema-definition/validate-lix-schema.test.js.map +1 -1
- package/dist/server-protocol-handler/environment/create-in-memory-environment.test.js +2 -2
- package/dist/server-protocol-handler/environment/create-in-memory-environment.test.js.map +1 -1
- package/dist/server-protocol-handler/routes/push-v1.test.js +1 -1
- package/dist/server-protocol-handler/routes/push-v1.test.js.map +1 -1
- package/dist/services/env-variables/index.js +1 -1
- package/dist/services/env-variables/index.js.map +1 -1
- package/dist/snapshot/create-snapshot.d.ts +2 -2
- package/dist/snapshot/create-snapshot.d.ts.map +1 -1
- package/dist/snapshot/create-snapshot.test.js +3 -3
- package/dist/snapshot/create-snapshot.test.js.map +1 -1
- package/dist/snapshot/database-schema.d.ts +19 -0
- package/dist/snapshot/database-schema.d.ts.map +1 -0
- package/dist/snapshot/database-schema.js +33 -0
- package/dist/snapshot/database-schema.js.map +1 -0
- package/dist/snapshot/database-schema.test.d.ts +2 -0
- package/dist/snapshot/database-schema.test.d.ts.map +1 -0
- package/dist/snapshot/database-schema.test.js +58 -0
- package/dist/snapshot/database-schema.test.js.map +1 -0
- package/dist/snapshot/schema.d.ts.map +1 -1
- package/dist/snapshot/schema.js +10 -2
- package/dist/snapshot/schema.js.map +1 -1
- package/dist/snapshot/schema.test.js +86 -0
- package/dist/snapshot/schema.test.js.map +1 -1
- package/dist/state/cache/clear-state-cache.d.ts +8 -0
- package/dist/state/cache/clear-state-cache.d.ts.map +1 -0
- package/dist/state/cache/clear-state-cache.js +14 -0
- package/dist/state/cache/clear-state-cache.js.map +1 -0
- package/dist/state/cache/clear-state-cache.test.d.ts +2 -0
- package/dist/state/cache/clear-state-cache.test.d.ts.map +1 -0
- package/dist/state/cache/clear-state-cache.test.js +34 -0
- package/dist/state/cache/clear-state-cache.test.js.map +1 -0
- package/dist/state/cache/is-stale-state-cache.d.ts +5 -0
- package/dist/state/cache/is-stale-state-cache.d.ts.map +1 -0
- package/dist/state/cache/is-stale-state-cache.js +22 -0
- package/dist/state/cache/is-stale-state-cache.js.map +1 -0
- package/dist/state/cache/is-stale-state-cache.test.d.ts +2 -0
- package/dist/state/cache/is-stale-state-cache.test.d.ts.map +1 -0
- package/dist/state/cache/is-stale-state-cache.test.js +27 -0
- package/dist/state/cache/is-stale-state-cache.test.js.map +1 -0
- package/dist/state/cache/mark-state-cache-as-stale.d.ts +10 -0
- package/dist/state/cache/mark-state-cache-as-stale.d.ts.map +1 -0
- package/dist/state/cache/mark-state-cache-as-stale.js +42 -0
- package/dist/state/cache/mark-state-cache-as-stale.js.map +1 -0
- package/dist/state/cache/populate-state-cache.d.ts +9 -0
- package/dist/state/cache/populate-state-cache.d.ts.map +1 -0
- package/dist/state/cache/populate-state-cache.js +106 -0
- package/dist/state/cache/populate-state-cache.js.map +1 -0
- package/dist/state/cache/populate-state-cache.test.d.ts +2 -0
- package/dist/state/cache/populate-state-cache.test.d.ts.map +1 -0
- package/dist/state/cache/populate-state-cache.test.js +204 -0
- package/dist/state/cache/populate-state-cache.test.js.map +1 -0
- package/dist/state/cache/schema.d.ts +20 -0
- package/dist/state/cache/schema.d.ts.map +1 -0
- package/dist/state/cache/schema.js +21 -0
- package/dist/state/cache/schema.js.map +1 -0
- package/dist/state/cache/update-state-cache.d.ts +21 -0
- package/dist/state/cache/update-state-cache.d.ts.map +1 -0
- package/dist/state/cache/update-state-cache.js +294 -0
- package/dist/state/cache/update-state-cache.js.map +1 -0
- package/dist/state/cache/update-state-cache.test.d.ts +2 -0
- package/dist/state/cache/update-state-cache.test.d.ts.map +1 -0
- package/dist/state/cache/update-state-cache.test.js +440 -0
- package/dist/state/cache/update-state-cache.test.js.map +1 -0
- package/dist/state/commit.d.ts +18 -0
- package/dist/state/commit.d.ts.map +1 -0
- package/dist/state/commit.js +457 -0
- package/dist/state/commit.js.map +1 -0
- package/dist/state/commit.test.d.ts +2 -0
- package/dist/state/commit.test.d.ts.map +1 -0
- package/dist/state/commit.test.js +1173 -0
- package/dist/state/commit.test.js.map +1 -0
- package/dist/state/get-version-record-by-id-or-throw.d.ts +2 -2
- package/dist/state/get-version-record-by-id-or-throw.d.ts.map +1 -1
- package/dist/state/get-version-record-by-id-or-throw.js.map +1 -1
- package/dist/state/handle-state-mutation.d.ts +0 -12
- package/dist/state/handle-state-mutation.d.ts.map +1 -1
- package/dist/state/handle-state-mutation.js +11 -206
- package/dist/state/handle-state-mutation.js.map +1 -1
- package/dist/state/handle-state-mutation.test.js +213 -159
- package/dist/state/handle-state-mutation.test.js.map +1 -1
- package/dist/state/insert-transaction-state.d.ts +71 -0
- package/dist/state/insert-transaction-state.d.ts.map +1 -0
- package/dist/state/insert-transaction-state.js +272 -0
- package/dist/state/insert-transaction-state.js.map +1 -0
- package/dist/state/insert-transaction-state.test.d.ts +2 -0
- package/dist/state/insert-transaction-state.test.d.ts.map +1 -0
- package/dist/state/insert-transaction-state.test.js +789 -0
- package/dist/state/insert-transaction-state.test.js.map +1 -0
- package/dist/state/materialize-state.d.ts +3 -0
- package/dist/state/materialize-state.d.ts.map +1 -0
- package/dist/state/materialize-state.js +230 -0
- package/dist/state/materialize-state.js.map +1 -0
- package/dist/state/materialize-state.test.d.ts +2 -0
- package/dist/state/materialize-state.test.d.ts.map +1 -0
- package/dist/state/materialize-state.test.js +1934 -0
- package/dist/state/materialize-state.test.js.map +1 -0
- package/dist/state/primary-key.d.ts +39 -0
- package/dist/state/primary-key.d.ts.map +1 -0
- package/dist/state/primary-key.js +62 -0
- package/dist/state/primary-key.js.map +1 -0
- package/dist/state/primary-key.test.d.ts +2 -0
- package/dist/state/primary-key.test.d.ts.map +1 -0
- package/dist/state/primary-key.test.js +114 -0
- package/dist/state/primary-key.test.js.map +1 -0
- package/dist/state/resolved-state-view.d.ts +33 -0
- package/dist/state/resolved-state-view.d.ts.map +1 -0
- package/dist/state/resolved-state-view.js +182 -0
- package/dist/state/resolved-state-view.js.map +1 -0
- package/dist/state/resolved-state-view.test.d.ts +2 -0
- package/dist/state/resolved-state-view.test.d.ts.map +1 -0
- package/dist/state/resolved-state-view.test.js +433 -0
- package/dist/state/resolved-state-view.test.js.map +1 -0
- package/dist/state/schema.d.ts +6 -19
- package/dist/state/schema.d.ts.map +1 -1
- package/dist/state/schema.js +533 -796
- package/dist/state/schema.js.map +1 -1
- package/dist/state/schema.test.js +1684 -1013
- package/dist/state/schema.test.js.map +1 -1
- package/dist/state/untracked/schema.d.ts +25 -0
- package/dist/state/untracked/schema.d.ts.map +1 -0
- package/dist/state/untracked/schema.js +38 -0
- package/dist/state/untracked/schema.js.map +1 -0
- package/dist/state/untracked/schema.test.d.ts +2 -0
- package/dist/state/untracked/schema.test.d.ts.map +1 -0
- package/dist/state/untracked/schema.test.js +275 -0
- package/dist/state/untracked/schema.test.js.map +1 -0
- package/dist/state/untracked/update-untracked-state.d.ts +36 -0
- package/dist/state/untracked/update-untracked-state.d.ts.map +1 -0
- package/dist/state/untracked/update-untracked-state.js +113 -0
- package/dist/state/untracked/update-untracked-state.js.map +1 -0
- package/dist/state/untracked/update-untracked-state.test.d.ts +2 -0
- package/dist/state/untracked/update-untracked-state.test.d.ts.map +1 -0
- package/dist/state/untracked/update-untracked-state.test.js +417 -0
- package/dist/state/untracked/update-untracked-state.test.js.map +1 -0
- package/dist/state/validate-snapshot-content.d.ts +9 -0
- package/dist/state/validate-snapshot-content.d.ts.map +1 -0
- package/dist/state/validate-snapshot-content.js +42 -0
- package/dist/state/validate-snapshot-content.js.map +1 -0
- package/dist/state/validate-snapshot-content.test.d.ts +2 -0
- package/dist/state/validate-snapshot-content.test.d.ts.map +1 -0
- package/dist/state/validate-snapshot-content.test.js +67 -0
- package/dist/state/validate-snapshot-content.test.js.map +1 -0
- package/dist/state/validate-state-mutation.d.ts +2 -2
- package/dist/state/validate-state-mutation.d.ts.map +1 -1
- package/dist/state/validate-state-mutation.js +211 -51
- package/dist/state/validate-state-mutation.js.map +1 -1
- package/dist/state/validate-state-mutation.test.js +910 -75
- package/dist/state/validate-state-mutation.test.js.map +1 -1
- package/dist/state-history/schema.d.ts +29 -19
- package/dist/state-history/schema.d.ts.map +1 -1
- package/dist/state-history/schema.js +49 -37
- package/dist/state-history/schema.js.map +1 -1
- package/dist/state-history/schema.test.js +221 -67
- package/dist/state-history/schema.test.js.map +1 -1
- package/dist/stored-schema/index.d.ts +1 -1
- package/dist/stored-schema/index.d.ts.map +1 -1
- package/dist/stored-schema/index.js +1 -1
- package/dist/stored-schema/index.js.map +1 -1
- package/dist/stored-schema/schema.d.ts +1 -1
- package/dist/stored-schema/schema.d.ts.map +1 -1
- package/dist/stored-schema/schema.test.js.map +1 -1
- package/dist/sync/push-to-server.test.js.map +1 -1
- package/dist/test-utilities/simulation-test/cache-miss-simulation.d.ts +8 -0
- package/dist/test-utilities/simulation-test/cache-miss-simulation.d.ts.map +1 -0
- package/dist/test-utilities/simulation-test/cache-miss-simulation.js +79 -0
- package/dist/test-utilities/simulation-test/cache-miss-simulation.js.map +1 -0
- package/dist/test-utilities/simulation-test/cache-miss-simulation.test.d.ts +2 -0
- package/dist/test-utilities/simulation-test/cache-miss-simulation.test.d.ts.map +1 -0
- package/dist/test-utilities/simulation-test/cache-miss-simulation.test.js +127 -0
- package/dist/test-utilities/simulation-test/cache-miss-simulation.test.js.map +1 -0
- package/dist/test-utilities/simulation-test/chaotic-timestamp-simulation.d.ts +2 -0
- package/dist/test-utilities/simulation-test/chaotic-timestamp-simulation.d.ts.map +1 -0
- package/dist/test-utilities/simulation-test/chaotic-timestamp-simulation.js +2 -0
- package/dist/test-utilities/simulation-test/chaotic-timestamp-simulation.js.map +1 -0
- package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.d.ts +10 -0
- package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.d.ts.map +1 -0
- package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.js +52 -0
- package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.js.map +1 -0
- package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.d.ts +2 -0
- package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.d.ts.map +1 -0
- package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.js +71 -0
- package/dist/test-utilities/simulation-test/out-of-order-sequence-simulation.test.js.map +1 -0
- package/dist/test-utilities/simulation-test/simulation-test.d.ts +82 -0
- package/dist/test-utilities/simulation-test/simulation-test.d.ts.map +1 -0
- package/dist/test-utilities/simulation-test/simulation-test.js +85 -0
- package/dist/test-utilities/simulation-test/simulation-test.js.map +1 -0
- package/dist/test-utilities/simulation-test/simulation-test.test.d.ts +2 -0
- package/dist/test-utilities/simulation-test/simulation-test.test.d.ts.map +1 -0
- package/dist/test-utilities/simulation-test/simulation-test.test.js +310 -0
- package/dist/test-utilities/simulation-test/simulation-test.test.js.map +1 -0
- package/dist/thread/comment-utils.d.ts +2 -0
- package/dist/thread/comment-utils.d.ts.map +1 -0
- package/dist/thread/comment-utils.js +2 -0
- package/dist/thread/comment-utils.js.map +1 -0
- package/dist/thread/comment.d.ts +24 -0
- package/dist/thread/comment.d.ts.map +1 -0
- package/dist/thread/comment.js +43 -0
- package/dist/thread/comment.js.map +1 -0
- package/dist/thread/create-thread-comment.d.ts +2 -2
- package/dist/thread/create-thread-comment.d.ts.map +1 -1
- package/dist/thread/create-thread-comment.js +20 -3
- package/dist/thread/create-thread-comment.js.map +1 -1
- package/dist/thread/create-thread-comment.test.js +49 -3
- package/dist/thread/create-thread-comment.test.js.map +1 -1
- package/dist/thread/create-thread.d.ts +18 -4
- package/dist/thread/create-thread.d.ts.map +1 -1
- package/dist/thread/create-thread.js +24 -3
- package/dist/thread/create-thread.js.map +1 -1
- package/dist/thread/create-thread.test.js +149 -0
- package/dist/thread/create-thread.test.js.map +1 -1
- package/dist/thread/database-schema.d.ts +20 -0
- package/dist/thread/database-schema.d.ts.map +1 -0
- package/dist/thread/database-schema.js +57 -0
- package/dist/thread/database-schema.js.map +1 -0
- package/dist/thread/database-schema.test.d.ts +2 -0
- package/dist/thread/database-schema.test.d.ts.map +1 -0
- package/dist/thread/database-schema.test.js +59 -0
- package/dist/thread/database-schema.test.js.map +1 -0
- package/dist/thread/index.d.ts +2 -1
- package/dist/thread/index.d.ts.map +1 -1
- package/dist/thread/schema.d.ts +13 -10
- package/dist/thread/schema.d.ts.map +1 -1
- package/dist/thread/schema.js +20 -14
- package/dist/thread/schema.js.map +1 -1
- package/dist/thread/schema.test.js +65 -0
- package/dist/thread/schema.test.js.map +1 -1
- package/dist/version/create-version.d.ts +14 -9
- package/dist/version/create-version.d.ts.map +1 -1
- package/dist/version/create-version.js +40 -12
- package/dist/version/create-version.js.map +1 -1
- package/dist/version/create-version.test.js +80 -25
- package/dist/version/create-version.test.js.map +1 -1
- package/dist/version/database-schema.d.ts +21 -0
- package/dist/version/database-schema.d.ts.map +1 -0
- package/dist/version/database-schema.js +169 -0
- package/dist/version/database-schema.js.map +1 -0
- package/dist/version/database-schema.test.d.ts +2 -0
- package/dist/version/database-schema.test.d.ts.map +1 -0
- package/dist/version/database-schema.test.js +625 -0
- package/dist/version/database-schema.test.js.map +1 -0
- package/dist/version/index.d.ts +1 -1
- package/dist/version/index.d.ts.map +1 -1
- package/dist/version/merge-version.d.ts +3 -0
- package/dist/version/merge-version.d.ts.map +1 -1
- package/dist/version/merge-version.js +3 -0
- package/dist/version/merge-version.js.map +1 -1
- package/dist/version/merge-version.test.js +10 -5
- package/dist/version/merge-version.test.js.map +1 -1
- package/dist/version/schema.d.ts +28 -23
- package/dist/version/schema.d.ts.map +1 -1
- package/dist/version/schema.js +42 -30
- package/dist/version/schema.js.map +1 -1
- package/dist/version/schema.test.js +311 -88
- package/dist/version/schema.test.js.map +1 -1
- package/dist/version/select-active-version.d.ts +7 -0
- package/dist/version/select-active-version.d.ts.map +1 -0
- package/dist/version/select-active-version.js +7 -0
- package/dist/version/select-active-version.js.map +1 -0
- package/dist/version/switch-version.d.ts +3 -3
- package/dist/version/switch-version.d.ts.map +1 -1
- package/dist/version/switch-version.js +1 -1
- package/dist/version/switch-version.test.js +1 -1
- package/dist/version/switch-version.test.js.map +1 -1
- package/dist/version/update-changes-in-version.d.ts +2 -0
- package/dist/version/update-changes-in-version.d.ts.map +1 -1
- package/dist/version/update-changes-in-version.js +2 -0
- package/dist/version/update-changes-in-version.js.map +1 -1
- package/dist/version-v2/create-version.d.ts +18 -0
- package/dist/version-v2/create-version.d.ts.map +1 -0
- package/dist/version-v2/create-version.js +35 -0
- package/dist/version-v2/create-version.js.map +1 -0
- package/dist/version-v2/create-version.test.d.ts +2 -0
- package/dist/version-v2/create-version.test.d.ts.map +1 -0
- package/dist/version-v2/create-version.test.js +88 -0
- package/dist/version-v2/create-version.test.js.map +1 -0
- package/dist/version-v2/database-schema.d.ts +21 -0
- package/dist/version-v2/database-schema.d.ts.map +1 -0
- package/dist/version-v2/database-schema.js +169 -0
- package/dist/version-v2/database-schema.js.map +1 -0
- package/dist/version-v2/database-schema.test.d.ts +2 -0
- package/dist/version-v2/database-schema.test.d.ts.map +1 -0
- package/dist/version-v2/database-schema.test.js +625 -0
- package/dist/version-v2/database-schema.test.js.map +1 -0
- package/dist/version-v2/index.d.ts +2 -0
- package/dist/version-v2/index.d.ts.map +1 -0
- package/dist/version-v2/index.js +2 -0
- package/dist/version-v2/index.js.map +1 -0
- package/dist/version-v2/swich-version.d.ts +27 -0
- package/dist/version-v2/swich-version.d.ts.map +1 -0
- package/dist/version-v2/swich-version.js +46 -0
- package/dist/version-v2/swich-version.js.map +1 -0
- package/dist/version-v2/switch-version.d.ts +27 -0
- package/dist/version-v2/switch-version.d.ts.map +1 -0
- package/dist/version-v2/switch-version.js +91 -0
- package/dist/version-v2/switch-version.js.map +1 -0
- package/dist/version-v2/switch-version.test.d.ts +2 -0
- package/dist/version-v2/switch-version.test.d.ts.map +1 -0
- package/dist/version-v2/switch-version.test.js +110 -0
- package/dist/version-v2/switch-version.test.js.map +1 -0
- package/dist/version-v2/with-skip-update-working-change-set.d.ts +3 -0
- package/dist/version-v2/with-skip-update-working-change-set.d.ts.map +1 -0
- package/dist/version-v2/with-skip-update-working-change-set.js +50 -0
- package/dist/version-v2/with-skip-update-working-change-set.js.map +1 -0
- package/dist/version-v2/with-skip-update-working-change-set.test.d.ts +2 -0
- package/dist/version-v2/with-skip-update-working-change-set.test.d.ts.map +1 -0
- package/dist/version-v2/with-skip-update-working-change-set.test.js +49 -0
- package/dist/version-v2/with-skip-update-working-change-set.test.js.map +1 -0
- package/package.json +3 -3
- package/src/account/create-account.ts +7 -7
- package/src/account/index.ts +2 -2
- package/src/account/schema.test.ts +99 -99
- package/src/account/schema.ts +91 -35
- package/src/account/switch-account.test.ts +4 -4
- package/src/account/switch-account.ts +6 -6
- package/src/change/index.ts +4 -1
- package/src/change/schema.test.ts +38 -0
- package/src/change/schema.ts +91 -11
- package/src/change-author/index.ts +4 -1
- package/src/change-author/schema.test.ts +306 -242
- package/src/change-author/schema.ts +18 -12
- package/src/change-proposal/create-change-proposal.ts +3 -3
- package/src/change-proposal/database-schema.ts +1 -1
- package/src/change-set/apply-change-set.test.ts +10 -7
- package/src/change-set/apply-change-set.ts +44 -56
- package/src/change-set/create-change-set.test.ts +0 -39
- package/src/change-set/create-change-set.ts +9 -33
- package/src/change-set/index.ts +3 -11
- package/src/change-set/schema.test.ts +0 -310
- package/src/change-set/schema.ts +43 -100
- package/src/commit/apply-commit.test.ts +426 -0
- package/src/commit/apply-commit.ts +74 -0
- package/src/{change-set → commit}/create-checkpoint.test.ts +244 -26
- package/src/commit/create-checkpoint.ts +140 -0
- package/src/commit/create-commit.ts +80 -0
- package/src/{change-set/create-merge-change-set.test.ts → commit/create-merge-commit.test.ts} +50 -19
- package/src/{change-set/create-merge-change-set.ts → commit/create-merge-commit.ts} +55 -16
- package/src/{change-set/create-transition-change-set.test.ts → commit/create-transition-commit.test.ts} +43 -32
- package/src/{change-set/create-transition-change-set.ts → commit/create-transition-commit.ts} +60 -22
- package/src/{change-set/create-undo-change-set.test.ts → commit/create-undo-commit.test.ts} +52 -23
- package/src/{change-set/create-undo-change-set.ts → commit/create-undo-commit.ts} +59 -26
- package/src/commit/index.ts +11 -0
- package/src/commit/schema.test.ts +257 -0
- package/src/commit/schema.ts +104 -0
- package/src/database/index.ts +0 -2
- package/src/database/init-db.ts +113 -45
- package/src/database/kysely-plugin/json-column-plugin.test.ts +404 -0
- package/src/database/kysely-plugin/json-column-plugin.ts +80 -15
- package/src/database/nano-id.test.ts +3 -3
- package/src/database/nano-id.ts +4 -1
- package/src/database/schema.ts +26 -24
- package/src/deterministic/generate-human-id.test.ts +154 -0
- package/src/deterministic/generate-human-id.ts +94 -0
- package/src/deterministic/index.ts +7 -0
- package/src/deterministic/is-deterministic-mode.test.ts +133 -0
- package/src/deterministic/is-deterministic-mode.ts +32 -0
- package/src/deterministic/nano-id.test.ts +200 -0
- package/src/deterministic/nano-id.ts +188 -0
- package/src/deterministic/options.test.ts +157 -0
- package/src/deterministic/options.ts +62 -0
- package/src/deterministic/random.test.ts +293 -0
- package/src/deterministic/random.ts +261 -0
- package/src/deterministic/sequence.test.ts +93 -0
- package/src/deterministic/sequence.ts +132 -0
- package/src/deterministic/timestamp.test.ts +170 -0
- package/src/deterministic/timestamp.ts +83 -0
- package/src/deterministic/uuid-v7.test.ts +144 -0
- package/src/deterministic/uuid-v7.ts +82 -0
- package/src/entity/eb-entity.test.ts +687 -0
- package/src/entity/eb-entity.ts +203 -0
- package/src/entity/index.ts +12 -0
- package/src/entity/label/create-entity-label.test.ts +316 -0
- package/src/entity/label/create-entity-label.ts +113 -0
- package/src/entity/label/schema.test.ts +692 -0
- package/src/entity/label/schema.ts +55 -0
- package/src/entity/schema.ts +22 -0
- package/src/entity/thread/create-entity-thread.test.ts +282 -0
- package/src/entity/thread/create-entity-thread.ts +134 -0
- package/src/entity/thread/query-threads.test.ts +394 -0
- package/src/entity/thread/schema.test.ts +170 -0
- package/src/entity/thread/schema.ts +55 -0
- package/src/entity-views/README.md +214 -0
- package/src/entity-views/entity-state-all.test.ts +202 -0
- package/src/entity-views/entity-state-all.ts +80 -11
- package/src/entity-views/entity-state-history.test.ts +78 -16
- package/src/entity-views/entity-state-history.ts +68 -19
- package/src/entity-views/entity-state.test.ts +141 -1
- package/src/entity-views/entity-state.ts +79 -10
- package/src/entity-views/entity-view-builder.test.ts +6 -6
- package/src/entity-views/types.ts +2 -2
- package/src/file/file-handlers.test.ts +4 -4
- package/src/file/file-handlers.ts +40 -0
- package/src/file/materialize-file-data-at-commit.ts +157 -0
- package/src/file/schema.test.ts +693 -37
- package/src/file/schema.ts +183 -56
- package/src/hooks/create-hooks.ts +7 -40
- package/src/index.ts +3 -0
- package/src/key-value/index.ts +1 -1
- package/src/key-value/schema.test.ts +103 -2
- package/src/key-value/schema.ts +66 -5
- package/src/label/create-label.ts +7 -7
- package/src/label/index.ts +1 -1
- package/src/label/schema.ts +7 -10
- package/src/lix/new-lix.test.ts +202 -2
- package/src/lix/new-lix.ts +305 -81
- package/src/lix/open-lix.test.ts +308 -5
- package/src/lix/open-lix.ts +169 -68
- package/src/lix/storage/in-memory.test.ts +9 -83
- package/src/lix/storage/in-memory.ts +13 -18
- package/src/lix/storage/lix-storage-adapter.ts +41 -5
- package/src/lix/storage/opfs.test.ts +254 -31
- package/src/lix/storage/opfs.ts +178 -40
- package/src/log/create-lix-own-log.test.ts +11 -7
- package/src/log/create-lix-own-log.ts +21 -32
- package/src/log/create-log.ts +4 -4
- package/src/log/index.ts +1 -1
- package/src/log/schema.ts +6 -10
- package/src/observe/create-observe.test.ts +395 -60
- package/src/observe/create-observe.ts +41 -3
- package/src/observe/determine-schema-keys.test.ts +371 -0
- package/src/observe/determine-schema-keys.ts +165 -0
- package/src/plugin/lix-plugin.ts +3 -3
- package/src/query-filter/change-set-element-in-ancestry-of.test.ts +112 -26
- package/src/query-filter/change-set-element-in-ancestry-of.ts +25 -20
- package/src/query-filter/change-set-element-in-symmetric-difference.test.ts +6 -6
- package/src/query-filter/change-set-element-in-symmetric-difference.ts +3 -3
- package/src/query-filter/change-set-element-is-leaf-of.test.ts +83 -24
- package/src/query-filter/change-set-element-is-leaf-of.ts +61 -39
- package/src/query-filter/commit-is-ancestor-of.test.ts +333 -0
- package/src/query-filter/commit-is-ancestor-of.ts +77 -0
- package/src/query-filter/commit-is-descendant-of.test.ts +365 -0
- package/src/query-filter/commit-is-descendant-of.ts +70 -0
- package/src/query-filter/index.ts +2 -4
- package/src/schema-definition/definition.test.ts +73 -25
- package/src/schema-definition/definition.ts +87 -30
- package/src/schema-definition/index.ts +1 -1
- package/src/schema-definition/validate-lix-schema.test.ts +14 -5
- package/src/schema-definition/validate-lix-schema.ts +9 -13
- package/src/server-protocol-handler/environment/create-in-memory-environment.test.ts +2 -2
- package/src/server-protocol-handler/routes/push-v1.test.ts +1 -1
- package/src/snapshot/schema.test.ts +113 -0
- package/src/snapshot/schema.ts +10 -2
- package/src/state/README.md +95 -0
- package/src/state/cache/clear-state-cache.test.ts +43 -0
- package/src/state/cache/clear-state-cache.ts +16 -0
- package/src/state/cache/is-stale-state-cache.test.ts +35 -0
- package/src/state/cache/is-stale-state-cache.ts +29 -0
- package/src/state/cache/mark-state-cache-as-stale.ts +53 -0
- package/src/state/cache/populate-state-cache.test.ts +259 -0
- package/src/state/cache/populate-state-cache.ts +124 -0
- package/src/state/cache/schema.ts +41 -0
- package/src/state/cache/update-state-cache.test.ts +510 -0
- package/src/state/cache/update-state-cache.ts +317 -0
- package/src/state/commit.test.ts +1402 -0
- package/src/state/commit.ts +587 -0
- package/src/state/insert-transaction-state.test.ts +928 -0
- package/src/state/insert-transaction-state.ts +306 -0
- package/src/state/materialize-state.test.ts +2358 -0
- package/src/state/materialize-state.ts +235 -0
- package/src/state/primary-key.test.ts +158 -0
- package/src/state/primary-key.ts +80 -0
- package/src/state/resolved-state-view.test.ts +521 -0
- package/src/state/resolved-state-view.ts +202 -0
- package/src/state/schema.test.ts +3116 -2272
- package/src/state/schema.ts +614 -910
- package/src/state/untracked/schema.test.ts +301 -0
- package/src/state/untracked/schema.ts +55 -0
- package/src/state/untracked/update-untracked-state.test.ts +466 -0
- package/src/state/untracked/update-untracked-state.ts +133 -0
- package/src/state/validate-state-mutation.test.ts +1032 -77
- package/src/state/validate-state-mutation.ts +270 -68
- package/src/state-history/schema.test.ts +246 -71
- package/src/state-history/schema.ts +78 -55
- package/src/stored-schema/index.ts +4 -1
- package/src/stored-schema/schema.test.ts +7 -7
- package/src/stored-schema/schema.ts +1 -1
- package/src/sync/push-to-server.test.ts +6 -6
- package/src/test-utilities/simulation-test/cache-miss-simulation.test.ts +162 -0
- package/src/test-utilities/simulation-test/cache-miss-simulation.ts +99 -0
- package/src/test-utilities/simulation-test/chaotic-timestamp-simulation.ts +0 -0
- package/src/test-utilities/simulation-test/out-of-order-sequence-simulation.test.ts +88 -0
- package/src/test-utilities/simulation-test/out-of-order-sequence-simulation.ts +69 -0
- package/src/test-utilities/simulation-test/simulation-test.test.ts +400 -0
- package/src/test-utilities/simulation-test/simulation-test.ts +176 -0
- package/src/thread/create-thread-comment.test.ts +62 -3
- package/src/thread/create-thread-comment.ts +34 -6
- package/src/thread/create-thread.test.ts +180 -0
- package/src/thread/create-thread.ts +32 -7
- package/src/thread/index.ts +3 -2
- package/src/thread/schema.test.ts +81 -0
- package/src/thread/schema.ts +24 -19
- package/src/version/create-version.test.ts +92 -26
- package/src/version/create-version.ts +49 -19
- package/src/version/index.ts +2 -2
- package/src/version/schema.test.ts +328 -92
- package/src/version/schema.ts +47 -33
- package/src/version/select-active-version.ts +18 -0
- package/src/version/switch-version.test.ts +1 -1
- package/src/version/switch-version.ts +3 -3
- package/dist/entity-views/entity-state_history.d.ts +0 -67
- package/dist/entity-views/entity-state_history.d.ts.map +0 -1
- package/dist/entity-views/entity-state_history.js +0 -58
- package/dist/entity-views/entity-state_history.js.map +0 -1
- package/dist/entity-views/generic-types.d.ts +0 -128
- package/dist/entity-views/generic-types.d.ts.map +0 -1
- package/dist/entity-views/generic-types.js +0 -2
- package/dist/entity-views/generic-types.js.map +0 -1
- package/dist/entity-views/generic-types.test.d.ts +0 -2
- package/dist/entity-views/generic-types.test.d.ts.map +0 -1
- package/dist/entity-views/generic-types.test.js +0 -99
- package/dist/entity-views/generic-types.test.js.map +0 -1
- package/dist/lix/to-blob.test.d.ts +0 -2
- package/dist/lix/to-blob.test.d.ts.map +0 -1
- package/dist/lix/to-blob.test.js +0 -18
- package/dist/lix/to-blob.test.js.map +0 -1
- package/dist/repository/comparison-example.js +0 -173
- package/dist/repository/comparison-example.js.map +0 -1
- package/dist/repository/entity-repository.d.ts +0 -53
- package/dist/repository/entity-repository.d.ts.map +0 -1
- package/dist/repository/entity-repository.js +0 -187
- package/dist/repository/entity-repository.js.map +0 -1
- package/dist/repository/entity-repository.test.d.ts +0 -2
- package/dist/repository/entity-repository.test.d.ts.map +0 -1
- package/dist/repository/entity-repository.test.js +0 -94
- package/dist/repository/entity-repository.test.js.map +0 -1
- package/dist/repository/example.d.ts +0 -6
- package/dist/repository/example.d.ts.map +0 -1
- package/dist/repository/example.js +0 -87
- package/dist/repository/example.js.map +0 -1
- package/dist/repository/file-repository.d.ts +0 -39
- package/dist/repository/file-repository.d.ts.map +0 -1
- package/dist/repository/file-repository.js +0 -93
- package/dist/repository/file-repository.js.map +0 -1
- package/dist/repository/file-repository.test.d.ts +0 -2
- package/dist/repository/file-repository.test.d.ts.map +0 -1
- package/dist/repository/file-repository.test.js +0 -165
- package/dist/repository/file-repository.test.js.map +0 -1
- package/dist/repository/index.d.ts +0 -6
- package/dist/repository/index.d.ts.map +0 -1
- package/dist/repository/index.js +0 -6
- package/dist/repository/index.js.map +0 -1
- package/dist/repository/integration.test.d.ts +0 -2
- package/dist/repository/integration.test.d.ts.map +0 -1
- package/dist/repository/integration.test.js +0 -136
- package/dist/repository/integration.test.js.map +0 -1
- package/dist/repository/key-value-repository.d.ts +0 -30
- package/dist/repository/key-value-repository.d.ts.map +0 -1
- package/dist/repository/key-value-repository.js +0 -60
- package/dist/repository/key-value-repository.js.map +0 -1
- package/dist/repository/key-value-repository.test.d.ts +0 -2
- package/dist/repository/key-value-repository.test.d.ts.map +0 -1
- package/dist/repository/key-value-repository.test.js +0 -122
- package/dist/repository/key-value-repository.test.js.map +0 -1
- package/dist/repository/markdown-plugin-example.js +0 -118
- package/dist/repository/markdown-plugin-example.js.map +0 -1
- package/dist/repository/query-builder.d.ts +0 -69
- package/dist/repository/query-builder.d.ts.map +0 -1
- package/dist/repository/query-builder.js +0 -155
- package/dist/repository/query-builder.js.map +0 -1
- package/dist/repository/query-builder.test.d.ts +0 -2
- package/dist/repository/query-builder.test.d.ts.map +0 -1
- package/dist/repository/query-builder.test.js +0 -244
- package/dist/repository/query-builder.test.js.map +0 -1
- package/dist/repository/repository-manager.d.ts +0 -27
- package/dist/repository/repository-manager.d.ts.map +0 -1
- package/dist/repository/repository-manager.js +0 -19
- package/dist/repository/repository-manager.js.map +0 -1
- package/dist/repository/repository-manager.test.d.ts +0 -2
- package/dist/repository/repository-manager.test.d.ts.map +0 -1
- package/dist/repository/repository-manager.test.js +0 -65
- package/dist/repository/repository-manager.test.js.map +0 -1
- package/dist/repository/test-helpers.js +0 -402
- package/dist/repository/test-helpers.js.map +0 -1
- package/dist/schema-definition/lix-generated.test.d.ts +0 -2
- package/dist/schema-definition/lix-generated.test.d.ts.map +0 -1
- package/dist/schema-definition/lix-generated.test.js +0 -127
- package/dist/schema-definition/lix-generated.test.js.map +0 -1
- package/dist/state/entity-view-builder.d.ts +0 -145
- package/dist/state/entity-view-builder.d.ts.map +0 -1
- package/dist/state/entity-view-builder.js +0 -280
- package/dist/state/entity-view-builder.js.map +0 -1
- package/dist/state/entity-view-builder.test.d.ts +0 -2
- package/dist/state/entity-view-builder.test.d.ts.map +0 -1
- package/dist/state/entity-view-builder.test.js +0 -523
- package/dist/state/entity-view-builder.test.js.map +0 -1
- package/src/change-set/create-checkpoint.ts +0 -101
- package/src/file/materialize-file-data-at-changeset.ts +0 -123
- package/src/query-filter/change-has-label.test.ts +0 -79
- package/src/query-filter/change-has-label.ts +0 -45
- package/src/query-filter/change-set-has-label.test.ts +0 -42
- package/src/query-filter/change-set-has-label.ts +0 -50
- package/src/query-filter/change-set-is-ancestor-of.test.ts +0 -178
- package/src/query-filter/change-set-is-ancestor-of.ts +0 -77
- package/src/query-filter/change-set-is-descendant-of.test.ts +0 -169
- package/src/query-filter/change-set-is-descendant-of.ts +0 -70
- package/src/state/create-changeset-for-transaction.ts +0 -321
- package/src/state/get-version-record-by-id-or-throw.ts +0 -51
- package/src/state/handle-state-mutation.test.ts +0 -761
- package/src/state/handle-state-mutation.ts +0 -418
|
@@ -3,7 +3,13 @@ import type { Lix } from "../lix/open-lix.js";
|
|
|
3
3
|
import { LixSchemaDefinition } from "../schema-definition/definition.js";
|
|
4
4
|
import { executeSync } from "../database/execute-sync.js";
|
|
5
5
|
import { sql } from "kysely";
|
|
6
|
-
import type {
|
|
6
|
+
import type { LixChange } from "../change/schema.js";
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* List of special entity types that are not stored as JSON in the state table,
|
|
10
|
+
* but have their own dedicated SQL tables.
|
|
11
|
+
*/
|
|
12
|
+
const SPECIAL_ENTITIES = ["lix_change", "state"] as const;
|
|
7
13
|
|
|
8
14
|
const ajv = new Ajv({
|
|
9
15
|
strict: true,
|
|
@@ -16,7 +22,7 @@ const validateLixSchema = ajv.compile(LixSchemaDefinition);
|
|
|
16
22
|
export function validateStateMutation(args: {
|
|
17
23
|
lix: Pick<Lix, "sqlite" | "db">;
|
|
18
24
|
schema: LixSchemaDefinition | null;
|
|
19
|
-
snapshot_content:
|
|
25
|
+
snapshot_content: LixChange["snapshot_content"];
|
|
20
26
|
operation: "insert" | "update" | "delete";
|
|
21
27
|
entity_id?: string;
|
|
22
28
|
version_id: string;
|
|
@@ -128,21 +134,41 @@ export function validateStateMutation(args: {
|
|
|
128
134
|
}
|
|
129
135
|
}
|
|
130
136
|
|
|
131
|
-
// Hardcoded validation for
|
|
132
|
-
if (args.schema["x-lix-key"] === "
|
|
137
|
+
// Hardcoded validation for commit_edge self-referencing
|
|
138
|
+
if (args.schema["x-lix-key"] === "lix_commit_edge") {
|
|
133
139
|
const content = args.snapshot_content as any;
|
|
134
140
|
if (content.parent_id === content.child_id) {
|
|
135
141
|
throw new Error(
|
|
136
142
|
"Self-referencing edges are not allowed: parent_id cannot equal child_id"
|
|
137
143
|
);
|
|
138
144
|
}
|
|
145
|
+
|
|
146
|
+
// Check for cycles if lix_debug is enabled
|
|
147
|
+
if (args.operation === "insert") {
|
|
148
|
+
const debugEnabled = executeSync({
|
|
149
|
+
lix: args.lix,
|
|
150
|
+
query: args.lix.db
|
|
151
|
+
.selectFrom("key_value_all")
|
|
152
|
+
.select("value")
|
|
153
|
+
.where("key", "=", "lix_debug")
|
|
154
|
+
.where("value", "=", "true"),
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
if (debugEnabled.length > 0 && debugEnabled[0].value === "true") {
|
|
158
|
+
validateAcyclicCommitGraph({
|
|
159
|
+
lix: args.lix,
|
|
160
|
+
newEdge: content,
|
|
161
|
+
version_id: args.version_id,
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
}
|
|
139
165
|
}
|
|
140
166
|
}
|
|
141
167
|
|
|
142
168
|
function validatePrimaryKeyConstraints(args: {
|
|
143
169
|
lix: Pick<Lix, "sqlite" | "db">;
|
|
144
170
|
schema: LixSchemaDefinition;
|
|
145
|
-
snapshot_content:
|
|
171
|
+
snapshot_content: LixChange["snapshot_content"];
|
|
146
172
|
operation: "insert" | "update" | "delete";
|
|
147
173
|
entity_id?: string;
|
|
148
174
|
version_id: string;
|
|
@@ -203,7 +229,7 @@ function validatePrimaryKeyConstraints(args: {
|
|
|
203
229
|
function validateUniqueConstraints(args: {
|
|
204
230
|
lix: Pick<Lix, "sqlite" | "db">;
|
|
205
231
|
schema: LixSchemaDefinition;
|
|
206
|
-
snapshot_content:
|
|
232
|
+
snapshot_content: LixChange["snapshot_content"];
|
|
207
233
|
operation: "insert" | "update" | "delete";
|
|
208
234
|
entity_id?: string;
|
|
209
235
|
version_id: string;
|
|
@@ -288,55 +314,111 @@ function getValueByPath(obj: any, path: string): any {
|
|
|
288
314
|
function validateForeignKeyConstraints(args: {
|
|
289
315
|
lix: Pick<Lix, "sqlite" | "db">;
|
|
290
316
|
schema: LixSchemaDefinition;
|
|
291
|
-
snapshot_content:
|
|
317
|
+
snapshot_content: LixChange["snapshot_content"];
|
|
292
318
|
version_id: string;
|
|
293
319
|
untracked?: boolean;
|
|
294
320
|
}): void {
|
|
295
321
|
const foreignKeys = args.schema["x-lix-foreign-keys"];
|
|
296
|
-
if (!foreignKeys) {
|
|
322
|
+
if (!foreignKeys || !Array.isArray(foreignKeys)) {
|
|
297
323
|
return;
|
|
298
324
|
}
|
|
299
325
|
|
|
300
326
|
// Validate each foreign key constraint
|
|
301
|
-
for (const
|
|
302
|
-
|
|
327
|
+
for (const foreignKey of foreignKeys) {
|
|
328
|
+
// Validate that properties arrays have same length
|
|
329
|
+
if (
|
|
330
|
+
foreignKey.properties.length !== foreignKey.references.properties.length
|
|
331
|
+
) {
|
|
332
|
+
throw new Error(
|
|
333
|
+
`Foreign key constraint error: Local properties (${foreignKey.properties.join(", ")}) and ` +
|
|
334
|
+
`referenced properties (${foreignKey.references.properties.join(", ")}) must have the same length`
|
|
335
|
+
);
|
|
336
|
+
}
|
|
337
|
+
|
|
338
|
+
// Extract values for all local properties
|
|
339
|
+
const localValues: any[] = [];
|
|
340
|
+
let hasNullValue = false;
|
|
303
341
|
|
|
304
|
-
|
|
342
|
+
for (const localProperty of foreignKey.properties) {
|
|
343
|
+
const value = (args.snapshot_content as any)[localProperty];
|
|
344
|
+
if (value === null || value === undefined) {
|
|
345
|
+
hasNullValue = true;
|
|
346
|
+
break;
|
|
347
|
+
}
|
|
348
|
+
localValues.push(value);
|
|
349
|
+
}
|
|
350
|
+
|
|
351
|
+
// Skip validation if any foreign key value is null or undefined
|
|
305
352
|
// (like SQL foreign keys, null values are allowed)
|
|
306
|
-
if (
|
|
353
|
+
if (hasNullValue) {
|
|
307
354
|
continue;
|
|
308
355
|
}
|
|
309
356
|
|
|
310
|
-
// Check if this references a
|
|
311
|
-
const
|
|
357
|
+
// Check if this references a special entity with its own SQL table
|
|
358
|
+
const isSpecialEntity = SPECIAL_ENTITIES.includes(
|
|
359
|
+
foreignKey.references.schemaKey as any
|
|
360
|
+
);
|
|
312
361
|
|
|
313
362
|
let query: any;
|
|
314
|
-
if (
|
|
315
|
-
// Query the
|
|
363
|
+
if (isSpecialEntity) {
|
|
364
|
+
// Query the dedicated SQL table directly
|
|
316
365
|
// Map schema key to actual table name
|
|
317
366
|
const tableName =
|
|
318
|
-
|
|
367
|
+
foreignKey.references.schemaKey === "lix_change"
|
|
319
368
|
? "change"
|
|
320
|
-
:
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
369
|
+
: foreignKey.references.schemaKey;
|
|
370
|
+
|
|
371
|
+
// Special handling for state table which supports composite keys
|
|
372
|
+
if (foreignKey.references.schemaKey === "state") {
|
|
373
|
+
query = args.lix.db
|
|
374
|
+
.selectFrom("state_all" as any)
|
|
375
|
+
.select(foreignKey.references.properties as any);
|
|
376
|
+
|
|
377
|
+
// Add WHERE conditions for each property
|
|
378
|
+
for (let i = 0; i < foreignKey.properties.length; i++) {
|
|
379
|
+
const refProperty = foreignKey.references.properties[i];
|
|
380
|
+
const localValue = localValues[i];
|
|
381
|
+
query = query.where(refProperty as any, "=", localValue);
|
|
382
|
+
}
|
|
383
|
+
} else {
|
|
384
|
+
// For other special entities, we only support single property references
|
|
385
|
+
if (foreignKey.properties.length !== 1) {
|
|
386
|
+
throw new Error(
|
|
387
|
+
`Foreign key constraint error: Special entity '${foreignKey.references.schemaKey}' references only support single property, ` +
|
|
388
|
+
`but got ${foreignKey.properties.length} properties`
|
|
389
|
+
);
|
|
390
|
+
}
|
|
391
|
+
|
|
392
|
+
query = args.lix.db
|
|
393
|
+
.selectFrom(tableName as any)
|
|
394
|
+
.select(foreignKey.references.properties[0] as any)
|
|
395
|
+
.where(
|
|
396
|
+
foreignKey.references.properties[0] as any,
|
|
397
|
+
"=",
|
|
398
|
+
localValues[0]
|
|
399
|
+
);
|
|
400
|
+
}
|
|
325
401
|
} else {
|
|
326
402
|
// Query JSON schema entities in the state table
|
|
327
403
|
query = args.lix.db
|
|
328
404
|
.selectFrom("state_all")
|
|
329
405
|
.select("snapshot_content")
|
|
330
|
-
.where("schema_key", "=",
|
|
331
|
-
|
|
332
|
-
|
|
406
|
+
.where("schema_key", "=", foreignKey.references.schemaKey);
|
|
407
|
+
|
|
408
|
+
// Add WHERE conditions for each property
|
|
409
|
+
for (let i = 0; i < foreignKey.properties.length; i++) {
|
|
410
|
+
const refProperty = foreignKey.references.properties[i];
|
|
411
|
+
const localValue = localValues[i];
|
|
412
|
+
query = query.where(
|
|
413
|
+
sql`json_extract(snapshot_content, '$.' || ${refProperty})`,
|
|
333
414
|
"=",
|
|
334
|
-
|
|
415
|
+
localValue
|
|
335
416
|
);
|
|
417
|
+
}
|
|
336
418
|
}
|
|
337
419
|
|
|
338
|
-
// Add version constraint if specified (only for
|
|
339
|
-
if (
|
|
420
|
+
// Add version constraint if specified (only for regular schema entities)
|
|
421
|
+
if (foreignKey.references.schemaVersion && !isSpecialEntity) {
|
|
340
422
|
// Get stored schema with specific version
|
|
341
423
|
const referencedSchema = executeSync({
|
|
342
424
|
lix: args.lix,
|
|
@@ -346,26 +428,30 @@ function validateForeignKeyConstraints(args: {
|
|
|
346
428
|
.where(
|
|
347
429
|
sql`json_extract(value, '$.["x-lix-key"]')`,
|
|
348
430
|
"=",
|
|
349
|
-
|
|
431
|
+
foreignKey.references.schemaKey
|
|
350
432
|
)
|
|
351
433
|
.where(
|
|
352
434
|
sql`json_extract(value, '$.["x-lix-version"]')`,
|
|
353
435
|
"=",
|
|
354
|
-
|
|
436
|
+
foreignKey.references.schemaVersion
|
|
355
437
|
),
|
|
356
438
|
});
|
|
357
439
|
|
|
358
440
|
if (referencedSchema.length === 0) {
|
|
359
441
|
throw new Error(
|
|
360
|
-
`Foreign key constraint violation. Referenced schema '${
|
|
442
|
+
`Foreign key constraint violation. Referenced schema '${foreignKey.references.schemaKey}' with version '${foreignKey.references.schemaVersion}' does not exist.`
|
|
361
443
|
);
|
|
362
444
|
}
|
|
363
445
|
}
|
|
364
446
|
|
|
365
447
|
const referencedStates = executeSync({
|
|
366
448
|
lix: args.lix,
|
|
367
|
-
query:
|
|
368
|
-
?
|
|
449
|
+
query: isSpecialEntity
|
|
450
|
+
? foreignKey.references.schemaKey === "state"
|
|
451
|
+
? query
|
|
452
|
+
.where("version_id", "=", args.version_id)
|
|
453
|
+
.where("inherited_from_version_id", "is", null)
|
|
454
|
+
: query
|
|
369
455
|
: query
|
|
370
456
|
.where("version_id", "=", args.version_id)
|
|
371
457
|
.where("inherited_from_version_id", "is", null),
|
|
@@ -383,12 +469,17 @@ function validateForeignKeyConstraints(args: {
|
|
|
383
469
|
const versionName =
|
|
384
470
|
versionInfo.length > 0 ? versionInfo[0].name : "unknown";
|
|
385
471
|
|
|
472
|
+
// Build the property/value pairs for error message
|
|
473
|
+
const localPropsStr = foreignKey.properties.join(", ");
|
|
474
|
+
const refPropsStr = foreignKey.references.properties.join(", ");
|
|
475
|
+
const valuesStr = localValues.map((v) => `'${v}'`).join(", ");
|
|
476
|
+
|
|
386
477
|
// First line: compact string for regex matching (backwards compatibility)
|
|
387
|
-
let errorMessage = `Foreign key constraint violation. The schema '${args.schema["x-lix-key"]}' (${args.schema["x-lix-version"]}) has a foreign key constraint on
|
|
478
|
+
let errorMessage = `Foreign key constraint violation. The schema '${args.schema["x-lix-key"]}' (${args.schema["x-lix-version"]}) has a foreign key constraint on (${localPropsStr}) referencing '${foreignKey.references.schemaKey}.(${refPropsStr})' but no matching record exists with values (${valuesStr}) in version '${args.version_id}' (${versionName}).`;
|
|
388
479
|
|
|
389
480
|
// Add foreign key relationship visualization
|
|
390
481
|
errorMessage += `\n\nForeign Key Relationship:\n`;
|
|
391
|
-
errorMessage += ` ${args.schema["x-lix-key"]}
|
|
482
|
+
errorMessage += ` ${args.schema["x-lix-key"]}.(${localPropsStr}) → ${foreignKey.references.schemaKey}.(${refPropsStr})\n`;
|
|
392
483
|
|
|
393
484
|
// Helper function to truncate property values
|
|
394
485
|
const truncateValue = (value: any, maxLength: number = 40): string => {
|
|
@@ -419,26 +510,37 @@ function validateForeignKeyConstraints(args: {
|
|
|
419
510
|
}
|
|
420
511
|
|
|
421
512
|
// If this is a tracked entity, check if the referenced entity is untracked
|
|
422
|
-
if (!args.untracked && !
|
|
423
|
-
//
|
|
513
|
+
if (!args.untracked && !isSpecialEntity) {
|
|
514
|
+
// Build query to check for untracked references
|
|
515
|
+
let untrackedQuery = args.lix.db
|
|
516
|
+
.selectFrom("state_all")
|
|
517
|
+
.select("entity_id")
|
|
518
|
+
.where("schema_key", "=", foreignKey.references.schemaKey)
|
|
519
|
+
.where("version_id", "=", args.version_id)
|
|
520
|
+
.where("untracked", "=", true);
|
|
521
|
+
|
|
522
|
+
// Add WHERE conditions for each property
|
|
523
|
+
for (let i = 0; i < foreignKey.properties.length; i++) {
|
|
524
|
+
const refProperty = foreignKey.references.properties[i];
|
|
525
|
+
const localValue = localValues[i];
|
|
526
|
+
untrackedQuery = untrackedQuery.where(
|
|
527
|
+
sql`json_extract(snapshot_content, '$.' || ${refProperty})`,
|
|
528
|
+
"=",
|
|
529
|
+
localValue
|
|
530
|
+
);
|
|
531
|
+
}
|
|
532
|
+
|
|
424
533
|
const untrackedReferences = executeSync({
|
|
425
534
|
lix: args.lix,
|
|
426
|
-
query:
|
|
427
|
-
.selectFrom("state_all")
|
|
428
|
-
.select("entity_id")
|
|
429
|
-
.where("schema_key", "=", foreignKeyDef.schemaKey)
|
|
430
|
-
.where("version_id", "=", args.version_id)
|
|
431
|
-
.where("untracked", "=", true)
|
|
432
|
-
.where(
|
|
433
|
-
sql`json_extract(snapshot_content, '$.' || ${foreignKeyDef.property})`,
|
|
434
|
-
"=",
|
|
435
|
-
foreignKeyValue
|
|
436
|
-
),
|
|
535
|
+
query: untrackedQuery,
|
|
437
536
|
});
|
|
438
537
|
|
|
439
538
|
if (untrackedReferences.length > 0) {
|
|
539
|
+
const refPropsStr = foreignKey.references.properties.join(", ");
|
|
540
|
+
const valuesStr = localValues.map((v) => `'${v}'`).join(", ");
|
|
541
|
+
|
|
440
542
|
let errorMessage = `Foreign key constraint violation: tracked entities cannot reference untracked entities. This would create broken references during sync.\n`;
|
|
441
|
-
errorMessage += `\nThe tracked entity '${args.schema["x-lix-key"]}' is trying to reference an untracked entity '${
|
|
543
|
+
errorMessage += `\nThe tracked entity '${args.schema["x-lix-key"]}' is trying to reference an untracked entity '${foreignKey.references.schemaKey}' with (${refPropsStr})=(${valuesStr}).\n`;
|
|
442
544
|
errorMessage += `\nUntracked entities are local-only and will not be synced to remote. If a tracked entity references an untracked entity, it would fail validation on the remote because the untracked entity doesn't exist there.\n`;
|
|
443
545
|
errorMessage += `\nSolutions:\n`;
|
|
444
546
|
errorMessage += `1. Make the referenced entity tracked (remove untracked flag)\n`;
|
|
@@ -555,44 +657,68 @@ function validateDeletionConstraints(args: {
|
|
|
555
657
|
}
|
|
556
658
|
|
|
557
659
|
// Check each foreign key in this schema
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
660
|
+
const foreignKeys = schema["x-lix-foreign-keys"];
|
|
661
|
+
if (!foreignKeys || !Array.isArray(foreignKeys)) {
|
|
662
|
+
continue;
|
|
663
|
+
}
|
|
664
|
+
|
|
665
|
+
for (const foreignKey of foreignKeys) {
|
|
561
666
|
// Skip if this foreign key doesn't reference our schema
|
|
562
|
-
if (
|
|
667
|
+
if (foreignKey.references.schemaKey !== args.schema["x-lix-key"]) {
|
|
563
668
|
continue;
|
|
564
669
|
}
|
|
565
670
|
|
|
566
|
-
// Get the
|
|
671
|
+
// Get the values of the properties that are being referenced
|
|
567
672
|
const rawContent = currentEntity[0].snapshot_content;
|
|
568
673
|
const entityContent =
|
|
569
674
|
typeof rawContent === "string"
|
|
570
675
|
? JSON.parse(rawContent)
|
|
571
676
|
: (rawContent as any);
|
|
572
|
-
const referencedValue = entityContent[foreignKeyDef.property];
|
|
573
677
|
|
|
574
|
-
|
|
678
|
+
// Extract referenced values
|
|
679
|
+
const referencedValues: any[] = [];
|
|
680
|
+
let hasNullValue = false;
|
|
681
|
+
|
|
682
|
+
for (const refProperty of foreignKey.references.properties) {
|
|
683
|
+
const value = entityContent[refProperty];
|
|
684
|
+
if (value === null || value === undefined) {
|
|
685
|
+
hasNullValue = true;
|
|
686
|
+
break;
|
|
687
|
+
}
|
|
688
|
+
referencedValues.push(value);
|
|
689
|
+
}
|
|
690
|
+
|
|
691
|
+
if (hasNullValue) {
|
|
575
692
|
continue;
|
|
576
693
|
}
|
|
577
694
|
|
|
578
|
-
//
|
|
695
|
+
// Build query to check if any entities reference these values
|
|
696
|
+
let query = args.lix.db
|
|
697
|
+
.selectFrom("state_all")
|
|
698
|
+
.select("entity_id")
|
|
699
|
+
.where("schema_key", "=", schema["x-lix-key"])
|
|
700
|
+
.where("version_id", "=", args.version_id);
|
|
701
|
+
|
|
702
|
+
// Add WHERE conditions for each property
|
|
703
|
+
for (let i = 0; i < foreignKey.properties.length; i++) {
|
|
704
|
+
const localProperty = foreignKey.properties[i];
|
|
705
|
+
const referencedValue = referencedValues[i];
|
|
706
|
+
query = query.where(
|
|
707
|
+
sql`json_extract(snapshot_content, '$.' || ${localProperty})`,
|
|
708
|
+
"=",
|
|
709
|
+
referencedValue
|
|
710
|
+
);
|
|
711
|
+
}
|
|
712
|
+
|
|
579
713
|
const referencingEntities = executeSync({
|
|
580
714
|
lix: args.lix,
|
|
581
|
-
query
|
|
582
|
-
.selectFrom("state_all")
|
|
583
|
-
.select("entity_id")
|
|
584
|
-
.where("schema_key", "=", schema["x-lix-key"])
|
|
585
|
-
.where("version_id", "=", args.version_id)
|
|
586
|
-
.where(
|
|
587
|
-
sql`json_extract(snapshot_content, '$.' || ${localProperty})`,
|
|
588
|
-
"=",
|
|
589
|
-
referencedValue
|
|
590
|
-
),
|
|
715
|
+
query,
|
|
591
716
|
});
|
|
592
717
|
|
|
593
718
|
if (referencingEntities.length > 0) {
|
|
719
|
+
const localPropsStr = foreignKey.properties.join(", ");
|
|
594
720
|
throw new Error(
|
|
595
|
-
`Foreign key constraint violation: Cannot delete entity because it is referenced by ${referencingEntities.length} record(s) in schema '${schema["x-lix-key"]}' via foreign key
|
|
721
|
+
`Foreign key constraint violation: Cannot delete entity because it is referenced by ${referencingEntities.length} record(s) in schema '${schema["x-lix-key"]}' via foreign key (${localPropsStr})`
|
|
596
722
|
);
|
|
597
723
|
}
|
|
598
724
|
}
|
|
@@ -662,3 +788,79 @@ function parseJsonPropertiesInSnapshotContent(
|
|
|
662
788
|
|
|
663
789
|
return parsed;
|
|
664
790
|
}
|
|
791
|
+
|
|
792
|
+
/**
|
|
793
|
+
* Validates that adding a new edge to the commit graph won't create a cycle.
|
|
794
|
+
* Uses depth-first search to detect cycles.
|
|
795
|
+
*/
|
|
796
|
+
function validateAcyclicCommitGraph(args: {
|
|
797
|
+
lix: Pick<Lix, "sqlite" | "db">;
|
|
798
|
+
newEdge: { parent_id: string; child_id: string };
|
|
799
|
+
version_id: string;
|
|
800
|
+
}): void {
|
|
801
|
+
// Get all existing edges
|
|
802
|
+
const existingEdges = executeSync({
|
|
803
|
+
lix: args.lix,
|
|
804
|
+
query: args.lix.db
|
|
805
|
+
.selectFrom("commit_edge_all")
|
|
806
|
+
.select(["parent_id", "child_id"])
|
|
807
|
+
.where("lixcol_version_id", "=", args.version_id),
|
|
808
|
+
});
|
|
809
|
+
|
|
810
|
+
// Build adjacency list including the new edge
|
|
811
|
+
const adjacencyList = new Map<string, string[]>();
|
|
812
|
+
|
|
813
|
+
// Add existing edges
|
|
814
|
+
for (const edge of existingEdges) {
|
|
815
|
+
if (!adjacencyList.has(edge.parent_id)) {
|
|
816
|
+
adjacencyList.set(edge.parent_id, []);
|
|
817
|
+
}
|
|
818
|
+
adjacencyList.get(edge.parent_id)!.push(edge.child_id);
|
|
819
|
+
}
|
|
820
|
+
|
|
821
|
+
// Add the new edge
|
|
822
|
+
if (!adjacencyList.has(args.newEdge.parent_id)) {
|
|
823
|
+
adjacencyList.set(args.newEdge.parent_id, []);
|
|
824
|
+
}
|
|
825
|
+
adjacencyList.get(args.newEdge.parent_id)!.push(args.newEdge.child_id);
|
|
826
|
+
|
|
827
|
+
// DFS to detect cycles
|
|
828
|
+
const visited = new Set<string>();
|
|
829
|
+
const recursionStack = new Set<string>();
|
|
830
|
+
|
|
831
|
+
function hasCycle(node: string, path: string[] = []): boolean {
|
|
832
|
+
visited.add(node);
|
|
833
|
+
recursionStack.add(node);
|
|
834
|
+
path.push(node);
|
|
835
|
+
|
|
836
|
+
const neighbors = adjacencyList.get(node) || [];
|
|
837
|
+
for (const neighbor of neighbors) {
|
|
838
|
+
if (!visited.has(neighbor)) {
|
|
839
|
+
if (hasCycle(neighbor, [...path])) {
|
|
840
|
+
return true;
|
|
841
|
+
}
|
|
842
|
+
} else if (recursionStack.has(neighbor)) {
|
|
843
|
+
// Found a cycle
|
|
844
|
+
const cycleStart = path.indexOf(neighbor);
|
|
845
|
+
const cyclePath = [...path.slice(cycleStart), neighbor];
|
|
846
|
+
|
|
847
|
+
throw new Error(
|
|
848
|
+
`Cycle detected in commit graph!\n` +
|
|
849
|
+
`New edge: ${args.newEdge.parent_id} -> ${args.newEdge.child_id}\n` +
|
|
850
|
+
`Cycle path: ${cyclePath.join(" -> ")}\n` +
|
|
851
|
+
`Adding this edge would create a cycle in the graph.`
|
|
852
|
+
);
|
|
853
|
+
}
|
|
854
|
+
}
|
|
855
|
+
|
|
856
|
+
recursionStack.delete(node);
|
|
857
|
+
return false;
|
|
858
|
+
}
|
|
859
|
+
|
|
860
|
+
// Check all nodes that haven't been visited
|
|
861
|
+
for (const node of adjacencyList.keys()) {
|
|
862
|
+
if (!visited.has(node)) {
|
|
863
|
+
hasCycle(node);
|
|
864
|
+
}
|
|
865
|
+
}
|
|
866
|
+
}
|