From 1f21595ab92703277d9f8f4b9c416368725bff3c Mon Sep 17 00:00:00 2001 From: Nuo Xu Date: Fri, 17 Nov 2023 10:18:48 -0800 Subject: [PATCH] Fix #8267: rpc url in custom network cannot be updated (#8437) --- .../Crypto/Stores/NetworkStore.swift | 84 ++++++++----------- .../Preview Content/MockStores.swift | 18 +++- .../Settings/CustomNetworkDetailsView.swift | 3 +- 3 files changed, 52 insertions(+), 53 deletions(-) diff --git a/Sources/BraveWallet/Crypto/Stores/NetworkStore.swift b/Sources/BraveWallet/Crypto/Stores/NetworkStore.swift index 4a9d8c05604..9e43747ba90 100644 --- a/Sources/BraveWallet/Crypto/Stores/NetworkStore.swift +++ b/Sources/BraveWallet/Crypto/Stores/NetworkStore.swift @@ -250,66 +250,52 @@ public class NetworkStore: ObservableObject, WalletObserverStore { // MARK: - Custom Networks @Published var isAddingNewNetwork: Bool = false - - public func addCustomNetwork( - _ network: BraveWallet.NetworkInfo, - completion: @escaping (_ accepted: Bool, _ errMsg: String) -> Void - ) { - func add(network: BraveWallet.NetworkInfo, completion: @escaping (_ accepted: Bool, _ errMsg: String) -> Void) { - rpcService.addChain(network) { [self] chainId, status, message in - if status == .success { - // Update `ethereumChains` by api calling - Task { - await updateChainList() + + @MainActor func addCustomNetwork(_ network: BraveWallet.NetworkInfo) async -> (accepted: Bool, errMsg: String) { + isAddingNewNetwork = true + if allChains.filter({ $0.coin == .eth }).contains(where: { $0.id.lowercased() == network.id.lowercased() }) { + let removeStatus = await rpcService.removeChain(network.chainId, coin: network.coin) + guard removeStatus else { + return (false, "Not able to remove network chainId (\(network.chainId)") + } + // delete local stored user assets that in this custom network + assetManager.removeGroup(for: network.walletUserAssetGroupId, completion: nil) + + let (_, addStatus, errMsg) = await rpcService.addChain(network) + guard addStatus == .success else { + // if adding is not succeeded, we have to add back the old network info + if let oldNetwork = allChains.filter({ $0.coin == .eth }).first(where: { $0.id.lowercased() == network.id.lowercased() }) { + let (_, addOldStatus, _) = await rpcService.addChain(oldNetwork) + guard addOldStatus == .success else { + isAddingNewNetwork = false + return (false, errMsg) } customNetworkNativeAssetMigration(network) isAddingNewNetwork = false - completion(true, "") + await updateChainList() + return (false, errMsg) } else { - // meaning add custom network failed for some reason. - // Also add the the old network back on rpc service - if let oldNetwork = allChains.filter({ $0.coin == .eth }).first(where: { $0.id.lowercased() == network.id.lowercased() }) { - rpcService.addChain(oldNetwork) { _, _, _ in - Task { - await self.updateChainList() - } - self.customNetworkNativeAssetMigration(network) - self.isAddingNewNetwork = false - completion(false, message) - } - } else { - isAddingNewNetwork = false - completion(false, message) - } - } - } - } - - isAddingNewNetwork = true - if allChains.filter({ $0.coin == .eth }).contains(where: { $0.id.lowercased() == network.id.lowercased() }) { - removeNetworkForNewAddition(network) { [self] success in - guard success else { isAddingNewNetwork = false - completion(false, Strings.Wallet.failedToRemoveCustomNetworkErrorMessage) - return + return (false, errMsg) } - add(network: network, completion: completion) } + customNetworkNativeAssetMigration(network) + isAddingNewNetwork = false + await updateChainList() + return (true, "") } else { - add(network: network, completion: completion) + let (_, addStatus, errMsg) = await rpcService.addChain(network) + guard addStatus == .success else { + isAddingNewNetwork = false + return (false, errMsg) + } + customNetworkNativeAssetMigration(network) + isAddingNewNetwork = false + await updateChainList() + return (true, "") } } - /// This method will not update `ethereumChains` - private func removeNetworkForNewAddition( - _ network: BraveWallet.NetworkInfo, - completion: @escaping (_ success: Bool) -> Void - ) { - rpcService.removeChain(network.id, coin: network.coin, completion: completion) - // delete local stored user assets that in this custom network - assetManager.removeGroup(for: network.walletUserAssetGroupId, completion: nil) - } - public func removeCustomNetwork( _ network: BraveWallet.NetworkInfo, completion: @escaping (_ success: Bool) -> Void diff --git a/Sources/BraveWallet/Preview Content/MockStores.swift b/Sources/BraveWallet/Preview Content/MockStores.swift index 4f87ffe86c8..4130fbda62e 100644 --- a/Sources/BraveWallet/Preview Content/MockStores.swift +++ b/Sources/BraveWallet/Preview Content/MockStores.swift @@ -56,8 +56,12 @@ extension NetworkStore { } static var previewStoreWithCustomNetworkAdded: NetworkStore { - let store = NetworkStore.previewStore - store.addCustomNetwork( + let keyringService = MockKeyringService() + let rpcService = MockJsonRpcService() + let walletService = MockBraveWalletService() + let swapService = MockSwapService() + let userAssetManager = TestableWalletUserAssetManager() + rpcService.addChain( .init( chainId: "0x100", chainName: "MockChain", @@ -72,7 +76,15 @@ extension NetworkStore { supportedKeyrings: [BraveWallet.KeyringId.default.rawValue].map(NSNumber.init(value:)), isEip1559: false ) - ) { _, _ in } + ) { _, _, _ in } + + let store = NetworkStore( + keyringService: keyringService, + rpcService: rpcService, + walletService: walletService, + swapService: swapService, + userAssetManager: userAssetManager + ) return store } } diff --git a/Sources/BraveWallet/Settings/CustomNetworkDetailsView.swift b/Sources/BraveWallet/Settings/CustomNetworkDetailsView.swift index 43a88a31c41..6896fefaff5 100644 --- a/Sources/BraveWallet/Settings/CustomNetworkDetailsView.swift +++ b/Sources/BraveWallet/Settings/CustomNetworkDetailsView.swift @@ -529,7 +529,8 @@ struct CustomNetworkDetailsView: View { supportedKeyrings: [BraveWallet.KeyringId.default.rawValue].map(NSNumber.init(value:)), isEip1559: false ) - networkStore.addCustomNetwork(network) { accepted, errMsg in + Task { @MainActor in + let (accepted, errMsg) = await networkStore.addCustomNetwork(network) guard accepted else { customNetworkError = .failed(errorMessage: errMsg) return