delete backup wallets if confirmed unfunded

This commit is contained in:
woodser 2023-01-20 10:08:38 -05:00
parent 9877ba87a4
commit e6baf0260a

View File

@ -613,12 +613,14 @@ public abstract class Trade implements Tradable, Model {
// complete arbitrator trade // complete arbitrator trade
if (isArbitrator() && !isCompleted()) processModel.getTradeManager().onTradeCompleted(this); if (isArbitrator() && !isCompleted()) processModel.getTradeManager().onTradeCompleted(this);
// reset address entries
processModel.getXmrWalletService().resetAddressEntriesForPendingTrade(getId()); processModel.getXmrWalletService().resetAddressEntriesForPendingTrade(getId());
} }
// cleanup when payout unlocks // cleanup when payout unlocks
if (newValue == Trade.PayoutState.PAYOUT_UNLOCKED) { if (newValue == Trade.PayoutState.PAYOUT_UNLOCKED) {
log.info("Payout unlocked for {} {}, deleting multisig wallet", getClass().getSimpleName(), getId()); // TODO: retain backup for some time? log.info("Payout unlocked for {} {}, deleting multisig wallet", getClass().getSimpleName(), getId());
deleteWallet(); deleteWallet();
if (txPollLooper != null) { if (txPollLooper != null) {
txPollLooper.stop(); txPollLooper.stop();
@ -967,6 +969,7 @@ public abstract class Trade implements Tradable, Model {
log.warn("Refusing to delete backup wallet for {} {} in the small chance it becomes funded", getClass().getSimpleName(), getId()); log.warn("Refusing to delete backup wallet for {} {} in the small chance it becomes funded", getClass().getSimpleName(), getId());
return; return;
} }
xmrWalletService.deleteMultisigWalletBackups(getId());
} else { } else {
log.warn("Multisig wallet to delete for trade {} does not exist", getId()); log.warn("Multisig wallet to delete for trade {} does not exist", getId());
} }
@ -1582,7 +1585,7 @@ public abstract class Trade implements Tradable, Model {
} }
private boolean isIdling() { private boolean isIdling() {
return this instanceof ArbitratorTrade && isDepositConfirmed(); // arbitrator idles after deposits confirm return this instanceof ArbitratorTrade && isDepositConfirmed(); // arbitrator idles trade after deposits confirm
} }
private void setStateDepositsPublished() { private void setStateDepositsPublished() {