mirror of
https://github.com/m2049r/xmrwallet
synced 2025-03-28 10:13:05 +01:00
don't do stuff if the wallet is already closed
This commit is contained in:
parent
d803a1e220
commit
454f3e412a
@ -281,7 +281,8 @@ public class WalletService extends Service {
|
|||||||
case START_SERVICE: {
|
case START_SERVICE: {
|
||||||
Bundle extras = msg.getData();
|
Bundle extras = msg.getData();
|
||||||
String cmd = extras.getString(REQUEST, null);
|
String cmd = extras.getString(REQUEST, null);
|
||||||
if (cmd.equals(REQUEST_CMD_LOAD)) {
|
switch (cmd) {
|
||||||
|
case REQUEST_CMD_LOAD:
|
||||||
String walletId = extras.getString(REQUEST_WALLET, null);
|
String walletId = extras.getString(REQUEST_WALLET, null);
|
||||||
String walletPw = extras.getString(REQUEST_CMD_LOAD_PW, null);
|
String walletPw = extras.getString(REQUEST_CMD_LOAD_PW, null);
|
||||||
Timber.d("LOAD wallet %s", walletId);
|
Timber.d("LOAD wallet %s", walletId);
|
||||||
@ -295,8 +296,10 @@ public class WalletService extends Service {
|
|||||||
stop();
|
stop();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if (cmd.equals(REQUEST_CMD_STORE)) {
|
break;
|
||||||
|
case REQUEST_CMD_STORE: {
|
||||||
Wallet myWallet = getWallet();
|
Wallet myWallet = getWallet();
|
||||||
|
if (myWallet == null) break;
|
||||||
Timber.d("STORE wallet: %s", myWallet.getName());
|
Timber.d("STORE wallet: %s", myWallet.getName());
|
||||||
boolean rc = myWallet.store();
|
boolean rc = myWallet.store();
|
||||||
Timber.d("wallet stored: %s with rc=%b", myWallet.getName(), rc);
|
Timber.d("wallet stored: %s with rc=%b", myWallet.getName(), rc);
|
||||||
@ -304,10 +307,14 @@ public class WalletService extends Service {
|
|||||||
Timber.w("Wallet store failed: %s", myWallet.getStatus().getErrorString());
|
Timber.w("Wallet store failed: %s", myWallet.getStatus().getErrorString());
|
||||||
}
|
}
|
||||||
if (observer != null) observer.onWalletStored(rc);
|
if (observer != null) observer.onWalletStored(rc);
|
||||||
} else if (cmd.equals(REQUEST_CMD_TX)) {
|
break;
|
||||||
|
}
|
||||||
|
case REQUEST_CMD_TX: {
|
||||||
Wallet myWallet = getWallet();
|
Wallet myWallet = getWallet();
|
||||||
|
if (myWallet == null) break;
|
||||||
Timber.d("CREATE TX for wallet: %s", myWallet.getName());
|
Timber.d("CREATE TX for wallet: %s", myWallet.getName());
|
||||||
myWallet.disposePendingTransaction(); // remove any old pending tx
|
myWallet.disposePendingTransaction(); // remove any old pending tx
|
||||||
|
|
||||||
TxData txData = extras.getParcelable(REQUEST_CMD_TX_DATA);
|
TxData txData = extras.getParcelable(REQUEST_CMD_TX_DATA);
|
||||||
String txTag = extras.getString(REQUEST_CMD_TX_TAG);
|
String txTag = extras.getString(REQUEST_CMD_TX_TAG);
|
||||||
PendingTransaction pendingTransaction = myWallet.createTransaction(txData);
|
PendingTransaction pendingTransaction = myWallet.createTransaction(txData);
|
||||||
@ -321,10 +328,14 @@ public class WalletService extends Service {
|
|||||||
} else {
|
} else {
|
||||||
myWallet.disposePendingTransaction();
|
myWallet.disposePendingTransaction();
|
||||||
}
|
}
|
||||||
} else if (cmd.equals(REQUEST_CMD_SWEEP)) {
|
break;
|
||||||
|
}
|
||||||
|
case REQUEST_CMD_SWEEP: {
|
||||||
Wallet myWallet = getWallet();
|
Wallet myWallet = getWallet();
|
||||||
|
if (myWallet == null) break;
|
||||||
Timber.d("SWEEP TX for wallet: %s", myWallet.getName());
|
Timber.d("SWEEP TX for wallet: %s", myWallet.getName());
|
||||||
myWallet.disposePendingTransaction(); // remove any old pending tx
|
myWallet.disposePendingTransaction(); // remove any old pending tx
|
||||||
|
|
||||||
String txTag = extras.getString(REQUEST_CMD_TX_TAG);
|
String txTag = extras.getString(REQUEST_CMD_TX_TAG);
|
||||||
PendingTransaction pendingTransaction = myWallet.createSweepUnmixableTransaction();
|
PendingTransaction pendingTransaction = myWallet.createSweepUnmixableTransaction();
|
||||||
PendingTransaction.Status status = pendingTransaction.getStatus();
|
PendingTransaction.Status status = pendingTransaction.getStatus();
|
||||||
@ -337,8 +348,11 @@ public class WalletService extends Service {
|
|||||||
} else {
|
} else {
|
||||||
myWallet.disposePendingTransaction();
|
myWallet.disposePendingTransaction();
|
||||||
}
|
}
|
||||||
} else if (cmd.equals(REQUEST_CMD_SEND)) {
|
break;
|
||||||
|
}
|
||||||
|
case REQUEST_CMD_SEND: {
|
||||||
Wallet myWallet = getWallet();
|
Wallet myWallet = getWallet();
|
||||||
|
if (myWallet == null) break;
|
||||||
Timber.d("SEND TX for wallet: %s", myWallet.getName());
|
Timber.d("SEND TX for wallet: %s", myWallet.getName());
|
||||||
PendingTransaction pendingTransaction = myWallet.getPendingTransaction();
|
PendingTransaction pendingTransaction = myWallet.getPendingTransaction();
|
||||||
if (pendingTransaction == null) {
|
if (pendingTransaction == null) {
|
||||||
@ -352,6 +366,7 @@ public class WalletService extends Service {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
final String txid = pendingTransaction.getFirstTxId(); // tx ids vanish after commit()!
|
final String txid = pendingTransaction.getFirstTxId(); // tx ids vanish after commit()!
|
||||||
|
|
||||||
boolean success = pendingTransaction.commit("", true);
|
boolean success = pendingTransaction.commit("", true);
|
||||||
if (success) {
|
if (success) {
|
||||||
myWallet.disposePendingTransaction();
|
myWallet.disposePendingTransaction();
|
||||||
@ -373,6 +388,8 @@ public class WalletService extends Service {
|
|||||||
if (observer != null) observer.onSendTransactionFailed(error);
|
if (observer != null) observer.onSendTransactionFailed(error);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user