From ed8dc516dc5aa5b47afec780a69f4a8176e57500 Mon Sep 17 00:00:00 2001 From: "Jason A. Donenfeld" Date: Wed, 6 Feb 2019 02:01:12 +0100 Subject: LegacyConfig: Remove and support plaintext for .mobileconfig Signed-off-by: Jason A. Donenfeld --- .../Shared/Model/NETunnelProviderProtocol+Extension.swift | 13 +++++++++++++ 1 file changed, 13 insertions(+) (limited to 'WireGuard/Shared/Model/NETunnelProviderProtocol+Extension.swift') diff --git a/WireGuard/Shared/Model/NETunnelProviderProtocol+Extension.swift b/WireGuard/Shared/Model/NETunnelProviderProtocol+Extension.swift index 3b7cd1e..bdc17ac 100644 --- a/WireGuard/Shared/Model/NETunnelProviderProtocol+Extension.swift +++ b/WireGuard/Shared/Model/NETunnelProviderProtocol+Extension.swift @@ -56,4 +56,17 @@ extension NETunnelProviderProtocol { guard let ref = passwordReference else { return nil } return Keychain.verifyReference(called: ref) ? ref : nil } + + @discardableResult + func migrateConfigurationIfNeeded(called name: String) -> Bool { + /* This is how we did things before we switched to putting items + * in the keychain. But it's still useful to keep the migration + * around so that .mobileconfig files are easier. + */ + guard let oldConfig = providerConfiguration?["WgQuickConfig"] as? String else { return false } + providerConfiguration = nil + guard passwordReference == nil else { return true } + passwordReference = Keychain.makeReference(containing: oldConfig, called: name) + return true + } } -- cgit v1.2.3-59-g8ed1b