mirror of
https://git.anonymousland.org/anonymousland/synapse.git
synced 2025-08-15 13:25:24 -04:00
Merge remote-tracking branch 'upstream/release-v1.36'
This commit is contained in:
commit
8d96b324dc
116 changed files with 4194 additions and 2503 deletions
|
@ -315,6 +315,17 @@ class SyncHandler:
|
|||
if context:
|
||||
context.tag = sync_type
|
||||
|
||||
# if we have a since token, delete any to-device messages before that token
|
||||
# (since we now know that the device has received them)
|
||||
if since_token is not None:
|
||||
since_stream_id = since_token.to_device_key
|
||||
deleted = await self.store.delete_messages_for_device(
|
||||
sync_config.user.to_string(), sync_config.device_id, since_stream_id
|
||||
)
|
||||
logger.debug(
|
||||
"Deleted %d to-device messages up to %d", deleted, since_stream_id
|
||||
)
|
||||
|
||||
if timeout == 0 or since_token is None or full_state:
|
||||
# we are going to return immediately, so don't bother calling
|
||||
# notifier.wait_for_events.
|
||||
|
@ -463,7 +474,7 @@ class SyncHandler:
|
|||
# ensure that we always include current state in the timeline
|
||||
current_state_ids = frozenset() # type: FrozenSet[str]
|
||||
if any(e.is_state() for e in recents):
|
||||
current_state_ids_map = await self.state.get_current_state_ids(
|
||||
current_state_ids_map = await self.store.get_current_state_ids(
|
||||
room_id
|
||||
)
|
||||
current_state_ids = frozenset(current_state_ids_map.values())
|
||||
|
@ -523,7 +534,7 @@ class SyncHandler:
|
|||
# ensure that we always include current state in the timeline
|
||||
current_state_ids = frozenset()
|
||||
if any(e.is_state() for e in loaded_recents):
|
||||
current_state_ids_map = await self.state.get_current_state_ids(
|
||||
current_state_ids_map = await self.store.get_current_state_ids(
|
||||
room_id
|
||||
)
|
||||
current_state_ids = frozenset(current_state_ids_map.values())
|
||||
|
@ -1229,16 +1240,6 @@ class SyncHandler:
|
|||
since_stream_id = int(sync_result_builder.since_token.to_device_key)
|
||||
|
||||
if since_stream_id != int(now_token.to_device_key):
|
||||
# We only delete messages when a new message comes in, but that's
|
||||
# fine so long as we delete them at some point.
|
||||
|
||||
deleted = await self.store.delete_messages_for_device(
|
||||
user_id, device_id, since_stream_id
|
||||
)
|
||||
logger.debug(
|
||||
"Deleted %d to-device messages up to %d", deleted, since_stream_id
|
||||
)
|
||||
|
||||
messages, stream_id = await self.store.get_new_messages_for_device(
|
||||
user_id, device_id, since_stream_id, now_token.to_device_key
|
||||
)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue