From 5af2ebf9ad960c68e948139c433f1b76df2c28df Mon Sep 17 00:00:00 2001 From: Boris Nagaev Date: Sun, 7 Jul 2024 01:03:15 -0300 Subject: [PATCH] lnd/signer: add ECDH method It can now be used as keychain.ECDHRing. --- lnd/signer.go | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/lnd/signer.go b/lnd/signer.go index 84b32cd..d16b5b3 100644 --- a/lnd/signer.go +++ b/lnd/signer.go @@ -265,3 +265,26 @@ func ECDH(privKey *btcec.PrivateKey, pub *btcec.PublicKey) ([32]byte, error) { sPubKey := btcec.NewPublicKey(&s.X, &s.Y) return sha256.Sum256(sPubKey.SerializeCompressed()), nil } + +// ECDH performs a scalar multiplication (ECDH-like operation) between +// the target key descriptor and remote public key. The output +// returned will be the sha256 of the resulting shared point serialized +// in compressed format. If k is our private key, and P is the public +// key, we perform the following operation: +// +// sx := k*P +// s := sha256(sx.SerializeCompressed()) +// +// NOTE: This is part of the keychain.ECDHRing interface. +func (s *Signer) ECDH(keyDesc keychain.KeyDescriptor, pubKey *btcec.PublicKey) ( + [32]byte, error) { + + // First, derive the private key. + privKey, err := s.FetchPrivateKey(&keyDesc) + if err != nil { + return [32]byte{}, fmt.Errorf("failed to derive the private "+ + "key: %w", err) + } + + return ECDH(privKey, pubKey) +}