aboutsummaryrefslogtreecommitdiffstats
path: root/libmproxy
diff options
context:
space:
mode:
authorAldo Cortesi <aldo@nullcube.com>2012-02-09 16:40:31 +1300
committerAldo Cortesi <aldo@nullcube.com>2012-02-09 16:40:31 +1300
commit2709441d5ba203da7c685b53692e66e273d20058 (patch)
treef88c842c951ea57b61ca7f3e11edd818b3d5f6b2 /libmproxy
parent46bd7808625543bb42d1c1f20ff5599b837d1ca8 (diff)
downloadmitmproxy-2709441d5ba203da7c685b53692e66e273d20058.tar.gz
mitmproxy-2709441d5ba203da7c685b53692e66e273d20058.tar.bz2
mitmproxy-2709441d5ba203da7c685b53692e66e273d20058.zip
Add get_query and set_query methods to Request.
Diffstat (limited to 'libmproxy')
-rw-r--r--libmproxy/console/connview.py6
-rw-r--r--libmproxy/flow.py21
-rw-r--r--libmproxy/utils.py12
3 files changed, 34 insertions, 5 deletions
diff --git a/libmproxy/console/connview.py b/libmproxy/console/connview.py
index 7fe4c899..d057a59f 100644
--- a/libmproxy/console/connview.py
+++ b/libmproxy/console/connview.py
@@ -377,7 +377,7 @@ class ConnectionView(common.WWrap):
conn = self.flow.response
self.flow.backup()
- if part == "b":
+ if part == "r":
c = self.master.spawn_editor(conn.content or "")
conn.content = c.rstrip("\n")
elif part == "h":
@@ -445,7 +445,7 @@ class ConnectionView(common.WWrap):
"Edit request",
(
("header", "h"),
- ("body", "b"),
+ ("raw body", "r"),
("url", "u"),
("method", "m"),
),
@@ -458,7 +458,7 @@ class ConnectionView(common.WWrap):
("code", "c"),
("message", "m"),
("header", "h"),
- ("body", "b"),
+ ("raw body", "r"),
),
self.edit
)
diff --git a/libmproxy/flow.py b/libmproxy/flow.py
index 818d8139..e929440e 100644
--- a/libmproxy/flow.py
+++ b/libmproxy/flow.py
@@ -2,7 +2,7 @@
This module provides more sophisticated flow tracking. These match requests
with their responses, and provide filtering and interception facilities.
"""
-import hashlib, Cookie, cookielib, copy, re
+import hashlib, Cookie, cookielib, copy, re, urlparse
import time
import tnetstring, filt, script, utils, encoding, proxy
from email.utils import parsedate_tz, formatdate, mktime_tz
@@ -312,6 +312,25 @@ class Request(HTTPMsg):
host = "%s:%s"%(self.host, self.port)
return host
+ def get_query(self):
+ """
+ Gets the request query string. Returns a list of (key, value)
+ tuples.
+ """
+ _, _, _, _, query, _ = urlparse.urlparse(self.get_url())
+ if not query:
+ return []
+ return utils.urldecode(query)
+
+ def set_query(self, q):
+ """
+ Takes a list of (key, value) tuples, and sets the request query
+ string.
+ """
+ scheme, netloc, path, params, _, fragment = urlparse.urlparse(self.get_url())
+ query = utils.urlencode(q)
+ self.set_url(urlparse.urlunparse([scheme, netloc, path, params, query, fragment]))
+
def get_url(self):
"""
Returns a URL string, constructed from the Request's URL compnents.
diff --git a/libmproxy/utils.py b/libmproxy/utils.py
index 4339ec6d..c12ccc9b 100644
--- a/libmproxy/utils.py
+++ b/libmproxy/utils.py
@@ -12,7 +12,7 @@
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
-import re, os, subprocess, datetime, urlparse, string
+import re, os, subprocess, datetime, urlparse, string, urllib
import time, functools, cgi, textwrap, hashlib
import json
@@ -123,9 +123,19 @@ def pretty_json(s):
def urldecode(s):
+ """
+ Takes a urlencoded string and returns a list of (key, value) tuples.
+ """
return cgi.parse_qsl(s)
+def urlencode(s):
+ """
+ Takes a list of (key, value) tuples and returns a urlencoded string.
+ """
+ return urllib.urlencode(s, False)
+
+
def hexdump(s):
"""
Returns a set of typles: