Merge pull request #398 from halseth/sighash-signdesc-hashtype
Use dynamic SigHash type when signing transactions.
This commit is contained in:
commit
e7e426a1cc
@ -467,7 +467,7 @@ func (m *mockSigner) SignOutputRaw(tx *wire.MsgTx, signDesc *lnwallet.SignDescri
|
|||||||
}
|
}
|
||||||
|
|
||||||
sig, err := txscript.RawTxInWitnessSignature(tx, signDesc.SigHashes,
|
sig, err := txscript.RawTxInWitnessSignature(tx, signDesc.SigHashes,
|
||||||
signDesc.InputIndex, amt, witnessScript, txscript.SigHashAll,
|
signDesc.InputIndex, amt, witnessScript, signDesc.HashType,
|
||||||
privKey)
|
privKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -493,7 +493,7 @@ func (m *mockSigner) ComputeInputScript(tx *wire.MsgTx, signDesc *lnwallet.SignD
|
|||||||
|
|
||||||
witnessScript, err := txscript.WitnessSignature(tx, signDesc.SigHashes,
|
witnessScript, err := txscript.WitnessSignature(tx, signDesc.SigHashes,
|
||||||
signDesc.InputIndex, signDesc.Output.Value, signDesc.Output.PkScript,
|
signDesc.InputIndex, signDesc.Output.Value, signDesc.Output.PkScript,
|
||||||
txscript.SigHashAll, privKey, true)
|
signDesc.HashType, privKey, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -141,7 +141,7 @@ func (b *BtcWallet) SignOutputRaw(tx *wire.MsgTx,
|
|||||||
|
|
||||||
amt := signDesc.Output.Value
|
amt := signDesc.Output.Value
|
||||||
sig, err := txscript.RawTxInWitnessSignature(tx, signDesc.SigHashes,
|
sig, err := txscript.RawTxInWitnessSignature(tx, signDesc.SigHashes,
|
||||||
signDesc.InputIndex, amt, witnessScript, txscript.SigHashAll,
|
signDesc.InputIndex, amt, witnessScript, signDesc.HashType,
|
||||||
privKey)
|
privKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -227,7 +227,7 @@ func (b *BtcWallet) ComputeInputScript(tx *wire.MsgTx,
|
|||||||
// TODO(roasbeef): adhere to passed HashType
|
// TODO(roasbeef): adhere to passed HashType
|
||||||
witnessScript, err := txscript.WitnessSignature(tx, signDesc.SigHashes,
|
witnessScript, err := txscript.WitnessSignature(tx, signDesc.SigHashes,
|
||||||
signDesc.InputIndex, signDesc.Output.Value, witnessProgram,
|
signDesc.InputIndex, signDesc.Output.Value, witnessProgram,
|
||||||
txscript.SigHashAll, privKey, true)
|
signDesc.HashType, privKey, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
@ -295,7 +295,7 @@ func senderHtlcSpendRevoke(signer Signer, signDesc *SignDescriptor,
|
|||||||
// manner in order to encode the revocation contract into a sig+key
|
// manner in order to encode the revocation contract into a sig+key
|
||||||
// pair.
|
// pair.
|
||||||
witnessStack := wire.TxWitness(make([][]byte, 3))
|
witnessStack := wire.TxWitness(make([][]byte, 3))
|
||||||
witnessStack[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[1] = revokeKey.SerializeCompressed()
|
witnessStack[1] = revokeKey.SerializeCompressed()
|
||||||
witnessStack[2] = signDesc.WitnessScript
|
witnessStack[2] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -337,7 +337,7 @@ func senderHtlcSpendRedeem(signer Signer, signDesc *SignDescriptor,
|
|||||||
// generated above under the receiver's public key, and the payment
|
// generated above under the receiver's public key, and the payment
|
||||||
// pre-image.
|
// pre-image.
|
||||||
witnessStack := wire.TxWitness(make([][]byte, 3))
|
witnessStack := wire.TxWitness(make([][]byte, 3))
|
||||||
witnessStack[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[1] = paymentPreimage
|
witnessStack[1] = paymentPreimage
|
||||||
witnessStack[2] = signDesc.WitnessScript
|
witnessStack[2] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -363,7 +363,7 @@ func senderHtlcSpendTimeout(receiverSig []byte, signer Signer,
|
|||||||
witnessStack := wire.TxWitness(make([][]byte, 5))
|
witnessStack := wire.TxWitness(make([][]byte, 5))
|
||||||
witnessStack[0] = nil
|
witnessStack[0] = nil
|
||||||
witnessStack[1] = append(receiverSig, byte(txscript.SigHashAll))
|
witnessStack[1] = append(receiverSig, byte(txscript.SigHashAll))
|
||||||
witnessStack[2] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[2] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[3] = nil
|
witnessStack[3] = nil
|
||||||
witnessStack[4] = signDesc.WitnessScript
|
witnessStack[4] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -517,7 +517,7 @@ func receiverHtlcSpendRedeem(senderSig, paymentPreimage []byte,
|
|||||||
witnessStack := wire.TxWitness(make([][]byte, 5))
|
witnessStack := wire.TxWitness(make([][]byte, 5))
|
||||||
witnessStack[0] = nil
|
witnessStack[0] = nil
|
||||||
witnessStack[1] = append(senderSig, byte(txscript.SigHashAll))
|
witnessStack[1] = append(senderSig, byte(txscript.SigHashAll))
|
||||||
witnessStack[2] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[2] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[3] = paymentPreimage
|
witnessStack[3] = paymentPreimage
|
||||||
witnessStack[4] = signDesc.WitnessScript
|
witnessStack[4] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -544,7 +544,7 @@ func receiverHtlcSpendRevoke(signer Signer, signDesc *SignDescriptor,
|
|||||||
// witness stack in order to force script execution to the HTLC
|
// witness stack in order to force script execution to the HTLC
|
||||||
// revocation clause.
|
// revocation clause.
|
||||||
witnessStack := wire.TxWitness(make([][]byte, 3))
|
witnessStack := wire.TxWitness(make([][]byte, 3))
|
||||||
witnessStack[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[1] = revokeKey.SerializeCompressed()
|
witnessStack[1] = revokeKey.SerializeCompressed()
|
||||||
witnessStack[2] = signDesc.WitnessScript
|
witnessStack[2] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -595,7 +595,7 @@ func receiverHtlcSpendTimeout(signer Signer, signDesc *SignDescriptor,
|
|||||||
}
|
}
|
||||||
|
|
||||||
witnessStack := wire.TxWitness(make([][]byte, 3))
|
witnessStack := wire.TxWitness(make([][]byte, 3))
|
||||||
witnessStack[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[1] = nil
|
witnessStack[1] = nil
|
||||||
witnessStack[2] = signDesc.WitnessScript
|
witnessStack[2] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -802,7 +802,7 @@ func htlcSpendSuccess(signer Signer, signDesc *SignDescriptor,
|
|||||||
// witness script), in order to force execution to the second portion
|
// witness script), in order to force execution to the second portion
|
||||||
// of the if clause.
|
// of the if clause.
|
||||||
witnessStack := wire.TxWitness(make([][]byte, 3))
|
witnessStack := wire.TxWitness(make([][]byte, 3))
|
||||||
witnessStack[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[1] = nil
|
witnessStack[1] = nil
|
||||||
witnessStack[2] = signDesc.WitnessScript
|
witnessStack[2] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -827,7 +827,7 @@ func htlcSpendRevoke(signer Signer, signDesc *SignDescriptor,
|
|||||||
// witness script), in order to force execution to the revocation
|
// witness script), in order to force execution to the revocation
|
||||||
// clause in the second level HTLC script.
|
// clause in the second level HTLC script.
|
||||||
witnessStack := wire.TxWitness(make([][]byte, 3))
|
witnessStack := wire.TxWitness(make([][]byte, 3))
|
||||||
witnessStack[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[1] = []byte{1}
|
witnessStack[1] = []byte{1}
|
||||||
witnessStack[2] = signDesc.WitnessScript
|
witnessStack[2] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -943,7 +943,7 @@ func CommitSpendTimeout(signer Signer, signDesc *SignDescriptor,
|
|||||||
// place an empty byte in order to ensure our script is still valid
|
// place an empty byte in order to ensure our script is still valid
|
||||||
// from the PoV of nodes that are enforcing minimal OP_IF/OP_NOTIF.
|
// from the PoV of nodes that are enforcing minimal OP_IF/OP_NOTIF.
|
||||||
witnessStack := wire.TxWitness(make([][]byte, 3))
|
witnessStack := wire.TxWitness(make([][]byte, 3))
|
||||||
witnessStack[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[1] = nil
|
witnessStack[1] = nil
|
||||||
witnessStack[2] = signDesc.WitnessScript
|
witnessStack[2] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -968,7 +968,7 @@ func CommitSpendRevoke(signer Signer, signDesc *SignDescriptor,
|
|||||||
// Place a 1 as the first item in the evaluated witness stack to
|
// Place a 1 as the first item in the evaluated witness stack to
|
||||||
// force script execution to the revocation clause.
|
// force script execution to the revocation clause.
|
||||||
witnessStack := wire.TxWitness(make([][]byte, 3))
|
witnessStack := wire.TxWitness(make([][]byte, 3))
|
||||||
witnessStack[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witnessStack[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witnessStack[1] = []byte{1}
|
witnessStack[1] = []byte{1}
|
||||||
witnessStack[2] = signDesc.WitnessScript
|
witnessStack[2] = signDesc.WitnessScript
|
||||||
|
|
||||||
@ -996,7 +996,7 @@ func CommitSpendNoDelay(signer Signer, signDesc *SignDescriptor,
|
|||||||
// we use the tweaked public key as the last item in the witness stack
|
// we use the tweaked public key as the last item in the witness stack
|
||||||
// which was originally used to created the pkScript we're spending.
|
// which was originally used to created the pkScript we're spending.
|
||||||
witness := make([][]byte, 2)
|
witness := make([][]byte, 2)
|
||||||
witness[0] = append(sweepSig, byte(txscript.SigHashAll))
|
witness[0] = append(sweepSig, byte(signDesc.HashType))
|
||||||
witness[1] = TweakPubKeyWithTweak(
|
witness[1] = TweakPubKeyWithTweak(
|
||||||
signDesc.PubKey, signDesc.SingleTweak,
|
signDesc.PubKey, signDesc.SingleTweak,
|
||||||
).SerializeCompressed()
|
).SerializeCompressed()
|
||||||
|
4
mock.go
4
mock.go
@ -25,7 +25,7 @@ func (m *mockSigner) SignOutputRaw(tx *wire.MsgTx,
|
|||||||
privKey := m.key
|
privKey := m.key
|
||||||
|
|
||||||
sig, err := txscript.RawTxInWitnessSignature(tx, signDesc.SigHashes,
|
sig, err := txscript.RawTxInWitnessSignature(tx, signDesc.SigHashes,
|
||||||
signDesc.InputIndex, amt, witnessScript, txscript.SigHashAll,
|
signDesc.InputIndex, amt, witnessScript, signDesc.HashType,
|
||||||
privKey)
|
privKey)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -38,7 +38,7 @@ func (m *mockSigner) ComputeInputScript(tx *wire.MsgTx,
|
|||||||
signDesc *lnwallet.SignDescriptor) (*lnwallet.InputScript, error) {
|
signDesc *lnwallet.SignDescriptor) (*lnwallet.InputScript, error) {
|
||||||
witnessScript, err := txscript.WitnessSignature(tx, signDesc.SigHashes,
|
witnessScript, err := txscript.WitnessSignature(tx, signDesc.SigHashes,
|
||||||
signDesc.InputIndex, signDesc.Output.Value,
|
signDesc.InputIndex, signDesc.Output.Value,
|
||||||
signDesc.Output.PkScript, txscript.SigHashAll, m.key, true)
|
signDesc.Output.PkScript, signDesc.HashType, m.key, true)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user