mirror of
https://github.com/passepartoutvpn/wireguard-apple.git
synced 2025-01-18 06:19:04 +00:00
VPN: Support adding multiple configurations in one shot
Signed-off-by: Roopesh Chander <roop@roopc.net>
This commit is contained in:
parent
9f5612f93f
commit
439f8f5a15
@ -97,6 +97,27 @@ class TunnelsManager {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func addMultiple(tunnelConfigurations: [TunnelConfiguration], completionHandler: @escaping (Int, Error?) -> Void) {
|
||||||
|
addMultiple(tunnelConfigurations: tunnelConfigurations[0...], completionHandler: completionHandler)
|
||||||
|
}
|
||||||
|
|
||||||
|
private func addMultiple(tunnelConfigurations: ArraySlice<TunnelConfiguration>, completionHandler: @escaping (Int, Error?) -> Void) {
|
||||||
|
assert(!tunnelConfigurations.isEmpty)
|
||||||
|
let head = tunnelConfigurations.first!
|
||||||
|
let tail = tunnelConfigurations[1 ..< tunnelConfigurations.count]
|
||||||
|
self.add(tunnelConfiguration: head) { [weak self] (tunnel, error) in
|
||||||
|
if (error != nil) {
|
||||||
|
completionHandler(tail.count, error)
|
||||||
|
} else if (tail.isEmpty) {
|
||||||
|
completionHandler(0, nil)
|
||||||
|
} else {
|
||||||
|
DispatchQueue.main.async {
|
||||||
|
self?.addMultiple(tunnelConfigurations: tail, completionHandler: completionHandler)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
func modify(tunnel: TunnelContainer, with tunnelConfiguration: TunnelConfiguration, completionHandler: @escaping (Error?) -> Void) {
|
func modify(tunnel: TunnelContainer, with tunnelConfiguration: TunnelConfiguration, completionHandler: @escaping (Error?) -> Void) {
|
||||||
let tunnelName = tunnelConfiguration.interface.name
|
let tunnelName = tunnelConfiguration.interface.name
|
||||||
assert(!tunnelName.isEmpty)
|
assert(!tunnelName.isEmpty)
|
||||||
|
Loading…
Reference in New Issue
Block a user