mirror of
https://github.com/bisq-network/bisq.git
synced 2025-02-24 23:18:17 +01:00
Accept segwit addresses when sending non-BSQ funds
This commit is contained in:
parent
41b2e6a56d
commit
864700775b
1 changed files with 9 additions and 5 deletions
|
@ -513,7 +513,7 @@ public class BsqWalletService extends WalletService implements DaoStateListener
|
||||||
|
|
||||||
public Transaction getPreparedSendBsqTx(String receiverAddress, Coin receiverAmount)
|
public Transaction getPreparedSendBsqTx(String receiverAddress, Coin receiverAmount)
|
||||||
throws AddressFormatException, InsufficientBsqException, WalletException, TransactionVerificationException, BsqChangeBelowDustException {
|
throws AddressFormatException, InsufficientBsqException, WalletException, TransactionVerificationException, BsqChangeBelowDustException {
|
||||||
return getPreparedSendTx(receiverAddress, receiverAmount, bsqCoinSelector);
|
return getPreparedSendTx(receiverAddress, receiverAmount, bsqCoinSelector, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
///////////////////////////////////////////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
@ -522,17 +522,21 @@ public class BsqWalletService extends WalletService implements DaoStateListener
|
||||||
|
|
||||||
public Transaction getPreparedSendBtcTx(String receiverAddress, Coin receiverAmount)
|
public Transaction getPreparedSendBtcTx(String receiverAddress, Coin receiverAmount)
|
||||||
throws AddressFormatException, InsufficientBsqException, WalletException, TransactionVerificationException, BsqChangeBelowDustException {
|
throws AddressFormatException, InsufficientBsqException, WalletException, TransactionVerificationException, BsqChangeBelowDustException {
|
||||||
return getPreparedSendTx(receiverAddress, receiverAmount, nonBsqCoinSelector);
|
return getPreparedSendTx(receiverAddress, receiverAmount, nonBsqCoinSelector, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
private Transaction getPreparedSendTx(String receiverAddress, Coin receiverAmount, CoinSelector coinSelector)
|
private Transaction getPreparedSendTx(String receiverAddress, Coin receiverAmount, CoinSelector coinSelector,
|
||||||
|
boolean allowSegwitOuput)
|
||||||
throws AddressFormatException, InsufficientBsqException, WalletException, TransactionVerificationException, BsqChangeBelowDustException {
|
throws AddressFormatException, InsufficientBsqException, WalletException, TransactionVerificationException, BsqChangeBelowDustException {
|
||||||
daoKillSwitch.assertDaoIsNotDisabled();
|
daoKillSwitch.assertDaoIsNotDisabled();
|
||||||
Transaction tx = new Transaction(params);
|
Transaction tx = new Transaction(params);
|
||||||
checkArgument(Restrictions.isAboveDust(receiverAmount),
|
checkArgument(Restrictions.isAboveDust(receiverAmount),
|
||||||
"The amount is too low (dust limit).");
|
"The amount is too low (dust limit).");
|
||||||
tx.addOutput(receiverAmount, LegacyAddress.fromBase58(params, receiverAddress));
|
if (allowSegwitOuput) {
|
||||||
|
tx.addOutput(receiverAmount, Address.fromString(params, receiverAddress));
|
||||||
|
} else {
|
||||||
|
tx.addOutput(receiverAmount, LegacyAddress.fromBase58(params, receiverAddress));
|
||||||
|
}
|
||||||
SendRequest sendRequest = SendRequest.forTx(tx);
|
SendRequest sendRequest = SendRequest.forTx(tx);
|
||||||
sendRequest.fee = Coin.ZERO;
|
sendRequest.fee = Coin.ZERO;
|
||||||
sendRequest.feePerKb = Coin.ZERO;
|
sendRequest.feePerKb = Coin.ZERO;
|
||||||
|
|
Loading…
Add table
Reference in a new issue