From e063433b7444bd6c9165e5ead824f1a8bdd4ac0a Mon Sep 17 00:00:00 2001 From: Alex Chen Date: Mon, 14 Jan 2019 18:20:19 +0800 Subject: [PATCH] Fix POST /get_missing_events/{roomId} #622 (#678) * Fix #622 /get_missing_events/{roomId} Signed-off-by: Alex Chen * Set initial size for eventsToFilter in /get_missing_events/{roomId} Signed-off-by: Alex Chen --- .../dendrite/federationapi/routing/routing.go | 4 ++-- .../matrix-org/dendrite/roomserver/query/query.go | 15 ++++++++++++++- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/src/github.com/matrix-org/dendrite/federationapi/routing/routing.go b/src/github.com/matrix-org/dendrite/federationapi/routing/routing.go index 1ca4f6679..035d54aa1 100644 --- a/src/github.com/matrix-org/dendrite/federationapi/routing/routing.go +++ b/src/github.com/matrix-org/dendrite/federationapi/routing/routing.go @@ -212,13 +212,13 @@ func Setup( }, )).Methods(http.MethodGet) - v1fedmux.Handle("get_missing_events/{roomID}", common.MakeFedAPI( + v1fedmux.Handle("/get_missing_events/{roomID}", common.MakeFedAPI( "federation_get_missing_events", cfg.Matrix.ServerName, keys, func(httpReq *http.Request, request *gomatrixserverlib.FederationRequest) util.JSONResponse { vars := mux.Vars(httpReq) return GetMissingEvents(httpReq, request, query, vars["roomID"]) }, - )).Methods(http.MethodGet) + )).Methods(http.MethodPost) v1fedmux.Handle("/backfill/{roomID}/", common.MakeFedAPI( "federation_backfill", cfg.Matrix.ServerName, keys, diff --git a/src/github.com/matrix-org/dendrite/roomserver/query/query.go b/src/github.com/matrix-org/dendrite/roomserver/query/query.go index 39e9333cf..b97d50b17 100644 --- a/src/github.com/matrix-org/dendrite/roomserver/query/query.go +++ b/src/github.com/matrix-org/dendrite/roomserver/query/query.go @@ -438,6 +438,7 @@ func (r *RoomserverQueryAPI) QueryMissingEvents( response *api.QueryMissingEventsResponse, ) error { var front []string + eventsToFilter := make(map[string]bool, len(request.LatestEvents)) visited := make(map[string]bool, request.Limit) // request.Limit acts as a hint to size. for _, id := range request.EarliestEvents { visited[id] = true @@ -446,6 +447,7 @@ func (r *RoomserverQueryAPI) QueryMissingEvents( for _, id := range request.LatestEvents { if !visited[id] { front = append(front, id) + eventsToFilter[id] = true } } @@ -454,7 +456,18 @@ func (r *RoomserverQueryAPI) QueryMissingEvents( return err } - response.Events, err = r.loadEvents(ctx, resultNIDs) + loadedEvents, err := r.loadEvents(ctx, resultNIDs) + if err != nil { + return err + } + + response.Events = make([]gomatrixserverlib.Event, 0, len(loadedEvents)-len(eventsToFilter)) + for _, event := range loadedEvents { + if !eventsToFilter[event.EventID()] { + response.Events = append(response.Events, event) + } + } + return err }