From e08a70e437b212f00787dfe43d211167b7d82130 Mon Sep 17 00:00:00 2001 From: Alfreedom <00tango.bromine@icloud.com> Date: Wed, 5 Jun 2024 12:10:48 +0200 Subject: [PATCH] refactor switch network logic --- CHANGELOG.md | 4 ++ example/android/gradle.properties | 4 +- example/ios/Runner.xcodeproj/project.pbxproj | 12 ++--- example/ios/Runner/Info.plist | 4 +- example/lib/home_page.dart | 14 +++--- example/pubspec.lock | 2 +- example/pubspec.yaml | 2 +- lib/pages/connet_network_page.dart | 51 +++++--------------- lib/pages/select_network_page.dart | 10 ++-- lib/services/w3m_service/i_w3m_service.dart | 4 +- lib/services/w3m_service/w3m_service.dart | 34 +++++++------ lib/utils/w3m_chains_presets.dart | 7 ++- lib/version.dart | 2 +- pubspec.yaml | 2 +- test/mock_classes.mocks.dart | 14 +++--- 15 files changed, 77 insertions(+), 89 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 93a7371e..b3af0266 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,7 @@ +## 3.2.2 + +- Network change improvements + ## 3.2.1 - Email Wallet improvements: diff --git a/example/android/gradle.properties b/example/android/gradle.properties index 1402382c..9c491cd5 100644 --- a/example/android/gradle.properties +++ b/example/android/gradle.properties @@ -1,5 +1,5 @@ org.gradle.jvmargs=-Xmx1536M android.useAndroidX=true android.enableJetifier=true -versionName=3.2.1 -versionCode=59 +versionName=3.2.2 +versionCode=61 diff --git a/example/ios/Runner.xcodeproj/project.pbxproj b/example/ios/Runner.xcodeproj/project.pbxproj index 2e28c337..71a9021d 100644 --- a/example/ios/Runner.xcodeproj/project.pbxproj +++ b/example/ios/Runner.xcodeproj/project.pbxproj @@ -470,7 +470,7 @@ CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements; CODE_SIGN_STYLE = Manual; - CURRENT_PROJECT_VERSION = 59; + CURRENT_PROJECT_VERSION = 61; DEVELOPMENT_TEAM = ""; "DEVELOPMENT_TEAM[sdk=iphoneos*]" = W5R8AG9K22; ENABLE_BITCODE = NO; @@ -496,7 +496,7 @@ buildSettings = { BUNDLE_LOADER = "$(TEST_HOST)"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 59; + CURRENT_PROJECT_VERSION = 61; GENERATE_INFOPLIST_FILE = YES; MARKETING_VERSION = 1.0; PRODUCT_BUNDLE_IDENTIFIER = com.web3modal.flutterExample.RunnerTests; @@ -514,7 +514,7 @@ buildSettings = { BUNDLE_LOADER = "$(TEST_HOST)"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 59; + CURRENT_PROJECT_VERSION = 61; GENERATE_INFOPLIST_FILE = YES; MARKETING_VERSION = 1.0; PRODUCT_BUNDLE_IDENTIFIER = com.web3modal.flutterExample.RunnerTests; @@ -530,7 +530,7 @@ buildSettings = { BUNDLE_LOADER = "$(TEST_HOST)"; CODE_SIGN_STYLE = Automatic; - CURRENT_PROJECT_VERSION = 59; + CURRENT_PROJECT_VERSION = 61; GENERATE_INFOPLIST_FILE = YES; MARKETING_VERSION = 1.0; PRODUCT_BUNDLE_IDENTIFIER = com.web3modal.flutterExample.RunnerTests; @@ -655,7 +655,7 @@ CLANG_ENABLE_MODULES = YES; CODE_SIGN_ENTITLEMENTS = Runner/Runner.entitlements; CODE_SIGN_STYLE = Manual; - CURRENT_PROJECT_VERSION = 59; + CURRENT_PROJECT_VERSION = 61; DEVELOPMENT_TEAM = ""; "DEVELOPMENT_TEAM[sdk=iphoneos*]" = W5R8AG9K22; ENABLE_BITCODE = NO; @@ -686,7 +686,7 @@ CODE_SIGN_IDENTITY = "Apple Development"; "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Distribution"; CODE_SIGN_STYLE = Manual; - CURRENT_PROJECT_VERSION = 59; + CURRENT_PROJECT_VERSION = 61; DEVELOPMENT_TEAM = ""; "DEVELOPMENT_TEAM[sdk=iphoneos*]" = W5R8AG9K22; ENABLE_BITCODE = NO; diff --git a/example/ios/Runner/Info.plist b/example/ios/Runner/Info.plist index 7aa9cdcc..a0ec3ffc 100644 --- a/example/ios/Runner/Info.plist +++ b/example/ios/Runner/Info.plist @@ -19,7 +19,7 @@ CFBundlePackageType APPL CFBundleShortVersionString - 3.2.1 + 3.2.2 CFBundleSignature ???? CFBundleURLTypes @@ -36,7 +36,7 @@ CFBundleVersion - 59 + 61 ITSAppUsesNonExemptEncryption LSApplicationQueriesSchemes diff --git a/example/lib/home_page.dart b/example/lib/home_page.dart index d1ed4b0f..9c768ec9 100644 --- a/example/lib/home_page.dart +++ b/example/lib/home_page.dart @@ -171,13 +171,13 @@ class _MyHomePageState extends State { ElevatedButton( onPressed: () async { _w3mService.launchConnectedWallet(); - _w3mService.requestAddChain(polygon).then( - (value) { - final success = value == true; - debugPrint('[ExampleApp] then success $success'); - Navigator.of(context).pop(); - }, - ); + try { + await _w3mService.requestSwitchToChain(polygon); + } catch (e) { + debugPrint('[ExampleApp] requestSwitchToChain $e'); + } + // ignore: use_build_context_synchronously + Navigator.of(context).pop(); }, child: const Text('Switch'), ), diff --git a/example/pubspec.lock b/example/pubspec.lock index 46e1fba1..7946a7b8 100644 --- a/example/pubspec.lock +++ b/example/pubspec.lock @@ -1139,7 +1139,7 @@ packages: path: ".." relative: true source: path - version: "3.2.1" + version: "3.2.2" web_socket_channel: dependency: transitive description: diff --git a/example/pubspec.yaml b/example/pubspec.yaml index 04d81ddb..99e1c1a9 100644 --- a/example/pubspec.yaml +++ b/example/pubspec.yaml @@ -3,7 +3,7 @@ description: A dApp showing how to use WalletConnect v2 with Flutter publish_to: "none" -version: 3.2.1 +version: 3.2.2 environment: sdk: ">=3.0.1 <4.0.0" diff --git a/lib/pages/connet_network_page.dart b/lib/pages/connet_network_page.dart index b4f1fc38..3681cc56 100644 --- a/lib/pages/connet_network_page.dart +++ b/lib/pages/connet_network_page.dart @@ -39,22 +39,25 @@ class _ConnectNetworkPageState extends State WidgetsBinding.instance.addPostFrameCallback((_) { _service = Web3ModalProvider.of(context).service; _service?.onModalError.subscribe(_errorListener); - _service!.web3App!.onSessionEvent.subscribe(_onSessionEvent); - _service!.web3App!.core.relayClient.onRelayClientMessage.subscribe( - _onRelayClientMessage, - ); setState(() {}); - Future.delayed(const Duration(milliseconds: 300), () { - _connect(); - }); + Future.delayed(const Duration(milliseconds: 300), () => _connect()); }); } - void _connect() { + void _connect() async { errorEvent = null; _service!.launchConnectedWallet(); - _service!.requestSwitchToChain(widget.chainInfo); - setState(() {}); + try { + await _service!.requestSwitchToChain(widget.chainInfo); + final chainId = widget.chainInfo.chainId; + if (W3MChainPresets.chains.containsKey(chainId)) { + Future.delayed(const Duration(milliseconds: 300), () { + widgetStack.instance.pop(); + }); + } + } catch (e) { + setState(() {}); + } } @override @@ -68,38 +71,10 @@ class _ConnectNetworkPageState extends State } } - void _onSessionEvent(SessionEvent? event) async { - if (!mounted) return; - if (event?.name == EventsConstants.chainChanged) { - debugPrint('[$runtimeType] _onSessionEvent $event'); - final chainId = event?.data.toString() ?? ''; - if (W3MChainPresets.chains.containsKey(chainId)) { - _service?.web3App?.onSessionEvent.unsubscribe(_onSessionEvent); - widgetStack.instance.pop(); - } - } - } - - void _onRelayClientMessage(MessageEvent? event) async { - if (!mounted) return; - if (event != null) { - final payloadString = await _service!.web3App!.core.crypto.decode( - event.topic, - event.message, - ); - if (payloadString == null) return; - debugPrint('[$runtimeType] payloadString $payloadString'); - } - } - void _errorListener(ModalError? event) => setState(() => errorEvent = event); @override void dispose() { - _service?.web3App?.core.relayClient.onRelayClientMessage.unsubscribe( - _onRelayClientMessage, - ); - _service?.web3App?.onSessionEvent.unsubscribe(_onSessionEvent); _service?.onModalError.unsubscribe(_errorListener); WidgetsBinding.instance.removeObserver(this); super.dispose(); diff --git a/lib/pages/select_network_page.dart b/lib/pages/select_network_page.dart index 82794db0..aaf797a8 100644 --- a/lib/pages/select_network_page.dart +++ b/lib/pages/select_network_page.dart @@ -22,17 +22,15 @@ class SelectNetworkPage extends StatelessWidget { final Function(W3MChainInfo)? onTapNetwork; - void _onSelectNetwork(BuildContext context, W3MChainInfo chainInfo) { + void _onSelectNetwork(BuildContext context, W3MChainInfo chainInfo) async { final service = Web3ModalProvider.of(context).service; if (service.isConnected) { final approvedChains = service.session!.getApprovedChains() ?? []; - final hasChainAlready = approvedChains.contains( - chainInfo.namespace, - ); + final isChainApproved = approvedChains.contains(chainInfo.namespace); if (chainInfo.chainId == service.selectedChain?.chainId) { widgetStack.instance.pop(); - } else if (hasChainAlready || service.session!.sessionService.isMagic) { - service.selectChain(chainInfo, switchChain: true); + } else if (isChainApproved || service.session!.sessionService.isMagic) { + await service.selectChain(chainInfo, switchChain: true); widgetStack.instance.pop(); } else { widgetStack.instance.push(ConnectNetworkPage(chainInfo: chainInfo)); diff --git a/lib/services/w3m_service/i_w3m_service.dart b/lib/services/w3m_service/i_w3m_service.dart index a73d4183..2e50c068 100644 --- a/lib/services/w3m_service/i_w3m_service.dart +++ b/lib/services/w3m_service/i_w3m_service.dart @@ -131,8 +131,8 @@ abstract class IW3MService with ChangeNotifier { required SessionRequestParams request, }); - Future requestSwitchToChain(W3MChainInfo newChain); - Future requestAddChain(W3MChainInfo newChain); + Future requestSwitchToChain(W3MChainInfo newChain); + Future requestAddChain(W3MChainInfo newChain); /// Closes the modal. void closeModal(); diff --git a/lib/services/w3m_service/w3m_service.dart b/lib/services/w3m_service/w3m_service.dart index 045b232f..e8747a87 100644 --- a/lib/services/w3m_service/w3m_service.dart +++ b/lib/services/w3m_service/w3m_service.dart @@ -1108,15 +1108,16 @@ class W3MService with ChangeNotifier, CoinbaseService implements IW3MService { } @override - Future requestSwitchToChain(W3MChainInfo newChain) async { + Future requestSwitchToChain(W3MChainInfo newChain) async { if (_currentSession?.sessionService.isMagic == true) { - return selectChain(newChain); + await selectChain(newChain); + return; } final currentChainId = _currentSelectedChain!.namespace; final newChainId = newChain.namespace; _logger.i('[$runtimeType] requesting switch to chain $newChainId'); try { - final response = await request( + await request( topic: _currentSession?.topic ?? '', chainId: currentChainId, switchToChainId: newChainId, @@ -1129,29 +1130,32 @@ class W3MService with ChangeNotifier, CoinbaseService implements IW3MService { ); _currentSelectedChain = newChain; await _setSesionAndChainData(_currentSession!); - return response ?? true; + return; } catch (e) { - _logger.i('[$runtimeType] requesting switchChain error $e'); + _logger.i('[$runtimeType] requestSwitchToChain error $e'); // if request errors due to user rejection then set the previous chain if (_isUserRejectedError(e)) { - loggerService.instance.i('[$runtimeType] User declined connection'); await _setLocalEthChain(_currentSelectedChain!); - return null; + throw JsonRpcError(code: 5002, message: 'User rejected methods.'); } else { - // Otherwise it meas chain has to be added. - return await requestAddChain(newChain); + try { + // Otherwise it meas chain has to be added. + return await requestAddChain(newChain); + } catch (e) { + rethrow; + } } } } @override - Future requestAddChain(W3MChainInfo newChain) async { + Future requestAddChain(W3MChainInfo newChain) async { final topic = _currentSession?.topic ?? ''; final currentChainId = _currentSelectedChain!.namespace; final newChainId = newChain.namespace; - _logger.i('[$runtimeType] requesting switch to chain $newChainId'); + _logger.i('[$runtimeType] requesting switch to add chain $newChainId'); try { - final response = await request( + await request( topic: topic, chainId: currentChainId, switchToChainId: newChainId, @@ -1162,11 +1166,11 @@ class W3MService with ChangeNotifier, CoinbaseService implements IW3MService { ); _currentSelectedChain = newChain; await _setSesionAndChainData(_currentSession!); - return response ?? true; + return; } catch (e) { - _logger.i('[$runtimeType] requesting addChain error $e'); + _logger.i('[$runtimeType] requestAddChain error $e'); await _setLocalEthChain(_currentSelectedChain!); - return null; + throw JsonRpcError(code: 5002, message: 'User rejected methods.'); } } diff --git a/lib/utils/w3m_chains_presets.dart b/lib/utils/w3m_chains_presets.dart index eaacc9d3..bd114bd8 100644 --- a/lib/utils/w3m_chains_presets.dart +++ b/lib/utils/w3m_chains_presets.dart @@ -33,7 +33,12 @@ class W3MChainPresets { chainId: '137', chainIcon: chainImagesId['137'], tokenName: 'MATIC', - rpcUrl: 'https://rpc-mainnet.maticvigil.com', + rpcUrl: 'https://polygon-bor-rpc.publicnode.com', + extraRpcUrls: [ + 'https://polygon.drpc.org', + 'https://1rpc.io/matic', + 'https://endpoints.omniatech.io/v1/matic/mainnet/public', + ], blockExplorer: W3MBlockExplorer( name: 'Explorer', url: 'https://polygonscan.com', diff --git a/lib/version.dart b/lib/version.dart index e11e1d06..cf4332e2 100644 --- a/lib/version.dart +++ b/lib/version.dart @@ -1,2 +1,2 @@ // Generated code. Do not modify. -const packageVersion = '3.2.1'; +const packageVersion = '3.2.2'; diff --git a/pubspec.yaml b/pubspec.yaml index 0fceec7d..d1a0da9d 100644 --- a/pubspec.yaml +++ b/pubspec.yaml @@ -1,6 +1,6 @@ name: web3modal_flutter description: "WalletConnect Web3Modal: Simple, intuitive wallet login. With this drop-in UI SDK, enable any wallet's users to seamlessly log in to your app and enjoy a unified experience" -version: 3.2.1 +version: 3.2.2 repository: https://github.com/WalletConnect/Web3ModalFlutter environment: diff --git a/test/mock_classes.mocks.dart b/test/mock_classes.mocks.dart index 9bfece6d..1b473d2e 100644 --- a/test/mock_classes.mocks.dart +++ b/test/mock_classes.mocks.dart @@ -870,23 +870,25 @@ class MockW3MService extends _i1.Mock implements _i3.W3MService { returnValueForMissingStub: _i14.Future.value(), ) as _i14.Future); @override - _i14.Future requestSwitchToChain(_i3.W3MChainInfo? newChain) => + _i14.Future requestSwitchToChain(_i3.W3MChainInfo? newChain) => (super.noSuchMethod( Invocation.method( #requestSwitchToChain, [newChain], ), - returnValue: _i14.Future.value(), - ) as _i14.Future); + returnValue: _i14.Future.value(), + returnValueForMissingStub: _i14.Future.value(), + ) as _i14.Future); @override - _i14.Future requestAddChain(_i3.W3MChainInfo? newChain) => + _i14.Future requestAddChain(_i3.W3MChainInfo? newChain) => (super.noSuchMethod( Invocation.method( #requestAddChain, [newChain], ), - returnValue: _i14.Future.value(), - ) as _i14.Future); + returnValue: _i14.Future.value(), + returnValueForMissingStub: _i14.Future.value(), + ) as _i14.Future); @override void addListener(_i17.VoidCallback? listener) => super.noSuchMethod( Invocation.method(