2016-10-19 20:20:44 +00:00
|
|
|
from mitmproxy import version
|
2016-10-19 22:27:05 +00:00
|
|
|
from mitmproxy import exceptions
|
2016-05-28 12:36:43 +00:00
|
|
|
from netlib.http import http1
|
2016-06-11 22:29:12 +00:00
|
|
|
from .. import language
|
2015-07-11 21:47:43 +00:00
|
|
|
|
|
|
|
|
2016-10-17 04:29:45 +00:00
|
|
|
class HTTPProtocol:
|
2015-07-11 21:47:43 +00:00
|
|
|
def __init__(self, pathod_handler):
|
|
|
|
self.pathod_handler = pathod_handler
|
|
|
|
|
|
|
|
def make_error_response(self, reason, body):
|
|
|
|
return language.http.make_error_response(reason, body)
|
|
|
|
|
|
|
|
def handle_http_connect(self, connect, lg):
|
|
|
|
"""
|
|
|
|
Handle a CONNECT request.
|
|
|
|
"""
|
2015-07-24 15:39:55 +00:00
|
|
|
|
2015-07-11 21:47:43 +00:00
|
|
|
self.pathod_handler.wfile.write(
|
2016-06-16 12:43:36 +00:00
|
|
|
b'HTTP/1.1 200 Connection established\r\n' +
|
|
|
|
(b'Proxy-agent: %s\r\n' % version.PATHOD.encode()) +
|
|
|
|
b'\r\n'
|
2015-07-11 21:47:43 +00:00
|
|
|
)
|
|
|
|
self.pathod_handler.wfile.flush()
|
|
|
|
if not self.pathod_handler.server.ssloptions.not_after_connect:
|
|
|
|
try:
|
|
|
|
cert, key, chain_file_ = self.pathod_handler.server.ssloptions.get_cert(
|
2016-06-16 12:46:51 +00:00
|
|
|
connect[0].encode()
|
2015-07-11 21:47:43 +00:00
|
|
|
)
|
|
|
|
self.pathod_handler.convert_to_ssl(
|
|
|
|
cert,
|
|
|
|
key,
|
2015-07-22 11:04:14 +00:00
|
|
|
handle_sni=self.pathod_handler.handle_sni,
|
2015-07-11 21:47:43 +00:00
|
|
|
request_client_cert=self.pathod_handler.server.ssloptions.request_client_cert,
|
|
|
|
cipher_list=self.pathod_handler.server.ssloptions.ciphers,
|
|
|
|
method=self.pathod_handler.server.ssloptions.ssl_version,
|
2015-08-29 10:30:54 +00:00
|
|
|
options=self.pathod_handler.server.ssloptions.ssl_options,
|
2015-07-11 21:47:43 +00:00
|
|
|
alpn_select=self.pathod_handler.server.ssloptions.alpn_select,
|
|
|
|
)
|
2016-10-19 22:27:05 +00:00
|
|
|
except exceptions.TlsException as v:
|
2015-07-11 21:47:43 +00:00
|
|
|
s = str(v)
|
|
|
|
lg(s)
|
|
|
|
return None, dict(type="error", msg=s)
|
|
|
|
return self.pathod_handler.handle_http_request, None
|
|
|
|
|
2015-07-19 18:10:07 +00:00
|
|
|
def read_request(self, lg=None):
|
2015-09-16 18:12:53 +00:00
|
|
|
return http1.read_request(self.pathod_handler.rfile)
|