2018-11-09 11:23:52 +00:00
|
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
// Copyright © 2018 WireGuard LLC. All Rights Reserved.
|
|
|
|
|
|
|
|
import NetworkExtension
|
|
|
|
|
|
|
|
class ErrorNotifier {
|
2018-12-13 20:54:53 +00:00
|
|
|
|
|
|
|
let activationAttemptId: String?
|
|
|
|
weak var tunnelProvider: NEPacketTunnelProvider?
|
|
|
|
|
2018-12-21 10:10:04 +00:00
|
|
|
var tunnelName: String?
|
|
|
|
|
2018-12-13 20:54:53 +00:00
|
|
|
init(activationAttemptId: String?, tunnelProvider: NEPacketTunnelProvider) {
|
|
|
|
self.activationAttemptId = activationAttemptId
|
|
|
|
self.tunnelProvider = tunnelProvider
|
|
|
|
ErrorNotifier.removeLastErrorFile()
|
|
|
|
}
|
|
|
|
|
|
|
|
func errorMessage(for error: PacketTunnelProviderError) -> (String, String)? {
|
2018-12-12 18:28:27 +00:00
|
|
|
switch error {
|
2018-11-09 11:23:52 +00:00
|
|
|
case .savedProtocolConfigurationIsInvalid:
|
2018-12-21 10:10:04 +00:00
|
|
|
return ("Activation failure", "Could not retrieve tunnel information from the saved configuration.")
|
|
|
|
case .dnsResolutionFailure:
|
|
|
|
return ("DNS resolution failure", "One or more endpoint domains could not be resolved.")
|
2018-11-09 11:23:52 +00:00
|
|
|
case .couldNotStartWireGuard:
|
2018-12-21 10:10:04 +00:00
|
|
|
return ("Activation failure", "WireGuard backend could not be started.")
|
2018-11-09 11:23:52 +00:00
|
|
|
case .coultNotSetNetworkSettings:
|
2018-12-21 10:10:04 +00:00
|
|
|
return ("Activation failure", "Error applying network settings on the tunnel.")
|
2018-11-09 11:23:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-13 20:54:53 +00:00
|
|
|
func notify(_ error: PacketTunnelProviderError) {
|
2018-12-21 17:50:32 +00:00
|
|
|
guard let (title, message) = errorMessage(for: error), let activationAttemptId = activationAttemptId, let lastErrorFilePath = FileManager.networkExtensionLastErrorFileURL?.path else { return }
|
|
|
|
let errorMessageData = "\(activationAttemptId)\n\(title)\n\(message)".data(using: .utf8)
|
|
|
|
FileManager.default.createFile(atPath: lastErrorFilePath, contents: errorMessageData, attributes: nil)
|
2018-12-13 20:54:53 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static func removeLastErrorFile() {
|
|
|
|
if let lastErrorFileURL = FileManager.networkExtensionLastErrorFileURL {
|
|
|
|
_ = FileManager.deleteFile(at: lastErrorFileURL)
|
|
|
|
}
|
2018-11-09 11:23:52 +00:00
|
|
|
}
|
|
|
|
}
|