2023-08-30 15:11:56 +00:00
|
|
|
import 'dart:io' show Directory, File, Platform;
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cake_wallet/bitcoin/bitcoin.dart';
|
2023-03-01 21:44:15 +00:00
|
|
|
import 'package:cake_wallet/entities/exchange_api_mode.dart';
|
2024-04-02 18:02:28 +00:00
|
|
|
import 'package:cake_wallet/entities/fiat_api_mode.dart';
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cw_core/pathForWallet.dart';
|
2021-01-15 17:41:30 +00:00
|
|
|
import 'package:cake_wallet/entities/secret_store_key.dart';
|
|
|
|
import 'package:flutter_secure_storage/flutter_secure_storage.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
import 'package:hive/hive.dart';
|
2023-08-30 15:11:56 +00:00
|
|
|
import 'package:path_provider/path_provider.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
2020-09-21 11:50:26 +00:00
|
|
|
import 'package:cake_wallet/entities/preferences_key.dart';
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cw_core/wallet_type.dart';
|
|
|
|
import 'package:cw_core/node.dart';
|
2020-09-21 11:50:26 +00:00
|
|
|
import 'package:cake_wallet/entities/balance_display_mode.dart';
|
|
|
|
import 'package:cake_wallet/entities/fiat_currency.dart';
|
|
|
|
import 'package:cake_wallet/entities/node_list.dart';
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cake_wallet/monero/monero.dart';
|
2020-09-23 18:26:10 +00:00
|
|
|
import 'package:cake_wallet/entities/contact.dart';
|
|
|
|
import 'package:cake_wallet/entities/fs_migration.dart';
|
2021-12-24 12:37:24 +00:00
|
|
|
import 'package:cw_core/wallet_info.dart';
|
2020-09-23 18:26:10 +00:00
|
|
|
import 'package:cake_wallet/exchange/trade.dart';
|
2021-01-15 17:41:30 +00:00
|
|
|
import 'package:encrypt/encrypt.dart' as encrypt;
|
2022-10-12 17:09:57 +00:00
|
|
|
import 'package:collection/collection.dart';
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2021-02-01 18:12:37 +00:00
|
|
|
const newCakeWalletMoneroUri = 'xmr-node.cakewallet.com:18081';
|
2021-05-07 07:36:38 +00:00
|
|
|
const cakeWalletBitcoinElectrumUri = 'electrum.cakewallet.com:50002';
|
Btc address types (#1263)
* inital migration changes
* feat: rest of changes
* minor fix [skip ci]
* fix: P2wshAddress & wallet address index
* fix: address review comments
* fix: address type restore
* feat: add testnet
* Fix review comments
Remove bitcoin_base from cw_core
* Fix address not matching selected type on start
* remove un-necessary parameter [skip ci]
* Remove bitcoin specific code from main lib
Fix possible runtime exception from list wrong access
* Minor fix
* fix: fixes for Testnet
* fix: bitcoin receive option dependency breaks monerocom
* Fix issues when building Monero.com
* feat: Transaction Builder changes
* fix: discover addresses, testnet restoring, duplicate unspent coins, and taproot address vs schnorr sig tweak
* fix: remove print
* feat: improve error when failed broadcast response
* feat: create fish shell env script
* fix: unmodifiable maps
* fix: build
* fix: build
* fix: computed observable side effect bug
* feat: add nix script for android build_all
* fix: wrong keypairs used for signing
* fix: wrong addresses when using fromScriptPubKey scripts
* fix(actual commit): testnet tx expanded + wrong addresses when using fromScriptPubKey scripts (update bitcoin_base deps)
* fix: self-send [skip ci]
* fix: p2wsh
* fix: testnet fees
* New versions
* Update macos build number
Minor UI fix
* fix: use new bitcoin_base ref, fix tx list wrong hex value & refactor hidden vs hd use
- if always use sideHd for isHidden, it is easier to simplify the functions instead of passing both which can be error prone
- (ps: now this could probably be changed, for example from isHidden to isChange since with address list we now see "hidden" addresses)
* Fix if condition to handle litecoin case
* fix: self-send, change address was always making direction incoming
* refactor: improve estimation function, add more inputs if balance missing
* fix: new bitcoin_base update, fixes script issues
* Update evm chain wallet service arguments
* Fix translation [skip ci]
* Fix translation [skip ci]
* Update strings_fr.arb [skip ci]
* fix: async isChange function not being awaited, refactor to reduce looping into a single place
* fix: _address vs address, missing p2sh
* fix: minor mistake in storing p2sh page type [skip ci]
* refactor: use already matched addresses property
* feat: improved perfomance for fetching transaction histories
* feat: continue perfomance change, improve address discovery only to last address by type with history
* fix: make sure transaction list is sorted by date
* refactor: isTestnet only for bitcoin
* fix: walletInfo type null case
* fix: deprecated p2pk
* refactor: make condition more readable
* refactor: remove unnecessary Str variant
* refactor: make condition more readable
* fix: infinite loop possible
* Revert removing isTestnet from other wallets [skip ci]
* refactor: rename addresses when matched by receive type
* Make the beta build [skip ci]
Remove app_env.fish
---------
Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
2024-02-23 16:13:30 +00:00
|
|
|
const publicBitcoinTestnetElectrumAddress = 'electrum.blockstream.info';
|
|
|
|
const publicBitcoinTestnetElectrumPort = '60002';
|
|
|
|
const publicBitcoinTestnetElectrumUri =
|
|
|
|
'$publicBitcoinTestnetElectrumAddress:$publicBitcoinTestnetElectrumPort';
|
2021-05-11 16:57:12 +00:00
|
|
|
const cakeWalletLitecoinElectrumUri = 'ltc-electrum.cakewallet.com:50002';
|
2022-05-18 16:13:58 +00:00
|
|
|
const havenDefaultNodeUri = 'nodes.havenprotocol.org:443';
|
2023-01-13 01:47:24 +00:00
|
|
|
const ethereumDefaultNodeUri = 'ethereum.publicnode.com';
|
2023-12-02 02:26:43 +00:00
|
|
|
const polygonDefaultNodeUri = 'polygon-bor.publicnode.com';
|
2023-10-12 22:50:16 +00:00
|
|
|
const cakeWalletBitcoinCashDefaultNodeUri = 'bitcoincash.stackwallet.com:50002';
|
2023-10-05 01:09:07 +00:00
|
|
|
const nanoDefaultNodeUri = 'rpc.nano.to';
|
|
|
|
const nanoDefaultPowNodeUri = 'rpc.nano.to';
|
CW-555-Add-Solana-Wallet (#1272)
* chore: Create cw_solana package and clean up files
* feat: Add Solana Wallet - Create, Restore form seed, restore from Key, Restore from QR, Send, Receive, transaction history, spl tokens
* fix: Make transactions file specific to solana only for solana transactions
* chore: Revert inject app details script
* fix: Fix issue with node and switch current node to main beta instead of testnet
* fix: Fix merge conflicts and adjust migration version
* fix: Fetch spl token error
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
* fix: Diplay and activate spl tokens bug
* fix: Review and fixes
* fix: reverted formatting for cryptocurrency class
* fix: Review comments, split sending flow into signing and sending separately, fix issues
* fix: Revert throwing unimplenented error
* chore: Fix comment
* chore: Fix comment
* fix: Errors in flow
* Update provider_types.dart [skip ci]
* fix: Issues with solana wallet
* Update solana_wallet.dart [skip ci]
* fix: Review comments
* fix: Date time config
* fix: Revert bash script for app details
* fix: Error with balance, displaying fees, fixing sent or received identifier bug, displaying token symbol with token transaction item in transactions list
* fix: Issues with address validation when sending spl tokens and walletconnect initial setup
* fix: Issues with sending, fetching transactions history, almost wrapping up walletconnect
* fix: Adjust imports that would affect monerocom building successfully
* fix: Refine transaction direction and continue work on walletconnect
* feat: Display SPL token transfers in the transaction history and finally settle the transaction direction
* fix: Delay in transactions history dispaly, show native token transactions first, then process spl token transactions
* feat: Switch node and revert solana chain id to previous id
* fix: Remove print statement
* fix: Remove await for transactions, fetch all transaction histories instantly and adjust solana send success message
* chore: Code refactoring and streamlined wallet type check for solana send success message
* fix: Make timeout error for node silent and add spl token images
---------
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
2024-02-23 13:39:19 +00:00
|
|
|
const solanaDefaultNodeUri = 'rpc.ankr.com';
|
2024-03-18 15:45:11 +00:00
|
|
|
const newCakeWalletBitcoinUri = 'btc-electrum.cakewallet.com:50002';
|
2021-02-01 18:12:37 +00:00
|
|
|
|
2023-08-30 15:11:56 +00:00
|
|
|
Future<void> defaultSettingsMigration(
|
2022-10-12 17:09:57 +00:00
|
|
|
{required int version,
|
|
|
|
required SharedPreferences sharedPreferences,
|
|
|
|
required FlutterSecureStorage secureStorage,
|
|
|
|
required Box<Node> nodes,
|
2023-09-07 15:34:22 +00:00
|
|
|
required Box<Node> powNodes,
|
2022-10-12 17:09:57 +00:00
|
|
|
required Box<WalletInfo> walletInfoSource,
|
|
|
|
required Box<Trade> tradeSource,
|
|
|
|
required Box<Contact> contactSource}) async {
|
2020-09-23 18:26:10 +00:00
|
|
|
if (Platform.isIOS) {
|
|
|
|
await ios_migrate_v1(walletInfoSource, tradeSource, contactSource);
|
|
|
|
}
|
|
|
|
|
2023-03-17 19:15:28 +00:00
|
|
|
// check current nodes for nullability regardless of the version
|
2023-08-16 21:09:29 +00:00
|
|
|
await checkCurrentNodes(nodes, powNodes, sharedPreferences);
|
2023-03-17 19:15:28 +00:00
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
final isNewInstall =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.currentDefaultSettingsMigrationVersion) == null;
|
2023-04-21 15:21:31 +00:00
|
|
|
|
2023-08-30 15:51:51 +00:00
|
|
|
await _validateWalletInfoBoxData(walletInfoSource);
|
2023-10-09 21:19:58 +00:00
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
await sharedPreferences.setBool(PreferencesKey.isNewInstall, isNewInstall);
|
2023-04-21 15:21:31 +00:00
|
|
|
|
2023-08-16 19:22:05 +00:00
|
|
|
final currentVersion =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.currentDefaultSettingsMigrationVersion) ?? 0;
|
2023-07-27 14:30:07 +00:00
|
|
|
|
2020-01-04 19:31:52 +00:00
|
|
|
if (currentVersion >= version) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-01-08 16:38:38 +00:00
|
|
|
final migrationVersionsLength = version - currentVersion;
|
2023-07-27 14:30:07 +00:00
|
|
|
final migrationVersions =
|
|
|
|
List<int>.generate(migrationVersionsLength, (i) => currentVersion + (i + 1));
|
2020-01-08 16:38:38 +00:00
|
|
|
|
2023-12-02 02:26:43 +00:00
|
|
|
/// When you add a new case, increase the initialMigrationVersion parameter in the main.dart file.
|
|
|
|
/// This ensures that this switch case runs the newly added case.
|
2020-01-08 16:38:38 +00:00
|
|
|
await Future.forEach(migrationVersions, (int version) async {
|
|
|
|
try {
|
|
|
|
switch (version) {
|
|
|
|
case 1:
|
|
|
|
await sharedPreferences.setString(
|
2023-07-27 14:30:07 +00:00
|
|
|
PreferencesKey.currentFiatCurrencyKey, FiatCurrency.usd.toString());
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentTransactionPriorityKeyLegacy,
|
2022-10-12 17:09:57 +00:00
|
|
|
monero!.getDefaultTransactionPriority().raw);
|
2020-01-08 16:38:38 +00:00
|
|
|
await sharedPreferences.setInt(
|
2023-07-27 14:30:07 +00:00
|
|
|
PreferencesKey.currentBalanceDisplayModeKey, BalanceDisplayMode.availableBalance.raw);
|
2020-01-20 19:04:26 +00:00
|
|
|
await sharedPreferences.setBool('save_recipient_address', true);
|
2020-01-08 16:38:38 +00:00
|
|
|
await resetToDefault(nodes);
|
2020-08-27 16:54:34 +00:00
|
|
|
await changeMoneroCurrentNodeToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
|
|
|
await changeBitcoinCurrentElectrumServerToDefault(
|
2020-01-08 16:38:38 +00:00
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
2021-05-07 07:36:38 +00:00
|
|
|
await changeLitecoinCurrentElectrumServerToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
2023-07-27 14:30:07 +00:00
|
|
|
await changeHavenCurrentNodeToDefault(sharedPreferences: sharedPreferences, nodes: nodes);
|
2023-10-12 22:50:16 +00:00
|
|
|
await changeBitcoinCashCurrentNodeToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
2020-01-08 16:38:38 +00:00
|
|
|
|
|
|
|
break;
|
|
|
|
case 2:
|
|
|
|
await replaceNodesMigration(nodes: nodes);
|
2023-07-27 14:30:07 +00:00
|
|
|
await replaceDefaultNode(sharedPreferences: sharedPreferences, nodes: nodes);
|
2020-01-08 16:38:38 +00:00
|
|
|
|
2020-07-06 20:09:03 +00:00
|
|
|
break;
|
|
|
|
case 3:
|
|
|
|
await updateNodeTypes(nodes: nodes);
|
|
|
|
await addBitcoinElectrumServerList(nodes: nodes);
|
2020-08-27 16:54:34 +00:00
|
|
|
|
|
|
|
break;
|
|
|
|
case 4:
|
|
|
|
await changeBitcoinCurrentElectrumServerToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
2020-01-08 16:38:38 +00:00
|
|
|
break;
|
2020-09-23 18:26:10 +00:00
|
|
|
|
2021-01-08 18:10:37 +00:00
|
|
|
case 5:
|
|
|
|
await addAddressesForMoneroWallets(walletInfoSource);
|
|
|
|
break;
|
2021-01-11 17:15:27 +00:00
|
|
|
|
|
|
|
case 6:
|
|
|
|
await updateDisplayModes(sharedPreferences);
|
|
|
|
break;
|
|
|
|
|
2021-01-15 17:41:30 +00:00
|
|
|
case 9:
|
|
|
|
await generateBackupPassword(secureStorage);
|
|
|
|
break;
|
2021-05-07 07:36:38 +00:00
|
|
|
|
2021-01-27 13:51:51 +00:00
|
|
|
case 10:
|
|
|
|
await changeTransactionPriorityAndFeeRateKeys(sharedPreferences);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 11:
|
|
|
|
await changeDefaultMoneroNode(nodes, sharedPreferences);
|
|
|
|
break;
|
2021-01-15 17:41:30 +00:00
|
|
|
|
2021-02-01 18:12:37 +00:00
|
|
|
case 12:
|
2023-08-16 21:09:29 +00:00
|
|
|
await checkCurrentNodes(nodes, powNodes, sharedPreferences);
|
2021-02-01 18:12:37 +00:00
|
|
|
break;
|
|
|
|
|
|
|
|
case 13:
|
2021-05-07 07:36:38 +00:00
|
|
|
await resetBitcoinElectrumServer(nodes, sharedPreferences);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case 15:
|
|
|
|
await addLitecoinElectrumServerList(nodes: nodes);
|
|
|
|
await changeLitecoinCurrentElectrumServerToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
2023-08-16 21:09:29 +00:00
|
|
|
await checkCurrentNodes(nodes, powNodes, sharedPreferences);
|
2021-02-01 18:12:37 +00:00
|
|
|
break;
|
|
|
|
|
2022-03-30 15:57:04 +00:00
|
|
|
case 16:
|
|
|
|
await addHavenNodeList(nodes: nodes);
|
2023-07-27 14:30:07 +00:00
|
|
|
await changeHavenCurrentNodeToDefault(sharedPreferences: sharedPreferences, nodes: nodes);
|
2023-08-16 21:09:29 +00:00
|
|
|
await checkCurrentNodes(nodes, powNodes, sharedPreferences);
|
2022-03-30 15:57:04 +00:00
|
|
|
break;
|
|
|
|
|
2022-05-18 16:13:58 +00:00
|
|
|
case 17:
|
|
|
|
await changeDefaultHavenNode(nodes);
|
|
|
|
break;
|
|
|
|
|
2022-11-29 23:37:56 +00:00
|
|
|
case 18:
|
|
|
|
await addOnionNode(nodes);
|
|
|
|
break;
|
|
|
|
|
2022-12-15 00:00:59 +00:00
|
|
|
case 19:
|
|
|
|
await validateBitcoinSavedTransactionPriority(sharedPreferences);
|
|
|
|
break;
|
2023-01-04 14:51:23 +00:00
|
|
|
case 20:
|
2023-03-01 21:44:15 +00:00
|
|
|
await migrateExchangeStatus(sharedPreferences);
|
|
|
|
break;
|
2023-03-08 10:04:38 +00:00
|
|
|
case 21:
|
2023-01-04 14:51:23 +00:00
|
|
|
await addEthereumNodeList(nodes: nodes);
|
|
|
|
await changeEthereumCurrentNodeToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
|
|
|
break;
|
2023-07-27 14:30:07 +00:00
|
|
|
case 22:
|
|
|
|
await addNanoNodeList(nodes: nodes);
|
2023-10-05 13:42:35 +00:00
|
|
|
await addNanoPowNodeList(nodes: powNodes);
|
2023-07-27 14:30:07 +00:00
|
|
|
await changeNanoCurrentNodeToDefault(sharedPreferences: sharedPreferences, nodes: nodes);
|
2023-08-16 21:09:29 +00:00
|
|
|
await changeNanoCurrentPowNodeToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: powNodes);
|
2023-07-27 14:30:07 +00:00
|
|
|
break;
|
2023-10-09 21:19:58 +00:00
|
|
|
case 23:
|
2023-10-12 22:50:16 +00:00
|
|
|
await addBitcoinCashElectrumServerList(nodes: nodes);
|
|
|
|
await changeBitcoinCurrentElectrumServerToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
|
|
|
break;
|
2023-10-16 13:51:18 +00:00
|
|
|
case 24:
|
2023-12-02 02:26:43 +00:00
|
|
|
await addPolygonNodeList(nodes: nodes);
|
|
|
|
await changePolygonCurrentNodeToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
|
|
|
break;
|
2023-11-30 21:39:09 +00:00
|
|
|
case 25:
|
|
|
|
await rewriteSecureStoragePin(secureStorage: secureStorage);
|
|
|
|
break;
|
2024-01-03 00:31:47 +00:00
|
|
|
case 26:
|
CW-555-Add-Solana-Wallet (#1272)
* chore: Create cw_solana package and clean up files
* feat: Add Solana Wallet - Create, Restore form seed, restore from Key, Restore from QR, Send, Receive, transaction history, spl tokens
* fix: Make transactions file specific to solana only for solana transactions
* chore: Revert inject app details script
* fix: Fix issue with node and switch current node to main beta instead of testnet
* fix: Fix merge conflicts and adjust migration version
* fix: Fetch spl token error
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
* fix: Diplay and activate spl tokens bug
* fix: Review and fixes
* fix: reverted formatting for cryptocurrency class
* fix: Review comments, split sending flow into signing and sending separately, fix issues
* fix: Revert throwing unimplenented error
* chore: Fix comment
* chore: Fix comment
* fix: Errors in flow
* Update provider_types.dart [skip ci]
* fix: Issues with solana wallet
* Update solana_wallet.dart [skip ci]
* fix: Review comments
* fix: Date time config
* fix: Revert bash script for app details
* fix: Error with balance, displaying fees, fixing sent or received identifier bug, displaying token symbol with token transaction item in transactions list
* fix: Issues with address validation when sending spl tokens and walletconnect initial setup
* fix: Issues with sending, fetching transactions history, almost wrapping up walletconnect
* fix: Adjust imports that would affect monerocom building successfully
* fix: Refine transaction direction and continue work on walletconnect
* feat: Display SPL token transfers in the transaction history and finally settle the transaction direction
* fix: Delay in transactions history dispaly, show native token transactions first, then process spl token transactions
* feat: Switch node and revert solana chain id to previous id
* fix: Remove print statement
* fix: Remove await for transactions, fetch all transaction histories instantly and adjust solana send success message
* chore: Code refactoring and streamlined wallet type check for solana send success message
* fix: Make timeout error for node silent and add spl token images
---------
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
2024-02-23 13:39:19 +00:00
|
|
|
|
|
|
|
/// commented out as it was a probable cause for some users to have white screen issues
|
|
|
|
/// maybe due to multiple access on Secure Storage at once
|
|
|
|
/// or long await time on start of the app
|
|
|
|
// await insecureStorageMigration(secureStorage: secureStorage, sharedPreferences: sharedPreferences);
|
|
|
|
case 27:
|
|
|
|
await addSolanaNodeList(nodes: nodes);
|
|
|
|
await changeSolanaCurrentNodeToDefault(
|
|
|
|
sharedPreferences: sharedPreferences, nodes: nodes);
|
2024-01-23 00:30:16 +00:00
|
|
|
break;
|
2024-03-18 15:45:11 +00:00
|
|
|
|
2024-03-14 18:26:00 +00:00
|
|
|
case 28:
|
|
|
|
await _updateMoneroPriority(sharedPreferences);
|
|
|
|
break;
|
2024-03-18 15:45:11 +00:00
|
|
|
|
|
|
|
case 29:
|
|
|
|
await changeDefaultBitcoinNode(nodes, sharedPreferences);
|
|
|
|
break;
|
|
|
|
|
2024-04-02 18:02:28 +00:00
|
|
|
case 30:
|
|
|
|
await disableServiceStatusFiatDisabled(sharedPreferences);
|
|
|
|
break;
|
|
|
|
|
2024-03-18 20:02:02 +00:00
|
|
|
case 31:
|
2024-04-12 12:36:42 +00:00
|
|
|
await updateNanoNodeList(nodes: nodes);
|
2023-10-09 21:19:58 +00:00
|
|
|
break;
|
2024-03-18 20:02:02 +00:00
|
|
|
|
2024-04-16 16:20:01 +00:00
|
|
|
case 32:
|
|
|
|
await updateBtcNanoWalletInfos(walletInfoSource);
|
|
|
|
|
2020-01-08 16:38:38 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
await sharedPreferences.setInt(
|
2022-11-29 23:37:56 +00:00
|
|
|
PreferencesKey.currentDefaultSettingsMigrationVersion, version);
|
2020-01-08 16:38:38 +00:00
|
|
|
} catch (e) {
|
|
|
|
print('Migration error: ${e.toString()}');
|
2020-01-04 19:31:52 +00:00
|
|
|
}
|
2020-01-08 16:38:38 +00:00
|
|
|
});
|
2020-01-04 19:31:52 +00:00
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentDefaultSettingsMigrationVersion, version);
|
2022-11-29 23:37:56 +00:00
|
|
|
}
|
|
|
|
|
2024-04-12 12:36:42 +00:00
|
|
|
Future<void> updateNanoNodeList({required Box<Node> nodes}) async {
|
|
|
|
final nodeList = await loadDefaultNanoNodes();
|
|
|
|
var listOfNewEndpoints = <String>[
|
|
|
|
"app.natrium.io",
|
|
|
|
"rainstorm.city",
|
|
|
|
"node.somenano.com",
|
|
|
|
"nanoslo.0x.no",
|
|
|
|
"www.bitrequest.app",
|
|
|
|
];
|
|
|
|
// add new nodes:
|
|
|
|
for (final node in nodeList) {
|
|
|
|
if (listOfNewEndpoints.contains(node.uriRaw)) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// update the nautilus node:
|
|
|
|
final nautilusNode =
|
|
|
|
nodes.values.firstWhereOrNull((element) => element.uriRaw == "node.perish.co");
|
|
|
|
if (nautilusNode != null) {
|
|
|
|
nautilusNode.uriRaw = "node.nautilus.io";
|
|
|
|
nautilusNode.path = "/api";
|
|
|
|
nautilusNode.useSSL = true;
|
|
|
|
await nautilusNode.save();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-04-02 18:02:28 +00:00
|
|
|
Future<void> disableServiceStatusFiatDisabled(SharedPreferences sharedPreferences) async {
|
2024-04-12 12:36:42 +00:00
|
|
|
final currentFiat = await sharedPreferences.getInt(PreferencesKey.currentFiatApiModeKey) ?? -1;
|
2024-04-02 18:02:28 +00:00
|
|
|
if (currentFiat == -1 || currentFiat == FiatApiMode.enabled.raw) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2024-04-05 16:11:47 +00:00
|
|
|
if (currentFiat == FiatApiMode.disabled.raw || currentFiat == FiatApiMode.torOnly.raw) {
|
2024-04-02 18:02:28 +00:00
|
|
|
await sharedPreferences.setBool(PreferencesKey.disableBulletinKey, true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-14 18:26:00 +00:00
|
|
|
Future<void> _updateMoneroPriority(SharedPreferences sharedPreferences) async {
|
|
|
|
final currentPriority =
|
|
|
|
await sharedPreferences.getInt(PreferencesKey.moneroTransactionPriority) ??
|
|
|
|
monero!.getDefaultTransactionPriority().serialize();
|
|
|
|
|
|
|
|
// was set to automatic but automatic should be 0
|
|
|
|
if (currentPriority == 1) {
|
|
|
|
sharedPreferences.setInt(PreferencesKey.moneroTransactionPriority,
|
|
|
|
monero!.getDefaultTransactionPriority().serialize()); // 0
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-30 15:11:56 +00:00
|
|
|
Future<void> _validateWalletInfoBoxData(Box<WalletInfo> walletInfoSource) async {
|
2023-11-03 19:24:45 +00:00
|
|
|
try {
|
|
|
|
final root = await getApplicationDocumentsDirectory();
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
for (var type in WalletType.values) {
|
|
|
|
if (type == WalletType.none) {
|
|
|
|
continue;
|
|
|
|
}
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
String prefix = walletTypeToString(type).toLowerCase();
|
|
|
|
Directory walletsDir = Directory('${root.path}/wallets/$prefix/');
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
if (!walletsDir.existsSync()) {
|
|
|
|
continue;
|
|
|
|
}
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
List<String> walletNames = walletsDir.listSync().map((e) => e.path.split("/").last).toList();
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
for (var name in walletNames) {
|
|
|
|
final Directory dir;
|
|
|
|
try {
|
|
|
|
dir = Directory(await pathForWalletDir(name: name, type: type));
|
|
|
|
} catch (_) {
|
|
|
|
continue;
|
|
|
|
}
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
final walletFiles = dir.listSync();
|
|
|
|
final hasCacheFile = walletFiles.any((element) => element.path.contains("$name/$name"));
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
if (!hasCacheFile) {
|
|
|
|
continue;
|
|
|
|
}
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
if (type == WalletType.monero || type == WalletType.haven) {
|
|
|
|
final hasKeysFile = walletFiles.any((element) => element.path.contains(".keys"));
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
if (!hasKeysFile) {
|
|
|
|
continue;
|
|
|
|
}
|
2023-08-30 15:11:56 +00:00
|
|
|
}
|
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
final id = prefix + '_' + name;
|
|
|
|
final exist = walletInfoSource.values.any((el) => el.id == id);
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
if (exist) {
|
|
|
|
continue;
|
|
|
|
}
|
2023-08-30 15:11:56 +00:00
|
|
|
|
2023-11-03 19:24:45 +00:00
|
|
|
final walletInfo = WalletInfo.external(
|
|
|
|
id: id,
|
|
|
|
type: type,
|
|
|
|
name: name,
|
|
|
|
isRecovery: true,
|
|
|
|
restoreHeight: 0,
|
|
|
|
date: DateTime.now(),
|
|
|
|
dirPath: dir.path,
|
|
|
|
path: '${dir.path}/$name',
|
|
|
|
address: '',
|
|
|
|
showIntroCakePayCard: false,
|
|
|
|
);
|
|
|
|
|
|
|
|
walletInfoSource.add(walletInfo);
|
|
|
|
}
|
2023-08-30 15:11:56 +00:00
|
|
|
}
|
2023-11-03 19:24:45 +00:00
|
|
|
} catch (_) {}
|
2023-08-30 15:11:56 +00:00
|
|
|
}
|
|
|
|
|
2022-12-15 00:00:59 +00:00
|
|
|
Future<void> validateBitcoinSavedTransactionPriority(SharedPreferences sharedPreferences) async {
|
2022-12-15 00:29:30 +00:00
|
|
|
if (bitcoin == null) {
|
|
|
|
return;
|
|
|
|
}
|
2022-12-15 00:05:00 +00:00
|
|
|
final int? savedBitcoinPriority =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.bitcoinTransactionPriority);
|
2022-12-15 00:29:30 +00:00
|
|
|
if (!bitcoin!.getTransactionPriorities().any((element) => element.raw == savedBitcoinPriority)) {
|
2023-07-27 14:30:07 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.bitcoinTransactionPriority,
|
|
|
|
bitcoin!.getMediumTransactionPriority().serialize());
|
2022-12-15 00:00:59 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-11-29 23:37:56 +00:00
|
|
|
Future<void> addOnionNode(Box<Node> nodes) async {
|
|
|
|
final onionNodeUri = "cakexmrl7bonq7ovjka5kuwuyd3f7qnkz6z6s6dmsy3uckwra7bvggyd.onion:18081";
|
|
|
|
|
2022-12-01 12:29:03 +00:00
|
|
|
// check if the user has this node before (added it manually)
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == onionNodeUri) == null) {
|
|
|
|
await nodes.add(Node(uri: onionNodeUri, type: WalletType.monero));
|
|
|
|
}
|
2020-01-04 19:31:52 +00:00
|
|
|
}
|
2020-01-08 16:38:38 +00:00
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Future<void> replaceNodesMigration({required Box<Node> nodes}) async {
|
2020-01-08 16:38:38 +00:00
|
|
|
final replaceNodes = <String, Node>{
|
|
|
|
'eu-node.cakewallet.io:18081':
|
2020-08-27 16:54:34 +00:00
|
|
|
Node(uri: 'xmr-node-eu.cakewallet.com:18081', type: WalletType.monero),
|
2023-07-27 14:30:07 +00:00
|
|
|
'node.cakewallet.io:18081':
|
|
|
|
Node(uri: 'xmr-node-usa-east.cakewallet.com:18081', type: WalletType.monero),
|
|
|
|
'node.xmr.ru:13666': Node(uri: 'node.monero.net:18081', type: WalletType.monero)
|
2020-01-08 16:38:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
nodes.values.forEach((Node node) async {
|
|
|
|
final nodeToReplace = replaceNodes[node.uri];
|
|
|
|
|
|
|
|
if (nodeToReplace != null) {
|
2021-05-10 16:00:20 +00:00
|
|
|
node.uriRaw = nodeToReplace.uriRaw;
|
2020-01-08 16:38:38 +00:00
|
|
|
node.login = nodeToReplace.login;
|
|
|
|
node.password = nodeToReplace.password;
|
|
|
|
await node.save();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-08-27 16:54:34 +00:00
|
|
|
Future<void> changeMoneroCurrentNodeToDefault(
|
2023-07-27 14:30:07 +00:00
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
2020-08-27 16:54:34 +00:00
|
|
|
final node = getMoneroDefaultNode(nodes: nodes);
|
2023-08-30 15:11:56 +00:00
|
|
|
final nodeId = node.key as int? ?? 0; // 0 - England
|
2020-08-27 16:54:34 +00:00
|
|
|
|
2022-11-29 23:37:56 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentNodeIdKey, nodeId);
|
2020-08-27 16:54:34 +00:00
|
|
|
}
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Node? getBitcoinDefaultElectrumServer({required Box<Node> nodes}) {
|
2023-07-27 14:30:07 +00:00
|
|
|
return nodes.values
|
|
|
|
.firstWhereOrNull((Node node) => node.uriRaw == cakeWalletBitcoinElectrumUri) ??
|
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.bitcoin);
|
2020-08-27 16:54:34 +00:00
|
|
|
}
|
|
|
|
|
Btc address types (#1263)
* inital migration changes
* feat: rest of changes
* minor fix [skip ci]
* fix: P2wshAddress & wallet address index
* fix: address review comments
* fix: address type restore
* feat: add testnet
* Fix review comments
Remove bitcoin_base from cw_core
* Fix address not matching selected type on start
* remove un-necessary parameter [skip ci]
* Remove bitcoin specific code from main lib
Fix possible runtime exception from list wrong access
* Minor fix
* fix: fixes for Testnet
* fix: bitcoin receive option dependency breaks monerocom
* Fix issues when building Monero.com
* feat: Transaction Builder changes
* fix: discover addresses, testnet restoring, duplicate unspent coins, and taproot address vs schnorr sig tweak
* fix: remove print
* feat: improve error when failed broadcast response
* feat: create fish shell env script
* fix: unmodifiable maps
* fix: build
* fix: build
* fix: computed observable side effect bug
* feat: add nix script for android build_all
* fix: wrong keypairs used for signing
* fix: wrong addresses when using fromScriptPubKey scripts
* fix(actual commit): testnet tx expanded + wrong addresses when using fromScriptPubKey scripts (update bitcoin_base deps)
* fix: self-send [skip ci]
* fix: p2wsh
* fix: testnet fees
* New versions
* Update macos build number
Minor UI fix
* fix: use new bitcoin_base ref, fix tx list wrong hex value & refactor hidden vs hd use
- if always use sideHd for isHidden, it is easier to simplify the functions instead of passing both which can be error prone
- (ps: now this could probably be changed, for example from isHidden to isChange since with address list we now see "hidden" addresses)
* Fix if condition to handle litecoin case
* fix: self-send, change address was always making direction incoming
* refactor: improve estimation function, add more inputs if balance missing
* fix: new bitcoin_base update, fixes script issues
* Update evm chain wallet service arguments
* Fix translation [skip ci]
* Fix translation [skip ci]
* Update strings_fr.arb [skip ci]
* fix: async isChange function not being awaited, refactor to reduce looping into a single place
* fix: _address vs address, missing p2sh
* fix: minor mistake in storing p2sh page type [skip ci]
* refactor: use already matched addresses property
* feat: improved perfomance for fetching transaction histories
* feat: continue perfomance change, improve address discovery only to last address by type with history
* fix: make sure transaction list is sorted by date
* refactor: isTestnet only for bitcoin
* fix: walletInfo type null case
* fix: deprecated p2pk
* refactor: make condition more readable
* refactor: remove unnecessary Str variant
* refactor: make condition more readable
* fix: infinite loop possible
* Revert removing isTestnet from other wallets [skip ci]
* refactor: rename addresses when matched by receive type
* Make the beta build [skip ci]
Remove app_env.fish
---------
Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
2024-02-23 16:13:30 +00:00
|
|
|
Node? getBitcoinTestnetDefaultElectrumServer({required Box<Node> nodes}) {
|
|
|
|
return nodes.values
|
|
|
|
.firstWhereOrNull((Node node) => node.uriRaw == publicBitcoinTestnetElectrumUri) ??
|
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.bitcoin);
|
|
|
|
}
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Node? getLitecoinDefaultElectrumServer({required Box<Node> nodes}) {
|
2023-07-27 14:30:07 +00:00
|
|
|
return nodes.values
|
|
|
|
.firstWhereOrNull((Node node) => node.uriRaw == cakeWalletLitecoinElectrumUri) ??
|
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.litecoin);
|
2021-05-07 07:36:38 +00:00
|
|
|
}
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Node? getHavenDefaultNode({required Box<Node> nodes}) {
|
2023-07-27 14:30:07 +00:00
|
|
|
return nodes.values.firstWhereOrNull((Node node) => node.uriRaw == havenDefaultNodeUri) ??
|
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.haven);
|
2022-03-30 15:57:04 +00:00
|
|
|
}
|
|
|
|
|
2023-01-04 14:51:23 +00:00
|
|
|
Node? getEthereumDefaultNode({required Box<Node> nodes}) {
|
2023-07-27 14:30:07 +00:00
|
|
|
return nodes.values.firstWhereOrNull((Node node) => node.uriRaw == ethereumDefaultNodeUri) ??
|
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.ethereum);
|
2023-01-04 14:51:23 +00:00
|
|
|
}
|
|
|
|
|
2023-12-02 02:26:43 +00:00
|
|
|
Node? getPolygonDefaultNode({required Box<Node> nodes}) {
|
|
|
|
return nodes.values.firstWhereOrNull((Node node) => node.uriRaw == polygonDefaultNodeUri) ??
|
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.polygon);
|
|
|
|
}
|
|
|
|
|
2023-07-26 17:15:22 +00:00
|
|
|
Node? getNanoDefaultNode({required Box<Node> nodes}) {
|
2023-07-27 14:30:07 +00:00
|
|
|
return nodes.values.firstWhereOrNull((Node node) => node.uriRaw == nanoDefaultNodeUri) ??
|
2023-08-16 17:23:53 +00:00
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.nano);
|
2023-07-26 17:15:22 +00:00
|
|
|
}
|
|
|
|
|
2023-09-07 15:34:22 +00:00
|
|
|
Node? getNanoDefaultPowNode({required Box<Node> nodes}) {
|
|
|
|
return nodes.values.firstWhereOrNull((Node node) => node.uriRaw == nanoDefaultPowNodeUri) ??
|
2023-08-18 13:27:09 +00:00
|
|
|
nodes.values.firstWhereOrNull((node) => (node.type == WalletType.nano));
|
2023-08-16 19:22:05 +00:00
|
|
|
}
|
|
|
|
|
2023-10-12 22:50:16 +00:00
|
|
|
Node? getBitcoinCashDefaultElectrumServer({required Box<Node> nodes}) {
|
2023-10-16 13:51:18 +00:00
|
|
|
return nodes.values
|
|
|
|
.firstWhereOrNull((Node node) => node.uriRaw == cakeWalletBitcoinCashDefaultNodeUri) ??
|
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.bitcoinCash);
|
2023-10-12 22:50:16 +00:00
|
|
|
}
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Node getMoneroDefaultNode({required Box<Node> nodes}) {
|
2020-01-08 16:38:38 +00:00
|
|
|
final timeZone = DateTime.now().timeZoneOffset.inHours;
|
2020-08-27 16:54:34 +00:00
|
|
|
var nodeUri = '';
|
2020-01-08 16:38:38 +00:00
|
|
|
|
2020-07-06 20:09:03 +00:00
|
|
|
if (timeZone >= 1) {
|
|
|
|
// Eurasia
|
2020-01-08 16:38:38 +00:00
|
|
|
nodeUri = 'xmr-node-eu.cakewallet.com:18081';
|
2020-07-06 20:09:03 +00:00
|
|
|
} else if (timeZone <= -4) {
|
|
|
|
// America
|
2020-01-08 16:38:38 +00:00
|
|
|
nodeUri = 'xmr-node-usa-east.cakewallet.com:18081';
|
|
|
|
}
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
try {
|
2023-07-27 14:30:07 +00:00
|
|
|
return nodes.values.firstWhere((Node node) => node.uriRaw == nodeUri);
|
|
|
|
} catch (_) {
|
2022-10-12 17:09:57 +00:00
|
|
|
return nodes.values.first;
|
|
|
|
}
|
2020-08-27 16:54:34 +00:00
|
|
|
}
|
2020-01-08 16:38:38 +00:00
|
|
|
|
CW-555-Add-Solana-Wallet (#1272)
* chore: Create cw_solana package and clean up files
* feat: Add Solana Wallet - Create, Restore form seed, restore from Key, Restore from QR, Send, Receive, transaction history, spl tokens
* fix: Make transactions file specific to solana only for solana transactions
* chore: Revert inject app details script
* fix: Fix issue with node and switch current node to main beta instead of testnet
* fix: Fix merge conflicts and adjust migration version
* fix: Fetch spl token error
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
* fix: Diplay and activate spl tokens bug
* fix: Review and fixes
* fix: reverted formatting for cryptocurrency class
* fix: Review comments, split sending flow into signing and sending separately, fix issues
* fix: Revert throwing unimplenented error
* chore: Fix comment
* chore: Fix comment
* fix: Errors in flow
* Update provider_types.dart [skip ci]
* fix: Issues with solana wallet
* Update solana_wallet.dart [skip ci]
* fix: Review comments
* fix: Date time config
* fix: Revert bash script for app details
* fix: Error with balance, displaying fees, fixing sent or received identifier bug, displaying token symbol with token transaction item in transactions list
* fix: Issues with address validation when sending spl tokens and walletconnect initial setup
* fix: Issues with sending, fetching transactions history, almost wrapping up walletconnect
* fix: Adjust imports that would affect monerocom building successfully
* fix: Refine transaction direction and continue work on walletconnect
* feat: Display SPL token transfers in the transaction history and finally settle the transaction direction
* fix: Delay in transactions history dispaly, show native token transactions first, then process spl token transactions
* feat: Switch node and revert solana chain id to previous id
* fix: Remove print statement
* fix: Remove await for transactions, fetch all transaction histories instantly and adjust solana send success message
* chore: Code refactoring and streamlined wallet type check for solana send success message
* fix: Make timeout error for node silent and add spl token images
---------
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
2024-02-23 13:39:19 +00:00
|
|
|
Node? getSolanaDefaultNode({required Box<Node> nodes}) {
|
|
|
|
return nodes.values.firstWhereOrNull((Node node) => node.uriRaw == solanaDefaultNodeUri) ??
|
|
|
|
nodes.values.firstWhereOrNull((node) => node.type == WalletType.solana);
|
|
|
|
}
|
|
|
|
|
2024-01-23 00:30:16 +00:00
|
|
|
Future<void> insecureStorageMigration({
|
|
|
|
required SharedPreferences sharedPreferences,
|
|
|
|
required FlutterSecureStorage secureStorage,
|
|
|
|
}) async {
|
|
|
|
bool? allowBiometricalAuthentication =
|
|
|
|
sharedPreferences.getBool(SecureKey.allowBiometricalAuthenticationKey);
|
|
|
|
bool? useTOTP2FA = sharedPreferences.getBool(SecureKey.useTOTP2FA);
|
|
|
|
bool? shouldRequireTOTP2FAForAccessingWallet =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForAccessingWallet);
|
|
|
|
bool? shouldRequireTOTP2FAForSendsToContact =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForSendsToContact);
|
|
|
|
bool? shouldRequireTOTP2FAForSendsToNonContact =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForSendsToNonContact);
|
|
|
|
bool? shouldRequireTOTP2FAForSendsToInternalWallets =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForSendsToInternalWallets);
|
|
|
|
bool? shouldRequireTOTP2FAForExchangesToInternalWallets =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForExchangesToInternalWallets);
|
|
|
|
bool? shouldRequireTOTP2FAForExchangesToExternalWallets =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForExchangesToExternalWallets);
|
|
|
|
bool? shouldRequireTOTP2FAForAddingContacts =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForAddingContacts);
|
|
|
|
bool? shouldRequireTOTP2FAForCreatingNewWallets =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForCreatingNewWallets);
|
|
|
|
bool? shouldRequireTOTP2FAForAllSecurityAndBackupSettings =
|
|
|
|
sharedPreferences.getBool(SecureKey.shouldRequireTOTP2FAForAllSecurityAndBackupSettings);
|
|
|
|
int? selectedCake2FAPreset = sharedPreferences.getInt(SecureKey.selectedCake2FAPreset);
|
|
|
|
String? totpSecretKey = sharedPreferences.getString(SecureKey.totpSecretKey);
|
|
|
|
int? pinTimeOutDuration = sharedPreferences.getInt(SecureKey.pinTimeOutDuration);
|
|
|
|
int? lastAuthTimeMilliseconds = sharedPreferences.getInt(SecureKey.lastAuthTimeMilliseconds);
|
|
|
|
|
|
|
|
try {
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.allowBiometricalAuthenticationKey,
|
|
|
|
value: allowBiometricalAuthentication.toString());
|
|
|
|
await secureStorage.write(key: SecureKey.useTOTP2FA, value: useTOTP2FA.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForAccessingWallet,
|
|
|
|
value: shouldRequireTOTP2FAForAccessingWallet.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForSendsToContact,
|
|
|
|
value: shouldRequireTOTP2FAForSendsToContact.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForSendsToNonContact,
|
|
|
|
value: shouldRequireTOTP2FAForSendsToNonContact.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForSendsToInternalWallets,
|
|
|
|
value: shouldRequireTOTP2FAForSendsToInternalWallets.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForExchangesToInternalWallets,
|
|
|
|
value: shouldRequireTOTP2FAForExchangesToInternalWallets.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForExchangesToExternalWallets,
|
|
|
|
value: shouldRequireTOTP2FAForExchangesToExternalWallets.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForAddingContacts,
|
|
|
|
value: shouldRequireTOTP2FAForAddingContacts.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForCreatingNewWallets,
|
|
|
|
value: shouldRequireTOTP2FAForCreatingNewWallets.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.shouldRequireTOTP2FAForAllSecurityAndBackupSettings,
|
|
|
|
value: shouldRequireTOTP2FAForAllSecurityAndBackupSettings.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.selectedCake2FAPreset, value: selectedCake2FAPreset.toString());
|
|
|
|
await secureStorage.write(key: SecureKey.totpSecretKey, value: totpSecretKey.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.pinTimeOutDuration, value: pinTimeOutDuration.toString());
|
|
|
|
await secureStorage.write(
|
|
|
|
key: SecureKey.lastAuthTimeMilliseconds, value: lastAuthTimeMilliseconds.toString());
|
|
|
|
} catch (e) {
|
|
|
|
print("Error migrating shared preferences to secure storage!: $e");
|
|
|
|
// this actually shouldn't be that big of a problem since we don't delete the old keys in this update
|
|
|
|
// and we read and write to the new locations when loading storage, the migration is just for extra safety
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-11-30 21:39:09 +00:00
|
|
|
Future<void> rewriteSecureStoragePin({required FlutterSecureStorage secureStorage}) async {
|
|
|
|
// the bug only affects ios/mac:
|
|
|
|
if (!Platform.isIOS && !Platform.isMacOS) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// first, get the encoded pin:
|
|
|
|
final keyForPinCode = generateStoreKeyFor(key: SecretStoreKey.pinCodePassword);
|
|
|
|
String? encodedPin;
|
|
|
|
try {
|
|
|
|
encodedPin = await secureStorage.read(key: keyForPinCode);
|
|
|
|
} catch (e) {
|
|
|
|
// either we don't have a pin, or we can't read it (maybe even because of the bug!)
|
|
|
|
// the only option here is to abort the migration or we risk losing the pin and locking the user out
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (encodedPin == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// ensure we overwrite by deleting the old key first:
|
|
|
|
await secureStorage.delete(key: keyForPinCode);
|
|
|
|
await secureStorage.write(
|
|
|
|
key: keyForPinCode,
|
|
|
|
value: encodedPin,
|
|
|
|
iOptions: IOSOptions(accessibility: KeychainAccessibility.first_unlock),
|
|
|
|
mOptions: MacOsOptions(accessibility: KeychainAccessibility.first_unlock),
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2020-08-27 16:54:34 +00:00
|
|
|
Future<void> changeBitcoinCurrentElectrumServerToDefault(
|
Btc address types (#1263)
* inital migration changes
* feat: rest of changes
* minor fix [skip ci]
* fix: P2wshAddress & wallet address index
* fix: address review comments
* fix: address type restore
* feat: add testnet
* Fix review comments
Remove bitcoin_base from cw_core
* Fix address not matching selected type on start
* remove un-necessary parameter [skip ci]
* Remove bitcoin specific code from main lib
Fix possible runtime exception from list wrong access
* Minor fix
* fix: fixes for Testnet
* fix: bitcoin receive option dependency breaks monerocom
* Fix issues when building Monero.com
* feat: Transaction Builder changes
* fix: discover addresses, testnet restoring, duplicate unspent coins, and taproot address vs schnorr sig tweak
* fix: remove print
* feat: improve error when failed broadcast response
* feat: create fish shell env script
* fix: unmodifiable maps
* fix: build
* fix: build
* fix: computed observable side effect bug
* feat: add nix script for android build_all
* fix: wrong keypairs used for signing
* fix: wrong addresses when using fromScriptPubKey scripts
* fix(actual commit): testnet tx expanded + wrong addresses when using fromScriptPubKey scripts (update bitcoin_base deps)
* fix: self-send [skip ci]
* fix: p2wsh
* fix: testnet fees
* New versions
* Update macos build number
Minor UI fix
* fix: use new bitcoin_base ref, fix tx list wrong hex value & refactor hidden vs hd use
- if always use sideHd for isHidden, it is easier to simplify the functions instead of passing both which can be error prone
- (ps: now this could probably be changed, for example from isHidden to isChange since with address list we now see "hidden" addresses)
* Fix if condition to handle litecoin case
* fix: self-send, change address was always making direction incoming
* refactor: improve estimation function, add more inputs if balance missing
* fix: new bitcoin_base update, fixes script issues
* Update evm chain wallet service arguments
* Fix translation [skip ci]
* Fix translation [skip ci]
* Update strings_fr.arb [skip ci]
* fix: async isChange function not being awaited, refactor to reduce looping into a single place
* fix: _address vs address, missing p2sh
* fix: minor mistake in storing p2sh page type [skip ci]
* refactor: use already matched addresses property
* feat: improved perfomance for fetching transaction histories
* feat: continue perfomance change, improve address discovery only to last address by type with history
* fix: make sure transaction list is sorted by date
* refactor: isTestnet only for bitcoin
* fix: walletInfo type null case
* fix: deprecated p2pk
* refactor: make condition more readable
* refactor: remove unnecessary Str variant
* refactor: make condition more readable
* fix: infinite loop possible
* Revert removing isTestnet from other wallets [skip ci]
* refactor: rename addresses when matched by receive type
* Make the beta build [skip ci]
Remove app_env.fish
---------
Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
2024-02-23 16:13:30 +00:00
|
|
|
{required SharedPreferences sharedPreferences,
|
|
|
|
required Box<Node> nodes,
|
|
|
|
bool? isTestnet}) async {
|
|
|
|
Node? server;
|
|
|
|
if (isTestnet == true) {
|
|
|
|
server = getBitcoinTestnetDefaultElectrumServer(nodes: nodes);
|
|
|
|
} else {
|
|
|
|
server = getBitcoinDefaultElectrumServer(nodes: nodes);
|
|
|
|
}
|
2023-08-30 15:11:56 +00:00
|
|
|
final serverId = server?.key as int? ?? 0;
|
2020-08-27 16:54:34 +00:00
|
|
|
|
2022-11-29 23:37:56 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentBitcoinElectrumSererIdKey, serverId);
|
2020-01-08 16:38:38 +00:00
|
|
|
}
|
|
|
|
|
2021-05-07 07:36:38 +00:00
|
|
|
Future<void> changeLitecoinCurrentElectrumServerToDefault(
|
2023-07-27 14:30:07 +00:00
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
2021-05-07 07:36:38 +00:00
|
|
|
final server = getLitecoinDefaultElectrumServer(nodes: nodes);
|
2023-08-30 15:11:56 +00:00
|
|
|
final serverId = server?.key as int? ?? 0;
|
2021-05-07 07:36:38 +00:00
|
|
|
|
2022-11-29 23:37:56 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentLitecoinElectrumSererIdKey, serverId);
|
2021-05-07 07:36:38 +00:00
|
|
|
}
|
|
|
|
|
2023-10-12 22:50:16 +00:00
|
|
|
Future<void> changeBitcoinCashCurrentNodeToDefault(
|
2023-10-16 13:51:18 +00:00
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
2023-10-12 22:50:16 +00:00
|
|
|
final server = getBitcoinCashDefaultElectrumServer(nodes: nodes);
|
2024-01-30 17:57:47 +00:00
|
|
|
final serverId = server?.key as int? ?? 0;
|
2023-10-12 22:50:16 +00:00
|
|
|
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentBitcoinCashNodeIdKey, serverId);
|
|
|
|
}
|
|
|
|
|
2022-03-30 15:57:04 +00:00
|
|
|
Future<void> changeHavenCurrentNodeToDefault(
|
2023-07-27 14:30:07 +00:00
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
2022-03-30 15:57:04 +00:00
|
|
|
final node = getHavenDefaultNode(nodes: nodes);
|
2023-08-30 15:11:56 +00:00
|
|
|
final nodeId = node?.key as int? ?? 0;
|
2022-03-30 15:57:04 +00:00
|
|
|
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentHavenNodeIdKey, nodeId);
|
|
|
|
}
|
|
|
|
|
2020-01-08 16:38:38 +00:00
|
|
|
Future<void> replaceDefaultNode(
|
2023-07-27 14:30:07 +00:00
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
2020-01-08 16:38:38 +00:00
|
|
|
const nodesForReplace = <String>[
|
|
|
|
'xmr-node-uk.cakewallet.com:18081',
|
|
|
|
'eu-node.cakewallet.io:18081',
|
|
|
|
'node.cakewallet.io:18081'
|
|
|
|
];
|
2022-11-29 23:37:56 +00:00
|
|
|
final currentNodeId = sharedPreferences.getInt(PreferencesKey.currentNodeIdKey);
|
2023-07-27 14:30:07 +00:00
|
|
|
final currentNode = nodes.values.firstWhereOrNull((Node node) => node.key == currentNodeId);
|
|
|
|
final needToReplace = currentNode == null ? true : nodesForReplace.contains(currentNode.uriRaw);
|
2020-01-08 16:38:38 +00:00
|
|
|
|
|
|
|
if (!needToReplace) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
await changeMoneroCurrentNodeToDefault(sharedPreferences: sharedPreferences, nodes: nodes);
|
2020-01-08 16:38:38 +00:00
|
|
|
}
|
2020-07-06 20:09:03 +00:00
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Future<void> updateNodeTypes({required Box<Node> nodes}) async {
|
2020-07-06 20:09:03 +00:00
|
|
|
nodes.values.forEach((node) async {
|
|
|
|
if (node.type == null) {
|
|
|
|
node.type = WalletType.monero;
|
|
|
|
await node.save();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Future<void> addBitcoinElectrumServerList({required Box<Node> nodes}) async {
|
2021-05-07 07:36:38 +00:00
|
|
|
final serverList = await loadBitcoinElectrumServerList();
|
2022-11-26 14:13:54 +00:00
|
|
|
for (var node in serverList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
2021-05-07 07:36:38 +00:00
|
|
|
}
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Future<void> addLitecoinElectrumServerList({required Box<Node> nodes}) async {
|
2021-05-07 07:36:38 +00:00
|
|
|
final serverList = await loadLitecoinElectrumServerList();
|
2022-11-26 14:13:54 +00:00
|
|
|
for (var node in serverList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
2020-07-06 20:09:03 +00:00
|
|
|
}
|
2021-01-08 18:10:37 +00:00
|
|
|
|
2023-10-12 22:50:16 +00:00
|
|
|
Future<void> addBitcoinCashElectrumServerList({required Box<Node> nodes}) async {
|
|
|
|
final serverList = await loadBitcoinCashElectrumServerList();
|
|
|
|
for (var node in serverList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-10-12 17:09:57 +00:00
|
|
|
Future<void> addHavenNodeList({required Box<Node> nodes}) async {
|
2022-03-30 15:57:04 +00:00
|
|
|
final nodeList = await loadDefaultHavenNodes();
|
2022-11-26 14:13:54 +00:00
|
|
|
for (var node in nodeList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
2022-03-30 15:57:04 +00:00
|
|
|
}
|
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
Future<void> addAddressesForMoneroWallets(Box<WalletInfo> walletInfoSource) async {
|
|
|
|
final moneroWalletsInfo = walletInfoSource.values.where((info) => info.type == WalletType.monero);
|
2021-01-08 18:10:37 +00:00
|
|
|
moneroWalletsInfo.forEach((info) async {
|
|
|
|
try {
|
2023-07-27 14:30:07 +00:00
|
|
|
final walletPath = await pathForWallet(name: info.name, type: WalletType.monero);
|
2021-01-08 18:10:37 +00:00
|
|
|
final addressFilePath = '$walletPath.address.txt';
|
|
|
|
final addressFile = File(addressFilePath);
|
|
|
|
|
|
|
|
if (!addressFile.existsSync()) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
final addressText = await addressFile.readAsString();
|
|
|
|
info.address = addressText;
|
|
|
|
await info.save();
|
|
|
|
} catch (e) {
|
|
|
|
print(e.toString());
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2021-01-11 17:15:27 +00:00
|
|
|
|
|
|
|
Future<void> updateDisplayModes(SharedPreferences sharedPreferences) async {
|
|
|
|
final currentBalanceDisplayMode =
|
2022-10-12 17:09:57 +00:00
|
|
|
sharedPreferences.getInt(PreferencesKey.currentBalanceDisplayModeKey) ?? -1;
|
2021-01-11 17:15:27 +00:00
|
|
|
final balanceDisplayMode = currentBalanceDisplayMode < 2 ? 3 : 2;
|
2023-07-27 14:30:07 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentBalanceDisplayModeKey, balanceDisplayMode);
|
2021-01-15 17:41:30 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> generateBackupPassword(FlutterSecureStorage secureStorage) async {
|
|
|
|
final key = generateStoreKeyFor(key: SecretStoreKey.backupPassword);
|
|
|
|
|
|
|
|
if ((await secureStorage.read(key: key))?.isNotEmpty ?? false) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
final password = encrypt.Key.fromSecureRandom(32).base16;
|
2023-11-27 13:28:34 +00:00
|
|
|
await secureStorage.delete(key: key);
|
2021-01-15 17:41:30 +00:00
|
|
|
await secureStorage.write(key: key, value: password);
|
2021-01-11 17:15:27 +00:00
|
|
|
}
|
2021-01-27 13:51:51 +00:00
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
Future<void> changeTransactionPriorityAndFeeRateKeys(SharedPreferences sharedPreferences) async {
|
|
|
|
final legacyTransactionPriority =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.currentTransactionPriorityKeyLegacy)!;
|
2021-01-27 13:51:51 +00:00
|
|
|
await sharedPreferences.setInt(
|
|
|
|
PreferencesKey.moneroTransactionPriority, legacyTransactionPriority);
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.bitcoinTransactionPriority,
|
2022-10-12 17:09:57 +00:00
|
|
|
bitcoin!.getMediumTransactionPriority().serialize());
|
2021-01-27 13:51:51 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> changeDefaultMoneroNode(
|
|
|
|
Box<Node> nodeSource, SharedPreferences sharedPreferences) async {
|
|
|
|
const cakeWalletMoneroNodeUriPattern = '.cakewallet.com';
|
2023-07-27 14:30:07 +00:00
|
|
|
final currentMoneroNodeId = sharedPreferences.getInt(PreferencesKey.currentNodeIdKey);
|
|
|
|
final currentMoneroNode = nodeSource.values.firstWhere((node) => node.key == currentMoneroNodeId);
|
2021-05-07 07:36:38 +00:00
|
|
|
final needToReplaceCurrentMoneroNode =
|
2021-05-10 16:00:20 +00:00
|
|
|
currentMoneroNode.uri.toString().contains(cakeWalletMoneroNodeUriPattern);
|
2021-01-27 13:51:51 +00:00
|
|
|
|
|
|
|
nodeSource.values.forEach((node) async {
|
2021-05-07 07:36:38 +00:00
|
|
|
if (node.type == WalletType.monero &&
|
2021-05-10 16:00:20 +00:00
|
|
|
node.uri.toString().contains(cakeWalletMoneroNodeUriPattern)) {
|
2021-01-27 13:51:51 +00:00
|
|
|
await node.delete();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
final newCakeWalletNode = Node(uri: newCakeWalletMoneroUri, type: WalletType.monero);
|
2021-01-27 13:51:51 +00:00
|
|
|
|
|
|
|
await nodeSource.add(newCakeWalletNode);
|
|
|
|
|
|
|
|
if (needToReplaceCurrentMoneroNode) {
|
2023-07-27 14:30:07 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentNodeIdKey, newCakeWalletNode.key as int);
|
2021-01-27 13:51:51 +00:00
|
|
|
}
|
|
|
|
}
|
2021-02-01 18:12:37 +00:00
|
|
|
|
2023-10-16 14:08:37 +00:00
|
|
|
Future<void> updateBtcNanoWalletInfos(Box<WalletInfo> walletsInfoSource) async {
|
|
|
|
for (WalletInfo walletInfo in walletsInfoSource.values) {
|
|
|
|
if (walletInfo.type == WalletType.nano || walletInfo.type == WalletType.bitcoin) {
|
|
|
|
walletInfo.derivationInfo = DerivationInfo(
|
|
|
|
derivationPath: walletInfo.derivationPath,
|
|
|
|
derivationType: walletInfo.derivationType,
|
|
|
|
address: walletInfo.address,
|
|
|
|
height: walletInfo.restoreHeight,
|
|
|
|
);
|
|
|
|
await walletInfo.save();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2024-03-18 15:45:11 +00:00
|
|
|
Future<void> changeDefaultBitcoinNode(
|
|
|
|
Box<Node> nodeSource, SharedPreferences sharedPreferences) async {
|
|
|
|
const cakeWalletBitcoinNodeUriPattern = '.cakewallet.com';
|
|
|
|
final currentBitcoinNodeId =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.currentBitcoinElectrumSererIdKey);
|
|
|
|
final currentBitcoinNode =
|
|
|
|
nodeSource.values.firstWhere((node) => node.key == currentBitcoinNodeId);
|
|
|
|
final needToReplaceCurrentBitcoinNode =
|
|
|
|
currentBitcoinNode.uri.toString().contains(cakeWalletBitcoinNodeUriPattern);
|
|
|
|
|
|
|
|
final newCakeWalletBitcoinNode = Node(uri: newCakeWalletBitcoinUri, type: WalletType.bitcoin);
|
|
|
|
|
|
|
|
await nodeSource.add(newCakeWalletBitcoinNode);
|
|
|
|
|
|
|
|
if (needToReplaceCurrentBitcoinNode) {
|
|
|
|
await sharedPreferences.setInt(
|
|
|
|
PreferencesKey.currentBitcoinElectrumSererIdKey, newCakeWalletBitcoinNode.key as int);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-08-18 13:27:09 +00:00
|
|
|
Future<void> checkCurrentNodes(
|
2023-09-07 15:34:22 +00:00
|
|
|
Box<Node> nodeSource, Box<Node> powNodeSource, SharedPreferences sharedPreferences) async {
|
2023-07-27 14:30:07 +00:00
|
|
|
final currentMoneroNodeId = sharedPreferences.getInt(PreferencesKey.currentNodeIdKey);
|
2021-05-07 07:36:38 +00:00
|
|
|
final currentBitcoinElectrumSeverId =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.currentBitcoinElectrumSererIdKey);
|
2023-07-27 14:30:07 +00:00
|
|
|
final currentLitecoinElectrumSeverId =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.currentLitecoinElectrumSererIdKey);
|
|
|
|
final currentHavenNodeId = sharedPreferences.getInt(PreferencesKey.currentHavenNodeIdKey);
|
|
|
|
final currentEthereumNodeId = sharedPreferences.getInt(PreferencesKey.currentEthereumNodeIdKey);
|
2023-12-02 02:26:43 +00:00
|
|
|
final currentPolygonNodeId = sharedPreferences.getInt(PreferencesKey.currentPolygonNodeIdKey);
|
2023-08-16 17:23:53 +00:00
|
|
|
final currentNanoNodeId = sharedPreferences.getInt(PreferencesKey.currentNanoNodeIdKey);
|
2023-08-16 19:22:05 +00:00
|
|
|
final currentNanoPowNodeId = sharedPreferences.getInt(PreferencesKey.currentNanoPowNodeIdKey);
|
2023-10-16 13:51:18 +00:00
|
|
|
final currentBitcoinCashNodeId =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.currentBitcoinCashNodeIdKey);
|
CW-555-Add-Solana-Wallet (#1272)
* chore: Create cw_solana package and clean up files
* feat: Add Solana Wallet - Create, Restore form seed, restore from Key, Restore from QR, Send, Receive, transaction history, spl tokens
* fix: Make transactions file specific to solana only for solana transactions
* chore: Revert inject app details script
* fix: Fix issue with node and switch current node to main beta instead of testnet
* fix: Fix merge conflicts and adjust migration version
* fix: Fetch spl token error
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
* fix: Diplay and activate spl tokens bug
* fix: Review and fixes
* fix: reverted formatting for cryptocurrency class
* fix: Review comments, split sending flow into signing and sending separately, fix issues
* fix: Revert throwing unimplenented error
* chore: Fix comment
* chore: Fix comment
* fix: Errors in flow
* Update provider_types.dart [skip ci]
* fix: Issues with solana wallet
* Update solana_wallet.dart [skip ci]
* fix: Review comments
* fix: Date time config
* fix: Revert bash script for app details
* fix: Error with balance, displaying fees, fixing sent or received identifier bug, displaying token symbol with token transaction item in transactions list
* fix: Issues with address validation when sending spl tokens and walletconnect initial setup
* fix: Issues with sending, fetching transactions history, almost wrapping up walletconnect
* fix: Adjust imports that would affect monerocom building successfully
* fix: Refine transaction direction and continue work on walletconnect
* feat: Display SPL token transfers in the transaction history and finally settle the transaction direction
* fix: Delay in transactions history dispaly, show native token transactions first, then process spl token transactions
* feat: Switch node and revert solana chain id to previous id
* fix: Remove print statement
* fix: Remove await for transactions, fetch all transaction histories instantly and adjust solana send success message
* chore: Code refactoring and streamlined wallet type check for solana send success message
* fix: Make timeout error for node silent and add spl token images
---------
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
2024-02-23 13:39:19 +00:00
|
|
|
final currentSolanaNodeId = sharedPreferences.getInt(PreferencesKey.currentSolanaNodeIdKey);
|
2023-07-27 14:30:07 +00:00
|
|
|
final currentMoneroNode =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentMoneroNodeId);
|
|
|
|
final currentBitcoinElectrumServer =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentBitcoinElectrumSeverId);
|
|
|
|
final currentLitecoinElectrumServer =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentLitecoinElectrumSeverId);
|
|
|
|
final currentHavenNodeServer =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentHavenNodeId);
|
|
|
|
final currentEthereumNodeServer =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentEthereumNodeId);
|
2023-12-02 02:26:43 +00:00
|
|
|
final currentPolygonNodeServer =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentPolygonNodeId);
|
2023-08-16 17:23:53 +00:00
|
|
|
final currentNanoNodeServer =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentNanoNodeId);
|
2023-08-16 19:22:05 +00:00
|
|
|
final currentNanoPowNodeServer =
|
2023-10-05 01:09:07 +00:00
|
|
|
powNodeSource.values.firstWhereOrNull((node) => node.key == currentNanoPowNodeId);
|
2023-10-16 13:51:18 +00:00
|
|
|
final currentBitcoinCashNodeServer =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentBitcoinCashNodeId);
|
CW-555-Add-Solana-Wallet (#1272)
* chore: Create cw_solana package and clean up files
* feat: Add Solana Wallet - Create, Restore form seed, restore from Key, Restore from QR, Send, Receive, transaction history, spl tokens
* fix: Make transactions file specific to solana only for solana transactions
* chore: Revert inject app details script
* fix: Fix issue with node and switch current node to main beta instead of testnet
* fix: Fix merge conflicts and adjust migration version
* fix: Fetch spl token error
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
* fix: Diplay and activate spl tokens bug
* fix: Review and fixes
* fix: reverted formatting for cryptocurrency class
* fix: Review comments, split sending flow into signing and sending separately, fix issues
* fix: Revert throwing unimplenented error
* chore: Fix comment
* chore: Fix comment
* fix: Errors in flow
* Update provider_types.dart [skip ci]
* fix: Issues with solana wallet
* Update solana_wallet.dart [skip ci]
* fix: Review comments
* fix: Date time config
* fix: Revert bash script for app details
* fix: Error with balance, displaying fees, fixing sent or received identifier bug, displaying token symbol with token transaction item in transactions list
* fix: Issues with address validation when sending spl tokens and walletconnect initial setup
* fix: Issues with sending, fetching transactions history, almost wrapping up walletconnect
* fix: Adjust imports that would affect monerocom building successfully
* fix: Refine transaction direction and continue work on walletconnect
* feat: Display SPL token transfers in the transaction history and finally settle the transaction direction
* fix: Delay in transactions history dispaly, show native token transactions first, then process spl token transactions
* feat: Switch node and revert solana chain id to previous id
* fix: Remove print statement
* fix: Remove await for transactions, fetch all transaction histories instantly and adjust solana send success message
* chore: Code refactoring and streamlined wallet type check for solana send success message
* fix: Make timeout error for node silent and add spl token images
---------
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
2024-02-23 13:39:19 +00:00
|
|
|
final currentSolanaNodeServer =
|
|
|
|
nodeSource.values.firstWhereOrNull((node) => node.key == currentSolanaNodeId);
|
2021-02-01 18:12:37 +00:00
|
|
|
if (currentMoneroNode == null) {
|
2023-07-27 14:30:07 +00:00
|
|
|
final newCakeWalletNode = Node(uri: newCakeWalletMoneroUri, type: WalletType.monero);
|
2021-02-01 18:12:37 +00:00
|
|
|
await nodeSource.add(newCakeWalletNode);
|
2023-07-27 14:30:07 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentNodeIdKey, newCakeWalletNode.key as int);
|
2021-02-01 18:12:37 +00:00
|
|
|
}
|
|
|
|
|
2021-05-07 07:36:38 +00:00
|
|
|
if (currentBitcoinElectrumServer == null) {
|
2023-07-27 14:30:07 +00:00
|
|
|
final cakeWalletElectrum = Node(uri: cakeWalletBitcoinElectrumUri, type: WalletType.bitcoin);
|
2021-02-01 18:12:37 +00:00
|
|
|
await nodeSource.add(cakeWalletElectrum);
|
2021-05-07 07:36:38 +00:00
|
|
|
await sharedPreferences.setInt(
|
2023-07-27 14:30:07 +00:00
|
|
|
PreferencesKey.currentBitcoinElectrumSererIdKey, cakeWalletElectrum.key as int);
|
2021-02-01 18:12:37 +00:00
|
|
|
}
|
|
|
|
|
2021-05-07 07:36:38 +00:00
|
|
|
if (currentLitecoinElectrumServer == null) {
|
2023-07-27 14:30:07 +00:00
|
|
|
final cakeWalletElectrum = Node(uri: cakeWalletLitecoinElectrumUri, type: WalletType.litecoin);
|
2021-05-07 07:36:38 +00:00
|
|
|
await nodeSource.add(cakeWalletElectrum);
|
|
|
|
await sharedPreferences.setInt(
|
2023-07-27 14:30:07 +00:00
|
|
|
PreferencesKey.currentLitecoinElectrumSererIdKey, cakeWalletElectrum.key as int);
|
2021-05-07 07:36:38 +00:00
|
|
|
}
|
2022-03-30 15:57:04 +00:00
|
|
|
|
|
|
|
if (currentHavenNodeServer == null) {
|
2022-10-19 22:21:16 +00:00
|
|
|
final node = Node(uri: havenDefaultNodeUri, type: WalletType.haven);
|
2022-03-30 15:57:04 +00:00
|
|
|
await nodeSource.add(node);
|
2023-07-27 14:30:07 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentHavenNodeIdKey, node.key as int);
|
2022-03-30 15:57:04 +00:00
|
|
|
}
|
2023-01-04 14:51:23 +00:00
|
|
|
|
|
|
|
if (currentEthereumNodeServer == null) {
|
|
|
|
final node = Node(uri: ethereumDefaultNodeUri, type: WalletType.ethereum);
|
|
|
|
await nodeSource.add(node);
|
2023-07-27 14:30:07 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentEthereumNodeIdKey, node.key as int);
|
2023-01-04 14:51:23 +00:00
|
|
|
}
|
2023-08-04 17:01:49 +00:00
|
|
|
|
2023-08-16 17:23:53 +00:00
|
|
|
if (currentNanoNodeServer == null) {
|
2023-10-05 01:09:07 +00:00
|
|
|
final node = Node(uri: nanoDefaultNodeUri, useSSL: true, type: WalletType.nano);
|
2023-08-04 17:01:49 +00:00
|
|
|
await nodeSource.add(node);
|
2023-08-16 19:22:05 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentNanoNodeIdKey, node.key as int);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (currentNanoPowNodeServer == null) {
|
2023-09-07 15:34:22 +00:00
|
|
|
Node? node = powNodeSource.values
|
2023-08-18 13:27:09 +00:00
|
|
|
.firstWhereOrNull((node) => node.uri.toString() == nanoDefaultPowNodeUri);
|
|
|
|
if (node == null) {
|
2023-10-05 01:09:07 +00:00
|
|
|
node = Node(uri: nanoDefaultPowNodeUri, useSSL: true, type: WalletType.nano);
|
2023-08-18 13:27:09 +00:00
|
|
|
await powNodeSource.add(node);
|
|
|
|
}
|
2023-08-16 19:22:05 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentNanoPowNodeIdKey, node.key as int);
|
2023-08-04 17:01:49 +00:00
|
|
|
}
|
2023-10-12 22:50:16 +00:00
|
|
|
|
|
|
|
if (currentBitcoinCashNodeServer == null) {
|
|
|
|
final node = Node(uri: cakeWalletBitcoinCashDefaultNodeUri, type: WalletType.bitcoinCash);
|
|
|
|
await nodeSource.add(node);
|
2023-10-16 13:51:18 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentBitcoinCashNodeIdKey, node.key as int);
|
2023-10-12 22:50:16 +00:00
|
|
|
}
|
2023-12-02 02:26:43 +00:00
|
|
|
|
|
|
|
if (currentPolygonNodeServer == null) {
|
|
|
|
final node = Node(uri: polygonDefaultNodeUri, type: WalletType.polygon);
|
|
|
|
await nodeSource.add(node);
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentPolygonNodeIdKey, node.key as int);
|
|
|
|
}
|
CW-555-Add-Solana-Wallet (#1272)
* chore: Create cw_solana package and clean up files
* feat: Add Solana Wallet - Create, Restore form seed, restore from Key, Restore from QR, Send, Receive, transaction history, spl tokens
* fix: Make transactions file specific to solana only for solana transactions
* chore: Revert inject app details script
* fix: Fix issue with node and switch current node to main beta instead of testnet
* fix: Fix merge conflicts and adjust migration version
* fix: Fetch spl token error
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
* fix: Diplay and activate spl tokens bug
* fix: Review and fixes
* fix: reverted formatting for cryptocurrency class
* fix: Review comments, split sending flow into signing and sending separately, fix issues
* fix: Revert throwing unimplenented error
* chore: Fix comment
* chore: Fix comment
* fix: Errors in flow
* Update provider_types.dart [skip ci]
* fix: Issues with solana wallet
* Update solana_wallet.dart [skip ci]
* fix: Review comments
* fix: Date time config
* fix: Revert bash script for app details
* fix: Error with balance, displaying fees, fixing sent or received identifier bug, displaying token symbol with token transaction item in transactions list
* fix: Issues with address validation when sending spl tokens and walletconnect initial setup
* fix: Issues with sending, fetching transactions history, almost wrapping up walletconnect
* fix: Adjust imports that would affect monerocom building successfully
* fix: Refine transaction direction and continue work on walletconnect
* feat: Display SPL token transfers in the transaction history and finally settle the transaction direction
* fix: Delay in transactions history dispaly, show native token transactions first, then process spl token transactions
* feat: Switch node and revert solana chain id to previous id
* fix: Remove print statement
* fix: Remove await for transactions, fetch all transaction histories instantly and adjust solana send success message
* chore: Code refactoring and streamlined wallet type check for solana send success message
* fix: Make timeout error for node silent and add spl token images
---------
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
2024-02-23 13:39:19 +00:00
|
|
|
|
|
|
|
if (currentSolanaNodeServer == null) {
|
|
|
|
final node = Node(uri: solanaDefaultNodeUri, type: WalletType.solana);
|
|
|
|
await nodeSource.add(node);
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentSolanaNodeIdKey, node.key as int);
|
|
|
|
}
|
2021-05-07 07:36:38 +00:00
|
|
|
}
|
2021-02-01 18:12:37 +00:00
|
|
|
|
2021-05-07 07:36:38 +00:00
|
|
|
Future<void> resetBitcoinElectrumServer(
|
|
|
|
Box<Node> nodeSource, SharedPreferences sharedPreferences) async {
|
|
|
|
final currentElectrumSeverId =
|
|
|
|
sharedPreferences.getInt(PreferencesKey.currentBitcoinElectrumSererIdKey);
|
2023-07-27 14:30:07 +00:00
|
|
|
final oldElectrumServer = nodeSource.values
|
|
|
|
.firstWhereOrNull((node) => node.uri.toString().contains('electrumx.cakewallet.com'));
|
|
|
|
var cakeWalletNode = nodeSource.values
|
|
|
|
.firstWhereOrNull((node) => node.uriRaw.toString() == cakeWalletBitcoinElectrumUri);
|
2021-02-01 18:12:37 +00:00
|
|
|
|
|
|
|
if (cakeWalletNode == null) {
|
2023-07-27 14:30:07 +00:00
|
|
|
cakeWalletNode = Node(uri: cakeWalletBitcoinElectrumUri, type: WalletType.bitcoin);
|
2021-02-01 18:12:37 +00:00
|
|
|
await nodeSource.add(cakeWalletNode);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (currentElectrumSeverId == oldElectrumServer?.key) {
|
2021-05-07 07:36:38 +00:00
|
|
|
await sharedPreferences.setInt(
|
2023-07-27 14:30:07 +00:00
|
|
|
PreferencesKey.currentBitcoinElectrumSererIdKey, cakeWalletNode.key as int);
|
2021-02-01 18:12:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
await oldElectrumServer?.delete();
|
|
|
|
}
|
2022-05-18 16:13:58 +00:00
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
Future<void> changeDefaultHavenNode(Box<Node> nodeSource) async {
|
2022-05-18 16:13:58 +00:00
|
|
|
const previousHavenDefaultNodeUri = 'vault.havenprotocol.org:443';
|
2023-07-27 14:30:07 +00:00
|
|
|
final havenNodes = nodeSource.values.where((node) => node.uriRaw == previousHavenDefaultNodeUri);
|
2022-05-18 16:13:58 +00:00
|
|
|
havenNodes.forEach((node) async {
|
|
|
|
node.uriRaw = havenDefaultNodeUri;
|
|
|
|
await node.save();
|
|
|
|
});
|
|
|
|
}
|
2023-01-04 14:51:23 +00:00
|
|
|
|
2023-03-01 21:44:15 +00:00
|
|
|
Future<void> migrateExchangeStatus(SharedPreferences sharedPreferences) async {
|
|
|
|
final isExchangeDisabled = sharedPreferences.getBool(PreferencesKey.disableExchangeKey);
|
|
|
|
if (isExchangeDisabled == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2023-08-16 19:22:05 +00:00
|
|
|
await sharedPreferences.setInt(PreferencesKey.exchangeStatusKey,
|
|
|
|
isExchangeDisabled ? ExchangeApiMode.disabled.raw : ExchangeApiMode.enabled.raw);
|
2023-03-08 10:04:38 +00:00
|
|
|
|
2023-03-01 21:46:05 +00:00
|
|
|
await sharedPreferences.remove(PreferencesKey.disableExchangeKey);
|
2023-03-01 21:44:15 +00:00
|
|
|
}
|
2023-03-08 10:04:38 +00:00
|
|
|
|
2023-01-04 14:51:23 +00:00
|
|
|
Future<void> addEthereumNodeList({required Box<Node> nodes}) async {
|
|
|
|
final nodeList = await loadDefaultEthereumNodes();
|
|
|
|
for (var node in nodeList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> changeEthereumCurrentNodeToDefault(
|
2023-08-16 19:22:05 +00:00
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
2023-01-04 14:51:23 +00:00
|
|
|
final node = getEthereumDefaultNode(nodes: nodes);
|
|
|
|
final nodeId = node?.key as int? ?? 0;
|
|
|
|
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentEthereumNodeIdKey, nodeId);
|
|
|
|
}
|
2023-07-27 14:30:07 +00:00
|
|
|
|
|
|
|
Future<void> addNanoNodeList({required Box<Node> nodes}) async {
|
|
|
|
final nodeList = await loadDefaultNanoNodes();
|
|
|
|
for (var node in nodeList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-10-05 01:09:07 +00:00
|
|
|
Future<void> addNanoPowNodeList({required Box<Node> nodes}) async {
|
|
|
|
final nodeList = await loadDefaultNanoPowNodes();
|
|
|
|
for (var node in nodeList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-07-27 14:30:07 +00:00
|
|
|
Future<void> changeNanoCurrentNodeToDefault(
|
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
|
|
|
final node = getNanoDefaultNode(nodes: nodes);
|
|
|
|
final nodeId = node?.key as int? ?? 0;
|
|
|
|
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentNanoNodeIdKey, nodeId);
|
|
|
|
}
|
2023-08-16 19:38:28 +00:00
|
|
|
|
|
|
|
Future<void> changeNanoCurrentPowNodeToDefault(
|
2023-09-07 15:34:22 +00:00
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
2023-08-16 19:38:28 +00:00
|
|
|
final node = getNanoDefaultPowNode(nodes: nodes);
|
|
|
|
final nodeId = node?.key as int? ?? 0;
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentNanoPowNodeIdKey, nodeId);
|
|
|
|
}
|
2023-12-02 02:26:43 +00:00
|
|
|
|
|
|
|
Future<void> addPolygonNodeList({required Box<Node> nodes}) async {
|
|
|
|
final nodeList = await loadDefaultPolygonNodes();
|
|
|
|
for (var node in nodeList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> changePolygonCurrentNodeToDefault(
|
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
|
|
|
final node = getPolygonDefaultNode(nodes: nodes);
|
|
|
|
final nodeId = node?.key as int? ?? 0;
|
|
|
|
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentPolygonNodeIdKey, nodeId);
|
|
|
|
}
|
CW-555-Add-Solana-Wallet (#1272)
* chore: Create cw_solana package and clean up files
* feat: Add Solana Wallet - Create, Restore form seed, restore from Key, Restore from QR, Send, Receive, transaction history, spl tokens
* fix: Make transactions file specific to solana only for solana transactions
* chore: Revert inject app details script
* fix: Fix issue with node and switch current node to main beta instead of testnet
* fix: Fix merge conflicts and adjust migration version
* fix: Fetch spl token error
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
* fix: Diplay and activate spl tokens bug
* fix: Review and fixes
* fix: reverted formatting for cryptocurrency class
* fix: Review comments, split sending flow into signing and sending separately, fix issues
* fix: Revert throwing unimplenented error
* chore: Fix comment
* chore: Fix comment
* fix: Errors in flow
* Update provider_types.dart [skip ci]
* fix: Issues with solana wallet
* Update solana_wallet.dart [skip ci]
* fix: Review comments
* fix: Date time config
* fix: Revert bash script for app details
* fix: Error with balance, displaying fees, fixing sent or received identifier bug, displaying token symbol with token transaction item in transactions list
* fix: Issues with address validation when sending spl tokens and walletconnect initial setup
* fix: Issues with sending, fetching transactions history, almost wrapping up walletconnect
* fix: Adjust imports that would affect monerocom building successfully
* fix: Refine transaction direction and continue work on walletconnect
* feat: Display SPL token transfers in the transaction history and finally settle the transaction direction
* fix: Delay in transactions history dispaly, show native token transactions first, then process spl token transactions
* feat: Switch node and revert solana chain id to previous id
* fix: Remove print statement
* fix: Remove await for transactions, fetch all transaction histories instantly and adjust solana send success message
* chore: Code refactoring and streamlined wallet type check for solana send success message
* fix: Make timeout error for node silent and add spl token images
---------
Signed-off-by: Blazebrain <davidadegoke16@gmail.com>
Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
2024-02-23 13:39:19 +00:00
|
|
|
|
|
|
|
Future<void> addSolanaNodeList({required Box<Node> nodes}) async {
|
|
|
|
final nodeList = await loadDefaultSolanaNodes();
|
|
|
|
for (var node in nodeList) {
|
|
|
|
if (nodes.values.firstWhereOrNull((element) => element.uriRaw == node.uriRaw) == null) {
|
|
|
|
await nodes.add(node);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Future<void> changeSolanaCurrentNodeToDefault(
|
|
|
|
{required SharedPreferences sharedPreferences, required Box<Node> nodes}) async {
|
|
|
|
final node = getSolanaDefaultNode(nodes: nodes);
|
|
|
|
final nodeId = node?.key as int? ?? 0;
|
|
|
|
|
|
|
|
await sharedPreferences.setInt(PreferencesKey.currentSolanaNodeIdKey, nodeId);
|
|
|
|
}
|