diff options
author | Erik Johnston <erik@matrix.org> | 2016-03-04 15:27:55 +0000 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2016-03-04 15:27:55 +0000 |
commit | 125f674eae8c98b2aaab61847dcecd1392258e30 (patch) | |
tree | 9881fadb943f82bdc1b9e0f1bbbc1074e9e71936 | |
parent | Merge pull request #598 from Rugvip/invite-state (diff) | |
download | synapse-125f674eae8c98b2aaab61847dcecd1392258e30.tar.xz |
Always include kicks and bans in full /sync
Diffstat (limited to '')
-rw-r--r-- | synapse/handlers/sync.py | 12 |
1 files changed, 9 insertions, 3 deletions
diff --git a/synapse/handlers/sync.py b/synapse/handlers/sync.py index fded6e4009..26a66814eb 100644 --- a/synapse/handlers/sync.py +++ b/synapse/handlers/sync.py @@ -209,9 +209,9 @@ class SyncHandler(BaseHandler): key=None ) - membership_list = (Membership.INVITE, Membership.JOIN) - if sync_config.filter_collection.include_leave: - membership_list += (Membership.LEAVE, Membership.BAN) + membership_list = ( + Membership.INVITE, Membership.JOIN, Membership.LEAVE, Membership.BAN + ) room_list = yield self.store.get_rooms_for_user_where_membership_is( user_id=sync_config.user.to_string(), @@ -257,6 +257,12 @@ class SyncHandler(BaseHandler): invite=invite, )) elif event.membership in (Membership.LEAVE, Membership.BAN): + # Always send down rooms we were banned or kicked from. + if not sync_config.filter_collection.include_leave: + if event.membership == Membership.LEAVE: + if sync_config.user.to_string() == event.sender: + continue + leave_token = now_token.copy_and_replace( "room_key", "s%d" % (event.stream_ordering,) ) |