diff options
author | Nick Mathewson <nickm@torproject.org> | 2005-03-02 20:22:10 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2005-03-02 20:22:10 +0000 |
commit | b494c2223df3a53e47045cf8044bbaeb2377ebf1 (patch) | |
tree | aad36c5019bc43d1e5639db095bd20bd7cc85e8d /doc | |
parent | 65230fd39f0c333ce8616f5a578f4941ea9f0b94 (diff) | |
download | tor-b494c2223df3a53e47045cf8044bbaeb2377ebf1.tar.gz tor-b494c2223df3a53e47045cf8044bbaeb2377ebf1.zip |
Specify and implement fragmented control messages to allow for (among other things) long GETINFO replies. Otherwise we could hit the 64K barrier on questions like "please dump your client-side DNS cache."
svn:r3726
Diffstat (limited to 'doc')
-rw-r--r-- | doc/TODO | 4 | ||||
-rw-r--r-- | doc/control-spec.txt | 37 |
2 files changed, 34 insertions, 7 deletions
@@ -62,7 +62,9 @@ N . Implement pending controller features. o MAPADDRESS o Map A->B. o Map DontCare->B. - - Way to handle overlong messages? + o Way to handle overlong messages + o Specify fragmented format + o Implement fragmented format - Event for "new descriptors" o Better stream IDs - EXTENDCIRCUIT <depends on revised circ selection stuff.> diff --git a/doc/control-spec.txt b/doc/control-spec.txt index bec7a5ea1a..e12998cd4d 100644 --- a/doc/control-spec.txt +++ b/doc/control-spec.txt @@ -51,6 +51,11 @@ the message. 3. Message types + Message types are drawn from the following ranges: + + 0x0000-0xEFFF : Reserved for use by official versions of this spec. + 0xF000-0xFFFF : Unallocated; usable by unofficial extensions. + 3.1. ERROR (Type 0x0000) Sent in response to a message that could not be processed as requested. @@ -232,8 +237,6 @@ the message. 3.11. MAPADDRESS (Type 0x000A) - [Proposal; not finalized] - Sent from the client to the server. The body contains a sequence of address mappings, each consisting of the address to be mapped, a single space, the replacement address, and a NL character. @@ -279,8 +282,6 @@ the message. 3.12 GETINFO (Type 0x000B) - [Proposal; not finalized] - Sent from the client to the server. The message body is as for GETCONF: one or more NL-terminated strings. The server replies with an INFOVALUE message. @@ -304,8 +305,6 @@ the message. 3.13 INFOVALUE (Type 0x000C) - [Proposal; not finalized] - Sent from the server to the client in response to a GETINFO message. Contains one or more items of the format: @@ -360,6 +359,32 @@ the message. the descriptor for any reason, the server must send an appropriate error message. +3.17 FRAGMENTHEADER (Type 0x0010) + + [Proposal; not finalized] + + Sent in either direction. Used to encapsulate messages longer than 65535 + bytes long. + + Underlying type [2 bytes] + Total Length [4 bytes] + Data [Rest of message] + + A FRAGMENTHEADER message MUST be followed immediately by a number of + FRAGMENT messages, such that lengths of the "Data" fields of the + FRAGMENTHEADER and FRAGMENT messages add to the "Total Length" field of the + FRAGMENTHEADER message. + + Implementations MUST NOT fragment messages of length less than 65536 bytes. + Implementations MUST be able to process fragmented messages that not + optimally packed. + +3.18 FRAGMENT (Type 0x0011) + + [Proposal; not finalized] + + Data [Entire message] + 4. Implementation notes 4.1. There are four ways we could authenticate, for now: |