@livestore/common 0.3.0-dev.33 → 0.3.0-dev.36
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/adapter-types.d.ts +5 -9
- package/dist/adapter-types.d.ts.map +1 -1
- package/dist/adapter-types.js.map +1 -1
- package/dist/devtools/devtools-messages-client-session.d.ts +30 -29
- package/dist/devtools/devtools-messages-client-session.d.ts.map +1 -1
- package/dist/devtools/devtools-messages-client-session.js +1 -0
- package/dist/devtools/devtools-messages-client-session.js.map +1 -1
- package/dist/devtools/devtools-messages-common.d.ts +6 -6
- package/dist/devtools/devtools-messages-leader.d.ts +25 -25
- package/dist/devtools/devtools-messages-leader.js +1 -1
- package/dist/devtools/devtools-messages-leader.js.map +1 -1
- package/dist/devtools/devtools-sessioninfo.d.ts +2 -0
- package/dist/devtools/devtools-sessioninfo.d.ts.map +1 -1
- package/dist/devtools/devtools-sessioninfo.js +1 -0
- package/dist/devtools/devtools-sessioninfo.js.map +1 -1
- package/dist/index.d.ts +3 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/leader-thread/LeaderSyncProcessor.d.ts +4 -4
- package/dist/leader-thread/LeaderSyncProcessor.d.ts.map +1 -1
- package/dist/leader-thread/LeaderSyncProcessor.js +21 -17
- package/dist/leader-thread/LeaderSyncProcessor.js.map +1 -1
- package/dist/leader-thread/apply-event.d.ts +4 -4
- package/dist/leader-thread/apply-event.d.ts.map +1 -1
- package/dist/leader-thread/apply-event.js +9 -9
- package/dist/leader-thread/apply-event.js.map +1 -1
- package/dist/leader-thread/eventlog.d.ts.map +1 -1
- package/dist/leader-thread/eventlog.js +11 -15
- package/dist/leader-thread/eventlog.js.map +1 -1
- package/dist/leader-thread/leader-worker-devtools.d.ts +1 -1
- package/dist/leader-thread/leader-worker-devtools.js +13 -12
- package/dist/leader-thread/leader-worker-devtools.js.map +1 -1
- package/dist/leader-thread/make-leader-thread-layer.d.ts +2 -2
- package/dist/leader-thread/make-leader-thread-layer.d.ts.map +1 -1
- package/dist/leader-thread/make-leader-thread-layer.js +11 -18
- package/dist/leader-thread/make-leader-thread-layer.js.map +1 -1
- package/dist/leader-thread/materialize-event.d.ts +16 -0
- package/dist/leader-thread/materialize-event.d.ts.map +1 -0
- package/dist/leader-thread/materialize-event.js +103 -0
- package/dist/leader-thread/materialize-event.js.map +1 -0
- package/dist/leader-thread/recreate-db.d.ts.map +1 -1
- package/dist/leader-thread/recreate-db.js +9 -17
- package/dist/leader-thread/recreate-db.js.map +1 -1
- package/dist/leader-thread/types.d.ts +5 -5
- package/dist/leader-thread/types.d.ts.map +1 -1
- package/dist/materializer-helper.d.ts.map +1 -1
- package/dist/materializer-helper.js +1 -1
- package/dist/materializer-helper.js.map +1 -1
- package/dist/query-builder/api.d.ts +4 -4
- package/dist/query-builder/api.d.ts.map +1 -1
- package/dist/query-builder/impl.d.ts +2 -2
- package/dist/query-builder/impl.test.d.ts +5 -5
- package/dist/query-builder/mod.d.ts +2 -2
- package/dist/rehydrate-from-eventlog.d.ts +1 -1
- package/dist/rehydrate-from-eventlog.d.ts.map +1 -1
- package/dist/rehydrate-from-eventlog.js +6 -7
- package/dist/rehydrate-from-eventlog.js.map +1 -1
- package/dist/rematerialize-from-eventlog.d.ts +14 -0
- package/dist/rematerialize-from-eventlog.d.ts.map +1 -0
- package/dist/rematerialize-from-eventlog.js +64 -0
- package/dist/rematerialize-from-eventlog.js.map +1 -0
- package/dist/schema/EventDef.d.ts +3 -3
- package/dist/schema/EventDef.d.ts.map +1 -1
- package/dist/schema/EventId.test.js +1 -1
- package/dist/schema/EventId.test.js.map +1 -1
- package/dist/schema/client-document-def.d.ts +2 -2
- package/dist/schema/db-schema/dsl/mod.d.ts +3 -3
- package/dist/schema/db-schema/mod.d.ts +2 -2
- package/dist/schema/mod.d.ts +4 -4
- package/dist/schema/mod.d.ts.map +1 -1
- package/dist/schema/mod.js +4 -4
- package/dist/schema/mod.js.map +1 -1
- package/dist/schema/schema-helpers.d.ts +1 -1
- package/dist/schema/schema.d.ts +25 -14
- package/dist/schema/schema.d.ts.map +1 -1
- package/dist/schema/schema.js +8 -28
- package/dist/schema/schema.js.map +1 -1
- package/dist/schema/state/mod.d.ts +3 -0
- package/dist/schema/state/mod.d.ts.map +1 -0
- package/dist/schema/state/mod.js +3 -0
- package/dist/schema/state/mod.js.map +1 -0
- package/dist/schema/state/sqlite/client-document-def.d.ts +223 -0
- package/dist/schema/state/sqlite/client-document-def.d.ts.map +1 -0
- package/dist/schema/state/sqlite/client-document-def.js +170 -0
- package/dist/schema/state/sqlite/client-document-def.js.map +1 -0
- package/dist/schema/state/sqlite/client-document-def.test.d.ts +2 -0
- package/dist/schema/state/sqlite/client-document-def.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/client-document-def.test.js +201 -0
- package/dist/schema/state/sqlite/client-document-def.test.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.d.ts +69 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.js +71 -0
- package/dist/schema/state/sqlite/db-schema/ast/sqlite.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/validate.d.ts +3 -0
- package/dist/schema/state/sqlite/db-schema/ast/validate.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/ast/validate.js +12 -0
- package/dist/schema/state/sqlite/db-schema/ast/validate.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts +90 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js +87 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.d.ts +2 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.js +29 -0
- package/dist/schema/state/sqlite/db-schema/dsl/field-defs.test.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts +90 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.js +41 -0
- package/dist/schema/state/sqlite/db-schema/dsl/mod.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/hash.d.ts +2 -0
- package/dist/schema/state/sqlite/db-schema/hash.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/hash.js +14 -0
- package/dist/schema/state/sqlite/db-schema/hash.js.map +1 -0
- package/dist/schema/state/sqlite/db-schema/mod.d.ts +3 -0
- package/dist/schema/state/sqlite/db-schema/mod.d.ts.map +1 -0
- package/dist/schema/state/sqlite/db-schema/mod.js +3 -0
- package/dist/schema/state/sqlite/db-schema/mod.js.map +1 -0
- package/dist/schema/state/sqlite/mod.d.ts +17 -0
- package/dist/schema/state/sqlite/mod.d.ts.map +1 -0
- package/dist/schema/state/sqlite/mod.js +41 -0
- package/dist/schema/state/sqlite/mod.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/api.d.ts +293 -0
- package/dist/schema/state/sqlite/query-builder/api.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/api.js +6 -0
- package/dist/schema/state/sqlite/query-builder/api.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.d.ts +7 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.js +190 -0
- package/dist/schema/state/sqlite/query-builder/astToSql.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/impl.d.ts +7 -0
- package/dist/schema/state/sqlite/query-builder/impl.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/impl.js +286 -0
- package/dist/schema/state/sqlite/query-builder/impl.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/impl.test.d.ts +87 -0
- package/dist/schema/state/sqlite/query-builder/impl.test.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/impl.test.js +554 -0
- package/dist/schema/state/sqlite/query-builder/impl.test.js.map +1 -0
- package/dist/schema/state/sqlite/query-builder/mod.d.ts +17 -0
- package/dist/schema/state/sqlite/query-builder/mod.d.ts.map +1 -0
- package/dist/schema/state/sqlite/query-builder/mod.js +17 -0
- package/dist/schema/state/sqlite/query-builder/mod.js.map +1 -0
- package/dist/schema/state/sqlite/schema-helpers.d.ts +4 -0
- package/dist/schema/state/sqlite/schema-helpers.d.ts.map +1 -0
- package/dist/schema/state/sqlite/schema-helpers.js +30 -0
- package/dist/schema/state/sqlite/schema-helpers.js.map +1 -0
- package/dist/schema/state/sqlite/sqlite-state.d.ts +12 -0
- package/dist/schema/state/sqlite/sqlite-state.d.ts.map +1 -0
- package/dist/schema/state/sqlite/sqlite-state.js +36 -0
- package/dist/schema/state/sqlite/sqlite-state.js.map +1 -0
- package/dist/schema/state/sqlite/system-tables.d.ts +574 -0
- package/dist/schema/state/sqlite/system-tables.d.ts.map +1 -0
- package/dist/schema/state/sqlite/system-tables.js +87 -0
- package/dist/schema/state/sqlite/system-tables.js.map +1 -0
- package/dist/schema/state/sqlite/table-def.d.ts +84 -0
- package/dist/schema/state/sqlite/table-def.d.ts.map +1 -0
- package/dist/schema/state/sqlite/table-def.js +36 -0
- package/dist/schema/state/sqlite/table-def.js.map +1 -0
- package/dist/schema/state/state.d.ts +3 -0
- package/dist/schema/state/state.d.ts.map +1 -0
- package/dist/schema/state/state.js +3 -0
- package/dist/schema/state/state.js.map +1 -0
- package/dist/schema/state.d.ts +3 -0
- package/dist/schema/state.d.ts.map +1 -0
- package/dist/schema/state.js +3 -0
- package/dist/schema/state.js.map +1 -0
- package/dist/schema/system-tables.d.ts +7 -433
- package/dist/schema/system-tables.d.ts.map +1 -1
- package/dist/schema/system-tables.js +1 -1
- package/dist/schema/system-tables.js.map +1 -1
- package/dist/schema/table-def.d.ts +2 -2
- package/dist/schema-management/migrations.d.ts +1 -1
- package/dist/schema-management/migrations.d.ts.map +1 -1
- package/dist/schema-management/migrations.js +14 -12
- package/dist/schema-management/migrations.js.map +1 -1
- package/dist/schema-management/validate-schema.d.ts +8 -0
- package/dist/schema-management/validate-schema.d.ts.map +1 -0
- package/dist/schema-management/validate-schema.js +39 -0
- package/dist/schema-management/validate-schema.js.map +1 -0
- package/dist/sql-queries/sql-queries.d.ts +1 -1
- package/dist/sql-queries/sql-queries.d.ts.map +1 -1
- package/dist/sql-queries/sql-query-builder.d.ts +1 -1
- package/dist/sql-queries/sql-query-builder.d.ts.map +1 -1
- package/dist/sql-queries/types.d.ts +1 -1
- package/dist/sql-queries/types.d.ts.map +1 -1
- package/dist/sync/ClientSessionSyncProcessor.d.ts +3 -3
- package/dist/sync/ClientSessionSyncProcessor.d.ts.map +1 -1
- package/dist/sync/ClientSessionSyncProcessor.js +6 -6
- package/dist/sync/ClientSessionSyncProcessor.js.map +1 -1
- package/dist/sync/next/test/event-fixtures.d.ts +7 -7
- package/dist/sync/syncstate.d.ts +4 -4
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/package.json +9 -3
- package/src/adapter-types.ts +4 -10
- package/src/devtools/devtools-messages-client-session.ts +1 -0
- package/src/devtools/devtools-messages-leader.ts +1 -1
- package/src/devtools/devtools-sessioninfo.ts +1 -0
- package/src/index.ts +3 -3
- package/src/leader-thread/LeaderSyncProcessor.ts +28 -30
- package/src/leader-thread/eventlog.ts +12 -17
- package/src/leader-thread/leader-worker-devtools.ts +15 -12
- package/src/leader-thread/make-leader-thread-layer.ts +15 -21
- package/src/leader-thread/{apply-event.ts → materialize-event.ts} +22 -28
- package/src/leader-thread/recreate-db.ts +9 -21
- package/src/leader-thread/types.ts +5 -5
- package/src/materializer-helper.ts +1 -1
- package/src/{rehydrate-from-eventlog.ts → rematerialize-from-eventlog.ts} +41 -38
- package/src/schema/EventDef.ts +1 -1
- package/src/schema/EventId.test.ts +1 -1
- package/src/schema/mod.ts +4 -4
- package/src/schema/schema.ts +34 -52
- package/src/schema/state/mod.ts +2 -0
- package/src/schema/{client-document-def.test.ts → state/sqlite/client-document-def.test.ts} +2 -2
- package/src/schema/{client-document-def.ts → state/sqlite/client-document-def.ts} +6 -6
- package/src/schema/{sqlite-state.ts → state/sqlite/mod.ts} +17 -6
- package/src/{query-builder → schema/state/sqlite/query-builder}/api.ts +21 -22
- package/src/{query-builder → schema/state/sqlite/query-builder}/astToSql.ts +3 -3
- package/src/{query-builder → schema/state/sqlite/query-builder}/impl.test.ts +1 -1
- package/src/{query-builder → schema/state/sqlite/query-builder}/impl.ts +3 -4
- package/src/schema/{schema-helpers.ts → state/sqlite/schema-helpers.ts} +1 -1
- package/src/schema/{system-tables.ts → state/sqlite/system-tables.ts} +6 -5
- package/src/schema/{table-def.ts → state/sqlite/table-def.ts} +2 -2
- package/src/schema-management/migrations.ts +17 -15
- package/src/sql-queries/sql-queries.ts +1 -1
- package/src/sql-queries/sql-query-builder.ts +1 -1
- package/src/sql-queries/types.ts +1 -1
- package/src/sync/ClientSessionSyncProcessor.ts +7 -7
- package/src/version.ts +1 -1
- package/src/schema/view.ts +0 -2
- package/tmp/pack.tgz +0 -0
- package/tsconfig.json +0 -12
- /package/src/schema/{db-schema → state/sqlite/db-schema}/ast/sqlite.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/ast/validate.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/dsl/__snapshots__/field-defs.test.ts.snap +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/dsl/field-defs.test.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/dsl/field-defs.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/dsl/mod.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/hash.ts +0 -0
- /package/src/schema/{db-schema → state/sqlite/db-schema}/mod.ts +0 -0
- /package/src/{query-builder → schema/state/sqlite/query-builder}/mod.ts +0 -0
- /package/src/schema-management/{validate-mutation-defs.ts → validate-schema.ts} +0 -0
@@ -2,12 +2,12 @@ import { Effect } from '@livestore/utils/effect';
|
|
2
2
|
import type { SqliteDb } from '../adapter-types.js';
|
3
3
|
import type { LiveStoreSchema } from '../schema/mod.js';
|
4
4
|
import { EventId } from '../schema/mod.js';
|
5
|
-
import type {
|
6
|
-
export declare const
|
5
|
+
import type { MaterializeEvent } from './types.js';
|
6
|
+
export declare const makeMaterializeEvent: ({ schema, dbState: db, dbEventlog, }: {
|
7
7
|
schema: LiveStoreSchema;
|
8
|
-
|
8
|
+
dbState: SqliteDb;
|
9
9
|
dbEventlog: SqliteDb;
|
10
|
-
}) => Effect.Effect<
|
10
|
+
}) => Effect.Effect<MaterializeEvent, never>;
|
11
11
|
export declare const rollback: ({ db, dbEventlog, eventIdsToRollback, }: {
|
12
12
|
db: SqliteDb;
|
13
13
|
dbEventlog: SqliteDb;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"apply-event.d.ts","sourceRoot":"","sources":["../../src/leader-thread/apply-event.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAyB,MAAM,yBAAyB,CAAA;AAEvE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAEnD,OAAO,KAAK,EAAE,eAAe,
|
1
|
+
{"version":3,"file":"apply-event.d.ts","sourceRoot":"","sources":["../../src/leader-thread/apply-event.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAyB,MAAM,yBAAyB,CAAA;AAEvE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAEnD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AACvD,OAAO,EAAE,OAAO,EAA6B,MAAM,kBAAkB,CAAA;AAKrE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AAElD,eAAO,MAAM,oBAAoB,GAAI,sCAIlC;IACD,MAAM,EAAE,eAAe,CAAA;IACvB,OAAO,EAAE,QAAQ,CAAA;IACjB,UAAU,EAAE,QAAQ,CAAA;CACrB,KAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,EAAE,KAAK,CAiGrC,CAAA;AAEJ,eAAO,MAAM,QAAQ,GAAI,yCAItB;IACD,EAAE,EAAE,QAAQ,CAAA;IACZ,UAAU,EAAE,QAAQ,CAAA;IACpB,kBAAkB,EAAE,OAAO,CAAC,OAAO,EAAE,CAAA;CACtC,sCAsCE,CAAA"}
|
@@ -1,12 +1,12 @@
|
|
1
1
|
import { LS_DEV, shouldNeverHappen } from '@livestore/utils';
|
2
2
|
import { Effect, ReadonlyArray, Schema } from '@livestore/utils/effect';
|
3
3
|
import { getExecArgsFromEvent } from '../materializer-helper.js';
|
4
|
-
import { EventId,
|
4
|
+
import { EventId, getEventDef, SystemTables } from '../schema/mod.js';
|
5
5
|
import { insertRow } from '../sql-queries/index.js';
|
6
6
|
import { sql } from '../util.js';
|
7
7
|
import { execSql, execSqlPrepared } from './connection.js';
|
8
8
|
import * as Eventlog from './eventlog.js';
|
9
|
-
export const
|
9
|
+
export const makeMaterializeEvent = ({ schema, dbState: db, dbEventlog, }) => Effect.gen(function* () {
|
10
10
|
const eventDefSchemaHashMap = new Map(
|
11
11
|
// TODO Running `Schema.hash` can be a bottleneck for larger schemas. There is an opportunity to run this
|
12
12
|
// at build time and lookup the pre-computed hash at runtime.
|
@@ -28,7 +28,7 @@ export const makeApplyEvent = ({ schema, dbReadModel: db, dbEventlog, }) => Effe
|
|
28
28
|
// }
|
29
29
|
// },
|
30
30
|
// })
|
31
|
-
// console.group('[@livestore/common:leader-thread:
|
31
|
+
// console.group('[@livestore/common:leader-thread:materializeEvent]', { eventName })
|
32
32
|
const session = db.session();
|
33
33
|
for (const { statementSql, bindValues } of execArgsArr) {
|
34
34
|
// console.debug(eventName, statementSql, bindValues)
|
@@ -39,8 +39,8 @@ export const makeApplyEvent = ({ schema, dbReadModel: db, dbEventlog, }) => Effe
|
|
39
39
|
session.finish();
|
40
40
|
// TODO use prepared statements
|
41
41
|
yield* execSql(db, ...insertRow({
|
42
|
-
tableName: SESSION_CHANGESET_META_TABLE,
|
43
|
-
columns: sessionChangesetMetaTable.sqliteDef.columns,
|
42
|
+
tableName: SystemTables.SESSION_CHANGESET_META_TABLE,
|
43
|
+
columns: SystemTables.sessionChangesetMetaTable.sqliteDef.columns,
|
44
44
|
values: {
|
45
45
|
idGlobal: eventEncoded.id.global,
|
46
46
|
idClient: eventEncoded.id.client,
|
@@ -68,7 +68,7 @@ export const makeApplyEvent = ({ schema, dbReadModel: db, dbEventlog, }) => Effe
|
|
68
68
|
}
|
69
69
|
: { _tag: 'no-op' },
|
70
70
|
};
|
71
|
-
}).pipe(Effect.withSpan(`@livestore/common:leader-thread:
|
71
|
+
}).pipe(Effect.withSpan(`@livestore/common:leader-thread:materializeEvent`, {
|
72
72
|
attributes: {
|
73
73
|
eventName: eventEncoded.name,
|
74
74
|
mutationId: eventEncoded.id,
|
@@ -78,7 +78,7 @@ export const makeApplyEvent = ({ schema, dbReadModel: db, dbEventlog, }) => Effe
|
|
78
78
|
});
|
79
79
|
export const rollback = ({ db, dbEventlog, eventIdsToRollback, }) => Effect.gen(function* () {
|
80
80
|
const rollbackEvents = db
|
81
|
-
.select(sql `SELECT * FROM ${SESSION_CHANGESET_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdsToRollback.map((id) => `(${id.global}, ${id.client})`).join(', ')})`)
|
81
|
+
.select(sql `SELECT * FROM ${SystemTables.SESSION_CHANGESET_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdsToRollback.map((id) => `(${id.global}, ${id.client})`).join(', ')})`)
|
82
82
|
.map((_) => ({ id: { global: _.idGlobal, client: _.idClient }, changeset: _.changeset, debug: _.debug }))
|
83
83
|
.toSorted((a, b) => EventId.compare(a.id, b.id));
|
84
84
|
// Apply changesets in reverse order
|
@@ -91,11 +91,11 @@ export const rollback = ({ db, dbEventlog, eventIdsToRollback, }) => Effect.gen(
|
|
91
91
|
const eventIdPairChunks = ReadonlyArray.chunksOf(100)(eventIdsToRollback.map((id) => `(${id.global}, ${id.client})`));
|
92
92
|
// Delete the changeset rows
|
93
93
|
for (const eventIdPairChunk of eventIdPairChunks) {
|
94
|
-
db.execute(sql `DELETE FROM ${SESSION_CHANGESET_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdPairChunk.join(', ')})`);
|
94
|
+
db.execute(sql `DELETE FROM ${SystemTables.SESSION_CHANGESET_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdPairChunk.join(', ')})`);
|
95
95
|
}
|
96
96
|
// Delete the eventlog rows
|
97
97
|
for (const eventIdPairChunk of eventIdPairChunks) {
|
98
|
-
dbEventlog.execute(sql `DELETE FROM ${EVENTLOG_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdPairChunk.join(', ')})`);
|
98
|
+
dbEventlog.execute(sql `DELETE FROM ${SystemTables.EVENTLOG_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdPairChunk.join(', ')})`);
|
99
99
|
}
|
100
100
|
}).pipe(Effect.withSpan('@livestore/common:LeaderSyncProcessor:rollback', {
|
101
101
|
attributes: { count: eventIdsToRollback.length },
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"apply-event.js","sourceRoot":"","sources":["../../src/leader-thread/apply-event.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAGvE,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAA;AAEhE,OAAO,
|
1
|
+
{"version":3,"file":"apply-event.js","sourceRoot":"","sources":["../../src/leader-thread/apply-event.ts"],"names":[],"mappings":"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"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"eventlog.d.ts","sourceRoot":"","sources":["../../src/leader-thread/eventlog.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAEhE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAA;AAC/C,OAAO,KAAK,cAAc,MAAM,6BAA6B,CAAA;AAc7D,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE5C,eAAO,MAAM,cAAc,GAAI,YAAY,QAAQ,
|
1
|
+
{"version":3,"file":"eventlog.d.ts","sourceRoot":"","sources":["../../src/leader-thread/eventlog.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAEhE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AACnD,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAA;AAC/C,OAAO,KAAK,cAAc,MAAM,6BAA6B,CAAA;AAc7D,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE5C,eAAO,MAAM,cAAc,GAAI,YAAY,QAAQ,0EAmB/C,CAAA;AAEJ,qCAAqC;AACrC,eAAO,MAAM,cAAc,GACzB,OAAO,OAAO,CAAC,OAAO,KACrB,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,cAAc,CAAC,eAAe,CAAC,EAAE,KAAK,EAAE,eAAe,CA6ClF,CAAA;AAEJ,eAAO,MAAM,mBAAmB,GAAI,YAAY,QAAQ,KAAG,OAAO,CAAC,OAMlE,CAAA;AAED,eAAO,MAAM,oBAAoB,GAAI,YAAY,QAAQ,KAAG,OAAO,CAAC,aAE/C,CAAA;AAGrB,eAAO,MAAM,iBAAiB,GAAI,YAAY,QAAQ,EAAE,MAAM,OAAO,CAAC,OAAO,SACG,CAAA;AAEhF,eAAO,MAAM,kBAAkB,GAC7B,cAAc,cAAc,CAAC,eAAe,EAC5C,YAAY,QAAQ,EACpB,oBAAoB,MAAM,EAC1B,UAAU,MAAM,EAChB,WAAW,MAAM,0EAsCf,CAAA;AAEJ,eAAO,MAAM,kBAAkB,GAAI,OAAO,aAAa,CAAC,cAAc,CAAC,eAAe,CAAC,oFAkBnF,CAAA;AAEJ,eAAO,MAAM,wBAAwB,GAAI,YAAY,OAAO,CAAC,aAAa;;;;;;;;;;;;2BAoBuC,CAAA"}
|
@@ -2,25 +2,21 @@ import { LS_DEV, shouldNeverHappen } from '@livestore/utils';
|
|
2
2
|
import { Effect, Option, Schema } from '@livestore/utils/effect';
|
3
3
|
import * as EventId from '../schema/EventId.js';
|
4
4
|
import * as LiveStoreEvent from '../schema/LiveStoreEvent.js';
|
5
|
-
import { EVENTLOG_META_TABLE, eventlogMetaTable, sessionChangesetMetaTable, SYNC_STATUS_TABLE,
|
5
|
+
import { EVENTLOG_META_TABLE, eventlogMetaTable, eventlogSystemTables, sessionChangesetMetaTable, SYNC_STATUS_TABLE, } from '../schema/state/sqlite/system-tables.js';
|
6
6
|
import { migrateTable } from '../schema-management/migrations.js';
|
7
7
|
import { insertRow, updateRows } from '../sql-queries/sql-queries.js';
|
8
8
|
import { prepareBindValues, sql } from '../util.js';
|
9
9
|
import { execSql } from './connection.js';
|
10
10
|
import { LeaderThreadCtx } from './types.js';
|
11
11
|
export const initEventlogDb = (dbEventlog) => Effect.gen(function* () {
|
12
|
-
|
13
|
-
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
behaviour: 'create-if-not-exists',
|
21
|
-
tableAst: syncStatusTable.sqliteDef.ast,
|
22
|
-
skipMetaTable: true,
|
23
|
-
});
|
12
|
+
for (const tableDef of eventlogSystemTables) {
|
13
|
+
yield* migrateTable({
|
14
|
+
db: dbEventlog,
|
15
|
+
behaviour: 'create-if-not-exists',
|
16
|
+
tableAst: tableDef.sqliteDef.ast,
|
17
|
+
skipMetaTable: true,
|
18
|
+
});
|
19
|
+
}
|
24
20
|
// Create sync status row if it doesn't exist
|
25
21
|
yield* execSql(dbEventlog, sql `INSERT INTO ${SYNC_STATUS_TABLE} (head)
|
26
22
|
SELECT ${EventId.ROOT.global}
|
@@ -28,12 +24,12 @@ export const initEventlogDb = (dbEventlog) => Effect.gen(function* () {
|
|
28
24
|
});
|
29
25
|
/** Exclusive of the "since event" */
|
30
26
|
export const getEventsSince = (since) => Effect.gen(function* () {
|
31
|
-
const { dbEventlog,
|
27
|
+
const { dbEventlog, dbState } = yield* LeaderThreadCtx;
|
32
28
|
const query = eventlogMetaTable.where('idGlobal', '>=', since.global).asSql();
|
33
29
|
const pendingEventsRaw = dbEventlog.select(query.query, prepareBindValues(query.bindValues, query.query));
|
34
30
|
const pendingEvents = Schema.decodeUnknownSync(eventlogMetaTable.rowSchema.pipe(Schema.Array))(pendingEventsRaw);
|
35
31
|
const sessionChangesetRows = sessionChangesetMetaTable.where('idGlobal', '>=', since.global).asSql();
|
36
|
-
const sessionChangesetRowsRaw =
|
32
|
+
const sessionChangesetRowsRaw = dbState.select(sessionChangesetRows.query, prepareBindValues(sessionChangesetRows.bindValues, sessionChangesetRows.query));
|
37
33
|
const sessionChangesetRowsDecoded = Schema.decodeUnknownSync(sessionChangesetMetaTable.rowSchema.pipe(Schema.Array))(sessionChangesetRowsRaw);
|
38
34
|
return pendingEvents
|
39
35
|
.map((eventlogEvent) => {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"eventlog.js","sourceRoot":"","sources":["../../src/leader-thread/eventlog.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAA;AAC5D,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAGhE,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAA;AAC/C,OAAO,KAAK,cAAc,MAAM,6BAA6B,CAAA;AAC7D,OAAO,EACL,mBAAmB,EACnB,iBAAiB,EACjB,yBAAyB,EACzB,iBAAiB,
|
1
|
+
{"version":3,"file":"eventlog.js","sourceRoot":"","sources":["../../src/leader-thread/eventlog.ts"],"names":[],"mappings":"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"}
|
@@ -2,5 +2,5 @@ import { Effect } from '@livestore/utils/effect';
|
|
2
2
|
import { UnexpectedError } from '../index.js';
|
3
3
|
import type { DevtoolsOptions } from './types.js';
|
4
4
|
import { LeaderThreadCtx } from './types.js';
|
5
|
-
export declare const bootDevtools: (options: DevtoolsOptions) => Effect.Effect<void, UnexpectedError, import("effect/Scope").Scope |
|
5
|
+
export declare const bootDevtools: (options: DevtoolsOptions) => Effect.Effect<void, UnexpectedError, LeaderThreadCtx | import("effect/Scope").Scope | import("@effect/platform/HttpClient").HttpClient>;
|
6
6
|
//# sourceMappingURL=leader-worker-devtools.d.ts.map
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { Effect, FiberMap, Option, Stream, SubscriptionRef } from '@livestore/utils/effect';
|
2
2
|
import { nanoid } from '@livestore/utils/nanoid';
|
3
3
|
import { Devtools, IntentionalShutdownCause, liveStoreVersion, UnexpectedError } from '../index.js';
|
4
|
-
import {
|
4
|
+
import { SystemTables } from '../schema/mod.js';
|
5
5
|
import { LeaderThreadCtx } from './types.js';
|
6
6
|
// TODO bind scope to the webchannel lifetime
|
7
7
|
export const bootDevtools = (options) => Effect.gen(function* () {
|
@@ -27,7 +27,7 @@ export const bootDevtools = (options) => Effect.gen(function* () {
|
|
27
27
|
}).pipe(Effect.tapCauseLogPretty, Effect.forkScoped);
|
28
28
|
}).pipe(Effect.withSpan('@livestore/common:leader-thread:devtools:boot'));
|
29
29
|
const listenToDevtools = ({ incomingMessages, sendMessage, persistenceInfo, }) => Effect.gen(function* () {
|
30
|
-
const { syncBackend, makeSqliteDb,
|
30
|
+
const { syncBackend, makeSqliteDb, dbState, dbEventlog, shutdownStateSubRef, shutdownChannel, syncProcessor, clientId, devtools, } = yield* LeaderThreadCtx;
|
31
31
|
const subscriptionFiberMap = yield* FiberMap.make();
|
32
32
|
const handledRequestIds = new Set();
|
33
33
|
yield* incomingMessages.pipe(Stream.tap((decodedEvent) => Effect.gen(function* () {
|
@@ -55,7 +55,7 @@ const listenToDevtools = ({ incomingMessages, sendMessage, persistenceInfo, }) =
|
|
55
55
|
return;
|
56
56
|
}
|
57
57
|
case 'LSD.Leader.SnapshotReq': {
|
58
|
-
const snapshot =
|
58
|
+
const snapshot = dbState.export();
|
59
59
|
yield* sendMessage(Devtools.Leader.SnapshotRes.make({ snapshot, ...reqPayload }));
|
60
60
|
return;
|
61
61
|
}
|
@@ -78,16 +78,17 @@ const listenToDevtools = ({ incomingMessages, sendMessage, persistenceInfo, }) =
|
|
78
78
|
return;
|
79
79
|
}
|
80
80
|
try {
|
81
|
-
if (tableNames.has(EVENTLOG_META_TABLE)) {
|
82
|
-
// Is eventlog
|
81
|
+
if (tableNames.has(SystemTables.EVENTLOG_META_TABLE)) {
|
82
|
+
// Is eventlog db
|
83
83
|
yield* SubscriptionRef.set(shutdownStateSubRef, 'shutting-down');
|
84
84
|
dbEventlog.import(data);
|
85
|
-
|
85
|
+
dbState.destroy();
|
86
86
|
}
|
87
|
-
else if (tableNames.has(SCHEMA_META_TABLE) &&
|
88
|
-
|
87
|
+
else if (tableNames.has(SystemTables.SCHEMA_META_TABLE) &&
|
88
|
+
tableNames.has(SystemTables.SCHEMA_EVENT_DEFS_META_TABLE)) {
|
89
|
+
// Is state db
|
89
90
|
yield* SubscriptionRef.set(shutdownStateSubRef, 'shutting-down');
|
90
|
-
|
91
|
+
dbState.import(data);
|
91
92
|
dbEventlog.destroy();
|
92
93
|
}
|
93
94
|
else {
|
@@ -113,7 +114,7 @@ const listenToDevtools = ({ incomingMessages, sendMessage, persistenceInfo, }) =
|
|
113
114
|
case 'LSD.Leader.ResetAllData.Request': {
|
114
115
|
const { mode } = decodedEvent;
|
115
116
|
yield* SubscriptionRef.set(shutdownStateSubRef, 'shutting-down');
|
116
|
-
|
117
|
+
dbState.destroy();
|
117
118
|
if (mode === 'all-data') {
|
118
119
|
dbEventlog.destroy();
|
119
120
|
}
|
@@ -127,10 +128,10 @@ const listenToDevtools = ({ incomingMessages, sendMessage, persistenceInfo, }) =
|
|
127
128
|
return;
|
128
129
|
}
|
129
130
|
const dbSizeQuery = `SELECT page_count * page_size as size FROM pragma_page_count(), pragma_page_size();`;
|
130
|
-
const dbFileSize =
|
131
|
+
const dbFileSize = dbState.select(dbSizeQuery, undefined)[0].size;
|
131
132
|
const eventlogFileSize = dbEventlog.select(dbSizeQuery, undefined)[0].size;
|
132
133
|
yield* sendMessage(Devtools.Leader.DatabaseFileInfoRes.make({
|
133
|
-
|
134
|
+
state: { fileSize: dbFileSize, persistenceInfo: persistenceInfo.state },
|
134
135
|
eventlog: { fileSize: eventlogFileSize, persistenceInfo: persistenceInfo.eventlog },
|
135
136
|
...reqPayload,
|
136
137
|
}));
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"leader-worker-devtools.js","sourceRoot":"","sources":["../../src/leader-thread/leader-worker-devtools.ts"],"names":[],"mappings":"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"}
|
1
|
+
{"version":3,"file":"leader-worker-devtools.js","sourceRoot":"","sources":["../../src/leader-thread/leader-worker-devtools.ts"],"names":[],"mappings":"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"}
|
@@ -14,7 +14,7 @@ export interface MakeLeaderThreadLayerParams {
|
|
14
14
|
schema: LiveStoreSchema;
|
15
15
|
makeSqliteDb: MakeSqliteDb;
|
16
16
|
syncOptions: SyncOptions | undefined;
|
17
|
-
|
17
|
+
dbState: LeaderSqliteDb;
|
18
18
|
dbEventlog: LeaderSqliteDb;
|
19
19
|
devtoolsOptions: DevtoolsOptions;
|
20
20
|
shutdownChannel: ShutdownChannel;
|
@@ -30,5 +30,5 @@ export interface MakeLeaderThreadLayerParams {
|
|
30
30
|
};
|
31
31
|
};
|
32
32
|
}
|
33
|
-
export declare const makeLeaderThreadLayer: ({ schema, storeId, clientId, syncPayload, makeSqliteDb, syncOptions,
|
33
|
+
export declare const makeLeaderThreadLayer: ({ schema, storeId, clientId, syncPayload, makeSqliteDb, syncOptions, dbState, dbEventlog, devtoolsOptions, shutdownChannel, params, testing, }: MakeLeaderThreadLayerParams) => Layer.Layer<LeaderThreadCtx, UnexpectedError, Scope.Scope | HttpClient.HttpClient>;
|
34
34
|
//# sourceMappingURL=make-leader-thread-layer.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"make-leader-thread-layer.d.ts","sourceRoot":"","sources":["../../src/leader-thread/make-leader-thread-layer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AACxE,OAAO,EAAY,MAAM,EAAE,KAAK,EAA0B,MAAM,yBAAyB,CAAA;AAEzF,OAAO,KAAK,EAAc,YAAY,
|
1
|
+
{"version":3,"file":"make-leader-thread-layer.d.ts","sourceRoot":"","sources":["../../src/leader-thread/make-leader-thread-layer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AACxE,OAAO,EAAY,MAAM,EAAE,KAAK,EAA0B,MAAM,yBAAyB,CAAA;AAEzF,OAAO,KAAK,EAAc,YAAY,EAAe,MAAM,qBAAqB,CAAA;AAChF,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAErD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAEvD,OAAO,KAAK,EAAoC,WAAW,EAAE,MAAM,iBAAiB,CAAA;AAOpF,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AAC5D,OAAO,KAAK,EACV,eAAe,EAGf,cAAc,EAEf,MAAM,YAAY,CAAA;AACnB,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE5C,MAAM,WAAW,2BAA2B;IAC1C,OAAO,EAAE,MAAM,CAAA;IACf,WAAW,EAAE,MAAM,CAAC,SAAS,GAAG,SAAS,CAAA;IACzC,QAAQ,EAAE,MAAM,CAAA;IAChB,MAAM,EAAE,eAAe,CAAA;IACvB,YAAY,EAAE,YAAY,CAAA;IAC1B,WAAW,EAAE,WAAW,GAAG,SAAS,CAAA;IACpC,OAAO,EAAE,cAAc,CAAA;IACvB,UAAU,EAAE,cAAc,CAAA;IAC1B,eAAe,EAAE,eAAe,CAAA;IAChC,eAAe,EAAE,eAAe,CAAA;IAChC,MAAM,CAAC,EAAE;QACP,kBAAkB,CAAC,EAAE,MAAM,CAAA;QAC3B,oBAAoB,CAAC,EAAE,MAAM,CAAA;KAC9B,CAAA;IACD,OAAO,CAAC,EAAE;QACR,aAAa,CAAC,EAAE;YACd,MAAM,CAAC,EAAE;gBACP,mBAAmB,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;aAC1C,CAAA;SACF,CAAA;KACF,CAAA;CACF;AAED,eAAO,MAAM,qBAAqB,GAAI,gJAanC,2BAA2B,KAAG,KAAK,CAAC,KAAK,CAAC,eAAe,EAAE,eAAe,EAAE,KAAK,CAAC,KAAK,GAAG,UAAU,CAAC,UAAU,CAgG/G,CAAA"}
|
@@ -2,18 +2,18 @@ import { Deferred, Effect, Layer, Queue, SubscriptionRef } from '@livestore/util
|
|
2
2
|
import { UnexpectedError } from '../adapter-types.js';
|
3
3
|
import { LiveStoreEvent } from '../schema/mod.js';
|
4
4
|
import { sql } from '../util.js';
|
5
|
-
import { makeApplyEvent } from './apply-event.js';
|
6
5
|
import * as Eventlog from './eventlog.js';
|
7
6
|
import { bootDevtools } from './leader-worker-devtools.js';
|
8
7
|
import { makeLeaderSyncProcessor } from './LeaderSyncProcessor.js';
|
8
|
+
import { makeMaterializeEvent } from './materialize-event.js';
|
9
9
|
import { recreateDb } from './recreate-db.js';
|
10
10
|
import { LeaderThreadCtx } from './types.js';
|
11
|
-
export const makeLeaderThreadLayer = ({ schema, storeId, clientId, syncPayload, makeSqliteDb, syncOptions,
|
11
|
+
export const makeLeaderThreadLayer = ({ schema, storeId, clientId, syncPayload, makeSqliteDb, syncOptions, dbState, dbEventlog, devtoolsOptions, shutdownChannel, params, testing, }) => Effect.gen(function* () {
|
12
12
|
const bootStatusQueue = yield* Queue.unbounded().pipe(Effect.acquireRelease(Queue.shutdown));
|
13
13
|
// TODO do more validation here than just checking the count of tables
|
14
14
|
// Either happens on initial boot or if schema changes
|
15
15
|
const dbEventlogMissing = dbEventlog.select(sql `select count(*) as count from sqlite_master`)[0].count === 0;
|
16
|
-
const
|
16
|
+
const dbStateMissing = dbState.select(sql `select count(*) as count from sqlite_master`)[0].count === 0;
|
17
17
|
const syncBackend = syncOptions?.backend === undefined
|
18
18
|
? undefined
|
19
19
|
: yield* syncOptions.backend({ storeId, clientId, payload: syncPayload });
|
@@ -29,8 +29,8 @@ export const makeLeaderThreadLayer = ({ schema, storeId, clientId, syncPayload,
|
|
29
29
|
schema,
|
30
30
|
dbEventlogMissing,
|
31
31
|
dbEventlog,
|
32
|
-
|
33
|
-
|
32
|
+
dbState,
|
33
|
+
dbStateMissing,
|
34
34
|
initialBlockingSyncContext,
|
35
35
|
onError: syncOptions?.onSyncError ?? 'ignore',
|
36
36
|
params: {
|
@@ -49,13 +49,13 @@ export const makeLeaderThreadLayer = ({ schema, storeId, clientId, syncPayload,
|
|
49
49
|
syncBackendLatchState: yield* SubscriptionRef.make({ latchClosed: false }),
|
50
50
|
}
|
51
51
|
: { enabled: false };
|
52
|
-
const
|
52
|
+
const materializeEvent = yield* makeMaterializeEvent({ schema, dbState, dbEventlog });
|
53
53
|
const ctx = {
|
54
54
|
schema,
|
55
55
|
bootStatusQueue,
|
56
56
|
storeId,
|
57
57
|
clientId,
|
58
|
-
|
58
|
+
dbState,
|
59
59
|
dbEventlog,
|
60
60
|
makeSqliteDb,
|
61
61
|
eventSchema: LiveStoreEvent.makeEventDefSchema(schema),
|
@@ -63,7 +63,7 @@ export const makeLeaderThreadLayer = ({ schema, storeId, clientId, syncPayload,
|
|
63
63
|
shutdownChannel,
|
64
64
|
syncBackend,
|
65
65
|
syncProcessor,
|
66
|
-
|
66
|
+
materializeEvent,
|
67
67
|
extraIncomingMessagesQueue,
|
68
68
|
devtools: devtoolsContext,
|
69
69
|
// State will be set during `bootLeaderThread`
|
@@ -73,7 +73,7 @@ export const makeLeaderThreadLayer = ({ schema, storeId, clientId, syncPayload,
|
|
73
73
|
globalThis.__leaderThreadCtx = ctx;
|
74
74
|
const layer = Layer.succeed(LeaderThreadCtx, ctx);
|
75
75
|
ctx.initialState = yield* bootLeaderThread({
|
76
|
-
|
76
|
+
dbStateMissing,
|
77
77
|
initialBlockingSyncContext,
|
78
78
|
devtoolsOptions,
|
79
79
|
}).pipe(Effect.provide(layer));
|
@@ -113,17 +113,10 @@ const makeInitialBlockingSyncContext = ({ initialSyncOptions, bootStatusQueue, }
|
|
113
113
|
* Blocks until the leader thread has finished its initial setup.
|
114
114
|
* It also starts various background processes (e.g. syncing)
|
115
115
|
*/
|
116
|
-
const bootLeaderThread = ({
|
116
|
+
const bootLeaderThread = ({ dbStateMissing, initialBlockingSyncContext, devtoolsOptions, }) => Effect.gen(function* () {
|
117
117
|
const { dbEventlog, bootStatusQueue, syncProcessor } = yield* LeaderThreadCtx;
|
118
118
|
yield* Eventlog.initEventlogDb(dbEventlog);
|
119
|
-
|
120
|
-
if (dbReadModelMissing) {
|
121
|
-
const recreateResult = yield* recreateDb;
|
122
|
-
migrationsReport = recreateResult.migrationsReport;
|
123
|
-
}
|
124
|
-
else {
|
125
|
-
migrationsReport = { migrations: [] };
|
126
|
-
}
|
119
|
+
const { migrationsReport } = dbStateMissing ? yield* recreateDb : { migrationsReport: { migrations: [] } };
|
127
120
|
// NOTE the sync processor depends on the dbs being initialized properly
|
128
121
|
const { initialLeaderHead } = yield* syncProcessor.boot;
|
129
122
|
if (initialBlockingSyncContext.blockingDeferred !== undefined) {
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"make-leader-thread-layer.js","sourceRoot":"","sources":["../../src/leader-thread/make-leader-thread-layer.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA;AAGzF,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAA;AAGrD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAEjD,OAAO,EAAE,GAAG,EAAE,MAAM,YAAY,CAAA;AAChC,OAAO,
|
1
|
+
{"version":3,"file":"make-leader-thread-layer.js","sourceRoot":"","sources":["../../src/leader-thread/make-leader-thread-layer.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,16 @@
|
|
1
|
+
import { Effect } from '@livestore/utils/effect';
|
2
|
+
import type { SqliteDb } from '../adapter-types.js';
|
3
|
+
import type { LiveStoreSchema } from '../schema/mod.js';
|
4
|
+
import { EventId } from '../schema/mod.js';
|
5
|
+
import type { MaterializeEvent } from './types.js';
|
6
|
+
export declare const makeMaterializeEvent: ({ schema, dbState: db, dbEventlog, }: {
|
7
|
+
schema: LiveStoreSchema;
|
8
|
+
dbState: SqliteDb;
|
9
|
+
dbEventlog: SqliteDb;
|
10
|
+
}) => Effect.Effect<MaterializeEvent, never>;
|
11
|
+
export declare const rollback: ({ dbState, dbEventlog, eventIdsToRollback, }: {
|
12
|
+
dbState: SqliteDb;
|
13
|
+
dbEventlog: SqliteDb;
|
14
|
+
eventIdsToRollback: EventId.EventId[];
|
15
|
+
}) => Effect.Effect<void, never, never>;
|
16
|
+
//# sourceMappingURL=materialize-event.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"materialize-event.d.ts","sourceRoot":"","sources":["../../src/leader-thread/materialize-event.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,MAAM,EAAyB,MAAM,yBAAyB,CAAA;AAEvE,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAEnD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AACvD,OAAO,EAAE,OAAO,EAA6B,MAAM,kBAAkB,CAAA;AAKrE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAA;AAElD,eAAO,MAAM,oBAAoB,GAAI,sCAIlC;IACD,MAAM,EAAE,eAAe,CAAA;IACvB,OAAO,EAAE,QAAQ,CAAA;IACjB,UAAU,EAAE,QAAQ,CAAA;CACrB,KAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,EAAE,KAAK,CAiGrC,CAAA;AAEJ,eAAO,MAAM,QAAQ,GAAI,8CAItB;IACD,OAAO,EAAE,QAAQ,CAAA;IACjB,UAAU,EAAE,QAAQ,CAAA;IACpB,kBAAkB,EAAE,OAAO,CAAC,OAAO,EAAE,CAAA;CACtC,sCAsCE,CAAA"}
|
@@ -0,0 +1,103 @@
|
|
1
|
+
import { LS_DEV, shouldNeverHappen } from '@livestore/utils';
|
2
|
+
import { Effect, ReadonlyArray, Schema } from '@livestore/utils/effect';
|
3
|
+
import { getExecArgsFromEvent } from '../materializer-helper.js';
|
4
|
+
import { EventId, getEventDef, SystemTables } from '../schema/mod.js';
|
5
|
+
import { insertRow } from '../sql-queries/index.js';
|
6
|
+
import { sql } from '../util.js';
|
7
|
+
import { execSql, execSqlPrepared } from './connection.js';
|
8
|
+
import * as Eventlog from './eventlog.js';
|
9
|
+
export const makeMaterializeEvent = ({ schema, dbState: db, dbEventlog, }) => Effect.gen(function* () {
|
10
|
+
const eventDefSchemaHashMap = new Map(
|
11
|
+
// TODO Running `Schema.hash` can be a bottleneck for larger schemas. There is an opportunity to run this
|
12
|
+
// at build time and lookup the pre-computed hash at runtime.
|
13
|
+
// Also see https://github.com/Effect-TS/effect/issues/2719
|
14
|
+
[...schema.eventsDefsMap.entries()].map(([k, v]) => [k, Schema.hash(v.schema)]));
|
15
|
+
return (eventEncoded, options) => Effect.gen(function* () {
|
16
|
+
const skipEventlog = options?.skipEventlog ?? false;
|
17
|
+
const eventName = eventEncoded.name;
|
18
|
+
const eventDef = getEventDef(schema, eventName);
|
19
|
+
const execArgsArr = getExecArgsFromEvent({
|
20
|
+
eventDef,
|
21
|
+
event: { decoded: undefined, encoded: eventEncoded },
|
22
|
+
});
|
23
|
+
// NOTE we might want to bring this back if we want to debug no-op events
|
24
|
+
// const makeExecuteOptions = (statementSql: string, bindValues: any) => ({
|
25
|
+
// onRowsChanged: (rowsChanged: number) => {
|
26
|
+
// if (rowsChanged === 0) {
|
27
|
+
// console.warn(`Event "${eventDef.name}" did not affect any rows:`, statementSql, bindValues)
|
28
|
+
// }
|
29
|
+
// },
|
30
|
+
// })
|
31
|
+
// console.group('[@livestore/common:leader-thread:materializeEvent]', { eventName })
|
32
|
+
const session = db.session();
|
33
|
+
for (const { statementSql, bindValues } of execArgsArr) {
|
34
|
+
// console.debug(eventName, statementSql, bindValues)
|
35
|
+
// TODO use cached prepared statements instead of exec
|
36
|
+
yield* execSqlPrepared(db, statementSql, bindValues);
|
37
|
+
}
|
38
|
+
const changeset = session.changeset();
|
39
|
+
session.finish();
|
40
|
+
// TODO use prepared statements
|
41
|
+
yield* execSql(db, ...insertRow({
|
42
|
+
tableName: SystemTables.SESSION_CHANGESET_META_TABLE,
|
43
|
+
columns: SystemTables.sessionChangesetMetaTable.sqliteDef.columns,
|
44
|
+
values: {
|
45
|
+
idGlobal: eventEncoded.id.global,
|
46
|
+
idClient: eventEncoded.id.client,
|
47
|
+
// NOTE the changeset will be empty (i.e. null) for no-op events
|
48
|
+
changeset: changeset ?? null,
|
49
|
+
debug: LS_DEV ? execArgsArr : null,
|
50
|
+
},
|
51
|
+
}));
|
52
|
+
// console.groupEnd()
|
53
|
+
// write to eventlog
|
54
|
+
if (skipEventlog === false) {
|
55
|
+
const eventName = eventEncoded.name;
|
56
|
+
const eventDefSchemaHash = eventDefSchemaHashMap.get(eventName) ?? shouldNeverHappen(`Unknown event definition: ${eventName}`);
|
57
|
+
yield* Eventlog.insertIntoEventlog(eventEncoded, dbEventlog, eventDefSchemaHash, eventEncoded.clientId, eventEncoded.sessionId);
|
58
|
+
}
|
59
|
+
else {
|
60
|
+
// console.debug('[@livestore/common:leader-thread] skipping eventlog write', mutation, statementSql, bindValues)
|
61
|
+
}
|
62
|
+
return {
|
63
|
+
sessionChangeset: changeset
|
64
|
+
? {
|
65
|
+
_tag: 'sessionChangeset',
|
66
|
+
data: changeset,
|
67
|
+
debug: LS_DEV ? execArgsArr : null,
|
68
|
+
}
|
69
|
+
: { _tag: 'no-op' },
|
70
|
+
};
|
71
|
+
}).pipe(Effect.withSpan(`@livestore/common:leader-thread:materializeEvent`, {
|
72
|
+
attributes: {
|
73
|
+
eventName: eventEncoded.name,
|
74
|
+
eventId: eventEncoded.id,
|
75
|
+
'span.label': `${EventId.toString(eventEncoded.id)} ${eventEncoded.name}`,
|
76
|
+
},
|
77
|
+
}));
|
78
|
+
});
|
79
|
+
export const rollback = ({ dbState, dbEventlog, eventIdsToRollback, }) => Effect.gen(function* () {
|
80
|
+
const rollbackEvents = dbState
|
81
|
+
.select(sql `SELECT * FROM ${SystemTables.SESSION_CHANGESET_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdsToRollback.map((id) => `(${id.global}, ${id.client})`).join(', ')})`)
|
82
|
+
.map((_) => ({ id: { global: _.idGlobal, client: _.idClient }, changeset: _.changeset, debug: _.debug }))
|
83
|
+
.toSorted((a, b) => EventId.compare(a.id, b.id));
|
84
|
+
// Apply changesets in reverse order
|
85
|
+
for (let i = rollbackEvents.length - 1; i >= 0; i--) {
|
86
|
+
const { changeset } = rollbackEvents[i];
|
87
|
+
if (changeset !== null) {
|
88
|
+
dbState.makeChangeset(changeset).invert().apply();
|
89
|
+
}
|
90
|
+
}
|
91
|
+
const eventIdPairChunks = ReadonlyArray.chunksOf(100)(eventIdsToRollback.map((id) => `(${id.global}, ${id.client})`));
|
92
|
+
// Delete the changeset rows
|
93
|
+
for (const eventIdPairChunk of eventIdPairChunks) {
|
94
|
+
dbState.execute(sql `DELETE FROM ${SystemTables.SESSION_CHANGESET_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdPairChunk.join(', ')})`);
|
95
|
+
}
|
96
|
+
// Delete the eventlog rows
|
97
|
+
for (const eventIdPairChunk of eventIdPairChunks) {
|
98
|
+
dbEventlog.execute(sql `DELETE FROM ${SystemTables.EVENTLOG_META_TABLE} WHERE (idGlobal, idClient) IN (${eventIdPairChunk.join(', ')})`);
|
99
|
+
}
|
100
|
+
}).pipe(Effect.withSpan('@livestore/common:LeaderSyncProcessor:rollback', {
|
101
|
+
attributes: { count: eventIdsToRollback.length },
|
102
|
+
}));
|
103
|
+
//# sourceMappingURL=materialize-event.js.map
|