From aba56f54ad743a6caa62e161c4b6c48bd8be0681 Mon Sep 17 00:00:00 2001 From: Louis Singer <41042567+louisinger@users.noreply.github.com> Date: Wed, 31 Jan 2024 16:29:51 +0100 Subject: [PATCH] Hotfix SignSchnorr api (#78) * fix signTaproot * revert MakeFile * fix validate * Fixes after review --------- Co-authored-by: Pietralberto Mazza <18440657+altafan@users.noreply.github.com> --- pkg/wallet/single-sig/sign.go | 23 ++++++++++++++++++----- 1 file changed, 18 insertions(+), 5 deletions(-) diff --git a/pkg/wallet/single-sig/sign.go b/pkg/wallet/single-sig/sign.go index 5f69d79..5a9c9d8 100644 --- a/pkg/wallet/single-sig/sign.go +++ b/pkg/wallet/single-sig/sign.go @@ -163,9 +163,17 @@ type SignTaprootArgs struct { } func (a SignTaprootArgs) validate() error { - if _, err := psetv2.NewPsetFromBase64(a.PsetBase64); err != nil { + ptx, err := psetv2.NewPsetFromBase64(a.PsetBase64) + if err != nil { return err } + + for i, in := range ptx.Inputs { + if in.GetUtxo() == nil { + return fmt.Errorf("missing prevout of input %d", i) + } + } + if len(a.DerivationPathMap) <= 0 { return ErrMissingDerivationPaths } @@ -397,10 +405,15 @@ func signTaproot( return nil, err } - prevout := ptx.Inputs[inIndex].GetUtxo() - prevoutScripts := [][]byte{prevout.Script} - prevoutAssets := [][]byte{prevout.Asset} - prevoutValues := [][]byte{prevout.Value} + prevoutScripts := make([][]byte, 0, len(unsignedTx.Inputs)) + prevoutAssets := make([][]byte, 0, len(unsignedTx.Inputs)) + prevoutValues := make([][]byte, 0, len(unsignedTx.Inputs)) + + for _, in := range ptx.Inputs { + prevoutScripts = append(prevoutScripts, in.GetUtxo().Script) + prevoutAssets = append(prevoutAssets, in.GetUtxo().Asset) + prevoutValues = append(prevoutValues, in.GetUtxo().Value) + } hashForSignature := unsignedTx.HashForWitnessV1( inIndex, prevoutScripts, prevoutAssets, prevoutValues, sighashType, genesisBlockHash, leafHash, nil,