Skip to content

Commit

Permalink
Refactor a bit
Browse files Browse the repository at this point in the history
  • Loading branch information
babolivier authored and phil-flex committed Mar 27, 2020
1 parent 8bdbd2f commit 30bfa8c
Showing 1 changed file with 30 additions and 28 deletions.
58 changes: 30 additions & 28 deletions synapse/visibility.py
Original file line number Diff line number Diff line change
Expand Up @@ -118,34 +118,36 @@ def allowed(event):
the original event if they can see it as normal.
"""
if event.type == "org.matrix.dummy_event" and filter_send_to_client:
return None

if (
not event.is_state()
and event.sender in ignore_list
and filter_send_to_client
):
return None

# Until MSC2261 has landed we can't redact malicious alias events, so for
# now we temporarily filter out m.room.aliases entirely to mitigate
# abuse, while we spec a better solution to advertising aliases
# on rooms.
if event.type == EventTypes.Aliases and filter_send_to_client:
return None

# Don't try to apply the room's retention policy if the event is a state event, as
# MSC1763 states that retention is only considered for non-state events.
if filter_send_to_client and not event.is_state():
retention_policy = retention_policies[event.room_id]
max_lifetime = retention_policy.get("max_lifetime")

if max_lifetime is not None:
oldest_allowed_ts = storage.main.clock.time_msec() - max_lifetime

if event.origin_server_ts < oldest_allowed_ts:
return None
# Only run some checks if these events aren't about to be sent to clients. This is
# because, if this is not the case, we're probably only checking if the users can
# see events in the room at that point in the DAG, and that shouldn't be decided
# on those checks.
if filter_send_to_client:
if event.type == "org.matrix.dummy_event":
return None

if not event.is_state() and event.sender in ignore_list:
return None

# Until MSC2261 has landed we can't redact malicious alias events, so for
# now we temporarily filter out m.room.aliases entirely to mitigate
# abuse, while we spec a better solution to advertising aliases
# on rooms.
if event.type == EventTypes.Aliases:
return None

# Don't try to apply the room's retention policy if the event is a state
# event, as MSC1763 states that retention is only considered for non-state
# events.
if not event.is_state():
retention_policy = retention_policies[event.room_id]
max_lifetime = retention_policy.get("max_lifetime")

if max_lifetime is not None:
oldest_allowed_ts = storage.main.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
Expand Down

0 comments on commit 30bfa8c

Please sign in to comment.