From 40ce2604ea7c86a3f9dd12cf45dceace94481944 Mon Sep 17 00:00:00 2001 From: Roopesh Chander Date: Thu, 8 Nov 2018 16:31:42 +0530 Subject: [PATCH] DNSResolver: Let's not cache DNS resolution results anymore --- .../DNSResolver.swift | 26 +++++++------------ 1 file changed, 9 insertions(+), 17 deletions(-) diff --git a/WireGuard/WireGuardNetworkExtension/DNSResolver.swift b/WireGuard/WireGuardNetworkExtension/DNSResolver.swift index 4181f75..d69b96d 100644 --- a/WireGuard/WireGuardNetworkExtension/DNSResolver.swift +++ b/WireGuard/WireGuardNetworkExtension/DNSResolver.swift @@ -12,7 +12,6 @@ class DNSResolver { let endpoints: [Endpoint?] let dispatchGroup: DispatchGroup var dispatchWorkItems: [DispatchWorkItem] - static var cache = NSCache() init(endpoints: [Endpoint?]) { self.endpoints = endpoints @@ -20,20 +19,14 @@ class DNSResolver { self.dispatchGroup = DispatchGroup() } - func resolveWithoutNetworkRequests() -> [Endpoint?]? { - var resolvedEndpoints: [Endpoint?] = Array(repeating: nil, count: endpoints.count) - for (i, endpoint) in self.endpoints.enumerated() { + func isAllEndpointsAlreadyResolved() -> Bool { + for endpoint in self.endpoints { guard let endpoint = endpoint else { continue } - if (endpoint.hasHostAsIPAddress()) { - resolvedEndpoints[i] = endpoint - } else if let resolvedEndpointStringInCache = DNSResolver.cache.object(forKey: endpoint.stringRepresentation() as NSString), - let resolvedEndpointInCache = Endpoint(from: resolvedEndpointStringInCache as String) { - resolvedEndpoints[i] = resolvedEndpointInCache - } else { - return nil + if (!endpoint.hasHostAsIPAddress()) { + return false } } - return resolvedEndpoints + return true } func resolveSync() throws -> [Endpoint?] { @@ -41,19 +34,18 @@ class DNSResolver { let dispatchGroup = self.dispatchGroup dispatchWorkItems = [] + if (isAllEndpointsAlreadyResolved()) { + return endpoints + } + var resolvedEndpoints: [Endpoint?] = Array(repeating: nil, count: endpoints.count) - var isResolvedByDNSRequest: [Bool] = Array(repeating: false, count: endpoints.count) for (i, endpoint) in self.endpoints.enumerated() { guard let endpoint = endpoint else { continue } if (endpoint.hasHostAsIPAddress()) { resolvedEndpoints[i] = endpoint - } else if let resolvedEndpointStringInCache = DNSResolver.cache.object(forKey: endpoint.stringRepresentation() as NSString), - let resolvedEndpointInCache = Endpoint(from: resolvedEndpointStringInCache as String) { - resolvedEndpoints[i] = resolvedEndpointInCache } else { let workItem = DispatchWorkItem { resolvedEndpoints[i] = DNSResolver.resolveSync(endpoint: endpoint) - isResolvedByDNSRequest[i] = true } dispatchWorkItems.append(workItem) DispatchQueue.global(qos: .userInitiated).async(group: dispatchGroup, execute: workItem)