diff options
author | Aldo Cortesi <aldo@nullcube.com> | 2012-02-09 16:40:31 +1300 |
---|---|---|
committer | Aldo Cortesi <aldo@nullcube.com> | 2012-02-09 16:40:31 +1300 |
commit | 2709441d5ba203da7c685b53692e66e273d20058 (patch) | |
tree | f88c842c951ea57b61ca7f3e11edd818b3d5f6b2 /libmproxy | |
parent | 46bd7808625543bb42d1c1f20ff5599b837d1ca8 (diff) | |
download | mitmproxy-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.py | 6 | ||||
-rw-r--r-- | libmproxy/flow.py | 21 | ||||
-rw-r--r-- | libmproxy/utils.py | 12 |
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: |