2019-05-06 14:05:28 -04:00
|
|
|
// Copyright (c) 2009-2019 The Bitcoin Core developers
|
2019-01-09 02:06:29 -08:00
|
|
|
// Distributed under the MIT software license, see the accompanying
|
|
|
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
|
|
|
|
|
|
|
#include <wallet/psbtwallet.h>
|
|
|
|
|
2019-02-14 10:01:06 -05:00
|
|
|
TransactionError FillPSBT(const CWallet* pwallet, PartiallySignedTransaction& psbtx, bool& complete, int sighash_type, bool sign, bool bip32derivs)
|
2019-01-09 02:06:29 -08:00
|
|
|
{
|
|
|
|
LOCK(pwallet->cs_wallet);
|
|
|
|
// Get all of the previous transactions
|
2019-02-09 20:51:33 -08:00
|
|
|
complete = true;
|
2019-01-09 02:06:29 -08:00
|
|
|
for (unsigned int i = 0; i < psbtx.tx->vin.size(); ++i) {
|
|
|
|
const CTxIn& txin = psbtx.tx->vin[i];
|
|
|
|
PSBTInput& input = psbtx.inputs.at(i);
|
|
|
|
|
|
|
|
if (PSBTInputSigned(input)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Verify input looks sane. This will check that we have at most one uxto, witness or non-witness.
|
|
|
|
if (!input.IsSane()) {
|
2019-02-14 10:01:06 -05:00
|
|
|
return TransactionError::INVALID_PSBT;
|
2019-01-09 02:06:29 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
// If we have no utxo, grab it from the wallet.
|
|
|
|
if (!input.non_witness_utxo && input.witness_utxo.IsNull()) {
|
|
|
|
const uint256& txhash = txin.prevout.hash;
|
|
|
|
const auto it = pwallet->mapWallet.find(txhash);
|
|
|
|
if (it != pwallet->mapWallet.end()) {
|
|
|
|
const CWalletTx& wtx = it->second;
|
|
|
|
// We only need the non_witness_utxo, which is a superset of the witness_utxo.
|
|
|
|
// The signing code will switch to the smaller witness_utxo if this is ok.
|
|
|
|
input.non_witness_utxo = wtx.tx;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Get the Sighash type
|
|
|
|
if (sign && input.sighash_type > 0 && input.sighash_type != sighash_type) {
|
2019-02-14 10:01:06 -05:00
|
|
|
return TransactionError::SIGHASH_MISMATCH;
|
2019-01-09 02:06:29 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
complete &= SignPSBTInput(HidingSigningProvider(pwallet, !sign, !bip32derivs), psbtx, i, sighash_type);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fill in the bip32 keypaths and redeemscripts for the outputs so that hardware wallets can identify change
|
|
|
|
for (unsigned int i = 0; i < psbtx.tx->vout.size(); ++i) {
|
2019-02-16 15:49:36 -08:00
|
|
|
UpdatePSBTOutput(HidingSigningProvider(pwallet, true, !bip32derivs), psbtx, i);
|
2019-01-09 02:06:29 -08:00
|
|
|
}
|
2019-02-09 20:51:33 -08:00
|
|
|
|
2019-02-14 10:01:06 -05:00
|
|
|
return TransactionError::OK;
|
2019-01-09 02:06:29 -08:00
|
|
|
}
|