mirror of
https://github.com/status-im/status-go.git
synced 2025-01-17 02:02:36 +00:00
40359f9c1b
* Adding wakunode module * Adding wakuv2 fleet files * Add waku fleets to update-fleet-config script * Adding config items for waku v2 * Conditionally start waku v2 node depending on config * Adapting common code to use go-waku * Setting log level to info * update dependencies * update fleet config to use WakuNodes instead of BootNodes * send and receive messages * use hash returned when publishing a message * add waku store protocol * trigger signal after receiving store messages * exclude linting rule SA1019 to check deprecated packages
50 lines
897 B
Go
50 lines
897 B
Go
package noise
|
|
|
|
import (
|
|
"crypto/hmac"
|
|
"hash"
|
|
)
|
|
|
|
func hkdf(h func() hash.Hash, outputs int, out1, out2, out3, chainingKey, inputKeyMaterial []byte) ([]byte, []byte, []byte) {
|
|
if len(out1) > 0 {
|
|
panic("len(out1) > 0")
|
|
}
|
|
if len(out2) > 0 {
|
|
panic("len(out2) > 0")
|
|
}
|
|
if len(out3) > 0 {
|
|
panic("len(out3) > 0")
|
|
}
|
|
if outputs > 3 {
|
|
panic("outputs > 3")
|
|
}
|
|
|
|
tempMAC := hmac.New(h, chainingKey)
|
|
tempMAC.Write(inputKeyMaterial)
|
|
tempKey := tempMAC.Sum(out2)
|
|
|
|
out1MAC := hmac.New(h, tempKey)
|
|
out1MAC.Write([]byte{0x01})
|
|
out1 = out1MAC.Sum(out1)
|
|
|
|
if outputs == 1 {
|
|
return out1, nil, nil
|
|
}
|
|
|
|
out2MAC := hmac.New(h, tempKey)
|
|
out2MAC.Write(out1)
|
|
out2MAC.Write([]byte{0x02})
|
|
out2 = out2MAC.Sum(out2)
|
|
|
|
if outputs == 2 {
|
|
return out1, out2, nil
|
|
}
|
|
|
|
out3MAC := hmac.New(h, tempKey)
|
|
out3MAC.Write(out2)
|
|
out3MAC.Write([]byte{0x03})
|
|
out3 = out3MAC.Sum(out3)
|
|
|
|
return out1, out2, out3
|
|
}
|