Linter and typing
This commit is contained in:
parent
5832764aab
commit
6bedec97ae
11
sanic/app.py
11
sanic/app.py
|
@ -63,9 +63,14 @@ class Sanic:
|
||||||
frame_records = stack()[1]
|
frame_records = stack()[1]
|
||||||
name = getmodulename(frame_records[1])
|
name = getmodulename(frame_records[1])
|
||||||
# Check for unsupported function on custom request objects
|
# Check for unsupported function on custom request objects
|
||||||
if request_class and any(hasattr(request_class, m) for m in (
|
if (
|
||||||
"body_init", "body_push", "body_finish"
|
request_class
|
||||||
)) and request_class.receive_body is Request.receive_body:
|
and any(
|
||||||
|
hasattr(request_class, m)
|
||||||
|
for m in ("body_init", "body_push", "body_finish")
|
||||||
|
)
|
||||||
|
and request_class.receive_body is Request.receive_body
|
||||||
|
):
|
||||||
raise NotImplementedError(
|
raise NotImplementedError(
|
||||||
"Request methods body_init, body_push and body_finish "
|
"Request methods body_init, body_push and body_finish "
|
||||||
f"are no longer supported. {request_class!r} should "
|
f"are no longer supported. {request_class!r} should "
|
||||||
|
|
|
@ -5,11 +5,11 @@ from multidict import CIMultiDict # type: ignore
|
||||||
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
from trio import Cancelled
|
from trio import Cancelled # type: ignore
|
||||||
|
|
||||||
CancelledErrors = CancelledError, Cancelled
|
CancelledErrors = [CancelledError, Cancelled]
|
||||||
except ImportError:
|
except ImportError:
|
||||||
CancelledErrors = (CancelledError,)
|
CancelledErrors = [CancelledError]
|
||||||
|
|
||||||
|
|
||||||
class Header(CIMultiDict):
|
class Header(CIMultiDict):
|
||||||
|
|
|
@ -179,7 +179,7 @@ class Http:
|
||||||
self.stage = Stage.HANDLER
|
self.stage = Stage.HANDLER
|
||||||
self.request = request
|
self.request = request
|
||||||
|
|
||||||
async def http1_response_header(self, data, end_stream) -> bytes:
|
async def http1_response_header(self, data, end_stream):
|
||||||
res = self.response
|
res = self.response
|
||||||
# Compatibility with simple response body
|
# Compatibility with simple response body
|
||||||
if not data and getattr(res, "body", None):
|
if not data and getattr(res, "body", None):
|
||||||
|
@ -244,22 +244,22 @@ class Http:
|
||||||
self.response_func = None
|
self.response_func = None
|
||||||
self.stage = Stage.IDLE
|
self.stage = Stage.IDLE
|
||||||
|
|
||||||
async def http1_response_chunked(self, data, end_stream) -> bytes:
|
async def http1_response_chunked(self, data, end_stream):
|
||||||
"""Format a part of response body in chunked encoding."""
|
"""Format a part of response body in chunked encoding."""
|
||||||
# Chunked encoding
|
# Chunked encoding
|
||||||
size = len(data)
|
size = len(data)
|
||||||
if end_stream:
|
if end_stream:
|
||||||
await self._send(
|
await self._send(
|
||||||
b"%x\r\n%b\r\n0\r\n\r\n" % (size, data)
|
b"%x\r\n%b\r\n0\r\n\r\n" % (size, data)
|
||||||
if size else
|
if size
|
||||||
b"0\r\n\r\n"
|
else b"0\r\n\r\n"
|
||||||
)
|
)
|
||||||
self.response_func = None
|
self.response_func = None
|
||||||
self.stage = Stage.IDLE
|
self.stage = Stage.IDLE
|
||||||
elif size:
|
elif size:
|
||||||
await self._send(b"%x\r\n%b\r\n" % (size, data))
|
await self._send(b"%x\r\n%b\r\n" % (size, data))
|
||||||
|
|
||||||
async def http1_response_normal(self, data: bytes, end_stream: bool) -> bytes:
|
async def http1_response_normal(self, data: bytes, end_stream: bool):
|
||||||
"""Format / keep track of non-chunked response."""
|
"""Format / keep track of non-chunked response."""
|
||||||
bytes_left = self.response_bytes_left - len(data)
|
bytes_left = self.response_bytes_left - len(data)
|
||||||
if bytes_left <= 0:
|
if bytes_left <= 0:
|
||||||
|
|
|
@ -132,24 +132,17 @@ class Request:
|
||||||
)
|
)
|
||||||
return response
|
return response
|
||||||
|
|
||||||
async def receive_body(self):
|
|
||||||
self.body = b"".join([data async for data in self.stream])
|
|
||||||
|
|
||||||
async def receive_body(self):
|
async def receive_body(self):
|
||||||
"""Receive request.body, if not already received.
|
"""Receive request.body, if not already received.
|
||||||
|
|
||||||
Streaming handlers may call this to receive the full body.
|
Streaming handlers may call this to receive the full body. Sanic calls
|
||||||
|
this function before running any handlers of non-streaming routes.
|
||||||
|
|
||||||
This is added as a compatibility shim in Sanic 20.3 because future
|
Custom request classes can override this for custom handling of both
|
||||||
versions of Sanic will make all requests streaming and will use this
|
streaming and non-streaming routes.
|
||||||
function instead of the non-async body_init/push/finish functions.
|
|
||||||
|
|
||||||
Please make an issue if your code depends on the old functionality and
|
|
||||||
cannot be upgraded to the new API.
|
|
||||||
"""
|
"""
|
||||||
if not self.stream:
|
if not self.body:
|
||||||
return
|
self.body = b"".join([data async for data in self.stream])
|
||||||
self.body = b"".join([data async for data in self.stream])
|
|
||||||
|
|
||||||
@property
|
@property
|
||||||
def json(self):
|
def json(self):
|
||||||
|
|
Loading…
Reference in New Issue
Block a user