Merge "Remove hidden API usage of Proxy.validate" am: a4a9e9bbc8 am: 1065160b6c
Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1552497 MUST ONLY BE SUBMITTED BY AUTOMERGER Change-Id: Id19b29b7140eeaa4d51821045f1b4549719b482c
This commit is contained in:
@@ -85,6 +85,7 @@ import android.security.keystore.StrongBoxUnavailableException;
|
||||
import android.service.restrictions.RestrictionsReceiver;
|
||||
import android.telephony.TelephonyManager;
|
||||
import android.telephony.data.ApnSetting;
|
||||
import android.text.TextUtils;
|
||||
import android.util.ArraySet;
|
||||
import android.util.Log;
|
||||
import android.util.Pair;
|
||||
@@ -4554,29 +4555,23 @@ public class DevicePolicyManager {
|
||||
InetSocketAddress sa = (InetSocketAddress) proxySpec.address();
|
||||
String hostName = sa.getHostName();
|
||||
int port = sa.getPort();
|
||||
StringBuilder hostBuilder = new StringBuilder();
|
||||
final String hostSpec = hostBuilder.append(hostName)
|
||||
.append(":").append(Integer.toString(port)).toString();
|
||||
final String exclSpec;
|
||||
final List<String> trimmedExclList;
|
||||
if (exclusionList == null) {
|
||||
exclSpec = "";
|
||||
trimmedExclList = Collections.emptyList();
|
||||
} else {
|
||||
StringBuilder listBuilder = new StringBuilder();
|
||||
boolean firstDomain = true;
|
||||
trimmedExclList = new ArrayList<>(exclusionList.size());
|
||||
for (String exclDomain : exclusionList) {
|
||||
if (!firstDomain) {
|
||||
listBuilder = listBuilder.append(",");
|
||||
} else {
|
||||
firstDomain = false;
|
||||
}
|
||||
listBuilder = listBuilder.append(exclDomain.trim());
|
||||
trimmedExclList.add(exclDomain.trim());
|
||||
}
|
||||
exclSpec = listBuilder.toString();
|
||||
}
|
||||
if (android.net.Proxy.validate(hostName, Integer.toString(port), exclSpec)
|
||||
!= android.net.Proxy.PROXY_VALID) throw new IllegalArgumentException();
|
||||
final ProxyInfo info = ProxyInfo.buildDirectProxy(hostName, port, trimmedExclList);
|
||||
// The hostSpec is built assuming that there is a specified port and hostname,
|
||||
// but ProxyInfo.isValid() accepts 0 / empty as unspecified: also reject them.
|
||||
if (port == 0 || TextUtils.isEmpty(hostName) || !info.isValid()) {
|
||||
throw new IllegalArgumentException();
|
||||
}
|
||||
|
||||
return new Pair<>(hostSpec, exclSpec);
|
||||
return new Pair<>(hostName + ":" + port, TextUtils.join(",", trimmedExclList));
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user