mirror of
https://github.com/element-hq/synapse.git
synced 2024-12-23 05:00:24 +03:00
Review comments
This commit is contained in:
parent
a2070a2c4e
commit
ba1a8be930
5 changed files with 27 additions and 16 deletions
|
@ -174,9 +174,8 @@ client (C):
|
|||
|
||||
#### POSITION (S)
|
||||
|
||||
The position of the stream has been updated. Sent to the client
|
||||
after all missing updates for a stream have been sent to the client
|
||||
and they're now up to date.
|
||||
On receipt of a POSITION command clients should check if they have missed any
|
||||
updates, and if so then fetch them out of band.
|
||||
|
||||
#### ERROR (S, C)
|
||||
|
||||
|
|
|
@ -25,6 +25,19 @@ logger = logging.getLogger(__name__)
|
|||
class ReplicationGetStreamUpdates(ReplicationEndpoint):
|
||||
"""Fetches stream updates from a server. Used for streams not persisted to
|
||||
the database, e.g. typing notifications.
|
||||
|
||||
The API looks like:
|
||||
|
||||
GET /_synapse/replication/get_repl_stream_updates/events?from_token=0&to_token=10&limit=100
|
||||
|
||||
200 OK
|
||||
|
||||
{
|
||||
updates: [ ... ],
|
||||
upto_token: 10,
|
||||
limited: False,
|
||||
}
|
||||
|
||||
"""
|
||||
|
||||
NAME = "get_repl_stream_updates"
|
||||
|
@ -32,7 +45,7 @@ class ReplicationGetStreamUpdates(ReplicationEndpoint):
|
|||
METHOD = "GET"
|
||||
|
||||
def __init__(self, hs):
|
||||
super(ReplicationGetStreamUpdates, self).__init__(hs)
|
||||
super().__init__(hs)
|
||||
|
||||
from synapse.replication.tcp.streams import STREAMS_MAP
|
||||
|
||||
|
|
|
@ -136,8 +136,8 @@ class PositionCommand(Command):
|
|||
"""Sent by the server to tell the client the stream postition without
|
||||
needing to send an RDATA.
|
||||
|
||||
Sent to the client after all missing updates for a stream have been sent
|
||||
to the client and they're now up to date.
|
||||
On receipt of a POSITION command clients should check if they have missed
|
||||
any updates, and if so then fetch them out of band.
|
||||
"""
|
||||
|
||||
NAME = "POSITION"
|
||||
|
|
|
@ -638,8 +638,7 @@ class ClientReplicationStreamProtocol(BaseReplicationStreamProtocol):
|
|||
# We've now caught up to position sent to us, notify handler.
|
||||
await self.handler.on_position(cmd.stream_name, cmd.token)
|
||||
|
||||
# When we get a `POSITION` command it means we've finished getting
|
||||
# missing updates for the given stream, and are now up to date.
|
||||
# We're now up to date wit the stream
|
||||
self.streams_connecting.discard(cmd.stream_name)
|
||||
if not self.streams_connecting:
|
||||
self.handler.finished_connecting()
|
||||
|
|
|
@ -79,10 +79,10 @@ class Stream(object):
|
|||
since the stream was constructed if it hadn't been called before).
|
||||
|
||||
Returns:
|
||||
Resolves to a pair `(updates, new_last_token, limited)`, where
|
||||
`updates` is a list of `(token, row)` entries, `new_last_token` is
|
||||
the new position in stream, and `limited` is whether there are
|
||||
more updates to fetch.
|
||||
A triplet `(updates, new_last_token, limited)`, where `updates` is
|
||||
a list of `(token, row)` entries, `new_last_token` is the new
|
||||
position in stream, and `limited` is whether there are more updates
|
||||
to fetch.
|
||||
"""
|
||||
current_token = self.current_token()
|
||||
updates, current_token, limited = await self.get_updates_since(
|
||||
|
@ -99,10 +99,10 @@ class Stream(object):
|
|||
stream updates
|
||||
|
||||
Returns:
|
||||
Resolves to a pair `(updates, new_last_token, limited)`, where
|
||||
`updates` is a list of `(token, row)` entries, `new_last_token` is
|
||||
the new position in stream, and `limited` is whether there are
|
||||
more updates to fetch.
|
||||
A triplet `(updates, new_last_token, limited)`, where `updates` is
|
||||
a list of `(token, row)` entries, `new_last_token` is the new
|
||||
position in stream, and `limited` is whether there are more updates
|
||||
to fetch.
|
||||
"""
|
||||
|
||||
if from_token in ("NOW", "now"):
|
||||
|
|
Loading…
Reference in a new issue