summary refs log tree commit diff
path: root/synapse
diff options
context:
space:
mode:
authorErik Johnston <erik@matrix.org>2019-08-01 13:45:35 +0100
committerGitHub <noreply@github.com>2019-08-01 13:45:35 +0100
commit0b36decfb6ea05a84a8efe6b73c2d8718e2a32ab (patch)
tree2e334430259bf28df7a604d886f66b64ae4a6bba /synapse
parentMerge pull request #5802 from matrix-org/erikj/deny_redacting_different_room (diff)
parentFix spelling. (diff)
downloadsynapse-0b36decfb6ea05a84a8efe6b73c2d8718e2a32ab.tar.xz
Merge pull request #5801 from matrix-org/erikj/recursive_tombstone
Don't allow clients to send tombstones that reference the same room
Diffstat (limited to 'synapse')
-rw-r--r--synapse/events/validator.py9
1 files changed, 9 insertions, 0 deletions
diff --git a/synapse/events/validator.py b/synapse/events/validator.py
index f7ffd1d561..6374dd067d 100644
--- a/synapse/events/validator.py
+++ b/synapse/events/validator.py
@@ -106,6 +106,15 @@ class EventValidator(object):
             if event.content["membership"] not in Membership.LIST:
                 raise SynapseError(400, "Invalid membership key")
 
+        elif event.type == EventTypes.Tombstone:
+            if "replacement_room" not in event.content:
+                raise SynapseError(400, "Content has no replacement_room key")
+
+            if event.content["replacement_room"] == event.room_id:
+                raise SynapseError(
+                    400, "Tombstone cannot reference the room it was sent in"
+                )
+
     def _ensure_strings(self, d, keys):
         for s in keys:
             if s not in d: