From: Brian Warner <warner@allmydata.com>
Date: Tue, 30 Oct 2007 02:51:12 +0000 (-0700)
Subject: docs/mutable.txt: add IV, define a place for it in the data structure
X-Git-Tag: allmydata-tahoe-0.7.0~347
X-Git-Url: https://git.rkrishnan.org/pf/content/en/service/FOOURL?a=commitdiff_plain;h=9b92bff51ced467d5bae925b64a4ca14aa3b6e2d;p=tahoe-lafs%2Ftahoe-lafs.git

docs/mutable.txt: add IV, define a place for it in the data structure
---

diff --git a/docs/mutable.txt b/docs/mutable.txt
index 845f88b9..a2ded975 100644
--- a/docs/mutable.txt
+++ b/docs/mutable.txt
@@ -114,7 +114,14 @@ the "write enabler" for that particular server.
 
 The private key is encrypted (using AES in counter mode) by the write key,
 and the resulting crypttext is stored on the servers. so it will be
-retrievable by anyone who knows the write key.
+retrievable by anyone who knows the write key. The write key is not used to
+encrypt anything else, and the private key never changes, so we do not need
+an IV for this purpose.
+
+The actual data is encrypted (using AES in counter mode) with a key derived
+by concatenating the readkey with the IV, the hashing the results and
+truncating to 16 bytes. The IV is randomly generated each time the slot is
+updated, and stored next to the encrypted data.
 
 The read-write URI consists of just the write key. The read-only URI contains
 the read key and the verification key hash.
@@ -344,17 +351,19 @@ is oblivious to this format.
        43       8        segment size
        51       8        data length
  5    59       32      offset table:
-       91       4        (6) signature
-       95       4        (7) share hash chain
-       99       4        (8) block hash tree
-       103      4        (9) share data
-       107      8        (10) encrypted private key
- 6    115      256     verification key (2048 RSA key 'n' value, e=3)
- 7    371      256     signature= RSAenc(sig-key, H(version+seqnum+r+encparm))
- 8    627      (a)     share hash chain
+       91       4        (7) signature
+       95       4        (8) share hash chain
+       99       4        (9) block hash tree
+       103      4        (10) IV
+       107      4        (11) share data
+       111      8        (12) encrypted private key
+ 6    119      256     verification key (2048 RSA key 'n' value, e=3)
+ 7    375      256     signature= RSAenc(sig-key, H(version+seqnum+r+encparm))
+ 8    631      (a)     share hash chain
  9    ??       (b)     block hash tree
-10    ??       LEN     share data
-11    ??       256     encrypted private key= AESenc(write-key, RSA 'd' value)
+10    ??       16      IV (share data is AES(H(readkey+IV)) )
+11    ??       LEN     share data
+12    ??       256     encrypted private key= AESenc(write-key, RSA 'd' value)
 
 (a) The share hash chain contains ceil(log(N)) hashes, each 32 bytes long.
     This is the set of hashes necessary to validate this share's leaf in the
@@ -484,9 +493,6 @@ provides explicit support for revision identifiers and branching.
 
 == TODO ==
 
-add IV, use it by hashing the long-term readkey with the IV to generate the
-per-version readkey.
-
 improve allocate-and-write or get-writer-buckets API to allow one-call (or
 maybe two-call) updates. The challenge is in figuring out which shares are on
 which machines. First cut will have lots of round trips.