@livestore/common 0.0.0-snapshot-909cdd1ac2fd591945c2be2b0f53e14d87f3c9d4
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/.tsbuildinfo +1 -0
- package/dist/__tests__/fixture.d.ts +72 -0
- package/dist/__tests__/fixture.d.ts.map +1 -0
- package/dist/__tests__/fixture.js +16 -0
- package/dist/__tests__/fixture.js.map +1 -0
- package/dist/adapter-types.d.ts +202 -0
- package/dist/adapter-types.d.ts.map +1 -0
- package/dist/adapter-types.js +49 -0
- package/dist/adapter-types.js.map +1 -0
- package/dist/bounded-collections.d.ts +36 -0
- package/dist/bounded-collections.d.ts.map +1 -0
- package/dist/bounded-collections.js +98 -0
- package/dist/bounded-collections.js.map +1 -0
- package/dist/debug-info.d.ts +122 -0
- package/dist/debug-info.d.ts.map +1 -0
- package/dist/debug-info.js +47 -0
- package/dist/debug-info.js.map +1 -0
- package/dist/derived-mutations.d.ts +109 -0
- package/dist/derived-mutations.d.ts.map +1 -0
- package/dist/derived-mutations.js +54 -0
- package/dist/derived-mutations.js.map +1 -0
- package/dist/derived-mutations.test.d.ts +2 -0
- package/dist/derived-mutations.test.d.ts.map +1 -0
- package/dist/derived-mutations.test.js +93 -0
- package/dist/derived-mutations.test.js.map +1 -0
- package/dist/devtools/devtools-bridge.d.ts +12 -0
- package/dist/devtools/devtools-bridge.d.ts.map +1 -0
- package/dist/devtools/devtools-bridge.js +2 -0
- package/dist/devtools/devtools-bridge.js.map +1 -0
- package/dist/devtools/devtools-messages.d.ts +705 -0
- package/dist/devtools/devtools-messages.d.ts.map +1 -0
- package/dist/devtools/devtools-messages.js +178 -0
- package/dist/devtools/devtools-messages.js.map +1 -0
- package/dist/devtools/devtools-window-message.d.ts +29 -0
- package/dist/devtools/devtools-window-message.d.ts.map +1 -0
- package/dist/devtools/devtools-window-message.js +33 -0
- package/dist/devtools/devtools-window-message.js.map +1 -0
- package/dist/devtools/index.d.ts +42 -0
- package/dist/devtools/index.d.ts.map +1 -0
- package/dist/devtools/index.js +49 -0
- package/dist/devtools/index.js.map +1 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +15 -0
- package/dist/index.js.map +1 -0
- package/dist/init-singleton-tables.d.ts +4 -0
- package/dist/init-singleton-tables.d.ts.map +1 -0
- package/dist/init-singleton-tables.js +16 -0
- package/dist/init-singleton-tables.js.map +1 -0
- package/dist/mutation.d.ts +13 -0
- package/dist/mutation.d.ts.map +1 -0
- package/dist/mutation.js +43 -0
- package/dist/mutation.js.map +1 -0
- package/dist/query-info.d.ts +47 -0
- package/dist/query-info.d.ts.map +1 -0
- package/dist/query-info.js +38 -0
- package/dist/query-info.js.map +1 -0
- package/dist/rehydrate-from-mutationlog.d.ts +14 -0
- package/dist/rehydrate-from-mutationlog.d.ts.map +1 -0
- package/dist/rehydrate-from-mutationlog.js +72 -0
- package/dist/rehydrate-from-mutationlog.js.map +1 -0
- package/dist/schema/index.d.ts +60 -0
- package/dist/schema/index.d.ts.map +1 -0
- package/dist/schema/index.js +66 -0
- package/dist/schema/index.js.map +1 -0
- package/dist/schema/mutations.d.ts +227 -0
- package/dist/schema/mutations.d.ts.map +1 -0
- package/dist/schema/mutations.js +68 -0
- package/dist/schema/mutations.js.map +1 -0
- package/dist/schema/schema-helpers.d.ts +4 -0
- package/dist/schema/schema-helpers.d.ts.map +1 -0
- package/dist/schema/schema-helpers.js +30 -0
- package/dist/schema/schema-helpers.js.map +1 -0
- package/dist/schema/system-tables.d.ts +331 -0
- package/dist/schema/system-tables.d.ts.map +1 -0
- package/dist/schema/system-tables.js +46 -0
- package/dist/schema/system-tables.js.map +1 -0
- package/dist/schema/table-def.d.ts +135 -0
- package/dist/schema/table-def.d.ts.map +1 -0
- package/dist/schema/table-def.js +70 -0
- package/dist/schema/table-def.js.map +1 -0
- package/dist/schema-management/common.d.ts +13 -0
- package/dist/schema-management/common.d.ts.map +1 -0
- package/dist/schema-management/common.js +25 -0
- package/dist/schema-management/common.js.map +1 -0
- package/dist/schema-management/migrations.d.ts +23 -0
- package/dist/schema-management/migrations.d.ts.map +1 -0
- package/dist/schema-management/migrations.js +116 -0
- package/dist/schema-management/migrations.js.map +1 -0
- package/dist/schema-management/validate-mutation-defs.d.ts +8 -0
- package/dist/schema-management/validate-mutation-defs.d.ts.map +1 -0
- package/dist/schema-management/validate-mutation-defs.js +39 -0
- package/dist/schema-management/validate-mutation-defs.js.map +1 -0
- package/dist/sql-queries/index.d.ts +4 -0
- package/dist/sql-queries/index.d.ts.map +1 -0
- package/dist/sql-queries/index.js +4 -0
- package/dist/sql-queries/index.js.map +1 -0
- package/dist/sql-queries/misc.d.ts +2 -0
- package/dist/sql-queries/misc.d.ts.map +1 -0
- package/dist/sql-queries/misc.js +2 -0
- package/dist/sql-queries/misc.js.map +1 -0
- package/dist/sql-queries/sql-queries.d.ts +72 -0
- package/dist/sql-queries/sql-queries.d.ts.map +1 -0
- package/dist/sql-queries/sql-queries.js +191 -0
- package/dist/sql-queries/sql-queries.js.map +1 -0
- package/dist/sql-queries/sql-query-builder.d.ts +47 -0
- package/dist/sql-queries/sql-query-builder.d.ts.map +1 -0
- package/dist/sql-queries/sql-query-builder.js +60 -0
- package/dist/sql-queries/sql-query-builder.js.map +1 -0
- package/dist/sql-queries/types.d.ts +50 -0
- package/dist/sql-queries/types.d.ts.map +1 -0
- package/dist/sql-queries/types.js +5 -0
- package/dist/sql-queries/types.js.map +1 -0
- package/dist/sync/index.d.ts +2 -0
- package/dist/sync/index.d.ts.map +1 -0
- package/dist/sync/index.js +2 -0
- package/dist/sync/index.js.map +1 -0
- package/dist/sync/next/compact-events.d.ts +15 -0
- package/dist/sync/next/compact-events.d.ts.map +1 -0
- package/dist/sync/next/compact-events.js +176 -0
- package/dist/sync/next/compact-events.js.map +1 -0
- package/dist/sync/next/facts.d.ts +37 -0
- package/dist/sync/next/facts.d.ts.map +1 -0
- package/dist/sync/next/facts.js +156 -0
- package/dist/sync/next/facts.js.map +1 -0
- package/dist/sync/next/graphology.d.ts +8 -0
- package/dist/sync/next/graphology.d.ts.map +1 -0
- package/dist/sync/next/graphology.js +36 -0
- package/dist/sync/next/graphology.js.map +1 -0
- package/dist/sync/next/graphology_.d.ts +3 -0
- package/dist/sync/next/graphology_.d.ts.map +1 -0
- package/dist/sync/next/graphology_.js +3 -0
- package/dist/sync/next/graphology_.js.map +1 -0
- package/dist/sync/next/history-dag.d.ts +30 -0
- package/dist/sync/next/history-dag.d.ts.map +1 -0
- package/dist/sync/next/history-dag.js +69 -0
- package/dist/sync/next/history-dag.js.map +1 -0
- package/dist/sync/next/mod.d.ts +5 -0
- package/dist/sync/next/mod.d.ts.map +1 -0
- package/dist/sync/next/mod.js +5 -0
- package/dist/sync/next/mod.js.map +1 -0
- package/dist/sync/next/rebase-events.d.ts +27 -0
- package/dist/sync/next/rebase-events.d.ts.map +1 -0
- package/dist/sync/next/rebase-events.js +41 -0
- package/dist/sync/next/rebase-events.js.map +1 -0
- package/dist/sync/next/test/compact-events.calculator.test.d.ts +2 -0
- package/dist/sync/next/test/compact-events.calculator.test.d.ts.map +1 -0
- package/dist/sync/next/test/compact-events.calculator.test.js +101 -0
- package/dist/sync/next/test/compact-events.calculator.test.js.map +1 -0
- package/dist/sync/next/test/compact-events.test.d.ts +2 -0
- package/dist/sync/next/test/compact-events.test.d.ts.map +1 -0
- package/dist/sync/next/test/compact-events.test.js +201 -0
- package/dist/sync/next/test/compact-events.test.js.map +1 -0
- package/dist/sync/next/test/mod.d.ts +2 -0
- package/dist/sync/next/test/mod.d.ts.map +1 -0
- package/dist/sync/next/test/mod.js +2 -0
- package/dist/sync/next/test/mod.js.map +1 -0
- package/dist/sync/next/test/mutation-fixtures.d.ts +73 -0
- package/dist/sync/next/test/mutation-fixtures.d.ts.map +1 -0
- package/dist/sync/next/test/mutation-fixtures.js +161 -0
- package/dist/sync/next/test/mutation-fixtures.js.map +1 -0
- package/dist/sync/sync.d.ts +45 -0
- package/dist/sync/sync.d.ts.map +1 -0
- package/dist/sync/sync.js +12 -0
- package/dist/sync/sync.js.map +1 -0
- package/dist/util.d.ts +25 -0
- package/dist/util.d.ts.map +1 -0
- package/dist/util.js +38 -0
- package/dist/util.js.map +1 -0
- package/dist/version.d.ts +10 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +12 -0
- package/dist/version.js.map +1 -0
- package/package.json +61 -0
- package/src/__tests__/fixture.ts +23 -0
- package/src/adapter-types.ts +216 -0
- package/src/ambient.d.ts +3 -0
- package/src/bounded-collections.ts +121 -0
- package/src/debug-info.ts +76 -0
- package/src/derived-mutations.test.ts +101 -0
- package/src/derived-mutations.ts +170 -0
- package/src/devtools/devtools-bridge.ts +13 -0
- package/src/devtools/devtools-messages.ts +247 -0
- package/src/devtools/devtools-window-message.ts +27 -0
- package/src/devtools/index.ts +49 -0
- package/src/index.ts +20 -0
- package/src/init-singleton-tables.ts +24 -0
- package/src/mutation.ts +69 -0
- package/src/query-info.ts +104 -0
- package/src/rehydrate-from-mutationlog.ts +131 -0
- package/src/schema/index.ts +144 -0
- package/src/schema/mutations.ts +313 -0
- package/src/schema/schema-helpers.ts +49 -0
- package/src/schema/system-tables.ts +84 -0
- package/src/schema/table-def.ts +312 -0
- package/src/schema-management/common.ts +44 -0
- package/src/schema-management/migrations.ts +188 -0
- package/src/schema-management/validate-mutation-defs.ts +63 -0
- package/src/sql-queries/index.ts +3 -0
- package/src/sql-queries/misc.ts +2 -0
- package/src/sql-queries/sql-queries.ts +359 -0
- package/src/sql-queries/sql-query-builder.ts +135 -0
- package/src/sql-queries/types.ts +97 -0
- package/src/sync/index.ts +1 -0
- package/src/sync/next/ambient.d.ts +3 -0
- package/src/sync/next/compact-events.ts +218 -0
- package/src/sync/next/facts.ts +229 -0
- package/src/sync/next/graphology.ts +49 -0
- package/src/sync/next/graphology_.ts +2 -0
- package/src/sync/next/history-dag.ts +109 -0
- package/src/sync/next/mod.ts +4 -0
- package/src/sync/next/rebase-events.ts +97 -0
- package/src/sync/next/test/compact-events.calculator.test.ts +121 -0
- package/src/sync/next/test/compact-events.test.ts +232 -0
- package/src/sync/next/test/mod.ts +1 -0
- package/src/sync/next/test/mutation-fixtures.ts +230 -0
- package/src/sync/sync.ts +46 -0
- package/src/util.ts +56 -0
- package/src/version.ts +13 -0
- package/tsconfig.json +11 -0
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { prepareBindValues } from '../util.js';
|
|
2
|
+
// TODO bring back statement caching
|
|
3
|
+
// will require proper scope-aware cleanup etc (for testing and apps with multiple LiveStore instances)
|
|
4
|
+
// const cachedStmts = new Map<string, PreparedStatement>()
|
|
5
|
+
export const dbExecute = (db, queryStr, bindValues) => {
|
|
6
|
+
// let stmt = cachedStmts.get(queryStr)
|
|
7
|
+
// if (!stmt) {
|
|
8
|
+
const stmt = db.prepare(queryStr);
|
|
9
|
+
// cachedStmts.set(queryStr, stmt)
|
|
10
|
+
// }
|
|
11
|
+
const preparedBindValues = bindValues ? prepareBindValues(bindValues, queryStr) : undefined;
|
|
12
|
+
stmt.execute(preparedBindValues);
|
|
13
|
+
stmt.finalize();
|
|
14
|
+
};
|
|
15
|
+
export const dbSelect = (db, queryStr, bindValues) => {
|
|
16
|
+
// let stmt = cachedStmts.get(queryStr)
|
|
17
|
+
// if (!stmt) {
|
|
18
|
+
const stmt = db.prepare(queryStr);
|
|
19
|
+
// cachedStmts.set(queryStr, stmt)
|
|
20
|
+
// }
|
|
21
|
+
const res = stmt.select(bindValues ? prepareBindValues(bindValues, queryStr) : undefined);
|
|
22
|
+
stmt.finalize();
|
|
23
|
+
return res;
|
|
24
|
+
};
|
|
25
|
+
//# sourceMappingURL=common.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"common.js","sourceRoot":"","sources":["../../src/schema-management/common.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAE9C,oCAAoC;AACpC,uGAAuG;AACvG,2DAA2D;AAE3D,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC,EAAuB,EAAE,QAAgB,EAAE,UAAyB,EAAE,EAAE;IAChG,uCAAuC;IACvC,eAAe;IACf,MAAM,IAAI,GAAG,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IACjC,kCAAkC;IAClC,IAAI;IAEJ,MAAM,kBAAkB,GAAG,UAAU,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAA;IAE3F,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAA;IAEhC,IAAI,CAAC,QAAQ,EAAE,CAAA;AACjB,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAI,EAAuB,EAAE,QAAgB,EAAE,UAAyB,EAAE,EAAE;IAClG,uCAAuC;IACvC,eAAe;IACf,MAAM,IAAI,GAAG,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;IACjC,kCAAkC;IAClC,IAAI;IAEJ,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAI,UAAU,CAAC,CAAC,CAAC,iBAAiB,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA;IAC5F,IAAI,CAAC,QAAQ,EAAE,CAAA;IACf,OAAO,GAAG,CAAA;AACZ,CAAC,CAAA"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { SqliteAst } from '@livestore/db-schema';
|
|
2
|
+
import { Effect } from '@livestore/utils/effect';
|
|
3
|
+
import type { SynchronousDatabase } from '../adapter-types.js';
|
|
4
|
+
import type { LiveStoreSchema } from '../schema/index.js';
|
|
5
|
+
import type { SchemaManager } from './common.js';
|
|
6
|
+
export declare const makeSchemaManager: (db: SynchronousDatabase) => Effect.Effect<SchemaManager>;
|
|
7
|
+
export declare const migrateDb: ({ db, schema, onProgress, }: {
|
|
8
|
+
db: SynchronousDatabase;
|
|
9
|
+
schema: LiveStoreSchema;
|
|
10
|
+
onProgress?: (opts: {
|
|
11
|
+
done: number;
|
|
12
|
+
total: number;
|
|
13
|
+
}) => Effect.Effect<void>;
|
|
14
|
+
}) => Effect.Effect<void, import("../adapter-types.js").UnexpectedError, never>;
|
|
15
|
+
export declare const migrateTable: ({ db, tableAst, schemaHash, behaviour, skipMetaTable, }: {
|
|
16
|
+
db: SynchronousDatabase;
|
|
17
|
+
tableAst: SqliteAst.Table;
|
|
18
|
+
schemaHash?: number;
|
|
19
|
+
behaviour: "drop-and-recreate" | "create-if-not-exists";
|
|
20
|
+
skipMetaTable?: boolean;
|
|
21
|
+
}) => Effect.Effect<void, never, never>;
|
|
22
|
+
export declare const makeColumnSpec: (tableAst: SqliteAst.Table) => string;
|
|
23
|
+
//# sourceMappingURL=migrations.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrations.d.ts","sourceRoot":"","sources":["../../src/schema-management/migrations.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAa,MAAM,sBAAsB,CAAA;AAE3D,OAAO,EAAE,MAAM,EAA0B,MAAM,yBAAyB,CAAA;AAExE,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAA;AAC9D,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AAUzD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAMhD,eAAO,MAAM,iBAAiB,OAAQ,mBAAmB,KAAG,MAAM,CAAC,MAAM,CAAC,aAAa,CAwBnF,CAAA;AAGJ,eAAO,MAAM,SAAS,gCAInB;IACD,EAAE,EAAE,mBAAmB,CAAA;IACvB,MAAM,EAAE,eAAe,CAAA;IACvB,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;CAC5E,8EAqDG,CAAA;AAEJ,eAAO,MAAM,YAAY,4DAMtB;IACD,EAAE,EAAE,mBAAmB,CAAA;IACvB,QAAQ,EAAE,SAAS,CAAC,KAAK,CAAA;IACzB,UAAU,CAAC,EAAE,MAAM,CAAA;IACnB,SAAS,EAAE,mBAAmB,GAAG,sBAAsB,CAAA;IACvD,aAAa,CAAC,EAAE,OAAO,CAAA;CACxB,sCA8ByG,CAAA;AAO1G,eAAO,MAAM,cAAc,aAAc,SAAS,CAAC,KAAK,WAQvD,CAAA"}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { SqliteAst, SqliteDsl } from '@livestore/db-schema';
|
|
2
|
+
import { memoizeByStringifyArgs } from '@livestore/utils';
|
|
3
|
+
import { Effect, Schema as EffectSchema } from '@livestore/utils/effect';
|
|
4
|
+
import { SCHEMA_META_TABLE, SCHEMA_MUTATIONS_META_TABLE, schemaMetaTable, schemaMutationsMetaTable, systemTables, } from '../schema/system-tables.js';
|
|
5
|
+
import { sql } from '../util.js';
|
|
6
|
+
import { dbExecute, dbSelect } from './common.js';
|
|
7
|
+
import { validateSchema } from './validate-mutation-defs.js';
|
|
8
|
+
const getMemoizedTimestamp = memoizeByStringifyArgs(() => new Date().toISOString());
|
|
9
|
+
export const makeSchemaManager = (db) => Effect.gen(function* () {
|
|
10
|
+
yield* migrateTable({
|
|
11
|
+
db,
|
|
12
|
+
tableAst: schemaMutationsMetaTable.sqliteDef.ast,
|
|
13
|
+
behaviour: 'create-if-not-exists',
|
|
14
|
+
});
|
|
15
|
+
return {
|
|
16
|
+
getMutationDefInfos: () => dbSelect(db, sql `SELECT * FROM ${SCHEMA_MUTATIONS_META_TABLE}`),
|
|
17
|
+
setMutationDefInfo: (info) => {
|
|
18
|
+
dbExecute(db, sql `INSERT OR REPLACE INTO ${SCHEMA_MUTATIONS_META_TABLE} (mutationName, schemaHash, updatedAt) VALUES ($mutationName, $schemaHash, $updatedAt)`, {
|
|
19
|
+
mutationName: info.mutationName,
|
|
20
|
+
schemaHash: info.schemaHash,
|
|
21
|
+
updatedAt: new Date().toISOString(),
|
|
22
|
+
});
|
|
23
|
+
},
|
|
24
|
+
};
|
|
25
|
+
});
|
|
26
|
+
// TODO more graceful DB migration (e.g. backup DB before destructive migrations)
|
|
27
|
+
export const migrateDb = ({ db, schema, onProgress, }) => Effect.gen(function* () {
|
|
28
|
+
yield* migrateTable({
|
|
29
|
+
db,
|
|
30
|
+
tableAst: schemaMetaTable.sqliteDef.ast,
|
|
31
|
+
behaviour: 'create-if-not-exists',
|
|
32
|
+
});
|
|
33
|
+
// TODO enforce that migrating tables isn't allowed once the store is running
|
|
34
|
+
const schemaManager = yield* makeSchemaManager(db);
|
|
35
|
+
yield* validateSchema(schema, schemaManager);
|
|
36
|
+
const schemaMetaRows = dbSelect(db, sql `SELECT * FROM ${SCHEMA_META_TABLE}`);
|
|
37
|
+
const dbSchemaHashByTable = Object.fromEntries(schemaMetaRows.map(({ tableName, schemaHash }) => [tableName, schemaHash]));
|
|
38
|
+
const tableDefs = new Set([
|
|
39
|
+
// NOTE it's important the `SCHEMA_META_TABLE` comes first since we're writing to it below
|
|
40
|
+
...systemTables,
|
|
41
|
+
...Array.from(schema.tables.values()).filter((_) => _.sqliteDef.name !== SCHEMA_META_TABLE),
|
|
42
|
+
]);
|
|
43
|
+
const tablesToMigrate = new Set();
|
|
44
|
+
for (const tableDef of tableDefs) {
|
|
45
|
+
const tableAst = tableDef.sqliteDef.ast;
|
|
46
|
+
const tableName = tableAst.name;
|
|
47
|
+
const dbSchemaHash = dbSchemaHashByTable[tableName];
|
|
48
|
+
const schemaHash = SqliteAst.hash(tableAst);
|
|
49
|
+
if (schemaHash !== dbSchemaHash) {
|
|
50
|
+
tablesToMigrate.add({ tableAst, schemaHash });
|
|
51
|
+
console.log(`Schema hash mismatch for table '${tableName}' (DB: ${dbSchemaHash}, expected: ${schemaHash}), migrating table...`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
let processedTables = 0;
|
|
55
|
+
const tablesCount = tablesToMigrate.size;
|
|
56
|
+
for (const { tableAst, schemaHash } of tablesToMigrate) {
|
|
57
|
+
yield* migrateTable({ db, tableAst, schemaHash, behaviour: 'create-if-not-exists' });
|
|
58
|
+
if (onProgress !== undefined) {
|
|
59
|
+
processedTables++;
|
|
60
|
+
yield* onProgress({ done: processedTables, total: tablesCount });
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
});
|
|
64
|
+
export const migrateTable = ({ db, tableAst, schemaHash = SqliteAst.hash(tableAst), behaviour, skipMetaTable = false, }) => Effect.gen(function* () {
|
|
65
|
+
// console.log(`Migrating table '${tableAst.name}'...`)
|
|
66
|
+
const tableName = tableAst.name;
|
|
67
|
+
const columnSpec = makeColumnSpec(tableAst);
|
|
68
|
+
if (behaviour === 'drop-and-recreate') {
|
|
69
|
+
// TODO need to possibly handle cascading deletes due to foreign keys
|
|
70
|
+
dbExecute(db, sql `drop table if exists ${tableName}`);
|
|
71
|
+
dbExecute(db, sql `create table if not exists ${tableName} (${columnSpec}) strict`);
|
|
72
|
+
}
|
|
73
|
+
else if (behaviour === 'create-if-not-exists') {
|
|
74
|
+
dbExecute(db, sql `create table if not exists ${tableName} (${columnSpec}) strict`);
|
|
75
|
+
}
|
|
76
|
+
for (const index of tableAst.indexes) {
|
|
77
|
+
dbExecute(db, createIndexFromDefinition(tableName, index));
|
|
78
|
+
}
|
|
79
|
+
if (skipMetaTable !== true) {
|
|
80
|
+
const updatedAt = getMemoizedTimestamp();
|
|
81
|
+
dbExecute(db, sql `
|
|
82
|
+
INSERT INTO ${SCHEMA_META_TABLE} (tableName, schemaHash, updatedAt) VALUES ($tableName, $schemaHash, $updatedAt)
|
|
83
|
+
ON CONFLICT (tableName) DO UPDATE SET schemaHash = $schemaHash, updatedAt = $updatedAt;
|
|
84
|
+
`, { tableName, schemaHash, updatedAt });
|
|
85
|
+
}
|
|
86
|
+
}).pipe(Effect.withSpan('@livestore/common:migrateTable', { attributes: { tableName: tableAst.name } }));
|
|
87
|
+
const createIndexFromDefinition = (tableName, index) => {
|
|
88
|
+
const uniqueStr = index.unique ? 'UNIQUE' : '';
|
|
89
|
+
return sql `create ${uniqueStr} index if not exists ${index.name} on ${tableName} (${index.columns.join(', ')})`;
|
|
90
|
+
};
|
|
91
|
+
export const makeColumnSpec = (tableAst) => {
|
|
92
|
+
const primaryKeys = tableAst.columns.filter((_) => _.primaryKey).map((_) => _.name);
|
|
93
|
+
const columnDefStrs = tableAst.columns.map(toSqliteColumnSpec);
|
|
94
|
+
if (primaryKeys.length > 0) {
|
|
95
|
+
columnDefStrs.push(`PRIMARY KEY (${primaryKeys.join(', ')})`);
|
|
96
|
+
}
|
|
97
|
+
return columnDefStrs.join(', ');
|
|
98
|
+
};
|
|
99
|
+
/** NOTE primary keys are applied on a table level not on a column level to account for multi-column primary keys */
|
|
100
|
+
const toSqliteColumnSpec = (column) => {
|
|
101
|
+
const columnTypeStr = column.type._tag;
|
|
102
|
+
const nullableStr = column.nullable === false ? 'not null' : '';
|
|
103
|
+
const defaultValueStr = (() => {
|
|
104
|
+
if (column.default._tag === 'None')
|
|
105
|
+
return '';
|
|
106
|
+
if (SqliteDsl.isSqlDefaultValue(column.default.value))
|
|
107
|
+
return `default ${column.default.value.sql}`;
|
|
108
|
+
const encodeValue = EffectSchema.encodeSync(column.schema);
|
|
109
|
+
const encodedDefaultValue = encodeValue(column.default.value);
|
|
110
|
+
if (columnTypeStr === 'text')
|
|
111
|
+
return `default '${encodedDefaultValue}'`;
|
|
112
|
+
return `default ${encodedDefaultValue}`;
|
|
113
|
+
})();
|
|
114
|
+
return `${column.name} ${columnTypeStr} ${nullableStr} ${defaultValueStr}`;
|
|
115
|
+
};
|
|
116
|
+
//# sourceMappingURL=migrations.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"migrations.js","sourceRoot":"","sources":["../../src/schema-management/migrations.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { Effect } from '@livestore/utils/effect';
|
|
2
|
+
import { UnexpectedError } from '../adapter-types.js';
|
|
3
|
+
import type { LiveStoreSchema } from '../schema/index.js';
|
|
4
|
+
import type { MutationDef } from '../schema/mutations.js';
|
|
5
|
+
import type { MutationDefInfo, SchemaManager } from './common.js';
|
|
6
|
+
export declare const validateSchema: (schema: LiveStoreSchema, schemaManager: SchemaManager) => Effect.Effect<void, UnexpectedError, never>;
|
|
7
|
+
export declare const validateMutationDef: (mutationDef: MutationDef.Any, schemaManager: SchemaManager, registeredMutationDefInfo: MutationDefInfo | undefined) => void;
|
|
8
|
+
//# sourceMappingURL=validate-mutation-defs.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-mutation-defs.d.ts","sourceRoot":"","sources":["../../src/schema-management/validate-mutation-defs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAU,MAAM,yBAAyB,CAAA;AAExD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AACrD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACzD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,wBAAwB,CAAA;AACzD,OAAO,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;AAEjE,eAAO,MAAM,cAAc,WAAY,eAAe,iBAAiB,aAAa,gDAwBhF,CAAA;AAEJ,eAAO,MAAM,mBAAmB,gBACjB,WAAW,CAAC,GAAG,iBACb,aAAa,6BACD,eAAe,GAAG,SAAS,SA0BvD,CAAA"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import { Effect, Schema } from '@livestore/utils/effect';
|
|
2
|
+
import { UnexpectedError } from '../adapter-types.js';
|
|
3
|
+
export const validateSchema = (schema, schemaManager) => Effect.gen(function* () {
|
|
4
|
+
// Validate mutation definitions
|
|
5
|
+
const registeredMutationDefInfos = schemaManager.getMutationDefInfos();
|
|
6
|
+
const missingMutationDefs = registeredMutationDefInfos.filter((registeredMutationDefInfo) => !schema.mutations.has(registeredMutationDefInfo.mutationName));
|
|
7
|
+
if (missingMutationDefs.length > 0) {
|
|
8
|
+
yield* new UnexpectedError({
|
|
9
|
+
cause: `Missing mutation definitions: ${missingMutationDefs.map((info) => info.mutationName).join(', ')}`,
|
|
10
|
+
});
|
|
11
|
+
}
|
|
12
|
+
for (const [, mutationDef] of schema.mutations) {
|
|
13
|
+
const registeredMutationDefInfo = registeredMutationDefInfos.find((info) => info.mutationName === mutationDef.name);
|
|
14
|
+
validateMutationDef(mutationDef, schemaManager, registeredMutationDefInfo);
|
|
15
|
+
}
|
|
16
|
+
// Validate table schemas
|
|
17
|
+
});
|
|
18
|
+
export const validateMutationDef = (mutationDef, schemaManager, registeredMutationDefInfo) => {
|
|
19
|
+
const schemaHash = Schema.hash(mutationDef.schema);
|
|
20
|
+
if (registeredMutationDefInfo === undefined) {
|
|
21
|
+
schemaManager.setMutationDefInfo({
|
|
22
|
+
schemaHash,
|
|
23
|
+
mutationName: mutationDef.name,
|
|
24
|
+
});
|
|
25
|
+
return;
|
|
26
|
+
}
|
|
27
|
+
if (schemaHash === registeredMutationDefInfo.schemaHash)
|
|
28
|
+
return;
|
|
29
|
+
// TODO bring back some form of schema compatibility check (see https://github.com/livestorejs/livestore/issues/69)
|
|
30
|
+
// const newSchemaIsCompatibleWithOldSchema = Schema.isSubType(jsonSchemaDefFromMgmtStore, mutationDef.schema)
|
|
31
|
+
// if (!newSchemaIsCompatibleWithOldSchema) {
|
|
32
|
+
// shouldNeverHappen(`Schema for mutation ${mutationDef.name} has changed in an incompatible way`)
|
|
33
|
+
// }
|
|
34
|
+
schemaManager.setMutationDefInfo({
|
|
35
|
+
schemaHash,
|
|
36
|
+
mutationName: mutationDef.name,
|
|
37
|
+
});
|
|
38
|
+
};
|
|
39
|
+
//# sourceMappingURL=validate-mutation-defs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"validate-mutation-defs.js","sourceRoot":"","sources":["../../src/schema-management/validate-mutation-defs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAExD,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAKrD,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,MAAuB,EAAE,aAA4B,EAAE,EAAE,CACtF,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAClB,gCAAgC;IAChC,MAAM,0BAA0B,GAAG,aAAa,CAAC,mBAAmB,EAAE,CAAA;IAEtE,MAAM,mBAAmB,GAAG,0BAA0B,CAAC,MAAM,CAC3D,CAAC,yBAAyB,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,yBAAyB,CAAC,YAAY,CAAC,CAC7F,CAAA;IAED,IAAI,mBAAmB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACnC,KAAK,CAAC,CAAC,IAAI,eAAe,CAAC;YACzB,KAAK,EAAE,iCAAiC,mBAAmB,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;SAC1G,CAAC,CAAA;IACJ,CAAC;IAED,KAAK,MAAM,CAAC,EAAE,WAAW,CAAC,IAAI,MAAM,CAAC,SAAS,EAAE,CAAC;QAC/C,MAAM,yBAAyB,GAAG,0BAA0B,CAAC,IAAI,CAC/D,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,KAAK,WAAW,CAAC,IAAI,CACjD,CAAA;QAED,mBAAmB,CAAC,WAAW,EAAE,aAAa,EAAE,yBAAyB,CAAC,CAAA;IAC5E,CAAC;IAED,yBAAyB;AAC3B,CAAC,CAAC,CAAA;AAEJ,MAAM,CAAC,MAAM,mBAAmB,GAAG,CACjC,WAA4B,EAC5B,aAA4B,EAC5B,yBAAsD,EACtD,EAAE;IACF,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAA;IAElD,IAAI,yBAAyB,KAAK,SAAS,EAAE,CAAC;QAC5C,aAAa,CAAC,kBAAkB,CAAC;YAC/B,UAAU;YACV,YAAY,EAAE,WAAW,CAAC,IAAI;SAC/B,CAAC,CAAA;QAEF,OAAM;IACR,CAAC;IAED,IAAI,UAAU,KAAK,yBAAyB,CAAC,UAAU;QAAE,OAAM;IAE/D,mHAAmH;IACnH,8GAA8G;IAE9G,6CAA6C;IAC7C,oGAAoG;IACpG,IAAI;IAEJ,aAAa,CAAC,kBAAkB,CAAC;QAC/B,UAAU;QACV,YAAY,EAAE,WAAW,CAAC,IAAI;KAC/B,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/sql-queries/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,wBAAwB,CAAA;AACtC,cAAc,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/sql-queries/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,wBAAwB,CAAA;AACtC,cAAc,YAAY,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"misc.d.ts","sourceRoot":"","sources":["../../src/sql-queries/misc.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,aAAa,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,OAAO,CAAC,KAAG,CAAC,MAAM,CAAC,GAAG,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAC3C,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"misc.js","sourceRoot":"","sources":["../../src/sql-queries/misc.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,aAAa,GAAG,CAAgC,GAAM,EAAoC,EAAE,CACvG,MAAM,CAAC,OAAO,CAAC,GAAG,CAAqC,CAAA"}
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import type { SqliteDsl } from '@livestore/db-schema';
|
|
2
|
+
import * as ClientTypes from './types.js';
|
|
3
|
+
export type BindValues = {
|
|
4
|
+
readonly [columnName: string]: any;
|
|
5
|
+
};
|
|
6
|
+
export declare const findManyRows: <TColumns extends SqliteDsl.Columns>({ columns, tableName, where, limit, }: {
|
|
7
|
+
tableName: string;
|
|
8
|
+
columns: TColumns;
|
|
9
|
+
where: ClientTypes.WhereValuesForColumns<TColumns>;
|
|
10
|
+
limit?: number;
|
|
11
|
+
}) => [string, BindValues];
|
|
12
|
+
export declare const countRows: <TColumns extends SqliteDsl.Columns>({ columns, tableName, where, }: {
|
|
13
|
+
tableName: string;
|
|
14
|
+
columns: TColumns;
|
|
15
|
+
where: ClientTypes.WhereValuesForColumns<TColumns>;
|
|
16
|
+
}) => [string, BindValues];
|
|
17
|
+
export declare const insertRow: <TColumns extends SqliteDsl.Columns>({ tableName, columns, values, options, }: {
|
|
18
|
+
tableName: string;
|
|
19
|
+
columns: TColumns;
|
|
20
|
+
values: ClientTypes.DecodedValuesForColumns<TColumns>;
|
|
21
|
+
options?: {
|
|
22
|
+
orReplace: boolean;
|
|
23
|
+
};
|
|
24
|
+
}) => [string, BindValues];
|
|
25
|
+
export declare const insertRowPrepared: <TColumns extends SqliteDsl.Columns>({ tableName, columns, options, }: {
|
|
26
|
+
tableName: string;
|
|
27
|
+
columns: TColumns;
|
|
28
|
+
options?: {
|
|
29
|
+
orReplace: boolean;
|
|
30
|
+
};
|
|
31
|
+
}) => string;
|
|
32
|
+
export declare const insertRows: <TColumns extends SqliteDsl.Columns>({ columns, tableName, valuesArray, }: {
|
|
33
|
+
tableName: string;
|
|
34
|
+
columns: TColumns;
|
|
35
|
+
valuesArray: ClientTypes.DecodedValuesForColumns<TColumns>[];
|
|
36
|
+
}) => [string, BindValues];
|
|
37
|
+
export declare const insertOrIgnoreRow: <TColumns extends SqliteDsl.Columns>({ columns, tableName, values: values_, returnRow, }: {
|
|
38
|
+
tableName: string;
|
|
39
|
+
columns: TColumns;
|
|
40
|
+
values: ClientTypes.DecodedValuesForColumns<TColumns>;
|
|
41
|
+
returnRow: boolean;
|
|
42
|
+
}) => [string, BindValues];
|
|
43
|
+
export declare const updateRows: <TColumns extends SqliteDsl.Columns>({ columns, tableName, updateValues: updateValues_, where, }: {
|
|
44
|
+
columns: TColumns;
|
|
45
|
+
tableName: string;
|
|
46
|
+
updateValues: Partial<ClientTypes.DecodedValuesForColumnsAll<TColumns>>;
|
|
47
|
+
where: ClientTypes.WhereValuesForColumns<TColumns>;
|
|
48
|
+
}) => [string, BindValues];
|
|
49
|
+
export declare const deleteRows: <TColumns extends SqliteDsl.Columns>({ columns, tableName, where, }: {
|
|
50
|
+
columns: TColumns;
|
|
51
|
+
tableName: string;
|
|
52
|
+
where: ClientTypes.WhereValuesForColumns<TColumns>;
|
|
53
|
+
}) => [string, BindValues];
|
|
54
|
+
export declare const upsertRow: <TColumns extends SqliteDsl.Columns>({ tableName, columns, createValues: createValues_, updateValues: updateValues_, where, }: {
|
|
55
|
+
tableName: string;
|
|
56
|
+
columns: TColumns;
|
|
57
|
+
createValues: ClientTypes.DecodedValuesForColumns<TColumns>;
|
|
58
|
+
updateValues: Partial<ClientTypes.DecodedValuesForColumnsAll<TColumns>>;
|
|
59
|
+
where: ClientTypes.WhereValuesForColumns<TColumns>;
|
|
60
|
+
}) => [string, BindValues];
|
|
61
|
+
export declare const createTable: ({ table, tableName, }: {
|
|
62
|
+
table: SqliteDsl.TableDefinition<any, SqliteDsl.Columns>;
|
|
63
|
+
tableName: string;
|
|
64
|
+
}) => string;
|
|
65
|
+
export declare const makeBindValues: <TColumns extends SqliteDsl.Columns, TKeys extends keyof TColumns>({ columns, values, variablePrefix, skipNil, }: {
|
|
66
|
+
columns: TColumns;
|
|
67
|
+
values: Partial<Record<TKeys, any>>;
|
|
68
|
+
variablePrefix?: string;
|
|
69
|
+
/** So far only used to prepare `where` statements */
|
|
70
|
+
skipNil?: boolean;
|
|
71
|
+
}) => Record<string, any>;
|
|
72
|
+
//# sourceMappingURL=sql-queries.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sql-queries.d.ts","sourceRoot":"","sources":["../../src/sql-queries/sql-queries.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import { shouldNeverHappen } from '@livestore/utils';
|
|
2
|
+
import { pipe, ReadonlyArray, Schema, TreeFormatter } from '@livestore/utils/effect';
|
|
3
|
+
import { sql } from '../util.js';
|
|
4
|
+
import { objectEntries } from './misc.js';
|
|
5
|
+
import * as ClientTypes from './types.js';
|
|
6
|
+
export const findManyRows = ({ columns, tableName, where, limit, }) => {
|
|
7
|
+
const whereSql = buildWhereSql({ where });
|
|
8
|
+
const whereModifier = whereSql === '' ? '' : `WHERE ${whereSql}`;
|
|
9
|
+
const limitModifier = limit ? `LIMIT ${limit}` : '';
|
|
10
|
+
const whereBindValues = makeBindValues({ columns, values: where, variablePrefix: 'where_', skipNil: true });
|
|
11
|
+
return [sql `SELECT * FROM ${tableName} ${whereModifier} ${limitModifier}`, whereBindValues];
|
|
12
|
+
};
|
|
13
|
+
export const countRows = ({ columns, tableName, where, }) => {
|
|
14
|
+
const whereSql = buildWhereSql({ where });
|
|
15
|
+
const whereModifier = whereSql === '' ? '' : `WHERE ${whereSql}`;
|
|
16
|
+
const whereBindValues = makeBindValues({ columns, values: where, variablePrefix: 'where_', skipNil: true });
|
|
17
|
+
return [sql `SELECT count(1) FROM ${tableName} ${whereModifier}`, whereBindValues];
|
|
18
|
+
};
|
|
19
|
+
export const insertRow = ({ tableName, columns, values, options = { orReplace: false }, }) => {
|
|
20
|
+
const stmt = insertRowPrepared({ tableName, columns, options });
|
|
21
|
+
return [stmt, makeBindValues({ columns, values })];
|
|
22
|
+
};
|
|
23
|
+
export const insertRowPrepared = ({ tableName, columns, options = { orReplace: false }, }) => {
|
|
24
|
+
const keysStr = Object.keys(columns).join(', ');
|
|
25
|
+
const valuesStr = Object.keys(columns)
|
|
26
|
+
.map((key) => `$${key}`)
|
|
27
|
+
.join(', ');
|
|
28
|
+
return sql `INSERT ${options.orReplace ? 'OR REPLACE ' : ''}INTO ${tableName} (${keysStr}) VALUES (${valuesStr})`;
|
|
29
|
+
};
|
|
30
|
+
export const insertRows = ({ columns, tableName, valuesArray, }) => {
|
|
31
|
+
const keysStr = Object.keys(valuesArray[0]).join(', ');
|
|
32
|
+
// NOTE consider batching for large arrays (https://sqlite.org/forum/info/f832398c19d30a4a)
|
|
33
|
+
const valuesStrs = valuesArray
|
|
34
|
+
.map((values, itemIndex) => Object.keys(values)
|
|
35
|
+
.map((_) => `$item_${itemIndex}_${_}`)
|
|
36
|
+
.join(', '))
|
|
37
|
+
.map((_) => `(${_})`)
|
|
38
|
+
.join(', ');
|
|
39
|
+
const bindValues = valuesArray.reduce((acc, values, itemIndex) => ({
|
|
40
|
+
...acc,
|
|
41
|
+
...makeBindValues({ columns, values, variablePrefix: `item_${itemIndex}_` }),
|
|
42
|
+
}), {});
|
|
43
|
+
return [sql `INSERT INTO ${tableName} (${keysStr}) VALUES ${valuesStrs}`, bindValues];
|
|
44
|
+
};
|
|
45
|
+
export const insertOrIgnoreRow = ({ columns, tableName, values: values_, returnRow, }) => {
|
|
46
|
+
const values = filterUndefinedFields(values_);
|
|
47
|
+
const keysStr = Object.keys(values).join(', ');
|
|
48
|
+
const valuesStr = Object.keys(values)
|
|
49
|
+
.map((_) => `$${_}`)
|
|
50
|
+
.join(', ');
|
|
51
|
+
const bindValues = makeBindValues({ columns, values });
|
|
52
|
+
const returningStmt = returnRow ? 'RETURNING *' : '';
|
|
53
|
+
return [sql `INSERT OR IGNORE INTO ${tableName} (${keysStr}) VALUES (${valuesStr}) ${returningStmt}`, bindValues];
|
|
54
|
+
};
|
|
55
|
+
export const updateRows = ({ columns, tableName, updateValues: updateValues_, where, }) => {
|
|
56
|
+
const updateValues = filterUndefinedFields(updateValues_);
|
|
57
|
+
// TODO return an Option instead of `select 1` if there are no update values
|
|
58
|
+
if (Object.keys(updateValues).length === 0) {
|
|
59
|
+
return [sql `select 1`, {}];
|
|
60
|
+
}
|
|
61
|
+
const updateValueStr = Object.keys(updateValues)
|
|
62
|
+
.map((columnName) => `${columnName} = $update_${columnName}`)
|
|
63
|
+
.join(', ');
|
|
64
|
+
const bindValues = {
|
|
65
|
+
...makeBindValues({ columns, values: updateValues, variablePrefix: 'update_' }),
|
|
66
|
+
...makeBindValues({ columns, values: where, variablePrefix: 'where_', skipNil: true }),
|
|
67
|
+
};
|
|
68
|
+
const whereSql = buildWhereSql({ where });
|
|
69
|
+
const whereModifier = whereSql === '' ? '' : `WHERE ${whereSql}`;
|
|
70
|
+
return [sql `UPDATE ${tableName} SET ${updateValueStr} ${whereModifier}`, bindValues];
|
|
71
|
+
};
|
|
72
|
+
export const deleteRows = ({ columns, tableName, where, }) => {
|
|
73
|
+
const bindValues = {
|
|
74
|
+
...makeBindValues({ columns, values: where, variablePrefix: 'where_', skipNil: true }),
|
|
75
|
+
};
|
|
76
|
+
const whereSql = buildWhereSql({ where });
|
|
77
|
+
const whereModifier = whereSql === '' ? '' : `WHERE ${whereSql}`;
|
|
78
|
+
return [sql `DELETE FROM ${tableName} ${whereModifier}`, bindValues];
|
|
79
|
+
};
|
|
80
|
+
export const upsertRow = ({ tableName, columns, createValues: createValues_, updateValues: updateValues_, where, }) => {
|
|
81
|
+
const createValues = filterUndefinedFields(createValues_);
|
|
82
|
+
const updateValues = filterUndefinedFields(updateValues_);
|
|
83
|
+
const keysStr = Object.keys(createValues).join(', ');
|
|
84
|
+
const createValuesStr = Object.keys(createValues)
|
|
85
|
+
.map((_) => `$create_${_}`)
|
|
86
|
+
.join(', ');
|
|
87
|
+
const conflictStr = Object.keys(where).join(', ');
|
|
88
|
+
const updateValueStr = Object.keys(updateValues)
|
|
89
|
+
.map((columnName) => `${columnName} = $update_${columnName}`)
|
|
90
|
+
.join(', ');
|
|
91
|
+
const bindValues = {
|
|
92
|
+
...makeBindValues({ columns, values: createValues, variablePrefix: 'create_' }),
|
|
93
|
+
...makeBindValues({ columns, values: updateValues, variablePrefix: 'update_' }),
|
|
94
|
+
};
|
|
95
|
+
return [
|
|
96
|
+
sql `
|
|
97
|
+
INSERT INTO ${tableName} (${keysStr})
|
|
98
|
+
VALUES (${createValuesStr})
|
|
99
|
+
ON CONFLICT (${conflictStr}) DO UPDATE SET ${updateValueStr}
|
|
100
|
+
`,
|
|
101
|
+
bindValues,
|
|
102
|
+
];
|
|
103
|
+
};
|
|
104
|
+
export const createTable = ({ table, tableName, }) => {
|
|
105
|
+
const primaryKeys = Object.entries(table.columns)
|
|
106
|
+
.filter(([_, columnDef]) => columnDef.primaryKey)
|
|
107
|
+
.map(([columnName, _]) => columnName);
|
|
108
|
+
const columnDefStrs = Object.entries(table.columns).map(([columnName, columnDef]) => {
|
|
109
|
+
const nullModifier = columnDef.nullable === true ? '' : 'NOT NULL';
|
|
110
|
+
const defaultModifier = columnDef.default._tag === 'None' ? '' : `DEFAULT ${columnDef.default.value}`;
|
|
111
|
+
return sql `${columnName} ${columnDef.columnType} ${nullModifier} ${defaultModifier}`;
|
|
112
|
+
});
|
|
113
|
+
if (primaryKeys.length > 0) {
|
|
114
|
+
columnDefStrs.push(`PRIMARY KEY (${primaryKeys.join(', ')})`);
|
|
115
|
+
}
|
|
116
|
+
return sql `CREATE TABLE ${tableName} (${columnDefStrs.join(', ')});`;
|
|
117
|
+
};
|
|
118
|
+
export const makeBindValues = ({ columns, values, variablePrefix = '', skipNil, }) => {
|
|
119
|
+
const codecMap = pipe(columns, objectEntries, ReadonlyArray.map(([columnName, columnDef]) => [
|
|
120
|
+
columnName,
|
|
121
|
+
(value) => {
|
|
122
|
+
if (columnDef.nullable === true && (value === null || value === undefined))
|
|
123
|
+
return null;
|
|
124
|
+
const res = Schema.encodeEither(columnDef.schema)(value);
|
|
125
|
+
if (res._tag === 'Left') {
|
|
126
|
+
const parseErrorStr = TreeFormatter.formatErrorSync(res.left);
|
|
127
|
+
const expectedSchemaStr = String(columnDef.schema.ast);
|
|
128
|
+
console.error(`\
|
|
129
|
+
Error making bind values for SQL query for column "${columnName}".
|
|
130
|
+
|
|
131
|
+
Expected schema: ${expectedSchemaStr}
|
|
132
|
+
|
|
133
|
+
Error: ${parseErrorStr}
|
|
134
|
+
|
|
135
|
+
Value:`, value);
|
|
136
|
+
debugger;
|
|
137
|
+
throw res.left;
|
|
138
|
+
}
|
|
139
|
+
else {
|
|
140
|
+
return res.right;
|
|
141
|
+
}
|
|
142
|
+
},
|
|
143
|
+
]), Object.fromEntries);
|
|
144
|
+
return pipe(Object.entries(values)
|
|
145
|
+
// NOTE null/undefined values are handled via explicit SQL syntax and don't need to be provided as bind values
|
|
146
|
+
.filter(([, value]) => skipNil !== true || (value !== null && value !== undefined))
|
|
147
|
+
.flatMap(([columnName, value]) => {
|
|
148
|
+
const codec = codecMap[columnName] ?? shouldNeverHappen(`No codec found for column "${columnName}"`);
|
|
149
|
+
// remap complex where-values with `op`
|
|
150
|
+
if (typeof value === 'object' && value !== null && 'op' in value) {
|
|
151
|
+
switch (value.op) {
|
|
152
|
+
case 'in': {
|
|
153
|
+
return value.val.map((value, i) => [`${variablePrefix}${columnName}_${i}`, codec(value)]);
|
|
154
|
+
}
|
|
155
|
+
case '=':
|
|
156
|
+
case '>':
|
|
157
|
+
case '<': {
|
|
158
|
+
return [[`${variablePrefix}${columnName}`, codec(value.val)]];
|
|
159
|
+
}
|
|
160
|
+
default: {
|
|
161
|
+
throw new Error(`Unknown op: ${value.op}`);
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
else {
|
|
166
|
+
return [[`${variablePrefix}${columnName}`, codec(value)]];
|
|
167
|
+
}
|
|
168
|
+
}), Object.fromEntries);
|
|
169
|
+
};
|
|
170
|
+
const buildWhereSql = ({ where, }) => {
|
|
171
|
+
const getWhereOp = (columnName, value) => {
|
|
172
|
+
if (value === null) {
|
|
173
|
+
return `IS NULL`;
|
|
174
|
+
}
|
|
175
|
+
else if (typeof value === 'object' && typeof value.op === 'string' && ClientTypes.isValidWhereOp(value.op)) {
|
|
176
|
+
return `${value.op} $where_${columnName}`;
|
|
177
|
+
}
|
|
178
|
+
else if (typeof value === 'object' && typeof value.op === 'string' && value.op === 'in') {
|
|
179
|
+
return `in (${value.val.map((_, i) => `$where_${columnName}_${i}`).join(', ')})`;
|
|
180
|
+
}
|
|
181
|
+
else {
|
|
182
|
+
return `= $where_${columnName}`;
|
|
183
|
+
}
|
|
184
|
+
};
|
|
185
|
+
return pipe(where, objectEntries, ReadonlyArray.map(([columnName, value]) => `${columnName} ${getWhereOp(columnName, value)}`), ReadonlyArray.join(' AND '));
|
|
186
|
+
};
|
|
187
|
+
// TODO better typing
|
|
188
|
+
const filterUndefinedFields = (obj) => {
|
|
189
|
+
return Object.fromEntries(Object.entries(obj).filter(([, value]) => value !== undefined));
|
|
190
|
+
};
|
|
191
|
+
//# sourceMappingURL=sql-queries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sql-queries.js","sourceRoot":"","sources":["../../src/sql-queries/sql-queries.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { SqliteDsl } from '@livestore/db-schema';
|
|
2
|
+
import type { BindValues } from './sql-queries.js';
|
|
3
|
+
import type * as ClientTypes from './types.js';
|
|
4
|
+
export type SqlQuery = [stmt: string, bindValues: BindValues, tableName: string];
|
|
5
|
+
export declare const makeSqlQueryBuilder: <TSchema extends SqliteDsl.DbSchema>(schema: TSchema) => {
|
|
6
|
+
findManyRows: <TTableName extends keyof TSchema & string>({ tableName, where, limit, }: {
|
|
7
|
+
tableName: TTableName;
|
|
8
|
+
where: ClientTypes.WhereValuesForTable<TSchema, TTableName>;
|
|
9
|
+
limit?: number;
|
|
10
|
+
}) => [string, BindValues, TTableName];
|
|
11
|
+
countRows: <TTableName extends keyof TSchema & string>({ tableName, where, }: {
|
|
12
|
+
tableName: TTableName;
|
|
13
|
+
where: ClientTypes.WhereValuesForTable<TSchema, TTableName>;
|
|
14
|
+
}) => [string, BindValues, TTableName];
|
|
15
|
+
insertRow: <TTableName extends keyof TSchema & string>({ tableName, values, options, }: {
|
|
16
|
+
tableName: TTableName;
|
|
17
|
+
values: ClientTypes.DecodedValuesForTable<TSchema, TTableName>;
|
|
18
|
+
options?: {
|
|
19
|
+
orReplace: boolean;
|
|
20
|
+
};
|
|
21
|
+
}) => [string, BindValues, TTableName];
|
|
22
|
+
insertRows: <TTableName extends keyof TSchema & string>({ tableName, valuesArray, }: {
|
|
23
|
+
tableName: TTableName;
|
|
24
|
+
valuesArray: ClientTypes.DecodedValuesForTable<TSchema, TTableName>[];
|
|
25
|
+
}) => [string, BindValues, TTableName];
|
|
26
|
+
insertOrIgnoreRow: <TTableName extends keyof TSchema & string>({ tableName, values, returnRow, }: {
|
|
27
|
+
tableName: TTableName;
|
|
28
|
+
values: ClientTypes.DecodedValuesForTable<TSchema, TTableName>;
|
|
29
|
+
returnRow?: boolean;
|
|
30
|
+
}) => [string, BindValues, TTableName];
|
|
31
|
+
updateRows: <TTableName extends keyof TSchema & string>({ tableName, updateValues, where, }: {
|
|
32
|
+
tableName: TTableName;
|
|
33
|
+
updateValues: Partial<ClientTypes.DecodedValuesForTableAll<TSchema, TTableName>>;
|
|
34
|
+
where: ClientTypes.WhereValuesForTable<TSchema, TTableName>;
|
|
35
|
+
}) => [string, BindValues, TTableName];
|
|
36
|
+
deleteRows: <TTableName extends keyof TSchema & string>({ tableName, where, }: {
|
|
37
|
+
tableName: TTableName;
|
|
38
|
+
where: ClientTypes.WhereValuesForTable<TSchema, TTableName>;
|
|
39
|
+
}) => [string, BindValues, TTableName];
|
|
40
|
+
upsertRow: <TTableName extends keyof TSchema & string>({ tableName, createValues, updateValues, where, }: {
|
|
41
|
+
tableName: TTableName;
|
|
42
|
+
createValues: ClientTypes.DecodedValuesForTable<TSchema, TTableName>;
|
|
43
|
+
updateValues: Partial<ClientTypes.DecodedValuesForTableAll<TSchema, TTableName>>;
|
|
44
|
+
where: ClientTypes.WhereValuesForTable<TSchema, TTableName>;
|
|
45
|
+
}) => [string, BindValues, TTableName];
|
|
46
|
+
};
|
|
47
|
+
//# sourceMappingURL=sql-query-builder.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"sql-query-builder.d.ts","sourceRoot":"","sources":["../../src/sql-queries/sql-query-builder.ts"],"names":[],"mappings":"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"}
|