Clarify comments in the space summary handler. (#9974)

pull/10009/head
Patrick Cloke 2021-05-17 09:01:19 -04:00 committed by GitHub
parent 653fe2f3cd
commit 9752849e2b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 47 additions and 5 deletions

1
changelog.d/9974.misc Normal file
View File

@ -0,0 +1 @@
Update comments in the space summary handler.

View File

@ -32,7 +32,6 @@ if TYPE_CHECKING:
logger = logging.getLogger(__name__) logger = logging.getLogger(__name__)
# number of rooms to return. We'll stop once we hit this limit. # number of rooms to return. We'll stop once we hit this limit.
# TODO: allow clients to reduce this with a request param.
MAX_ROOMS = 50 MAX_ROOMS = 50
# max number of events to return per room. # max number of events to return per room.
@ -231,11 +230,15 @@ class SpaceSummaryHandler:
Generate a room entry and a list of event entries for a given room. Generate a room entry and a list of event entries for a given room.
Args: Args:
requester: The requesting user, or None if this is over federation. requester:
The user requesting the summary, if it is a local request. None
if this is a federation request.
room_id: The room ID to summarize. room_id: The room ID to summarize.
suggested_only: True if only suggested children should be returned. suggested_only: True if only suggested children should be returned.
Otherwise, all children are returned. Otherwise, all children are returned.
max_children: The maximum number of children to return for this node. max_children:
The maximum number of children rooms to include. This is capped
to a server-set limit.
Returns: Returns:
A tuple of: A tuple of:
@ -278,6 +281,26 @@ class SpaceSummaryHandler:
max_children: Optional[int], max_children: Optional[int],
exclude_rooms: Iterable[str], exclude_rooms: Iterable[str],
) -> Tuple[Sequence[JsonDict], Sequence[JsonDict]]: ) -> Tuple[Sequence[JsonDict], Sequence[JsonDict]]:
"""
Request room entries and a list of event entries for a given room by querying a remote server.
Args:
room: The room to summarize.
suggested_only: True if only suggested children should be returned.
Otherwise, all children are returned.
max_children:
The maximum number of children rooms to include. This is capped
to a server-set limit.
exclude_rooms:
Rooms IDs which do not need to be summarized.
Returns:
A tuple of:
An iterable of rooms.
An iterable of the sorted children events. This may be limited
to a maximum size or may include all children.
"""
room_id = room.room_id room_id = room.room_id
logger.info("Requesting summary for %s via %s", room_id, room.via) logger.info("Requesting summary for %s via %s", room_id, room.via)
@ -310,8 +333,26 @@ class SpaceSummaryHandler:
) )
async def _is_room_accessible(self, room_id: str, requester: Optional[str]) -> bool: async def _is_room_accessible(self, room_id: str, requester: Optional[str]) -> bool:
# if we have an authenticated requesting user, first check if they are in the """
# room Calculate whether the room should be shown in the spaces summary.
It should be included if:
* The requester is joined or invited to the room.
* The history visibility is set to world readable.
Args:
room_id: The room ID to summarize.
requester:
The user requesting the summary, if it is a local request. None
if this is a federation request.
Returns:
True if the room should be included in the spaces summary.
"""
# if we have an authenticated requesting user, first check if they are able to view
# stripped state in the room.
if requester: if requester:
try: try:
await self._auth.check_user_in_room(room_id, requester) await self._auth.check_user_in_room(room_id, requester)