-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Fix additional type hints from Twisted upgrade #9518
Changes from 10 commits
db2e164
99c1ce4
7c2b13f
9ed6dbb
5cf5863
b9c941a
6926db7
01a3edb
96b3466
c9767e9
23d4438
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
Fix incorrect type hints. |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -21,6 +21,7 @@ | |
import types | ||
import urllib | ||
from http import HTTPStatus | ||
from inspect import isawaitable | ||
from io import BytesIO | ||
from typing import ( | ||
Any, | ||
|
@@ -30,6 +31,7 @@ | |
Iterable, | ||
Iterator, | ||
List, | ||
Optional, | ||
Pattern, | ||
Tuple, | ||
Union, | ||
|
@@ -79,10 +81,12 @@ def return_json_error(f: failure.Failure, request: SynapseRequest) -> None: | |
"""Sends a JSON error response to clients.""" | ||
|
||
if f.check(SynapseError): | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Should we change this to There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I don't think so. This is the proper way to check against twisted failures? There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. True, probably easier (and more likely) for us to remove a There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think my thought is that if we want to make that change we should do is as a discrete step, not bury it in this PR! |
||
error_code = f.value.code | ||
error_dict = f.value.error_dict() | ||
# mypy doesn't understand that f.check asserts the type. | ||
exc = f.value # type: SynapseError # type: ignore | ||
error_code = exc.code | ||
error_dict = exc.error_dict() | ||
|
||
logger.info("%s SynapseError: %s - %s", request, error_code, f.value.msg) | ||
logger.info("%s SynapseError: %s - %s", request, error_code, exc.msg) | ||
else: | ||
error_code = 500 | ||
error_dict = {"error": "Internal server error", "errcode": Codes.UNKNOWN} | ||
|
@@ -91,7 +95,7 @@ def return_json_error(f: failure.Failure, request: SynapseRequest) -> None: | |
"Failed handle request via %r: %r", | ||
request.request_metrics.name, | ||
request, | ||
exc_info=(f.type, f.value, f.getTracebackObject()), | ||
exc_info=(f.type, f.value, f.getTracebackObject()), # type: ignore | ||
) | ||
|
||
# Only respond with an error response if we haven't already started writing, | ||
|
@@ -128,7 +132,8 @@ def return_html_error( | |
`{msg}` placeholders), or a jinja2 template | ||
""" | ||
if f.check(CodeMessageException): | ||
cme = f.value | ||
# mypy doesn't understand that f.check asserts the type. | ||
cme = f.value # type: CodeMessageException # type: ignore | ||
code = cme.code | ||
msg = cme.msg | ||
|
||
|
@@ -142,7 +147,7 @@ def return_html_error( | |
logger.error( | ||
"Failed handle request %r", | ||
request, | ||
exc_info=(f.type, f.value, f.getTracebackObject()), | ||
exc_info=(f.type, f.value, f.getTracebackObject()), # type: ignore | ||
) | ||
else: | ||
code = HTTPStatus.INTERNAL_SERVER_ERROR | ||
|
@@ -151,7 +156,7 @@ def return_html_error( | |
logger.error( | ||
"Failed handle request %r", | ||
request, | ||
exc_info=(f.type, f.value, f.getTracebackObject()), | ||
exc_info=(f.type, f.value, f.getTracebackObject()), # type: ignore | ||
) | ||
|
||
if isinstance(error_template, str): | ||
|
@@ -278,7 +283,7 @@ async def _async_render(self, request: Request): | |
raw_callback_return = method_handler(request) | ||
|
||
# Is it synchronous? We'll allow this for now. | ||
if isinstance(raw_callback_return, (defer.Deferred, types.CoroutineType)): | ||
if isawaitable(raw_callback_return): | ||
callback_return = await raw_callback_return | ||
else: | ||
callback_return = raw_callback_return # type: ignore | ||
|
@@ -399,8 +404,10 @@ def _get_handler_for_request( | |
A tuple of the callback to use, the name of the servlet, and the | ||
key word arguments to pass to the callback | ||
""" | ||
# At this point the path must be bytes. | ||
request_path_bytes = request.path # type: bytes # type: ignore | ||
request_path = request_path_bytes.decode("ascii") | ||
# Treat HEAD requests as GET requests. | ||
request_path = request.path.decode("ascii") | ||
request_method = request.method | ||
if request_method == b"HEAD": | ||
request_method = b"GET" | ||
|
@@ -551,7 +558,7 @@ def __init__( | |
request: Request, | ||
iterator: Iterator[bytes], | ||
): | ||
self._request = request | ||
self._request = request # type: Optional[Request] | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We set it to |
||
self._iterator = iterator | ||
self._paused = False | ||
|
||
|
@@ -563,7 +570,7 @@ def _send_data(self, data: List[bytes]) -> None: | |
""" | ||
Send a list of bytes as a chunk of a response. | ||
""" | ||
if not data: | ||
if not data or not self._request: | ||
return | ||
self._request.write(b"".join(data)) | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -38,6 +38,7 @@ | |
|
||
import twisted.internet.base | ||
import twisted.internet.tcp | ||
from twisted.internet import defer | ||
from twisted.mail.smtp import sendmail | ||
from twisted.web.iweb import IPolicyForHTTPS | ||
|
||
|
@@ -403,7 +404,7 @@ def get_room_shutdown_handler(self) -> RoomShutdownHandler: | |
return RoomShutdownHandler(self) | ||
|
||
@cache_in_self | ||
def get_sendmail(self) -> sendmail: | ||
def get_sendmail(self) -> Callable[..., defer.Deferred]: | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I started adding a better type signature here, but |
||
return sendmail | ||
|
||
@cache_in_self | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We haven't switched this to
async
sincerequest
is part of theIAgent
interface.