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

Fix BIP 78 & BIP 174 Conflict: Keep input utxo data through input finalization #1396

Merged
merged 2 commits into from
Jan 14, 2025

Conversation

DanGould
Copy link
Contributor

@DanGould DanGould commented Dec 20, 2022

According to the psbt Input Finalizer spec "All other data except the UTXO and unknown fields in the input key-value map should be cleared from the PSBT. The UTXO should be kept to allow Transaction Extractors to verify the final network serialized transaction." In Bip78, the receiver clears this data after it finalizes its inputs, even if the utxo belongs to the sender which will need that data.

I ran into a problem where LND's FinalizePsbt gRPC fails when this utxo data is missing. I see no good reason to remove this utxo information from the PSBT. I think LND's RPC should also succeed regardless of this data being present because it can look it up with the unsigned_tx's input outpoint (that's what bitcoind's finalizePsbt rpc does). Still I think LND's RPC is technically BIP-0174 spec-compliant while BIP-0078 seems not to be.

https://github.com/lightningnetwork/lnd/blob/cf9a9864cf253dbbcac5904d360bbbde763e1ebe/lnwallet/rpcwallet/rpcwallet.go#L270-L286
According to the psbt Input Finalizer spec "All other data except the UTXO and unknown fields in the input key-value map should be cleared from the PSBT. The UTXO should be kept to allow Transaction Extractors to verify the final network serialized transaction."

I ran into a problem where an LND acting as sender FinalizePsbt gRPC fails when sender utxo information is missing. I see no good reason to remove utxo information from the PSBT.

Edit Jun 2024: This problem also cropped up in sparrow wallet


tagging this issue in the rust-payjoin library

@nickfarrow @Kixunil @NicolasDorier

@murchandamus
Copy link
Contributor

Seems reasonable, but needs an endorsement from the original BIP author, @NicolasDorier.

@murchandamus murchandamus added Pending acceptance This BIP modification requires sign-off by the champion of the BIP being modified Proposed BIP modification labels May 8, 2024
@DanGould
Copy link
Contributor Author

@NicolasDorier This issue cropped itself up in Sparrow wallet too, where sparrow won't sign based solely on an outpoint but requires the utxo scripts to sign.

sparrowwallet/sparrow#1428

It would be great to resolve this as payjoin adoption is mounting.

@spacebear21
Copy link

The reference sender implementation should also be updated to remove this check:

// Verify that <code>non_witness_utxo</code> and <code>witness_utxo</code> are not specified.
if (proposedPSBTInput.NonWitnessUtxo != null || proposedPSBTInput.WitnessUtxo != null)
    throw new PayjoinSenderException("The receiver added non_witness_utxo or witness_utxo to one of our inputs");

The test vectors should likely be updated as well.

@craigraw
Copy link
Contributor

+1

It would at least be good to understand why this information is removed from the original PSBT, which is technically in conflict with BIP174.

@DanGould
Copy link
Contributor Author

My guess was that the spec was written this way out of convenience for the original NBitcoin / BTCPayServer implementation.

The BTCPayServer sender calls proposedPayjoin.SignAll. By excluding the utxo fields the signer would not have to do an exhaustive search for signable scriptPubKeys. I didn't find anywhere where including a foreign utxo would cause an error. But it looks like exhaustive search could make the signer take a long time to return.

The reference sender implementation and \`payjoin proposal\` test vectors
are adjusted accordingly.

According to the psbt Input Finalizer spec "All other data except the
UTXO and unknown fields in the input key-value map should be cleared from
the PSBT. The UTXO should be kept to allow Transaction Extractors to
verify the final network serialized transaction."

I ran into a problem where an LND acting as sender FinalizePsbt gRPC
fails when sender utxo information is missing. I see no good reason to
remove utxo information from the PSBT.
@jonatack
Copy link
Member

jonatack commented Jun 21, 2024

@NicolasDorier could you please weigh in here?

@murchandamus
Copy link
Contributor

Hey, has there been any movement on this PR? @NicolasDorier, I think it might be waiting for your review.

@jonatack
Copy link
Member

jonatack commented Jan 7, 2025

@NicolasDorier could you please weight in here?

Re-pinging @NicolasDorier.

@NicolasDorier
Copy link
Contributor

Sorry about the lack of reply, ACK.

@jonatack jonatack removed the Pending acceptance This BIP modification requires sign-off by the champion of the BIP being modified label Jan 14, 2025
@jonatack jonatack merged commit 2f862f7 into bitcoin:master Jan 14, 2025
4 checks passed
DanGould added a commit to DanGould/payjoin-client that referenced this pull request Jan 15, 2025
BIP 78 was updated to permit this behavior in order to be in compliance
with BIP 174 (PSBT).

See: bitcoin/bips#1396
DanGould added a commit to DanGould/rust-payjoin that referenced this pull request Jan 23, 2025
BIP 78 (Payjoin v1) was updated to remain in compliance
with BIP 174 (PSBT v0).

See: bitcoin/bips#1396
DanGould added a commit to DanGould/rust-payjoin that referenced this pull request Jan 23, 2025
BIP 78 (Payjoin v1) was updated to remain in compliance
with BIP 174 (PSBT v0).

See: bitcoin/bips#1396
See also: payjoin#480
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

7 participants