commit 6982edff1b24e5d185245216dae12e1acfec3143 Author: Roger Dingledine arma@torproject.org Date: Mon Apr 11 15:10:21 2011 -0400
interim commit while i clean up proposal 180 --- proposals/180-pluggable-transport.txt | 121 ++++++++++++++++----------------- 1 files changed, 58 insertions(+), 63 deletions(-)
diff --git a/proposals/180-pluggable-transport.txt b/proposals/180-pluggable-transport.txt index dc0564d..b1836e0 100644 --- a/proposals/180-pluggable-transport.txt +++ b/proposals/180-pluggable-transport.txt @@ -102,8 +102,8 @@ Non-Goals current proposal, though we are not currently sure whether it's a good idea to implement.
- We deliberately reject any design that would involve linking more code - into Tor's process space. + We deliberately reject any design that would involve linking the + transport plugins into Tor's process space.
Design overview
@@ -188,20 +188,19 @@ Specifications: Client behavior options, even if the same executable and options are listed for more than one method.
- If instead of a transport name, the torrc lists "*" for a managed proxy, - tor uses that proxy for all transports that it supports. So - "ClientTransportPlugin * exec /usr/libexec/tor/foobar" tells Tor - that it should use the foobar plugin for everything that it supports. + If instead of a transport method, the torrc lists "*" for a managed + proxy, Tor uses that proxy for all transport methods that the plugin + supports. So "ClientTransportPlugin * exec /usr/libexec/tor/foobar" + tells Tor that Tor should use the foobar plugin for every method that + the proxy supports. See the "Managed proxy interface" section below + for details on how Tor learns which methods a plugin supports.
- If two proxies support the same method, Tor should use whichever + If two plugins support the same method, Tor should use whichever one is listed first.
The same program can implement a managed or an external proxy: it just needs to take an argument saying which one to be.
- See "Managed proxy behavior" for more information on the managed - proxy interface. - Server behavior
Server proxies are configured similarly to client proxies. When @@ -216,7 +215,7 @@ Server behavior this in-band.
As before, the server lists proxies in its torrc. These can be - external proxies that run on their own, or managedproxies that Tor + external proxies that run on their own, or managed proxies that Tor launches.
An external server proxy is configured as @@ -227,9 +226,9 @@ Server behavior configuration information that we'll tell users.
A managed proxy is configured as - ServerTransportPlugin method exec /path/to/binary [options] + ServerTransportPlugin method exec /path/to/binary [options] or - ServerTransportPlugin * exec /path/to/binary [options] + ServerTransportPlugin * exec /path/to/binary [options]
When possible, Tor should launch only one binary of each binary/option pair configured. So if the torrc contains @@ -243,12 +242,12 @@ Server behavior
Managed proxy interface
- When the Tor client launches a client proxy from the command - line, it communicates via environment variables. At a minimum, - it sets: + When the Tor client or relay launches a managed proxy, it communicates + via environment variables. At a minimum, it sets:
{Client and server} - HOME, PATH -- as you'd expect. + + "HOME", "PATH" -- as you'd expect.
"STATE_LOCATION" -- a directory where the proxy should store state if it wants to. This directory is not required to @@ -272,19 +271,23 @@ Managed proxy interface
{Server only}
- "EXT_SERVER_PORT=addr:portnum" -- A port (probably on localhost) that - speaks the extended server protocol. + "EXTENDED_SERVER_PORT=addr:portnum" -- A port (probably on localhost) + that speaks the extended server protocol. (See the "The extended + ORPort protocol" section below.)
"ORPORT=addr:portnum" -- Our regular ORPort in a form suitable - for local connections. + for local connections, i.e. connections from the proxy to + the ORPort.
- "BINDADDR=addr" -- An address on which to listen for local + "BINDADDR=addr" -- An address on which to listen for client proxy connections. This might be the advertised address, or might be a local address that Tor will forward ports to. It MUST be an address that will work with bind().
"SERVER_TRANSPORTS=..." -- A comma-separated list of server - methods that the proxy should support, or * + methods that the proxy should support, or * if all methods + should be enabled. The proxy SHOULD ignore methods that it + doesn't recognize.
The transport proxy replies by writing NL-terminated lines to stdout. The metaformat is @@ -300,14 +303,14 @@ Managed proxy interface
First, the proxy writes "VERSION 1" to say that it supports this protocol. It must either pick a version that Tor told it about, or - pick no version at all, and say "ERROR no-version\n" and exit. + pick no version at all, say "ERROR no-version\n", and exit.
The proxy should then open its ports. If running as a client proxy, it should not use fixed ports; instead it should autoselect ports to avoid conflicts. A client proxy should by default only listen on localhost for connections.
- A server proxy SHOULD try listen at a consistent port, though it + A server proxy SHOULD try to listen at a consistent port, though it SHOULD pick a different one if the port it last used is now allocated.
A client or server proxy then should tell which methods it has @@ -334,20 +337,18 @@ Managed proxy interface should say: CMETHOD-ERROR methodname "Message"
- A proxy should tell Tor about the server methods it is providing + A proxy should also tell Tor about the server methods it is providing by printing zero or more SMETHOD lines. These lines look like:
- SMETHOD methodname address:port [Options] + SMETHOD methodname address:port [Options]
If there's an error setting up a configured server method, the proxy should say: SMETHOD-ERROR methodname "message"
The 'address:port' part of an SMETHOD line is the address to put - in the bridge line. The ARGS: part is a list of key-value pairs - that the client needs to know. The Options part is a list of - space-separated K:V flags that Tor should know about. Recognized - options are: + in the bridge line. The Options part is a list of space-separated + K:V flags that Tor should know about. Recognized options are:
- FORWARD:1
@@ -363,16 +364,18 @@ Managed proxy interface - DECLARE:K=V,...
If this option is set, all the K=V options should be - added as extension entries to the router descriptor. (See - below) + added as extension entries to the router descriptor, so other + relays can make use of it. (See below)
- - USE-EXTPORT:1 + - USE-EXTENDED-PORT:1
If this option is set, the server plugin is using the extended server port.
- SMETHOD and CMETHOD lines may be interspersed. After the list - SMETHOD line, the proxy says "SMETHODS DONE" + SMETHOD and CMETHOD lines may be interspersed, to allow the proxies to + report success even when some methods may require probing your network, + connecting to some kind of peers, etc. After the last SMETHOD line, + the proxy says "SMETHODS DONE".
The proxy SHOULD NOT tell Tor about a server or client method unless it is actually open and ready to use. @@ -388,7 +391,7 @@ Managed proxy interface closed. Proxies should respond to a second INT signal by shutting down cleanly.
-The extended ORPort protocol. +The extended ORPort protocol
Server transports may need to connect to the bridge and pass additional information about client connections that the bridge @@ -422,17 +425,17 @@ The extended ORPort protocol. about client addresses, but that's a historically error-prone way to go about annotating connections.]
-Advertising bridge methods: +Advertising bridge methods
Bridges put the 'method' lines in their extra-info documents.
method SP methodname SP address:port SP arglist NL
The address:port parse are as returned from an SMETHOD line. The - arglist is a K=V,... list as retuned in the ARGS part of the + arglist is a K=V,... list as returned in the ARGS part of the SMETHOD line.
- If the SMETHOD line includes a DECLARE: part, the routerinfo gets + If the SMETHOD line includes a DECLARE: part, the router descriptor gets a new line:
method-info SP methodname SP arglist NL @@ -445,7 +448,7 @@ Bridge authority behavior transport method before we allow its use: the point of this design is to remove bottlenecks in transport deployment.
-Bridgedb behavior: +Bridgedb behavior
Bridgedb can, given a set of router descriptors and their corresponding extrainfo documents, generate a set of bridge lines @@ -455,9 +458,10 @@ Bridgedb behavior: Implementation plan
First, we should implement per-bridge proxies via the "external - proxy" method described in "Specifications: Client behavior". the + proxy" method described in "Specifications: Client behavior". Also, + we'll want to build the extended-server-port mechanism. This will let bridges run - transport proxies such that they can give bridge lines to + transport proxies such that they can generate bridge lines to give to clients for testing, so long as the user configures and launches their proxies on their own.
@@ -465,15 +469,15 @@ Implementation plan the whole idea there is silly.
If we do, the next most important part seems to be getting - the client-side automatic part written. And once that's done, we + the client-side automation part written. And once that's done, we can evaluate how much of the server side is easy for people to do and how much is hard.
The "obfsproxy" obfuscating proxy is a likely candidate for an - initial transport, as is Steven Murdoch's http thing or something - similar. + initial transport (trac entry #2760), as is Steven Murdoch's http + thing (trac entry #2759) or something similar.
-Notes on plugins to write: +Notes on plugins to write
We should ship a couple of null plugin implementations in one or two popular, portable languages so that people get an idea of how to @@ -482,23 +486,15 @@ Notes on plugins to write: 1. We should have one that's just a proof of concept that does nothing but transfer bytes back and forth.
- 1. We should not do a rot13 one. - - 2. We should implement a basic proxy that does not transform the bytes at all - - 1. We should implement DNS or HTTP using other software (as goodesll + 2. We should implement DNS or HTTP using other software (as Geoff Goodell did years ago with DNS) as an example of wrapping existing code into our plugin model.
- 2. The obfuscated-ssh superencipherment is pretty trivial and pretty - useful. It makes the protocol stringwise unfingerprintable. + 3. The obfuscated-ssh superencipherment is pretty trivial and pretty + useful. It makes the protocol stringwise unfingerprintable.
- 1. Nick needs to be told firmly not to bikeshed the obfuscated-ssh - superencipherment too badly - - 1. Go ahead, bikeshed my day - - 1. If we do a raw-traffic proxy, openssh tunnels would be the logical choice. + 4. If we do a raw-traffic proxy, openssh tunnels would be the logical + choice.
Appendix: recommendations for transports
@@ -506,8 +502,9 @@ Appendix: recommendations for transports someday do so well at circumvention that it should be implemented inside Tor, it should use the same license as Tor.
- Use libraries that Tor already requires. (You can rely on openssl and - libevent being present if current Tor is present.) + Tor already uses OpenSSL, Libevent, and zlib. Before you go and decide + to use crypto++ in your transport plugin, ask yourself whether OpenSSL + wouldn't be a nicer choice.
Be portable: most Tor users are on Windows, and most Tor developers are not, so designing your code for just one of these platforms will @@ -529,5 +526,3 @@ Appendix: recommendations for transports protocols -- and in many cases, most possible variants of a given protocol won't actually exist in the wild.
- -