Ver código fonte

Merge pull request #845 from matrix-org/markjh/synchrotron_presence

Fix a KeyError in the synchrotron presence
Mark Haines 8 anos atrás
pai
commit
b0932b34cb
1 arquivos alterados com 4 adições e 1 exclusões
  1. 4 1
      synapse/app/synchrotron.py

+ 4 - 1
synapse/app/synchrotron.py

@@ -187,7 +187,10 @@ class SynchrotronPresence(object):
                 yield self._send_syncing_users_now()
 
         def _end():
-            if affect_presence:
+            # We check that the user_id is in user_to_num_current_syncs because
+            # user_to_num_current_syncs may have been cleared if we are
+            # shutting down.
+            if affect_presence and user_id in self.user_to_num_current_syncs:
                 self.user_to_num_current_syncs[user_id] -= 1
 
         @contextlib.contextmanager