Skip to content

Commit

Permalink
Automatically merged updates to draft EIP(s) 2333 (ethereum#2743)
Browse files Browse the repository at this point in the history
Hi, I'm a bot! This change was automatically merged because:

 - It only modifies existing Draft or Last Call EIP(s)
 - The PR was approved or written by at least one author of each modified EIP
 - The build is passing
  • Loading branch information
CarlBeek authored and tkstanczak committed Nov 7, 2020
1 parent ac1447e commit a5c87e6
Showing 1 changed file with 16 additions and 5 deletions.
21 changes: 16 additions & 5 deletions EIPS/eip-2333.md
Original file line number Diff line number Diff line change
Expand Up @@ -115,21 +115,23 @@ Every key generated via the key derivation process derives a child key via a set
3. not_IKM = flip_bits(IKM)
4. lamport_1 = IKM_to_lamport_SK(not_IKM, salt)
5. lamport_PK = ""
6. for i = 0 to 255
6. for i in 1, .., 255
lamport_PK = lamport_PK | SHA256(lamport_0[i])
7. for i = 0 to 255
7. for i in 1, .., 255
lamport_PK = lamport_PK | SHA256(lamport_1[i])
8. compressed_lamport_PK = SHA256(lamport_PK)
9. return compressed_lamport_PK
```

**Note:** The indexing, `i`, in the above procedure iterates from 1 to 255 (inclusive). This is due to the limit to which HKDF can stretch the input bytes (255 times the length of the input bytes). The result of this is that the security of the lamport-backup signature is \*only\* 127.5 bit.

#### `HKDF_mod_r`

`hkdf_mod_r()` is used to hash 32 random bytes into the subgroup of the BLS12-381 private keys.

##### Inputs

* `IKM`, a secret octet string.
* `IKM`, a secret octet string >= 256 bits in length

##### Outputs

Expand All @@ -139,7 +141,7 @@ Every key generated via the key derivation process derives a child key via a set

* `HKDF-Extract` is as defined in RFC5869, instantiated with hash H.
* `HKDF-Expand` is as defined in RFC5869, instantiated with hash H.
* `L` is the integer given by ceil((1.5 * ceil(log2(r))) / 8).
* `L` is the integer given by `ceil((3 * ceil(log2(r))) / 16)`.(`L=48`)
* `"BLS-SIG-KEYGEN-SALT-"` is an ASCII string comprising 20 octets.
* `""` is the empty string.
* `OS2IP` is as defined in [RFC3447](https://ietf.org/rfc/rfc3447.txt) (Big endian encoding)
Expand Down Expand Up @@ -177,9 +179,11 @@ The child key derivation function takes in the parent's private key and the inde

### `derive_master_SK`

The child key derivation function takes in the parent's private key and the index of the child and returns the child private key. The seed should ideally be derived from a mnemonic, with the intention being that [BIP39 mnemonics](https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki), with the associated [mnemonic_to_seed method](https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki#from-mnemonic-to-seed) be used.

##### Inputs

* `seed`, the source entropy for the entire tree, a octet string >= 128 bits
* `seed`, the source entropy for the entire tree, a octet string >= 256 bits in length

##### Outputs

Expand Down Expand Up @@ -231,6 +235,13 @@ child_index = 0
child_SK = 7419543105316279183937430842449358701327973165530407166294956473095303972104
```

This test case can be extended to test the entire mnemonic-to -child_SK` stack, assuming [BIP39](https://github.com/bitcoin/bips/blob/master/bip-0039.mediawiki) is used as the mnemonic generation mechanism. Using the following parameters, the above seed can be calculated:

```test
mnemonic = "abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon abandon about"
passphrase = "TREZOR"
```

### Test Case 1

```text
Expand Down

0 comments on commit a5c87e6

Please sign in to comment.