summary refs log tree commit diff
path: root/synapse/visibility.py
diff options
context:
space:
mode:
authorBrendan Abolivier <babolivier@matrix.org>2019-08-28 18:49:13 +0100
committerGitHub <noreply@github.com>2019-08-28 18:49:13 +0100
commit99eec6d2d5cc76e645c3fd7ca6cda85b2bab6feb (patch)
tree6434740f5f259c420f0863ad50d7a0ff3314d5a9 /synapse/visibility.py
parentMerge pull request #5812 from matrix-org/babolivier/account-validity-messages (diff)
parentMerge branch 'dinsic' into babolivier/dinsic-message-retention (diff)
downloadsynapse-99eec6d2d5cc76e645c3fd7ca6cda85b2bab6feb.tar.xz
Merge pull request #5815 from matrix-org/babolivier/dinsic-message-retention dinsic_2019-08-29
Message retention policies at the room and server levels
Diffstat (limited to 'synapse/visibility.py')
-rw-r--r--synapse/visibility.py15
1 files changed, 15 insertions, 0 deletions
diff --git a/synapse/visibility.py b/synapse/visibility.py

index 16c40cd74c..5b6562b481 100644 --- a/synapse/visibility.py +++ b/synapse/visibility.py
@@ -92,6 +92,12 @@ def filter_events_for_client(store, user_id, events, is_peeking=False, erased_senders = yield store.are_users_erased((e.sender for e in events)) + room_ids = set(e.room_id for e in events) + retention_policies = {} + + for room_id in room_ids: + retention_policies[room_id] = yield store.get_retention_policy_for_room(room_id) + def allowed(event): """ Args: @@ -109,6 +115,15 @@ def filter_events_for_client(store, user_id, events, is_peeking=False, if not event.is_state() and event.sender in ignore_list: return None + retention_policy = retention_policies[event.room_id] + max_lifetime = retention_policy.get("max_lifetime") + + if max_lifetime is not None: + oldest_allowed_ts = store.clock.time_msec() - max_lifetime + + if event.origin_server_ts < oldest_allowed_ts: + return None + if event.event_id in always_include_ids: return event