You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Currently, clients can't receive events they missed, when they weren't connected to the server. This can happen for many reasons, but most notably because the user closed the client application, or because of an internet failure. This means that once they reconnect, their state will be out-of-date, and they will need to refetch all of the data instead of incrementally fetching what they need. This issue is for tracking potential solutions.
Solutions?
solution 1
introduce a new StreamEventsResponse.event variant:
messageStreamId {
uint64stream_id=1;
}
StreamId lets the client know the ID of the current stream they are using. This will be sent to the client upon connection of the stream.
introduce a new StreamEventsRequest.request variant:
messageKeepTrack { }
KeepTrack lets the server know that after the current stream has ended, it should store any events dispatched to this user under the ID of the stream that ended.
introduce a new RPC to ChatService called SynchronizeEvents. it's request type will take a uint64 stream_id = 1;.
ChatService.SynchronizeEvents will return a list of events, ordered from oldest to newest, that the client has missed since the end of the stream the ID was bound to. After this is called, the stream ID should be invalidated, and all the events should be removed.
The events should only contain the newest state, and nothing in between. New messages should not be kept, only edited / deleted messages, as new messages will potentially take up a lot of storage. The client can fetch the new messages itself.
solution 2
servers attach a "last modification time" to basically everything (profiles, messages, guilds, channels, etc)
clients later can synchronize their state by sending a request with the last time they were connected. the server will figure out what's missing and send it to the client. the response can simply be a list of events, ordered from oldest to newest that the client can apply easily without writing new logic.
Unlike the first one, this doesn't require much protocol change aside from one new RPC, and doesn't require the server to store redundant state. However this is potentially much more complex for servers (?).
The text was updated successfully, but these errors were encountered:
Currently, clients can't receive events they missed, when they weren't connected to the server. This can happen for many reasons, but most notably because the user closed the client application, or because of an internet failure. This means that once they reconnect, their state will be out-of-date, and they will need to refetch all of the data instead of incrementally fetching what they need. This issue is for tracking potential solutions.
Solutions?
solution 1
StreamEventsResponse.event
variant:StreamId
lets the client know the ID of the current stream they are using. This will be sent to the client upon connection of the stream.StreamEventsRequest.request
variant:KeepTrack
lets the server know that after the current stream has ended, it should store any events dispatched to this user under the ID of the stream that ended.ChatService
calledSynchronizeEvents
. it's request type will take auint64 stream_id = 1;
.ChatService.SynchronizeEvents
will return a list of events, ordered from oldest to newest, that the client has missed since the end of the stream the ID was bound to. After this is called, the stream ID should be invalidated, and all the events should be removed.The events should only contain the newest state, and nothing in between. New messages should not be kept, only edited / deleted messages, as new messages will potentially take up a lot of storage. The client can fetch the new messages itself.
solution 2
Unlike the first one, this doesn't require much protocol change aside from one new RPC, and doesn't require the server to store redundant state. However this is potentially much more complex for servers (?).
The text was updated successfully, but these errors were encountered: