@livestore/livestore 0.0.10 → 0.0.12
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/package.json +7 -7
- package/src/__tests__/reactive.test.ts +39 -0
- package/src/react/useLiveStoreComponent.ts +4 -2
- package/src/reactive.ts +2 -1
- package/dist/.tsbuildinfo +0 -1
- package/dist/QueryCache.d.ts +0 -20
- package/dist/QueryCache.d.ts.map +0 -1
- package/dist/QueryCache.js +0 -71
- package/dist/QueryCache.js.map +0 -1
- package/dist/__tests__/react/fixture.d.ts +0 -141
- package/dist/__tests__/react/fixture.d.ts.map +0 -1
- package/dist/__tests__/react/fixture.js +0 -68
- package/dist/__tests__/react/fixture.js.map +0 -1
- package/dist/__tests__/react/useLiveStoreComponent.test.d.ts +0 -2
- package/dist/__tests__/react/useLiveStoreComponent.test.d.ts.map +0 -1
- package/dist/__tests__/react/useLiveStoreComponent.test.js +0 -78
- package/dist/__tests__/react/useLiveStoreComponent.test.js.map +0 -1
- package/dist/__tests__/reactive.test.d.ts +0 -2
- package/dist/__tests__/reactive.test.d.ts.map +0 -1
- package/dist/__tests__/reactive.test.js +0 -167
- package/dist/__tests__/reactive.test.js.map +0 -1
- package/dist/backends/base.d.ts +0 -13
- package/dist/backends/base.d.ts.map +0 -1
- package/dist/backends/base.js +0 -53
- package/dist/backends/base.js.map +0 -1
- package/dist/backends/index.d.ts +0 -45
- package/dist/backends/index.d.ts.map +0 -1
- package/dist/backends/index.js +0 -38
- package/dist/backends/index.js.map +0 -1
- package/dist/backends/noop.d.ts +0 -18
- package/dist/backends/noop.d.ts.map +0 -1
- package/dist/backends/noop.js +0 -21
- package/dist/backends/noop.js.map +0 -1
- package/dist/backends/tauri.d.ts +0 -22
- package/dist/backends/tauri.d.ts.map +0 -1
- package/dist/backends/tauri.js +0 -48
- package/dist/backends/tauri.js.map +0 -1
- package/dist/backends/utils/idb.d.ts +0 -10
- package/dist/backends/utils/idb.d.ts.map +0 -1
- package/dist/backends/utils/idb.js +0 -58
- package/dist/backends/utils/idb.js.map +0 -1
- package/dist/backends/web-in-memory.d.ts +0 -22
- package/dist/backends/web-in-memory.d.ts.map +0 -1
- package/dist/backends/web-in-memory.js +0 -45
- package/dist/backends/web-in-memory.js.map +0 -1
- package/dist/backends/web-worker.d.ts +0 -17
- package/dist/backends/web-worker.d.ts.map +0 -1
- package/dist/backends/web-worker.js +0 -139
- package/dist/backends/web-worker.js.map +0 -1
- package/dist/backends/web.d.ts +0 -27
- package/dist/backends/web.d.ts.map +0 -1
- package/dist/backends/web.js +0 -63
- package/dist/backends/web.js.map +0 -1
- package/dist/bounded-collections.d.ts +0 -34
- package/dist/bounded-collections.d.ts.map +0 -1
- package/dist/bounded-collections.js +0 -103
- package/dist/bounded-collections.js.map +0 -1
- package/dist/componentKey.d.ts +0 -20
- package/dist/componentKey.d.ts.map +0 -1
- package/dist/componentKey.js +0 -3
- package/dist/componentKey.js.map +0 -1
- package/dist/effect/LiveStore.d.ts +0 -42
- package/dist/effect/LiveStore.d.ts.map +0 -1
- package/dist/effect/LiveStore.js +0 -40
- package/dist/effect/LiveStore.js.map +0 -1
- package/dist/effect/index.d.ts +0 -2
- package/dist/effect/index.d.ts.map +0 -1
- package/dist/effect/index.js +0 -2
- package/dist/effect/index.js.map +0 -1
- package/dist/events.d.ts +0 -7
- package/dist/events.d.ts.map +0 -1
- package/dist/events.js +0 -2
- package/dist/events.js.map +0 -1
- package/dist/inMemoryDatabase.d.ts +0 -65
- package/dist/inMemoryDatabase.d.ts.map +0 -1
- package/dist/inMemoryDatabase.js +0 -241
- package/dist/inMemoryDatabase.js.map +0 -1
- package/dist/index.d.ts +0 -20
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js +0 -10
- package/dist/index.js.map +0 -1
- package/dist/otel.d.ts +0 -5
- package/dist/otel.d.ts.map +0 -1
- package/dist/otel.js +0 -17
- package/dist/otel.js.map +0 -1
- package/dist/react/LiveStoreContext.d.ts +0 -11
- package/dist/react/LiveStoreContext.d.ts.map +0 -1
- package/dist/react/LiveStoreContext.js +0 -10
- package/dist/react/LiveStoreContext.js.map +0 -1
- package/dist/react/LiveStoreProvider.d.ts +0 -21
- package/dist/react/LiveStoreProvider.d.ts.map +0 -1
- package/dist/react/LiveStoreProvider.js +0 -48
- package/dist/react/LiveStoreProvider.js.map +0 -1
- package/dist/react/index.d.ts +0 -7
- package/dist/react/index.d.ts.map +0 -1
- package/dist/react/index.js +0 -6
- package/dist/react/index.js.map +0 -1
- package/dist/react/useGlobalQuery.d.ts +0 -3
- package/dist/react/useGlobalQuery.d.ts.map +0 -1
- package/dist/react/useGlobalQuery.js +0 -25
- package/dist/react/useGlobalQuery.js.map +0 -1
- package/dist/react/useGraphQL.d.ts +0 -11
- package/dist/react/useGraphQL.d.ts.map +0 -1
- package/dist/react/useGraphQL.js +0 -67
- package/dist/react/useGraphQL.js.map +0 -1
- package/dist/react/useLiveStoreComponent.d.ts +0 -70
- package/dist/react/useLiveStoreComponent.d.ts.map +0 -1
- package/dist/react/useLiveStoreComponent.js +0 -272
- package/dist/react/useLiveStoreComponent.js.map +0 -1
- package/dist/react/utils/useStateRefWithReactiveInput.d.ts +0 -13
- package/dist/react/utils/useStateRefWithReactiveInput.d.ts.map +0 -1
- package/dist/react/utils/useStateRefWithReactiveInput.js +0 -38
- package/dist/react/utils/useStateRefWithReactiveInput.js.map +0 -1
- package/dist/reactive.d.ts +0 -140
- package/dist/reactive.d.ts.map +0 -1
- package/dist/reactive.js +0 -301
- package/dist/reactive.js.map +0 -1
- package/dist/reactiveQueries/base-class.d.ts +0 -24
- package/dist/reactiveQueries/base-class.d.ts.map +0 -1
- package/dist/reactiveQueries/base-class.js +0 -22
- package/dist/reactiveQueries/base-class.js.map +0 -1
- package/dist/reactiveQueries/graphql.d.ts +0 -25
- package/dist/reactiveQueries/graphql.d.ts.map +0 -1
- package/dist/reactiveQueries/graphql.js +0 -18
- package/dist/reactiveQueries/graphql.js.map +0 -1
- package/dist/reactiveQueries/js.d.ts +0 -19
- package/dist/reactiveQueries/js.d.ts.map +0 -1
- package/dist/reactiveQueries/js.js +0 -13
- package/dist/reactiveQueries/js.js.map +0 -1
- package/dist/reactiveQueries/sql.d.ts +0 -31
- package/dist/reactiveQueries/sql.d.ts.map +0 -1
- package/dist/reactiveQueries/sql.js +0 -32
- package/dist/reactiveQueries/sql.js.map +0 -1
- package/dist/schema.d.ts +0 -163
- package/dist/schema.d.ts.map +0 -1
- package/dist/schema.js +0 -92
- package/dist/schema.js.map +0 -1
- package/dist/store.d.ts +0 -192
- package/dist/store.d.ts.map +0 -1
- package/dist/store.js +0 -539
- package/dist/store.js.map +0 -1
- package/dist/util.d.ts +0 -24
- package/dist/util.d.ts.map +0 -1
- package/dist/util.js +0 -51
- package/dist/util.js.map +0 -1
package/dist/backends/base.js
DELETED
|
@@ -1,53 +0,0 @@
|
|
|
1
|
-
/* eslint-disable @typescript-eslint/no-unused-vars */
|
|
2
|
-
import { errorToString } from '@livestore/utils';
|
|
3
|
-
import { identity } from '@livestore/utils/effect';
|
|
4
|
-
import * as otel from '@opentelemetry/api';
|
|
5
|
-
export class BaseBackend {
|
|
6
|
-
constructor() {
|
|
7
|
-
this.select = async (query, bindValues) => {
|
|
8
|
-
throw new Error('Method not implemented.');
|
|
9
|
-
};
|
|
10
|
-
this.execute = (query, bindValues, parentSpan) => {
|
|
11
|
-
throw new Error('Method not implemented.');
|
|
12
|
-
};
|
|
13
|
-
this.getPersistedData = async (parentSpan) => {
|
|
14
|
-
throw new Error('Method not implemented.');
|
|
15
|
-
};
|
|
16
|
-
// TODO move `applyEvent` logic to Store and only call `execute` here
|
|
17
|
-
this.applyEvent = (event, eventDefinition, parentSpan) => {
|
|
18
|
-
const ctx = parentSpan ? otel.trace.setSpan(otel.context.active(), parentSpan) : otel.context.active();
|
|
19
|
-
this.otelTracer.startActiveSpan('LiveStore:backend:applyEvent', {}, ctx, (span) => {
|
|
20
|
-
try {
|
|
21
|
-
// Careful: this SQL statement is duplicated in the backend.
|
|
22
|
-
// Remember to update it in src-tauri/src/store.rs:apply_event as well.
|
|
23
|
-
// await this.execute(sql`insert into ${EVENTS_TABLE_NAME} (id, type, args) values ($id, $type, $args)`, {
|
|
24
|
-
// id: event.id,
|
|
25
|
-
// type: event.type,
|
|
26
|
-
// args: JSON.stringify(event.args ?? {}),
|
|
27
|
-
// })
|
|
28
|
-
const statement = typeof eventDefinition.statement === 'function'
|
|
29
|
-
? eventDefinition.statement(event.args)
|
|
30
|
-
: eventDefinition.statement;
|
|
31
|
-
const prepareBindValues = eventDefinition.prepareBindValues ?? identity;
|
|
32
|
-
const bindValues = typeof eventDefinition.statement === 'function' && statement.argsAlreadyBound
|
|
33
|
-
? {}
|
|
34
|
-
: prepareBindValues(event.args);
|
|
35
|
-
span.setAttributes({
|
|
36
|
-
'livestore.statement.sql': statement.sql,
|
|
37
|
-
'livestore.statement.writeTables': statement.writeTables,
|
|
38
|
-
'livestore.statement.bindVales': JSON.stringify(bindValues),
|
|
39
|
-
});
|
|
40
|
-
this.execute(statement.sql, bindValues, span);
|
|
41
|
-
}
|
|
42
|
-
catch (e) {
|
|
43
|
-
span.setStatus({ code: otel.SpanStatusCode.ERROR, message: errorToString(e) });
|
|
44
|
-
throw e;
|
|
45
|
-
}
|
|
46
|
-
finally {
|
|
47
|
-
span.end();
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
};
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
//# sourceMappingURL=base.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"base.js","sourceRoot":"","sources":["../../src/backends/base.ts"],"names":[],"mappings":"AAAA,sDAAsD;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAChD,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAA;AAClD,OAAO,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAQ1C,MAAM,OAAgB,WAAW;IAAjC;QAGE,WAAM,GAAG,KAAK,EAAW,KAAa,EAAE,UAAyB,EAA8B,EAAE;YAC/F,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAA;QAC5C,CAAC,CAAA;QAED,YAAO,GAAG,CAAC,KAAa,EAAE,UAAyB,EAAE,UAAsB,EAAQ,EAAE;YACnF,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAA;QAC5C,CAAC,CAAA;QAED,qBAAgB,GAAG,KAAK,EAAE,UAAsB,EAAuB,EAAE;YACvE,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAA;QAC5C,CAAC,CAAA;QAED,qEAAqE;QACrE,eAAU,GAAG,CAAC,KAAqB,EAAE,eAAiC,EAAE,UAAsB,EAAQ,EAAE;YACtG,MAAM,GAAG,GAAG,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAA;YACtG,IAAI,CAAC,UAAU,CAAC,eAAe,CAAC,8BAA8B,EAAE,EAAE,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE,EAAE;gBAChF,IAAI;oBACF,4DAA4D;oBAC5D,uEAAuE;oBACvE,0GAA0G;oBAC1G,kBAAkB;oBAClB,sBAAsB;oBACtB,4CAA4C;oBAC5C,KAAK;oBAEL,MAAM,SAAS,GACb,OAAO,eAAe,CAAC,SAAS,KAAK,UAAU;wBAC7C,CAAC,CAAC,eAAe,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC;wBACvC,CAAC,CAAC,eAAe,CAAC,SAAS,CAAA;oBAE/B,MAAM,iBAAiB,GAAG,eAAe,CAAC,iBAAiB,IAAI,QAAQ,CAAA;oBAEvE,MAAM,UAAU,GACd,OAAO,eAAe,CAAC,SAAS,KAAK,UAAU,IAAI,SAAS,CAAC,gBAAgB;wBAC3E,CAAC,CAAC,EAAE;wBACJ,CAAC,CAAC,iBAAiB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAA;oBAEnC,IAAI,CAAC,aAAa,CAAC;wBACjB,yBAAyB,EAAE,SAAS,CAAC,GAAG;wBACxC,iCAAiC,EAAE,SAAS,CAAC,WAAW;wBACxD,+BAA+B,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;qBAC5D,CAAC,CAAA;oBAEF,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,EAAE,UAAU,EAAE,IAAI,CAAC,CAAA;iBAC9C;gBAAC,OAAO,CAAM,EAAE;oBACf,IAAI,CAAC,SAAS,CAAC,EAAE,IAAI,EAAE,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,OAAO,EAAE,aAAa,CAAC,CAAC,CAAC,EAAE,CAAC,CAAA;oBAC9E,MAAM,CAAC,CAAA;iBACR;wBAAS;oBACR,IAAI,CAAC,GAAG,EAAE,CAAA;iBACX;YACH,CAAC,CAAC,CAAA;QACJ,CAAC,CAAA;IACH,CAAC;CAAA"}
|
package/dist/backends/index.d.ts
DELETED
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
import type * as otel from '@opentelemetry/api';
|
|
2
|
-
import type { LiveStoreEvent } from '../events.js';
|
|
3
|
-
import type { ActionDefinition } from '../schema.js';
|
|
4
|
-
import type { ParamsObject } from '../util.js';
|
|
5
|
-
import type { BackendOptionsTauri } from './tauri.js';
|
|
6
|
-
import type { BackendOptionsWeb } from './web.js';
|
|
7
|
-
import type { BackendOptionsWebInMemory } from './web-in-memory.js';
|
|
8
|
-
export type WritableDatabaseLocation = {
|
|
9
|
-
type: 'opfs';
|
|
10
|
-
virtualFilename: string;
|
|
11
|
-
} | {
|
|
12
|
-
type: 'indexeddb';
|
|
13
|
-
virtualFilename: string;
|
|
14
|
-
} | {
|
|
15
|
-
type: 'filesystem';
|
|
16
|
-
directory: string;
|
|
17
|
-
filename: string;
|
|
18
|
-
} | {
|
|
19
|
-
type: 'volatile-in-memory';
|
|
20
|
-
};
|
|
21
|
-
export interface Backend {
|
|
22
|
-
select<T = any>(query: string, bindValues?: ParamsObject, parentSpan?: otel.Span): Promise<SelectResponse<T>>;
|
|
23
|
-
execute(query: string, bindValues?: ParamsObject, parentSpan?: otel.Span): void;
|
|
24
|
-
/** Apply an event to the backend */
|
|
25
|
-
applyEvent(event: LiveStoreEvent, eventDefiniton: ActionDefinition, parentSpan?: otel.Span): void;
|
|
26
|
-
/** Return a snapshot of persisted data from the backend */
|
|
27
|
-
getPersistedData(parentSpan?: otel.Span): Promise<Uint8Array>;
|
|
28
|
-
}
|
|
29
|
-
export type BackendType = 'tauri' | 'web' | 'web-in-memory';
|
|
30
|
-
export declare const isBackendType: (type: string) => type is BackendType;
|
|
31
|
-
export type SelectResponse<T = any> = {
|
|
32
|
-
results: T[];
|
|
33
|
-
[key: string]: any;
|
|
34
|
-
};
|
|
35
|
-
export declare enum IndexType {
|
|
36
|
-
Basic = "Basic",
|
|
37
|
-
FullText = "FullText"
|
|
38
|
-
}
|
|
39
|
-
export type BackendOptions = BackendOptionsTauri | BackendOptionsWeb | BackendOptionsWebInMemory;
|
|
40
|
-
export type BackendOtelProps = {
|
|
41
|
-
otelTracer: otel.Tracer;
|
|
42
|
-
parentSpan: otel.Span;
|
|
43
|
-
};
|
|
44
|
-
export declare const createBackend: (options: BackendOptions, otelProps: BackendOtelProps) => Promise<Backend>;
|
|
45
|
-
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/backends/index.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAE/C,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,cAAc,CAAA;AAClD,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAA;AACpD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAE9C,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,YAAY,CAAA;AACrD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAA;AAEjD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,oBAAoB,CAAA;AAInE,MAAM,MAAM,wBAAwB,GAChC;IACE,IAAI,EAAE,MAAM,CAAA;IACZ,eAAe,EAAE,MAAM,CAAA;CACxB,GACD;IACE,IAAI,EAAE,WAAW,CAAA;IACjB,eAAe,EAAE,MAAM,CAAA;CACxB,GACD;IACE,IAAI,EAAE,YAAY,CAAA;IAClB,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,EAAE,MAAM,CAAA;CACjB,GACD;IACE,IAAI,EAAE,oBAAoB,CAAA;CAC3B,CAAA;AAEL,MAAM,WAAW,OAAO;IAGtB,MAAM,CAAC,CAAC,GAAG,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,YAAY,EAAE,UAAU,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,CAAA;IAI7G,OAAO,CAAC,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,YAAY,EAAE,UAAU,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;IAE/E,oCAAoC;IACpC,UAAU,CAAC,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,gBAAgB,EAAE,UAAU,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAA;IAEjG,2DAA2D;IAC3D,gBAAgB,CAAC,UAAU,CAAC,EAAE,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,UAAU,CAAC,CAAA;CAC9D;AAED,MAAM,MAAM,WAAW,GAAG,OAAO,GAAG,KAAK,GAAG,eAAe,CAAA;AAE3D,eAAO,MAAM,aAAa,SAAU,MAAM,wBAEzC,CAAA;AAED,MAAM,MAAM,cAAc,CAAC,CAAC,GAAG,GAAG,IAAI;IACpC,OAAO,EAAE,CAAC,EAAE,CAAA;IAGZ,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CACnB,CAAA;AAED,oBAAY,SAAS;IACnB,KAAK,UAAU;IACf,QAAQ,aAAa;CACtB;AAED,MAAM,MAAM,cAAc,GAAG,mBAAmB,GAAG,iBAAiB,GAAG,yBAAyB,CAAA;AAChG,MAAM,MAAM,gBAAgB,GAAG;IAC7B,UAAU,EAAE,IAAI,CAAC,MAAM,CAAA;IACvB,UAAU,EAAE,IAAI,CAAC,IAAI,CAAA;CACtB,CAAA;AAED,eAAO,MAAM,aAAa,YAAmB,cAAc,aAAa,gBAAgB,KAAG,QAAQ,OAAO,CAkBzG,CAAA"}
|
package/dist/backends/index.js
DELETED
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
// A backend represents a raw SQLite database.
|
|
2
|
-
// Examples include:
|
|
3
|
-
// - A native SQLite process running in a Tauri Rust process
|
|
4
|
-
// - A SQL.js WASM version of SQLite running in a web worker
|
|
5
|
-
//
|
|
6
|
-
// We can send commands to execute various kinds of queries,
|
|
7
|
-
// and respond to various events from the database.
|
|
8
|
-
import { casesHandled } from '../util.js';
|
|
9
|
-
import { WebWorkerBackend } from './web.js';
|
|
10
|
-
import { WebInMemoryBackend } from './web-in-memory.js';
|
|
11
|
-
export const isBackendType = (type) => {
|
|
12
|
-
return type === 'tauri' || type === 'web' || type === 'web-in-memory';
|
|
13
|
-
};
|
|
14
|
-
export var IndexType;
|
|
15
|
-
(function (IndexType) {
|
|
16
|
-
IndexType["Basic"] = "Basic";
|
|
17
|
-
IndexType["FullText"] = "FullText";
|
|
18
|
-
})(IndexType || (IndexType = {}));
|
|
19
|
-
export const createBackend = async (options, otelProps) => {
|
|
20
|
-
switch (options.type) {
|
|
21
|
-
case 'tauri': {
|
|
22
|
-
// NOTE Dynamic import is needed to avoid Tauri is a dependency of LiveStore (e.g. when used in the web)
|
|
23
|
-
const { TauriBackend } = await import('./tauri.js');
|
|
24
|
-
return await TauriBackend.load(options, otelProps);
|
|
25
|
-
}
|
|
26
|
-
case 'web': {
|
|
27
|
-
return WebWorkerBackend.load(options, otelProps);
|
|
28
|
-
}
|
|
29
|
-
// NOTE currently only needed for testing
|
|
30
|
-
case 'web-in-memory': {
|
|
31
|
-
return WebInMemoryBackend.load(options, otelProps);
|
|
32
|
-
}
|
|
33
|
-
default: {
|
|
34
|
-
casesHandled(options);
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
};
|
|
38
|
-
//# sourceMappingURL=index.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/backends/index.ts"],"names":[],"mappings":"AAAA,8CAA8C;AAC9C,oBAAoB;AACpB,4DAA4D;AAC5D,4DAA4D;AAC5D,EAAE;AACF,4DAA4D;AAC5D,mDAAmD;AAOnD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAGzC,OAAO,EAAE,gBAAgB,EAAE,MAAM,UAAU,CAAA;AAE3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAA;AAuCvD,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,IAAY,EAAuB,EAAE;IACjE,OAAO,IAAI,KAAK,OAAO,IAAI,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,eAAe,CAAA;AACvE,CAAC,CAAA;AASD,MAAM,CAAN,IAAY,SAGX;AAHD,WAAY,SAAS;IACnB,4BAAe,CAAA;IACf,kCAAqB,CAAA;AACvB,CAAC,EAHW,SAAS,KAAT,SAAS,QAGpB;AAQD,MAAM,CAAC,MAAM,aAAa,GAAG,KAAK,EAAE,OAAuB,EAAE,SAA2B,EAAoB,EAAE;IAC5G,QAAQ,OAAO,CAAC,IAAI,EAAE;QACpB,KAAK,OAAO,CAAC,CAAC;YACZ,wGAAwG;YACxG,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,MAAM,CAAC,YAAY,CAAC,CAAA;YACnD,OAAO,MAAM,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAA;SACnD;QACD,KAAK,KAAK,CAAC,CAAC;YACV,OAAO,gBAAgB,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAA;SACjD;QACD,yCAAyC;QACzC,KAAK,eAAe,CAAC,CAAC;YACpB,OAAO,kBAAkB,CAAC,IAAI,CAAC,OAAO,EAAE,SAAS,CAAC,CAAA;SACnD;QACD,OAAO,CAAC,CAAC;YACP,YAAY,CAAC,OAAO,CAAC,CAAA;SACtB;KACF;AACH,CAAC,CAAA"}
|
package/dist/backends/noop.d.ts
DELETED
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import type * as otel from '@opentelemetry/api';
|
|
2
|
-
import type { ParamsObject } from '../util.js';
|
|
3
|
-
import { BaseBackend } from './base.js';
|
|
4
|
-
import type { SelectResponse } from './index.js';
|
|
5
|
-
export type BackendOptionsNoop = {
|
|
6
|
-
type: 'noop';
|
|
7
|
-
/** Specifies where to persist data for this backend */
|
|
8
|
-
otelTracer?: otel.Tracer;
|
|
9
|
-
};
|
|
10
|
-
export declare class NoopBackend extends BaseBackend {
|
|
11
|
-
readonly otelTracer: otel.Tracer;
|
|
12
|
-
constructor(otelTracer: otel.Tracer);
|
|
13
|
-
static load: (options: BackendOptionsNoop) => Promise<NoopBackend>;
|
|
14
|
-
execute: (_query: string, _bindValues?: ParamsObject) => void;
|
|
15
|
-
select: <T>(_query: string, _bindValues?: ParamsObject) => Promise<SelectResponse<T>>;
|
|
16
|
-
getPersistedData: () => Promise<Uint8Array>;
|
|
17
|
-
}
|
|
18
|
-
//# sourceMappingURL=noop.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"noop.d.ts","sourceRoot":"","sources":["../../src/backends/noop.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAE/C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAEhD,MAAM,MAAM,kBAAkB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAA;IACZ,uDAAuD;IACvD,UAAU,CAAC,EAAE,IAAI,CAAC,MAAM,CAAA;CACzB,CAAA;AAED,qBAAa,WAAY,SAAQ,WAAW;IAC9B,QAAQ,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM;gBAAvB,UAAU,EAAE,IAAI,CAAC,MAAM;IAI5C,MAAM,CAAC,IAAI,YAAmB,kBAAkB,KAAG,QAAQ,WAAW,CAAC,CAEtE;IAED,OAAO,WAAY,MAAM,gBAAgB,YAAY,KAAG,IAAI,CAAM;IAElE,MAAM,cAAqB,MAAM,gBAAgB,YAAY,gCAE5D;IAED,gBAAgB,QAAa,QAAQ,UAAU,CAAC,CAE/C;CACF"}
|
package/dist/backends/noop.js
DELETED
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
var _a;
|
|
2
|
-
import { makeNoopTracer } from '@livestore/utils';
|
|
3
|
-
import { BaseBackend } from './base.js';
|
|
4
|
-
export class NoopBackend extends BaseBackend {
|
|
5
|
-
constructor(otelTracer) {
|
|
6
|
-
super();
|
|
7
|
-
this.otelTracer = otelTracer;
|
|
8
|
-
this.execute = (_query, _bindValues) => { };
|
|
9
|
-
this.select = async (_query, _bindValues) => {
|
|
10
|
-
return { results: [] };
|
|
11
|
-
};
|
|
12
|
-
this.getPersistedData = async () => {
|
|
13
|
-
return new Uint8Array();
|
|
14
|
-
};
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
_a = NoopBackend;
|
|
18
|
-
NoopBackend.load = async (options) => {
|
|
19
|
-
return new _a(options.otelTracer ?? makeNoopTracer());
|
|
20
|
-
};
|
|
21
|
-
//# sourceMappingURL=noop.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"noop.js","sourceRoot":"","sources":["../../src/backends/noop.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAIjD,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AASvC,MAAM,OAAO,WAAY,SAAQ,WAAW;IAC1C,YAAqB,UAAuB;QAC1C,KAAK,EAAE,CAAA;QADY,eAAU,GAAV,UAAU,CAAa;QAQ5C,YAAO,GAAG,CAAC,MAAc,EAAE,WAA0B,EAAQ,EAAE,GAAE,CAAC,CAAA;QAElE,WAAM,GAAG,KAAK,EAAK,MAAc,EAAE,WAA0B,EAA8B,EAAE;YAC3F,OAAO,EAAE,OAAO,EAAE,EAAE,EAAE,CAAA;QACxB,CAAC,CAAA;QAED,qBAAgB,GAAG,KAAK,IAAyB,EAAE;YACjD,OAAO,IAAI,UAAU,EAAE,CAAA;QACzB,CAAC,CAAA;IAdD,CAAC;;;AAEM,gBAAI,GAAG,KAAK,EAAE,OAA2B,EAAwB,EAAE;IACxE,OAAO,IAAI,EAAW,CAAC,OAAO,CAAC,UAAU,IAAI,cAAc,EAAE,CAAC,CAAA;AAChE,CAAC,AAFU,CAEV"}
|
package/dist/backends/tauri.d.ts
DELETED
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import type * as otel from '@opentelemetry/api';
|
|
2
|
-
import type { ParamsObject } from '../util.js';
|
|
3
|
-
import { BaseBackend } from './base.js';
|
|
4
|
-
import type { BackendOtelProps, SelectResponse } from './index.js';
|
|
5
|
-
export type BackendOptionsTauri = {
|
|
6
|
-
type: 'tauri';
|
|
7
|
-
dbDirPath: string;
|
|
8
|
-
appDbFileName: string;
|
|
9
|
-
};
|
|
10
|
-
export declare class TauriBackend extends BaseBackend {
|
|
11
|
-
readonly dbFilePath: string;
|
|
12
|
-
readonly dbDirPath: string;
|
|
13
|
-
readonly otelTracer: otel.Tracer;
|
|
14
|
-
readonly parentSpan: otel.Span;
|
|
15
|
-
constructor(dbFilePath: string, dbDirPath: string, otelTracer: otel.Tracer, parentSpan: otel.Span);
|
|
16
|
-
static load: ({ dbDirPath, appDbFileName }: BackendOptionsTauri, { otelTracer, parentSpan }: BackendOtelProps) => Promise<TauriBackend>;
|
|
17
|
-
execute: (query: string, bindValues?: ParamsObject, parentSpan?: otel.Span) => void;
|
|
18
|
-
select: <T>(query: string, bindValues?: ParamsObject, parentSpan?: otel.Span) => Promise<SelectResponse<T>>;
|
|
19
|
-
getPersistedData: (parentSpan?: otel.Span) => Promise<Uint8Array>;
|
|
20
|
-
private getOtelData;
|
|
21
|
-
}
|
|
22
|
-
//# sourceMappingURL=tauri.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"tauri.d.ts","sourceRoot":"","sources":["../../src/backends/tauri.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAG/C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAE9C,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,KAAK,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAElE,MAAM,MAAM,mBAAmB,GAAG;IAChC,IAAI,EAAE,OAAO,CAAA;IACb,SAAS,EAAE,MAAM,CAAA;IACjB,aAAa,EAAE,MAAM,CAAA;CACtB,CAAA;AAED,qBAAa,YAAa,SAAQ,WAAW;IAEzC,QAAQ,CAAC,UAAU,EAAE,MAAM;IAC3B,QAAQ,CAAC,SAAS,EAAE,MAAM;IAC1B,QAAQ,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM;IAChC,QAAQ,CAAC,UAAU,EAAE,IAAI,CAAC,IAAI;gBAHrB,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,IAAI,CAAC,MAAM,EACvB,UAAU,EAAE,IAAI,CAAC,IAAI;IAKhC,MAAM,CAAC,IAAI,iCACqB,mBAAmB,8BACrB,gBAAgB,KAC3C,QAAQ,YAAY,CAAC,CAKvB;IAED,OAAO,UAAW,MAAM,eAAe,YAAY,eAAe,KAAK,IAAI,KAAG,IAAI,CAQjF;IAED,MAAM,aAAoB,MAAM,eAAe,YAAY,eAAe,KAAK,IAAI,gCAOlF;IAED,gBAAgB,gBAAuB,KAAK,IAAI,KAAG,QAAQ,UAAU,CAAC,CAOrE;IAED,OAAO,CAAC,WAAW,CAA2E;CAC/F"}
|
package/dist/backends/tauri.js
DELETED
|
@@ -1,48 +0,0 @@
|
|
|
1
|
-
var _a;
|
|
2
|
-
import { getTraceParentHeader } from '@livestore/utils';
|
|
3
|
-
import { invoke } from '@tauri-apps/api';
|
|
4
|
-
import { prepareBindValues } from '../util.js';
|
|
5
|
-
import { BaseBackend } from './base.js';
|
|
6
|
-
export class TauriBackend extends BaseBackend {
|
|
7
|
-
constructor(dbFilePath, dbDirPath, otelTracer, parentSpan) {
|
|
8
|
-
super();
|
|
9
|
-
this.dbFilePath = dbFilePath;
|
|
10
|
-
this.dbDirPath = dbDirPath;
|
|
11
|
-
this.otelTracer = otelTracer;
|
|
12
|
-
this.parentSpan = parentSpan;
|
|
13
|
-
this.execute = (query, bindValues, parentSpan) => {
|
|
14
|
-
// console.log({ query, bindValues, prepared: prepareBindValues(bindValues ?? {}, query) })
|
|
15
|
-
void invoke('execute', {
|
|
16
|
-
dbName: this.dbFilePath,
|
|
17
|
-
query,
|
|
18
|
-
values: prepareBindValues(bindValues ?? {}, query),
|
|
19
|
-
otelData: this.getOtelData(parentSpan),
|
|
20
|
-
});
|
|
21
|
-
};
|
|
22
|
-
this.select = async (query, bindValues, parentSpan) => {
|
|
23
|
-
return invoke('select', {
|
|
24
|
-
db: this.dbFilePath,
|
|
25
|
-
query,
|
|
26
|
-
values: bindValues ?? {},
|
|
27
|
-
otelData: this.getOtelData(parentSpan),
|
|
28
|
-
});
|
|
29
|
-
};
|
|
30
|
-
this.getPersistedData = async (parentSpan) => {
|
|
31
|
-
const headers = new Headers();
|
|
32
|
-
headers.set('traceparent', getTraceParentHeader(parentSpan ?? this.parentSpan));
|
|
33
|
-
return fetch(`http://localhost:38787/get-persisted-data?file_path=${this.dbFilePath}`, { headers }).then((response) => response.arrayBuffer().then((buffer) => new Uint8Array(buffer)));
|
|
34
|
-
};
|
|
35
|
-
this.getOtelData = (parentSpan) => getOtelData_(parentSpan ?? this.parentSpan);
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
_a = TauriBackend;
|
|
39
|
-
TauriBackend.load = async ({ dbDirPath, appDbFileName }, { otelTracer, parentSpan }) => {
|
|
40
|
-
const dbFilePath = `${dbDirPath}/${appDbFileName}`;
|
|
41
|
-
await invoke('initialize_connection', { dbName: dbFilePath, otelData: getOtelData_(parentSpan) });
|
|
42
|
-
return new _a(dbFilePath, dbDirPath, otelTracer, parentSpan);
|
|
43
|
-
};
|
|
44
|
-
const getOtelData_ = (parentSpan) => {
|
|
45
|
-
const spanContext = parentSpan?.spanContext();
|
|
46
|
-
return spanContext ? { trace_id: spanContext.traceId, span_id: spanContext.spanId } : undefined;
|
|
47
|
-
};
|
|
48
|
-
//# sourceMappingURL=tauri.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"tauri.js","sourceRoot":"","sources":["../../src/backends/tauri.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAA;AAEvD,OAAO,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAA;AAGxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AASvC,MAAM,OAAO,YAAa,SAAQ,WAAW;IAC3C,YACW,UAAkB,EAClB,SAAiB,EACjB,UAAuB,EACvB,UAAqB;QAE9B,KAAK,EAAE,CAAA;QALE,eAAU,GAAV,UAAU,CAAQ;QAClB,cAAS,GAAT,SAAS,CAAQ;QACjB,eAAU,GAAV,UAAU,CAAa;QACvB,eAAU,GAAV,UAAU,CAAW;QAehC,YAAO,GAAG,CAAC,KAAa,EAAE,UAAyB,EAAE,UAAsB,EAAQ,EAAE;YACnF,2FAA2F;YAC3F,KAAK,MAAM,CAAC,SAAS,EAAE;gBACrB,MAAM,EAAE,IAAI,CAAC,UAAU;gBACvB,KAAK;gBACL,MAAM,EAAE,iBAAiB,CAAC,UAAU,IAAI,EAAE,EAAE,KAAK,CAAC;gBAClD,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;aACvC,CAAC,CAAA;QACJ,CAAC,CAAA;QAED,WAAM,GAAG,KAAK,EAAK,KAAa,EAAE,UAAyB,EAAE,UAAsB,EAA8B,EAAE;YACjH,OAAO,MAAM,CAAC,QAAQ,EAAE;gBACtB,EAAE,EAAE,IAAI,CAAC,UAAU;gBACnB,KAAK;gBACL,MAAM,EAAE,UAAU,IAAI,EAAE;gBACxB,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC;aACvC,CAAC,CAAA;QACJ,CAAC,CAAA;QAED,qBAAgB,GAAG,KAAK,EAAE,UAAsB,EAAuB,EAAE;YACvE,MAAM,OAAO,GAAG,IAAI,OAAO,EAAE,CAAA;YAC7B,OAAO,CAAC,GAAG,CAAC,aAAa,EAAE,oBAAoB,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAA;YAE/E,OAAO,KAAK,CAAC,uDAAuD,IAAI,CAAC,UAAU,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC,IAAI,CACtG,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,IAAI,UAAU,CAAC,MAAM,CAAC,CAAC,CAC9E,CAAA;QACH,CAAC,CAAA;QAEO,gBAAW,GAAG,CAAC,UAAsB,EAAE,EAAE,CAAC,YAAY,CAAC,UAAU,IAAI,IAAI,CAAC,UAAU,CAAE,CAAA;IAxC9F,CAAC;;;AAEM,iBAAI,GAAG,KAAK,EACjB,EAAE,SAAS,EAAE,aAAa,EAAuB,EACjD,EAAE,UAAU,EAAE,UAAU,EAAoB,EACrB,EAAE;IACzB,MAAM,UAAU,GAAG,GAAG,SAAS,IAAI,aAAa,EAAE,CAAA;IAClD,MAAM,MAAM,CAAC,uBAAuB,EAAE,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,YAAY,CAAC,UAAU,CAAC,EAAE,CAAC,CAAA;IAEjG,OAAO,IAAI,EAAY,CAAC,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,UAAU,CAAC,CAAA;AACxE,CAAC,AARU,CAQV;AAiCH,MAAM,YAAY,GAAG,CAAC,UAAiC,EAAE,EAAE;IACzD,MAAM,WAAW,GAAG,UAAU,EAAE,WAAW,EAAE,CAAA;IAC7C,OAAO,WAAW,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,WAAW,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,SAAS,CAAA;AACjG,CAAC,CAAA"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
export declare class IDB {
|
|
2
|
-
private dbName;
|
|
3
|
-
private storeName;
|
|
4
|
-
private db;
|
|
5
|
-
constructor(dbName: string, storeName?: string);
|
|
6
|
-
private open;
|
|
7
|
-
get(key: string): Promise<Uint8Array | undefined>;
|
|
8
|
-
put(key: string, value: Uint8Array): Promise<void>;
|
|
9
|
-
}
|
|
10
|
-
//# sourceMappingURL=idb.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"idb.d.ts","sourceRoot":"","sources":["../../../src/backends/utils/idb.ts"],"names":[],"mappings":"AAGA,qBAAa,GAAG;IAIZ,OAAO,CAAC,MAAM;IACd,OAAO,CAAC,SAAS;IAJnB,OAAO,CAAC,EAAE,CAA2B;gBAG3B,MAAM,EAAE,MAAM,EACd,SAAS,GAAE,MAAuB;YAG9B,IAAI;IAwBL,GAAG,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,SAAS,CAAC;IAkBjD,GAAG,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;CAiBhE"}
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
/* eslint-disable unicorn/prefer-add-event-listener */
|
|
2
|
-
/* eslint-disable prefer-arrow/prefer-arrow-functions */
|
|
3
|
-
export class IDB {
|
|
4
|
-
constructor(dbName, storeName = 'binary_store') {
|
|
5
|
-
this.dbName = dbName;
|
|
6
|
-
this.storeName = storeName;
|
|
7
|
-
this.db = null;
|
|
8
|
-
}
|
|
9
|
-
async open() {
|
|
10
|
-
if (this.db)
|
|
11
|
-
return this.db;
|
|
12
|
-
return new Promise((resolve, reject) => {
|
|
13
|
-
const openRequest = indexedDB.open(this.dbName, 1);
|
|
14
|
-
openRequest.onupgradeneeded = () => {
|
|
15
|
-
const db = openRequest.result;
|
|
16
|
-
if (!db.objectStoreNames.contains(this.storeName)) {
|
|
17
|
-
db.createObjectStore(this.storeName);
|
|
18
|
-
}
|
|
19
|
-
};
|
|
20
|
-
openRequest.onsuccess = () => {
|
|
21
|
-
this.db = openRequest.result;
|
|
22
|
-
resolve(this.db);
|
|
23
|
-
};
|
|
24
|
-
openRequest.onerror = () => {
|
|
25
|
-
reject(new Error('Failed to open database.'));
|
|
26
|
-
};
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
async get(key) {
|
|
30
|
-
const db = await this.open();
|
|
31
|
-
return new Promise((resolve, reject) => {
|
|
32
|
-
const transaction = db.transaction(this.storeName, 'readonly');
|
|
33
|
-
const store = transaction.objectStore(this.storeName);
|
|
34
|
-
const getRequest = store.get(key);
|
|
35
|
-
getRequest.onsuccess = () => {
|
|
36
|
-
resolve(getRequest.result);
|
|
37
|
-
};
|
|
38
|
-
getRequest.onerror = () => {
|
|
39
|
-
reject(new Error('Failed to get data.'));
|
|
40
|
-
};
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
async put(key, value) {
|
|
44
|
-
const db = await this.open();
|
|
45
|
-
return new Promise((resolve, reject) => {
|
|
46
|
-
const transaction = db.transaction(this.storeName, 'readwrite');
|
|
47
|
-
const store = transaction.objectStore(this.storeName);
|
|
48
|
-
const putRequest = store.put(value, key);
|
|
49
|
-
putRequest.onsuccess = () => {
|
|
50
|
-
resolve();
|
|
51
|
-
};
|
|
52
|
-
putRequest.onerror = () => {
|
|
53
|
-
reject(new Error('Failed to write data.'));
|
|
54
|
-
};
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
//# sourceMappingURL=idb.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"idb.js","sourceRoot":"","sources":["../../../src/backends/utils/idb.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import type * as otel from '@opentelemetry/api';
|
|
2
|
-
import type * as SqliteWasm from 'sqlite-esm';
|
|
3
|
-
import type { ParamsObject } from '../util.js';
|
|
4
|
-
import { BaseBackend } from './base.js';
|
|
5
|
-
import type { BackendOtelProps, SelectResponse } from './index.js';
|
|
6
|
-
export type BackendOptionsWebInMemory = {
|
|
7
|
-
type: 'web-in-memory';
|
|
8
|
-
};
|
|
9
|
-
declare type DatabaseWithCAPI = SqliteWasm.Database & {
|
|
10
|
-
capi: SqliteWasm.CAPI;
|
|
11
|
-
};
|
|
12
|
-
export declare class WebInMemoryBackend extends BaseBackend {
|
|
13
|
-
readonly otelTracer: otel.Tracer;
|
|
14
|
-
readonly db: DatabaseWithCAPI;
|
|
15
|
-
constructor(otelTracer: otel.Tracer, db: DatabaseWithCAPI);
|
|
16
|
-
static load: (_options: BackendOptionsWebInMemory, { otelTracer }: BackendOtelProps) => Promise<WebInMemoryBackend>;
|
|
17
|
-
execute: (query: string, bindValues?: ParamsObject) => void;
|
|
18
|
-
select: <T>(query: string, bindValues?: ParamsObject) => Promise<SelectResponse<T>>;
|
|
19
|
-
getPersistedData: () => Promise<Uint8Array>;
|
|
20
|
-
}
|
|
21
|
-
export {};
|
|
22
|
-
//# sourceMappingURL=web-in-memory.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"web-in-memory.d.ts","sourceRoot":"","sources":["../../src/backends/web-in-memory.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,IAAI,MAAM,oBAAoB,CAAA;AAC/C,OAAO,KAAK,KAAK,UAAU,MAAM,YAAY,CAAA;AAG7C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,YAAY,CAAA;AAE9C,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AACvC,OAAO,KAAK,EAAE,gBAAgB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAA;AAElE,MAAM,MAAM,yBAAyB,GAAG;IACtC,IAAI,EAAE,eAAe,CAAA;CACtB,CAAA;AAED,OAAO,MAAM,gBAAgB,GAAG,UAAU,CAAC,QAAQ,GAAG;IAAE,IAAI,EAAE,UAAU,CAAC,IAAI,CAAA;CAAE,CAAA;AAG/E,qBAAa,kBAAmB,SAAQ,WAAW;IAE/C,QAAQ,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM;IAChC,QAAQ,CAAC,EAAE,EAAE,gBAAgB;gBADpB,UAAU,EAAE,IAAI,CAAC,MAAM,EACvB,EAAE,EAAE,gBAAgB;IAK/B,MAAM,CAAC,IAAI,aACC,yBAAyB,kBACnB,gBAAgB,KAC/B,QAAQ,kBAAkB,CAAC,CAS7B;IAED,OAAO,UAAW,MAAM,eAAe,YAAY,KAAG,IAAI,CAOzD;IAED,MAAM,aAAoB,MAAM,eAAe,YAAY,gCAY1D;IAED,gBAAgB,QAAa,QAAQ,UAAU,CAAC,CAE/C;CACF"}
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
var _a;
|
|
2
|
-
import sqlite3InitModule from 'sqlite-esm';
|
|
3
|
-
import { prepareBindValues } from '../util.js';
|
|
4
|
-
import { BaseBackend } from './base.js';
|
|
5
|
-
// NOTE: This backend is currently only used for testing
|
|
6
|
-
export class WebInMemoryBackend extends BaseBackend {
|
|
7
|
-
constructor(otelTracer, db) {
|
|
8
|
-
super();
|
|
9
|
-
this.otelTracer = otelTracer;
|
|
10
|
-
this.db = db;
|
|
11
|
-
this.execute = (query, bindValues) => {
|
|
12
|
-
this.db.exec({
|
|
13
|
-
sql: query,
|
|
14
|
-
bind: prepareBindValues(bindValues ?? {}, query),
|
|
15
|
-
returnValue: 'resultRows',
|
|
16
|
-
rowMode: 'object',
|
|
17
|
-
});
|
|
18
|
-
};
|
|
19
|
-
this.select = async (query, bindValues) => {
|
|
20
|
-
const resultRows = [];
|
|
21
|
-
this.db.exec({
|
|
22
|
-
sql: query,
|
|
23
|
-
bind: prepareBindValues(bindValues ?? {}, query),
|
|
24
|
-
rowMode: 'object',
|
|
25
|
-
resultRows,
|
|
26
|
-
// callback: (row: any) => console.log('select result', db.filename, query, row),
|
|
27
|
-
});
|
|
28
|
-
return { results: resultRows };
|
|
29
|
-
};
|
|
30
|
-
this.getPersistedData = async () => {
|
|
31
|
-
return this.db.capi.sqlite3_js_db_export(this.db.pointer);
|
|
32
|
-
};
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
_a = WebInMemoryBackend;
|
|
36
|
-
WebInMemoryBackend.load = async (_options, { otelTracer }) => {
|
|
37
|
-
const sqlite3 = await sqlite3InitModule({
|
|
38
|
-
print: (message) => console.log(`[sql-client] ${message}`),
|
|
39
|
-
printErr: (message) => console.error(`[sql-client] ${message}`),
|
|
40
|
-
});
|
|
41
|
-
const db = new sqlite3.oo1.DB({ filename: ':memory:', flags: 'c' });
|
|
42
|
-
db.capi = sqlite3.capi;
|
|
43
|
-
return new _a(otelTracer, db);
|
|
44
|
-
};
|
|
45
|
-
//# sourceMappingURL=web-in-memory.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"web-in-memory.js","sourceRoot":"","sources":["../../src/backends/web-in-memory.ts"],"names":[],"mappings":";AAEA,OAAO,iBAAiB,MAAM,YAAY,CAAA;AAG1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAA;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,WAAW,CAAA;AASvC,wDAAwD;AACxD,MAAM,OAAO,kBAAmB,SAAQ,WAAW;IACjD,YACW,UAAuB,EACvB,EAAoB;QAE7B,KAAK,EAAE,CAAA;QAHE,eAAU,GAAV,UAAU,CAAa;QACvB,OAAE,GAAF,EAAE,CAAkB;QAmB/B,YAAO,GAAG,CAAC,KAAa,EAAE,UAAyB,EAAQ,EAAE;YAC3D,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,KAAK;gBACV,IAAI,EAAE,iBAAiB,CAAC,UAAU,IAAI,EAAE,EAAE,KAAK,CAAS;gBACxD,WAAW,EAAE,YAAY;gBACzB,OAAO,EAAE,QAAQ;aAClB,CAAC,CAAA;QACJ,CAAC,CAAA;QAED,WAAM,GAAG,KAAK,EAAK,KAAa,EAAE,UAAyB,EAA8B,EAAE;YACzF,MAAM,UAAU,GAAQ,EAAE,CAAA;YAE1B,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC;gBACX,GAAG,EAAE,KAAK;gBACV,IAAI,EAAE,iBAAiB,CAAC,UAAU,IAAI,EAAE,EAAE,KAAK,CAAS;gBACxD,OAAO,EAAE,QAAQ;gBACjB,UAAU;gBACV,iFAAiF;aAC1E,CAAC,CAAA;YAEV,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,CAAA;QAChC,CAAC,CAAA;QAED,qBAAgB,GAAG,KAAK,IAAyB,EAAE;YACjD,OAAO,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,OAAO,CAAC,CAAA;QAC3D,CAAC,CAAA;IAzCD,CAAC;;;AAEM,uBAAI,GAAG,KAAK,EACjB,QAAmC,EACnC,EAAE,UAAU,EAAoB,EACH,EAAE;IAC/B,MAAM,OAAO,GAAG,MAAM,iBAAiB,CAAC;QACtC,KAAK,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,gBAAgB,OAAO,EAAE,CAAC;QAC1D,QAAQ,EAAE,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,gBAAgB,OAAO,EAAE,CAAC;KAChE,CAAC,CAAA;IACF,MAAM,EAAE,GAAG,IAAI,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,QAAQ,EAAE,UAAU,EAAE,KAAK,EAAE,GAAG,EAAE,CAAqB,CAAA;IACvF,EAAE,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,CAAA;IAEtB,OAAO,IAAI,EAAkB,CAAC,UAAU,EAAE,EAAE,CAAC,CAAA;AAC/C,CAAC,AAZU,CAYV"}
|
|
@@ -1,17 +0,0 @@
|
|
|
1
|
-
import type { Bindable } from '../util.js';
|
|
2
|
-
import type { SelectResponse, WritableDatabaseLocation } from './index.js';
|
|
3
|
-
type ExecutionQueueItem = {
|
|
4
|
-
query: string;
|
|
5
|
-
bindValues?: Bindable;
|
|
6
|
-
};
|
|
7
|
-
declare const wrappedWorker: {
|
|
8
|
-
initialize: ({ persistentDatabaseLocation }: {
|
|
9
|
-
persistentDatabaseLocation: WritableDatabaseLocation;
|
|
10
|
-
}) => Promise<void>;
|
|
11
|
-
executeBulk: (executionItems: ExecutionQueueItem[]) => void;
|
|
12
|
-
select: <T = any>(query: string, bindValues?: Bindable) => SelectResponse<T>;
|
|
13
|
-
getPersistedData: () => Promise<Uint8Array>;
|
|
14
|
-
};
|
|
15
|
-
export type WrappedWorker = typeof wrappedWorker;
|
|
16
|
-
export {};
|
|
17
|
-
//# sourceMappingURL=web-worker.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"web-worker.d.ts","sourceRoot":"","sources":["../../src/backends/web-worker.ts"],"names":[],"mappings":"AAUA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAA;AAE1C,OAAO,KAAK,EAAE,cAAc,EAAE,wBAAwB,EAAE,MAAM,YAAY,CAAA;AA6E1E,KAAK,kBAAkB,GAAG;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,UAAU,CAAC,EAAE,QAAQ,CAAA;CAAE,CAAA;AA2ElE,QAAA,MAAM,aAAa;;oCA/HqE,wBAAwB;;kCAsD3E,kBAAkB,EAAE,KAAG,IAAI;6BA4ChC,MAAM,eAAe,QAAQ;4BAa1B,QAAQ,UAAU,CAAC;CAgBqB,CAAA;AAE3E,MAAM,MAAM,aAAa,GAAG,OAAO,aAAa,CAAA"}
|
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
// Web Worker file for running SQLite in a web worker.
|
|
2
|
-
// TODO: create types for these libraries? SQL.js already should have types;
|
|
3
|
-
// we just need the types to apply to the fork.
|
|
4
|
-
import { shouldNeverHappen } from '@livestore/utils';
|
|
5
|
-
import * as Comlink from 'comlink';
|
|
6
|
-
import sqlite3InitModule from 'sqlite-esm';
|
|
7
|
-
import { casesHandled, sql } from '../util.js';
|
|
8
|
-
import { IDB } from './utils/idb.js';
|
|
9
|
-
// A global variable to hold the database connection.
|
|
10
|
-
// let db: SqliteWasm.Database
|
|
11
|
-
let db;
|
|
12
|
-
let sqlite3;
|
|
13
|
-
// TODO get rid of this in favour of a "proper" IDB SQLite backend
|
|
14
|
-
let idb;
|
|
15
|
-
/** The location where this database backend persists its data */
|
|
16
|
-
let persistentDatabaseLocation_;
|
|
17
|
-
const configureConnection = () => db.exec(sql `
|
|
18
|
-
PRAGMA page_size=8192;
|
|
19
|
-
PRAGMA journal_mode=MEMORY;
|
|
20
|
-
PRAGMA foreign_keys='ON'; -- we want foreign key constraints to be enforced
|
|
21
|
-
`);
|
|
22
|
-
/** A full virtual filename in the IDB FS */
|
|
23
|
-
const fullyQualifiedFilename = (name) => `${name}.db`;
|
|
24
|
-
const initialize = async ({ persistentDatabaseLocation }) => {
|
|
25
|
-
persistentDatabaseLocation_ = persistentDatabaseLocation;
|
|
26
|
-
sqlite3 = await sqlite3InitModule({
|
|
27
|
-
print: (message) => console.log(`[sql-client] ${message}`),
|
|
28
|
-
printErr: (message) => console.error(`[sql-client] ${message}`),
|
|
29
|
-
});
|
|
30
|
-
switch (persistentDatabaseLocation.type) {
|
|
31
|
-
case 'opfs': {
|
|
32
|
-
try {
|
|
33
|
-
db = new sqlite3.oo1.OpfsDb(fullyQualifiedFilename(persistentDatabaseLocation.virtualFilename)); // , 'c'
|
|
34
|
-
}
|
|
35
|
-
catch (e) {
|
|
36
|
-
debugger;
|
|
37
|
-
}
|
|
38
|
-
break;
|
|
39
|
-
}
|
|
40
|
-
case 'indexeddb': {
|
|
41
|
-
try {
|
|
42
|
-
db = new sqlite3.oo1.DB({ filename: ':memory:', flags: 'c' });
|
|
43
|
-
idb = new IDB(persistentDatabaseLocation.virtualFilename);
|
|
44
|
-
const bytes = await idb.get('db');
|
|
45
|
-
if (bytes !== undefined) {
|
|
46
|
-
// Based on https://sqlite.org/forum/forumpost/2119230da8ac5357a13b731f462dc76e08621a4a29724f7906d5f35bb8508465
|
|
47
|
-
// TODO find cleaner way to do this once possible in sqlite3-wasm
|
|
48
|
-
const p = sqlite3.wasm.allocFromTypedArray(bytes);
|
|
49
|
-
const _rc = sqlite3.capi.sqlite3_deserialize(db.pointer, 'main', p, bytes.length, bytes.length, 0);
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
catch (e) {
|
|
53
|
-
debugger;
|
|
54
|
-
}
|
|
55
|
-
break;
|
|
56
|
-
}
|
|
57
|
-
case 'filesystem': {
|
|
58
|
-
throw new Error('Persisting to native FS is not supported in the web worker backend');
|
|
59
|
-
}
|
|
60
|
-
case 'volatile-in-memory': {
|
|
61
|
-
break;
|
|
62
|
-
}
|
|
63
|
-
default: {
|
|
64
|
-
casesHandled(persistentDatabaseLocation);
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
configureConnection();
|
|
68
|
-
};
|
|
69
|
-
// TODO get rid of this in favour of a "proper" IDB SQLite backend
|
|
70
|
-
let idbPersistTimeout;
|
|
71
|
-
const executeBulk = (executionItems) => {
|
|
72
|
-
let batchItems = [];
|
|
73
|
-
while (executionItems.length > 0) {
|
|
74
|
-
try {
|
|
75
|
-
db.exec('BEGIN TRANSACTION'); // Start the transaction
|
|
76
|
-
batchItems = executionItems.splice(0, 50);
|
|
77
|
-
for (const { query, bindValues } of batchItems) {
|
|
78
|
-
db.exec({
|
|
79
|
-
sql: query,
|
|
80
|
-
bind: bindValues,
|
|
81
|
-
returnValue: 'resultRows',
|
|
82
|
-
rowMode: 'object',
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
db.exec('COMMIT'); // Commit the transaction
|
|
86
|
-
}
|
|
87
|
-
catch (error) {
|
|
88
|
-
try {
|
|
89
|
-
db.exec('ROLLBACK'); // Rollback in case of an error
|
|
90
|
-
}
|
|
91
|
-
catch (e) {
|
|
92
|
-
console.error('Error rolling back transaction', e);
|
|
93
|
-
}
|
|
94
|
-
shouldNeverHappen(`Error executing query: ${error} \n ${JSON.stringify(batchItems)}`);
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
// TODO get rid of this in favour of a "proper" IDB SQLite backend
|
|
98
|
-
if (persistentDatabaseLocation_.type === 'indexeddb') {
|
|
99
|
-
if (idbPersistTimeout !== undefined) {
|
|
100
|
-
clearTimeout(idbPersistTimeout);
|
|
101
|
-
}
|
|
102
|
-
idbPersistTimeout = setTimeout(() => {
|
|
103
|
-
const data = sqlite3.capi.sqlite3_js_db_export(db.pointer);
|
|
104
|
-
void idb.put('db', data);
|
|
105
|
-
}, 1000);
|
|
106
|
-
}
|
|
107
|
-
};
|
|
108
|
-
const select = (query, bindValues) => {
|
|
109
|
-
const resultRows = [];
|
|
110
|
-
db.exec({
|
|
111
|
-
sql: query,
|
|
112
|
-
bind: bindValues,
|
|
113
|
-
rowMode: 'object',
|
|
114
|
-
resultRows,
|
|
115
|
-
});
|
|
116
|
-
return { results: resultRows };
|
|
117
|
-
};
|
|
118
|
-
const getPersistedData = async () => {
|
|
119
|
-
// TODO get rid of this in favour of a "proper" IDB SQLite backend
|
|
120
|
-
if (persistentDatabaseLocation_.type === 'indexeddb') {
|
|
121
|
-
const data = sqlite3.capi.sqlite3_js_db_export(db.pointer);
|
|
122
|
-
return Comlink.transfer(data, [data.buffer]);
|
|
123
|
-
}
|
|
124
|
-
const rootHandle = await navigator.storage.getDirectory();
|
|
125
|
-
const fileHandle = await rootHandle.getFileHandle(db.filename);
|
|
126
|
-
const file = await fileHandle.getFile();
|
|
127
|
-
const buffer = await file.arrayBuffer();
|
|
128
|
-
const data = new Uint8Array(buffer);
|
|
129
|
-
return Comlink.transfer(data, [data.buffer]);
|
|
130
|
-
};
|
|
131
|
-
const wrappedWorker = { initialize, executeBulk, select, getPersistedData };
|
|
132
|
-
Comlink.expose(wrappedWorker);
|
|
133
|
-
// NOTE keep this around for debugging
|
|
134
|
-
// db.exec({
|
|
135
|
-
// sql: `select * from sqlite_master where name = 'library_tracks'`,
|
|
136
|
-
// callback: (_: TODO) => console.log(_),
|
|
137
|
-
// rowMode: 'object',
|
|
138
|
-
// } as TODO)
|
|
139
|
-
//# sourceMappingURL=web-worker.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"web-worker.js","sourceRoot":"","sources":["../../src/backends/web-worker.ts"],"names":[],"mappings":"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"}
|