From dfc5e0ea7fd47892bf674cae851fe96e6b4d4e4f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Em=C4=ABls?= Date: Wed, 11 Oct 2023 14:46:15 +0200 Subject: [PATCH 1/2] Log if same-ip is used every time wg is configured --- ios/PacketTunnel/PacketTunnelProvider.swift | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/ios/PacketTunnel/PacketTunnelProvider.swift b/ios/PacketTunnel/PacketTunnelProvider.swift index 910c8b2befa2..e115c5a34049 100644 --- a/ios/PacketTunnel/PacketTunnelProvider.swift +++ b/ios/PacketTunnel/PacketTunnelProvider.swift @@ -208,7 +208,7 @@ class PacketTunnelProvider: NEPacketTunnelProvider { let selectorResult = tunnelConfiguration.selectorResult self.selectorResult = selectorResult self.providerLogger.debug("Set tunnel relay to \(selectorResult.relay.hostname).") - self.logIfDeviceHasSameIP(than: tunnelConfiguration.wgTunnelConfig.interface.addresses) + self.logIfDeviceHasSameIP(as: tunnelConfiguration.wgTunnelConfig.interface.addresses) // Start tunnel. self.adapter.start(tunnelConfiguration: tunnelConfiguration.wgTunnelConfig) { error in @@ -239,7 +239,7 @@ class PacketTunnelProvider: NEPacketTunnelProvider { } } - private func logIfDeviceHasSameIP(than addresses: [IPAddressRange]) { + private func logIfDeviceHasSameIP(as addresses: [IPAddressRange]) { let hasIPv4SameAddress = addresses.compactMap { $0.address as? IPv4Address } .contains { $0 == ApplicationConfiguration.sameIPv4 } let hasIPv6SameAddress = addresses.compactMap { $0.address as? IPv6Address } @@ -664,6 +664,7 @@ class PacketTunnelProvider: NEPacketTunnelProvider { providerLogger.debug("Set tunnel relay to \(newTunnelRelay.hostname).") setReconnecting(true) + logIfDeviceHasSameIP(as: tunnelConfiguration.wgTunnelConfig.interface.addresses) adapter.update(tunnelConfiguration: tunnelConfiguration.wgTunnelConfig) { error in self.dispatchQueue.async { if let error { From a9f8b5624ea6f2eaf66d45608b4296b802d249c3 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Em=C4=ABls?= Date: Wed, 11 Oct 2023 15:00:53 +0200 Subject: [PATCH 2/2] Add user agent header for all requests on iOS --- ios/MullvadREST/HTTP.swift | 1 + ios/MullvadREST/RESTRequestFactory.swift | 1 + 2 files changed, 2 insertions(+) diff --git a/ios/MullvadREST/HTTP.swift b/ios/MullvadREST/HTTP.swift index 900ab2a49aee..93074fdbd35a 100644 --- a/ios/MullvadREST/HTTP.swift +++ b/ios/MullvadREST/HTTP.swift @@ -47,4 +47,5 @@ enum HTTPHeader { static let contentType = "Content-Type" static let etag = "ETag" static let ifNoneMatch = "If-None-Match" + static let userAgent = "User-Agent" } diff --git a/ios/MullvadREST/RESTRequestFactory.swift b/ios/MullvadREST/RESTRequestFactory.swift index 00ed23e9aea2..f0a3f3334eb4 100644 --- a/ios/MullvadREST/RESTRequestFactory.swift +++ b/ios/MullvadREST/RESTRequestFactory.swift @@ -62,6 +62,7 @@ extension REST { request.httpShouldHandleCookies = false request.addValue(hostname, forHTTPHeaderField: HTTPHeader.host) request.addValue("application/json", forHTTPHeaderField: HTTPHeader.contentType) + request.addValue("mullvad-app", forHTTPHeaderField: HTTPHeader.userAgent) request.httpMethod = method.rawValue let prefixedPathTemplate = URLPathTemplate(stringLiteral: pathPrefix) + pathTemplate