From bd2763d977a4cad6f797f5378fc6db96e842dcf2 Mon Sep 17 00:00:00 2001 From: Benedict Wong Date: Mon, 23 Mar 2020 13:56:36 -0700 Subject: [PATCH] Add negotiated DNS servers to VPN config This change plumbs the DNS servers through from the IkeSessionConfiguration. Previously the getInternalDnsServer() was not implemented. Bug: 152242520 Test: FrameworksNetTests passing Change-Id: Icd80b3688de2a39e222a4501787f8c54951c2ba0 --- .../core/java/com/android/server/connectivity/Vpn.java | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/services/core/java/com/android/server/connectivity/Vpn.java b/services/core/java/com/android/server/connectivity/Vpn.java index e80b39f8ce34..120e744a9740 100644 --- a/services/core/java/com/android/server/connectivity/Vpn.java +++ b/services/core/java/com/android/server/connectivity/Vpn.java @@ -2248,12 +2248,16 @@ public class Vpn { final String interfaceName = mTunnelIface.getInterfaceName(); final int maxMtu = mProfile.getMaxMtu(); final List internalAddresses = childConfig.getInternalAddresses(); + final List dnsAddrStrings = new ArrayList<>(); final Collection newRoutes = VpnIkev2Utils.getRoutesFromTrafficSelectors( childConfig.getOutboundTrafficSelectors()); for (final LinkAddress address : internalAddresses) { mTunnelIface.addAddress(address.getAddress(), address.getPrefixLength()); } + for (InetAddress addr : childConfig.getInternalDnsServers()) { + dnsAddrStrings.add(addr.getHostAddress()); + } final NetworkAgent networkAgent; final LinkProperties lp; @@ -2269,7 +2273,9 @@ public class Vpn { mConfig.routes.clear(); mConfig.routes.addAll(newRoutes); - // TODO: Add DNS servers from negotiation + if (mConfig.dnsServers == null) mConfig.dnsServers = new ArrayList<>(); + mConfig.dnsServers.clear(); + mConfig.dnsServers.addAll(dnsAddrStrings); networkAgent = mNetworkAgent; -- GitLab