mirror of
https://github.com/matrix-org/dendrite.git
synced 2026-01-16 18:43:10 -06:00
Split "timeline" and "state" after applying filtering
This commit is contained in:
parent
f10c6f26e5
commit
6c0c369286
|
|
@ -251,8 +251,10 @@ func (p *PDUStreamProvider) addRoomDeltaToResponse(
|
||||||
}
|
}
|
||||||
return r.From, fmt.Errorf("p.DB.RecentEvents: %w", err)
|
return r.From, fmt.Errorf("p.DB.RecentEvents: %w", err)
|
||||||
}
|
}
|
||||||
recentEvents := snapshot.StreamEventsToEvents(device, recentStreamEvents)
|
recentEvents := gomatrixserverlib.HeaderedReverseTopologicalOrdering(
|
||||||
delta.StateEvents = removeDuplicates(delta.StateEvents, recentEvents) // roll back
|
snapshot.StreamEventsToEvents(device, recentStreamEvents),
|
||||||
|
gomatrixserverlib.TopologicalOrderByPrevEvents,
|
||||||
|
)
|
||||||
prevBatch, err := snapshot.GetBackwardTopologyPos(ctx, recentStreamEvents)
|
prevBatch, err := snapshot.GetBackwardTopologyPos(ctx, recentStreamEvents)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return r.From, fmt.Errorf("p.DB.GetBackwardTopologyPos: %w", err)
|
return r.From, fmt.Errorf("p.DB.GetBackwardTopologyPos: %w", err)
|
||||||
|
|
@ -263,10 +265,6 @@ func (p *PDUStreamProvider) addRoomDeltaToResponse(
|
||||||
return r.To, nil
|
return r.To, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sort the events so that we can pick out the latest events from both sections.
|
|
||||||
recentEvents = gomatrixserverlib.HeaderedReverseTopologicalOrdering(recentEvents, gomatrixserverlib.TopologicalOrderByPrevEvents)
|
|
||||||
delta.StateEvents = gomatrixserverlib.HeaderedReverseTopologicalOrdering(delta.StateEvents, gomatrixserverlib.TopologicalOrderByAuthEvents)
|
|
||||||
|
|
||||||
// Work out what the highest stream position is for all of the events in this
|
// Work out what the highest stream position is for all of the events in this
|
||||||
// room that were returned.
|
// room that were returned.
|
||||||
latestPosition := r.To
|
latestPosition := r.To
|
||||||
|
|
@ -314,6 +312,14 @@ func (p *PDUStreamProvider) addRoomDeltaToResponse(
|
||||||
limited = true
|
limited = true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Now that we've filtered the timeline, work out which state events are still
|
||||||
|
// left. Anything that appears in the filtered timeline will be removed from the
|
||||||
|
// "state" section and kept in "timeline".
|
||||||
|
delta.StateEvents = gomatrixserverlib.HeaderedReverseTopologicalOrdering(
|
||||||
|
removeDuplicates(delta.StateEvents, recentEvents),
|
||||||
|
gomatrixserverlib.TopologicalOrderByAuthEvents,
|
||||||
|
)
|
||||||
|
|
||||||
if len(delta.StateEvents) > 0 {
|
if len(delta.StateEvents) > 0 {
|
||||||
updateLatestPosition(delta.StateEvents[len(delta.StateEvents)-1].EventID())
|
updateLatestPosition(delta.StateEvents[len(delta.StateEvents)-1].EventID())
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue