Use a single query in `ProfileHandler.get_profile` (#13209)
2 files changed, 8 insertions, 12 deletions
diff --git a/changelog.d/13209.misc b/changelog.d/13209.misc
new file mode 100644
index 0000000000..cb0b8b4e63
--- /dev/null
+++ b/changelog.d/13209.misc
@@ -0,0 +1 @@
+Reduce number of queries used to get profile information. Contributed by Nick @ Beeper (@fizzadar).
diff --git a/synapse/handlers/profile.py b/synapse/handlers/profile.py
index 6eed3826a7..d8ff5289b5 100644
--- a/synapse/handlers/profile.py
+++ b/synapse/handlers/profile.py
@@ -67,19 +67,14 @@ class ProfileHandler:
target_user = UserID.from_string(user_id)
if self.hs.is_mine(target_user):
- try:
- displayname = await self.store.get_profile_displayname(
- target_user.localpart
- )
- avatar_url = await self.store.get_profile_avatar_url(
- target_user.localpart
- )
- except StoreError as e:
- if e.code == 404:
- raise SynapseError(404, "Profile was not found", Codes.NOT_FOUND)
- raise
+ profileinfo = await self.store.get_profileinfo(target_user.localpart)
+ if profileinfo.display_name is None:
+ raise SynapseError(404, "Profile was not found", Codes.NOT_FOUND)
- return {"displayname": displayname, "avatar_url": avatar_url}
+ return {
+ "displayname": profileinfo.display_name,
+ "avatar_url": profileinfo.avatar_url,
+ }
else:
try:
result = await self.federation.make_query(
|