aboutsummaryrefslogtreecommitdiffstats
path: root/docs
diff options
context:
space:
mode:
authorThomas Kriechbaumer <thomas@kriechbaumer.name>2017-08-17 10:18:05 +0200
committerThomas Kriechbaumer <thomas@kriechbaumer.name>2017-12-12 22:09:46 +0100
commit3cb459d56daeae8fd2b923c27f39ca5595a50e7b (patch)
tree9b48be479690bf52b35b5283462b4f025b60f5ad /docs
parent5214f544e7b690dea2a45cb4cda44bbffec9a77e (diff)
downloadmitmproxy-3cb459d56daeae8fd2b923c27f39ca5595a50e7b.tar.gz
mitmproxy-3cb459d56daeae8fd2b923c27f39ca5595a50e7b.tar.bz2
mitmproxy-3cb459d56daeae8fd2b923c27f39ca5595a50e7b.zip
docs++: add individual protocol pages
Diffstat (limited to 'docs')
-rw-r--r--docs/features/passthrough.rst4
-rw-r--r--docs/index.rst10
-rw-r--r--docs/protocols/http1.rst15
-rw-r--r--docs/protocols/http2.rst16
-rw-r--r--docs/protocols/tcpproxy.rst (renamed from docs/features/tcpproxy.rst)6
-rw-r--r--docs/protocols/websocket.rst17
-rw-r--r--docs/scripting/events.rst2
7 files changed, 63 insertions, 7 deletions
diff --git a/docs/features/passthrough.rst b/docs/features/passthrough.rst
index 00462e9d..dbaf3506 100644
--- a/docs/features/passthrough.rst
+++ b/docs/features/passthrough.rst
@@ -13,7 +13,7 @@ mechanism:
away. Note that mitmproxy's "Limit" option is often the better alternative here, as it is
not affected by the limitations listed below.
-If you want to peek into (SSL-protected) non-HTTP connections, check out the :ref:`tcpproxy`
+If you want to peek into (SSL-protected) non-HTTP connections, check out the :ref:`tcp_proxy`
feature.
If you want to ignore traffic from mitmproxy's processing because of large response bodies,
take a look at the :ref:`streaming` feature.
@@ -88,7 +88,7 @@ Here are some other examples for ignore patterns:
.. seealso::
- - :ref:`tcpproxy`
+ - :ref:`tcp_proxy`
- :ref:`streaming`
- mitmproxy's "Limit" feature
diff --git a/docs/index.rst b/docs/index.rst
index 7cf593ff..8dba4d04 100644
--- a/docs/index.rst
+++ b/docs/index.rst
@@ -22,6 +22,15 @@
.. toctree::
:hidden:
+ :caption: Protocols
+
+ protocols/http1
+ protocols/http2
+ protocols/websocket
+ protocols/tcpproxy
+
+.. toctree::
+ :hidden:
:caption: Features
features/anticache
@@ -36,7 +45,6 @@
features/streaming
features/socksproxy
features/sticky
- features/tcpproxy
features/upstreamproxy
features/upstreamcerts
diff --git a/docs/protocols/http1.rst b/docs/protocols/http1.rst
new file mode 100644
index 00000000..21e68785
--- /dev/null
+++ b/docs/protocols/http1.rst
@@ -0,0 +1,15 @@
+.. _http1_protocol:
+
+HTTP/1.0 and HTTP/1.1
+===========================
+
+.. seealso::
+
+ - `RFC7230: HTTP/1.1: Message Syntax and Routing <http://tools.ietf.org/html/rfc7230>`_
+ - `RFC7231: HTTP/1.1: Semantics and Content <http://tools.ietf.org/html/rfc7231>`_
+
+HTTP/1.0 and HTTP/1.1 support in mitmproxy is based on our custom HTTP stack,
+which takes care of all semantics and on-the-wire parsing/serialization tasks.
+
+mitmproxy currently does not support HTTP trailers - but if you want to send
+us a PR, we promise to take look!
diff --git a/docs/protocols/http2.rst b/docs/protocols/http2.rst
new file mode 100644
index 00000000..b3268ae5
--- /dev/null
+++ b/docs/protocols/http2.rst
@@ -0,0 +1,16 @@
+.. _http2_protocol:
+
+HTTP/2
+======
+
+.. seealso::
+
+ - `RFC7540: Hypertext Transfer Protocol Version 2 (HTTP/2) <http://tools.ietf.org/html/rfc7540>`_
+
+HTTP/2 support in mitmproxy is based on the amazing work by the python-hyper
+community with the `hyper-h2 <https://github.com/python-hyper/hyper-h2>`_
+project. It fully encapsulates the internal state of HTTP/2 connections and
+provides an easy-to-use event-based API.
+
+mitmproxy currently does not support HTTP/2 trailers - but if you want to send
+us a PR, we promise to take look!
diff --git a/docs/features/tcpproxy.rst b/docs/protocols/tcpproxy.rst
index cba374e3..77248573 100644
--- a/docs/features/tcpproxy.rst
+++ b/docs/protocols/tcpproxy.rst
@@ -1,7 +1,7 @@
-.. _tcpproxy:
+.. _tcp_proxy:
-TCP Proxy
-=========
+TCP Proxy / Fallback
+====================
In case mitmproxy does not handle a specific protocol, you can exempt
hostnames from processing, so that mitmproxy acts as a generic TCP forwarder.
diff --git a/docs/protocols/websocket.rst b/docs/protocols/websocket.rst
new file mode 100644
index 00000000..85cff3ac
--- /dev/null
+++ b/docs/protocols/websocket.rst
@@ -0,0 +1,17 @@
+.. _websocket_protocol:
+
+WebSocket
+=========
+
+.. seealso::
+
+ - `RFC6455: The WebSocket Protocol <http://tools.ietf.org/html/rfc6455>`_
+ - `RFC7692: Compression Extensions for WebSocket <http://tools.ietf.org/html/rfc7692>`_
+
+WebSocket support in mitmproxy is based on the amazing work by the python-hyper
+community with the `wsproto <https://github.com/python-hyper/wsproto>`_
+project. It fully encapsulates WebSocket frames/messages/connections and
+provides an easy-to-use event-based API.
+
+mitmproxy fully supports the compression extension for WebSocket messages,
+provided by wsproto.
diff --git a/docs/scripting/events.rst b/docs/scripting/events.rst
index 8f9463ff..9e84dacf 100644
--- a/docs/scripting/events.rst
+++ b/docs/scripting/events.rst
@@ -211,7 +211,7 @@ TCP Events
----------
These events are called only if the connection is in :ref:`TCP mode
-<tcpproxy>`. So, for instance, TCP events are not called for ordinary HTTP/S
+<tcp_proxy>`. So, for instance, TCP events are not called for ordinary HTTP/S
connections.
.. list-table::