summary refs log tree commit diff
path: root/synapse/state.py
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2016-04-01 16:17:32 +0100
committerErik Johnston <erik@matrix.org>2016-04-01 16:17:32 +0100
commitc906f3066152ba7a65c0765a5812b71bb8a4016c (patch)
tree3b76d68a0cdf734a5385b3ab8d0c50e370426c6d /synapse/state.py
parentMerge pull request #684 from matrix-org/markjh/backfill_id_gen (diff)
downloadsynapse-c906f3066152ba7a65c0765a5812b71bb8a4016c.tar.xz
Do checks for memberships before creating events
Diffstat (limited to 'synapse/state.py')
-rw-r--r--synapse/state.py8
1 files changed, 5 insertions, 3 deletions
diff --git a/synapse/state.py b/synapse/state.py
index 4672ada1b3..5a5fd8ff12 100644
--- a/synapse/state.py
+++ b/synapse/state.py
@@ -75,7 +75,8 @@ class StateHandler(object):
         self._state_cache.start()
 
     @defer.inlineCallbacks
-    def get_current_state(self, room_id, event_type=None, state_key=""):
+    def get_current_state(self, room_id, event_type=None, state_key="",
+                          latest_event_ids=None):
         """ Retrieves the current state for the room. This is done by
         calling `get_latest_events_in_room` to get the leading edges of the
         event graph and then resolving any of the state conflicts.
@@ -88,9 +89,10 @@ class StateHandler(object):
 
         :returns map from (type, state_key) to event
         """
-        event_ids = yield self.store.get_latest_event_ids_in_room(room_id)
+        if not latest_event_ids:
+            latest_event_ids = yield self.store.get_latest_event_ids_in_room(room_id)
 
-        res = yield self.resolve_state_groups(room_id, event_ids)
+        res = yield self.resolve_state_groups(room_id, latest_event_ids)
         state = res[1]
 
         if event_type: