Skip to content

Commit

Permalink
Fix brave/brave-ios#8267: rpc url in custom network cannot be updated (
Browse files Browse the repository at this point in the history
  • Loading branch information
nuo-xu authored Nov 17, 2023
1 parent 6300254 commit 65137ed
Show file tree
Hide file tree
Showing 3 changed files with 52 additions and 53 deletions.
84 changes: 35 additions & 49 deletions Sources/BraveWallet/Crypto/Stores/NetworkStore.swift
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down
18 changes: 15 additions & 3 deletions Sources/BraveWallet/Preview Content/MockStores.swift
Original file line number Diff line number Diff line change
Expand Up @@ -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",
Expand All @@ -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
}
}
Expand Down
3 changes: 2 additions & 1 deletion Sources/BraveWallet/Settings/CustomNetworkDetailsView.swift
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down

0 comments on commit 65137ed

Please sign in to comment.