TunnelsManager: get rid of name set

Instead, tunnels itself should be a sorted-set. For now it's a list,
which is probably fine though.
This commit is contained in:
Jason A. Donenfeld 2018-11-03 03:53:08 +01:00
parent 2fdbe1c492
commit aa5634ee27

View File

@ -31,30 +31,26 @@ enum TunnelManagementError: Error {
class TunnelsManager { class TunnelsManager {
var tunnels: [TunnelContainer] private var tunnels: [TunnelContainer]
weak var delegate: TunnelsManagerDelegate? = nil weak var delegate: TunnelsManagerDelegate? = nil
private var isAddingTunnel: Bool = false private var isAddingTunnel: Bool = false
private var isModifyingTunnel: Bool = false private var isModifyingTunnel: Bool = false
private var isDeletingTunnel: Bool = false private var isDeletingTunnel: Bool = false
private var tunnelNames: Set<String>
private var currentTunnel: TunnelContainer? private var currentTunnel: TunnelContainer?
private var currentTunnelStatusObservationToken: AnyObject? private var currentTunnelStatusObservationToken: AnyObject?
init(tunnelProviders: [NETunnelProviderManager]) { init(tunnelProviders: [NETunnelProviderManager]) {
var tunnelNames: Set<String> = []
var tunnels = tunnelProviders.map { TunnelContainer(tunnel: $0) } var tunnels = tunnelProviders.map { TunnelContainer(tunnel: $0) }
tunnels.sort { $0.name < $1.name } tunnels.sort { $0.name < $1.name }
var currentTunnel: TunnelContainer? = nil var currentTunnel: TunnelContainer? = nil
for tunnel in tunnels { for tunnel in tunnels {
tunnelNames.insert(tunnel.name)
if (tunnel.status != .inactive) { if (tunnel.status != .inactive) {
currentTunnel = tunnel currentTunnel = tunnel
} }
} }
self.tunnels = tunnels self.tunnels = tunnels
self.tunnelNames = tunnelNames
if let currentTunnel = currentTunnel { if let currentTunnel = currentTunnel {
setCurrentTunnel(tunnel: currentTunnel) setCurrentTunnel(tunnel: currentTunnel)
} }
@ -70,10 +66,6 @@ class TunnelsManager {
} }
} }
func containsTunnel(named name: String) -> Bool {
return tunnelNames.contains(name)
}
func add(tunnelConfiguration: TunnelConfiguration, completionHandler: @escaping (TunnelContainer?, TunnelManagementError?) -> Void) { func add(tunnelConfiguration: TunnelConfiguration, completionHandler: @escaping (TunnelContainer?, TunnelManagementError?) -> Void) {
let tunnelName = tunnelConfiguration.interface.name let tunnelName = tunnelConfiguration.interface.name
if tunnelName.isEmpty { if tunnelName.isEmpty {
@ -81,7 +73,7 @@ class TunnelsManager {
return return
} }
guard (!containsTunnel(named: tunnelName)) else { if self.tunnels.contains(where: { $0.name == tunnelName }) {
completionHandler(nil, TunnelManagementError.tunnelAlreadyExistsWithThatName) completionHandler(nil, TunnelManagementError.tunnelAlreadyExistsWithThatName)
return return
} }
@ -103,7 +95,6 @@ class TunnelsManager {
let tunnel = TunnelContainer(tunnel: tunnelProviderManager) let tunnel = TunnelContainer(tunnel: tunnelProviderManager)
s.tunnels.append(tunnel) s.tunnels.append(tunnel)
s.tunnels.sort { $0.name < $1.name } s.tunnels.sort { $0.name < $1.name }
s.tunnelNames.insert(tunnel.name)
s.delegate?.tunnelAdded(at: s.tunnels.firstIndex(of: tunnel)!) s.delegate?.tunnelAdded(at: s.tunnels.firstIndex(of: tunnel)!)
completionHandler(tunnel, nil) completionHandler(tunnel, nil)
} }
@ -141,7 +132,7 @@ class TunnelsManager {
let isNameChanged = (tunnelName != tunnelProviderManager.localizedDescription) let isNameChanged = (tunnelName != tunnelProviderManager.localizedDescription)
var oldName: String? = nil var oldName: String? = nil
if (isNameChanged) { if (isNameChanged) {
guard (!containsTunnel(named: tunnelName)) else { if self.tunnels.contains(where: { $0.name == tunnelName }) {
completionHandler(TunnelManagementError.tunnelAlreadyExistsWithThatName) completionHandler(TunnelManagementError.tunnelAlreadyExistsWithThatName)
return return
} }
@ -162,8 +153,6 @@ class TunnelsManager {
if let s = self { if let s = self {
if (isNameChanged) { if (isNameChanged) {
let oldIndex = s.tunnels.firstIndex(of: tunnel)! let oldIndex = s.tunnels.firstIndex(of: tunnel)!
s.tunnelNames.remove(oldName!)
s.tunnelNames.insert(tunnel.name)
s.tunnels.sort { $0.name < $1.name } s.tunnels.sort { $0.name < $1.name }
let newIndex = s.tunnels.firstIndex(of: tunnel)! let newIndex = s.tunnels.firstIndex(of: tunnel)!
s.delegate?.tunnelMoved(at: oldIndex, to: newIndex) s.delegate?.tunnelMoved(at: oldIndex, to: newIndex)
@ -195,7 +184,6 @@ class TunnelsManager {
if let s = self { if let s = self {
let index = s.tunnels.firstIndex(of: tunnel)! let index = s.tunnels.firstIndex(of: tunnel)!
s.tunnels.remove(at: index) s.tunnels.remove(at: index)
s.tunnelNames.remove(tunnel.name)
s.delegate?.tunnelRemoved(at: index) s.delegate?.tunnelRemoved(at: index)
} }
completionHandler(nil) completionHandler(nil)