@livestore/livestore 0.2.0 → 0.3.0-dev.11
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 -1
- package/dist/SqliteDbWrapper.d.ts +54 -0
- package/dist/SqliteDbWrapper.d.ts.map +1 -0
- package/dist/SqliteDbWrapper.js +212 -0
- package/dist/SqliteDbWrapper.js.map +1 -0
- package/dist/SynchronousDatabaseWrapper.d.ts +20 -6
- package/dist/SynchronousDatabaseWrapper.d.ts.map +1 -1
- package/dist/SynchronousDatabaseWrapper.js +38 -6
- package/dist/SynchronousDatabaseWrapper.js.map +1 -1
- package/dist/__tests__/fixture.d.ts +252 -0
- package/dist/__tests__/fixture.d.ts.map +1 -0
- package/dist/__tests__/fixture.js +18 -0
- package/dist/__tests__/fixture.js.map +1 -0
- package/dist/effect/LiveStore.d.ts +16 -12
- package/dist/effect/LiveStore.d.ts.map +1 -1
- package/dist/effect/LiveStore.js +14 -14
- package/dist/effect/LiveStore.js.map +1 -1
- package/dist/index.d.ts +6 -7
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +4 -4
- package/dist/index.js.map +1 -1
- package/dist/live-queries/base-class.d.ts +64 -21
- package/dist/live-queries/base-class.d.ts.map +1 -1
- package/dist/live-queries/base-class.js +56 -13
- package/dist/live-queries/base-class.js.map +1 -1
- package/dist/live-queries/computed.d.ts +7 -7
- package/dist/live-queries/computed.d.ts.map +1 -1
- package/dist/live-queries/computed.js +35 -11
- package/dist/live-queries/computed.js.map +1 -1
- package/dist/live-queries/{sql.d.ts → db-query.d.ts} +19 -14
- package/dist/live-queries/db-query.d.ts.map +1 -0
- package/dist/live-queries/db-query.js +244 -0
- package/dist/live-queries/db-query.js.map +1 -0
- package/dist/live-queries/db-query.test.d.ts +2 -0
- package/dist/live-queries/db-query.test.d.ts.map +1 -0
- package/dist/live-queries/db-query.test.js +123 -0
- package/dist/live-queries/db-query.test.js.map +1 -0
- package/dist/live-queries/db.d.ts +12 -15
- package/dist/live-queries/db.d.ts.map +1 -1
- package/dist/live-queries/db.js +72 -48
- package/dist/live-queries/db.js.map +1 -1
- package/dist/live-queries/db.test.js +18 -15
- package/dist/live-queries/db.test.js.map +1 -1
- package/dist/live-queries/graphql.d.ts +8 -8
- package/dist/live-queries/graphql.d.ts.map +1 -1
- package/dist/live-queries/graphql.js +35 -9
- package/dist/live-queries/graphql.js.map +1 -1
- package/dist/live-queries/make-ref.d.ts +20 -0
- package/dist/live-queries/make-ref.d.ts.map +1 -0
- package/dist/live-queries/make-ref.js +33 -0
- package/dist/live-queries/make-ref.js.map +1 -0
- package/dist/reactive.d.ts +15 -13
- package/dist/reactive.d.ts.map +1 -1
- package/dist/reactive.js +15 -9
- package/dist/reactive.js.map +1 -1
- package/dist/row-query-utils.d.ts +4 -4
- package/dist/row-query-utils.d.ts.map +1 -1
- package/dist/row-query-utils.js +14 -10
- package/dist/row-query-utils.js.map +1 -1
- package/dist/store/create-store.d.ts +13 -12
- package/dist/store/create-store.d.ts.map +1 -1
- package/dist/store/create-store.js +27 -33
- package/dist/store/create-store.js.map +1 -1
- package/dist/store/devtools.d.ts +3 -3
- package/dist/store/devtools.d.ts.map +1 -1
- package/dist/store/devtools.js +56 -34
- package/dist/store/devtools.js.map +1 -1
- package/dist/store/store-types.d.ts +18 -18
- package/dist/store/store-types.d.ts.map +1 -1
- package/dist/store/store-types.js.map +1 -1
- package/dist/store/store.d.ts +57 -38
- package/dist/store/store.d.ts.map +1 -1
- package/dist/store/store.js +225 -188
- package/dist/store/store.js.map +1 -1
- package/dist/store/store.test.d.ts +2 -0
- package/dist/store/store.test.d.ts.map +1 -0
- package/dist/store/store.test.js +27 -0
- package/dist/store/store.test.js.map +1 -0
- package/dist/utils/dev.d.ts.map +1 -1
- package/dist/utils/dev.js +3 -2
- package/dist/utils/dev.js.map +1 -1
- package/dist/utils/expo.d.ts +2 -0
- package/dist/utils/expo.d.ts.map +1 -0
- package/dist/utils/expo.js +8 -0
- package/dist/utils/expo.js.map +1 -0
- package/dist/utils/function-string.d.ts +7 -0
- package/dist/utils/function-string.d.ts.map +1 -0
- package/dist/utils/function-string.js +9 -0
- package/dist/utils/function-string.js.map +1 -0
- package/dist/utils/stack-info.d.ts.map +1 -1
- package/dist/utils/stack-info.js +6 -1
- package/dist/utils/stack-info.js.map +1 -1
- package/dist/utils/stack-info.test.js +54 -1
- package/dist/utils/stack-info.test.js.map +1 -1
- package/dist/utils/tests/fixture.d.ts +2 -6
- package/dist/utils/tests/fixture.d.ts.map +1 -1
- package/dist/utils/tests/fixture.js +7 -13
- package/dist/utils/tests/fixture.js.map +1 -1
- package/dist/utils/tests/mod.d.ts +1 -0
- package/dist/utils/tests/mod.d.ts.map +1 -1
- package/dist/utils/tests/mod.js +1 -0
- package/dist/utils/tests/mod.js.map +1 -1
- package/dist/utils/tests/otel.d.ts +60 -1
- package/dist/utils/tests/otel.d.ts.map +1 -1
- package/dist/utils/tests/otel.js +65 -4
- package/dist/utils/tests/otel.js.map +1 -1
- package/package.json +12 -12
- package/src/{SynchronousDatabaseWrapper.ts → SqliteDbWrapper.ts} +59 -13
- package/src/ambient.d.ts +1 -1
- package/src/effect/LiveStore.ts +32 -33
- package/src/index.ts +14 -7
- package/src/live-queries/__snapshots__/{db.test.ts.snap → db-query.test.ts.snap} +220 -69
- package/src/live-queries/base-class.ts +160 -40
- package/src/live-queries/computed.ts +45 -19
- package/src/live-queries/{db.test.ts → db-query.test.ts} +23 -12
- package/src/live-queries/{db.ts → db-query.ts} +124 -61
- package/src/live-queries/graphql.ts +47 -21
- package/src/live-queries/make-ref.ts +47 -0
- package/src/reactive.ts +52 -27
- package/src/row-query-utils.ts +29 -18
- package/src/store/create-store.ts +106 -113
- package/src/store/devtools.ts +65 -39
- package/src/store/store-types.ts +20 -18
- package/src/store/store.ts +361 -290
- package/src/utils/dev.ts +4 -2
- package/src/utils/function-string.ts +12 -0
- package/src/utils/stack-info.test.ts +58 -1
- package/src/utils/stack-info.ts +6 -1
- package/src/utils/tests/fixture.ts +6 -16
- package/src/utils/tests/mod.ts +1 -0
- package/src/utils/tests/otel.ts +71 -5
- package/dist/live-queries/sql.d.ts.map +0 -1
- package/dist/live-queries/sql.js +0 -175
- package/dist/live-queries/sql.js.map +0 -1
- package/dist/live-queries/sql.test.d.ts +0 -2
- package/dist/live-queries/sql.test.d.ts.map +0 -1
- package/dist/live-queries/sql.test.js +0 -285
- package/dist/live-queries/sql.test.js.map +0 -1
- package/dist/reactiveQueries/base-class.d.ts +0 -64
- package/dist/reactiveQueries/base-class.d.ts.map +0 -1
- package/dist/reactiveQueries/base-class.js +0 -31
- package/dist/reactiveQueries/base-class.js.map +0 -1
- package/dist/reactiveQueries/computed.d.ts +0 -26
- package/dist/reactiveQueries/computed.d.ts.map +0 -1
- package/dist/reactiveQueries/computed.js +0 -38
- package/dist/reactiveQueries/computed.js.map +0 -1
- package/dist/reactiveQueries/graphql.d.ts +0 -49
- package/dist/reactiveQueries/graphql.d.ts.map +0 -1
- package/dist/reactiveQueries/graphql.js +0 -122
- package/dist/reactiveQueries/graphql.js.map +0 -1
- package/dist/reactiveQueries/sql.d.ts +0 -62
- package/dist/reactiveQueries/sql.d.ts.map +0 -1
- package/dist/reactiveQueries/sql.js +0 -175
- package/dist/reactiveQueries/sql.js.map +0 -1
- package/dist/reactiveQueries/sql.test.d.ts +0 -2
- package/dist/reactiveQueries/sql.test.d.ts.map +0 -1
- package/dist/reactiveQueries/sql.test.js +0 -285
- package/dist/reactiveQueries/sql.test.js.map +0 -1
- package/dist/row-query.d.ts +0 -16
- package/dist/row-query.d.ts.map +0 -1
- package/dist/row-query.js +0 -30
- package/dist/row-query.js.map +0 -1
- package/src/global-state.ts +0 -20
package/src/utils/dev.ts
CHANGED
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { isDevEnv } from '@livestore/utils'
|
|
2
|
+
|
|
1
3
|
/* eslint-disable unicorn/prefer-global-this */
|
|
2
4
|
export const downloadBlob = (
|
|
3
5
|
data: Uint8Array | Blob | string,
|
|
@@ -24,7 +26,7 @@ export const downloadURL = (data: string, fileName: string) => {
|
|
|
24
26
|
}
|
|
25
27
|
|
|
26
28
|
export const exposeDebugUtils = () => {
|
|
27
|
-
if (
|
|
28
|
-
globalThis.
|
|
29
|
+
if (isDevEnv()) {
|
|
30
|
+
globalThis.__debugLiveStoreUtils = { downloadBlob }
|
|
29
31
|
}
|
|
30
32
|
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
// Related https://github.com/facebook/hermes/issues/612#issuecomment-2549404649
|
|
2
|
+
const REACT_NATIVE_BAD_FUNCTION_STRING = 'function() { [bytecode] }'
|
|
3
|
+
|
|
4
|
+
export const isValidFunctionString = (
|
|
5
|
+
fnStr: string,
|
|
6
|
+
): { _tag: 'valid' } | { _tag: 'invalid'; reason: 'react-native' } => {
|
|
7
|
+
if (fnStr === REACT_NATIVE_BAD_FUNCTION_STRING) {
|
|
8
|
+
return { _tag: 'invalid', reason: 'react-native' }
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
return { _tag: 'valid' }
|
|
12
|
+
}
|
|
@@ -46,7 +46,7 @@ Error
|
|
|
46
46
|
|
|
47
47
|
it('Tracklist_ stacktrace', async () => {
|
|
48
48
|
const stackTrace = `\
|
|
49
|
-
|
|
49
|
+
Error
|
|
50
50
|
at https://localhost:8081/@fs/Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/livestore/dist/react/useQuery.js?t=1701368568351:19:23
|
|
51
51
|
at mountMemo (https://localhost:8081/node_modules/.vite-web/deps/chunk-YKTDXTVC.js?v=86daed82:12817:27)
|
|
52
52
|
at Object.useMemo (https://localhost:8081/node_modules/.vite-web/deps/chunk-YKTDXTVC.js?v=86daed82:13141:24)
|
|
@@ -77,3 +77,60 @@ stack Error
|
|
|
77
77
|
}
|
|
78
78
|
`)
|
|
79
79
|
})
|
|
80
|
+
|
|
81
|
+
it('React 19', async () => {
|
|
82
|
+
const stackTrace = `\
|
|
83
|
+
Error:
|
|
84
|
+
at /Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/react/src/useQuery.ts:57:19
|
|
85
|
+
at mountMemo (/Users/schickling/Code/overtone/node_modules/.pnpm/react-dom@19.0.0_react@19.0.0/node_modules/react-dom/cjs/react-dom-client.development.js:6816:23)
|
|
86
|
+
at Object.useMemo (/Users/schickling/Code/overtone/node_modules/.pnpm/react-dom@19.0.0_react@19.0.0/node_modules/react-dom/cjs/react-dom-client.development.js:22757:18)
|
|
87
|
+
at Object.process.env.NODE_ENV.exports.useMemo (/Users/schickling/Code/overtone/node_modules/.pnpm/react@19.0.0/node_modules/react/cjs/react.development.js:1488:34)
|
|
88
|
+
at Module.useQueryRef (/Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/react/src/useQuery.ts:54:27)
|
|
89
|
+
at Module.useRow (/Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/react/src/useRow.ts:111:20)
|
|
90
|
+
at TestComponent (/Users/schickling/Code/overtone/node_modules/.pnpm/@testing-library+react@16.1.0_@testing-library+dom@10.4.0_@types+react-dom@19.0.3_@types+reac_2jaiibiag2sxou3wtzbuqx3r5a/node_modules/@testing-library/react/dist/pure.js:309:27)
|
|
91
|
+
at Object.react-stack-bottom-frame (/Users/schickling/Code/overtone/node_modules/.pnpm/react-dom@19.0.0_react@19.0.0/node_modules/react-dom/cjs/react-dom-client.development.js:22428:20)
|
|
92
|
+
at renderWithHooks (/Users/schickling/Code/overtone/node_modules/.pnpm/react-dom@19.0.0_react@19.0.0/node_modules/react-dom/cjs/react-dom-client.development.js:5757:22)
|
|
93
|
+
`
|
|
94
|
+
|
|
95
|
+
const stackInfo = extractStackInfoFromStackTrace(stackTrace)
|
|
96
|
+
expect(stackInfo).toMatchInlineSnapshot(`
|
|
97
|
+
{
|
|
98
|
+
"frames": [
|
|
99
|
+
{
|
|
100
|
+
"filePath": "/Users/schickling/Code/overtone/node_modules/.pnpm/@testing-library+react@16.1.0_@testing-library+dom@10.4.0_@types+react-dom@19.0.3_@types+reac_2jaiibiag2sxou3wtzbuqx3r5a/node_modules/@testing-library/react/dist/pure.js:309:27",
|
|
101
|
+
"name": "TestComponent",
|
|
102
|
+
},
|
|
103
|
+
{
|
|
104
|
+
"filePath": "/Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/react/src/useRow.ts:111:20",
|
|
105
|
+
"name": "useRow",
|
|
106
|
+
},
|
|
107
|
+
],
|
|
108
|
+
}
|
|
109
|
+
`)
|
|
110
|
+
})
|
|
111
|
+
|
|
112
|
+
it('React 19 - skip react-stack-bottom-frame', async () => {
|
|
113
|
+
const stackTrace = `\
|
|
114
|
+
Error:
|
|
115
|
+
at /Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/react/src/useQuery.ts:57:19
|
|
116
|
+
at mountMemo (/Users/schickling/Code/overtone/node_modules/.pnpm/react-dom@19.0.0_react@19.0.0/node_modules/react-dom/cjs/react-dom-client.development.js:6816:23)
|
|
117
|
+
at Object.useMemo (/Users/schickling/Code/overtone/node_modules/.pnpm/react-dom@19.0.0_react@19.0.0/node_modules/react-dom/cjs/react-dom-client.development.js:22757:18)
|
|
118
|
+
at Object.process.env.NODE_ENV.exports.useMemo (/Users/schickling/Code/overtone/node_modules/.pnpm/react@19.0.0/node_modules/react/cjs/react.development.js:1488:34)
|
|
119
|
+
at Module.useQueryRef (/Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/react/src/useQuery.ts:54:27)
|
|
120
|
+
at Module.useRow (/Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/react/src/useRow.ts:111:20)
|
|
121
|
+
at Object.react-stack-bottom-frame (/Users/schickling/Code/overtone/node_modules/.pnpm/react-dom@19.0.0_react@19.0.0/node_modules/react-dom/cjs/react-dom-client.development.js:22428:20)
|
|
122
|
+
at renderWithHooks (/Users/schickling/Code/overtone/node_modules/.pnpm/react-dom@19.0.0_react@19.0.0/node_modules/react-dom/cjs/react-dom-client.development.js:5757:22)
|
|
123
|
+
`
|
|
124
|
+
|
|
125
|
+
const stackInfo = extractStackInfoFromStackTrace(stackTrace)
|
|
126
|
+
expect(stackInfo).toMatchInlineSnapshot(`
|
|
127
|
+
{
|
|
128
|
+
"frames": [
|
|
129
|
+
{
|
|
130
|
+
"filePath": "/Users/schickling/Code/overtone/submodules/livestore/packages/@livestore/react/src/useRow.ts:111:20",
|
|
131
|
+
"name": "useRow",
|
|
132
|
+
},
|
|
133
|
+
],
|
|
134
|
+
}
|
|
135
|
+
`)
|
|
136
|
+
})
|
package/src/utils/stack-info.ts
CHANGED
|
@@ -34,15 +34,20 @@ export const extractStackInfoFromStackTrace = (stackTrace: string): StackInfo =>
|
|
|
34
34
|
|
|
35
35
|
while ((match = namePattern.exec(stackTrace)) !== null) {
|
|
36
36
|
const [, name, filePath] = match as any as [string, string, string]
|
|
37
|
+
// console.debug(name, filePath)
|
|
37
38
|
|
|
38
39
|
// NOTE No idea where this `Module.` comes from - possibly a Vite thing?
|
|
39
40
|
if ((name.startsWith('use') || name.startsWith('Module.use')) && name.endsWith('QueryRef') === false) {
|
|
40
41
|
hasReachedStart = true
|
|
42
|
+
// console.debug('hasReachedStart. adding one more frame.')
|
|
41
43
|
|
|
42
44
|
frames.unshift({ name: name.replace(/^Module\./, ''), filePath })
|
|
43
45
|
} else if (hasReachedStart) {
|
|
44
46
|
// We've reached the end of the `use*` functions, so we're adding the component name and stop
|
|
45
|
-
|
|
47
|
+
// Unless it's `react-stack-bottom-frame`, which we skip
|
|
48
|
+
if (name !== 'Object.react-stack-bottom-frame') {
|
|
49
|
+
frames.unshift({ name, filePath })
|
|
50
|
+
}
|
|
46
51
|
break
|
|
47
52
|
}
|
|
48
53
|
}
|
|
@@ -1,7 +1,8 @@
|
|
|
1
|
+
import { provideOtel } from '@livestore/common'
|
|
1
2
|
import type { FromInputSchema } from '@livestore/common/schema'
|
|
2
3
|
import type { Store } from '@livestore/livestore'
|
|
3
|
-
import { createStore, DbSchema,
|
|
4
|
-
import { Effect
|
|
4
|
+
import { createStore, DbSchema, makeSchema } from '@livestore/livestore'
|
|
5
|
+
import { Effect } from '@livestore/utils/effect'
|
|
5
6
|
import { makeInMemoryAdapter } from '@livestore/web'
|
|
6
7
|
import type * as otel from '@opentelemetry/api'
|
|
7
8
|
|
|
@@ -46,28 +47,17 @@ export interface FixtureSchema extends FromInputSchema.DeriveSchema<{ tables: ty
|
|
|
46
47
|
export const makeTodoMvc = ({
|
|
47
48
|
otelTracer,
|
|
48
49
|
otelContext,
|
|
49
|
-
useGlobalReactivityGraph = true,
|
|
50
50
|
}: {
|
|
51
51
|
otelTracer?: otel.Tracer
|
|
52
52
|
otelContext?: otel.Context
|
|
53
|
-
useGlobalReactivityGraph?: boolean
|
|
54
53
|
} = {}) =>
|
|
55
54
|
Effect.gen(function* () {
|
|
56
|
-
const reactivityGraph = useGlobalReactivityGraph ? globalReactivityGraph : makeReactivityGraph()
|
|
57
|
-
|
|
58
|
-
const fiberSet = yield* FiberSet.make()
|
|
59
|
-
|
|
60
55
|
const store: Store<any, FixtureSchema> = yield* createStore({
|
|
61
56
|
schema,
|
|
62
57
|
storeId: 'default',
|
|
63
58
|
adapter: makeInMemoryAdapter(),
|
|
64
|
-
|
|
65
|
-
otelOptions: {
|
|
66
|
-
tracer: otelTracer,
|
|
67
|
-
rootSpanContext: otelContext,
|
|
68
|
-
},
|
|
69
|
-
fiberSet,
|
|
59
|
+
debug: { instanceId: 'test' },
|
|
70
60
|
})
|
|
71
61
|
|
|
72
|
-
return
|
|
73
|
-
})
|
|
62
|
+
return store
|
|
63
|
+
}).pipe(provideOtel({ parentSpanContext: otelContext, otelTracer: otelTracer }))
|
package/src/utils/tests/mod.ts
CHANGED
package/src/utils/tests/otel.ts
CHANGED
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { identity } from '@livestore/utils/effect'
|
|
2
2
|
import type { Attributes } from '@opentelemetry/api'
|
|
3
3
|
import type { InMemorySpanExporter, ReadableSpan } from '@opentelemetry/sdk-trace-base'
|
|
4
|
-
|
|
5
4
|
type SimplifiedNestedSpan = { _name: string; attributes: any; children: SimplifiedNestedSpan[] }
|
|
6
5
|
|
|
7
6
|
export const getSimplifiedRootSpan = (
|
|
@@ -21,27 +20,35 @@ export const getSimplifiedRootSpan = (
|
|
|
21
20
|
})
|
|
22
21
|
|
|
23
22
|
type NestedSpan = { span: ReadableSpan; children: NestedSpan[] }
|
|
24
|
-
const rootSpan = spansMap.get(spans.find((_) => _.name === '
|
|
23
|
+
const rootSpan = spansMap.get(spans.find((_) => _.name === 'createStore')!.spanContext().spanId)!
|
|
25
24
|
|
|
26
25
|
const simplifySpanRec = (span: NestedSpan): SimplifiedNestedSpan =>
|
|
27
26
|
omitEmpty({
|
|
28
27
|
_name: span.span.name,
|
|
29
28
|
attributes: mapAttributesfn(span.span.attributes),
|
|
30
29
|
children: span.children
|
|
31
|
-
.filter((_) => _.span.name !== 'createStore')
|
|
30
|
+
.filter((_) => _.span.name !== 'createStore:makeAdapter')
|
|
32
31
|
// .sort((a, b) => compareHrTime(a.span.startTime, b.span.startTime))
|
|
33
32
|
.map(simplifySpanRec),
|
|
34
33
|
})
|
|
35
34
|
|
|
35
|
+
// console.log('rootSpan', rootSpan.span)
|
|
36
|
+
|
|
36
37
|
// console.dir(
|
|
37
38
|
// spans.map((_) => [_.spanContext().spanId, _.name, _.attributes, _.parentSpanId]),
|
|
38
39
|
// { depth: 10 },
|
|
39
40
|
// )
|
|
40
41
|
|
|
41
|
-
|
|
42
|
+
const simplifiedRootSpan = simplifySpanRec(rootSpan)
|
|
43
|
+
|
|
44
|
+
// console.log('simplifiedRootSpan', simplifiedRootSpan)
|
|
45
|
+
|
|
46
|
+
// writeFileSync('tmp/trace.json', JSON.stringify(toTraceFile(spans), null, 2))
|
|
47
|
+
|
|
48
|
+
return simplifiedRootSpan
|
|
42
49
|
}
|
|
43
50
|
|
|
44
|
-
// const compareHrTime = (a: [number,
|
|
51
|
+
// const compareHrTime = (a: [number, numndber], b: [number, number]) => {
|
|
45
52
|
// if (a[0] !== b[0]) return a[0] - b[0]
|
|
46
53
|
// return a[1] - b[1]
|
|
47
54
|
// }
|
|
@@ -59,3 +66,62 @@ const omitEmpty = (obj: any) => {
|
|
|
59
66
|
}
|
|
60
67
|
return result
|
|
61
68
|
}
|
|
69
|
+
|
|
70
|
+
export const toTraceFile = (spans: ReadableSpan[]) => {
|
|
71
|
+
const hrTimeToBigInt = (hrTime: [number, number]) => (BigInt(hrTime[0]) * BigInt(1e9) + BigInt(hrTime[1])).toString()
|
|
72
|
+
return {
|
|
73
|
+
batches: [
|
|
74
|
+
{
|
|
75
|
+
resource: {
|
|
76
|
+
attributes: [
|
|
77
|
+
{
|
|
78
|
+
key: 'service.name',
|
|
79
|
+
value: {
|
|
80
|
+
stringValue: 'test',
|
|
81
|
+
},
|
|
82
|
+
},
|
|
83
|
+
],
|
|
84
|
+
droppedAttributesCount: 0,
|
|
85
|
+
},
|
|
86
|
+
instrumentationLibrarySpans: [
|
|
87
|
+
{
|
|
88
|
+
spans: spans.map((span) => ({
|
|
89
|
+
traceId: span.spanContext().traceId,
|
|
90
|
+
spanId: span.spanContext().spanId,
|
|
91
|
+
...(span.parentSpanId ? { parentSpanId: span.parentSpanId } : {}),
|
|
92
|
+
// traceState: span.spanContext().traceState ?? '',
|
|
93
|
+
name: span.name,
|
|
94
|
+
kind: 'SPAN_KIND_INTERNAL',
|
|
95
|
+
startTimeUnixNano: hrTimeToBigInt(span.startTime),
|
|
96
|
+
endTimeUnixNano: hrTimeToBigInt(span.endTime),
|
|
97
|
+
attributes: Object.entries(span.attributes).map(([key, value]) => ({
|
|
98
|
+
key,
|
|
99
|
+
value:
|
|
100
|
+
typeof value === 'string'
|
|
101
|
+
? { stringValue: value }
|
|
102
|
+
: typeof value === 'number'
|
|
103
|
+
? Number.isInteger(value)
|
|
104
|
+
? { intValue: value }
|
|
105
|
+
: { doubleValue: value }
|
|
106
|
+
: typeof value === 'boolean'
|
|
107
|
+
? { boolValue: value }
|
|
108
|
+
: { stringValue: JSON.stringify(value) },
|
|
109
|
+
})),
|
|
110
|
+
droppedAttributesCount: span.droppedAttributesCount ?? 0,
|
|
111
|
+
droppedEventsCount: span.droppedEventsCount ?? 0,
|
|
112
|
+
droppedLinksCount: span.droppedLinksCount ?? 0,
|
|
113
|
+
status: {
|
|
114
|
+
code: span.status.code,
|
|
115
|
+
message: span.status.message ?? '',
|
|
116
|
+
},
|
|
117
|
+
})),
|
|
118
|
+
instrumentationLibrary: {
|
|
119
|
+
name: 'livestore',
|
|
120
|
+
version: '',
|
|
121
|
+
},
|
|
122
|
+
},
|
|
123
|
+
],
|
|
124
|
+
},
|
|
125
|
+
],
|
|
126
|
+
}
|
|
127
|
+
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sql.d.ts","sourceRoot":"","sources":["../../src/live-queries/sql.ts"],"names":[],"mappings":"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"}
|
package/dist/live-queries/sql.js
DELETED
|
@@ -1,175 +0,0 @@
|
|
|
1
|
-
import { getResultSchema, isQueryBuilder, prepareBindValues, QueryBuilderAstSymbol, replaceSessionIdSymbol, } from '@livestore/common';
|
|
2
|
-
import { deepEqual, shouldNeverHappen } from '@livestore/utils';
|
|
3
|
-
import { Predicate, Schema, TreeFormatter } from '@livestore/utils/effect';
|
|
4
|
-
import * as otel from '@opentelemetry/api';
|
|
5
|
-
import { globalReactivityGraph } from '../global-state.js';
|
|
6
|
-
import { isThunk, NOT_REFRESHED_YET } from '../reactive.js';
|
|
7
|
-
import { makeExecBeforeFirstRun, rowQueryLabel } from '../row-query.js';
|
|
8
|
-
import { getDurationMsFromSpan } from '../utils/otel.js';
|
|
9
|
-
import { LiveStoreQueryBase, makeGetAtomResult } from './base-class.js';
|
|
10
|
-
/**
|
|
11
|
-
* NOTE `query` is only supposed to read data. Don't use it to insert/update/delete data but use mutations instead.
|
|
12
|
-
*/
|
|
13
|
-
export const queryDb = (queryInput, options) => new LiveStoreDbQuery({
|
|
14
|
-
queryInput,
|
|
15
|
-
label: options?.label,
|
|
16
|
-
reactivityGraph: options?.reactivityGraph,
|
|
17
|
-
map: options?.map,
|
|
18
|
-
queryInfo: Predicate.hasProperty(options, 'queryInfo') ? options.queryInfo : undefined,
|
|
19
|
-
});
|
|
20
|
-
/* An object encapsulating a reactive SQL query */
|
|
21
|
-
export class LiveStoreDbQuery extends LiveStoreQueryBase {
|
|
22
|
-
_tag = 'sql';
|
|
23
|
-
/** A reactive thunk representing the query text */
|
|
24
|
-
queryInput$;
|
|
25
|
-
/** A reactive thunk representing the query results */
|
|
26
|
-
results$;
|
|
27
|
-
label;
|
|
28
|
-
// TODO
|
|
29
|
-
queryInfo;
|
|
30
|
-
reactivityGraph;
|
|
31
|
-
mapResult;
|
|
32
|
-
constructor({ queryInput, label: inputLabel, reactivityGraph, map, queryInfo: queryInfo_, }) {
|
|
33
|
-
super();
|
|
34
|
-
// TODO implement a proper toString method
|
|
35
|
-
this.label = inputLabel ? `sql(${inputLabel})` : `sql(${queryInput.toString()})`;
|
|
36
|
-
this.reactivityGraph = reactivityGraph ?? globalReactivityGraph;
|
|
37
|
-
this.mapResult = map === undefined ? (rows) => rows : map;
|
|
38
|
-
const schemaRef = {
|
|
39
|
-
current: typeof queryInput === 'function' ? undefined : isQueryBuilder(queryInput) ? undefined : queryInput.schema,
|
|
40
|
-
};
|
|
41
|
-
const execBeforeFirstRunRef = {
|
|
42
|
-
current: undefined,
|
|
43
|
-
};
|
|
44
|
-
let queryInputRaw$OrQueryInputRaw;
|
|
45
|
-
const queryBuilderToQueryInputRaw = (qb) => {
|
|
46
|
-
const qbRes = qb.asSql();
|
|
47
|
-
const schema = getResultSchema(qb);
|
|
48
|
-
const ast = qb[QueryBuilderAstSymbol];
|
|
49
|
-
if (ast._tag === 'RowQuery') {
|
|
50
|
-
execBeforeFirstRunRef.current = makeExecBeforeFirstRun({
|
|
51
|
-
table: ast.tableDef,
|
|
52
|
-
insertValues: ast.insertValues,
|
|
53
|
-
id: ast.id,
|
|
54
|
-
});
|
|
55
|
-
this.label = rowQueryLabel(ast.tableDef, ast.id);
|
|
56
|
-
}
|
|
57
|
-
return {
|
|
58
|
-
query: qbRes.query,
|
|
59
|
-
schema,
|
|
60
|
-
bindValues: qbRes.bindValues,
|
|
61
|
-
queriedTables: new Set([ast.tableDef.sqliteDef.name]),
|
|
62
|
-
queryInfo: ast._tag === 'RowQuery' ? { _tag: 'Row', table: ast.tableDef, id: ast.id } : { _tag: 'None' },
|
|
63
|
-
};
|
|
64
|
-
};
|
|
65
|
-
if (typeof queryInput === 'function') {
|
|
66
|
-
queryInputRaw$OrQueryInputRaw = this.reactivityGraph.makeThunk((get, setDebugInfo, ctx, otelContext) => {
|
|
67
|
-
const startMs = performance.now();
|
|
68
|
-
const queryInputResult = queryInput(makeGetAtomResult(get, otelContext ?? ctx.rootOtelContext), ctx);
|
|
69
|
-
const durationMs = performance.now() - startMs;
|
|
70
|
-
const queryInputRaw = isQueryBuilder(queryInputResult)
|
|
71
|
-
? queryBuilderToQueryInputRaw(queryInputResult)
|
|
72
|
-
: queryInputResult;
|
|
73
|
-
setDebugInfo({ _tag: 'computed', label: `${this.label}:queryInput`, query: queryInputRaw.query, durationMs });
|
|
74
|
-
schemaRef.current = queryInputRaw.schema;
|
|
75
|
-
this.queryInfo = queryInputRaw.queryInfo;
|
|
76
|
-
return queryInputRaw;
|
|
77
|
-
}, {
|
|
78
|
-
label: `${this.label}:query`,
|
|
79
|
-
// TODO adjust to `sqlQueryInput` + adjust in devtools
|
|
80
|
-
meta: { liveStoreThunkType: 'sqlQuery' },
|
|
81
|
-
// NOTE we're not checking the schema here as we assume the query string to always change when the schema might change
|
|
82
|
-
equal: (a, b) => a.query === b.query && deepEqual(a.bindValues, b.bindValues),
|
|
83
|
-
});
|
|
84
|
-
// TODO come up with a better way to handle this
|
|
85
|
-
this.queryInfo = { _tag: 'None' };
|
|
86
|
-
}
|
|
87
|
-
else {
|
|
88
|
-
const queryInputRaw = isQueryBuilder(queryInput) ? queryBuilderToQueryInputRaw(queryInput) : queryInput;
|
|
89
|
-
schemaRef.current = queryInputRaw.schema;
|
|
90
|
-
queryInputRaw$OrQueryInputRaw = queryInputRaw;
|
|
91
|
-
// this.label = inputLabel ? this.label : `sql(${})`
|
|
92
|
-
if (inputLabel === undefined && isQueryBuilder(queryInput)) {
|
|
93
|
-
const ast = queryInput[QueryBuilderAstSymbol];
|
|
94
|
-
if (ast._tag === 'RowQuery') {
|
|
95
|
-
this.label = `sql(${rowQueryLabel(ast.tableDef, ast.id)})`;
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
this.queryInfo = queryInputRaw.queryInfo;
|
|
99
|
-
}
|
|
100
|
-
// TODO
|
|
101
|
-
const label = this.label;
|
|
102
|
-
const queriedTablesRef = { current: undefined };
|
|
103
|
-
// const schemaEqual = Schema.equivalence(schema)
|
|
104
|
-
// TODO also support derived equality for `map` (probably will depend on having an easy way to transform a schema without an `encode` step)
|
|
105
|
-
// This would mean dropping the `map` option
|
|
106
|
-
const resultsEqual = map === undefined
|
|
107
|
-
? (a, b) => a === NOT_REFRESHED_YET || b === NOT_REFRESHED_YET ? false : Schema.equivalence(schemaRef.current)(a, b)
|
|
108
|
-
: undefined;
|
|
109
|
-
const results$ = this.reactivityGraph.makeThunk((get, setDebugInfo, queryContext, otelContext) => queryContext.otelTracer.startActiveSpan('sql:...', // NOTE span name will be overridden further down
|
|
110
|
-
{}, otelContext ?? queryContext.rootOtelContext, (span) => {
|
|
111
|
-
const otelContext = otel.trace.setSpan(otel.context.active(), span);
|
|
112
|
-
const { store } = queryContext;
|
|
113
|
-
if (execBeforeFirstRunRef.current !== undefined) {
|
|
114
|
-
execBeforeFirstRunRef.current(queryContext, otelContext);
|
|
115
|
-
execBeforeFirstRunRef.current = undefined;
|
|
116
|
-
}
|
|
117
|
-
const queryInputResult = isThunk(queryInputRaw$OrQueryInputRaw)
|
|
118
|
-
? get(queryInputRaw$OrQueryInputRaw, otelContext)
|
|
119
|
-
: queryInputRaw$OrQueryInputRaw;
|
|
120
|
-
const sqlString = queryInputResult.query;
|
|
121
|
-
const bindValues = queryInputResult.bindValues;
|
|
122
|
-
if (queriedTablesRef.current === undefined) {
|
|
123
|
-
queriedTablesRef.current = store.syncDbWrapper.getTablesUsed(sqlString);
|
|
124
|
-
}
|
|
125
|
-
if (bindValues !== undefined) {
|
|
126
|
-
replaceSessionIdSymbol(bindValues, store.clientSession.coordinator.sessionId);
|
|
127
|
-
}
|
|
128
|
-
// Establish a reactive dependency on the tables used in the query
|
|
129
|
-
for (const tableName of queriedTablesRef.current) {
|
|
130
|
-
const tableRef = store.tableRefs[tableName] ?? shouldNeverHappen(`No table ref found for ${tableName}`);
|
|
131
|
-
get(tableRef, otelContext);
|
|
132
|
-
}
|
|
133
|
-
span.setAttribute('sql.query', sqlString);
|
|
134
|
-
span.updateName(`sql:${sqlString.slice(0, 50)}`);
|
|
135
|
-
const rawDbResults = store.syncDbWrapper.select(sqlString, {
|
|
136
|
-
queriedTables: queriedTablesRef.current,
|
|
137
|
-
bindValues: bindValues ? prepareBindValues(bindValues, sqlString) : undefined,
|
|
138
|
-
otelContext,
|
|
139
|
-
});
|
|
140
|
-
span.setAttribute('sql.rowsCount', rawDbResults.length);
|
|
141
|
-
const parsedResult = Schema.decodeEither(schemaRef.current)(rawDbResults);
|
|
142
|
-
if (parsedResult._tag === 'Left') {
|
|
143
|
-
const parseErrorStr = TreeFormatter.formatErrorSync(parsedResult.left);
|
|
144
|
-
const expectedSchemaStr = String(schemaRef.current.ast);
|
|
145
|
-
const bindValuesStr = bindValues === undefined ? '' : `\nBind values: ${JSON.stringify(bindValues)}`;
|
|
146
|
-
console.error(`\
|
|
147
|
-
Error parsing SQL query result.
|
|
148
|
-
|
|
149
|
-
Query: ${sqlString}\
|
|
150
|
-
${bindValuesStr}
|
|
151
|
-
|
|
152
|
-
Expected schema: ${expectedSchemaStr}
|
|
153
|
-
|
|
154
|
-
Error: ${parseErrorStr}
|
|
155
|
-
|
|
156
|
-
Result:`, rawDbResults);
|
|
157
|
-
return shouldNeverHappen(`Error parsing SQL query result: ${parsedResult.left}`);
|
|
158
|
-
}
|
|
159
|
-
const result = this.mapResult(parsedResult.right);
|
|
160
|
-
span.end();
|
|
161
|
-
const durationMs = getDurationMsFromSpan(span);
|
|
162
|
-
this.executionTimes.push(durationMs);
|
|
163
|
-
setDebugInfo({ _tag: 'sql', label: `${label}:results`, query: sqlString, durationMs });
|
|
164
|
-
return result;
|
|
165
|
-
}), { label: `${label}:results`, meta: { liveStoreThunkType: 'sqlResult' }, equal: resultsEqual });
|
|
166
|
-
this.results$ = results$;
|
|
167
|
-
}
|
|
168
|
-
destroy = () => {
|
|
169
|
-
if (this.queryInput$ !== undefined) {
|
|
170
|
-
this.reactivityGraph.destroyNode(this.queryInput$);
|
|
171
|
-
}
|
|
172
|
-
this.reactivityGraph.destroyNode(this.results$);
|
|
173
|
-
};
|
|
174
|
-
}
|
|
175
|
-
//# sourceMappingURL=sql.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sql.js","sourceRoot":"","sources":["../../src/live-queries/sql.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"sql.test.d.ts","sourceRoot":"","sources":["../../src/live-queries/sql.test.ts"],"names":[],"mappings":""}
|