When using the new WKDownloadDelegate, I try to download a file, and the first time it downloads fine, but when I attempt to download the same file again, WKDownloadDelegate invokes this method:
func download(_ download: WKDownload, didFailWithError error: Error, resumeData: Data?)
When I print this to the console:
download(_ download: <WKDownload: 0x7fc58fb2dfd0>, didFailWithError error: The operation couldn’t be completed. (NSURLErrorDomain error -3000.), resumeData: nil
Problem is I can't find any information about this error (-3000), so any suggestions would be nice.
Here is the whole WKDownloadDelegate code
public func download(_ download: WKDownload, decideDestinationUsing response: URLResponse, suggestedFilename: String, completionHandler: @escaping (URL?) -> Void) {
let tempDirectory = FileManager.default.temporaryDirectory
let tempFolderName = UUID().uuidString
let tempDirectoryPath = tempDirectory.appendingPathComponent(tempFolderName)
try? FileManager.default.createDirectory(at: tempDirectoryPath, withIntermediateDirectories: false)
let url = tempDirectory.appendingPathComponent(suggestedFilename)
currentDownloadedPreviewItemUrl = url
completionHandler(url)
}
public func downloadDidFinish(_ download: WKDownload) {
guard let currentDownloadedPreviewItemUrl = currentDownloadedPreviewItemUrl else {
print("Download finished but no URL found")
return
}
DispatchQueue.main.async {
let activityVC = UIActivityViewController(activityItems: [currentDownloadedPreviewItemUrl], applicationActivities: nil)
activityVC.popoverPresentationController?.sourceView = self.view
activityVC.popoverPresentationController?.sourceRect = self.view.frame
activityVC.popoverPresentationController?.barButtonItem = self.navigationItem.rightBarButtonItem
self.present(activityVC, animated: true, completion: nil)
}
}
public func download(_ download: WKDownload, didFailWithError error: Error, resumeData: Data?) {
debugPrint("------------------")
debugPrint("download(_ download: \(download), didFailWithError error: \(error.localizedDescription), resumeData: \(resumeData)")
debugPrint("------------------")
}
I am clumsy, so I will post what was the problem for anyone that ever encounters error -3000 again. When working with WKDownloadDelegate and the method
func download(_ download: WKDownload, decideDestinationUsing response: URLResponse, suggestedFilename: String, completionHandler: @escaping (URL?) -> Void)
is invoked, when passing the URL to the completion handler, you MUST ENSURE that a file with the same name doesn't exist, or else it will later throw an error in downloadDidFail method.
So in my case I fixed the code in this method:
public func download(_ download: WKDownload, decideDestinationUsing response: URLResponse, suggestedFilename: String, completionHandler: @escaping (URL?) -> Void) {
let tempDirectory = FileManager.default.temporaryDirectory
let tempFolderName = UUID().uuidString
let tempDirectoryPath = tempDirectory.appendingPathComponent(tempFolderName)
do {
try FileManager.default.createDirectory(at: tempDirectoryPath, withIntermediateDirectories: false)
} catch {
debugPrint(error)
}
let url = tempDirectoryPath.appendingPathComponent(suggestedFilename)
currentDownloadedPreviewItemUrl = url
completionHandler(url)
}
Notice that line
let url = tempDirectoryPath.appendingPathComponent(suggestedFilename)
is using tempDirectoryPath instead of tempDirectory