2021-02-04 19:22:36 +00:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
import contextlib
|
|
|
|
import inspect
|
|
|
|
import textwrap
|
|
|
|
from pathlib import Path
|
|
|
|
|
|
|
|
from mitmproxy import hooks, log, addonmanager
|
|
|
|
from mitmproxy.proxy import server_hooks, layer
|
2022-07-27 00:20:30 +00:00
|
|
|
from mitmproxy.proxy.layers import dns, http, modes, tcp, tls, udp, websocket
|
2021-02-04 19:22:36 +00:00
|
|
|
|
|
|
|
known = set()
|
|
|
|
|
|
|
|
|
2022-04-26 11:51:11 +00:00
|
|
|
def category(name: str, desc: str, hooks: list[type[hooks.Hook]]) -> None:
|
2021-02-04 19:22:36 +00:00
|
|
|
all_params = [
|
2022-09-18 10:44:18 +00:00
|
|
|
list(inspect.signature(hook.__init__, eval_str=True).parameters.values())[1:] for hook in hooks
|
2021-02-04 19:22:36 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
# slightly overengineered, but this was fun to write. ¯\_(ツ)_/¯
|
|
|
|
imports = set()
|
|
|
|
types = set()
|
|
|
|
for params in all_params:
|
|
|
|
for param in params:
|
|
|
|
try:
|
|
|
|
mod = inspect.getmodule(param.annotation).__name__
|
|
|
|
if mod == "typing":
|
|
|
|
# this is ugly, but can be removed once we are on Python 3.9+ only
|
2022-04-26 11:53:35 +00:00
|
|
|
imports.add(
|
|
|
|
inspect.getmodule(param.annotation.__args__[0]).__name__
|
|
|
|
)
|
2021-02-04 19:22:36 +00:00
|
|
|
types.add(param.annotation._name)
|
|
|
|
else:
|
|
|
|
imports.add(mod)
|
|
|
|
except AttributeError:
|
|
|
|
raise ValueError(f"Missing type annotation: {params}")
|
|
|
|
imports.discard("builtins")
|
|
|
|
if types:
|
|
|
|
print(f"from typing import {', '.join(sorted(types))}")
|
2022-09-17 13:41:54 +00:00
|
|
|
print("import logging")
|
2021-02-04 19:22:36 +00:00
|
|
|
for imp in sorted(imports):
|
|
|
|
print(f"import {imp}")
|
|
|
|
print()
|
|
|
|
|
2021-02-04 21:52:28 +00:00
|
|
|
print(f"class {name}Events:")
|
|
|
|
print(f' """{desc}"""')
|
2021-02-04 19:22:36 +00:00
|
|
|
|
|
|
|
first = True
|
|
|
|
for hook, params in zip(hooks, all_params):
|
|
|
|
if first:
|
|
|
|
first = False
|
|
|
|
else:
|
|
|
|
print()
|
|
|
|
if hook.name in known:
|
|
|
|
raise RuntimeError(f"Already documented: {hook}")
|
|
|
|
known.add(hook.name)
|
|
|
|
doc = inspect.getdoc(hook)
|
2021-02-04 21:52:28 +00:00
|
|
|
print(f" def {hook.name}({', '.join(str(p) for p in ['self'] + params)}):")
|
2021-02-04 19:22:36 +00:00
|
|
|
print(textwrap.indent(f'"""\n{doc}\n"""', " "))
|
|
|
|
if params:
|
2022-04-26 11:53:35 +00:00
|
|
|
print(
|
2022-09-17 13:41:54 +00:00
|
|
|
f' logging.info(f"{hook.name}: {" ".join("{" + p.name + "=}" for p in params)}")'
|
2022-04-26 11:53:35 +00:00
|
|
|
)
|
2021-02-04 19:22:36 +00:00
|
|
|
else:
|
2022-09-17 13:41:54 +00:00
|
|
|
print(f' logging.info("{hook.name}")')
|
2021-02-04 19:22:36 +00:00
|
|
|
print("")
|
|
|
|
|
|
|
|
|
|
|
|
outfile = Path(__file__).parent.parent / "src" / "generated" / "events.py"
|
|
|
|
|
|
|
|
with outfile.open("w") as f, contextlib.redirect_stdout(f):
|
2021-02-04 21:52:28 +00:00
|
|
|
print("# This file is autogenerated, do not edit manually.")
|
2021-02-04 19:22:36 +00:00
|
|
|
|
|
|
|
category(
|
|
|
|
"Lifecycle",
|
2021-02-04 21:52:28 +00:00
|
|
|
"",
|
2021-02-04 19:22:36 +00:00
|
|
|
[
|
|
|
|
addonmanager.LoadHook,
|
|
|
|
hooks.RunningHook,
|
|
|
|
hooks.ConfigureHook,
|
|
|
|
hooks.DoneHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2021-02-04 19:22:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
category(
|
|
|
|
"Connection",
|
2021-02-04 21:52:28 +00:00
|
|
|
"",
|
2021-02-04 19:22:36 +00:00
|
|
|
[
|
|
|
|
server_hooks.ClientConnectedHook,
|
|
|
|
server_hooks.ClientDisconnectedHook,
|
|
|
|
server_hooks.ServerConnectHook,
|
|
|
|
server_hooks.ServerConnectedHook,
|
|
|
|
server_hooks.ServerDisconnectedHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2021-02-04 19:22:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
category(
|
|
|
|
"HTTP",
|
2021-02-04 21:52:28 +00:00
|
|
|
"",
|
2021-02-04 19:22:36 +00:00
|
|
|
[
|
|
|
|
http.HttpRequestHeadersHook,
|
|
|
|
http.HttpRequestHook,
|
|
|
|
http.HttpResponseHeadersHook,
|
|
|
|
http.HttpResponseHook,
|
|
|
|
http.HttpErrorHook,
|
|
|
|
http.HttpConnectHook,
|
2021-06-14 10:11:57 +00:00
|
|
|
http.HttpConnectUpstreamHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2021-02-04 19:22:36 +00:00
|
|
|
)
|
|
|
|
|
2022-03-27 13:23:59 +00:00
|
|
|
category(
|
|
|
|
"DNS",
|
|
|
|
"",
|
|
|
|
[
|
|
|
|
dns.DnsRequestHook,
|
|
|
|
dns.DnsResponseHook,
|
|
|
|
dns.DnsErrorHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2022-03-27 13:23:59 +00:00
|
|
|
)
|
|
|
|
|
2021-02-04 19:22:36 +00:00
|
|
|
category(
|
|
|
|
"TCP",
|
2021-02-04 21:52:28 +00:00
|
|
|
"",
|
2021-02-04 19:22:36 +00:00
|
|
|
[
|
|
|
|
tcp.TcpStartHook,
|
|
|
|
tcp.TcpMessageHook,
|
|
|
|
tcp.TcpEndHook,
|
|
|
|
tcp.TcpErrorHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2021-02-04 19:22:36 +00:00
|
|
|
)
|
|
|
|
|
2022-07-27 00:20:30 +00:00
|
|
|
category(
|
|
|
|
"UDP",
|
|
|
|
"",
|
|
|
|
[
|
|
|
|
udp.UdpStartHook,
|
|
|
|
udp.UdpMessageHook,
|
|
|
|
udp.UdpEndHook,
|
|
|
|
udp.UdpErrorHook,
|
|
|
|
],
|
|
|
|
)
|
|
|
|
|
2021-02-04 19:22:36 +00:00
|
|
|
category(
|
|
|
|
"TLS",
|
2021-02-04 21:52:28 +00:00
|
|
|
"",
|
2021-02-04 19:22:36 +00:00
|
|
|
[
|
|
|
|
tls.TlsClienthelloHook,
|
2021-07-09 18:15:38 +00:00
|
|
|
tls.TlsStartClientHook,
|
|
|
|
tls.TlsStartServerHook,
|
2021-11-22 09:10:14 +00:00
|
|
|
tls.TlsEstablishedClientHook,
|
|
|
|
tls.TlsEstablishedServerHook,
|
|
|
|
tls.TlsFailedClientHook,
|
|
|
|
tls.TlsFailedServerHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2021-02-04 19:22:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
category(
|
|
|
|
"WebSocket",
|
2021-02-04 21:52:28 +00:00
|
|
|
"",
|
2021-02-04 19:22:36 +00:00
|
|
|
[
|
|
|
|
websocket.WebsocketStartHook,
|
|
|
|
websocket.WebsocketMessageHook,
|
|
|
|
websocket.WebsocketEndHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2021-02-04 19:22:36 +00:00
|
|
|
)
|
|
|
|
|
2021-08-25 13:46:22 +00:00
|
|
|
category(
|
|
|
|
"SOCKSv5",
|
|
|
|
"",
|
|
|
|
[
|
|
|
|
modes.Socks5AuthHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2021-08-25 13:46:22 +00:00
|
|
|
)
|
|
|
|
|
2021-02-04 19:22:36 +00:00
|
|
|
category(
|
2021-02-04 21:52:28 +00:00
|
|
|
"AdvancedLifecycle",
|
|
|
|
"",
|
2021-02-04 19:22:36 +00:00
|
|
|
[
|
|
|
|
layer.NextLayerHook,
|
|
|
|
hooks.UpdateHook,
|
|
|
|
log.AddLogHook,
|
2022-04-26 11:53:35 +00:00
|
|
|
],
|
2021-02-04 19:22:36 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
not_documented = set(hooks.all_hooks.keys()) - known
|
|
|
|
if not_documented:
|
|
|
|
raise RuntimeError(f"Not documented: {not_documented}")
|