diff --git a/synapse/appservice/__init__.py b/synapse/appservice/__init__.py index 0dfa00df44c7..71b534b0397f 100644 --- a/synapse/appservice/__init__.py +++ b/synapse/appservice/__init__.py @@ -172,15 +172,11 @@ async def _matches_user_in_member_list( Returns: True if this service would like to know about this room. """ - member_list = await store.get_users_in_room( - room_id, on_invalidate=cache_context.invalidate + app_service_users_in_room = await store.get_app_service_users_in_room( + room_id, self, on_invalidate=cache_context.invalidate ) - # check joined member events - for user_id in member_list: - if self.is_interested_in_user(user_id): - return True - return False + return len(app_service_users_in_room) > 0 def is_interested_in_user( self, diff --git a/synapse/handlers/room_member.py b/synapse/handlers/room_member.py index 88158822e009..96cc6eae71be 100644 --- a/synapse/handlers/room_member.py +++ b/synapse/handlers/room_member.py @@ -1150,7 +1150,7 @@ async def transfer_room_state_on_room_upgrade( logger.info("Transferring room state from %s to %s", old_room_id, room_id) # Find all local users that were in the old room and copy over each user's state - users = await self.store.get_users_in_room(old_room_id) + users = await self.store.get_local_users_in_room(old_room_id) await self.copy_user_state_on_room_upgrade(old_room_id, room_id, users) # Add new room to the room directory if the old room was there diff --git a/synapse/handlers/user_directory.py b/synapse/handlers/user_directory.py index 8c3c52e1caa6..19df4de43930 100644 --- a/synapse/handlers/user_directory.py +++ b/synapse/handlers/user_directory.py @@ -392,6 +392,7 @@ async def _track_user_joined_room(self, room_id: str, user_id: str) -> None: if is_public: await self.store.add_users_in_public_rooms(room_id, (user_id,)) else: + # TODO: get_local_users_in_room here users_in_room = await self.store.get_users_in_room(room_id) other_users_in_room = [ other diff --git a/synapse/storage/databases/main/appservice.py b/synapse/storage/databases/main/appservice.py index 64b70a7b28ee..26fd4fa31a85 100644 --- a/synapse/storage/databases/main/appservice.py +++ b/synapse/storage/databases/main/appservice.py @@ -157,7 +157,19 @@ async def get_app_service_users_in_room( app_service: "ApplicationService", cache_context: _CacheContext, ) -> List[str]: - users_in_room = await self.get_users_in_room( + """ + Get all users in a room that the appservice controls. + + Args: + room_id: The room to check in. + app_service: The application service to check interest/control against + + Returns: + List of user IDs that the appservice controls. + """ + # We can use `get_local_users_in_room(...)` here because an application + # service can only act on behalf of users of the server it's on. + users_in_room = await self.get_local_users_in_room( room_id, on_invalidate=cache_context.invalidate ) return list(filter(app_service.is_interested_in_user, users_in_room)) diff --git a/synapse/storage/databases/main/roommember.py b/synapse/storage/databases/main/roommember.py index 982e1f08e30b..8a9e553397b4 100644 --- a/synapse/storage/databases/main/roommember.py +++ b/synapse/storage/databases/main/roommember.py @@ -152,13 +152,18 @@ async def get_users_in_room(self, room_id: str) -> List[str]: `get_current_hosts_in_room()` and so we can re-use the cache but it's not horrible to have here either. - Uses `m.room.member`s in the room state at the current forward extremities to - determine which users are in the room. - - Will return inaccurate results for rooms with partial state, since the state for - the forward extremities of those rooms will exclude most members. We may also - calculate room state incorrectly for such rooms and believe that a member is or - is not in the room when the opposite is true. + Uses `m.room.member`s in the room state at the current forward + extremities to determine which users are in the room. + + Will return inaccurate results for rooms with partial state, since the + state for the forward extremities of those rooms will exclude most + members. We may also calculate room state incorrectly for such rooms and + believe that a member is or is not in the room when the opposite is + true. + + Note: If you only care about users in the room local to the homeserver, + use `get_local_users_in_room(...)` instead which will be more + performant. """ return await self.db_pool.runInteraction( "get_users_in_room", self.get_users_in_room_txn, room_id