@livestore/common 0.2.0 → 0.3.0-dev.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (243) hide show
  1. package/dist/.tsbuildinfo +1 -1
  2. package/dist/__tests__/fixture.d.ts +163 -1
  3. package/dist/__tests__/fixture.d.ts.map +1 -1
  4. package/dist/__tests__/fixture.js +3 -1
  5. package/dist/__tests__/fixture.js.map +1 -1
  6. package/dist/adapter-types.d.ts +53 -38
  7. package/dist/adapter-types.d.ts.map +1 -1
  8. package/dist/adapter-types.js +5 -7
  9. package/dist/adapter-types.js.map +1 -1
  10. package/dist/bounded-collections.d.ts +2 -2
  11. package/dist/bounded-collections.d.ts.map +1 -1
  12. package/dist/debug-info.d.ts +13 -13
  13. package/dist/derived-mutations.d.ts +1 -1
  14. package/dist/derived-mutations.d.ts.map +1 -1
  15. package/dist/devtools/devtools-bridge.d.ts +2 -2
  16. package/dist/devtools/devtools-bridge.d.ts.map +1 -1
  17. package/dist/devtools/devtools-messages.d.ts +84 -196
  18. package/dist/devtools/devtools-messages.d.ts.map +1 -1
  19. package/dist/devtools/devtools-messages.js +55 -61
  20. package/dist/devtools/devtools-messages.js.map +1 -1
  21. package/dist/devtools/index.d.ts.map +1 -1
  22. package/dist/devtools/index.js +1 -2
  23. package/dist/devtools/index.js.map +1 -1
  24. package/dist/index.d.ts +2 -1
  25. package/dist/index.d.ts.map +1 -1
  26. package/dist/index.js +2 -1
  27. package/dist/index.js.map +1 -1
  28. package/dist/init-singleton-tables.d.ts +1 -1
  29. package/dist/init-singleton-tables.d.ts.map +1 -1
  30. package/dist/leader-thread/apply-mutation.d.ts +8 -0
  31. package/dist/leader-thread/apply-mutation.d.ts.map +1 -0
  32. package/dist/leader-thread/apply-mutation.js +95 -0
  33. package/dist/leader-thread/apply-mutation.js.map +1 -0
  34. package/dist/leader-thread/connection.d.ts +11 -0
  35. package/dist/leader-thread/connection.d.ts.map +1 -0
  36. package/dist/leader-thread/connection.js +44 -0
  37. package/dist/leader-thread/connection.js.map +1 -0
  38. package/dist/leader-thread/leader-sync-processor.d.ts +47 -0
  39. package/dist/leader-thread/leader-sync-processor.d.ts.map +1 -0
  40. package/dist/leader-thread/leader-sync-processor.js +422 -0
  41. package/dist/leader-thread/leader-sync-processor.js.map +1 -0
  42. package/dist/leader-thread/leader-worker-devtools.d.ts +6 -0
  43. package/dist/leader-thread/leader-worker-devtools.d.ts.map +1 -0
  44. package/dist/leader-thread/leader-worker-devtools.js +216 -0
  45. package/dist/leader-thread/leader-worker-devtools.js.map +1 -0
  46. package/dist/leader-thread/make-leader-thread-layer.d.ts +20 -0
  47. package/dist/leader-thread/make-leader-thread-layer.d.ts.map +1 -0
  48. package/dist/leader-thread/make-leader-thread-layer.js +106 -0
  49. package/dist/leader-thread/make-leader-thread-layer.js.map +1 -0
  50. package/dist/leader-thread/mod.d.ts +7 -0
  51. package/dist/leader-thread/mod.d.ts.map +1 -0
  52. package/dist/leader-thread/mod.js +7 -0
  53. package/dist/leader-thread/mod.js.map +1 -0
  54. package/dist/leader-thread/mutationlog.d.ts +23 -0
  55. package/dist/leader-thread/mutationlog.d.ts.map +1 -0
  56. package/dist/leader-thread/mutationlog.js +27 -0
  57. package/dist/leader-thread/mutationlog.js.map +1 -0
  58. package/dist/leader-thread/pull-queue-set.d.ts +7 -0
  59. package/dist/leader-thread/pull-queue-set.d.ts.map +1 -0
  60. package/dist/leader-thread/pull-queue-set.js +39 -0
  61. package/dist/leader-thread/pull-queue-set.js.map +1 -0
  62. package/dist/leader-thread/recreate-db.d.ts +7 -0
  63. package/dist/leader-thread/recreate-db.d.ts.map +1 -0
  64. package/dist/leader-thread/recreate-db.js +69 -0
  65. package/dist/leader-thread/recreate-db.js.map +1 -0
  66. package/dist/leader-thread/shutdown-channel.d.ts +15 -0
  67. package/dist/leader-thread/shutdown-channel.d.ts.map +1 -0
  68. package/dist/leader-thread/shutdown-channel.js +7 -0
  69. package/dist/leader-thread/shutdown-channel.js.map +1 -0
  70. package/dist/leader-thread/types.d.ts +87 -0
  71. package/dist/leader-thread/types.d.ts.map +1 -0
  72. package/dist/leader-thread/types.js +11 -0
  73. package/dist/leader-thread/types.js.map +1 -0
  74. package/dist/mutation.d.ts +3 -4
  75. package/dist/mutation.d.ts.map +1 -1
  76. package/dist/mutation.js +0 -14
  77. package/dist/mutation.js.map +1 -1
  78. package/dist/otel.d.ts +7 -0
  79. package/dist/otel.d.ts.map +1 -0
  80. package/dist/otel.js +11 -0
  81. package/dist/otel.js.map +1 -0
  82. package/dist/query-builder/api.d.ts +2 -2
  83. package/dist/query-builder/api.d.ts.map +1 -1
  84. package/dist/query-builder/api.js.map +1 -1
  85. package/dist/query-builder/impl.d.ts +1 -1
  86. package/dist/query-builder/impl.d.ts.map +1 -1
  87. package/dist/query-builder/impl.js +21 -4
  88. package/dist/query-builder/impl.js.map +1 -1
  89. package/dist/query-builder/impl.test.js +24 -1
  90. package/dist/query-builder/impl.test.js.map +1 -1
  91. package/dist/query-info.d.ts +1 -1
  92. package/dist/query-info.d.ts.map +1 -1
  93. package/dist/rehydrate-from-mutationlog.d.ts +1 -1
  94. package/dist/rehydrate-from-mutationlog.d.ts.map +1 -1
  95. package/dist/rehydrate-from-mutationlog.js +6 -6
  96. package/dist/rehydrate-from-mutationlog.js.map +1 -1
  97. package/dist/schema/EventId.d.ts +37 -0
  98. package/dist/schema/EventId.d.ts.map +1 -0
  99. package/dist/schema/EventId.js +30 -0
  100. package/dist/schema/EventId.js.map +1 -0
  101. package/dist/schema/MutationEvent.d.ts +191 -0
  102. package/dist/schema/MutationEvent.d.ts.map +1 -0
  103. package/dist/schema/MutationEvent.js +56 -0
  104. package/dist/schema/MutationEvent.js.map +1 -0
  105. package/dist/schema/mod.d.ts +8 -0
  106. package/dist/schema/mod.d.ts.map +1 -0
  107. package/dist/schema/mod.js +8 -0
  108. package/dist/schema/mod.js.map +1 -0
  109. package/dist/schema/mutations.d.ts +3 -123
  110. package/dist/schema/mutations.d.ts.map +1 -1
  111. package/dist/schema/mutations.js +0 -26
  112. package/dist/schema/mutations.js.map +1 -1
  113. package/dist/schema/{index.d.ts → schema.d.ts} +1 -5
  114. package/dist/schema/schema.d.ts.map +1 -0
  115. package/dist/schema/{index.js → schema.js} +1 -5
  116. package/dist/schema/schema.js.map +1 -0
  117. package/dist/schema/system-tables.d.ts +55 -29
  118. package/dist/schema/system-tables.d.ts.map +1 -1
  119. package/dist/schema/system-tables.js +10 -5
  120. package/dist/schema/system-tables.js.map +1 -1
  121. package/dist/schema-management/migrations.d.ts +1 -1
  122. package/dist/schema-management/migrations.d.ts.map +1 -1
  123. package/dist/schema-management/migrations.js +6 -1
  124. package/dist/schema-management/migrations.js.map +1 -1
  125. package/dist/schema-management/validate-mutation-defs.d.ts +1 -1
  126. package/dist/schema-management/validate-mutation-defs.d.ts.map +1 -1
  127. package/dist/sync/client-session-sync-processor.d.ts +45 -0
  128. package/dist/sync/client-session-sync-processor.d.ts.map +1 -0
  129. package/dist/sync/client-session-sync-processor.js +131 -0
  130. package/dist/sync/client-session-sync-processor.js.map +1 -0
  131. package/dist/sync/index.d.ts +2 -0
  132. package/dist/sync/index.d.ts.map +1 -1
  133. package/dist/sync/index.js +2 -0
  134. package/dist/sync/index.js.map +1 -1
  135. package/dist/sync/next/compact-events.d.ts +1 -1
  136. package/dist/sync/next/compact-events.d.ts.map +1 -1
  137. package/dist/sync/next/compact-events.js +2 -1
  138. package/dist/sync/next/compact-events.js.map +1 -1
  139. package/dist/sync/next/facts.d.ts +5 -5
  140. package/dist/sync/next/facts.d.ts.map +1 -1
  141. package/dist/sync/next/facts.js +1 -1
  142. package/dist/sync/next/facts.js.map +1 -1
  143. package/dist/sync/next/history-dag-common.d.ts +30 -0
  144. package/dist/sync/next/history-dag-common.d.ts.map +1 -0
  145. package/dist/sync/next/history-dag-common.js +20 -0
  146. package/dist/sync/next/history-dag-common.js.map +1 -0
  147. package/dist/sync/next/history-dag.d.ts +4 -27
  148. package/dist/sync/next/history-dag.d.ts.map +1 -1
  149. package/dist/sync/next/history-dag.js +1 -19
  150. package/dist/sync/next/history-dag.js.map +1 -1
  151. package/dist/sync/next/mod.d.ts +1 -0
  152. package/dist/sync/next/mod.d.ts.map +1 -1
  153. package/dist/sync/next/mod.js +1 -0
  154. package/dist/sync/next/mod.js.map +1 -1
  155. package/dist/sync/next/rebase-events.d.ts +3 -2
  156. package/dist/sync/next/rebase-events.d.ts.map +1 -1
  157. package/dist/sync/next/rebase-events.js.map +1 -1
  158. package/dist/sync/next/test/compact-events.test.d.ts.map +1 -1
  159. package/dist/sync/next/test/compact-events.test.js +2 -1
  160. package/dist/sync/next/test/compact-events.test.js.map +1 -1
  161. package/dist/sync/next/test/mutation-fixtures.d.ts +1 -1
  162. package/dist/sync/next/test/mutation-fixtures.d.ts.map +1 -1
  163. package/dist/sync/next/test/mutation-fixtures.js +4 -3
  164. package/dist/sync/next/test/mutation-fixtures.js.map +1 -1
  165. package/dist/sync/sync.d.ts +33 -12
  166. package/dist/sync/sync.d.ts.map +1 -1
  167. package/dist/sync/sync.js +10 -1
  168. package/dist/sync/sync.js.map +1 -1
  169. package/dist/sync/syncstate.d.ts +123 -0
  170. package/dist/sync/syncstate.d.ts.map +1 -0
  171. package/dist/sync/syncstate.js +248 -0
  172. package/dist/sync/syncstate.js.map +1 -0
  173. package/dist/sync/syncstate.test.d.ts +2 -0
  174. package/dist/sync/syncstate.test.d.ts.map +1 -0
  175. package/dist/sync/syncstate.test.js +399 -0
  176. package/dist/sync/syncstate.test.js.map +1 -0
  177. package/dist/sync/validate-push-payload.d.ts +5 -0
  178. package/dist/sync/validate-push-payload.d.ts.map +1 -0
  179. package/dist/sync/validate-push-payload.js +15 -0
  180. package/dist/sync/validate-push-payload.js.map +1 -0
  181. package/dist/util.d.ts +2 -2
  182. package/dist/util.d.ts.map +1 -1
  183. package/dist/version.d.ts +2 -2
  184. package/dist/version.d.ts.map +1 -1
  185. package/dist/version.js +2 -2
  186. package/package.json +13 -6
  187. package/src/__tests__/fixture.ts +5 -1
  188. package/src/adapter-types.ts +60 -34
  189. package/src/derived-mutations.test.ts +1 -1
  190. package/src/derived-mutations.ts +1 -1
  191. package/src/devtools/devtools-bridge.ts +2 -2
  192. package/src/devtools/devtools-messages.ts +70 -74
  193. package/src/devtools/index.ts +1 -2
  194. package/src/index.ts +2 -1
  195. package/src/init-singleton-tables.ts +1 -1
  196. package/src/leader-thread/apply-mutation.ts +143 -0
  197. package/src/leader-thread/connection.ts +67 -0
  198. package/src/leader-thread/leader-sync-processor.ts +666 -0
  199. package/src/leader-thread/leader-worker-devtools.ts +358 -0
  200. package/src/leader-thread/make-leader-thread-layer.ts +192 -0
  201. package/src/leader-thread/mod.ts +6 -0
  202. package/src/leader-thread/mutationlog.ts +42 -0
  203. package/src/leader-thread/pull-queue-set.ts +58 -0
  204. package/src/leader-thread/recreate-db.ts +109 -0
  205. package/src/leader-thread/shutdown-channel.ts +13 -0
  206. package/src/leader-thread/types.ts +129 -0
  207. package/src/mutation.ts +3 -21
  208. package/src/otel.ts +20 -0
  209. package/src/query-builder/api.ts +3 -2
  210. package/src/query-builder/impl.test.ts +28 -1
  211. package/src/query-builder/impl.ts +21 -5
  212. package/src/query-info.ts +1 -1
  213. package/src/rehydrate-from-mutationlog.ts +7 -11
  214. package/src/schema/EventId.ts +46 -0
  215. package/src/schema/MutationEvent.ts +161 -0
  216. package/src/schema/mod.ts +7 -0
  217. package/src/schema/mutations.ts +5 -126
  218. package/src/schema/{index.ts → schema.ts} +0 -5
  219. package/src/schema/system-tables.ts +18 -5
  220. package/src/schema-management/migrations.ts +9 -2
  221. package/src/schema-management/validate-mutation-defs.ts +1 -1
  222. package/src/sync/client-session-sync-processor.ts +207 -0
  223. package/src/sync/index.ts +2 -0
  224. package/src/sync/next/compact-events.ts +3 -2
  225. package/src/sync/next/facts.ts +11 -5
  226. package/src/sync/next/history-dag-common.ts +44 -0
  227. package/src/sync/next/history-dag.ts +3 -45
  228. package/src/sync/next/mod.ts +1 -0
  229. package/src/sync/next/rebase-events.ts +6 -5
  230. package/src/sync/next/test/compact-events.test.ts +3 -2
  231. package/src/sync/next/test/mutation-fixtures.ts +7 -6
  232. package/src/sync/sync.ts +32 -12
  233. package/src/sync/syncstate.test.ts +464 -0
  234. package/src/sync/syncstate.ts +385 -0
  235. package/src/sync/validate-push-payload.ts +18 -0
  236. package/src/version.ts +2 -2
  237. package/dist/schema/index.d.ts.map +0 -1
  238. package/dist/schema/index.js.map +0 -1
  239. package/dist/sync/next-mutation-event-id-pair.d.ts +0 -14
  240. package/dist/sync/next-mutation-event-id-pair.d.ts.map +0 -1
  241. package/dist/sync/next-mutation-event-id-pair.js +0 -13
  242. package/dist/sync/next-mutation-event-id-pair.js.map +0 -1
  243. package/src/sync/next-mutation-event-id-pair.ts +0 -20
@@ -0,0 +1,248 @@
1
+ import { shouldNeverHappen } from '@livestore/utils';
2
+ import { ReadonlyArray, Schema } from '@livestore/utils/effect';
3
+ import * as EventId from '../schema/EventId.js';
4
+ import * as MutationEvent from '../schema/MutationEvent.js';
5
+ export const SyncState = Schema.Struct({
6
+ pending: Schema.Array(MutationEvent.EncodedWithMeta),
7
+ rollbackTail: Schema.Array(MutationEvent.EncodedWithMeta),
8
+ upstreamHead: EventId.EventId,
9
+ localHead: EventId.EventId,
10
+ }).annotations({ title: 'SyncState' });
11
+ export class PayloadUpstreamRebase extends Schema.TaggedStruct('upstream-rebase', {
12
+ /** Rollback until this event in the rollback tail (inclusive). Starting from the end of the rollback tail. */
13
+ rollbackUntil: EventId.EventId,
14
+ newEvents: Schema.Array(MutationEvent.EncodedWithMeta),
15
+ /** Trim rollback tail up to this event (inclusive). */
16
+ trimRollbackUntil: Schema.optional(EventId.EventId),
17
+ }) {
18
+ }
19
+ export class PayloadUpstreamAdvance extends Schema.TaggedStruct('upstream-advance', {
20
+ newEvents: Schema.Array(MutationEvent.EncodedWithMeta),
21
+ /** Trim rollback tail up to this event (inclusive). */
22
+ trimRollbackUntil: Schema.optional(EventId.EventId),
23
+ }) {
24
+ }
25
+ export class PayloadLocalPush extends Schema.TaggedStruct('local-push', {
26
+ newEvents: Schema.Array(MutationEvent.EncodedWithMeta),
27
+ }) {
28
+ }
29
+ export class Payload extends Schema.Union(PayloadUpstreamRebase, PayloadUpstreamAdvance, PayloadLocalPush) {
30
+ }
31
+ export const PayloadUpstream = Schema.Union(PayloadUpstreamRebase, PayloadUpstreamAdvance);
32
+ export const updateSyncState = ({ syncState, payload, isLocalEvent, isEqualEvent, ignoreLocalEvents = false, }) => {
33
+ const trimRollbackTail = (rollbackTail) => {
34
+ const trimRollbackUntil = payload._tag === 'local-push' ? undefined : payload.trimRollbackUntil;
35
+ if (trimRollbackUntil === undefined)
36
+ return rollbackTail;
37
+ const index = rollbackTail.findIndex((event) => EventId.isEqual(event.id, trimRollbackUntil));
38
+ if (index === -1)
39
+ return [];
40
+ return rollbackTail.slice(index + 1);
41
+ };
42
+ switch (payload._tag) {
43
+ case 'upstream-rebase': {
44
+ // Find the index of the rollback event in the rollback tail
45
+ const rollbackIndex = syncState.rollbackTail.findIndex((event) => EventId.isEqual(event.id, payload.rollbackUntil));
46
+ if (rollbackIndex === -1) {
47
+ return shouldNeverHappen(`Rollback event not found in rollback tail. Rollback until: [${payload.rollbackUntil.global},${payload.rollbackUntil.local}]. Rollback tail: [${syncState.rollbackTail.map((e) => e.toString()).join(', ')}]`);
48
+ }
49
+ const eventsToRollback = [...syncState.rollbackTail.slice(rollbackIndex), ...syncState.pending];
50
+ // Get the last new event's ID as the new upstream head
51
+ const newUpstreamHead = payload.newEvents.at(-1)?.id ?? syncState.upstreamHead;
52
+ // Rebase pending events on top of the new events
53
+ const rebasedPending = rebaseEvents({
54
+ events: syncState.pending,
55
+ baseEventId: newUpstreamHead,
56
+ isLocalEvent,
57
+ });
58
+ return {
59
+ _tag: 'rebase',
60
+ newSyncState: {
61
+ pending: rebasedPending,
62
+ rollbackTail: trimRollbackTail([...syncState.rollbackTail.slice(0, rollbackIndex), ...payload.newEvents]),
63
+ upstreamHead: newUpstreamHead,
64
+ localHead: rebasedPending.at(-1)?.id ?? newUpstreamHead,
65
+ },
66
+ previousSyncState: syncState,
67
+ newEvents: payload.newEvents,
68
+ eventsToRollback,
69
+ };
70
+ }
71
+ case 'upstream-advance': {
72
+ if (payload.newEvents.length === 0) {
73
+ return {
74
+ _tag: 'advance',
75
+ newSyncState: {
76
+ pending: syncState.pending,
77
+ rollbackTail: trimRollbackTail(syncState.rollbackTail),
78
+ upstreamHead: syncState.upstreamHead,
79
+ localHead: syncState.localHead,
80
+ },
81
+ previousSyncState: syncState,
82
+ newEvents: [],
83
+ };
84
+ }
85
+ // Validate that newEvents are sorted in ascending order by eventId
86
+ for (let i = 1; i < payload.newEvents.length; i++) {
87
+ if (EventId.isGreaterThan(payload.newEvents[i - 1].id, payload.newEvents[i].id)) {
88
+ return shouldNeverHappen('Events must be sorted in ascending order by eventId');
89
+ }
90
+ }
91
+ const newUpstreamHead = payload.newEvents.at(-1).id;
92
+ const divergentPendingIndex = findDivergencePoint({
93
+ existingEvents: syncState.pending,
94
+ incomingEvents: payload.newEvents,
95
+ isEqualEvent,
96
+ isLocalEvent,
97
+ ignoreLocalEvents,
98
+ });
99
+ if (divergentPendingIndex === -1) {
100
+ const pendingEventIds = new Set(syncState.pending.map((e) => `${e.id.global},${e.id.local}`));
101
+ const newEvents = payload.newEvents.filter((e) => !pendingEventIds.has(`${e.id.global},${e.id.local}`));
102
+ // In the case where the incoming events are a subset of the pending events,
103
+ // we need to split the pending events into two groups:
104
+ // - pendingMatching: The pending events up to point where they match the incoming events
105
+ // - pendingRemaining: The pending events after the point where they match the incoming events
106
+ // The `localIndexOffset` is used to account for the local events that are being ignored
107
+ let localIndexOffset = 0;
108
+ const [pendingMatching, pendingRemaining] = ReadonlyArray.splitWhere(syncState.pending, (pendingEvent, index) => {
109
+ if (ignoreLocalEvents && isLocalEvent(pendingEvent)) {
110
+ localIndexOffset++;
111
+ return false;
112
+ }
113
+ const newEvent = payload.newEvents.at(index - localIndexOffset);
114
+ if (!newEvent) {
115
+ return true;
116
+ }
117
+ return isEqualEvent(pendingEvent, newEvent) === false;
118
+ });
119
+ const seenEventIds = new Set();
120
+ const pendingAndNewEvents = [...pendingMatching, ...payload.newEvents].filter((event) => {
121
+ const eventIdStr = `${event.id.global},${event.id.local}`;
122
+ if (seenEventIds.has(eventIdStr)) {
123
+ return false;
124
+ }
125
+ seenEventIds.add(eventIdStr);
126
+ return true;
127
+ });
128
+ return {
129
+ _tag: 'advance',
130
+ newSyncState: {
131
+ pending: pendingRemaining,
132
+ rollbackTail: trimRollbackTail([...syncState.rollbackTail, ...pendingAndNewEvents]),
133
+ upstreamHead: newUpstreamHead,
134
+ localHead: pendingRemaining.at(-1)?.id ?? newUpstreamHead,
135
+ },
136
+ previousSyncState: syncState,
137
+ newEvents,
138
+ };
139
+ }
140
+ else {
141
+ const divergentPending = syncState.pending.slice(divergentPendingIndex);
142
+ const rebasedPending = rebaseEvents({
143
+ events: divergentPending,
144
+ baseEventId: newUpstreamHead,
145
+ isLocalEvent,
146
+ });
147
+ const divergentNewEventsIndex = findDivergencePoint({
148
+ existingEvents: payload.newEvents,
149
+ incomingEvents: syncState.pending,
150
+ isEqualEvent,
151
+ isLocalEvent,
152
+ ignoreLocalEvents,
153
+ });
154
+ return {
155
+ _tag: 'rebase',
156
+ newSyncState: {
157
+ pending: rebasedPending,
158
+ rollbackTail: trimRollbackTail([...syncState.rollbackTail, ...payload.newEvents]),
159
+ upstreamHead: newUpstreamHead,
160
+ localHead: rebasedPending.at(-1).id,
161
+ },
162
+ previousSyncState: syncState,
163
+ newEvents: [...payload.newEvents.slice(divergentNewEventsIndex), ...rebasedPending],
164
+ eventsToRollback: [...syncState.rollbackTail, ...divergentPending],
165
+ };
166
+ }
167
+ }
168
+ case 'local-push': {
169
+ if (payload.newEvents.length === 0) {
170
+ return { _tag: 'advance', newSyncState: syncState, previousSyncState: syncState, newEvents: [] };
171
+ }
172
+ const newEventsFirst = payload.newEvents.at(0);
173
+ const invalidEventId = EventId.isGreaterThan(newEventsFirst.id, syncState.localHead) === false;
174
+ if (invalidEventId) {
175
+ const expectedMinimumId = EventId.nextPair(syncState.localHead, true).id;
176
+ return { _tag: 'reject', previousSyncState: syncState, expectedMinimumId };
177
+ }
178
+ else {
179
+ return {
180
+ _tag: 'advance',
181
+ newSyncState: {
182
+ pending: [...syncState.pending, ...payload.newEvents],
183
+ rollbackTail: syncState.rollbackTail,
184
+ upstreamHead: syncState.upstreamHead,
185
+ localHead: payload.newEvents.at(-1).id,
186
+ },
187
+ previousSyncState: syncState,
188
+ newEvents: payload.newEvents,
189
+ };
190
+ }
191
+ }
192
+ // case 'upstream-trim-rollback-tail': {
193
+ // // Find the index of the new rollback start in the rollback tail
194
+ // const startIndex = syncState.rollbackTail.findIndex((event) => eventIdsEqual(event.id, payload.trimRollbackUntil))
195
+ // if (startIndex === -1) {
196
+ // return shouldNeverHappen('New rollback start event not found in rollback tail')
197
+ // }
198
+ // // Keep only the events from the start index onwards
199
+ // const newRollbackTail = syncState.rollbackTail.slice(startIndex)
200
+ // return {
201
+ // _tag: 'advance',
202
+ // syncState: {
203
+ // pending: syncState.pending,
204
+ // rollbackTail: newRollbackTail,
205
+ // upstreamHead: syncState.upstreamHead,
206
+ // localHead: syncState.localHead,
207
+ // },
208
+ // newEvents: [],
209
+ // }
210
+ // }
211
+ }
212
+ };
213
+ /**
214
+ * Gets the index relative to `existingEvents` where the divergence point is
215
+ * by comparing each event in `existingEvents` to the corresponding event in `incomingEvents`
216
+ */
217
+ const findDivergencePoint = ({ existingEvents, incomingEvents, isEqualEvent, isLocalEvent, ignoreLocalEvents, }) => {
218
+ if (ignoreLocalEvents) {
219
+ const filteredExistingEvents = existingEvents.filter((event) => !isLocalEvent(event));
220
+ const divergencePointWithoutLocalEvents = findDivergencePoint({
221
+ existingEvents: filteredExistingEvents,
222
+ incomingEvents,
223
+ isEqualEvent,
224
+ isLocalEvent,
225
+ ignoreLocalEvents: false,
226
+ });
227
+ if (divergencePointWithoutLocalEvents === -1)
228
+ return -1;
229
+ const divergencePointEventId = existingEvents[divergencePointWithoutLocalEvents].id;
230
+ // Now find the divergence point in the original array
231
+ return existingEvents.findIndex((event) => EventId.isEqual(event.id, divergencePointEventId));
232
+ }
233
+ return existingEvents.findIndex((existingEvent, index) => {
234
+ const incomingEvent = incomingEvents[index];
235
+ // return !incomingEvent || !isEqualEvent(existingEvent, incomingEvent)
236
+ return incomingEvent && !isEqualEvent(existingEvent, incomingEvent);
237
+ });
238
+ };
239
+ const rebaseEvents = ({ events, baseEventId, isLocalEvent, }) => {
240
+ let prevEventId = baseEventId;
241
+ return events.map((event) => {
242
+ const isLocal = isLocalEvent(event);
243
+ const newEvent = event.rebase(prevEventId, isLocal);
244
+ prevEventId = newEvent.id;
245
+ return newEvent;
246
+ });
247
+ };
248
+ //# sourceMappingURL=syncstate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"syncstate.js","sourceRoot":"","sources":["../../src/sync/syncstate.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=syncstate.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"syncstate.test.d.ts","sourceRoot":"","sources":["../../src/sync/syncstate.test.ts"],"names":[],"mappings":""}