diff options
author | Erik Johnston <erik@matrix.org> | 2016-04-01 16:17:32 +0100 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2016-04-01 16:17:32 +0100 |
commit | c906f3066152ba7a65c0765a5812b71bb8a4016c (patch) | |
tree | 3b76d68a0cdf734a5385b3ab8d0c50e370426c6d /synapse/state.py | |
parent | Merge pull request #684 from matrix-org/markjh/backfill_id_gen (diff) | |
download | synapse-c906f3066152ba7a65c0765a5812b71bb8a4016c.tar.xz |
Do checks for memberships before creating events
Diffstat (limited to 'synapse/state.py')
-rw-r--r-- | synapse/state.py | 8 |
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: |