summary refs log tree commit diff
path: root/synapse
diff options
context:
space:
mode:
authorAndrew Morgan <andrew@amorgan.xyz>2020-02-17 16:35:24 +0000
committerAndrew Morgan <andrew@amorgan.xyz>2020-02-17 16:35:24 +0000
commitd246c99947cfcb00ff39f40ef78fd5185c977ddc (patch)
treefc06edfe2015a028a3817cdc08060e1142d80fb7 /synapse
parentremove unused and unnecessary check for FederationDeniedError (#5645) (diff)
parentMerge pull request #5638 from matrix-org/babolivier/invite-json (diff)
downloadsynapse-d246c99947cfcb00ff39f40ef78fd5185c977ddc.tar.xz
Merge pull request #5638 from matrix-org/babolivier/invite-json
Diffstat (limited to 'synapse')
-rw-r--r--synapse/handlers/room_member.py28
1 files changed, 24 insertions, 4 deletions
diff --git a/synapse/handlers/room_member.py b/synapse/handlers/room_member.py

index ccf99bfff2..07aea3330e 100644 --- a/synapse/handlers/room_member.py +++ b/synapse/handlers/room_member.py
@@ -25,8 +25,14 @@ from twisted.internet import defer import synapse.server import synapse.types from synapse.api.constants import EventTypes, Membership -from synapse.api.errors import AuthError, Codes, ProxiedRequestError, SynapseError from synapse.api.ratelimiting import Ratelimiter +from synapse.api.errors import ( + AuthError, + Codes, + ProxiedRequestError, + HttpResponseException, + SynapseError, +) from synapse.types import RoomID, UserID from synapse.util.async_helpers import Linearizer from synapse.util.distributor import user_joined_room, user_left_room @@ -932,9 +938,23 @@ class RoomMemberHandler(object): "sender_avatar_url": inviter_avatar_url, } - data = yield self.simple_http_client.post_urlencoded_get_json( - is_url, invite_config - ) + try: + data = yield self.simple_http_client.post_json_get_json( + is_url, invite_config + ) + except HttpResponseException as e: + # Some identity servers may only support application/x-www-form-urlencoded + # types. This is especially true with old instances of Sydent, see + # https://github.com/matrix-org/sydent/pull/170 + logger.info( + "Failed to POST %s with JSON, falling back to urlencoded form: %s", + is_url, + e, + ) + data = yield self.simple_http_client.post_urlencoded_get_json( + is_url, invite_config + ) + # TODO: Check for success token = data["token"] public_keys = data.get("public_keys", [])