diff options
author | David Baker <dave@matrix.org> | 2017-03-23 18:50:31 +0000 |
---|---|---|
committer | David Baker <dave@matrix.org> | 2017-03-23 18:50:31 +0000 |
commit | e1f1784f99dbb7815250e4963b6969230ea6e8d3 (patch) | |
tree | 9bafe48c19316502b63d6e822faad978dfaae74a /synapse | |
parent | Merge pull request #1783 from pik/filter-validation (diff) | |
download | synapse-e1f1784f99dbb7815250e4963b6969230ea6e8d3.tar.xz |
Fix rejection of invites not reaching sync
Always allow the user to see their own leave events, otherwise they won't see the event if they reject an invite for a room whose history visibility is set such that they cannot see events before joining.
Diffstat (limited to 'synapse')
-rw-r--r-- | synapse/visibility.py | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/synapse/visibility.py b/synapse/visibility.py index 199b16d827..31659156ae 100644 --- a/synapse/visibility.py +++ b/synapse/visibility.py @@ -134,6 +134,13 @@ def filter_events_for_clients(store, user_tuples, events, event_id_to_state): if prev_membership not in MEMBERSHIP_PRIORITY: prev_membership = "leave" + # Always allow the user to see their own leave events, otherwise + # they won't see the room disappear if they reject the invite + if membership == "leave" and ( + prev_membership == "join" or prev_membership == "invite" + ): + return True + new_priority = MEMBERSHIP_PRIORITY.index(membership) old_priority = MEMBERSHIP_PRIORITY.index(prev_membership) if old_priority < new_priority: |