aboutsummaryrefslogtreecommitdiffstats
path: root/netlib/http/http1
diff options
context:
space:
mode:
Diffstat (limited to 'netlib/http/http1')
-rw-r--r--netlib/http/http1/assemble.py65
-rw-r--r--netlib/http/http1/read.py8
2 files changed, 40 insertions, 33 deletions
diff --git a/netlib/http/http1/assemble.py b/netlib/http/http1/assemble.py
index 88aeac05..864f6017 100644
--- a/netlib/http/http1/assemble.py
+++ b/netlib/http/http1/assemble.py
@@ -7,24 +7,24 @@ from .. import CONTENT_MISSING
def assemble_request(request):
- if request.body == CONTENT_MISSING:
+ if request.content == CONTENT_MISSING:
raise HttpException("Cannot assemble flow with CONTENT_MISSING")
head = assemble_request_head(request)
- body = b"".join(assemble_body(request.headers, [request.body]))
+ body = b"".join(assemble_body(request.headers, [request.data.content]))
return head + body
def assemble_request_head(request):
- first_line = _assemble_request_line(request)
- headers = _assemble_request_headers(request)
+ first_line = _assemble_request_line(request.data)
+ headers = _assemble_request_headers(request.data)
return b"%s\r\n%s\r\n" % (first_line, headers)
def assemble_response(response):
- if response.body == CONTENT_MISSING:
+ if response.content == CONTENT_MISSING:
raise HttpException("Cannot assemble flow with CONTENT_MISSING")
head = assemble_response_head(response)
- body = b"".join(assemble_body(response.headers, [response.body]))
+ body = b"".join(assemble_body(response.headers, [response.content]))
return head + body
@@ -45,42 +45,49 @@ def assemble_body(headers, body_chunks):
yield chunk
-def _assemble_request_line(request, form=None):
- if form is None:
- form = request.form_out
+def _assemble_request_line(request_data):
+ """
+ Args:
+ request_data (netlib.http.request.RequestData)
+ """
+ form = request_data.first_line_format
if form == "relative":
return b"%s %s %s" % (
- request.method,
- request.path,
- request.http_version
+ request_data.method,
+ request_data.path,
+ request_data.http_version
)
elif form == "authority":
return b"%s %s:%d %s" % (
- request.method,
- request.host,
- request.port,
- request.http_version
+ request_data.method,
+ request_data.host,
+ request_data.port,
+ request_data.http_version
)
elif form == "absolute":
return b"%s %s://%s:%d%s %s" % (
- request.method,
- request.scheme,
- request.host,
- request.port,
- request.path,
- request.http_version
+ request_data.method,
+ request_data.scheme,
+ request_data.host,
+ request_data.port,
+ request_data.path,
+ request_data.http_version
)
- else: # pragma: nocover
+ else:
raise RuntimeError("Invalid request form")
-def _assemble_request_headers(request):
- headers = request.headers.copy()
- if "host" not in headers and request.scheme and request.host and request.port:
+def _assemble_request_headers(request_data):
+ """
+ Args:
+ request_data (netlib.http.request.RequestData)
+ """
+ headers = request_data.headers.copy()
+ if "host" not in headers and request_data.scheme and request_data.host and request_data.port:
headers["host"] = utils.hostport(
- request.scheme,
- request.host,
- request.port
+ request_data.scheme,
+ request_data.host,
+ request_data.port
)
return bytes(headers)
diff --git a/netlib/http/http1/read.py b/netlib/http/http1/read.py
index 4c898348..76721e06 100644
--- a/netlib/http/http1/read.py
+++ b/netlib/http/http1/read.py
@@ -11,7 +11,7 @@ from .. import Request, Response, Headers
def read_request(rfile, body_size_limit=None):
request = read_request_head(rfile)
expected_body_size = expected_http_body_size(request)
- request._body = b"".join(read_body(rfile, expected_body_size, limit=body_size_limit))
+ request.data.content = b"".join(read_body(rfile, expected_body_size, limit=body_size_limit))
request.timestamp_end = time.time()
return request
@@ -155,7 +155,7 @@ def connection_close(http_version, headers):
# If we don't have a Connection header, HTTP 1.1 connections are assumed to
# be persistent
- return http_version != b"HTTP/1.1"
+ return http_version != "HTTP/1.1" and http_version != b"HTTP/1.1" # FIXME: Remove one case.
def expected_http_body_size(request, response=None):
@@ -184,11 +184,11 @@ def expected_http_body_size(request, response=None):
if headers.get("expect", "").lower() == "100-continue":
return 0
else:
- if request.method.upper() == b"HEAD":
+ if request.method.upper() == "HEAD":
return 0
if 100 <= response_code <= 199:
return 0
- if response_code == 200 and request.method.upper() == b"CONNECT":
+ if response_code == 200 and request.method.upper() == "CONNECT":
return 0
if response_code in (204, 304):
return 0