Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: support taproot for signAllInputsHD #2137

Open
wants to merge 6 commits into
base: master
Choose a base branch
from

Conversation

jasonandjay
Copy link
Member

  • issue discussion: Feature Request: Taproot support for signAllInputsHD #2132
  • feat
    • affected Signature Methods
      • signAllInputsHD
      • signAllInputsAsyncHD
      • signInputHD
      • signInputAsyncHD
    • remove conflict default sighashTypes of signInputHD
      • Transaction.SIGHASH_DEFAULT for _signTaprootInput
      • Transaction.SIGHASH_ALL for _signInput
      • so we should remove the outermost default signType
    • add integration test for HDWallet with tapBip32Derivation
      • we will need more integration tests later.

@jasonandjay jasonandjay requested review from junderw and motorina0 July 24, 2024 08:10
@jasonandjay

This comment was marked as resolved.

@jasonandjay
Copy link
Member Author

How about code review progress?

@cpuchainorg
Copy link

@junderw Could you check this PR?

@landabaso
Copy link

I have an observation regarding the asymmetry in signInput when using ecpair.

I'm not saying this is incorrect, but this PR allows psbt.signInputHD(index, node), which detects if the input is a Taproot input and internally tweaks the signer (getTweakSignersFromHD).

On the other hand, in psbt.signInput(index, ecpair), the user must pre-tweak the signer manually.

As a result, it's not possible to use signAllInputs with a common ecpair for both Taproot and non-Taproot inputs, whereas signAllInputsHD allows using a common node for both.

Again, I'm not saying this is necessarily wrong. Perhaps this is the only viable approach, but I wanted to highlight this to see if there’s anything further we can do, or at least reflect this behavior more clearly in the comments at the top of psbt.ts.

landabaso added a commit to bitcoinerlab/descriptors that referenced this pull request Mar 12, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants