use of jota.utils.StopWatch in project run-wallet-android by runplay.
the class GetAccountDataRequestHandler method handle.
@Override
public ApiResponse handle(ApiRequest inrequest) {
GetAccountDataRequest request = (GetAccountDataRequest) inrequest;
GetTransferResponse gtr = null;
StopWatch stopWatch = new StopWatch();
NodeInfoResponse nodeInfo = Store.getNodeInfo();
Wallet wallet = Store.getWallet(context, request.getSeed());
if (wallet != null && nodeInfo != null) {
List<Address> alreadyAddress = Store.getAddresses(context, request.getSeed());
List<Address> usingAddress = Store.getDisplayAddresses(alreadyAddress);
List<Address> checkAddress = new ArrayList<>();
if (request.getIfSingleAddressOrNull() != null) {
Address address = Store.isAlreadyAddress(request.getIfSingleAddressOrNull(), alreadyAddress);
if (address != null) {
checkAddress.add(address);
}
} else {
for (Address add : usingAddress) {
if (!add.isUsed() || (add.isUsed() && (add.getPendingValue() != 0 || add.getValue() != 0))) {
if (request.isForce() || nodeInfo.getLatestMilestoneIndex() != add.getLastMilestone()) {
checkAddress.add(add);
}
}
}
}
if (!checkAddress.isEmpty()) {
try {
List<String> checkAddressString = new ArrayList<>();
List<String> checkAddressBal = new ArrayList<>();
for (Address addr : checkAddress) {
checkAddressBal.add(addr.getAddress());
}
GetBalancesResponse gbal = apiProxy.getBalances(100, checkAddressBal);
for (int i = 0; i < gbal.getBalances().length; i++) {
Address addr = checkAddress.get(i);
long gotBalance = Sf.toLong(gbal.getBalances()[i]);
if (addr.getValue() != gotBalance || addr.getPendingValue() != 0) {
addr.setValue(gotBalance);
checkAddressString.add(addr.getAddress());
}
}
if (!checkAddressString.isEmpty()) {
Bundle[] bundles = apiProxy.bundlesFromAddresses(checkAddressString.toArray(new String[checkAddressString.size()]), true);
gtr = GetTransferResponse.create(bundles, stopWatch.getElapsedTimeMili());
}
List<Transfer> transfers = new ArrayList<>();
if (gtr != null && gtr.getTransfers().length > 0) {
List<Transfer> alreadyTransfer = Store.getTransfers(context, request.getSeed());
Audit.bundlePopulateTransfers(gtr.getTransfers(), transfers, alreadyAddress);
if (request.getIfSingleAddressOrNull() != null) {
Audit.setTransfersToAddresses(request.getSeed(), transfers, alreadyAddress, wallet, alreadyTransfer);
} else {
Audit.setTransfersToAddresses(request.getSeed(), transfers, alreadyAddress, wallet, alreadyTransfer);
}
Audit.processNudgeAttempts(context, request.getSeed(), transfers);
Store.updateAccountData(context, request.getSeed(), wallet, transfers, alreadyAddress);
}
if (request.getIfSingleAddressOrNull() == null) {
WalletAddressesFragment.setShouldRefresh(true);
WalletTransfersFragment.setShouldRefresh(true);
List<String> checkOthersString = new ArrayList<>();
for (Address address : checkAddress) {
if (!checkAddressString.contains(address.getAddress()))
checkOthersString.add(address.getAddress());
}
if (!checkOthersString.isEmpty()) {
Bundle[] bundles = apiProxy.bundlesFromAddresses(checkOthersString.toArray(new String[checkOthersString.size()]), true);
gtr = GetTransferResponse.create(bundles, stopWatch.getElapsedTimeMili());
}
if (gtr != null && gtr.getTransfers().length > 0) {
transfers = new ArrayList<>();
List<Transfer> alreadyTransfer = Store.getTransfers(context, request.getSeed());
Audit.bundlePopulateTransfers(gtr.getTransfers(), transfers, alreadyAddress);
if (request.getIfSingleAddressOrNull() != null) {
Audit.setTransfersToAddresses(request.getSeed(), transfers, alreadyAddress, wallet, alreadyTransfer);
} else {
Audit.setTransfersToAddresses(request.getSeed(), transfers, alreadyAddress, wallet, alreadyTransfer);
}
Audit.processNudgeAttempts(context, request.getSeed(), transfers);
Store.updateAccountData(context, request.getSeed(), wallet, transfers, alreadyAddress);
}
}
} catch (Exception e) {
Log.e("ERR066", "ERROR: " + e.getMessage());
}
}
AppService.setFastMode();
return new GetAccountDataResponse();
}
return new ApiResponse();
}
use of jota.utils.StopWatch in project run-wallet-android by runplay.
the class GetBalanceAndFormatRequestHandler method handle.
@Override
public ApiResponse handle(ApiRequest request) {
int notificationId = Utils.createNewID();
ApiResponse response;
try {
StopWatch stopWatch = new StopWatch();
// stopWatch.
// Log.e("BALF","Getting balances and format");
response = new GetBalanceAndFormatResponse(apiProxy.getBalanceAndFormat(((GetBalanceAndFormatRequest) request).addresses, 0L, 0, stopWatch, 0));
List<Input> inputs = ((GetBalanceAndFormatResponse) response).getInputs();
} catch (ArgumentException e) {
NetworkError error = new NetworkError();
if (e instanceof ArgumentException) {
if (e.getMessage().contains("Sending to a used address.") || e.getMessage().contains("Private key reuse detect!")) {
final Activity activity = (Activity) context;
Bundle bundle = new Bundle();
bundle.putString("error", e.getMessage());
KeyReuseDetectedDialog dialog = new KeyReuseDetectedDialog();
dialog.setArguments(bundle);
dialog.show(activity.getFragmentManager(), null);
error.setErrorType(NetworkErrorType.KEY_REUSE_ERROR);
}
}
if (error.getErrorType() != NetworkErrorType.KEY_REUSE_ERROR) {
error.setErrorType(NetworkErrorType.NETWORK_ERROR);
}
response = error;
}
return response;
}
use of jota.utils.StopWatch in project run-wallet-android by runplay.
the class MessageFirstLoadRequestHandler method handle.
@Override
public ApiResponse handle(ApiRequest request) {
try {
// Log.e("FIRST-TIME-MSG","called");
StopWatch stopWatch = new StopWatch();
MessageFirstLoadRequest firstLoadRequest = (MessageFirstLoadRequest) request;
GetTransferResponse gtr = null;
List<Address> allAddresses = new ArrayList<>();
int start = 0;
final int addcount = 5;
while (true) {
GetNewAddressResponse gnr = apiProxy.getNewAddress(String.valueOf(Store.getSeedRaw(context, MsgStore.getSeed())), firstLoadRequest.getSecurity(), start, false, start + addcount, true);
for (String add : gnr.getAddresses()) {
// Log.e("FIRST-TIME-MSG","CALC ADDRESS: "+allAddresses+" -- "+stopWatch.getElapsedTimeSecs());
final FindTransactionResponse tr = apiProxy.findTransactionsByAddresses(add);
Address newaddress = new Address(add, false, true);
if (tr.getHashes().length == 0) {
newaddress.setAttached(false);
}
allAddresses.add(newaddress);
}
int countempty = 0;
for (int i = allAddresses.size() - 1; i >= 0 && i >= allAddresses.size() - 4; i--) {
if (!allAddresses.get(i).isAttached()) {
countempty++;
}
}
if (countempty >= 2) {
break;
}
start += addcount;
}
List<String> transactionaddresses = new ArrayList<>();
for (Address add : allAddresses) {
if (add.isAttached())
transactionaddresses.add(add.getAddress());
}
if (!transactionaddresses.isEmpty()) {
try {
Bundle[] bundles = apiProxy.bundlesFromAddresses(transactionaddresses.toArray(new String[transactionaddresses.size()]), true);
gtr = GetTransferResponse.create(bundles, stopWatch.getElapsedTimeMili());
} catch (Exception e) {
Log.e("FIRST-LOAD-MSG", "ex: " + e.getMessage());
}
} else {
gtr = GetTransferResponse.create(new Bundle[] {}, stopWatch.getElapsedTimeMili());
}
List<Transfer> transfers = new ArrayList<>();
long seedTotal = 0;
Wallet wallet = new Wallet(MsgStore.getSeed().id, seedTotal, System.currentTimeMillis());
// Audit.setTransfersToAddresses(firstLoadRequest.getSeed(),gtr,transfers,allAddresses,wallet);
MsgStore.updateMessageData(context, wallet, transfers, allAddresses);
// AppService.generateMessageNewAddress(context);
// if()
} catch (ArgumentException e) {
Log.e("FIRST-TIME-MSG", "ex: " + e.getMessage());
return new NetworkError();
}
return new ApiResponse();
}
use of jota.utils.StopWatch in project run-wallet-android by runplay.
the class RefreshUsedAddressesHandler method checkUsedAddressForSeed.
private GetAccountDataResponse checkUsedAddressForSeed(Seeds.Seed seed, boolean report) {
Wallet wallet = Store.getWallet(context, seed);
if (wallet != null) {
List<Address> alreadyAddress = Store.getAddresses(context, seed);
GetTransferResponse gtr = null;
StopWatch stopWatch = new StopWatch();
List<Address> checkAddress = new ArrayList<>();
for (Address tmp : alreadyAddress) {
if (tmp.isUsed() && tmp.getValue() == 0) {
checkAddress.add(tmp);
}
}
if (!checkAddress.isEmpty()) {
try {
List<String> checkAddressString = new ArrayList<>();
List<String> checkAddressBal = new ArrayList<>();
for (Address addr : checkAddress) {
checkAddressBal.add(addr.getAddress());
}
GetBalancesResponse gbal = apiProxy.getBalances(100, checkAddressBal);
for (int i = 0; i < gbal.getBalances().length; i++) {
Address addr = checkAddress.get(i);
long gotBalance = Sf.toLong(gbal.getBalances()[i]);
if (gotBalance != 0 || addr.getPendingValue() != 0) {
addr.setValue(gotBalance);
checkAddressString.add(addr.getAddress());
}
if (report) {
if (gotBalance > 0) {
Store.setUsedAddressCheckResult(context.getString(R.string.usedAddressNoOk) + " " + IotaToText.convertRawIotaAmountToDisplayText(gotBalance, true));
} else {
Store.setUsedAddressCheckResult(context.getString(R.string.usedAddressOk));
}
}
}
if (!checkAddressString.isEmpty()) {
Bundle[] bundles = apiProxy.bundlesFromAddresses(checkAddressString.toArray(new String[checkAddressString.size()]), true);
gtr = GetTransferResponse.create(bundles, stopWatch.getElapsedTimeMili());
}
List<Transfer> transfers = new ArrayList<>();
if (gtr != null && gtr.getTransfers().length > 0) {
List<Transfer> alreadyTransfer = Store.getTransfers(context, seed);
Audit.bundlePopulateTransfers(gtr.getTransfers(), transfers, alreadyAddress);
Audit.setTransfersToAddresses(seed, transfers, alreadyAddress, wallet, alreadyTransfer);
Audit.processNudgeAttempts(context, seed, transfers);
Store.updateAccountData(context, seed, wallet, transfers, alreadyAddress);
}
} catch (Exception e) {
Log.e("ERR066", "ERROR: " + e.getMessage());
}
}
}
return new GetAccountDataResponse();
}
Aggregations