Skip to content
This repository has been archived by the owner on Apr 26, 2024. It is now read-only.

Commit

Permalink
Resync remote device list when detected as stale. (#6786)
Browse files Browse the repository at this point in the history
  • Loading branch information
erikjohnston authored Jan 30, 2020
1 parent c3d4ad8 commit b660327
Show file tree
Hide file tree
Showing 4 changed files with 28 additions and 7 deletions.
1 change: 1 addition & 0 deletions changelog.d/6786.misc
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Attempt to resync remote users' devices when detected as stale.
10 changes: 8 additions & 2 deletions synapse/handlers/devicemessage.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
from twisted.internet import defer

from synapse.api.errors import SynapseError
from synapse.logging.context import run_in_background
from synapse.logging.opentracing import (
get_active_span_text_map,
log_kv,
Expand Down Expand Up @@ -48,6 +49,8 @@ def __init__(self, hs):
"m.direct_to_device", self.on_direct_to_device_edu
)

self._device_list_updater = hs.get_device_handler().device_list_updater

@defer.inlineCallbacks
def on_direct_to_device_edu(self, origin, content):
local_messages = {}
Expand Down Expand Up @@ -134,8 +137,11 @@ def _check_for_unknown_devices(
unknown_devices,
)
yield self.store.mark_remote_user_device_cache_as_stale(sender_user_id)
# TODO: Poke something to start trying to refetch user's
# keys.

# Immediately attempt a resync in the background
run_in_background(
self._device_list_updater.user_device_resync, sender_user_id
)

@defer.inlineCallbacks
def send_device_message(self, sender_user_id, message_type, messages):
Expand Down
18 changes: 16 additions & 2 deletions synapse/handlers/federation.py
Original file line number Diff line number Diff line change
Expand Up @@ -57,6 +57,7 @@
run_in_background,
)
from synapse.logging.utils import log_function
from synapse.replication.http.devices import ReplicationUserDevicesResyncRestServlet
from synapse.replication.http.federation import (
ReplicationCleanRoomRestServlet,
ReplicationFederationSendEventsRestServlet,
Expand Down Expand Up @@ -156,6 +157,13 @@ def __init__(self, hs):
hs
)

if hs.config.worker_app:
self._user_device_resync = ReplicationUserDevicesResyncRestServlet.make_client(
hs
)
else:
self._device_list_updater = hs.get_device_handler().device_list_updater

# When joining a room we need to queue any events for that room up
self.room_queues = {}
self._room_pdu_linearizer = Linearizer("fed_room_pdu")
Expand Down Expand Up @@ -759,8 +767,14 @@ async def _process_received_pdu(
await self.store.mark_remote_user_device_cache_as_stale(
event.sender
)
# TODO: Poke something to start trying to refetch user's
# keys.

# Immediately attempt a resync in the background
if self.config.worker_app:
return run_in_background(self._user_device_resync, event.sender)
else:
return run_in_background(
self._device_list_updater.user_device_resync, event.sender
)

@log_function
async def backfill(self, dest, room_id, limit, extremities):
Expand Down
6 changes: 3 additions & 3 deletions tests/handlers/test_typing.py
Original file line number Diff line number Diff line change
Expand Up @@ -81,6 +81,9 @@ def make_homeserver(self, reactor, clock):
]
)

# the tests assume that we are starting at unix time 1000
reactor.pump((1000,))

hs = self.setup_test_homeserver(
notifier=Mock(), http_client=mock_federation_client, keyring=mock_keyring
)
Expand All @@ -90,9 +93,6 @@ def make_homeserver(self, reactor, clock):
return hs

def prepare(self, reactor, clock, hs):
# the tests assume that we are starting at unix time 1000
reactor.pump((1000,))

mock_notifier = hs.get_notifier()
self.on_new_event = mock_notifier.on_new_event

Expand Down

0 comments on commit b660327

Please sign in to comment.