From 27265fc22231c5418f28c58b08d43344f10e26cb Mon Sep 17 00:00:00 2001 From: Eric Kuck Date: Tue, 11 Dec 2018 16:12:04 -0600 Subject: Added an (unfinished) NWPathMonitor implementation for reconnecting on network changes Signed-off-by: Eric Kuck --- .../PacketTunnelSettingsGenerator.swift | 14 ++++++++++++++ 1 file changed, 14 insertions(+) (limited to 'WireGuard/WireGuardNetworkExtension/PacketTunnelSettingsGenerator.swift') diff --git a/WireGuard/WireGuardNetworkExtension/PacketTunnelSettingsGenerator.swift b/WireGuard/WireGuardNetworkExtension/PacketTunnelSettingsGenerator.swift index 4007196..906aea9 100644 --- a/WireGuard/WireGuardNetworkExtension/PacketTunnelSettingsGenerator.swift +++ b/WireGuard/WireGuardNetworkExtension/PacketTunnelSettingsGenerator.swift @@ -15,6 +15,20 @@ class PacketTunnelSettingsGenerator { self.resolvedEndpoints = resolvedEndpoints } + func endpointFromSettings() -> String { + var wgSettings = "listen_port=\(tunnelConfiguration.interface.listenPort ?? 0)\n" + + for (i, peer) in tunnelConfiguration.peers.enumerated() { + wgSettings.append("public_key=\(peer.publicKey.hexEncodedString())\n") + if let endpoint = resolvedEndpoints[i] { + if case .name(_, _) = endpoint.host { assert(false, "Endpoint is not resolved") } + wgSettings.append("endpoint=\(endpoint.stringRepresentation())\n") + } + } + + return wgSettings + } + func generateWireGuardSettings() -> String { var wgSettings = "" let privateKey = tunnelConfiguration.interface.privateKey.hexEncodedString() -- cgit v1.2.3-59-g8ed1b