This commit is contained in:
Andrea Spacca 2021-01-05 14:28:07 +01:00
parent 3d319b1247
commit 3d1a807f7e
2 changed files with 9 additions and 22 deletions

View File

@ -1197,30 +1197,17 @@ class ProxyDaemon:
if not client: if not client:
return self._unknown_token return self._unknown_token
room_id = request.match_info["room_id"]
# The room is not in the joined rooms list, just forward it.
try: try:
room = client.rooms[room_id] content = await request.json()
encrypt = room.encrypted except (JSONDecodeError, ContentTypeError):
except KeyError: return self._not_json
try:
content = await self._map_media_upload("avatar_url", content, request, client)
return await self.forward_to_web(request, data=json.dumps(content), token=client.access_token)
except ValueError:
return await self.forward_to_web(request, token=client.access_token) return await self.forward_to_web(request, token=client.access_token)
# The room isn't encrypted just forward the message.
if not encrypt:
try:
content = await request.json()
except (JSONDecodeError, ContentTypeError):
return self._not_json
try:
content = await self._map_media_upload("avatar_url", content, request, client)
return await self.forward_to_web(request, data=json.dumps(content), token=client.access_token)
except ValueError:
return await self.forward_to_web(request, token=client.access_token)
return await self.forward_to_web(request, token=client.access_token)
async def download(self, request): async def download(self, request):
server_name = request.match_info["server_name"] server_name = request.match_info["server_name"]
media_id = request.match_info["media_id"] media_id = request.match_info["media_id"]

View File

@ -97,7 +97,7 @@ async def init(data_dir, server_conf, send_queue, recv_queue):
r"/_matrix/media/r0/upload", r"/_matrix/media/r0/upload",
proxy.upload, proxy.upload,
), ),
web.post( web.put(
r"/_matrix/client/r0/profile/{userId}/avatar_url", r"/_matrix/client/r0/profile/{userId}/avatar_url",
proxy.profile, proxy.profile,
), ),