mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-03-06 14:19:59 -05:00
refactor: helper function signWithExternalSigner()
Does not change behavior. Review hint: git show --color-moved --color-moved-ws=allow-indentation-change
This commit is contained in:
parent
026b5b4523
commit
4b5a6cd149
2 changed files with 38 additions and 27 deletions
|
@ -447,6 +447,34 @@ void SendCoinsDialog::presentPSBT(PartiallySignedTransaction& psbtx)
|
||||||
} // msgBox.exec()
|
} // msgBox.exec()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool SendCoinsDialog::signWithExternalSigner(PartiallySignedTransaction& psbtx, CMutableTransaction& mtx, bool& complete) {
|
||||||
|
TransactionError err;
|
||||||
|
try {
|
||||||
|
err = model->wallet().fillPSBT(SIGHASH_ALL, /*sign=*/true, /*bip32derivs=*/true, /*n_signed=*/nullptr, psbtx, complete);
|
||||||
|
} catch (const std::runtime_error& e) {
|
||||||
|
QMessageBox::critical(nullptr, tr("Sign failed"), e.what());
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (err == TransactionError::EXTERNAL_SIGNER_NOT_FOUND) {
|
||||||
|
//: "External signer" means using devices such as hardware wallets.
|
||||||
|
QMessageBox::critical(nullptr, tr("External signer not found"), "External signer not found");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (err == TransactionError::EXTERNAL_SIGNER_FAILED) {
|
||||||
|
//: "External signer" means using devices such as hardware wallets.
|
||||||
|
QMessageBox::critical(nullptr, tr("External signer failure"), "External signer failure");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (err != TransactionError::OK) {
|
||||||
|
tfm::format(std::cerr, "Failed to sign PSBT");
|
||||||
|
processSendCoinsReturn(WalletModel::TransactionCreationFailed);
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
// fillPSBT does not always properly finalize
|
||||||
|
complete = FinalizeAndExtractPSBT(psbtx, mtx);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
void SendCoinsDialog::sendButtonClicked([[maybe_unused]] bool checked)
|
void SendCoinsDialog::sendButtonClicked([[maybe_unused]] bool checked)
|
||||||
{
|
{
|
||||||
if(!model || !model->getOptionsModel())
|
if(!model || !model->getOptionsModel())
|
||||||
|
@ -479,33 +507,7 @@ void SendCoinsDialog::sendButtonClicked([[maybe_unused]] bool checked)
|
||||||
assert(!complete);
|
assert(!complete);
|
||||||
assert(err == TransactionError::OK);
|
assert(err == TransactionError::OK);
|
||||||
if (model->wallet().hasExternalSigner()) {
|
if (model->wallet().hasExternalSigner()) {
|
||||||
try {
|
send_failure = !signWithExternalSigner(psbtx, mtx, complete);
|
||||||
err = model->wallet().fillPSBT(SIGHASH_ALL, true /* sign */, true /* bip32derivs */, nullptr, psbtx, complete);
|
|
||||||
} catch (const std::runtime_error& e) {
|
|
||||||
QMessageBox::critical(nullptr, tr("Sign failed"), e.what());
|
|
||||||
send_failure = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (err == TransactionError::EXTERNAL_SIGNER_NOT_FOUND) {
|
|
||||||
//: "External signer" means using devices such as hardware wallets.
|
|
||||||
QMessageBox::critical(nullptr, tr("External signer not found"), "External signer not found");
|
|
||||||
send_failure = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (err == TransactionError::EXTERNAL_SIGNER_FAILED) {
|
|
||||||
//: "External signer" means using devices such as hardware wallets.
|
|
||||||
QMessageBox::critical(nullptr, tr("External signer failure"), "External signer failure");
|
|
||||||
send_failure = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (err != TransactionError::OK) {
|
|
||||||
tfm::format(std::cerr, "Failed to sign PSBT");
|
|
||||||
processSendCoinsReturn(WalletModel::TransactionCreationFailed);
|
|
||||||
send_failure = true;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
// fillPSBT does not always properly finalize
|
|
||||||
complete = FinalizeAndExtractPSBT(psbtx, mtx);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Broadcast transaction if complete (even with an external signer this
|
// Broadcast transaction if complete (even with an external signer this
|
||||||
|
|
|
@ -79,6 +79,15 @@ private:
|
||||||
void minimizeFeeSection(bool fMinimize);
|
void minimizeFeeSection(bool fMinimize);
|
||||||
// Format confirmation message
|
// Format confirmation message
|
||||||
bool PrepareSendText(QString& question_string, QString& informative_text, QString& detailed_text);
|
bool PrepareSendText(QString& question_string, QString& informative_text, QString& detailed_text);
|
||||||
|
/* Sign PSBT using external signer.
|
||||||
|
*
|
||||||
|
* @param[in,out] psbtx the PSBT to sign
|
||||||
|
* @param[in,out] mtx needed to attempt to finalize
|
||||||
|
* @param[in,out] complete whether the PSBT is complete (a successfully signed multisig transaction may not be complete)
|
||||||
|
*
|
||||||
|
* @returns false if any failure occurred, which may include the user rejection of a transaction on the device.
|
||||||
|
*/
|
||||||
|
bool signWithExternalSigner(PartiallySignedTransaction& psbt, CMutableTransaction& mtx, bool& complete);
|
||||||
void updateFeeMinimizedLabel();
|
void updateFeeMinimizedLabel();
|
||||||
void updateCoinControlState();
|
void updateCoinControlState();
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue