mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-18 08:45:05 +00:00
CW-371-Restore-height-issue-with-QR-code-Wallet-incorrectly-assigns-today's-restore-height-to-legacy-wallets (#925)
* fix height for legacy wallets * get height by first tx under singular seed
This commit is contained in:
parent
18ba724009
commit
c835059d13
2 changed files with 52 additions and 15 deletions
|
@ -122,6 +122,8 @@ int getMoneroHeigthByDate({required DateTime date}) {
|
||||||
}
|
}
|
||||||
|
|
||||||
const havenDates = {
|
const havenDates = {
|
||||||
|
"2023-05": 1352995,
|
||||||
|
"2023-04": 1331460,
|
||||||
"2023-03": 1309180,
|
"2023-03": 1309180,
|
||||||
"2023-01": 1266810,
|
"2023-01": 1266810,
|
||||||
"2022-12": 1244510,
|
"2022-12": 1244510,
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
import 'package:cake_wallet/store/app_store.dart';
|
import 'package:cake_wallet/store/app_store.dart';
|
||||||
|
import 'package:cw_core/transaction_direction.dart';
|
||||||
|
import 'package:cw_core/transaction_info.dart';
|
||||||
import 'package:cw_core/wallet_type.dart';
|
import 'package:cw_core/wallet_type.dart';
|
||||||
import 'package:mobx/mobx.dart';
|
import 'package:mobx/mobx.dart';
|
||||||
import 'package:cake_wallet/generated/i18n.dart';
|
import 'package:cake_wallet/generated/i18n.dart';
|
||||||
|
@ -19,12 +21,26 @@ abstract class WalletKeysViewModelBase with Store {
|
||||||
? S.current.wallet_seed
|
? S.current.wallet_seed
|
||||||
: S.current.wallet_keys,
|
: S.current.wallet_keys,
|
||||||
_restoreHeight = _appStore.wallet!.walletInfo.restoreHeight,
|
_restoreHeight = _appStore.wallet!.walletInfo.restoreHeight,
|
||||||
|
_restoreHeightByTransactions = 0,
|
||||||
items = ObservableList<StandartListItem>() {
|
items = ObservableList<StandartListItem>() {
|
||||||
_populateItems();
|
_populateItems();
|
||||||
|
|
||||||
reaction((_) => _appStore.wallet, (WalletBase? _wallet) {
|
reaction((_) => _appStore.wallet, (WalletBase? _wallet) {
|
||||||
_populateItems();
|
_populateItems();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (_appStore.wallet!.type == WalletType.monero || _appStore.wallet!.type == WalletType.haven) {
|
||||||
|
final accountTransactions = _getWalletTransactions(_appStore.wallet!);
|
||||||
|
if (accountTransactions.isNotEmpty) {
|
||||||
|
final incomingAccountTransactions =
|
||||||
|
accountTransactions.where((tx) => tx.direction == TransactionDirection.incoming);
|
||||||
|
if (incomingAccountTransactions.isNotEmpty) {
|
||||||
|
incomingAccountTransactions.toList().sort((a, b) => a.date.compareTo(b.date));
|
||||||
|
_restoreHeightByTransactions = _getRestoreHeightByTransactions(
|
||||||
|
_appStore.wallet!.type, incomingAccountTransactions.first.date);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
final ObservableList<StandartListItem> items;
|
final ObservableList<StandartListItem> items;
|
||||||
|
@ -35,6 +51,8 @@ abstract class WalletKeysViewModelBase with Store {
|
||||||
|
|
||||||
final int _restoreHeight;
|
final int _restoreHeight;
|
||||||
|
|
||||||
|
int _restoreHeightByTransactions;
|
||||||
|
|
||||||
void _populateItems() {
|
void _populateItems() {
|
||||||
items.clear();
|
items.clear();
|
||||||
|
|
||||||
|
@ -78,7 +96,7 @@ abstract class WalletKeysViewModelBase with Store {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<int?> currentHeight() async {
|
Future<int?> _currentHeight() async {
|
||||||
if (_appStore.wallet!.type == WalletType.haven) {
|
if (_appStore.wallet!.type == WalletType.haven) {
|
||||||
return await haven!.getCurrentHeight();
|
return await haven!.getCurrentHeight();
|
||||||
}
|
}
|
||||||
|
@ -88,7 +106,6 @@ abstract class WalletKeysViewModelBase with Store {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
String get _scheme {
|
String get _scheme {
|
||||||
switch (_appStore.wallet!.type) {
|
switch (_appStore.wallet!.type) {
|
||||||
case WalletType.monero:
|
case WalletType.monero:
|
||||||
|
@ -105,14 +122,14 @@ abstract class WalletKeysViewModelBase with Store {
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<String?> get restoreHeight async {
|
Future<String?> get restoreHeight async {
|
||||||
if (_restoreHeight != 0) {
|
if (_restoreHeightByTransactions != 0)
|
||||||
return _restoreHeight.toString();
|
return getRoundedRestoreHeight(_restoreHeightByTransactions);
|
||||||
}
|
if (_restoreHeight != 0) return _restoreHeight.toString();
|
||||||
final _currentHeight = await currentHeight();
|
|
||||||
if (_currentHeight == null) {
|
final currentHeight = await _currentHeight();
|
||||||
return null;
|
if (currentHeight == null) return null;
|
||||||
}
|
|
||||||
return ((_currentHeight / 1000).floor() * 1000).toString();
|
return getRoundedRestoreHeight(currentHeight);
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<Map<String, String>> get _queryParams async {
|
Future<Map<String, String>> get _queryParams async {
|
||||||
|
@ -123,10 +140,28 @@ abstract class WalletKeysViewModelBase with Store {
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<Uri> get url async {
|
Future<Uri> get url async => Uri(
|
||||||
return Uri(
|
scheme: _scheme,
|
||||||
scheme: _scheme,
|
queryParameters: await _queryParams,
|
||||||
queryParameters: await _queryParams,
|
);
|
||||||
);
|
|
||||||
|
List<TransactionInfo> _getWalletTransactions(WalletBase wallet) {
|
||||||
|
if (wallet.type == WalletType.monero) {
|
||||||
|
return monero!.getTransactionHistory(wallet).transactions.values.toList();
|
||||||
|
} else if (wallet.type == WalletType.haven) {
|
||||||
|
return haven!.getTransactionHistory(wallet).transactions.values.toList();
|
||||||
|
}
|
||||||
|
return [];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int _getRestoreHeightByTransactions(WalletType type, DateTime date) {
|
||||||
|
if (type == WalletType.monero) {
|
||||||
|
return monero!.getHeigthByDate(date: date);
|
||||||
|
} else if (type == WalletType.haven) {
|
||||||
|
return haven!.getHeightByDate(date: date);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getRoundedRestoreHeight(int height) => ((height / 1000).floor() * 1000).toString();
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue