aboutsummaryrefslogtreecommitdiffstats
path: root/netlib/http/response.py
diff options
context:
space:
mode:
authorMaximilian Hils <git@maximilianhils.com>2016-04-02 22:49:05 +0200
committerMaximilian Hils <git@maximilianhils.com>2016-04-02 22:49:05 +0200
commit4e2acc4d9d453126ac0e8aa20f3cb7dcc6a85a8c (patch)
tree99f7f7055fcbbd091c939cb7fe99584e49866bd9 /netlib/http/response.py
parenta267934d99e2e5d561a71ee3bc3944ddb6f6ce53 (diff)
downloadmitmproxy-4e2acc4d9d453126ac0e8aa20f3cb7dcc6a85a8c.tar.gz
mitmproxy-4e2acc4d9d453126ac0e8aa20f3cb7dcc6a85a8c.tar.bz2
mitmproxy-4e2acc4d9d453126ac0e8aa20f3cb7dcc6a85a8c.zip
move HTTPResponse.refresh into netlib
Diffstat (limited to 'netlib/http/response.py')
-rw-r--r--netlib/http/response.py34
1 files changed, 34 insertions, 0 deletions
diff --git a/netlib/http/response.py b/netlib/http/response.py
index 8af3c041..4e2e6442 100644
--- a/netlib/http/response.py
+++ b/netlib/http/response.py
@@ -1,6 +1,8 @@
from __future__ import absolute_import, print_function, division
import warnings
+from email.utils import parsedate_tz, formatdate, mktime_tz
+import time
from . import cookies
from .headers import Headers
@@ -94,6 +96,38 @@ class Response(Message):
values.append(header)
self.headers.set_all("set-cookie", values)
+ def refresh(self, now=None):
+ """
+ This fairly complex and heuristic function refreshes a server
+ response for replay.
+
+ - It adjusts date, expires and last-modified headers.
+ - It adjusts cookie expiration.
+ """
+ if not now:
+ now = time.time()
+ delta = now - self.timestamp_start
+ refresh_headers = [
+ "date",
+ "expires",
+ "last-modified",
+ ]
+ for i in refresh_headers:
+ if i in self.headers:
+ d = parsedate_tz(self.headers[i])
+ if d:
+ new = mktime_tz(d) + delta
+ self.headers[i] = formatdate(new)
+ c = []
+ for set_cookie_header in self.headers.get_all("set-cookie"):
+ try:
+ refreshed = cookies.refresh_set_cookie_header(set_cookie_header, delta)
+ except ValueError:
+ refreshed = set_cookie_header
+ c.append(refreshed)
+ if c:
+ self.headers.set_all("set-cookie", c)
+
# Legacy
def get_cookies(self): # pragma: no cover