summary refs log tree commit diff
path: root/synapse
diff options
context:
space:
mode:
authorAndrew Morgan <andrew@amorgan.xyz>2020-02-26 12:08:58 +0000
committerAndrew Morgan <andrew@amorgan.xyz>2020-02-26 12:08:58 +0000
commit2ac458d86dacea2a144be0434953730fc4d5d201 (patch)
tree43bc24178047e48f211f65e17988c8b229829e40 /synapse
parentMerge pull request #6141 from matrix-org/erikj/censor_redactions_fix (diff)
parentMerge pull request #6145 from matrix-org/erikj/fix_censored_redactions (diff)
downloadsynapse-2ac458d86dacea2a144be0434953730fc4d5d201.tar.xz
Merge pull request #6145 from matrix-org/erikj/fix_censored_redactions
Diffstat (limited to 'synapse')
-rw-r--r--synapse/storage/events_worker.py14
1 files changed, 14 insertions, 0 deletions
diff --git a/synapse/storage/events_worker.py b/synapse/storage/events_worker.py
index c6fa7f82fd..57ce0304e9 100644
--- a/synapse/storage/events_worker.py
+++ b/synapse/storage/events_worker.py
@@ -238,6 +238,20 @@ class EventsWorkerStore(SQLBaseStore):
             # we have to recheck auth now.
 
             if not allow_rejected and entry.event.type == EventTypes.Redaction:
+                if not hasattr(entry.event, "redacts"):
+                    # A redacted redaction doesn't have a `redacts` key, in
+                    # which case lets just withhold the event.
+                    #
+                    # Note: Most of the time if the redactions has been
+                    # redacted we still have the un-redacted event in the DB
+                    # and so we'll still see the `redacts` key. However, this
+                    # isn't always true e.g. if we have censored the event.
+                    logger.debug(
+                        "Withholding redaction event %s as we don't have redacts key",
+                        event_id,
+                    )
+                    continue
+
                 redacted_event_id = entry.event.redacts
                 event_map = yield self._get_events_from_cache_or_db([redacted_event_id])
                 original_event_entry = event_map.get(redacted_event_id)