aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarcelo Glezer <mg@tekii.com.ar>2015-01-14 12:03:40 -0300
committerMarcelo Glezer <mg@tekii.com.ar>2015-01-14 12:03:40 -0300
commita4bfa677e95b058c50d49b4b3ae986351ed0cbf8 (patch)
treef30559fea9c6d9924fb12dcfd4b97466d19719e1
parent34d355a62b3103e322793e2af652ee0aa867ddaf (diff)
downloadmitmproxy-a4bfa677e95b058c50d49b4b3ae986351ed0cbf8.tar.gz
mitmproxy-a4bfa677e95b058c50d49b4b3ae986351ed0cbf8.tar.bz2
mitmproxy-a4bfa677e95b058c50d49b4b3ae986351ed0cbf8.zip
now content and header are working and exception for binary files are handled correctly
-rw-r--r--libmproxy/console/flowlist.py13
-rw-r--r--libmproxy/protocol/http.py14
2 files changed, 16 insertions, 11 deletions
diff --git a/libmproxy/console/flowlist.py b/libmproxy/console/flowlist.py
index 89dc56a9..655df74d 100644
--- a/libmproxy/console/flowlist.py
+++ b/libmproxy/console/flowlist.py
@@ -13,6 +13,7 @@ def _mkhelp():
("D", "duplicate flow"),
("e", "toggle eventlog"),
("F", "toggle follow flow list"),
+ ("g", "copy response(content/headers) to clipboard"),
("l", "set limit filter pattern"),
("L", "load saved flows"),
("r", "replay request"),
@@ -139,9 +140,15 @@ class ConnectionItem(common.WWrap):
)
def server_copy_response(self, k):
if k == "c":
- pyperclip.copy(self.flow.response_content())
- elif k == "t":
- pyperclip.copy(self.flow.response_headers())
+ try:
+ pyperclip.copy(self.flow.response_content())
+ except TypeError:
+ self.master.statusbar.message("Content is binary or can be converted to text")
+ elif k == "h":
+ try:
+ pyperclip.copy(self.flow.response_headers())
+ except TypeError:
+ self.master.statusbar.message("Error converting headers to text")
def keypress(self, (maxcol,), key):
key = common.shortcuts(key)
diff --git a/libmproxy/protocol/http.py b/libmproxy/protocol/http.py
index 4de1c0a6..f822fcc8 100644
--- a/libmproxy/protocol/http.py
+++ b/libmproxy/protocol/http.py
@@ -954,20 +954,18 @@ class HTTPFlow(Flow):
return c
def response_content(self):
- s = "[No Content]"
with decoded(self.response):
s = self.response.content
+ if s == None:
+ s = "[No content]"
return s
def response_headers(self):
with decoded(self.response):
- sh = ""
- for i in self.flow.response.headers:
- v = self.flow.response.headers[i]
- for j in v:
- sh += str(i)+"="+str(v[j])+"\n"
- return sh
-
+ s = str(self.response.headers)
+ if s == None:
+ s = "[]"
+ return s
class HttpAuthenticationError(Exception):
def __init__(self, auth_headers=None):