diff options
author | Nick Mathewson <nickm@torproject.org> | 2003-08-25 18:50:29 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2003-08-25 18:50:29 +0000 |
commit | ee0440f908dcc06cbfe8279b89f4bd30071555b7 (patch) | |
tree | eedd772475a343c1d64dd5d0958149da7ba5e390 /doc | |
parent | 0878ceb77905df95ac2e37a456d1a575f43a7605 (diff) | |
download | tor-ee0440f908dcc06cbfe8279b89f4bd30071555b7.tar.gz tor-ee0440f908dcc06cbfe8279b89f4bd30071555b7.zip |
Correct description of extracting Kf and Kb from g^xy.
svn:r414
Diffstat (limited to 'doc')
-rw-r--r-- | doc/tor-spec.txt | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/doc/tor-spec.txt b/doc/tor-spec.txt index eeec99d8b6..0e6d3ec8d5 100644 --- a/doc/tor-spec.txt +++ b/doc/tor-spec.txt @@ -278,11 +278,18 @@ which reveals the downstream node. 4.2. Setting circuit keys Once the handshake between the OP and an OR is completed, both - servers can now calculate g^xy with ordinary DH. They divide the - last 32 bytes of this shared secret into two 16-byte keys, the - first of which (called Kf) is used to encrypt the stream of data - going from the OP to the OR, and second of which (called Kb) is - used to encrypt the stream of data going from the OR to the OP. + servers can now calculate g^xy with ordinary DH. From the base key + material g^xy, they compute two 16 byte keys, called Kf and Kb as + follows. First, the server represents g^xy as a big-endian + unsigned integer. Next, the server computes 40 bytes of key data + as K = SHA1(g^xy | [00]) | SHA1(g^xy | [01]) where "00" is a single + octet whose value is zero, and "01" is a single octet whose value + is one. The first 16 bytes of K form Kf, and the next 16 bytes of + K form Kb. + + Kf is used to encrypt the stream of data going from the OP to the + OR, whereas Kb is used to encrypt the stream of data going from the + OR to the OP. 4.3. Creating circuits |