diff options
author | Erik Johnston <erik@matrix.org> | 2019-06-17 17:30:05 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2019-06-17 17:30:05 +0100 |
commit | 8353ddd95165262767c4c3b960a3f00acb12d4ce (patch) | |
tree | ef3497ca4cad6b654e105409da0de6479231e0b4 /synapse/handlers | |
parent | Merge pull request #5478 from matrix-org/joriks/demo_python3 (diff) | |
parent | Newsfile (diff) | |
download | synapse-8353ddd95165262767c4c3b960a3f00acb12d4ce.tar.xz |
Merge pull request #5479 from matrix-org/erikj/add_create_room_hook_develop
Add third party rules hook into create room
Diffstat (limited to 'synapse/handlers')
-rw-r--r-- | synapse/handlers/room.py | 25 |
1 files changed, 24 insertions, 1 deletions
diff --git a/synapse/handlers/room.py b/synapse/handlers/room.py index 4a17911a87..74793bab33 100644 --- a/synapse/handlers/room.py +++ b/synapse/handlers/room.py @@ -75,6 +75,10 @@ class RoomCreationHandler(BaseHandler): # linearizer to stop two upgrades happening at once self._upgrade_linearizer = Linearizer("room_upgrade_linearizer") + self._server_notices_mxid = hs.config.server_notices_mxid + + self.third_party_event_rules = hs.get_third_party_event_rules() + @defer.inlineCallbacks def upgrade_room(self, requester, old_room_id, new_version): """Replace a room with a new room with a different version @@ -470,7 +474,26 @@ class RoomCreationHandler(BaseHandler): yield self.auth.check_auth_blocking(user_id) - if not self.spam_checker.user_may_create_room(user_id): + if (self._server_notices_mxid is not None and + requester.user.to_string() == self._server_notices_mxid): + # allow the server notices mxid to create rooms + is_requester_admin = True + else: + is_requester_admin = yield self.auth.is_server_admin( + requester.user, + ) + + # Check whether the third party rules allows/changes the room create + # request. + yield self.third_party_event_rules.on_create_room( + requester, + config, + is_requester_admin=is_requester_admin, + ) + + if not is_requester_admin and not self.spam_checker.user_may_create_room( + user_id, + ): raise SynapseError(403, "You are not permitted to create rooms") if ratelimit: |