summary refs log tree commit diff
path: root/synapse/state.py
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2015-02-04 10:36:28 +0000
committerErik Johnston <erik@matrix.org>2015-02-04 10:36:28 +0000
commitf275ba49bbcb86e111ed0d66dd99da617220ae79 (patch)
tree2aedafb7b4c6eea9d4b1c3c0e16a3e2a895428ab /synapse/state.py
parentRearrange persist_event so that do all the queries that need to be done befor... (diff)
downloadsynapse-f275ba49bbcb86e111ed0d66dd99da617220ae79.tar.xz
Fix state resolution to remember join_rules is a type of auth event.
Diffstat (limited to 'synapse/state.py')
-rw-r--r--synapse/state.py14
1 files changed, 13 insertions, 1 deletions
diff --git a/synapse/state.py b/synapse/state.py

index 8a056ee955..6a6fb8aea0 100644 --- a/synapse/state.py +++ b/synapse/state.py
@@ -37,7 +37,10 @@ def _get_state_key_from_event(event): KeyStateTuple = namedtuple("KeyStateTuple", ("context", "type", "state_key")) -AuthEventTypes = (EventTypes.Create, EventTypes.Member, EventTypes.PowerLevels,) +AuthEventTypes = ( + EventTypes.Create, EventTypes.Member, EventTypes.PowerLevels, + EventTypes.JoinRules, +) class StateHandler(object): @@ -259,6 +262,15 @@ class StateHandler(object): auth_events.update(resolved_state) for key, events in conflicted_state.items(): + if key[0] == EventTypes.JoinRules: + resolved_state[key] = self._resolve_auth_events( + events, + auth_events + ) + + auth_events.update(resolved_state) + + for key, events in conflicted_state.items(): if key[0] == EventTypes.Member: resolved_state[key] = self._resolve_auth_events( events,