mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-06-28 12:29:51 +00:00
* decred: Add decred. (#1322) * multi: Add initial decred screens. (#1165) Use a mock libwallet for now. * cw_decred: add libdcrwallet dependency and link library for android, ios and macos (#1240) * change cw_decred from package to plugin * add libdcrwallet dependency and link library for android, ios and macos * remove spvwallet, make some libdcrwallet fns async, light refactor * libdcrwallet: use json payload returns * use specific libwallet commit hash * decred: fix Rename wallet. --------- Co-authored-by: JoeGruff <joegruffins@gmail.com> * decred: Add sync. * decred: Add send transaction. * decred: Fix fee estimation. * decred: List transactions. * decred: Add rescan. * decred: Sign message. * decred: Add new addr and addrs. * decred: Add change wallet pass. * decred: Add restore from seed. * decred: Add watching only wallets. * decred: Enable mainnet. * decred: Allow using blank node address. This allows a persistent peer to be unset, falling back to decred seeders. * decred: Rescan from wallet birthday. * add and update macos build scripts, update build readme, gitignore macos project.pbxproj Signed-off-by: Philemon Ukane <ukanephilemon@gmail.com> * multi: hide decred rescan page if it's not ready - move hasRescan method to WalletBase and implement for decred Signed-off-by: Philemon Ukane <ukanephilemon@gmail.com> * cw_decred: fix bug where decred wallets are not loaded after app restart Signed-off-by: Philemon Ukane <ukanephilemon@gmail.com> * add buy and sell for decred via onramp Signed-off-by: Philemon Ukane <ukanephilemon@gmail.com> * bug-fix: account for other send outputs that are part of the same tx Signed-off-by: Philemon Ukane <ukanephilemon@gmail.com> * decred: Return address with no peers. * decred: Update pubspec. * decred: Add verify message. * upgrade hive_generator dep in cw_decred * decred: Clean up code. --------- Signed-off-by: Philemon Ukane <ukanephilemon@gmail.com> Co-authored-by: Wisdom Arerosuoghene <wisdom.arerosuoghene@gmail.com> Co-authored-by: Philemon Ukane <ukanephilemon@gmail.com> * fix extracted addresses not used fix conflicts with main * remove print [skip ci] * minor formatting * fix initial migration version * add build decred script to workflow * install go before build decred fix switch cases * trial 2 to fix decred build * re-install go * revert build script change * refactor/clean nodes functions * Fix address book issue Fix send ALL (to be continued with the fees point) * Fix transactions display issues Add missing file * Fix unconfirmed balance not displayed Change Wallet order Minor cleanup * Fix workflow * Fix workflow * Fix workflow * test * hardcode path for now * fix + cleanup decred build script to work on mac and linux * Update decred build script * Run actions on pull requests, extract commit message * run after checkout * add safe directory * Get commit message from base.sha instead of last commit * base -> head * Do not merge main branch into pr * [skip slack] [run tests] clone by sha * Proper name for decred library in the build script * Throw an error when ANDROID_HOME or ANDROID_NDK_VERSION is missing * Fix conflicts with main * minor code enhancement * decred: Add used address history. (#1941) * decred: Update pubspec. * decred testnet * decred: Add used address history. * decred: Remove default node list. * populate transaction history before sync begins * decred: Add some awaits. * decred: Fix send all. * decred: Add clang export to build script. * decred: Update logo colors. * cleanup cw_decred.dart * make decred wallet addresses selectable in receive page * decred: Always set default addr when used. * decred: Add back default node list. * decred: Allow creating addresses manually. --------- Co-authored-by: Wisdom Arerosuoghene <wisdom.arerosuoghene@gmail.com> Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com> * minor fixes and cleanup * minor fix, feel free to test now * - Fix transaction details - Fix Nodes - Add processing sync status * Add decred info card * push missing file * Add missing text for decred info card * minor: change docs link [skip ci] * decred: Update derivation info. (#2013) * decred: Update derivation info. * decred: Allow unsynced unused addresses. * decred: Update dcrwallet dep to 4.3.0. * Merge main and fix conflicts * Merge main and fix conflicts * decred: Fix background sync panic. (#2080) * decred: Run libwallet in isolate. (#2077) * decred: Fix contact save inquiry. (#2083) Also fix tx time and the fee shown on pending transactions. * Disable send button in view only decred wallets * - Fix frozen coins - Add URI support - Fix fees in tx details - Handle empty coins send - Handle wallets in address book * Merge main * remove print [skip ci] * Fix restore from QR * minor improvement for QR restore * minor fixes [skip ci] * decred: Get slip44 addrs before sync completes. (#2092) * - Fix loading wallet more than one time - Fix minor UI issue --------- Signed-off-by: Philemon Ukane <ukanephilemon@gmail.com> Co-authored-by: JoeGruffins <34998433+JoeGruffins@users.noreply.github.com> Co-authored-by: Wisdom Arerosuoghene <wisdom.arerosuoghene@gmail.com> Co-authored-by: Philemon Ukane <ukanephilemon@gmail.com> Co-authored-by: Czarek Nakamoto <cyjan@mrcyjanek.net>
159 lines
6 KiB
Dart
159 lines
6 KiB
Dart
import 'package:cake_wallet/di.dart';
|
|
import 'package:cake_wallet/entities/auto_generate_subaddress_status.dart';
|
|
import 'package:cake_wallet/entities/fiat_api_mode.dart';
|
|
import 'package:cake_wallet/entities/update_haven_rate.dart';
|
|
import 'package:cake_wallet/entities/wallet_manager.dart';
|
|
import 'package:cake_wallet/ethereum/ethereum.dart';
|
|
import 'package:cake_wallet/polygon/polygon.dart';
|
|
import 'package:cake_wallet/solana/solana.dart';
|
|
import 'package:cake_wallet/tron/tron.dart';
|
|
import 'package:cw_core/crypto_currency.dart';
|
|
import 'package:cw_core/transaction_history.dart';
|
|
import 'package:cw_core/balance.dart';
|
|
import 'package:cw_core/transaction_info.dart';
|
|
import 'package:cw_core/utils/print_verbose.dart';
|
|
import 'package:mobx/mobx.dart';
|
|
import 'package:cake_wallet/reactions/check_connection.dart';
|
|
import 'package:cake_wallet/reactions/on_wallet_sync_status_change.dart';
|
|
import 'package:cake_wallet/store/dashboard/fiat_conversion_store.dart';
|
|
import 'package:cake_wallet/store/app_store.dart';
|
|
import 'package:cake_wallet/store/settings_store.dart';
|
|
import 'package:cake_wallet/core/fiat_conversion_service.dart';
|
|
import 'package:cw_core/wallet_base.dart';
|
|
import 'package:cw_core/wallet_type.dart';
|
|
|
|
ReactionDisposer? _onCurrentWalletChangeReaction;
|
|
ReactionDisposer? _onCurrentWalletChangeFiatRateUpdateReaction;
|
|
//ReactionDisposer _onCurrentWalletAddressChangeReaction;
|
|
|
|
void startCurrentWalletChangeReaction(
|
|
AppStore appStore, SettingsStore settingsStore, FiatConversionStore fiatConversionStore) {
|
|
_onCurrentWalletChangeReaction?.reaction.dispose();
|
|
_onCurrentWalletChangeFiatRateUpdateReaction?.reaction.dispose();
|
|
//_onCurrentWalletAddressChangeReaction?.reaction?dispose();
|
|
|
|
//_onCurrentWalletAddressChangeReaction = reaction((_) => appStore.wallet.walletAddresses.address,
|
|
//(String address) async {
|
|
//if (address == appStore.wallet.walletInfo.yatLastUsedAddress) {
|
|
// return;
|
|
//}
|
|
|
|
//try {
|
|
// final yatStore = getIt.get<YatStore>();
|
|
// await updateEmojiIdAddress(
|
|
// appStore.wallet.walletInfo.yatEmojiId,
|
|
// appStore.wallet.walletAddresses.address,
|
|
// yatStore.apiKey,
|
|
// appStore.wallet.type
|
|
// );
|
|
// appStore.wallet.walletInfo.yatLastUsedAddress = address;
|
|
// await appStore.wallet.walletInfo.save();
|
|
//} catch (e) {
|
|
// printV(e.toString());
|
|
//}
|
|
//});
|
|
|
|
_onCurrentWalletChangeReaction = reaction((_) => appStore.wallet,
|
|
(WalletBase<Balance, TransactionHistoryBase<TransactionInfo>, TransactionInfo>?
|
|
wallet) async {
|
|
try {
|
|
if (wallet == null) {
|
|
return;
|
|
}
|
|
|
|
await getIt.get<WalletManager>().ensureGroupHasHashedIdentifier(wallet);
|
|
|
|
final node = settingsStore.getCurrentNode(wallet.type);
|
|
|
|
startWalletSyncStatusChangeReaction(wallet, fiatConversionStore);
|
|
startCheckConnectionReaction(wallet, settingsStore);
|
|
|
|
await Future.delayed(Duration.zero);
|
|
|
|
if (wallet.type == WalletType.monero ||
|
|
wallet.type == WalletType.wownero ||
|
|
wallet.type == WalletType.bitcoin ||
|
|
wallet.type == WalletType.litecoin ||
|
|
wallet.type == WalletType.bitcoinCash ||
|
|
wallet.type == WalletType.decred) {
|
|
_setAutoGenerateSubaddressStatus(wallet, settingsStore);
|
|
}
|
|
|
|
await wallet.connectToNode(node: node);
|
|
if (wallet.type == WalletType.nano || wallet.type == WalletType.banano) {
|
|
final powNode = settingsStore.getCurrentPowNode(wallet.type);
|
|
await wallet.connectToPowNode(node: powNode);
|
|
}
|
|
|
|
if (wallet.type == WalletType.haven) {
|
|
await updateHavenRate(fiatConversionStore);
|
|
}
|
|
|
|
if (wallet.walletInfo.address.isEmpty) {
|
|
wallet.walletInfo.address = wallet.walletAddresses.address;
|
|
|
|
if (wallet.walletInfo.isInBox) {
|
|
await wallet.walletInfo.save();
|
|
}
|
|
}
|
|
} catch (e) {
|
|
printV(e.toString());
|
|
}
|
|
});
|
|
|
|
_onCurrentWalletChangeFiatRateUpdateReaction = reaction((_) => appStore.wallet,
|
|
(WalletBase<Balance, TransactionHistoryBase<TransactionInfo>, TransactionInfo>?
|
|
wallet) async {
|
|
try {
|
|
if (wallet == null || settingsStore.fiatApiMode == FiatApiMode.disabled) {
|
|
return;
|
|
}
|
|
|
|
fiatConversionStore.prices[wallet.currency] = 0;
|
|
fiatConversionStore.prices[wallet.currency] = await FiatConversionService.fetchPrice(
|
|
crypto: wallet.currency,
|
|
fiat: settingsStore.fiatCurrency,
|
|
torOnly: settingsStore.fiatApiMode == FiatApiMode.torOnly);
|
|
|
|
Iterable<CryptoCurrency>? currencies;
|
|
if (wallet.type == WalletType.ethereum) {
|
|
currencies =
|
|
ethereum!.getERC20Currencies(appStore.wallet!).where((element) => element.enabled);
|
|
}
|
|
if (wallet.type == WalletType.polygon) {
|
|
currencies =
|
|
polygon!.getERC20Currencies(appStore.wallet!).where((element) => element.enabled);
|
|
}
|
|
if (wallet.type == WalletType.solana) {
|
|
currencies =
|
|
solana!.getSPLTokenCurrencies(appStore.wallet!).where((element) => element.enabled);
|
|
}
|
|
if (wallet.type == WalletType.tron) {
|
|
currencies =
|
|
tron!.getTronTokenCurrencies(appStore.wallet!).where((element) => element.enabled);
|
|
}
|
|
|
|
if (currencies != null) {
|
|
for (final currency in currencies) {
|
|
() async {
|
|
fiatConversionStore.prices[currency] = await FiatConversionService.fetchPrice(
|
|
crypto: currency,
|
|
fiat: settingsStore.fiatCurrency,
|
|
torOnly: settingsStore.fiatApiMode == FiatApiMode.torOnly);
|
|
}.call();
|
|
}
|
|
}
|
|
} catch (e) {
|
|
printV(e.toString());
|
|
}
|
|
});
|
|
}
|
|
|
|
void _setAutoGenerateSubaddressStatus(
|
|
WalletBase<Balance, TransactionHistoryBase<TransactionInfo>, TransactionInfo> wallet,
|
|
SettingsStore settingsStore,
|
|
) async {
|
|
wallet.isEnabledAutoGenerateSubaddress =
|
|
settingsStore.autoGenerateSubaddressStatus == AutoGenerateSubaddressStatus.enabled ||
|
|
settingsStore.autoGenerateSubaddressStatus == AutoGenerateSubaddressStatus.initialized;
|
|
}
|