Modifications to ruequest and router files to fix linting issues.

This commit is contained in:
Andres Sanchez
2018-11-01 10:04:40 -06:00
parent e63d0091af
commit e3655b525d
2 changed files with 22 additions and 15 deletions

View File

@@ -1,16 +1,10 @@
import json
import sys import sys
import json
from cgi import parse_header from cgi import parse_header
from collections import namedtuple from collections import namedtuple
from http.cookies import SimpleCookie from http.cookies import SimpleCookie
from urllib.parse import parse_qs, urlunparse
from httptools import parse_url from httptools import parse_url
from urllib.parse import parse_qs, urlunparse
from sanic.exceptions import InvalidUsage
from sanic.log import error_logger, logger
try: try:
from ujson import loads as json_loads from ujson import loads as json_loads
@@ -24,6 +18,8 @@ except ImportError:
else: else:
json_loads = json.loads json_loads = json.loads
from sanic.exceptions import InvalidUsage
from sanic.log import error_logger, logger
DEFAULT_HTTP_CONTENT_TYPE = "application/octet-stream" DEFAULT_HTTP_CONTENT_TYPE = "application/octet-stream"
@@ -71,6 +67,7 @@ class Request(dict):
"_port", "_port",
"__weakref__", "__weakref__",
"raw_url", "raw_url",
"_match_info",
) )
def __init__(self, url_bytes, headers, version, method, transport): def __init__(self, url_bytes, headers, version, method, transport):
@@ -93,6 +90,7 @@ class Request(dict):
self.uri_template = None self.uri_template = None
self._cookies = None self._cookies = None
self.stream = None self.stream = None
self._match_info = None
def __repr__(self): def __repr__(self):
if self.method is None or not self.path: if self.method is None or not self.path:
@@ -273,8 +271,14 @@ class Request(dict):
@property @property
def match_info(self): def match_info(self):
"""return matched info after resolving route""" """return matched info after resolving route"""
if self._match_info is not None:
return self._match_info
return self.app.router.get(self)[2] return self.app.router.get(self)[2]
@match_info.setter
def match_info(self, value):
self._match_info = value
@property @property
def path(self): def path(self):
return self._parsed_url.path.decode("utf-8") return self._parsed_url.path.decode("utf-8")

View File

@@ -1,15 +1,13 @@
import re import re
import uuid import uuid
from collections import defaultdict, namedtuple from collections import defaultdict, namedtuple
from collections.abc import Iterable from collections.abc import Iterable
from functools import lru_cache from functools import lru_cache
from urllib.parse import unquote from urllib.parse import unquote
from sanic.exceptions import MethodNotSupported, NotFound from sanic.exceptions import NotFound, MethodNotSupported
from sanic.views import CompositionView from sanic.views import CompositionView
Route = namedtuple( Route = namedtuple(
"Route", ["handler", "methods", "pattern", "parameters", "name", "uri"] "Route", ["handler", "methods", "pattern", "parameters", "name", "uri"]
) )
@@ -393,15 +391,20 @@ class Router:
""" """
# No virtual hosts specified; default behavior # No virtual hosts specified; default behavior
if not self.hosts: if not self.hosts:
return self._get(request.path, request.method, "") processed = self._get(request.path, request.method, "")
# virtual hosts specified; try to match route to the host header # virtual hosts specified; try to match route to the host header
try: try:
return self._get( processed = self._get(
request.path, request.method, request.headers.get("Host", "") request.path, request.method, request.headers.get("Host", "")
) )
# try default hosts # try default hosts
except NotFound: except NotFound:
return self._get(request.path, request.method, "") processed = self._get(request.path, request.method, "")
handler, args, kwargs, uri = processed
kwargs = kwargs if request._match_info is None else request._match_info
return handler, args, kwargs, uri
def get_supported_methods(self, url): def get_supported_methods(self, url):
"""Get a list of supported methods for a url and optional host. """Get a list of supported methods for a url and optional host.