Browse Source

Merge pull request #4362 from matrix-org/erikj/better_errors

Use RequestSendFailed when fail to parse content type headers
Erik Johnston 5 years ago
parent
commit
d1d81d0651
2 changed files with 6 additions and 5 deletions
  1. 1 0
      changelog.d/4362.misc
  2. 5 5
      synapse/http/matrixfederationclient.py

+ 1 - 0
changelog.d/4362.misc

@@ -0,0 +1 @@
+Add better logging for unexpected errors while sending transactions

+ 5 - 5
synapse/http/matrixfederationclient.py

@@ -823,21 +823,21 @@ def check_content_type_is_json(headers):
         headers (twisted.web.http_headers.Headers): headers to check
 
     Raises:
-        RuntimeError if the
+        RequestSendFailed: if the Content-Type header is missing or isn't JSON
 
     """
     c_type = headers.getRawHeaders(b"Content-Type")
     if c_type is None:
-        raise RuntimeError(
+        raise RequestSendFailed(RuntimeError(
             "No Content-Type header"
-        )
+        ), can_retry=False)
 
     c_type = c_type[0].decode('ascii')  # only the first header
     val, options = cgi.parse_header(c_type)
     if val != "application/json":
-        raise RuntimeError(
+        raise RequestSendFailed(RuntimeError(
             "Content-Type not application/json: was '%s'" % c_type
-        )
+        ), can_retry=False)
 
 
 def encode_query_args(args):