diff options
author | Richard van der Hoff <richard@matrix.org> | 2018-08-06 15:15:19 +0100 |
---|---|---|
committer | Richard van der Hoff <richard@matrix.org> | 2018-08-06 16:11:24 +0100 |
commit | 19a17068f1bc98a1556ff618b544b5fbf57eeba0 (patch) | |
tree | 37ce3bb5d4f8fa711036a4710b61c9ea34095ea2 /synapse/event_auth.py | |
parent | include known room versions in outgoing make_joins (diff) | |
download | synapse-19a17068f1bc98a1556ff618b544b5fbf57eeba0.tar.xz |
Check m.room.create for sane room_versions
Diffstat (limited to 'synapse/event_auth.py')
-rw-r--r-- | synapse/event_auth.py | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/synapse/event_auth.py b/synapse/event_auth.py index b32f64e729..6baeccca38 100644 --- a/synapse/event_auth.py +++ b/synapse/event_auth.py @@ -20,7 +20,7 @@ from signedjson.key import decode_verify_key_bytes from signedjson.sign import SignatureVerifyException, verify_signed_json from unpaddedbase64 import decode_base64 -from synapse.api.constants import EventTypes, JoinRules, Membership +from synapse.api.constants import KNOWN_ROOM_VERSIONS, EventTypes, JoinRules, Membership from synapse.api.errors import AuthError, EventSizeError, SynapseError from synapse.types import UserID, get_domain_from_id @@ -83,6 +83,14 @@ def check(event, auth_events, do_sig_check=True, do_size_check=True): 403, "Creation event's room_id domain does not match sender's" ) + + room_version = event.content.get("room_version", "1") + if room_version not in KNOWN_ROOM_VERSIONS: + raise AuthError( + 403, + "room appears to have unsupported version %s" % ( + room_version, + )) # FIXME logger.debug("Allowing! %s", event) return |