wormhole/node/pkg/devnet/deterministic_bridge_key.go

21 lines
588 B
Go
Raw Normal View History

package devnet
import (
"crypto/ecdsa"
"crypto/elliptic"
mathrand "math/rand"
)
// InsecureDeterministicEcdsaKeyByIndex generates a deterministic ecdsa.PrivateKey from a given index.
func InsecureDeterministicEcdsaKeyByIndex(c elliptic.Curve, idx uint64) *ecdsa.PrivateKey {
// use 555 as offset to deterministically generate key 0 to match vaa-test such that
// we generate the same key.
r := mathrand.New(mathrand.NewSource(int64(555 + idx))) //#nosec G404 Testnet/devnet keys are not secret.
key, err := ecdsa.GenerateKey(c, r)
if err != nil {
panic(err)
}
return key
}