Fix bug where we sent remote presence states to remote servers (#9850)
parent
495b214f4f
commit
db70435de7
|
@ -0,0 +1 @@
|
||||||
|
Add experimental support for handling presence on a worker.
|
|
@ -539,6 +539,10 @@ class FederationSender(AbstractFederationSender):
|
||||||
# No-op if presence is disabled.
|
# No-op if presence is disabled.
|
||||||
return
|
return
|
||||||
|
|
||||||
|
# Ensure we only send out presence states for local users.
|
||||||
|
for state in states:
|
||||||
|
assert self.is_mine_id(state.user_id)
|
||||||
|
|
||||||
for destination in destinations:
|
for destination in destinations:
|
||||||
if destination == self.server_name:
|
if destination == self.server_name:
|
||||||
continue
|
continue
|
||||||
|
|
|
@ -125,6 +125,7 @@ class BasePresenceHandler(abc.ABC):
|
||||||
self.store = hs.get_datastore()
|
self.store = hs.get_datastore()
|
||||||
self.presence_router = hs.get_presence_router()
|
self.presence_router = hs.get_presence_router()
|
||||||
self.state = hs.get_state_handler()
|
self.state = hs.get_state_handler()
|
||||||
|
self.is_mine_id = hs.is_mine_id
|
||||||
|
|
||||||
self._federation = None
|
self._federation = None
|
||||||
if hs.should_send_federation() or not hs.config.worker_app:
|
if hs.should_send_federation() or not hs.config.worker_app:
|
||||||
|
@ -261,7 +262,8 @@ class BasePresenceHandler(abc.ABC):
|
||||||
self, states: List[UserPresenceState]
|
self, states: List[UserPresenceState]
|
||||||
):
|
):
|
||||||
"""If this instance is a federation sender, send the states to all
|
"""If this instance is a federation sender, send the states to all
|
||||||
destinations that are interested.
|
destinations that are interested. Filters out any states for remote
|
||||||
|
users.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
if not self._send_federation:
|
if not self._send_federation:
|
||||||
|
@ -270,6 +272,11 @@ class BasePresenceHandler(abc.ABC):
|
||||||
# If this worker sends federation we must have a FederationSender.
|
# If this worker sends federation we must have a FederationSender.
|
||||||
assert self._federation
|
assert self._federation
|
||||||
|
|
||||||
|
states = [s for s in states if self.is_mine_id(s.user_id)]
|
||||||
|
|
||||||
|
if not states:
|
||||||
|
return
|
||||||
|
|
||||||
hosts_and_states = await get_interested_remotes(
|
hosts_and_states = await get_interested_remotes(
|
||||||
self.store,
|
self.store,
|
||||||
self.presence_router,
|
self.presence_router,
|
||||||
|
@ -292,7 +299,6 @@ class WorkerPresenceHandler(BasePresenceHandler):
|
||||||
def __init__(self, hs):
|
def __init__(self, hs):
|
||||||
super().__init__(hs)
|
super().__init__(hs)
|
||||||
self.hs = hs
|
self.hs = hs
|
||||||
self.is_mine_id = hs.is_mine_id
|
|
||||||
|
|
||||||
self._presence_enabled = hs.config.use_presence
|
self._presence_enabled = hs.config.use_presence
|
||||||
|
|
||||||
|
@ -492,7 +498,6 @@ class PresenceHandler(BasePresenceHandler):
|
||||||
def __init__(self, hs: "HomeServer"):
|
def __init__(self, hs: "HomeServer"):
|
||||||
super().__init__(hs)
|
super().__init__(hs)
|
||||||
self.hs = hs
|
self.hs = hs
|
||||||
self.is_mine_id = hs.is_mine_id
|
|
||||||
self.server_name = hs.hostname
|
self.server_name = hs.hostname
|
||||||
self.wheel_timer = WheelTimer()
|
self.wheel_timer = WheelTimer()
|
||||||
self.notifier = hs.get_notifier()
|
self.notifier = hs.get_notifier()
|
||||||
|
|
Loading…
Reference in New Issue