From 09fbfc0aa772e941ca2b3a414e9530fa64716af3 Mon Sep 17 00:00:00 2001 From: Anh Do <18567+quanganhdo@users.noreply.github.com> Date: Mon, 22 Apr 2024 15:52:54 -0400 Subject: [PATCH] lastDisconnectError now matches against NEVPNConnectionError (#2753) --- .../Feedback/VPNMetadataCollector.swift | 33 ++++++++++++------- 1 file changed, 22 insertions(+), 11 deletions(-) diff --git a/DuckDuckGo/Feedback/VPNMetadataCollector.swift b/DuckDuckGo/Feedback/VPNMetadataCollector.swift index cc3b47bf0a..963cae47da 100644 --- a/DuckDuckGo/Feedback/VPNMetadataCollector.swift +++ b/DuckDuckGo/Feedback/VPNMetadataCollector.swift @@ -237,18 +237,29 @@ final class DefaultVPNMetadataCollector: VPNMetadataCollector { tunnelManager.connection.fetchLastDisconnectError { error in let message = { if let error = error as? NSError { - if error.domain == NEVPNConnectionErrorDomain, let code = NEDNSSettingsManagerError(rawValue: error.code) { + if error.domain == NEVPNConnectionErrorDomain, + let code = NEVPNConnectionError(rawValue: error.code) { switch code { - case .configurationCannotBeRemoved: - return "configurationCannotBeRemoved" - case .configurationDisabled: - return "configurationDisabled" - case .configurationInvalid: - return "configurationInvalid" - case .configurationStale: - return "configurationStale" - default: - return error.localizedDescription + case .overslept: return "overslept" + case .noNetworkAvailable: return "noNetworkAvailable" + case .unrecoverableNetworkChange: return "unrecoverableNetworkChange" + case .configurationFailed: return "configurationFailed" + case .serverAddressResolutionFailed: return "serverAddressResolutionFailed" + case .serverNotResponding: return "serverNotResponding" + case .serverDead: return "serverDead" + case .authenticationFailed: return "authenticationFailed" + case .clientCertificateInvalid: return "clientCertificateInvalid" + case .clientCertificateNotYetValid: return "clientCertificateNotYetValid" + case .clientCertificateExpired: return "clientCertificateExpired" + case .pluginFailed: return "pluginFailed" + case .configurationNotFound: return "configurationNotFound" + case .pluginDisabled: return "pluginDisabled" + case .negotiationFailed: return "negotiationFailed" + case .serverDisconnected: return "serverDisconnected" + case .serverCertificateInvalid: return "serverCertificateInvalid" + case .serverCertificateNotYetValid: return "serverCertificateNotYetValid" + case .serverCertificateExpired: return "serverCertificateExpired" + default: return error.localizedDescription } } else { return error.localizedDescription