Zip importing: importFromFile should take a completionHandler
Deletion of the being-imported file should be done in the completionHandler. Signed-off-by: Roopesh Chander <roop@roopc.net>
This commit is contained in:
parent
7ef12d93a7
commit
af78fa9a1c
|
@ -27,8 +27,9 @@ class AppDelegate: UIResponder, UIApplicationDelegate {
|
||||||
}
|
}
|
||||||
|
|
||||||
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) -> Bool {
|
func application(_ app: UIApplication, open url: URL, options: [UIApplication.OpenURLOptionsKey: Any] = [:]) -> Bool {
|
||||||
mainVC?.tunnelsListVC?.importFromFile(url: url)
|
mainVC?.tunnelsListVC?.importFromFile(url: url) {
|
||||||
_ = FileManager.deleteFile(at: url)
|
_ = FileManager.deleteFile(at: url)
|
||||||
|
}
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -165,7 +165,7 @@ class TunnelsListTableViewController: UIViewController {
|
||||||
self.present(scanQRCodeNC, animated: true)
|
self.present(scanQRCodeNC, animated: true)
|
||||||
}
|
}
|
||||||
|
|
||||||
func importFromFile(url: URL) {
|
func importFromFile(url: URL, completionHandler: (() -> Void)?) {
|
||||||
guard let tunnelsManager = tunnelsManager else { return }
|
guard let tunnelsManager = tunnelsManager else { return }
|
||||||
if (url.pathExtension == "zip") {
|
if (url.pathExtension == "zip") {
|
||||||
ZipImporter.importConfigFiles(from: url) { [weak self] result in
|
ZipImporter.importConfigFiles(from: url) { [weak self] result in
|
||||||
|
@ -176,11 +176,12 @@ class TunnelsListTableViewController: UIViewController {
|
||||||
let configs: [TunnelConfiguration?] = result.value!
|
let configs: [TunnelConfiguration?] = result.value!
|
||||||
tunnelsManager.addMultiple(tunnelConfigurations: configs.compactMap { $0 }) { [weak self] (numberSuccessful) in
|
tunnelsManager.addMultiple(tunnelConfigurations: configs.compactMap { $0 }) { [weak self] (numberSuccessful) in
|
||||||
if numberSuccessful == configs.count {
|
if numberSuccessful == configs.count {
|
||||||
|
completionHandler?()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
ErrorPresenter.showErrorAlert(title: "Created \(numberSuccessful) tunnels",
|
ErrorPresenter.showErrorAlert(title: "Created \(numberSuccessful) tunnels",
|
||||||
message: "Created \(numberSuccessful) of \(configs.count) tunnels from zip archive",
|
message: "Created \(numberSuccessful) of \(configs.count) tunnels from zip archive",
|
||||||
from: self)
|
from: self, onPresented: completionHandler)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else /* if (url.pathExtension == "conf") -- we assume everything else is a conf */ {
|
} else /* if (url.pathExtension == "conf") -- we assume everything else is a conf */ {
|
||||||
|
@ -189,13 +190,15 @@ class TunnelsListTableViewController: UIViewController {
|
||||||
let tunnelConfiguration = try? WgQuickConfigFileParser.parse(fileContents, name: fileBaseName) {
|
let tunnelConfiguration = try? WgQuickConfigFileParser.parse(fileContents, name: fileBaseName) {
|
||||||
tunnelsManager.add(tunnelConfiguration: tunnelConfiguration) { [weak self] result in
|
tunnelsManager.add(tunnelConfiguration: tunnelConfiguration) { [weak self] result in
|
||||||
if let error = result.error {
|
if let error = result.error {
|
||||||
ErrorPresenter.showErrorAlert(error: error, from: self)
|
ErrorPresenter.showErrorAlert(error: error, from: self, onPresented: completionHandler)
|
||||||
|
} else {
|
||||||
|
completionHandler?()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
ErrorPresenter.showErrorAlert(title: "Unable to import tunnel",
|
ErrorPresenter.showErrorAlert(title: "Unable to import tunnel",
|
||||||
message: "An error occured when importing the tunnel configuration.",
|
message: "An error occured when importing the tunnel configuration.",
|
||||||
from: self)
|
from: self, onPresented: completionHandler)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -205,7 +208,9 @@ class TunnelsListTableViewController: UIViewController {
|
||||||
|
|
||||||
extension TunnelsListTableViewController: UIDocumentPickerDelegate {
|
extension TunnelsListTableViewController: UIDocumentPickerDelegate {
|
||||||
func documentPicker(_ controller: UIDocumentPickerViewController, didPickDocumentsAt urls: [URL]) {
|
func documentPicker(_ controller: UIDocumentPickerViewController, didPickDocumentsAt urls: [URL]) {
|
||||||
urls.forEach(importFromFile)
|
urls.forEach {
|
||||||
|
importFromFile(url: $0, completionHandler: nil)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue