diff options
author | Erik Johnston <erik@matrix.org> | 2016-02-19 12:07:49 +0000 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2016-02-19 12:19:56 +0000 |
commit | 42ac5f0c1ae560e64dd5e9335d7f16b83fdabda4 (patch) | |
tree | a100285e743df6e6220bd6e6b58e9aaa03fda114 /synapse | |
parent | Add Measures to presence (diff) | |
download | synapse-42ac5f0c1ae560e64dd5e9335d7f16b83fdabda4.tar.xz |
Only send presence updates to remote hosts if user is ours
Diffstat (limited to 'synapse')
-rw-r--r-- | synapse/handlers/presence.py | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/synapse/handlers/presence.py b/synapse/handlers/presence.py index 44bdc97ccb..451fc70b37 100644 --- a/synapse/handlers/presence.py +++ b/synapse/handlers/presence.py @@ -428,13 +428,21 @@ class PresenceHandler(BaseHandler): hosts_to_states = {} for room_id, states in room_ids_to_states.items(): + local_states = filter(self.hs.is_mine_id, states) + if not local_states: + continue + hosts = yield self.store.get_joined_hosts_for_room(room_id) for host in hosts: - hosts_to_states.setdefault(host, []).extend(states) + hosts_to_states.setdefault(host, []).extend(local_states) for user_id, states in users_to_states.items(): + local_states = filter(self.hs.is_mine_id, states) + if not local_states: + continue + host = UserID.from_string(user_id).domain - hosts_to_states.setdefault(host, []).extend(states) + hosts_to_states.setdefault(host, []).extend(local_states) # TODO: de-dup hosts_to_states, as a single host might have multiple # of same presence |