@livestore/common 0.3.0-dev.26 → 0.3.0-dev.27
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 +13 -12
- package/dist/adapter-types.d.ts.map +1 -1
- package/dist/adapter-types.js +5 -6
- package/dist/adapter-types.js.map +1 -1
- package/dist/devtools/devtools-messages-client-session.d.ts +21 -21
- package/dist/devtools/devtools-messages-common.d.ts +13 -6
- package/dist/devtools/devtools-messages-common.d.ts.map +1 -1
- package/dist/devtools/devtools-messages-common.js +6 -0
- package/dist/devtools/devtools-messages-common.js.map +1 -1
- package/dist/devtools/devtools-messages-leader.d.ts +25 -25
- package/dist/devtools/devtools-messages-leader.d.ts.map +1 -1
- package/dist/devtools/devtools-messages-leader.js +1 -2
- package/dist/devtools/devtools-messages-leader.js.map +1 -1
- package/dist/leader-thread/LeaderSyncProcessor.d.ts +15 -6
- package/dist/leader-thread/LeaderSyncProcessor.d.ts.map +1 -1
- package/dist/leader-thread/LeaderSyncProcessor.js +211 -189
- package/dist/leader-thread/LeaderSyncProcessor.js.map +1 -1
- package/dist/leader-thread/apply-mutation.d.ts +14 -9
- package/dist/leader-thread/apply-mutation.d.ts.map +1 -1
- package/dist/leader-thread/apply-mutation.js +43 -36
- package/dist/leader-thread/apply-mutation.js.map +1 -1
- package/dist/leader-thread/leader-worker-devtools.d.ts +1 -1
- package/dist/leader-thread/leader-worker-devtools.d.ts.map +1 -1
- package/dist/leader-thread/leader-worker-devtools.js +4 -5
- package/dist/leader-thread/leader-worker-devtools.js.map +1 -1
- package/dist/leader-thread/make-leader-thread-layer.d.ts.map +1 -1
- package/dist/leader-thread/make-leader-thread-layer.js +21 -33
- package/dist/leader-thread/make-leader-thread-layer.js.map +1 -1
- package/dist/leader-thread/mod.d.ts +1 -1
- package/dist/leader-thread/mod.d.ts.map +1 -1
- package/dist/leader-thread/mod.js +1 -1
- package/dist/leader-thread/mod.js.map +1 -1
- package/dist/leader-thread/mutationlog.d.ts +19 -3
- package/dist/leader-thread/mutationlog.d.ts.map +1 -1
- package/dist/leader-thread/mutationlog.js +105 -12
- package/dist/leader-thread/mutationlog.js.map +1 -1
- package/dist/leader-thread/pull-queue-set.d.ts +1 -1
- package/dist/leader-thread/pull-queue-set.d.ts.map +1 -1
- package/dist/leader-thread/pull-queue-set.js +6 -16
- package/dist/leader-thread/pull-queue-set.js.map +1 -1
- package/dist/leader-thread/recreate-db.d.ts.map +1 -1
- package/dist/leader-thread/recreate-db.js +4 -3
- package/dist/leader-thread/recreate-db.js.map +1 -1
- package/dist/leader-thread/types.d.ts +34 -19
- package/dist/leader-thread/types.d.ts.map +1 -1
- package/dist/leader-thread/types.js.map +1 -1
- package/dist/rehydrate-from-mutationlog.d.ts +5 -4
- package/dist/rehydrate-from-mutationlog.d.ts.map +1 -1
- package/dist/rehydrate-from-mutationlog.js +7 -9
- package/dist/rehydrate-from-mutationlog.js.map +1 -1
- package/dist/schema/EventId.d.ts +9 -0
- package/dist/schema/EventId.d.ts.map +1 -1
- package/dist/schema/EventId.js +17 -2
- package/dist/schema/EventId.js.map +1 -1
- package/dist/schema/MutationEvent.d.ts +78 -25
- package/dist/schema/MutationEvent.d.ts.map +1 -1
- package/dist/schema/MutationEvent.js +25 -12
- package/dist/schema/MutationEvent.js.map +1 -1
- package/dist/schema/schema.js +1 -1
- package/dist/schema/schema.js.map +1 -1
- package/dist/schema/system-tables.d.ts +67 -0
- package/dist/schema/system-tables.d.ts.map +1 -1
- package/dist/schema/system-tables.js +12 -1
- package/dist/schema/system-tables.js.map +1 -1
- package/dist/sync/ClientSessionSyncProcessor.d.ts +9 -1
- package/dist/sync/ClientSessionSyncProcessor.d.ts.map +1 -1
- package/dist/sync/ClientSessionSyncProcessor.js +25 -19
- package/dist/sync/ClientSessionSyncProcessor.js.map +1 -1
- package/dist/sync/sync.d.ts +6 -5
- package/dist/sync/sync.d.ts.map +1 -1
- package/dist/sync/sync.js.map +1 -1
- package/dist/sync/syncstate.d.ts +47 -71
- package/dist/sync/syncstate.d.ts.map +1 -1
- package/dist/sync/syncstate.js +118 -127
- package/dist/sync/syncstate.js.map +1 -1
- package/dist/sync/syncstate.test.js +204 -275
- package/dist/sync/syncstate.test.js.map +1 -1
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/package.json +2 -2
- package/src/adapter-types.ts +11 -13
- package/src/devtools/devtools-messages-common.ts +9 -0
- package/src/devtools/devtools-messages-leader.ts +1 -2
- package/src/leader-thread/LeaderSyncProcessor.ts +381 -346
- package/src/leader-thread/apply-mutation.ts +81 -71
- package/src/leader-thread/leader-worker-devtools.ts +5 -7
- package/src/leader-thread/make-leader-thread-layer.ts +26 -41
- package/src/leader-thread/mod.ts +1 -1
- package/src/leader-thread/mutationlog.ts +166 -13
- package/src/leader-thread/recreate-db.ts +4 -3
- package/src/leader-thread/types.ts +33 -23
- package/src/rehydrate-from-mutationlog.ts +12 -12
- package/src/schema/EventId.ts +20 -2
- package/src/schema/MutationEvent.ts +32 -16
- package/src/schema/schema.ts +1 -1
- package/src/schema/system-tables.ts +20 -1
- package/src/sync/ClientSessionSyncProcessor.ts +35 -23
- package/src/sync/sync.ts +6 -9
- package/src/sync/syncstate.test.ts +230 -306
- package/src/sync/syncstate.ts +176 -171
- package/src/version.ts +1 -1
- package/src/leader-thread/pull-queue-set.ts +0 -67
@@ -1,11 +1,27 @@
|
|
1
|
-
import { Effect } from '@livestore/utils/effect';
|
1
|
+
import { Effect, Option, Schema } from '@livestore/utils/effect';
|
2
2
|
import type { SqliteDb } from '../adapter-types.js';
|
3
3
|
import * as EventId from '../schema/EventId.js';
|
4
|
-
import
|
4
|
+
import * as MutationEvent from '../schema/MutationEvent.js';
|
5
5
|
import { LeaderThreadCtx } from './types.js';
|
6
|
+
export declare const initMutationLogDb: (dbMutationLog: SqliteDb) => Effect.Effect<void, import("../adapter-types.js").SqliteError, never>;
|
6
7
|
/** Exclusive of the "since event" */
|
7
|
-
export declare const getMutationEventsSince: (since: EventId.EventId) => Effect.Effect<ReadonlyArray<MutationEvent.
|
8
|
+
export declare const getMutationEventsSince: (since: EventId.EventId) => Effect.Effect<ReadonlyArray<MutationEvent.EncodedWithMeta>, never, LeaderThreadCtx>;
|
8
9
|
export declare const getClientHeadFromDb: (dbMutationLog: SqliteDb) => EventId.EventId;
|
9
10
|
export declare const getBackendHeadFromDb: (dbMutationLog: SqliteDb) => EventId.GlobalEventId;
|
10
11
|
export declare const updateBackendHead: (dbMutationLog: SqliteDb, head: EventId.EventId) => void;
|
12
|
+
export declare const insertIntoMutationLog: (mutationEventEncoded: MutationEvent.EncodedWithMeta, dbMutationLog: SqliteDb, mutationDefSchemaHash: number, clientId: string, sessionId: string) => Effect.Effect<void, import("../adapter-types.js").SqliteError, never>;
|
13
|
+
export declare const updateSyncMetadata: (items: ReadonlyArray<MutationEvent.EncodedWithMeta>) => Effect.Effect<void, import("../adapter-types.js").SqliteError, LeaderThreadCtx>;
|
14
|
+
export declare const getSyncBackendCursorInfo: (remoteHead: EventId.GlobalEventId) => Effect.Effect<Option.None<{
|
15
|
+
cursor: {
|
16
|
+
global: EventId.GlobalEventId;
|
17
|
+
client: EventId.ClientEventId;
|
18
|
+
};
|
19
|
+
metadata: Option.Option<Schema.JsonValue>;
|
20
|
+
}> | Option.Some<{
|
21
|
+
cursor: {
|
22
|
+
global: EventId.GlobalEventId;
|
23
|
+
client: EventId.ClientEventId;
|
24
|
+
};
|
25
|
+
metadata: Option.Option<Schema.JsonValue>;
|
26
|
+
}>, never, LeaderThreadCtx>;
|
11
27
|
//# sourceMappingURL=mutationlog.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"mutationlog.d.ts","sourceRoot":"","sources":["../../src/leader-thread/mutationlog.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"mutationlog.d.ts","sourceRoot":"","sources":["../../src/leader-thread/mutationlog.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,aAAa,MAAM,4BAA4B,CAAA;AAc3D,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE5C,eAAO,MAAM,iBAAiB,GAAI,eAAe,QAAQ,0EAwBrD,CAAA;AAEJ,qCAAqC;AACrC,eAAO,MAAM,sBAAsB,GACjC,OAAO,OAAO,CAAC,OAAO,KACrB,MAAM,CAAC,MAAM,CAAC,aAAa,CAAC,aAAa,CAAC,eAAe,CAAC,EAAE,KAAK,EAAE,eAAe,CAgDjF,CAAA;AAEJ,eAAO,MAAM,mBAAmB,GAAI,eAAe,QAAQ,KAAG,OAAO,CAAC,OAMrE,CAAA;AAED,eAAO,MAAM,oBAAoB,GAAI,eAAe,QAAQ,KAAG,OAAO,CAAC,aAElD,CAAA;AAGrB,eAAO,MAAM,iBAAiB,GAAI,eAAe,QAAQ,EAAE,MAAM,OAAO,CAAC,OAAO,SACG,CAAA;AAEnF,eAAO,MAAM,qBAAqB,GAChC,sBAAsB,aAAa,CAAC,eAAe,EACnD,eAAe,QAAQ,EACvB,uBAAuB,MAAM,EAC7B,UAAU,MAAM,EAChB,WAAW,MAAM,0EAsCf,CAAA;AAEJ,eAAO,MAAM,kBAAkB,GAAI,OAAO,aAAa,CAAC,aAAa,CAAC,eAAe,CAAC,oFAkBlF,CAAA;AAEJ,eAAO,MAAM,wBAAwB,GAAI,YAAY,OAAO,CAAC,aAAa;;;;;;;;;;;;2BAoB0C,CAAA"}
|
@@ -1,24 +1,65 @@
|
|
1
|
-
import {
|
1
|
+
import { LS_DEV, shouldNeverHappen } from '@livestore/utils';
|
2
|
+
import { Effect, Option, Schema } from '@livestore/utils/effect';
|
2
3
|
import * as EventId from '../schema/EventId.js';
|
3
|
-
import
|
4
|
+
import * as MutationEvent from '../schema/MutationEvent.js';
|
5
|
+
import { MUTATION_LOG_META_TABLE, mutationLogMetaTable, sessionChangesetMetaTable, SYNC_STATUS_TABLE, syncStatusTable, } from '../schema/system-tables.js';
|
6
|
+
import { migrateTable } from '../schema-management/migrations.js';
|
7
|
+
import { insertRow, updateRows } from '../sql-queries/sql-queries.js';
|
4
8
|
import { prepareBindValues, sql } from '../util.js';
|
9
|
+
import { execSql } from './connection.js';
|
5
10
|
import { LeaderThreadCtx } from './types.js';
|
11
|
+
export const initMutationLogDb = (dbMutationLog) => Effect.gen(function* () {
|
12
|
+
yield* migrateTable({
|
13
|
+
db: dbMutationLog,
|
14
|
+
behaviour: 'create-if-not-exists',
|
15
|
+
tableAst: mutationLogMetaTable.sqliteDef.ast,
|
16
|
+
skipMetaTable: true,
|
17
|
+
});
|
18
|
+
yield* migrateTable({
|
19
|
+
db: dbMutationLog,
|
20
|
+
behaviour: 'create-if-not-exists',
|
21
|
+
tableAst: syncStatusTable.sqliteDef.ast,
|
22
|
+
skipMetaTable: true,
|
23
|
+
});
|
24
|
+
// Create sync status row if it doesn't exist
|
25
|
+
yield* execSql(dbMutationLog, sql `INSERT INTO ${SYNC_STATUS_TABLE} (head)
|
26
|
+
SELECT ${EventId.ROOT.global}
|
27
|
+
WHERE NOT EXISTS (SELECT 1 FROM ${SYNC_STATUS_TABLE})`, {});
|
28
|
+
});
|
6
29
|
/** Exclusive of the "since event" */
|
7
30
|
export const getMutationEventsSince = (since) => Effect.gen(function* () {
|
8
|
-
const { dbMutationLog } = yield* LeaderThreadCtx;
|
31
|
+
const { dbMutationLog, dbReadModel } = yield* LeaderThreadCtx;
|
9
32
|
const query = mutationLogMetaTable.query.where('idGlobal', '>=', since.global).asSql();
|
10
33
|
const pendingMutationEventsRaw = dbMutationLog.select(query.query, prepareBindValues(query.bindValues, query.query));
|
11
34
|
const pendingMutationEvents = Schema.decodeUnknownSync(mutationLogMetaTable.schema.pipe(Schema.Array))(pendingMutationEventsRaw);
|
35
|
+
const sessionChangesetRows = sessionChangesetMetaTable.query.where('idGlobal', '>=', since.global).asSql();
|
36
|
+
const sessionChangesetRowsRaw = dbReadModel.select(sessionChangesetRows.query, prepareBindValues(sessionChangesetRows.bindValues, sessionChangesetRows.query));
|
37
|
+
const sessionChangesetRowsDecoded = Schema.decodeUnknownSync(sessionChangesetMetaTable.schema.pipe(Schema.Array))(sessionChangesetRowsRaw);
|
12
38
|
return pendingMutationEvents
|
13
|
-
.map((
|
14
|
-
|
15
|
-
|
16
|
-
|
17
|
-
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
|
39
|
+
.map((mutationLogEvent) => {
|
40
|
+
const sessionChangeset = sessionChangesetRowsDecoded.find((readModelEvent) => readModelEvent.idGlobal === mutationLogEvent.idGlobal &&
|
41
|
+
readModelEvent.idClient === mutationLogEvent.idClient);
|
42
|
+
return MutationEvent.EncodedWithMeta.make({
|
43
|
+
mutation: mutationLogEvent.mutation,
|
44
|
+
args: mutationLogEvent.argsJson,
|
45
|
+
id: { global: mutationLogEvent.idGlobal, client: mutationLogEvent.idClient },
|
46
|
+
parentId: { global: mutationLogEvent.parentIdGlobal, client: mutationLogEvent.parentIdClient },
|
47
|
+
clientId: mutationLogEvent.clientId,
|
48
|
+
sessionId: mutationLogEvent.sessionId,
|
49
|
+
meta: {
|
50
|
+
sessionChangeset: sessionChangeset && sessionChangeset.changeset !== null
|
51
|
+
? {
|
52
|
+
_tag: 'sessionChangeset',
|
53
|
+
data: sessionChangeset.changeset,
|
54
|
+
debug: sessionChangeset.debug,
|
55
|
+
}
|
56
|
+
: { _tag: 'unset' },
|
57
|
+
syncMetadata: mutationLogEvent.syncMetadataJson,
|
58
|
+
},
|
59
|
+
});
|
60
|
+
})
|
61
|
+
.filter((_) => EventId.compare(_.id, since) > 0)
|
62
|
+
.sort((a, b) => EventId.compare(a.id, b.id));
|
22
63
|
});
|
23
64
|
export const getClientHeadFromDb = (dbMutationLog) => {
|
24
65
|
const res = dbMutationLog.select(sql `select idGlobal, idClient from ${MUTATION_LOG_META_TABLE} order by idGlobal DESC, idClient DESC limit 1`)[0];
|
@@ -28,4 +69,56 @@ export const getBackendHeadFromDb = (dbMutationLog) => dbMutationLog.select(sql
|
|
28
69
|
EventId.ROOT.global;
|
29
70
|
// TODO use prepared statements
|
30
71
|
export const updateBackendHead = (dbMutationLog, head) => dbMutationLog.execute(sql `UPDATE ${SYNC_STATUS_TABLE} SET head = ${head.global}`);
|
72
|
+
export const insertIntoMutationLog = (mutationEventEncoded, dbMutationLog, mutationDefSchemaHash, clientId, sessionId) => Effect.gen(function* () {
|
73
|
+
// Check history consistency during LS_DEV
|
74
|
+
if (LS_DEV && mutationEventEncoded.parentId.global !== EventId.ROOT.global) {
|
75
|
+
const parentMutationExists = dbMutationLog.select(`SELECT COUNT(*) as count FROM ${MUTATION_LOG_META_TABLE} WHERE idGlobal = ? AND idClient = ?`, [mutationEventEncoded.parentId.global, mutationEventEncoded.parentId.client])[0].count === 1;
|
76
|
+
if (parentMutationExists === false) {
|
77
|
+
shouldNeverHappen(`Parent mutation ${mutationEventEncoded.parentId.global},${mutationEventEncoded.parentId.client} does not exist`);
|
78
|
+
}
|
79
|
+
}
|
80
|
+
// TODO use prepared statements
|
81
|
+
yield* execSql(dbMutationLog, ...insertRow({
|
82
|
+
tableName: MUTATION_LOG_META_TABLE,
|
83
|
+
columns: mutationLogMetaTable.sqliteDef.columns,
|
84
|
+
values: {
|
85
|
+
idGlobal: mutationEventEncoded.id.global,
|
86
|
+
idClient: mutationEventEncoded.id.client,
|
87
|
+
parentIdGlobal: mutationEventEncoded.parentId.global,
|
88
|
+
parentIdClient: mutationEventEncoded.parentId.client,
|
89
|
+
mutation: mutationEventEncoded.mutation,
|
90
|
+
argsJson: mutationEventEncoded.args ?? {},
|
91
|
+
clientId,
|
92
|
+
sessionId,
|
93
|
+
schemaHash: mutationDefSchemaHash,
|
94
|
+
syncMetadataJson: mutationEventEncoded.meta.syncMetadata,
|
95
|
+
},
|
96
|
+
}));
|
97
|
+
});
|
98
|
+
export const updateSyncMetadata = (items) => Effect.gen(function* () {
|
99
|
+
const { dbMutationLog } = yield* LeaderThreadCtx;
|
100
|
+
// TODO try to do this in a single query
|
101
|
+
for (let i = 0; i < items.length; i++) {
|
102
|
+
const mutationEvent = items[i];
|
103
|
+
yield* execSql(dbMutationLog, ...updateRows({
|
104
|
+
tableName: MUTATION_LOG_META_TABLE,
|
105
|
+
columns: mutationLogMetaTable.sqliteDef.columns,
|
106
|
+
where: { idGlobal: mutationEvent.id.global, idClient: mutationEvent.id.client },
|
107
|
+
updateValues: { syncMetadataJson: mutationEvent.meta.syncMetadata },
|
108
|
+
}));
|
109
|
+
}
|
110
|
+
});
|
111
|
+
export const getSyncBackendCursorInfo = (remoteHead) => Effect.gen(function* () {
|
112
|
+
const { dbMutationLog } = yield* LeaderThreadCtx;
|
113
|
+
if (remoteHead === EventId.ROOT.global)
|
114
|
+
return Option.none();
|
115
|
+
const MutationlogQuerySchema = Schema.Struct({
|
116
|
+
syncMetadataJson: Schema.parseJson(Schema.Option(Schema.JsonValue)),
|
117
|
+
}).pipe(Schema.pluck('syncMetadataJson'), Schema.Array, Schema.head);
|
118
|
+
const syncMetadataOption = yield* Effect.sync(() => dbMutationLog.select(sql `SELECT syncMetadataJson FROM ${MUTATION_LOG_META_TABLE} WHERE idGlobal = ${remoteHead} ORDER BY idClient ASC LIMIT 1`)).pipe(Effect.andThen(Schema.decode(MutationlogQuerySchema)), Effect.map(Option.flatten), Effect.orDie);
|
119
|
+
return Option.some({
|
120
|
+
cursor: { global: remoteHead, client: EventId.clientDefault },
|
121
|
+
metadata: syncMetadataOption,
|
122
|
+
});
|
123
|
+
}).pipe(Effect.withSpan('@livestore/common:mutationlog:getSyncBackendCursorInfo', { attributes: { remoteHead } }));
|
31
124
|
//# sourceMappingURL=mutationlog.js.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"mutationlog.js","sourceRoot":"","sources":["../../src/leader-thread/mutationlog.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;
|
1
|
+
{"version":3,"file":"mutationlog.js","sourceRoot":"","sources":["../../src/leader-thread/mutationlog.ts"],"names":[],"mappings":"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"}
|
@@ -2,6 +2,6 @@ import { Effect, Queue } from '@livestore/utils/effect';
|
|
2
2
|
import { LeaderThreadCtx, type PullQueueItem } from './types.js';
|
3
3
|
export declare const makePullQueueSet: Effect.Effect<{
|
4
4
|
makeQueue: (since: import("../schema/EventId.js").EventId) => Effect.Effect<Queue.Queue<PullQueueItem>, import("../adapter-types.js").UnexpectedError, import("effect/Scope").Scope | LeaderThreadCtx>;
|
5
|
-
offer: (item: PullQueueItem) => Effect.Effect<void, import("../adapter-types.js").UnexpectedError
|
5
|
+
offer: (item: PullQueueItem) => Effect.Effect<void, import("../adapter-types.js").UnexpectedError>;
|
6
6
|
}, never, import("effect/Scope").Scope>;
|
7
7
|
//# sourceMappingURL=pull-queue-set.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"pull-queue-set.d.ts","sourceRoot":"","sources":["../../src/leader-thread/pull-queue-set.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;
|
1
|
+
{"version":3,"file":"pull-queue-set.d.ts","sourceRoot":"","sources":["../../src/leader-thread/pull-queue-set.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AAGvD,OAAO,EAAE,eAAe,EAAE,KAAK,aAAa,EAAqB,MAAM,YAAY,CAAA;AAEnF,eAAO,MAAM,gBAAgB;kEAoDw2H,OAAQ,MAAM,CAAC,MAAM,KAAK;oCAAkG,OAAQ,MAAM;uCAD7gI,CAAA"}
|
@@ -1,7 +1,5 @@
|
|
1
1
|
import { Effect, Queue } from '@livestore/utils/effect';
|
2
|
-
import * as MutationEvent from '../schema/MutationEvent.js';
|
3
2
|
import { getMutationEventsSince } from './mutationlog.js';
|
4
|
-
import { LeaderThreadCtx } from './types.js';
|
5
3
|
export const makePullQueueSet = Effect.gen(function* () {
|
6
4
|
const set = new Set();
|
7
5
|
yield* Effect.addFinalizer(() => Effect.gen(function* () {
|
@@ -13,9 +11,10 @@ export const makePullQueueSet = Effect.gen(function* () {
|
|
13
11
|
const makeQueue = (since) => Effect.gen(function* () {
|
14
12
|
const queue = yield* Queue.unbounded().pipe(Effect.acquireRelease(Queue.shutdown));
|
15
13
|
yield* Effect.addFinalizer(() => Effect.sync(() => set.delete(queue)));
|
16
|
-
const
|
17
|
-
|
18
|
-
|
14
|
+
const newEvents = yield* getMutationEventsSince(since);
|
15
|
+
yield* Effect.log(`[@livestore/common:pull-queue-set] making queue for since ${since}`, newEvents);
|
16
|
+
yield* Effect.addFinalizerLog(`[@livestore/common:pull-queue-set] shutting down queue for since ${since}`);
|
17
|
+
if (newEvents.length > 0) {
|
19
18
|
yield* queue.offer({ payload: { _tag: 'upstream-advance', newEvents }, remaining: 0 });
|
20
19
|
}
|
21
20
|
set.add(queue);
|
@@ -23,19 +22,10 @@ export const makePullQueueSet = Effect.gen(function* () {
|
|
23
22
|
});
|
24
23
|
const offer = (item) => Effect.gen(function* () {
|
25
24
|
// Short-circuit if the payload is an empty upstream advance
|
26
|
-
if (item.payload._tag === 'upstream-advance' &&
|
27
|
-
item.payload.newEvents.length === 0 &&
|
28
|
-
item.payload.trimRollbackUntil === undefined) {
|
25
|
+
if (item.payload._tag === 'upstream-advance' && item.payload.newEvents.length === 0) {
|
29
26
|
return;
|
30
27
|
}
|
31
|
-
|
32
|
-
if (clientId === 'client-b') {
|
33
|
-
// console.log(
|
34
|
-
// 'offer',
|
35
|
-
// item.payload._tag,
|
36
|
-
// item.payload.newEvents.map((_) => _.toJSON()),
|
37
|
-
// )
|
38
|
-
}
|
28
|
+
console.log('[@livestore/common:pull-queue-set] offering item', item);
|
39
29
|
for (const queue of set) {
|
40
30
|
yield* Queue.offer(queue, item);
|
41
31
|
}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"pull-queue-set.js","sourceRoot":"","sources":["../../src/leader-thread/pull-queue-set.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AAEvD,OAAO,
|
1
|
+
{"version":3,"file":"pull-queue-set.js","sourceRoot":"","sources":["../../src/leader-thread/pull-queue-set.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AAEvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,kBAAkB,CAAA;AAGzD,MAAM,CAAC,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IAClD,MAAM,GAAG,GAAG,IAAI,GAAG,EAA8B,CAAA;IAEjD,KAAK,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,CAC9B,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;QAClB,KAAK,MAAM,KAAK,IAAI,GAAG,EAAE,CAAC;YACxB,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAA;QAC9B,CAAC;QAED,GAAG,CAAC,KAAK,EAAE,CAAA;IACb,CAAC,CAAC,CACH,CAAA;IAED,MAAM,SAAS,GAA8B,CAAC,KAAK,EAAE,EAAE,CACrD,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;QAClB,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,KAAK,CAAC,SAAS,EAAiB,CAAC,IAAI,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAA;QAEjG,KAAK,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;QAEtE,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,sBAAsB,CAAC,KAAK,CAAC,CAAA;QAEtD,KAAK,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,6DAA6D,KAAK,EAAE,EAAE,SAAS,CAAC,CAAA;QAClG,KAAK,CAAC,CAAC,MAAM,CAAC,eAAe,CAAC,oEAAoE,KAAK,EAAE,CAAC,CAAA;QAE1G,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACzB,KAAK,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE,SAAS,EAAE,EAAE,SAAS,EAAE,CAAC,EAAE,CAAC,CAAA;QACxF,CAAC;QAED,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;QAEd,OAAO,KAAK,CAAA;IACd,CAAC,CAAC,CAAA;IAEJ,MAAM,KAAK,GAA0B,CAAC,IAAI,EAAE,EAAE,CAC5C,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;QAClB,4DAA4D;QAC5D,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,KAAK,kBAAkB,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACpF,OAAM;QACR,CAAC;QAED,OAAO,CAAC,GAAG,CAAC,kDAAkD,EAAE,IAAI,CAAC,CAAA;QAErE,KAAK,MAAM,KAAK,IAAI,GAAG,EAAE,CAAC;YACxB,KAAK,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAA;QACjC,CAAC;IACH,CAAC,CAAC,CAAA;IAEJ,OAAO;QACL,SAAS;QACT,KAAK;KACN,CAAA;AACH,CAAC,CAAC,CAAA"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"recreate-db.d.ts","sourceRoot":"","sources":["../../src/leader-thread/recreate-db.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AACzD,OAAO,EAAE,MAAM,EAAS,MAAM,yBAAyB,CAAA;AAEvD,OAAO,KAAK,EAAE,gBAAgB,EAAE,cAAc,EAAkB,gBAAgB,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAClH,OAAO,EAAkE,eAAe,EAAE,MAAM,aAAa,CAAA;AAE7G,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE5C,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,CACpC;IAAE,gBAAgB,EAAE,gBAAgB,CAAA;CAAE,EACtC,eAAe,GAAG,WAAW,GAAG,cAAc,GAAG,gBAAgB,EACjE,eAAe,GAAG,UAAU,CAAC,UAAU,
|
1
|
+
{"version":3,"file":"recreate-db.d.ts","sourceRoot":"","sources":["../../src/leader-thread/recreate-db.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAA;AACzD,OAAO,EAAE,MAAM,EAAS,MAAM,yBAAyB,CAAA;AAEvD,OAAO,KAAK,EAAE,gBAAgB,EAAE,cAAc,EAAkB,gBAAgB,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAClH,OAAO,EAAkE,eAAe,EAAE,MAAM,aAAa,CAAA;AAE7G,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE5C,eAAO,MAAM,UAAU,EAAE,MAAM,CAAC,MAAM,CACpC;IAAE,gBAAgB,EAAE,gBAAgB,CAAA;CAAE,EACtC,eAAe,GAAG,WAAW,GAAG,cAAc,GAAG,gBAAgB,EACjE,eAAe,GAAG,UAAU,CAAC,UAAU,CA8GxC,CAAA"}
|
@@ -4,7 +4,7 @@ import { initializeSingletonTables, migrateDb, rehydrateFromMutationLog, Unexpec
|
|
4
4
|
import { configureConnection } from './connection.js';
|
5
5
|
import { LeaderThreadCtx } from './types.js';
|
6
6
|
export const recreateDb = Effect.gen(function* () {
|
7
|
-
const { dbReadModel, dbMutationLog, schema, bootStatusQueue } = yield* LeaderThreadCtx;
|
7
|
+
const { dbReadModel, dbMutationLog, schema, bootStatusQueue, applyMutation } = yield* LeaderThreadCtx;
|
8
8
|
const migrationOptions = schema.migrationOptions;
|
9
9
|
let migrationsReport;
|
10
10
|
yield* Effect.addFinalizer(Effect.fn('recreateDb:finalizer')(function* (ex) {
|
@@ -34,10 +34,11 @@ export const recreateDb = Effect.gen(function* () {
|
|
34
34
|
const initResult = yield* initDb(hooks);
|
35
35
|
migrationsReport = initResult.migrationsReport;
|
36
36
|
yield* rehydrateFromMutationLog({
|
37
|
-
db: initResult.tmpDb,
|
38
|
-
|
37
|
+
// db: initResult.tmpDb,
|
38
|
+
dbMutationLog,
|
39
39
|
schema,
|
40
40
|
migrationOptions,
|
41
|
+
applyMutation,
|
41
42
|
onProgress: ({ done, total }) => Queue.offer(bootStatusQueue, { stage: 'rehydrating', progress: { done, total } }),
|
42
43
|
});
|
43
44
|
yield* Effect.tryAll(() => hooks?.post?.(initResult.tmpDb)).pipe(UnexpectedError.mapToUnexpectedError);
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"recreate-db.js","sourceRoot":"","sources":["../../src/leader-thread/recreate-db.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAE/C,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AAGvD,OAAO,EAAE,yBAAyB,EAAE,SAAS,EAAE,wBAAwB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAC7G,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAA;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE5C,MAAM,CAAC,MAAM,UAAU,GAInB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IACtB,MAAM,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,EAAE,eAAe,EAAE,GAAG,KAAK,CAAC,CAAC,eAAe,CAAA;
|
1
|
+
{"version":3,"file":"recreate-db.js","sourceRoot":"","sources":["../../src/leader-thread/recreate-db.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAE/C,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,yBAAyB,CAAA;AAGvD,OAAO,EAAE,yBAAyB,EAAE,SAAS,EAAE,wBAAwB,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAC7G,OAAO,EAAE,mBAAmB,EAAE,MAAM,iBAAiB,CAAA;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAE5C,MAAM,CAAC,MAAM,UAAU,GAInB,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;IACtB,MAAM,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,EAAE,eAAe,EAAE,aAAa,EAAE,GAAG,KAAK,CAAC,CAAC,eAAe,CAAA;IAErG,MAAM,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,CAAA;IAChD,IAAI,gBAAkC,CAAA;IAEtC,KAAK,CAAC,CAAC,MAAM,CAAC,YAAY,CACxB,MAAM,CAAC,EAAE,CAAC,sBAAsB,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE;QAC7C,IAAI,EAAE,CAAC,IAAI,KAAK,SAAS;YAAE,WAAW,CAAC,OAAO,EAAE,CAAA;IAClD,CAAC,CAAC,CACH,CAAA;IAED,uFAAuF;IACvF,qEAAqE;IACrE,oCAAoC;IACpC,2DAA2D;IAC3D,MAAM,KAAK,GAAG,WAAW,CAAA;IACzB,KAAK,CAAC,CAAC,mBAAmB,CAAC,KAAK,EAAE,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,CAAA;IAExD,MAAM,MAAM,GAAG,CAAC,KAA0C,EAAE,EAAE,CAC5D,MAAM,CAAC,GAAG,CAAC,QAAQ,CAAC;QAClB,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAA;QAE3F,MAAM,gBAAgB,GAAG,KAAK,CAAC,CAAC,SAAS,CAAC;YACxC,EAAE,EAAE,KAAK;YACT,MAAM;YACN,UAAU,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,CAC9B,KAAK,CAAC,KAAK,CAAC,eAAe,EAAE,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;SAClF,CAAC,CAAA;QAEF,yBAAyB,CAAC,MAAM,EAAE,KAAK,CAAC,CAAA;QAExC,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAA;QAE1F,OAAO,EAAE,gBAAgB,EAAE,KAAK,EAAE,CAAA;IACpC,CAAC,CAAC,CAAA;IAEJ,QAAQ,gBAAgB,CAAC,QAAQ,EAAE,CAAC;QAClC,KAAK,mBAAmB,CAAC,CAAC,CAAC;YACzB,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,CAAA;YACpC,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;YAEvC,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,CAAA;YAE9C,KAAK,CAAC,CAAC,wBAAwB,CAAC;gBAC9B,wBAAwB;gBACxB,aAAa;gBACb,MAAM;gBACN,gBAAgB;gBAChB,aAAa;gBACb,UAAU,EAAE,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,EAAE,CAC9B,KAAK,CAAC,KAAK,CAAC,eAAe,EAAE,EAAE,KAAK,EAAE,aAAa,EAAE,QAAQ,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;aACpF,CAAC,CAAA;YAEF,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAA;YAEtG,MAAK;QACP,CAAC;QACD,KAAK,YAAY,CAAC,CAAC,CAAC;YAClB,MAAM,KAAK,GAAG,gBAAgB,CAAC,KAAK,CAAA;YACpC,MAAM,UAAU,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;YAEvC,gBAAgB,GAAG,UAAU,CAAC,gBAAgB,CAAA;YAE9C,gEAAgE;YAEhE,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,oBAAoB,CAAC,CAAA;YAEtG,MAAK;QACP,CAAC;QACD,KAAK,QAAQ,CAAC,CAAC,CAAC;YACd,MAAM,SAAS,GAAG,WAAW,CAAC,MAAM,EAAE,CAAA;YAEtC,gBAAgB,GAAG,EAAE,UAAU,EAAE,EAAE,EAAE,CAAA;YAErC,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CACpF,eAAe,CAAC,oBAAoB,CACrC,CAAA;YAED,KAAK,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;YAEvB,uBAAuB;YAEvB,MAAK;QACP,CAAC;QACD,OAAO,CAAC,CAAC,CAAC;YACR,YAAY,CAAC,gBAAgB,CAAC,CAAA;QAChC,CAAC;IACH,CAAC;IAED,kBAAkB;IAClB,uEAAuE;IACvE,mDAAmD;IACnD,0EAA0E;IAC1E,IAAI;IAEJ,0FAA0F;IAC1F,mGAAmG;IACnG,0CAA0C;IAC1C,2CAA2C;IAE3C,kBAAkB;IAClB,gBAAgB;IAEhB,OAAO,EAAE,gBAAgB,EAAE,CAAA;AAC7B,CAAC,CAAC,CAAC,IAAI,CACL,MAAM,CAAC,MAAM,EAAE,qFAAqF;AACpG,MAAM,CAAC,QAAQ,CAAC,4CAA4C,CAAC,EAC7D,MAAM,CAAC,sBAAsB,CAAC,4CAA4C,CAAC,CAC5E,CAAA"}
|
@@ -1,5 +1,6 @@
|
|
1
|
-
import type { Deferred, Effect, HttpClient, Option, Queue, Scope, Subscribable, SubscriptionRef, WebChannel } from '@livestore/utils/effect';
|
1
|
+
import type { Deferred, Effect, HttpClient, Option, Queue, Scope, Stream, Subscribable, SubscriptionRef, WebChannel } from '@livestore/utils/effect';
|
2
2
|
import { Context, Schema } from '@livestore/utils/effect';
|
3
|
+
import type { LeaderPullCursor, SqliteError } from '../adapter-types.js';
|
3
4
|
import type { BootStatus, Devtools, LeaderAheadError, MakeSqliteDb, MigrationsReport, PersistenceInfo, SqliteDb, SyncBackend, UnexpectedError } from '../index.js';
|
4
5
|
import type { EventId, LiveStoreSchema, MutationEvent } from '../schema/mod.js';
|
5
6
|
import type * as SyncState from '../sync/syncstate.js';
|
@@ -59,7 +60,7 @@ declare const LeaderThreadCtx_base: Context.TagClass<LeaderThreadCtx, "LeaderThr
|
|
59
60
|
devtools: DevtoolsContext;
|
60
61
|
syncBackend: SyncBackend | undefined;
|
61
62
|
syncProcessor: LeaderSyncProcessor;
|
62
|
-
|
63
|
+
applyMutation: ApplyMutation;
|
63
64
|
initialState: {
|
64
65
|
leaderHead: EventId.EventId;
|
65
66
|
migrationsReport: MigrationsReport;
|
@@ -73,6 +74,18 @@ declare const LeaderThreadCtx_base: Context.TagClass<LeaderThreadCtx, "LeaderThr
|
|
73
74
|
}>;
|
74
75
|
export declare class LeaderThreadCtx extends LeaderThreadCtx_base {
|
75
76
|
}
|
77
|
+
export type ApplyMutation = (mutationEventEncoded: MutationEvent.EncodedWithMeta, options?: {
|
78
|
+
/** Needed for rehydrateFromMutationLog */
|
79
|
+
skipMutationLog?: boolean;
|
80
|
+
}) => Effect.Effect<{
|
81
|
+
sessionChangeset: {
|
82
|
+
_tag: 'sessionChangeset';
|
83
|
+
data: Uint8Array;
|
84
|
+
debug: any;
|
85
|
+
} | {
|
86
|
+
_tag: 'no-op';
|
87
|
+
};
|
88
|
+
}, SqliteError | UnexpectedError>;
|
76
89
|
export type InitialBlockingSyncContext = {
|
77
90
|
blockingDeferred: Deferred.Deferred<void> | undefined;
|
78
91
|
update: (_: {
|
@@ -80,40 +93,42 @@ export type InitialBlockingSyncContext = {
|
|
80
93
|
processed: number;
|
81
94
|
}) => Effect.Effect<void>;
|
82
95
|
};
|
83
|
-
export type PullQueueItem = {
|
84
|
-
payload: SyncState.PayloadUpstream;
|
85
|
-
remaining: number;
|
86
|
-
};
|
87
96
|
export interface LeaderSyncProcessor {
|
97
|
+
/** Used by client sessions to subscribe to upstream sync state changes */
|
98
|
+
pull: (args: {
|
99
|
+
cursor: LeaderPullCursor;
|
100
|
+
}) => Stream.Stream<{
|
101
|
+
payload: typeof SyncState.PayloadUpstream.Type;
|
102
|
+
mergeCounter: number;
|
103
|
+
}, UnexpectedError>;
|
104
|
+
/** The `pullQueue` API can be used instead of `pull` when more convenient */
|
105
|
+
pullQueue: (args: {
|
106
|
+
cursor: LeaderPullCursor;
|
107
|
+
}) => Effect.Effect<Queue.Queue<{
|
108
|
+
payload: typeof SyncState.PayloadUpstream.Type;
|
109
|
+
mergeCounter: number;
|
110
|
+
}>, UnexpectedError, Scope.Scope>;
|
111
|
+
/** Used by client sessions to push mutations to the leader thread */
|
88
112
|
push: (
|
89
113
|
/** `batch` needs to follow the same rules as `batch` in `SyncBackend.push` */
|
90
114
|
batch: ReadonlyArray<MutationEvent.EncodedWithMeta>, options?: {
|
91
|
-
/**
|
92
|
-
* This generation number is used to automatically reject subsequent pushes
|
93
|
-
* of a previously rejected push from a client session. This might occur in
|
94
|
-
* certain concurrent scenarios.
|
95
|
-
*/
|
96
115
|
/**
|
97
116
|
* If true, the effect will only finish when the local push has been processed (i.e. succeeded or was rejected).
|
98
117
|
* @default false
|
99
118
|
*/
|
100
119
|
waitForProcessing?: boolean;
|
101
120
|
}) => Effect.Effect<void, LeaderAheadError>;
|
121
|
+
/** Currently only used by devtools which don't provide their own event numbers */
|
102
122
|
pushPartial: (args: {
|
103
123
|
mutationEvent: MutationEvent.PartialAnyEncoded;
|
104
124
|
clientId: string;
|
105
125
|
sessionId: string;
|
106
|
-
}) => Effect.Effect<void, UnexpectedError
|
107
|
-
boot:
|
108
|
-
dbReady: Deferred.Deferred<void>;
|
109
|
-
}) => Effect.Effect<{
|
126
|
+
}) => Effect.Effect<void, UnexpectedError>;
|
127
|
+
boot: Effect.Effect<{
|
110
128
|
initialLeaderHead: EventId.EventId;
|
111
129
|
}, UnexpectedError, LeaderThreadCtx | Scope.Scope | HttpClient.HttpClient>;
|
112
130
|
syncState: Subscribable.Subscribable<SyncState.SyncState>;
|
113
|
-
|
114
|
-
export interface PullQueueSet {
|
115
|
-
makeQueue: (since: EventId.EventId) => Effect.Effect<Queue.Queue<PullQueueItem>, UnexpectedError, Scope.Scope | LeaderThreadCtx>;
|
116
|
-
offer: (item: PullQueueItem) => Effect.Effect<void, UnexpectedError, LeaderThreadCtx>;
|
131
|
+
getMergeCounter: () => number;
|
117
132
|
}
|
118
133
|
export {};
|
119
134
|
//# sourceMappingURL=types.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/leader-thread/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,QAAQ,EACR,MAAM,EACN,UAAU,EACV,MAAM,EACN,KAAK,EACL,KAAK,EACL,YAAY,EACZ,eAAe,EACf,UAAU,EACX,MAAM,yBAAyB,CAAA;AAChC,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAEzD,OAAO,KAAK,EACV,UAAU,EACV,QAAQ,EACR,gBAAgB,EAChB,YAAY,EACZ,gBAAgB,EAChB,eAAe,EACf,QAAQ,EACR,WAAW,EACX,eAAe,EAChB,MAAM,aAAa,CAAA;AACpB,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AAC/E,OAAO,KAAK,KAAK,SAAS,MAAM,sBAAsB,CAAA;AACtD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAA;AAE5D,MAAM,MAAM,aAAa,GAAG,SAAS,GAAG,eAAe,CAAA;AAEvD,eAAO,MAAM,sBAAsB,iCAAkC,CAAA;AACrE,MAAM,MAAM,sBAAsB,GAAG,OAAO,sBAAsB,CAAC,IAAI,CAAA;AAEvE,eAAO,MAAM,0BAA0B;;EAErC,CAAA;AAEF,MAAM,MAAM,0BAA0B,GAAG,OAAO,0BAA0B,CAAC,IAAI,CAAA;AAE/E,eAAO,MAAM,kBAAkB;;IAAmE,CAAA;AAClG,MAAM,MAAM,kBAAkB,GAAG,OAAO,kBAAkB,CAAC,IAAI,CAAA;AAE/D,MAAM,MAAM,eAAe,GAAG,MAAM,CAAC,MAAM,CAAC;IAC1C,MAAM,EAAE,OAAO,CAAC,OAAO,CAAA;IACvB,QAAQ,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAA;CAC1C,CAAC,CAAA;AAMF,MAAM,MAAM,cAAc,GAAG,QAAQ,CAAC;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,eAAe,EAAE,eAAe,CAAA;CAAE,CAAC,CAAA;AAC9F,MAAM,MAAM,mBAAmB,GAAG;IAAE,SAAS,EAAE,eAAe,CAAC;IAAC,WAAW,EAAE,eAAe,CAAA;CAAE,CAAA;AAE9F,MAAM,MAAM,eAAe,GACvB;IACE,OAAO,EAAE,KAAK,CAAA;CACf,GACD;IACE,OAAO,EAAE,IAAI,CAAA;IACb,eAAe,EAAE,MAAM,CAAC,MAAM,CAC5B;QACE,kBAAkB,EAAE,UAAU,CAAC,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,YAAY,EAAE,QAAQ,CAAC,MAAM,CAAC,cAAc,CAAC,CAAA;QACvG,eAAe,EAAE,mBAAmB,CAAA;KACrC,EACD,eAAe,EACf,KAAK,CAAC,KAAK,CACZ,CAAA;CACF,CAAA;AAEL,MAAM,MAAM,eAAe,GACvB;IACE,OAAO,EAAE,IAAI,CAAA;IAGb,gBAAgB,EAAE,MAAM,CAAC,KAAK,CAAA;IAC9B,qBAAqB,EAAE,eAAe,CAAC,eAAe,CAAC;QAAE,WAAW,EAAE,OAAO,CAAA;KAAE,CAAC,CAAA;CACjF,GACD;IACE,OAAO,EAAE,KAAK,CAAA;CACf,CAAA;;YAKO,eAAe;aACd,MAAM;cACL,MAAM;kBACF,YAAY;iBACb,cAAc;mBACZ,cAAc;qBACZ,KAAK,CAAC,KAAK,CAAC,UAAU,CAAC;yBAEnB,eAAe,CAAC,eAAe,CAAC,aAAa,CAAC;qBAClD,eAAe;yBACX,aAAa,CAAC,oBAAoB,CAAC,GAAG,CAAC;cAClD,eAAe;iBACZ,WAAW,GAAG,SAAS;mBACrB,mBAAmB;
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/leader-thread/types.ts"],"names":[],"mappings":"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"}
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/leader-thread/types.ts"],"names":[],"mappings":"
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/leader-thread/types.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAoBzD,MAAM,CAAC,MAAM,sBAAsB,GAAG,MAAM,CAAC,YAAY,CAAC,MAAM,EAAE,EAAE,CAAC,CAAA;AAGrE,MAAM,CAAC,MAAM,0BAA0B,GAAG,MAAM,CAAC,YAAY,CAAC,UAAU,EAAE;IACxE,OAAO,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,CAAC;CAChE,CAAC,CAAA;AAIF,MAAM,CAAC,MAAM,kBAAkB,GAAG,MAAM,CAAC,KAAK,CAAC,sBAAsB,EAAE,0BAA0B,CAAC,CAAA;AA2ClG,MAAM,OAAO,eAAgB,SAAQ,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,EA6BhE;CAAG"}
|
@@ -1,14 +1,15 @@
|
|
1
1
|
import { Effect } from '@livestore/utils/effect';
|
2
2
|
import { type MigrationOptionsFromMutationLog, type SqliteDb, UnexpectedError } from './adapter-types.js';
|
3
|
+
import type { ApplyMutation } from './leader-thread/mod.js';
|
3
4
|
import type { LiveStoreSchema } from './schema/mod.js';
|
4
|
-
export declare const rehydrateFromMutationLog: ({
|
5
|
-
|
6
|
-
db: SqliteDb;
|
5
|
+
export declare const rehydrateFromMutationLog: ({ dbMutationLog, schema, migrationOptions, onProgress, applyMutation, }: {
|
6
|
+
dbMutationLog: SqliteDb;
|
7
7
|
schema: LiveStoreSchema;
|
8
8
|
migrationOptions: MigrationOptionsFromMutationLog;
|
9
9
|
onProgress: (_: {
|
10
10
|
done: number;
|
11
11
|
total: number;
|
12
12
|
}) => Effect.Effect<void>;
|
13
|
-
|
13
|
+
applyMutation: ApplyMutation;
|
14
|
+
}) => Effect.Effect<void, UnexpectedError | import("./adapter-types.js").SqliteError, never>;
|
14
15
|
//# sourceMappingURL=rehydrate-from-mutationlog.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"rehydrate-from-mutationlog.d.ts","sourceRoot":"","sources":["../src/rehydrate-from-mutationlog.ts"],"names":[],"mappings":"AACA,OAAO,EAAS,MAAM,EAA0B,MAAM,yBAAyB,CAAA;AAE/E,OAAO,EAAE,KAAK,+BAA+B,EAAE,KAAK,QAAQ,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;
|
1
|
+
{"version":3,"file":"rehydrate-from-mutationlog.d.ts","sourceRoot":"","sources":["../src/rehydrate-from-mutationlog.ts"],"names":[],"mappings":"AACA,OAAO,EAAS,MAAM,EAA0B,MAAM,yBAAyB,CAAA;AAE/E,OAAO,EAAE,KAAK,+BAA+B,EAAE,KAAK,QAAQ,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAA;AACzG,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAA;AAC3D,OAAO,KAAK,EAAE,eAAe,EAAmC,MAAM,iBAAiB,CAAA;AAKvF,eAAO,MAAM,wBAAwB,GAAI,yEAQtC;IACD,aAAa,EAAE,QAAQ,CAAA;IAEvB,MAAM,EAAE,eAAe,CAAA;IACvB,gBAAgB,EAAE,+BAA+B,CAAA;IACjD,UAAU,EAAE,CAAC,CAAC,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IACvE,aAAa,EAAE,aAAa,CAAA;CAC7B,2FA+FE,CAAA"}
|
@@ -1,16 +1,14 @@
|
|
1
1
|
import { memoizeByRef } from '@livestore/utils';
|
2
2
|
import { Chunk, Effect, Option, Schema, Stream } from '@livestore/utils/effect';
|
3
3
|
import { UnexpectedError } from './adapter-types.js';
|
4
|
-
import {
|
5
|
-
import { EventId, getMutationDef, MUTATION_LOG_META_TABLE } from './schema/mod.js';
|
4
|
+
import { EventId, getMutationDef, MUTATION_LOG_META_TABLE, MutationEvent } from './schema/mod.js';
|
6
5
|
import { sql } from './util.js';
|
7
|
-
export const rehydrateFromMutationLog = ({
|
6
|
+
export const rehydrateFromMutationLog = ({ dbMutationLog,
|
8
7
|
// TODO re-use this db when bringing back the boot in-memory db implementation
|
9
8
|
// db,
|
10
|
-
schema, migrationOptions, onProgress, }) => Effect.gen(function* () {
|
11
|
-
const mutationsCount =
|
9
|
+
schema, migrationOptions, onProgress, applyMutation, }) => Effect.gen(function* () {
|
10
|
+
const mutationsCount = dbMutationLog.select(`SELECT COUNT(*) AS count FROM ${MUTATION_LOG_META_TABLE}`)[0].count;
|
12
11
|
const hashMutation = memoizeByRef((mutation) => Schema.hash(mutation.schema));
|
13
|
-
const applyMutation = yield* makeApplyMutation;
|
14
12
|
const processMutation = (row) => Effect.gen(function* () {
|
15
13
|
const mutationDef = getMutationDef(schema, row.mutation);
|
16
14
|
if (migrationOptions.excludeMutations?.has(row.mutation) === true)
|
@@ -28,18 +26,18 @@ the persisted mutation event args for mutation "${row.mutation}".
|
|
28
26
|
This likely means the schema has changed in an incompatible way.
|
29
27
|
`,
|
30
28
|
})));
|
31
|
-
const mutationEventEncoded = {
|
29
|
+
const mutationEventEncoded = MutationEvent.EncodedWithMeta.make({
|
32
30
|
id: { global: row.idGlobal, client: row.idClient },
|
33
31
|
parentId: { global: row.parentIdGlobal, client: row.parentIdClient },
|
34
32
|
mutation: row.mutation,
|
35
33
|
args,
|
36
34
|
clientId: row.clientId,
|
37
35
|
sessionId: row.sessionId,
|
38
|
-
};
|
36
|
+
});
|
39
37
|
yield* applyMutation(mutationEventEncoded, { skipMutationLog: true });
|
40
38
|
}).pipe(Effect.withSpan(`@livestore/common:rehydrateFromMutationLog:processMutation`));
|
41
39
|
const CHUNK_SIZE = 100;
|
42
|
-
const stmt =
|
40
|
+
const stmt = dbMutationLog.prepare(sql `\
|
43
41
|
SELECT * FROM ${MUTATION_LOG_META_TABLE}
|
44
42
|
WHERE idGlobal > $idGlobal OR (idGlobal = $idGlobal AND idClient > $idClient)
|
45
43
|
ORDER BY idGlobal ASC, idClient ASC
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"rehydrate-from-mutationlog.js","sourceRoot":"","sources":["../src/rehydrate-from-mutationlog.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAA;AAC/C,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAE/E,OAAO,EAAuD,eAAe,EAAE,MAAM,oBAAoB,CAAA;
|
1
|
+
{"version":3,"file":"rehydrate-from-mutationlog.js","sourceRoot":"","sources":["../src/rehydrate-from-mutationlog.ts"],"names":[],"mappings":"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"}
|
package/dist/schema/EventId.d.ts
CHANGED
@@ -16,8 +16,12 @@ export type EventId = {
|
|
16
16
|
global: GlobalEventId;
|
17
17
|
client: ClientEventId;
|
18
18
|
};
|
19
|
+
/**
|
20
|
+
* NOTE: Client mutation events with a non-0 client id, won't be synced to the sync backend.
|
21
|
+
*/
|
19
22
|
export declare const EventId: Schema.Struct<{
|
20
23
|
global: Schema.BrandSchema<number & Brand.Brand<"GlobalEventId">, number, never>;
|
24
|
+
/** Only increments for clientOnly mutations */
|
21
25
|
client: Schema.BrandSchema<number & Brand.Brand<"ClientEventId">, number, never>;
|
22
26
|
}>;
|
23
27
|
/**
|
@@ -43,6 +47,11 @@ export declare const ROOT: {
|
|
43
47
|
};
|
44
48
|
export declare const isGreaterThan: (a: EventId, b: EventId) => boolean;
|
45
49
|
export declare const isGreaterThanOrEqual: (a: EventId, b: EventId) => boolean;
|
50
|
+
export declare const max: (a: EventId, b: EventId) => EventId;
|
51
|
+
export declare const diff: (a: EventId, b: EventId) => {
|
52
|
+
global: number;
|
53
|
+
client: number;
|
54
|
+
};
|
46
55
|
export declare const make: (id: EventId | typeof EventId.Encoded) => EventId;
|
47
56
|
export declare const nextPair: (id: EventId, isLocal: boolean) => EventIdPair;
|
48
57
|
//# sourceMappingURL=EventId.d.ts.map
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"EventId.d.ts","sourceRoot":"","sources":["../../src/schema/EventId.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAEvD,MAAM,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;AAClE,eAAO,MAAM,YAAY,wCAAiC,CAAA;AAC1D,eAAO,MAAM,aAAa,0EAA6C,CAAA;AAEvE,MAAM,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;AAClE,eAAO,MAAM,aAAa,wCAAiC,CAAA;AAC3D,eAAO,MAAM,aAAa,0EAA8C,CAAA;AAExE,eAAO,MAAM,aAAa,EAAe,aAAa,CAAA;AAEtD;;;;;GAKG;AACH,MAAM,MAAM,OAAO,GAAG;IAAE,MAAM,EAAE,aAAa,CAAC;IAAC,MAAM,EAAE,aAAa,CAAA;CAAE,CAAA;
|
1
|
+
{"version":3,"file":"EventId.d.ts","sourceRoot":"","sources":["../../src/schema/EventId.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,yBAAyB,CAAA;AAEvD,MAAM,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;AAClE,eAAO,MAAM,YAAY,wCAAiC,CAAA;AAC1D,eAAO,MAAM,aAAa,0EAA6C,CAAA;AAEvE,MAAM,MAAM,aAAa,GAAG,KAAK,CAAC,OAAO,CAAC,MAAM,EAAE,eAAe,CAAC,CAAA;AAClE,eAAO,MAAM,aAAa,wCAAiC,CAAA;AAC3D,eAAO,MAAM,aAAa,0EAA8C,CAAA;AAExE,eAAO,MAAM,aAAa,EAAe,aAAa,CAAA;AAEtD;;;;;GAKG;AACH,MAAM,MAAM,OAAO,GAAG;IAAE,MAAM,EAAE,aAAa,CAAC;IAAC,MAAM,EAAE,aAAa,CAAA;CAAE,CAAA;AAKtE;;GAEG;AACH,eAAO,MAAM,OAAO;;IAElB,+CAA+C;;EAEH,CAAA;AAE9C;;GAEG;AACH,eAAO,MAAM,OAAO,GAAI,GAAG,OAAO,EAAE,GAAG,OAAO,WAK7C,CAAA;AAED;;GAEG;AACH,eAAO,MAAM,QAAQ,GAAI,IAAI,OAAO,WAAuE,CAAA;AAE3G;;GAEG;AACH,eAAO,MAAM,UAAU,GAAI,KAAK,MAAM,KAAG,OAMxC,CAAA;AAED,eAAO,MAAM,OAAO,GAAI,GAAG,OAAO,EAAE,GAAG,OAAO,YAAmD,CAAA;AAEjG,MAAM,MAAM,WAAW,GAAG;IAAE,EAAE,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,OAAO,CAAA;CAAE,CAAA;AAE5D,eAAO,MAAM,IAAI;YAAyB,aAAa;;CAA2C,CAAA;AAElG,eAAO,MAAM,aAAa,GAAI,GAAG,OAAO,EAAE,GAAG,OAAO,YAEnD,CAAA;AAED,eAAO,MAAM,oBAAoB,GAAI,GAAG,OAAO,EAAE,GAAG,OAAO,YAE1D,CAAA;AAED,eAAO,MAAM,GAAG,GAAI,GAAG,OAAO,EAAE,GAAG,OAAO,YAEzC,CAAA;AAED,eAAO,MAAM,IAAI,GAAI,GAAG,OAAO,EAAE,GAAG,OAAO;;;CAK1C,CAAA;AAED,eAAO,MAAM,IAAI,GAAI,IAAI,OAAO,GAAG,OAAO,OAAO,CAAC,OAAO,KAAG,OAE3D,CAAA;AAED,eAAO,MAAM,QAAQ,GAAI,IAAI,OAAO,EAAE,SAAS,OAAO,KAAG,WAUxD,CAAA"}
|
package/dist/schema/EventId.js
CHANGED
@@ -4,8 +4,14 @@ export const ClientEventId = Schema.fromBrand(localEventId)(Schema.Int);
|
|
4
4
|
export const globalEventId = Brand.nominal();
|
5
5
|
export const GlobalEventId = Schema.fromBrand(globalEventId)(Schema.Int);
|
6
6
|
export const clientDefault = 0;
|
7
|
+
// export const EventSequenceNumber = Schema.Struct({})
|
8
|
+
// export const EventNumber = Schema.Struct({})
|
9
|
+
/**
|
10
|
+
* NOTE: Client mutation events with a non-0 client id, won't be synced to the sync backend.
|
11
|
+
*/
|
7
12
|
export const EventId = Schema.Struct({
|
8
13
|
global: GlobalEventId,
|
14
|
+
/** Only increments for clientOnly mutations */
|
9
15
|
client: ClientEventId,
|
10
16
|
}).annotations({ title: 'LiveStore.EventId' });
|
11
17
|
/**
|
@@ -20,7 +26,7 @@ export const compare = (a, b) => {
|
|
20
26
|
/**
|
21
27
|
* Convert an event id to a string representation.
|
22
28
|
*/
|
23
|
-
export const toString = (id) => `
|
29
|
+
export const toString = (id) => (id.client === 0 ? `e${id.global}` : `e${id.global}+${id.client}`);
|
24
30
|
/**
|
25
31
|
* Convert a string representation of an event id to an event id.
|
26
32
|
*/
|
@@ -32,13 +38,22 @@ export const fromString = (str) => {
|
|
32
38
|
return { global, client };
|
33
39
|
};
|
34
40
|
export const isEqual = (a, b) => a.global === b.global && a.client === b.client;
|
35
|
-
export const ROOT = { global:
|
41
|
+
export const ROOT = { global: 0, client: clientDefault };
|
36
42
|
export const isGreaterThan = (a, b) => {
|
37
43
|
return a.global > b.global || (a.global === b.global && a.client > b.client);
|
38
44
|
};
|
39
45
|
export const isGreaterThanOrEqual = (a, b) => {
|
40
46
|
return a.global > b.global || (a.global === b.global && a.client >= b.client);
|
41
47
|
};
|
48
|
+
export const max = (a, b) => {
|
49
|
+
return a.global > b.global || (a.global === b.global && a.client > b.client) ? a : b;
|
50
|
+
};
|
51
|
+
export const diff = (a, b) => {
|
52
|
+
return {
|
53
|
+
global: a.global - b.global,
|
54
|
+
client: a.client - b.client,
|
55
|
+
};
|
56
|
+
};
|
42
57
|
export const make = (id) => {
|
43
58
|
return Schema.is(EventId)(id) ? id : Schema.decodeSync(EventId)(id);
|
44
59
|
};
|