use of jota.dto.response.GetBalancesResponse 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.dto.response.GetBalancesResponse in project run-wallet-android by runplay.
the class GetFirstLoadRequestHandler method handle.
@Override
public ApiResponse handle(ApiRequest request) {
FirstTimeHolder holder = new FirstTimeHolder();
// StopWatch stopWatch = new StopWatch();
GetFirstLoadRequest firstLoadRequest = (GetFirstLoadRequest) request;
Wallet wallet = null;
List<Address> allAddresses = new ArrayList<>();
List<Transfer> transfers = new ArrayList<>();
long started = System.currentTimeMillis();
if (!firstLoadRequest.getSeed().isappgenerated) {
holders.put(firstLoadRequest.getSeed().id, holder);
while (holder.userConfirmedBalance == null || started < System.currentTimeMillis() - 60000) {
try {
this.wait(1000);
} catch (Exception e) {
}
}
} else {
holder.userConfirmedBalance = false;
holders.put(firstLoadRequest.getSeed().id, holder);
}
boolean userDeclaredBalance = holder.userConfirmedBalance == null ? false : holder.userConfirmedBalance.booleanValue();
holder.userConfirmedBalance = userDeclaredBalance ? Boolean.TRUE : Boolean.FALSE;
// Log.e("FL","uc="+holder.userConfirmedBalance+" - ud="+userDeclaredBalance);
if (!userDeclaredBalance || firstLoadRequest.getSeed().isappgenerated) {
try {
final GetNewAddressResponse gna = apiProxy.getNewAddress(String.valueOf(Store.getSeedRaw(context, firstLoadRequest.getSeed())), firstLoadRequest.getSecurity(), 0, false, 1, false);
for (String add : gna.getAddresses()) {
Address newaddress = new Address(add, false, false);
newaddress.setIndexName(1);
allAddresses.add(newaddress);
}
} catch (Exception e) {
}
wallet = new Wallet(firstLoadRequest.getSeed().id, 0, System.currentTimeMillis());
} else {
long timestamp = System.currentTimeMillis();
holder.showWaitMessage = true;
holder.predictaddress = 0;
Map<Integer, Address> already = new HashMap<>();
int start = 0;
boolean stop = false;
List<Bundle> allbundles = new ArrayList<>();
Map<String, Boolean> hasalready = new HashMap<>();
wallet = new Wallet(((GetFirstLoadRequest) request).getSeed().id, 0, System.currentTimeMillis());
List<Transfer> addInTransfers = new ArrayList<>();
SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context);
final int maxAddresses = Sf.toInt(prefs.getString(Constants.PREF_FIRST_LOAD_ATTEMPTS, "" + Constants.PREF_FIRST_LOAD_ATTEMPTS_DEFAULT));
final int stopWhenCountEmpty = Sf.toInt(prefs.getString(Constants.PREF_FIRST_LOAD_RANGE, "" + Constants.PREF_FIRST_LOAD_RANGE_DEFAULT));
while (!stop) {
Address alreadyAddress = already.get(start);
Map<String, Boolean> snapshotBalanceAlreadyAddresses = new HashMap();
boolean foundTransfers = false;
if (alreadyAddress != null) {
holder.countaddress++;
alreadyAddress.setIndex(start);
alreadyAddress.setIndexName(start + 1);
allAddresses.add(alreadyAddress);
} else {
Address newaddress = null;
long useBalance = 0L;
try {
GetNewAddressResponse gnr = apiProxy.getNewAddress(String.valueOf(Store.getSeedRaw(context, firstLoadRequest.getSeed())), firstLoadRequest.getSecurity(), start, false, 1, false);
String add = gnr.getAddresses().get(0);
// Log.e("FIRST-TIME", "CALC ADDRESS: " + add + " -- " + start+"-");
newaddress = new Address(add, false, false);
holder.countaddress++;
newaddress.setIndex(start);
newaddress.setIndexName(start + 1);
allAddresses.add(newaddress);
List<String> tmpadd = new ArrayList<>();
tmpadd.add(newaddress.getAddress());
GetBalancesResponse gbal = apiProxy.getBalances(100, tmpadd);
useBalance = Sf.toLong(gbal.getBalances()[0]);
newaddress.setValue(useBalance);
newaddress.setLastMilestone(gbal.getMilestoneIndex());
newaddress.setAttached(true);
Bundle[] bundles = apiProxy.bundlesFromAddresses(new String[] { newaddress.getAddress() }, true);
if (bundles != null && bundles.length > 0) {
newaddress.setAttached(true);
foundTransfers = true;
for (int i = 0; i < bundles.length; i++) {
String hash = bundles[i].getTransactions().get(0).getHash();
if (hasalready.get(hash) == null) {
hasalready.put(hash, true);
allbundles.add(bundles[i]);
}
}
}
long oldWallet = wallet.getBalance();
long expecting = oldWallet + useBalance;
holder.predictaddress = expecting;
transfers.clear();
Audit.bundlePopulateTransfers(allbundles.toArray(new Bundle[allbundles.size()]), transfers, allAddresses);
Audit.setTransfersToAddresses(((GetFirstLoadRequest) request).getSeed(), transfers, allAddresses, wallet, addInTransfers);
if (wallet.getBalance() != expecting && useBalance > 0) {
if (snapshotBalanceAlreadyAddresses.get(newaddress.getAddress()) == null) {
long theBalance = expecting - wallet.getBalance();
// Log.e("MK-SNAP","snap::: set-bal: "+theBalance+" - wallet:"+wallet.getBalance()+" - expect:"+expecting+" - add-bal"+useBalance+" - snap-add-tran-value:"+newaddress.getValue()+" - on-address:"+newaddress.getAddress());
Transfer addInTran = new Transfer(timestamp, newaddress.getAddress(), "SNAP" + SeedRandomGenerator.generateNewSeed().substring(0, 23), true, theBalance, "Snapshot balance confirmed", "SNAP999999999999999999");
TransferTransaction tt = new TransferTransaction(newaddress.getAddress(), theBalance);
List<TransferTransaction> tmptt = new ArrayList<>();
tmptt.add(tt);
addInTran.setTransactions(tmptt);
addInTransfers.add(addInTran);
Audit.setTransfersToAddresses(((GetFirstLoadRequest) request).getSeed(), transfers, allAddresses, wallet, addInTransfers);
}
}
snapshotBalanceAlreadyAddresses.put(newaddress.getAddress(), true);
holder.counttransfers = transfers.size();
} catch (Exception e) {
Log.e("ERR-FLR020", "address index: " + start + ", ex: " + e.getMessage());
}
}
int lastComplete = 0;
// boolean hasLastComplete=false;
for (int i = 0; i < allAddresses.size(); i++) {
Address tmpadd = allAddresses.get(i);
if (tmpadd.getValue() != 0) {
lastComplete = i;
}
}
// Log.e("WALLET","current value: "+wallet.getBalance()+" - "+wallet.getBalancePendingIn()+" -- "+wallet.getBalancePendingOut());
int countempty = 0;
if (!foundTransfers && lastComplete > 0 && allAddresses.size() >= stopWhenCountEmpty) {
for (int i = allAddresses.size() - 1; i >= 0 && i > lastComplete; i--) {
countempty++;
}
}
start++;
// Log.e("COUNT_EMPTY",allAddresses.size()+" addresses, empty: "+countempty);
if (countempty >= stopWhenCountEmpty || start > maxAddresses) {
stop = true;
}
}
for (Transfer tran : transfers) {
if (!tran.getTransactions().isEmpty()) {
if (tran.getTimestamp() < timestamp)
timestamp = tran.getTimestamp();
}
}
timestamp = timestamp - 600000;
for (Transfer addIn : addInTransfers) {
addIn.setTimestamp(--timestamp);
}
allAddresses = allAddresses.subList(0, allAddresses.size() - (stopWhenCountEmpty));
Audit.setTransfersToAddresses(((GetFirstLoadRequest) request).getSeed(), transfers, allAddresses, wallet, addInTransfers);
}
boolean hasTransfer = false;
for (int i = allAddresses.size() - 1; i >= 0; i--) {
Address address = allAddresses.get(i);
if (address.getValue() != 0 || address.getPendingValue() != 0) {
hasTransfer = true;
} else if (hasTransfer) {
address.setUsed(true);
}
}
Store.setAccountData(context, ((GetFirstLoadRequest) request).getSeed(), wallet, transfers, allAddresses);
holder.isFinished = true;
AppService.auditAddressesWithDelay(context, ((GetFirstLoadRequest) request).getSeed());
return new GetFirstLoadResponse();
}
use of jota.dto.response.GetBalancesResponse 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