breez fixes

This commit is contained in:
Matthew Fosse 2024-05-23 12:20:22 -07:00
parent 9459b74f94
commit 362c0bd231
10 changed files with 20 additions and 14 deletions

View file

@ -831,7 +831,7 @@ abstract class ElectrumWalletBase
Future<void> rescan({required int height}) async => throw UnimplementedError(); Future<void> rescan({required int height}) async => throw UnimplementedError();
@override @override
Future<void> close() async { Future<void> close({bool? switchingToSameWalletType}) async {
try { try {
await electrumClient.close(); await electrumClient.close();
} catch (_) {} } catch (_) {}

View file

@ -80,7 +80,7 @@ abstract class WalletBase<BalanceType extends Balance, HistoryType extends Trans
Future<void> rescan({required int height}); Future<void> rescan({required int height});
void close(); void close({bool? switchingToSameWalletType});
Future<void> changePassword(String password); Future<void> changePassword(String password);

View file

@ -177,7 +177,7 @@ abstract class EVMChainWalletBase
} }
@override @override
void close() { void close({bool? switchingToSameWalletType}) {
_client.stop(); _client.stop();
_transactionsUpdateTimer?.cancel(); _transactionsUpdateTimer?.cancel();
} }

View file

@ -233,11 +233,13 @@ abstract class LightningWalletBase extends ElectrumWallet with Store {
print("initialized breez: ${(await sdk.isInitialized())}"); print("initialized breez: ${(await sdk.isInitialized())}");
} }
Future<void> stopBreez() async { Future<void> stopBreez(bool disconnect) async {
if (disconnect) {
final sdk = await BreezSDK(); final sdk = await BreezSDK();
if (await sdk.isInitialized()) { if (await sdk.isInitialized()) {
await sdk.disconnect(); await sdk.disconnect();
} }
}
await _nodeStateSub?.cancel(); await _nodeStateSub?.cancel();
await _paymentsSub?.cancel(); await _paymentsSub?.cancel();
} }
@ -363,12 +365,13 @@ abstract class LightningWalletBase extends ElectrumWallet with Store {
Future<String> makePath() async => pathForWallet(name: walletInfo.name, type: walletInfo.type); Future<String> makePath() async => pathForWallet(name: walletInfo.name, type: walletInfo.type);
@override @override
Future<void> close() async { Future<void> close({bool? switchingToSameWalletType}) async {
try { try {
await electrumClient.close(); await electrumClient.close();
} catch (_) {} } catch (_) {}
try { try {
await stopBreez(); bool shouldDisconnect = switchingToSameWalletType == null || !switchingToSameWalletType;
await stopBreez(shouldDisconnect);
} catch (e, s) { } catch (e, s) {
print("Error stopping breez: $e\n$s"); print("Error stopping breez: $e\n$s");
} }

View file

@ -142,7 +142,7 @@ abstract class MoneroWalletBase
Future<void>? updateBalance() => null; Future<void>? updateBalance() => null;
@override @override
void close() { void close({bool? switchingToSameWalletType}) {
_listener?.stop(); _listener?.stop();
_onAccountChangeReaction?.reaction.dispose(); _onAccountChangeReaction?.reaction.dispose();
_autoSaveTimer?.cancel(); _autoSaveTimer?.cancel();

View file

@ -138,7 +138,7 @@ abstract class NanoWalletBase
} }
@override @override
void close() { void close({bool? switchingToSameWalletType}) {
_client.stop(); _client.stop();
_receiveTimer?.cancel(); _receiveTimer?.cancel();
} }

View file

@ -165,7 +165,7 @@ abstract class SolanaWalletBase
Future<void> changePassword(String password) => throw UnimplementedError("changePassword"); Future<void> changePassword(String password) => throw UnimplementedError("changePassword");
@override @override
void close() { void close({bool? switchingToSameWalletType}) {
_client.stop(); _client.stop();
_transactionsUpdateTimer?.cancel(); _transactionsUpdateTimer?.cancel();
} }

View file

@ -186,7 +186,7 @@ abstract class TronWalletBase
} }
@override @override
void close() { void close({bool? switchingToSameWalletType}) {
_transactionsUpdateTimer?.cancel(); _transactionsUpdateTimer?.cancel();
} }

View file

@ -80,6 +80,7 @@ class WalletCreationService {
case WalletType.solana: case WalletType.solana:
case WalletType.tron: case WalletType.tron:
return true; return true;
case WalletType.lightning:
case WalletType.monero: case WalletType.monero:
case WalletType.none: case WalletType.none:
case WalletType.bitcoin: case WalletType.bitcoin:

View file

@ -3,6 +3,7 @@ import 'package:cake_wallet/di.dart';
import 'package:cake_wallet/reactions/wallet_connect.dart'; import 'package:cake_wallet/reactions/wallet_connect.dart';
import 'package:cake_wallet/utils/exception_handler.dart'; import 'package:cake_wallet/utils/exception_handler.dart';
import 'package:cw_core/transaction_info.dart'; import 'package:cw_core/transaction_info.dart';
import 'package:cw_core/wallet_type.dart';
import 'package:mobx/mobx.dart'; import 'package:mobx/mobx.dart';
import 'package:cw_core/balance.dart'; import 'package:cw_core/balance.dart';
import 'package:cw_core/wallet_base.dart'; import 'package:cw_core/wallet_base.dart';
@ -37,7 +38,8 @@ abstract class AppStoreBase with Store {
@action @action
Future<void> changeCurrentWallet( Future<void> changeCurrentWallet(
WalletBase<Balance, TransactionHistoryBase<TransactionInfo>, TransactionInfo> wallet) async { WalletBase<Balance, TransactionHistoryBase<TransactionInfo>, TransactionInfo> wallet) async {
this.wallet?.close(); bool switchingToSameWalletType = this.wallet?.type == wallet.type;
this.wallet?.close(switchingToSameWalletType: switchingToSameWalletType);
this.wallet = wallet; this.wallet = wallet;
this.wallet!.setExceptionHandler(ExceptionHandler.onError); this.wallet!.setExceptionHandler(ExceptionHandler.onError);