aboutsummaryrefslogtreecommitdiff
path: root/syncapi/storage/shared/syncserver.go
diff options
context:
space:
mode:
authorNeil Alexander <neilalexander@users.noreply.github.com>2022-03-18 10:40:01 +0000
committerGitHub <noreply@github.com>2022-03-18 10:40:01 +0000
commit475d3c1af96c663ecc25859d654fad6063e70b8a (patch)
tree767f75372473f32ab1e4d95bff0cde7ea77cb968 /syncapi/storage/shared/syncserver.go
parent191486438cc0d2999dc93878901f7d7d4cae4293 (diff)
Better mapping of stream positions to topological positions in `/messages` (#2263)
* Convert stream positions into topological positions for both `from` and `to` in `/messages` * Hopefully it works now * Remove unnecessary logging * Return sane values if `StreamToTopologicalPosition` can't work out the right thing to do * Revert logging change * tweaks * Fix `selectEventIDsInRangeASCSQL` * Test `Getting messages going forward is limited for a departed room (SPEC-216)` was passing incorrectly so un-whitelist it
Diffstat (limited to 'syncapi/storage/shared/syncserver.go')
-rw-r--r--syncapi/storage/shared/syncserver.go51
1 files changed, 20 insertions, 31 deletions
diff --git a/syncapi/storage/shared/syncserver.go b/syncapi/storage/shared/syncserver.go
index 2c166eef..9a2dc0d4 100644
--- a/syncapi/storage/shared/syncserver.go
+++ b/syncapi/storage/shared/syncserver.go
@@ -155,37 +155,6 @@ func (d *Database) Events(ctx context.Context, eventIDs []string) ([]*gomatrixse
return d.StreamEventsToEvents(nil, streamEvents), nil
}
-// GetEventsInStreamingRange retrieves all of the events on a given ordering using the
-// given extremities and limit.
-func (d *Database) GetEventsInStreamingRange(
- ctx context.Context,
- from, to *types.StreamingToken,
- roomID string, eventFilter *gomatrixserverlib.RoomEventFilter,
- backwardOrdering bool,
-) (events []types.StreamEvent, err error) {
- r := types.Range{
- From: from.PDUPosition,
- To: to.PDUPosition,
- Backwards: backwardOrdering,
- }
- if backwardOrdering {
- // When using backward ordering, we want the most recent events first.
- if events, _, err = d.OutputEvents.SelectRecentEvents(
- ctx, nil, roomID, r, eventFilter, false, false,
- ); err != nil {
- return
- }
- } else {
- // When using forward ordering, we want the least recent events first.
- if events, err = d.OutputEvents.SelectEarlyEvents(
- ctx, nil, roomID, r, eventFilter,
- ); err != nil {
- return
- }
- }
- return events, err
-}
-
func (d *Database) AllJoinedUsersInRooms(ctx context.Context) (map[string][]string, error) {
return d.CurrentRoomState.SelectJoinedUsers(ctx)
}
@@ -513,6 +482,26 @@ func (d *Database) EventPositionInTopology(
return types.TopologyToken{Depth: depth, PDUPosition: stream}, nil
}
+func (d *Database) StreamToTopologicalPosition(
+ ctx context.Context, roomID string, streamPos types.StreamPosition, backwardOrdering bool,
+) (types.TopologyToken, error) {
+ topoPos, err := d.Topology.SelectStreamToTopologicalPosition(ctx, nil, roomID, streamPos, backwardOrdering)
+ switch {
+ case err == sql.ErrNoRows && backwardOrdering: // no events in range, going backward
+ return types.TopologyToken{PDUPosition: streamPos}, nil
+ case err == sql.ErrNoRows && !backwardOrdering: // no events in range, going forward
+ topoPos, streamPos, err = d.Topology.SelectMaxPositionInTopology(ctx, nil, roomID)
+ if err != nil {
+ return types.TopologyToken{}, fmt.Errorf("d.Topology.SelectMaxPositionInTopology: %w", err)
+ }
+ return types.TopologyToken{Depth: topoPos, PDUPosition: streamPos}, nil
+ case err != nil: // some other error happened
+ return types.TopologyToken{}, fmt.Errorf("d.Topology.SelectStreamToTopologicalPosition: %w", err)
+ default:
+ return types.TopologyToken{Depth: topoPos, PDUPosition: streamPos}, nil
+ }
+}
+
func (d *Database) GetFilter(
ctx context.Context, localpart string, filterID string,
) (*gomatrixserverlib.Filter, error) {