1
0

Merge pull request #5801 from matrix-org/erikj/recursive_tombstone

This commit is contained in:
Andrew Morgan
2020-02-20 15:49:08 +00:00
2 changed files with 10 additions and 0 deletions

1
changelog.d/5801.misc Normal file
View File

@@ -0,0 +1 @@
Don't allow clients to send tombstone events that reference the room it's sent in.

View File

@@ -200,6 +200,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: