diff options
author | Aldo Cortesi <aldo@nullcube.com> | 2013-12-08 10:15:43 +1300 |
---|---|---|
committer | Aldo Cortesi <aldo@nullcube.com> | 2013-12-08 10:15:43 +1300 |
commit | ed74b628569348d3d71cfe6e6a5f29b5289ee82c (patch) | |
tree | 0d23809113380fbcf78531a41fb913af134e6c12 /netlib/http.py | |
parent | bed2aed9db346f37b858c8f7f069f65e9f59d0e9 (diff) | |
parent | 5aad09ab816b2343ca686d45e6c5d2b8ba07b10b (diff) | |
download | mitmproxy-ed74b628569348d3d71cfe6e6a5f29b5289ee82c.tar.gz mitmproxy-ed74b628569348d3d71cfe6e6a5f29b5289ee82c.tar.bz2 mitmproxy-ed74b628569348d3d71cfe6e6a5f29b5289ee82c.zip |
Merge branch 'fix_invalid_tcp_close'
Diffstat (limited to 'netlib/http.py')
-rw-r--r-- | netlib/http.py | 17 |
1 files changed, 4 insertions, 13 deletions
diff --git a/netlib/http.py b/netlib/http.py index f1a2bfb5..7060b688 100644 --- a/netlib/http.py +++ b/netlib/http.py @@ -283,32 +283,23 @@ def parse_init_http(line): return method, url, httpversion -def request_connection_close(httpversion, headers): +def connection_close(httpversion, headers): """ - Checks the request to see if the client connection should be closed. + Checks the message to see if the client connection should be closed according to RFC 2616 Section 8.1 """ + # At first, check if we have an explicit Connection header. if "connection" in headers: toks = get_header_tokens(headers, "connection") if "close" in toks: return True elif "keep-alive" in toks: return False - # HTTP 1.1 connections are assumed to be persistent + # If we don't have a Connection header, HTTP 1.1 connections are assumed to be persistent if httpversion == (1, 1): return False return True -def response_connection_close(httpversion, headers): - """ - Checks the response to see if the client connection should be closed. - """ - if request_connection_close(httpversion, headers): - return True - elif (not has_chunked_encoding(headers)) and "content-length" in headers: - return False - return True - def read_http_body_request(rfile, wfile, headers, httpversion, limit): """ |