[tor-commits] [torspec] 01/03: prop340: Move stream_id to body becoming a per command value
gitolite role
git at cupani.torproject.org
Mon Feb 6 14:04:02 UTC 2023
This is an automated email from the git hooks/post-receive script.
dgoulet pushed a commit to branch main
in repository torspec.
commit c6d10a93489e817efd48498dc9cb2f03480d052b
Author: David Goulet <dgoulet at torproject.org>
AuthorDate: Wed Jan 11 10:14:19 2023 -0500
prop340: Move stream_id to body becoming a per command value
Signed-off-by: David Goulet <dgoulet at torproject.org>
---
proposals/340-packed-and-fragmented.md | 21 ++++++++++++---------
1 file changed, 12 insertions(+), 9 deletions(-)
diff --git a/proposals/340-packed-and-fragmented.md b/proposals/340-packed-and-fragmented.md
index e7f08f4..0d83f67 100644
--- a/proposals/340-packed-and-fragmented.md
+++ b/proposals/340-packed-and-fragmented.md
@@ -66,12 +66,16 @@ Relay _messages_ now follow the following format:
Header
command u8
length u16
- stream_id u16
Body
data u8[length]
We require that "command" is never 0.
+One big change from the current tor protocol is the missing `stream_id` which
+we propose to move into the body because most commands set it to 0 because
+they don't need it. Meaning that the `stream_id` becomes a value specified
+per-command.
+
Messages can be split across relay cells; multiple messages can occur in
a single relay cell. We enforce the following rules:
@@ -191,8 +195,8 @@ cell. Here it is a BEGIN message.
message header:
command BEGIN [1 byte]
length 23 [2 bytes]
- stream_id (...) [2 bytes]
message body
+ stream_id (...) [2 bytes]
"www.torproject.org:443\0" [23 bytes]
end-of-messages marker
0 [1 byte]
@@ -215,8 +219,8 @@ across two relay cells.
message header:
command EXTEND [1 byte]
length 800 [2 bytes]
- stream_id 0 [2 bytes]
message body
+ stream_id 0 [2 bytes]
(extend body, part 1) [488 bytes]
Cell 2:
@@ -249,14 +253,13 @@ message in the same cell.
message header:
command BEGIN_DIR [1 byte]
length 0 [2 bytes]
- stream_id 32 [2 bytes]
message body:
- (empty) --- [0 bytes]
+ stream_id 32 [2 bytes]
message header:
command DATA [1 byte]
length 25 [2 bytes]
- stream_id 32 [2 bytes]
message body:
+ stream_id 32 [2 bytes]
"HTTP/1.0 GET /tor/foo\r\n\r\n" [25 bytes]
end-of-messages marker
0 [1 byte]
@@ -281,8 +284,8 @@ above; this is only an example of what parties need to accept.)
message header:
command DATAGRAM [1 byte]
length 1200 [2 bytes]
- stream_id 99 [2 bytes]
message body
+ stream_id 99 [2 bytes]
(datagram body, part 1) [488 bytes]
Cell 2:
@@ -307,16 +310,16 @@ above; this is only an example of what parties need to accept.)
message header:
command SENDME [1 byte]
length 23 [2 bytes]
- stream_id 0 [2 bytes]
message body:
+ stream_id 0 [2 bytes]
version 1 [1 byte]
datalen 20 [2 bytes]
data (digest to ack) [20 bytes]
message header:
command XON [1 byte]
length 1 [2 bytes]
- stream_id 50 [2 bytes]
message body:
+ stream_id 50 [2 bytes]
version 1 [1 byte]
end-of-messages marker
0 [1 byte]
--
To stop receiving notification emails like this one, please contact
the administrator of this repository.
More information about the tor-commits
mailing list