Fix application service not being able to join remote federated room without a profile set (#13131)

Fix https://github.com/matrix-org/synapse/issues/4778

Complement tests: https://github.com/matrix-org/complement/pull/399
This commit is contained in:
Eric Eastwood 2022-07-05 05:56:06 -05:00 committed by GitHub
parent 65e675504f
commit 2c2a42cc10
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 24 additions and 9 deletions

1
changelog.d/13131.bugfix Normal file
View File

@ -0,0 +1 @@
Fix application service not being able to join remote federated room without a profile set.

View File

@ -846,10 +846,17 @@ class RoomMemberHandler(metaclass=abc.ABCMeta):
content["membership"] = Membership.JOIN content["membership"] = Membership.JOIN
try:
profile = self.profile_handler profile = self.profile_handler
if not content_specified: if not content_specified:
content["displayname"] = await profile.get_displayname(target) content["displayname"] = await profile.get_displayname(target)
content["avatar_url"] = await profile.get_avatar_url(target) content["avatar_url"] = await profile.get_avatar_url(target)
except Exception as e:
logger.info(
"Failed to get profile information while processing remote join for %r: %s",
target,
e,
)
if requester.is_guest: if requester.is_guest:
content["kind"] = "guest" content["kind"] = "guest"
@ -926,11 +933,18 @@ class RoomMemberHandler(metaclass=abc.ABCMeta):
content["membership"] = Membership.KNOCK content["membership"] = Membership.KNOCK
try:
profile = self.profile_handler profile = self.profile_handler
if "displayname" not in content: if "displayname" not in content:
content["displayname"] = await profile.get_displayname(target) content["displayname"] = await profile.get_displayname(target)
if "avatar_url" not in content: if "avatar_url" not in content:
content["avatar_url"] = await profile.get_avatar_url(target) content["avatar_url"] = await profile.get_avatar_url(target)
except Exception as e:
logger.info(
"Failed to get profile information while processing remote knock for %r: %s",
target,
e,
)
return await self.remote_knock( return await self.remote_knock(
remote_room_hosts, room_id, target, content remote_room_hosts, room_id, target, content