@livestore/common 0.2.0 → 0.3.0-dev.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (244) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/__tests__/fixture.d.ts +163 -1
  3. package/dist/__tests__/fixture.d.ts.map +1 -1
  4. package/dist/__tests__/fixture.js +3 -1
  5. package/dist/__tests__/fixture.js.map +1 -1
  6. package/dist/adapter-types.d.ts +53 -38
  7. package/dist/adapter-types.d.ts.map +1 -1
  8. package/dist/adapter-types.js +5 -7
  9. package/dist/adapter-types.js.map +1 -1
  10. package/dist/bounded-collections.d.ts +2 -2
  11. package/dist/bounded-collections.d.ts.map +1 -1
  12. package/dist/debug-info.d.ts +13 -13
  13. package/dist/derived-mutations.d.ts +1 -1
  14. package/dist/derived-mutations.d.ts.map +1 -1
  15. package/dist/devtools/devtools-bridge.d.ts +2 -2
  16. package/dist/devtools/devtools-bridge.d.ts.map +1 -1
  17. package/dist/devtools/devtools-messages.d.ts +84 -196
  18. package/dist/devtools/devtools-messages.d.ts.map +1 -1
  19. package/dist/devtools/devtools-messages.js +55 -61
  20. package/dist/devtools/devtools-messages.js.map +1 -1
  21. package/dist/devtools/index.d.ts.map +1 -1
  22. package/dist/devtools/index.js +1 -2
  23. package/dist/devtools/index.js.map +1 -1
  24. package/dist/index.d.ts +2 -1
  25. package/dist/index.d.ts.map +1 -1
  26. package/dist/index.js +2 -1
  27. package/dist/index.js.map +1 -1
  28. package/dist/init-singleton-tables.d.ts +1 -1
  29. package/dist/init-singleton-tables.d.ts.map +1 -1
  30. package/dist/leader-thread/apply-mutation.d.ts +8 -0
  31. package/dist/leader-thread/apply-mutation.d.ts.map +1 -0
  32. package/dist/leader-thread/apply-mutation.js +95 -0
  33. package/dist/leader-thread/apply-mutation.js.map +1 -0
  34. package/dist/leader-thread/connection.d.ts +11 -0
  35. package/dist/leader-thread/connection.d.ts.map +1 -0
  36. package/dist/leader-thread/connection.js +44 -0
  37. package/dist/leader-thread/connection.js.map +1 -0
  38. package/dist/leader-thread/leader-sync-processor.d.ts +47 -0
  39. package/dist/leader-thread/leader-sync-processor.d.ts.map +1 -0
  40. package/dist/leader-thread/leader-sync-processor.js +422 -0
  41. package/dist/leader-thread/leader-sync-processor.js.map +1 -0
  42. package/dist/leader-thread/leader-worker-devtools.d.ts +6 -0
  43. package/dist/leader-thread/leader-worker-devtools.d.ts.map +1 -0
  44. package/dist/leader-thread/leader-worker-devtools.js +216 -0
  45. package/dist/leader-thread/leader-worker-devtools.js.map +1 -0
  46. package/dist/leader-thread/make-leader-thread-layer.d.ts +20 -0
  47. package/dist/leader-thread/make-leader-thread-layer.d.ts.map +1 -0
  48. package/dist/leader-thread/make-leader-thread-layer.js +106 -0
  49. package/dist/leader-thread/make-leader-thread-layer.js.map +1 -0
  50. package/dist/leader-thread/mod.d.ts +7 -0
  51. package/dist/leader-thread/mod.d.ts.map +1 -0
  52. package/dist/leader-thread/mod.js +7 -0
  53. package/dist/leader-thread/mod.js.map +1 -0
  54. package/dist/leader-thread/mutationlog.d.ts +23 -0
  55. package/dist/leader-thread/mutationlog.d.ts.map +1 -0
  56. package/dist/leader-thread/mutationlog.js +27 -0
  57. package/dist/leader-thread/mutationlog.js.map +1 -0
  58. package/dist/leader-thread/pull-queue-set.d.ts +7 -0
  59. package/dist/leader-thread/pull-queue-set.d.ts.map +1 -0
  60. package/dist/leader-thread/pull-queue-set.js +39 -0
  61. package/dist/leader-thread/pull-queue-set.js.map +1 -0
  62. package/dist/leader-thread/recreate-db.d.ts +7 -0
  63. package/dist/leader-thread/recreate-db.d.ts.map +1 -0
  64. package/dist/leader-thread/recreate-db.js +69 -0
  65. package/dist/leader-thread/recreate-db.js.map +1 -0
  66. package/dist/leader-thread/shutdown-channel.d.ts +15 -0
  67. package/dist/leader-thread/shutdown-channel.d.ts.map +1 -0
  68. package/dist/leader-thread/shutdown-channel.js +7 -0
  69. package/dist/leader-thread/shutdown-channel.js.map +1 -0
  70. package/dist/leader-thread/types.d.ts +87 -0
  71. package/dist/leader-thread/types.d.ts.map +1 -0
  72. package/dist/leader-thread/types.js +11 -0
  73. package/dist/leader-thread/types.js.map +1 -0
  74. package/dist/mutation.d.ts +3 -4
  75. package/dist/mutation.d.ts.map +1 -1
  76. package/dist/mutation.js +0 -14
  77. package/dist/mutation.js.map +1 -1
  78. package/dist/otel.d.ts +7 -0
  79. package/dist/otel.d.ts.map +1 -0
  80. package/dist/otel.js +11 -0
  81. package/dist/otel.js.map +1 -0
  82. package/dist/query-builder/api.d.ts +2 -2
  83. package/dist/query-builder/api.d.ts.map +1 -1
  84. package/dist/query-builder/api.js.map +1 -1
  85. package/dist/query-builder/impl.d.ts +1 -1
  86. package/dist/query-builder/impl.d.ts.map +1 -1
  87. package/dist/query-builder/impl.js +21 -4
  88. package/dist/query-builder/impl.js.map +1 -1
  89. package/dist/query-builder/impl.test.js +24 -1
  90. package/dist/query-builder/impl.test.js.map +1 -1
  91. package/dist/query-info.d.ts +1 -1
  92. package/dist/query-info.d.ts.map +1 -1
  93. package/dist/rehydrate-from-mutationlog.d.ts +1 -1
  94. package/dist/rehydrate-from-mutationlog.d.ts.map +1 -1
  95. package/dist/rehydrate-from-mutationlog.js +6 -6
  96. package/dist/rehydrate-from-mutationlog.js.map +1 -1
  97. package/dist/schema/EventId.d.ts +37 -0
  98. package/dist/schema/EventId.d.ts.map +1 -0
  99. package/dist/schema/EventId.js +30 -0
  100. package/dist/schema/EventId.js.map +1 -0
  101. package/dist/schema/MutationEvent.d.ts +191 -0
  102. package/dist/schema/MutationEvent.d.ts.map +1 -0
  103. package/dist/schema/MutationEvent.js +56 -0
  104. package/dist/schema/MutationEvent.js.map +1 -0
  105. package/dist/schema/mod.d.ts +8 -0
  106. package/dist/schema/mod.d.ts.map +1 -0
  107. package/dist/schema/mod.js +8 -0
  108. package/dist/schema/mod.js.map +1 -0
  109. package/dist/schema/mutations.d.ts +3 -123
  110. package/dist/schema/mutations.d.ts.map +1 -1
  111. package/dist/schema/mutations.js +0 -26
  112. package/dist/schema/mutations.js.map +1 -1
  113. package/dist/schema/{index.d.ts → schema.d.ts} +1 -5
  114. package/dist/schema/schema.d.ts.map +1 -0
  115. package/dist/schema/{index.js → schema.js} +1 -5
  116. package/dist/schema/schema.js.map +1 -0
  117. package/dist/schema/system-tables.d.ts +55 -29
  118. package/dist/schema/system-tables.d.ts.map +1 -1
  119. package/dist/schema/system-tables.js +10 -5
  120. package/dist/schema/system-tables.js.map +1 -1
  121. package/dist/schema-management/migrations.d.ts +1 -1
  122. package/dist/schema-management/migrations.d.ts.map +1 -1
  123. package/dist/schema-management/migrations.js +6 -1
  124. package/dist/schema-management/migrations.js.map +1 -1
  125. package/dist/schema-management/validate-mutation-defs.d.ts +1 -1
  126. package/dist/schema-management/validate-mutation-defs.d.ts.map +1 -1
  127. package/dist/sync/client-session-sync-processor.d.ts +45 -0
  128. package/dist/sync/client-session-sync-processor.d.ts.map +1 -0
  129. package/dist/sync/client-session-sync-processor.js +131 -0
  130. package/dist/sync/client-session-sync-processor.js.map +1 -0
  131. package/dist/sync/index.d.ts +2 -0
  132. package/dist/sync/index.d.ts.map +1 -1
  133. package/dist/sync/index.js +2 -0
  134. package/dist/sync/index.js.map +1 -1
  135. package/dist/sync/next/compact-events.d.ts +1 -1
  136. package/dist/sync/next/compact-events.d.ts.map +1 -1
  137. package/dist/sync/next/compact-events.js +2 -1
  138. package/dist/sync/next/compact-events.js.map +1 -1
  139. package/dist/sync/next/facts.d.ts +5 -5
  140. package/dist/sync/next/facts.d.ts.map +1 -1
  141. package/dist/sync/next/facts.js +1 -1
  142. package/dist/sync/next/facts.js.map +1 -1
  143. package/dist/sync/next/history-dag-common.d.ts +30 -0
  144. package/dist/sync/next/history-dag-common.d.ts.map +1 -0
  145. package/dist/sync/next/history-dag-common.js +20 -0
  146. package/dist/sync/next/history-dag-common.js.map +1 -0
  147. package/dist/sync/next/history-dag.d.ts +4 -27
  148. package/dist/sync/next/history-dag.d.ts.map +1 -1
  149. package/dist/sync/next/history-dag.js +1 -19
  150. package/dist/sync/next/history-dag.js.map +1 -1
  151. package/dist/sync/next/mod.d.ts +1 -0
  152. package/dist/sync/next/mod.d.ts.map +1 -1
  153. package/dist/sync/next/mod.js +1 -0
  154. package/dist/sync/next/mod.js.map +1 -1
  155. package/dist/sync/next/rebase-events.d.ts +3 -2
  156. package/dist/sync/next/rebase-events.d.ts.map +1 -1
  157. package/dist/sync/next/rebase-events.js.map +1 -1
  158. package/dist/sync/next/test/compact-events.test.d.ts.map +1 -1
  159. package/dist/sync/next/test/compact-events.test.js +2 -1
  160. package/dist/sync/next/test/compact-events.test.js.map +1 -1
  161. package/dist/sync/next/test/mutation-fixtures.d.ts +1 -1
  162. package/dist/sync/next/test/mutation-fixtures.d.ts.map +1 -1
  163. package/dist/sync/next/test/mutation-fixtures.js +4 -3
  164. package/dist/sync/next/test/mutation-fixtures.js.map +1 -1
  165. package/dist/sync/sync.d.ts +33 -12
  166. package/dist/sync/sync.d.ts.map +1 -1
  167. package/dist/sync/sync.js +10 -1
  168. package/dist/sync/sync.js.map +1 -1
  169. package/dist/sync/syncstate.d.ts +123 -0
  170. package/dist/sync/syncstate.d.ts.map +1 -0
  171. package/dist/sync/syncstate.js +248 -0
  172. package/dist/sync/syncstate.js.map +1 -0
  173. package/dist/sync/syncstate.test.d.ts +2 -0
  174. package/dist/sync/syncstate.test.d.ts.map +1 -0
  175. package/dist/sync/syncstate.test.js +399 -0
  176. package/dist/sync/syncstate.test.js.map +1 -0
  177. package/dist/sync/validate-push-payload.d.ts +5 -0
  178. package/dist/sync/validate-push-payload.d.ts.map +1 -0
  179. package/dist/sync/validate-push-payload.js +15 -0
  180. package/dist/sync/validate-push-payload.js.map +1 -0
  181. package/dist/util.d.ts +2 -2
  182. package/dist/util.d.ts.map +1 -1
  183. package/dist/version.d.ts +2 -2
  184. package/dist/version.d.ts.map +1 -1
  185. package/dist/version.js +2 -2
  186. package/dist/version.js.map +1 -1
  187. package/package.json +13 -6
  188. package/src/__tests__/fixture.ts +5 -1
  189. package/src/adapter-types.ts +60 -34
  190. package/src/derived-mutations.test.ts +1 -1
  191. package/src/derived-mutations.ts +1 -1
  192. package/src/devtools/devtools-bridge.ts +2 -2
  193. package/src/devtools/devtools-messages.ts +70 -74
  194. package/src/devtools/index.ts +1 -2
  195. package/src/index.ts +2 -1
  196. package/src/init-singleton-tables.ts +1 -1
  197. package/src/leader-thread/apply-mutation.ts +143 -0
  198. package/src/leader-thread/connection.ts +67 -0
  199. package/src/leader-thread/leader-sync-processor.ts +666 -0
  200. package/src/leader-thread/leader-worker-devtools.ts +358 -0
  201. package/src/leader-thread/make-leader-thread-layer.ts +192 -0
  202. package/src/leader-thread/mod.ts +6 -0
  203. package/src/leader-thread/mutationlog.ts +42 -0
  204. package/src/leader-thread/pull-queue-set.ts +58 -0
  205. package/src/leader-thread/recreate-db.ts +109 -0
  206. package/src/leader-thread/shutdown-channel.ts +13 -0
  207. package/src/leader-thread/types.ts +129 -0
  208. package/src/mutation.ts +3 -21
  209. package/src/otel.ts +20 -0
  210. package/src/query-builder/api.ts +3 -2
  211. package/src/query-builder/impl.test.ts +28 -1
  212. package/src/query-builder/impl.ts +21 -5
  213. package/src/query-info.ts +1 -1
  214. package/src/rehydrate-from-mutationlog.ts +7 -11
  215. package/src/schema/EventId.ts +46 -0
  216. package/src/schema/MutationEvent.ts +161 -0
  217. package/src/schema/mod.ts +7 -0
  218. package/src/schema/mutations.ts +5 -126
  219. package/src/schema/{index.ts → schema.ts} +0 -5
  220. package/src/schema/system-tables.ts +18 -5
  221. package/src/schema-management/migrations.ts +9 -2
  222. package/src/schema-management/validate-mutation-defs.ts +1 -1
  223. package/src/sync/client-session-sync-processor.ts +207 -0
  224. package/src/sync/index.ts +2 -0
  225. package/src/sync/next/compact-events.ts +3 -2
  226. package/src/sync/next/facts.ts +11 -5
  227. package/src/sync/next/history-dag-common.ts +44 -0
  228. package/src/sync/next/history-dag.ts +3 -45
  229. package/src/sync/next/mod.ts +1 -0
  230. package/src/sync/next/rebase-events.ts +6 -5
  231. package/src/sync/next/test/compact-events.test.ts +3 -2
  232. package/src/sync/next/test/mutation-fixtures.ts +7 -6
  233. package/src/sync/sync.ts +32 -12
  234. package/src/sync/syncstate.test.ts +464 -0
  235. package/src/sync/syncstate.ts +385 -0
  236. package/src/sync/validate-push-payload.ts +18 -0
  237. package/src/version.ts +2 -2
  238. package/dist/schema/index.d.ts.map +0 -1
  239. package/dist/schema/index.js.map +0 -1
  240. package/dist/sync/next-mutation-event-id-pair.d.ts +0 -14
  241. package/dist/sync/next-mutation-event-id-pair.d.ts.map +0 -1
  242. package/dist/sync/next-mutation-event-id-pair.js +0 -13
  243. package/dist/sync/next-mutation-event-id-pair.js.map +0 -1
  244. package/src/sync/next-mutation-event-id-pair.ts +0 -20
@@ -0,0 +1,143 @@
1
+ import { memoizeByRef, shouldNeverHappen } from '@livestore/utils'
2
+ import type { Scope } from '@livestore/utils/effect'
3
+ import { Effect, Option, Schema } from '@livestore/utils/effect'
4
+
5
+ import type { SqliteError, SynchronousDatabase, UnexpectedError } from '../index.js'
6
+ import {
7
+ getExecArgsFromMutation,
8
+ MUTATION_LOG_META_TABLE,
9
+ mutationLogMetaTable,
10
+ SESSION_CHANGESET_META_TABLE,
11
+ sessionChangesetMetaTable,
12
+ } from '../index.js'
13
+ import type { LiveStoreSchema, MutationEvent } from '../schema/mod.js'
14
+ import { insertRow } from '../sql-queries/index.js'
15
+ import { execSql, execSqlPrepared } from './connection.js'
16
+ import { LeaderThreadCtx } from './types.js'
17
+
18
+ export type ApplyMutation = (
19
+ mutationEventEncoded: MutationEvent.AnyEncoded,
20
+ ) => Effect.Effect<void, SqliteError | UnexpectedError>
21
+
22
+ export const makeApplyMutation: Effect.Effect<ApplyMutation, never, Scope.Scope | LeaderThreadCtx> = Effect.gen(
23
+ function* () {
24
+ const leaderThreadCtx = yield* LeaderThreadCtx
25
+ const shouldExcludeMutationFromLog = makeShouldExcludeMutationFromLog(leaderThreadCtx.schema)
26
+
27
+ const mutationDefSchemaHashMap = new Map(
28
+ // TODO Running `Schema.hash` can be a bottleneck for larger schemas. There is an opportunity to run this
29
+ // at build time and lookup the pre-computed hash at runtime.
30
+ // Also see https://github.com/Effect-TS/effect/issues/2719
31
+ [...leaderThreadCtx.schema.mutations.entries()].map(([k, v]) => [k, Schema.hash(v.schema)] as const),
32
+ )
33
+
34
+ return (mutationEventEncoded) =>
35
+ Effect.gen(function* () {
36
+ const { mutationEventSchema, schema, db, dbLog } = leaderThreadCtx
37
+ const mutationEventDecoded = Schema.decodeUnknownSync(mutationEventSchema)(mutationEventEncoded)
38
+
39
+ const mutationName = mutationEventDecoded.mutation
40
+ const mutationDef = schema.mutations.get(mutationName) ?? shouldNeverHappen(`Unknown mutation: ${mutationName}`)
41
+
42
+ const execArgsArr = getExecArgsFromMutation({ mutationDef, mutationEventDecoded })
43
+
44
+ // console.group('[@livestore/common:leader-thread:applyMutation]', { mutationName })
45
+
46
+ const session = db.session()
47
+
48
+ for (const { statementSql, bindValues } of execArgsArr) {
49
+ // console.debug(mutationName, statementSql, bindValues)
50
+ // TODO use cached prepared statements instead of exec
51
+ yield* execSqlPrepared(db, statementSql, bindValues)
52
+ }
53
+
54
+ const changeset = session.changeset()
55
+ session.finish()
56
+ // NOTE for no-op mutations (e.g. if the state didn't change) the changeset will be empty
57
+ // TODO possibly write a null value instead of omitting the row
58
+ if (changeset !== undefined && changeset.length > 0) {
59
+ // TODO use prepared statements
60
+ yield* execSql(
61
+ db,
62
+ ...insertRow({
63
+ tableName: SESSION_CHANGESET_META_TABLE,
64
+ columns: sessionChangesetMetaTable.sqliteDef.columns,
65
+ values: {
66
+ idGlobal: mutationEventEncoded.id.global,
67
+ idLocal: mutationEventEncoded.id.local,
68
+ changeset,
69
+ debug: execArgsArr,
70
+ },
71
+ }),
72
+ )
73
+ }
74
+
75
+ // console.groupEnd()
76
+
77
+ // write to mutation_log
78
+ const excludeFromMutationLog = shouldExcludeMutationFromLog(mutationName, mutationEventDecoded)
79
+ if (excludeFromMutationLog === false) {
80
+ yield* insertIntoMutationLog(mutationEventEncoded, dbLog, mutationDefSchemaHashMap)
81
+ } else {
82
+ // console.debug('[@livestore/common:leader-thread] skipping mutation log write', mutation, statementSql, bindValues)
83
+ }
84
+ }).pipe(
85
+ Effect.withSpan(`@livestore/common:leader-thread:applyMutation`, {
86
+ attributes: {
87
+ mutationName: mutationEventEncoded.mutation,
88
+ mutationId: mutationEventEncoded.id,
89
+ 'span.label': mutationEventEncoded.mutation,
90
+ },
91
+ }),
92
+ // Effect.logDuration('@livestore/common:leader-thread:applyMutation'),
93
+ )
94
+ },
95
+ )
96
+
97
+ const insertIntoMutationLog = (
98
+ mutationEventEncoded: MutationEvent.AnyEncoded,
99
+ dbLog: SynchronousDatabase,
100
+ mutationDefSchemaHashMap: Map<string, number>,
101
+ ) =>
102
+ Effect.gen(function* () {
103
+ const mutationName = mutationEventEncoded.mutation
104
+ const mutationDefSchemaHash =
105
+ mutationDefSchemaHashMap.get(mutationName) ?? shouldNeverHappen(`Unknown mutation: ${mutationName}`)
106
+
107
+ // TODO use prepared statements
108
+ yield* execSql(
109
+ dbLog,
110
+ ...insertRow({
111
+ tableName: MUTATION_LOG_META_TABLE,
112
+ columns: mutationLogMetaTable.sqliteDef.columns,
113
+ values: {
114
+ idGlobal: mutationEventEncoded.id.global,
115
+ idLocal: mutationEventEncoded.id.local,
116
+ parentIdGlobal: mutationEventEncoded.parentId.global,
117
+ parentIdLocal: mutationEventEncoded.parentId.local,
118
+ mutation: mutationEventEncoded.mutation,
119
+ argsJson: mutationEventEncoded.args ?? {},
120
+ schemaHash: mutationDefSchemaHash,
121
+ syncMetadataJson: Option.none(),
122
+ },
123
+ }),
124
+ )
125
+ })
126
+
127
+ // TODO let's consider removing this "should exclude" mechanism in favour of log compaction etc
128
+ const makeShouldExcludeMutationFromLog = memoizeByRef((schema: LiveStoreSchema) => {
129
+ const migrationOptions = schema.migrationOptions
130
+ const mutationLogExclude =
131
+ migrationOptions.strategy === 'from-mutation-log'
132
+ ? (migrationOptions.excludeMutations ?? new Set(['livestore.RawSql']))
133
+ : new Set(['livestore.RawSql'])
134
+
135
+ return (mutationName: string, mutationEventDecoded: MutationEvent.Any): boolean => {
136
+ if (mutationLogExclude.has(mutationName)) return true
137
+
138
+ const mutationDef = schema.mutations.get(mutationName) ?? shouldNeverHappen(`Unknown mutation: ${mutationName}`)
139
+ const execArgsArr = getExecArgsFromMutation({ mutationDef, mutationEventDecoded })
140
+
141
+ return execArgsArr.some((_) => _.statementSql.includes('__livestore'))
142
+ }
143
+ })
@@ -0,0 +1,67 @@
1
+ // import type { WaSqlite } from '@livestore/sqlite-wasm'
2
+ import { Effect } from '@livestore/utils/effect'
3
+
4
+ import type { SynchronousDatabase } from '../adapter-types.js'
5
+ import { SqliteError } from '../adapter-types.js'
6
+ import type { BindValues } from '../sql-queries/index.js'
7
+ import type { PreparedBindValues } from '../util.js'
8
+ import { prepareBindValues, sql } from '../util.js'
9
+
10
+ // TODO
11
+ namespace WaSqlite {
12
+ export type SQLiteError = any
13
+ }
14
+
15
+ export const configureConnection = (syncDb: SynchronousDatabase, { fkEnabled }: { fkEnabled: boolean }) =>
16
+ execSql(
17
+ syncDb,
18
+ sql`
19
+ PRAGMA page_size=8192;
20
+ PRAGMA journal_mode=MEMORY;
21
+ ${fkEnabled ? sql`PRAGMA foreign_keys='ON';` : sql`PRAGMA foreign_keys='OFF';`}
22
+ `,
23
+ {},
24
+ )
25
+
26
+ export const execSql = (syncDb: SynchronousDatabase, sql: string, bind: BindValues) => {
27
+ const bindValues = prepareBindValues(bind, sql)
28
+ return Effect.try({
29
+ try: () => syncDb.execute(sql, bindValues),
30
+ catch: (cause) =>
31
+ new SqliteError({ cause, query: { bindValues, sql }, code: (cause as WaSqlite.SQLiteError).code }),
32
+ }).pipe(
33
+ Effect.asVoid,
34
+ // Effect.logDuration(`@livestore/common:execSql:${sql}`),
35
+ Effect.withSpan(`@livestore/common:execSql`, {
36
+ attributes: { 'span.label': sql, sql, bindValueKeys: Object.keys(bindValues) },
37
+ }),
38
+ )
39
+ }
40
+
41
+ // const selectSqlPrepared = <T>(stmt: PreparedStatement, bind: BindValues) => {
42
+ // const bindValues = prepareBindValues(bind, stmt.sql)
43
+ // return Effect.try({
44
+ // try: () => stmt.select<T>(bindValues),
45
+ // catch: (cause) =>
46
+ // new SqliteError({ cause, query: { bindValues, sql: stmt.sql }, code: (cause as WaSqlite.SQLiteError).code }),
47
+ // })
48
+ // }
49
+
50
+ // TODO actually use prepared statements
51
+ export const execSqlPrepared = (syncDb: SynchronousDatabase, sql: string, bindValues: PreparedBindValues) => {
52
+ return Effect.try({
53
+ try: () => syncDb.execute(sql, bindValues),
54
+ catch: (cause) =>
55
+ new SqliteError({ cause, query: { bindValues, sql }, code: (cause as WaSqlite.SQLiteError).code }),
56
+ }).pipe(
57
+ Effect.asVoid,
58
+ // Effect.logDuration(`@livestore/common:execSqlPrepared:${sql}`),
59
+ Effect.withSpan(`@livestore/common:execSqlPrepared`, {
60
+ attributes: {
61
+ 'span.label': sql,
62
+ sql,
63
+ bindValueKeys: Object.keys(bindValues),
64
+ },
65
+ }),
66
+ )
67
+ }