]> git.ipfire.org Git - thirdparty/wireguard-apple.git/commit
Kit: PacketTunnelSettingsGenerator: do not require DNS queries if no DNS
authorJason A. Donenfeld <Jason@zx2c4.com>
Wed, 16 Dec 2020 23:10:28 +0000 (00:10 +0100)
committerJason A. Donenfeld <Jason@zx2c4.com>
Wed, 16 Dec 2020 23:10:28 +0000 (00:10 +0100)
commit20bdf46792905de8862ae7641e50e0f9f99ec946
treea38a17a2952a8ef7aa0dec6003a2104e73a2da63
parent4ded3f6bfe4826788ded865a83854c63e300fffe
Kit: PacketTunnelSettingsGenerator: do not require DNS queries if no DNS

Prior, we would set matchDomains=[""] even if the user didn't provide
any DNS servers. This was kind of incoherent, but I guess we had in mind
some kind of non-sensical leakproof scheme that never really worked
anyway. NetworkExtension didn't like this, so setTunnelNetworkSettings
would, rather than return an error, simply timeout and never call its
callback function. But everything worked fine, so we had code in the UI
to check to make sure everything was okay after 5 seconds or so of no
callback. Recent changes made the timeout fatal on the network extension
side, so rather than succeed, configs with no DNS server started
erroring out, causing user reports.

This commit attempts to handle the root cause of the timeout issue by
not twiddling with DNS settings if no DNS server was specified. For now,
however, it leaves the hard-timeout semantics in place.

Reported-by: Filipe Mendonça <cfilipem@gmail.com>
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Sources/WireGuardKit/PacketTunnelSettingsGenerator.swift