mirror of
https://github.com/matrix-org/dendrite.git
synced 2025-12-17 03:43:11 -06:00
final tweaks/hacks
This commit is contained in:
parent
c723a367b2
commit
6063a8497c
|
|
@ -40,6 +40,7 @@ type messagesReq struct {
|
||||||
roomID string
|
roomID string
|
||||||
from *types.TopologyToken
|
from *types.TopologyToken
|
||||||
to *types.TopologyToken
|
to *types.TopologyToken
|
||||||
|
fromStream *types.StreamingToken
|
||||||
wasToProvided bool
|
wasToProvided bool
|
||||||
limit int
|
limit int
|
||||||
backwardOrdering bool
|
backwardOrdering bool
|
||||||
|
|
@ -66,11 +67,16 @@ func OnIncomingMessagesRequest(
|
||||||
|
|
||||||
// Extract parameters from the request's URL.
|
// Extract parameters from the request's URL.
|
||||||
// Pagination tokens.
|
// Pagination tokens.
|
||||||
|
var fromStream *types.StreamingToken
|
||||||
from, err := types.NewTopologyTokenFromString(req.URL.Query().Get("from"))
|
from, err := types.NewTopologyTokenFromString(req.URL.Query().Get("from"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return util.JSONResponse{
|
fs, err2 := types.NewStreamTokenFromString(req.URL.Query().Get("from"))
|
||||||
Code: http.StatusBadRequest,
|
fromStream = &fs
|
||||||
JSON: jsonerror.InvalidArgumentValue("Invalid from parameter: " + err.Error()),
|
if err2 != nil {
|
||||||
|
return util.JSONResponse{
|
||||||
|
Code: http.StatusBadRequest,
|
||||||
|
JSON: jsonerror.InvalidArgumentValue("Invalid from parameter: " + err2.Error()),
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -141,6 +147,7 @@ func OnIncomingMessagesRequest(
|
||||||
roomID: roomID,
|
roomID: roomID,
|
||||||
from: &from,
|
from: &from,
|
||||||
to: &to,
|
to: &to,
|
||||||
|
fromStream: fromStream,
|
||||||
wasToProvided: wasToProvided,
|
wasToProvided: wasToProvided,
|
||||||
limit: limit,
|
limit: limit,
|
||||||
backwardOrdering: backwardOrdering,
|
backwardOrdering: backwardOrdering,
|
||||||
|
|
@ -181,9 +188,21 @@ func (r *messagesReq) retrieveEvents() (
|
||||||
end types.TopologyToken, err error,
|
end types.TopologyToken, err error,
|
||||||
) {
|
) {
|
||||||
// Retrieve the events from the local database.
|
// Retrieve the events from the local database.
|
||||||
streamEvents, err := r.db.GetEventsInRange(
|
var streamEvents []types.StreamEvent
|
||||||
r.ctx, r.from, r.to, r.roomID, r.limit, r.backwardOrdering,
|
if r.fromStream != nil {
|
||||||
)
|
toStream := r.to.StreamToken()
|
||||||
|
util.GetLogger(r.ctx).Infof("quack fromStream positions %v", r.fromStream.Positions)
|
||||||
|
util.GetLogger(r.ctx).Infof("quack toStream positions %v", toStream.Positions)
|
||||||
|
streamEvents, err = r.db.GetEventsInStreamingRange(
|
||||||
|
r.ctx, r.fromStream, &toStream, r.roomID, r.limit, r.backwardOrdering,
|
||||||
|
)
|
||||||
|
} else {
|
||||||
|
util.GetLogger(r.ctx).Infof("quack from positions %v", r.from.Positions)
|
||||||
|
util.GetLogger(r.ctx).Infof("quack to positions %v", r.to.Positions)
|
||||||
|
streamEvents, err = r.db.GetEventsInTopologicalRange(
|
||||||
|
r.ctx, r.from, r.to, r.roomID, r.limit, r.backwardOrdering,
|
||||||
|
)
|
||||||
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
err = fmt.Errorf("GetEventsInRange: %w", err)
|
err = fmt.Errorf("GetEventsInRange: %w", err)
|
||||||
return
|
return
|
||||||
|
|
|
||||||
|
|
@ -263,16 +263,14 @@ func (d *SyncServerDatasource) GetEventsInTopologicalRange(
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetEventsInStreamingRange retrieves all of the events on a given ordering using the
|
||||||
|
// given extremities and limit.
|
||||||
func (d *SyncServerDatasource) GetEventsInStreamingRange(
|
func (d *SyncServerDatasource) GetEventsInStreamingRange(
|
||||||
ctx context.Context,
|
ctx context.Context,
|
||||||
from, to *types.StreamingToken,
|
from, to *types.StreamingToken,
|
||||||
roomID string, limit int,
|
roomID string, limit int,
|
||||||
backwardOrdering bool,
|
backwardOrdering bool,
|
||||||
) (events []types.StreamEvent, err error) {
|
) (events []types.StreamEvent, err error) {
|
||||||
// If the pagination token's type is types.PaginationTokenTypeStream, the
|
|
||||||
// events must be retrieved from the table contaning the syncapi server's
|
|
||||||
// whole stream of events.
|
|
||||||
|
|
||||||
if backwardOrdering {
|
if backwardOrdering {
|
||||||
// When using backward ordering, we want the most recent events first.
|
// When using backward ordering, we want the most recent events first.
|
||||||
if events, err = d.events.selectRecentEvents(
|
if events, err = d.events.selectRecentEvents(
|
||||||
|
|
@ -288,8 +286,7 @@ func (d *SyncServerDatasource) GetEventsInStreamingRange(
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return events, err
|
||||||
return
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *SyncServerDatasource) SyncPosition(ctx context.Context) (types.StreamingToken, error) {
|
func (d *SyncServerDatasource) SyncPosition(ctx context.Context) (types.StreamingToken, error) {
|
||||||
|
|
@ -589,18 +586,17 @@ func (d *SyncServerDatasource) getResponseWithPDUsForCompleteSync(
|
||||||
// oldest event in the room's topology.
|
// oldest event in the room's topology.
|
||||||
var backwardTopologyPos, backwardStreamPos types.StreamPosition
|
var backwardTopologyPos, backwardStreamPos types.StreamPosition
|
||||||
backwardTopologyPos, backwardStreamPos, err = d.topology.selectPositionInTopology(ctx, recentStreamEvents[0].EventID())
|
backwardTopologyPos, backwardStreamPos, err = d.topology.selectPositionInTopology(ctx, recentStreamEvents[0].EventID())
|
||||||
if backwardTopologyPos-1 <= 0 {
|
if err != nil {
|
||||||
backwardTopologyPos = types.StreamPosition(1)
|
return
|
||||||
} else {
|
|
||||||
backwardTopologyPos--
|
|
||||||
}
|
}
|
||||||
|
prevBatch := types.NewTopologyToken(backwardTopologyPos, backwardStreamPos)
|
||||||
|
prevBatch.Decrement()
|
||||||
|
|
||||||
// We don't include a device here as we don't need to send down
|
// We don't include a device here as we don't need to send down
|
||||||
// transaction IDs for complete syncs
|
// transaction IDs for complete syncs
|
||||||
recentEvents := d.StreamEventsToEvents(nil, recentStreamEvents)
|
recentEvents := d.StreamEventsToEvents(nil, recentStreamEvents)
|
||||||
stateEvents = removeDuplicates(stateEvents, recentEvents)
|
stateEvents = removeDuplicates(stateEvents, recentEvents)
|
||||||
jr := types.NewJoinResponse()
|
jr := types.NewJoinResponse()
|
||||||
prevBatch := types.NewTopologyToken(backwardTopologyPos, backwardStreamPos)
|
|
||||||
jr.Timeline.PrevBatch = prevBatch.String()
|
jr.Timeline.PrevBatch = prevBatch.String()
|
||||||
jr.Timeline.Events = gomatrixserverlib.HeaderedToClientEvents(recentEvents, gomatrixserverlib.FormatSync)
|
jr.Timeline.Events = gomatrixserverlib.HeaderedToClientEvents(recentEvents, gomatrixserverlib.FormatSync)
|
||||||
jr.Timeline.Limited = true
|
jr.Timeline.Limited = true
|
||||||
|
|
|
||||||
|
|
@ -107,6 +107,9 @@ func (t *TopologyToken) Depth() StreamPosition {
|
||||||
func (t *TopologyToken) PDUPosition() StreamPosition {
|
func (t *TopologyToken) PDUPosition() StreamPosition {
|
||||||
return t.Positions[1]
|
return t.Positions[1]
|
||||||
}
|
}
|
||||||
|
func (t *TopologyToken) StreamToken() StreamingToken {
|
||||||
|
return NewStreamToken(t.PDUPosition(), 0)
|
||||||
|
}
|
||||||
func (t *TopologyToken) String() string {
|
func (t *TopologyToken) String() string {
|
||||||
return t.syncToken.String()
|
return t.syncToken.String()
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in a new issue