@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.
Files changed (220) hide show
  1. package/dist/.tsbuildinfo +1 -0
  2. package/dist/__tests__/fixture.d.ts +72 -0
  3. package/dist/__tests__/fixture.d.ts.map +1 -0
  4. package/dist/__tests__/fixture.js +16 -0
  5. package/dist/__tests__/fixture.js.map +1 -0
  6. package/dist/adapter-types.d.ts +202 -0
  7. package/dist/adapter-types.d.ts.map +1 -0
  8. package/dist/adapter-types.js +49 -0
  9. package/dist/adapter-types.js.map +1 -0
  10. package/dist/bounded-collections.d.ts +36 -0
  11. package/dist/bounded-collections.d.ts.map +1 -0
  12. package/dist/bounded-collections.js +98 -0
  13. package/dist/bounded-collections.js.map +1 -0
  14. package/dist/debug-info.d.ts +122 -0
  15. package/dist/debug-info.d.ts.map +1 -0
  16. package/dist/debug-info.js +47 -0
  17. package/dist/debug-info.js.map +1 -0
  18. package/dist/derived-mutations.d.ts +109 -0
  19. package/dist/derived-mutations.d.ts.map +1 -0
  20. package/dist/derived-mutations.js +54 -0
  21. package/dist/derived-mutations.js.map +1 -0
  22. package/dist/derived-mutations.test.d.ts +2 -0
  23. package/dist/derived-mutations.test.d.ts.map +1 -0
  24. package/dist/derived-mutations.test.js +93 -0
  25. package/dist/derived-mutations.test.js.map +1 -0
  26. package/dist/devtools/devtools-bridge.d.ts +12 -0
  27. package/dist/devtools/devtools-bridge.d.ts.map +1 -0
  28. package/dist/devtools/devtools-bridge.js +2 -0
  29. package/dist/devtools/devtools-bridge.js.map +1 -0
  30. package/dist/devtools/devtools-messages.d.ts +705 -0
  31. package/dist/devtools/devtools-messages.d.ts.map +1 -0
  32. package/dist/devtools/devtools-messages.js +178 -0
  33. package/dist/devtools/devtools-messages.js.map +1 -0
  34. package/dist/devtools/devtools-window-message.d.ts +29 -0
  35. package/dist/devtools/devtools-window-message.d.ts.map +1 -0
  36. package/dist/devtools/devtools-window-message.js +33 -0
  37. package/dist/devtools/devtools-window-message.js.map +1 -0
  38. package/dist/devtools/index.d.ts +42 -0
  39. package/dist/devtools/index.d.ts.map +1 -0
  40. package/dist/devtools/index.js +49 -0
  41. package/dist/devtools/index.js.map +1 -0
  42. package/dist/index.d.ts +19 -0
  43. package/dist/index.d.ts.map +1 -0
  44. package/dist/index.js +15 -0
  45. package/dist/index.js.map +1 -0
  46. package/dist/init-singleton-tables.d.ts +4 -0
  47. package/dist/init-singleton-tables.d.ts.map +1 -0
  48. package/dist/init-singleton-tables.js +16 -0
  49. package/dist/init-singleton-tables.js.map +1 -0
  50. package/dist/mutation.d.ts +13 -0
  51. package/dist/mutation.d.ts.map +1 -0
  52. package/dist/mutation.js +43 -0
  53. package/dist/mutation.js.map +1 -0
  54. package/dist/query-info.d.ts +47 -0
  55. package/dist/query-info.d.ts.map +1 -0
  56. package/dist/query-info.js +38 -0
  57. package/dist/query-info.js.map +1 -0
  58. package/dist/rehydrate-from-mutationlog.d.ts +14 -0
  59. package/dist/rehydrate-from-mutationlog.d.ts.map +1 -0
  60. package/dist/rehydrate-from-mutationlog.js +72 -0
  61. package/dist/rehydrate-from-mutationlog.js.map +1 -0
  62. package/dist/schema/index.d.ts +60 -0
  63. package/dist/schema/index.d.ts.map +1 -0
  64. package/dist/schema/index.js +66 -0
  65. package/dist/schema/index.js.map +1 -0
  66. package/dist/schema/mutations.d.ts +227 -0
  67. package/dist/schema/mutations.d.ts.map +1 -0
  68. package/dist/schema/mutations.js +68 -0
  69. package/dist/schema/mutations.js.map +1 -0
  70. package/dist/schema/schema-helpers.d.ts +4 -0
  71. package/dist/schema/schema-helpers.d.ts.map +1 -0
  72. package/dist/schema/schema-helpers.js +30 -0
  73. package/dist/schema/schema-helpers.js.map +1 -0
  74. package/dist/schema/system-tables.d.ts +331 -0
  75. package/dist/schema/system-tables.d.ts.map +1 -0
  76. package/dist/schema/system-tables.js +46 -0
  77. package/dist/schema/system-tables.js.map +1 -0
  78. package/dist/schema/table-def.d.ts +135 -0
  79. package/dist/schema/table-def.d.ts.map +1 -0
  80. package/dist/schema/table-def.js +70 -0
  81. package/dist/schema/table-def.js.map +1 -0
  82. package/dist/schema-management/common.d.ts +13 -0
  83. package/dist/schema-management/common.d.ts.map +1 -0
  84. package/dist/schema-management/common.js +25 -0
  85. package/dist/schema-management/common.js.map +1 -0
  86. package/dist/schema-management/migrations.d.ts +23 -0
  87. package/dist/schema-management/migrations.d.ts.map +1 -0
  88. package/dist/schema-management/migrations.js +116 -0
  89. package/dist/schema-management/migrations.js.map +1 -0
  90. package/dist/schema-management/validate-mutation-defs.d.ts +8 -0
  91. package/dist/schema-management/validate-mutation-defs.d.ts.map +1 -0
  92. package/dist/schema-management/validate-mutation-defs.js +39 -0
  93. package/dist/schema-management/validate-mutation-defs.js.map +1 -0
  94. package/dist/sql-queries/index.d.ts +4 -0
  95. package/dist/sql-queries/index.d.ts.map +1 -0
  96. package/dist/sql-queries/index.js +4 -0
  97. package/dist/sql-queries/index.js.map +1 -0
  98. package/dist/sql-queries/misc.d.ts +2 -0
  99. package/dist/sql-queries/misc.d.ts.map +1 -0
  100. package/dist/sql-queries/misc.js +2 -0
  101. package/dist/sql-queries/misc.js.map +1 -0
  102. package/dist/sql-queries/sql-queries.d.ts +72 -0
  103. package/dist/sql-queries/sql-queries.d.ts.map +1 -0
  104. package/dist/sql-queries/sql-queries.js +191 -0
  105. package/dist/sql-queries/sql-queries.js.map +1 -0
  106. package/dist/sql-queries/sql-query-builder.d.ts +47 -0
  107. package/dist/sql-queries/sql-query-builder.d.ts.map +1 -0
  108. package/dist/sql-queries/sql-query-builder.js +60 -0
  109. package/dist/sql-queries/sql-query-builder.js.map +1 -0
  110. package/dist/sql-queries/types.d.ts +50 -0
  111. package/dist/sql-queries/types.d.ts.map +1 -0
  112. package/dist/sql-queries/types.js +5 -0
  113. package/dist/sql-queries/types.js.map +1 -0
  114. package/dist/sync/index.d.ts +2 -0
  115. package/dist/sync/index.d.ts.map +1 -0
  116. package/dist/sync/index.js +2 -0
  117. package/dist/sync/index.js.map +1 -0
  118. package/dist/sync/next/compact-events.d.ts +15 -0
  119. package/dist/sync/next/compact-events.d.ts.map +1 -0
  120. package/dist/sync/next/compact-events.js +176 -0
  121. package/dist/sync/next/compact-events.js.map +1 -0
  122. package/dist/sync/next/facts.d.ts +37 -0
  123. package/dist/sync/next/facts.d.ts.map +1 -0
  124. package/dist/sync/next/facts.js +156 -0
  125. package/dist/sync/next/facts.js.map +1 -0
  126. package/dist/sync/next/graphology.d.ts +8 -0
  127. package/dist/sync/next/graphology.d.ts.map +1 -0
  128. package/dist/sync/next/graphology.js +36 -0
  129. package/dist/sync/next/graphology.js.map +1 -0
  130. package/dist/sync/next/graphology_.d.ts +3 -0
  131. package/dist/sync/next/graphology_.d.ts.map +1 -0
  132. package/dist/sync/next/graphology_.js +3 -0
  133. package/dist/sync/next/graphology_.js.map +1 -0
  134. package/dist/sync/next/history-dag.d.ts +30 -0
  135. package/dist/sync/next/history-dag.d.ts.map +1 -0
  136. package/dist/sync/next/history-dag.js +69 -0
  137. package/dist/sync/next/history-dag.js.map +1 -0
  138. package/dist/sync/next/mod.d.ts +5 -0
  139. package/dist/sync/next/mod.d.ts.map +1 -0
  140. package/dist/sync/next/mod.js +5 -0
  141. package/dist/sync/next/mod.js.map +1 -0
  142. package/dist/sync/next/rebase-events.d.ts +27 -0
  143. package/dist/sync/next/rebase-events.d.ts.map +1 -0
  144. package/dist/sync/next/rebase-events.js +41 -0
  145. package/dist/sync/next/rebase-events.js.map +1 -0
  146. package/dist/sync/next/test/compact-events.calculator.test.d.ts +2 -0
  147. package/dist/sync/next/test/compact-events.calculator.test.d.ts.map +1 -0
  148. package/dist/sync/next/test/compact-events.calculator.test.js +101 -0
  149. package/dist/sync/next/test/compact-events.calculator.test.js.map +1 -0
  150. package/dist/sync/next/test/compact-events.test.d.ts +2 -0
  151. package/dist/sync/next/test/compact-events.test.d.ts.map +1 -0
  152. package/dist/sync/next/test/compact-events.test.js +201 -0
  153. package/dist/sync/next/test/compact-events.test.js.map +1 -0
  154. package/dist/sync/next/test/mod.d.ts +2 -0
  155. package/dist/sync/next/test/mod.d.ts.map +1 -0
  156. package/dist/sync/next/test/mod.js +2 -0
  157. package/dist/sync/next/test/mod.js.map +1 -0
  158. package/dist/sync/next/test/mutation-fixtures.d.ts +73 -0
  159. package/dist/sync/next/test/mutation-fixtures.d.ts.map +1 -0
  160. package/dist/sync/next/test/mutation-fixtures.js +161 -0
  161. package/dist/sync/next/test/mutation-fixtures.js.map +1 -0
  162. package/dist/sync/sync.d.ts +45 -0
  163. package/dist/sync/sync.d.ts.map +1 -0
  164. package/dist/sync/sync.js +12 -0
  165. package/dist/sync/sync.js.map +1 -0
  166. package/dist/util.d.ts +25 -0
  167. package/dist/util.d.ts.map +1 -0
  168. package/dist/util.js +38 -0
  169. package/dist/util.js.map +1 -0
  170. package/dist/version.d.ts +10 -0
  171. package/dist/version.d.ts.map +1 -0
  172. package/dist/version.js +12 -0
  173. package/dist/version.js.map +1 -0
  174. package/package.json +61 -0
  175. package/src/__tests__/fixture.ts +23 -0
  176. package/src/adapter-types.ts +216 -0
  177. package/src/ambient.d.ts +3 -0
  178. package/src/bounded-collections.ts +121 -0
  179. package/src/debug-info.ts +76 -0
  180. package/src/derived-mutations.test.ts +101 -0
  181. package/src/derived-mutations.ts +170 -0
  182. package/src/devtools/devtools-bridge.ts +13 -0
  183. package/src/devtools/devtools-messages.ts +247 -0
  184. package/src/devtools/devtools-window-message.ts +27 -0
  185. package/src/devtools/index.ts +49 -0
  186. package/src/index.ts +20 -0
  187. package/src/init-singleton-tables.ts +24 -0
  188. package/src/mutation.ts +69 -0
  189. package/src/query-info.ts +104 -0
  190. package/src/rehydrate-from-mutationlog.ts +131 -0
  191. package/src/schema/index.ts +144 -0
  192. package/src/schema/mutations.ts +313 -0
  193. package/src/schema/schema-helpers.ts +49 -0
  194. package/src/schema/system-tables.ts +84 -0
  195. package/src/schema/table-def.ts +312 -0
  196. package/src/schema-management/common.ts +44 -0
  197. package/src/schema-management/migrations.ts +188 -0
  198. package/src/schema-management/validate-mutation-defs.ts +63 -0
  199. package/src/sql-queries/index.ts +3 -0
  200. package/src/sql-queries/misc.ts +2 -0
  201. package/src/sql-queries/sql-queries.ts +359 -0
  202. package/src/sql-queries/sql-query-builder.ts +135 -0
  203. package/src/sql-queries/types.ts +97 -0
  204. package/src/sync/index.ts +1 -0
  205. package/src/sync/next/ambient.d.ts +3 -0
  206. package/src/sync/next/compact-events.ts +218 -0
  207. package/src/sync/next/facts.ts +229 -0
  208. package/src/sync/next/graphology.ts +49 -0
  209. package/src/sync/next/graphology_.ts +2 -0
  210. package/src/sync/next/history-dag.ts +109 -0
  211. package/src/sync/next/mod.ts +4 -0
  212. package/src/sync/next/rebase-events.ts +97 -0
  213. package/src/sync/next/test/compact-events.calculator.test.ts +121 -0
  214. package/src/sync/next/test/compact-events.test.ts +232 -0
  215. package/src/sync/next/test/mod.ts +1 -0
  216. package/src/sync/next/test/mutation-fixtures.ts +230 -0
  217. package/src/sync/sync.ts +46 -0
  218. package/src/util.ts +56 -0
  219. package/src/version.ts +13 -0
  220. 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,4 @@
1
+ export * from './sql-queries.js';
2
+ export * from './sql-query-builder.js';
3
+ export * from './types.js';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -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,4 @@
1
+ export * from './sql-queries.js';
2
+ export * from './sql-query-builder.js';
3
+ export * from './types.js';
4
+ //# sourceMappingURL=index.js.map
@@ -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,2 @@
1
+ export declare const objectEntries: <T extends Record<string, any>>(obj: T) => [keyof T & string, T[keyof T]][];
2
+ //# sourceMappingURL=misc.d.ts.map
@@ -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,2 @@
1
+ export const objectEntries = (obj) => Object.entries(obj);
2
+ //# sourceMappingURL=misc.js.map
@@ -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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"}