summary refs log tree commit diff
path: root/synapse
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2016-02-19 12:07:49 +0000
committerErik Johnston <erik@matrix.org>2016-02-19 12:19:56 +0000
commit42ac5f0c1ae560e64dd5e9335d7f16b83fdabda4 (patch)
treea100285e743df6e6220bd6e6b58e9aaa03fda114 /synapse
parentAdd Measures to presence (diff)
downloadsynapse-42ac5f0c1ae560e64dd5e9335d7f16b83fdabda4.tar.xz
Only send presence updates to remote hosts if user is ours
Diffstat (limited to 'synapse')
-rw-r--r--synapse/handlers/presence.py12
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