mirror of
https://mau.dev/maunium/synapse.git
synced 2025-01-05 22:24:01 +01:00
Fix a bug in the joined_rooms admin API (#8643)
If the user was not in any rooms then the API returned the same error as if the user did not exist.
This commit is contained in:
parent
cf9a17a2b3
commit
4ac3a8c5dc
3 changed files with 20 additions and 4 deletions
1
changelog.d/8643.bugfix
Normal file
1
changelog.d/8643.bugfix
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Fix a bug in the `joined_rooms` admin API if the user has never joined any rooms. The bug was introduced, along with the API, in v1.21.0.
|
|
@ -702,9 +702,10 @@ class UserMembershipRestServlet(RestServlet):
|
||||||
if not self.is_mine(UserID.from_string(user_id)):
|
if not self.is_mine(UserID.from_string(user_id)):
|
||||||
raise SynapseError(400, "Can only lookup local users")
|
raise SynapseError(400, "Can only lookup local users")
|
||||||
|
|
||||||
room_ids = await self.store.get_rooms_for_user(user_id)
|
user = await self.store.get_user_by_id(user_id)
|
||||||
if not room_ids:
|
if user is None:
|
||||||
raise NotFoundError("User not found")
|
raise NotFoundError("Unknown user")
|
||||||
|
|
||||||
|
room_ids = await self.store.get_rooms_for_user(user_id)
|
||||||
ret = {"joined_rooms": list(room_ids), "total": len(room_ids)}
|
ret = {"joined_rooms": list(room_ids), "total": len(room_ids)}
|
||||||
return 200, ret
|
return 200, ret
|
||||||
|
|
|
@ -1016,7 +1016,6 @@ class UserMembershipRestTestCase(unittest.HomeserverTestCase):
|
||||||
servlets = [
|
servlets = [
|
||||||
synapse.rest.admin.register_servlets,
|
synapse.rest.admin.register_servlets,
|
||||||
login.register_servlets,
|
login.register_servlets,
|
||||||
sync.register_servlets,
|
|
||||||
room.register_servlets,
|
room.register_servlets,
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -1082,6 +1081,21 @@ class UserMembershipRestTestCase(unittest.HomeserverTestCase):
|
||||||
self.assertEqual(400, channel.code, msg=channel.json_body)
|
self.assertEqual(400, channel.code, msg=channel.json_body)
|
||||||
self.assertEqual("Can only lookup local users", channel.json_body["error"])
|
self.assertEqual("Can only lookup local users", channel.json_body["error"])
|
||||||
|
|
||||||
|
def test_no_memberships(self):
|
||||||
|
"""
|
||||||
|
Tests that a normal lookup for rooms is successfully
|
||||||
|
if user has no memberships
|
||||||
|
"""
|
||||||
|
# Get rooms
|
||||||
|
request, channel = self.make_request(
|
||||||
|
"GET", self.url, access_token=self.admin_user_tok,
|
||||||
|
)
|
||||||
|
self.render(request)
|
||||||
|
|
||||||
|
self.assertEqual(200, channel.code, msg=channel.json_body)
|
||||||
|
self.assertEqual(0, channel.json_body["total"])
|
||||||
|
self.assertEqual(0, len(channel.json_body["joined_rooms"]))
|
||||||
|
|
||||||
def test_get_rooms(self):
|
def test_get_rooms(self):
|
||||||
"""
|
"""
|
||||||
Tests that a normal lookup for rooms is successfully
|
Tests that a normal lookup for rooms is successfully
|
||||||
|
|
Loading…
Reference in a new issue