Skip to content
This repository has been archived by the owner on Apr 26, 2024. It is now read-only.

Improve error responses when a remote server doesn't allow you to access its public rooms list #6899

Merged
merged 6 commits into from
Apr 6, 2020
1 change: 1 addition & 0 deletions changelog.d/6899.bugfix
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
Improve error responses when accessing remote public room lists.
23 changes: 12 additions & 11 deletions synapse/handlers/room_list.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@

import logging
from collections import namedtuple
from typing import Any, Dict, Optional

from six import iteritems

Expand Down Expand Up @@ -105,22 +106,22 @@ def get_local_public_room_list(
@defer.inlineCallbacks
def _get_public_room_list(
self,
limit=None,
since_token=None,
search_filter=None,
network_tuple=EMPTY_THIRD_PARTY_ID,
from_federation=False,
):
limit: Optional[int] = None,
since_token: Optional[str] = None,
search_filter: Optional[Dict] = None,
network_tuple: ThirdPartyInstanceID = EMPTY_THIRD_PARTY_ID,
from_federation: bool = False,
) -> Dict[str, Any]:
"""Generate a public room list.
Args:
limit (int|None): Maximum amount of rooms to return.
since_token (str|None)
search_filter (dict|None): Dictionary to filter rooms by.
network_tuple (ThirdPartyInstanceID): Which public list to use.
limit: Maximum amount of rooms to return.
since_token:
search_filter: Dictionary to filter rooms by.
network_tuple: Which public list to use.
This can be (None, None) to indicate the main list, or a particular
appservice and network id to use an appservice specific one.
Setting to None returns all public rooms across all lists.
from_federation (bool): Whether this request originated from a
from_federation: Whether this request originated from a
federating server or a client. Used for room filtering.
"""

Expand Down
53 changes: 40 additions & 13 deletions synapse/rest/client/v1/room.py
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
from synapse.api.errors import (
AuthError,
Codes,
HttpResponseException,
InvalidClientCredentialsError,
SynapseError,
)
Expand Down Expand Up @@ -371,10 +372,23 @@ async def on_GET(self, request):
limit = None

handler = self.hs.get_room_list_handler()
if server:
data = await handler.get_remote_public_room_list(
server, limit=limit, since_token=since_token
)
if server and server != self.hs.config.server_name:
try:
data = await handler.get_remote_public_room_list(
server, limit=limit, since_token=since_token
)
except HttpResponseException as e:
if e.code == 401:
raise SynapseError(
400,
"The remote server is only allowing local users to view "
"its public rooms list",
anoadragon453 marked this conversation as resolved.
Show resolved Hide resolved
errcode=Codes.FORBIDDEN,
)
else:
raise SynapseError(
400, "Unable to retrieve remote public rooms list"
)
anoadragon453 marked this conversation as resolved.
Show resolved Hide resolved
else:
data = await handler.get_local_public_room_list(
limit=limit, since_token=since_token
Expand Down Expand Up @@ -411,15 +425,28 @@ async def on_POST(self, request):
limit = None

handler = self.hs.get_room_list_handler()
if server:
data = await handler.get_remote_public_room_list(
server,
limit=limit,
since_token=since_token,
search_filter=search_filter,
include_all_networks=include_all_networks,
third_party_instance_id=third_party_instance_id,
)
if server and server != self.hs.config.server_name:
try:
data = await handler.get_remote_public_room_list(
server,
limit=limit,
since_token=since_token,
search_filter=search_filter,
include_all_networks=include_all_networks,
third_party_instance_id=third_party_instance_id,
)
except HttpResponseException as e:
if e.code == 401:
raise SynapseError(
400,
"The remote server is only allowing local users to view "
"its public rooms list",
errcode=Codes.FORBIDDEN,
)
else:
raise SynapseError(
400, "Unable to retrieve remote public rooms list"
)
else:
data = await handler.get_local_public_room_list(
limit=limit,
Expand Down