mitmproxy/examples/custom_contentviews.py

70 lines
2.1 KiB
Python
Raw Normal View History

2015-11-13 21:55:27 +00:00
import string
import lxml.html
import lxml.etree
from mitmproxy import utils, contentviews
2015-11-13 21:55:27 +00:00
2015-11-14 02:46:34 +00:00
class ViewPigLatin(contentviews.View):
2015-11-13 21:55:27 +00:00
name = "pig_latin_HTML"
prompt = ("pig latin HTML", "l")
content_types = ["text/html"]
def __call__(self, data, **metadata):
if utils.isXML(data):
parser = lxml.etree.HTMLParser(
strip_cdata=True,
remove_blank_text=True
)
d = lxml.html.fromstring(data, parser=parser)
docinfo = d.getroottree().docinfo
def piglify(src):
words = string.split(src)
ret = ''
for word in words:
idx = -1
2016-05-29 08:23:39 +00:00
while word[idx] in string.punctuation and (idx * -1) != len(word):
idx -= 1
2015-11-13 21:55:27 +00:00
if word[0].lower() in 'aeiou':
2015-11-14 02:46:34 +00:00
if idx == -1:
ret += word[0:] + "hay"
else:
ret += word[0:len(word) + idx + 1] + "hay" + word[idx + 1:]
2015-11-13 21:55:27 +00:00
else:
2015-11-14 02:46:34 +00:00
if idx == -1:
ret += word[1:] + word[0] + "ay"
else:
ret += word[1:len(word) + idx + 1] + word[0] + "ay" + word[idx + 1:]
2015-11-13 21:55:27 +00:00
ret += ' '
return ret.strip()
def recurse(root):
if hasattr(root, 'text') and root.text:
2015-11-14 02:46:34 +00:00
root.text = piglify(root.text)
2015-11-13 21:55:27 +00:00
if hasattr(root, 'tail') and root.tail:
2015-11-14 02:46:34 +00:00
root.tail = piglify(root.tail)
2015-11-13 21:55:27 +00:00
if len(root):
for child in root:
recurse(child)
recurse(d)
s = lxml.etree.tostring(
d,
pretty_print=True,
doctype=docinfo.doctype
)
2015-11-14 02:46:34 +00:00
return "HTML", contentviews.format_text(s)
2015-11-13 21:55:27 +00:00
pig_view = ViewPigLatin()
def start(context, argv):
context.add_contentview(pig_view)
2016-03-10 20:17:05 +00:00
def done(context):
2015-11-13 21:55:27 +00:00
context.remove_contentview(pig_view)