2014-09-05 13:05:44 +00:00
|
|
|
# Usage: mitmdump -s "iframe_injector.py url"
|
|
|
|
# (this script works best with --anticache)
|
2014-09-12 00:42:45 +00:00
|
|
|
from bs4 import BeautifulSoup
|
2015-09-03 22:46:42 +00:00
|
|
|
from libmproxy.models import decoded
|
2014-09-05 13:05:44 +00:00
|
|
|
|
|
|
|
|
2014-09-08 14:02:31 +00:00
|
|
|
def start(context, argv):
|
2014-09-05 13:05:44 +00:00
|
|
|
if len(argv) != 2:
|
|
|
|
raise ValueError('Usage: -s "iframe_injector.py url"')
|
2014-09-08 14:02:31 +00:00
|
|
|
context.iframe_url = 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, ...)
|
2014-09-12 00:42:45 +00:00
|
|
|
html = BeautifulSoup(flow.response.content)
|
|
|
|
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)
|
|
|
|
flow.response.content = str(html)
|
2015-05-30 00:03:28 +00:00
|
|
|
context.log("Iframe inserted.")
|