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

Commit 6840ebe

Browse files
authored
Merge pull request #5385 from matrix-org/erikj/reduce_http_exceptions
Handle HttpResponseException when using federation client.
2 parents dd927b2 + 6745b7d commit 6840ebe

File tree

5 files changed

+29
-19
lines changed

5 files changed

+29
-19
lines changed

changelog.d/5383.misc

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Don't log non-200 responses from federation queries as exceptions.

synapse/groups/attestations.py

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -42,7 +42,7 @@
4242

4343
from twisted.internet import defer
4444

45-
from synapse.api.errors import RequestSendFailed, SynapseError
45+
from synapse.api.errors import HttpResponseException, RequestSendFailed, SynapseError
4646
from synapse.metrics.background_process_metrics import run_as_background_process
4747
from synapse.types import get_domain_from_id
4848
from synapse.util.logcontext import run_in_background
@@ -195,7 +195,7 @@ def _renew_attestation(group_id, user_id):
195195
yield self.store.update_attestation_renewal(
196196
group_id, user_id, attestation
197197
)
198-
except RequestSendFailed as e:
198+
except (RequestSendFailed, HttpResponseException) as e:
199199
logger.warning(
200200
"Failed to renew attestation of %r in %r: %s",
201201
user_id, group_id, e,

synapse/handlers/groups_local.py

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -49,9 +49,7 @@ def f(self, group_id, *args, **kwargs):
4949
def http_response_errback(failure):
5050
failure.trap(HttpResponseException)
5151
e = failure.value
52-
if e.code == 403:
53-
raise e.to_synapse_error()
54-
return failure
52+
raise e.to_synapse_error()
5553

5654
def request_failed_errback(failure):
5755
failure.trap(RequestSendFailed)

synapse/handlers/profile.py

Lines changed: 16 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -15,12 +15,15 @@
1515

1616
import logging
1717

18+
from six import raise_from
19+
1820
from twisted.internet import defer
1921

2022
from synapse.api.errors import (
2123
AuthError,
22-
CodeMessageException,
2324
Codes,
25+
HttpResponseException,
26+
RequestSendFailed,
2427
StoreError,
2528
SynapseError,
2629
)
@@ -85,10 +88,10 @@ def get_profile(self, user_id):
8588
ignore_backoff=True,
8689
)
8790
defer.returnValue(result)
88-
except CodeMessageException as e:
89-
if e.code != 404:
90-
logger.exception("Failed to get displayname")
91-
raise
91+
except RequestSendFailed as e:
92+
raise_from(SynapseError(502, "Failed to fetch profile"), e)
93+
except HttpResponseException as e:
94+
raise e.to_synapse_error()
9295

9396
@defer.inlineCallbacks
9497
def get_profile_from_cache(self, user_id):
@@ -142,10 +145,10 @@ def get_displayname(self, target_user):
142145
},
143146
ignore_backoff=True,
144147
)
145-
except CodeMessageException as e:
146-
if e.code != 404:
147-
logger.exception("Failed to get displayname")
148-
raise
148+
except RequestSendFailed as e:
149+
raise_from(SynapseError(502, "Failed to fetch profile"), e)
150+
except HttpResponseException as e:
151+
raise e.to_synapse_error()
149152

150153
defer.returnValue(result["displayname"])
151154

@@ -208,10 +211,10 @@ def get_avatar_url(self, target_user):
208211
},
209212
ignore_backoff=True,
210213
)
211-
except CodeMessageException as e:
212-
if e.code != 404:
213-
logger.exception("Failed to get avatar_url")
214-
raise
214+
except RequestSendFailed as e:
215+
raise_from(SynapseError(502, "Failed to fetch profile"), e)
216+
except HttpResponseException as e:
217+
raise e.to_synapse_error()
215218

216219
defer.returnValue(result["avatar_url"])
217220

synapse/replication/http/_base.py

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -17,11 +17,17 @@
1717
import logging
1818
import re
1919

20+
from six import raise_from
2021
from six.moves import urllib
2122

2223
from twisted.internet import defer
2324

24-
from synapse.api.errors import CodeMessageException, HttpResponseException
25+
from synapse.api.errors import (
26+
CodeMessageException,
27+
HttpResponseException,
28+
RequestSendFailed,
29+
SynapseError,
30+
)
2531
from synapse.util.caches.response_cache import ResponseCache
2632
from synapse.util.stringutils import random_string
2733

@@ -175,6 +181,8 @@ def send_request(**kwargs):
175181
# on the master process that we should send to the client. (And
176182
# importantly, not stack traces everywhere)
177183
raise e.to_synapse_error()
184+
except RequestSendFailed as e:
185+
raise_from(SynapseError(502, "Failed to talk to master"), e)
178186

179187
defer.returnValue(result)
180188

0 commit comments

Comments
 (0)