summaryrefslogtreecommitdiffstats
path: root/wifi/java/android
diff options
context:
space:
mode:
Diffstat (limited to 'wifi/java/android')
-rw-r--r--wifi/java/android/net/wifi/WifiConfigStore.java437
-rw-r--r--wifi/java/android/net/wifi/WifiConfiguration.java53
-rw-r--r--wifi/java/android/net/wifi/WifiStateMachine.java34
3 files changed, 315 insertions, 209 deletions
diff --git a/wifi/java/android/net/wifi/WifiConfigStore.java b/wifi/java/android/net/wifi/WifiConfigStore.java
index 9634157..be5fab4 100644
--- a/wifi/java/android/net/wifi/WifiConfigStore.java
+++ b/wifi/java/android/net/wifi/WifiConfigStore.java
@@ -20,6 +20,9 @@ import android.app.ActivityManagerNative;
import android.content.Context;
import android.content.Intent;
import android.net.DhcpInfo;
+import android.net.LinkAddress;
+import android.net.LinkProperties;
+import android.net.NetworkUtils;
import android.net.ProxyProperties;
import android.net.wifi.WifiConfiguration.IpAssignment;
import android.net.wifi.WifiConfiguration.KeyMgmt;
@@ -34,13 +37,18 @@ import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
+import java.io.EOFException;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
+import java.net.InetAddress;
import java.net.InetSocketAddress;
+import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.BitSet;
+import java.util.Collection;
import java.util.HashMap;
+import java.util.Iterator;
import java.util.List;
/**
@@ -61,13 +69,10 @@ import java.util.List;
* ..
*
* (key, value) pairs for a given network are grouped together and can
- * be in any order. A "EOS" at the end of a set of (key, value) pairs
+ * be in any order. A EOS at the end of a set of (key, value) pairs
* indicates that the next set of (key, value) pairs are for a new
- * network. A network is identified by a unique "id". If there is no
- * "id" key in the (key, value) pairs, the data is discarded. An IP
- * configuration includes the keys - "ipAssignment", "ipAddress", "gateway",
- * "netmask", "dns1" and "dns2". A proxy configuration includes "proxySettings",
- * "proxyHost", "proxyPort" and "exclusionList"
+ * network. A network is identified by a unique ID_KEY. If there is no
+ * ID_KEY in the (key, value) pairs, the data is discarded.
*
* An invalid version on read would result in discarding the contents of
* the file. On the next write, the latest version is written to file.
@@ -118,6 +123,18 @@ class WifiConfigStore {
private static final int IPCONFIG_FILE_VERSION = 1;
+ /* IP and proxy configuration keys */
+ private static final String ID_KEY = "id";
+ private static final String IP_ASSIGNMENT_KEY = "ipAssignment";
+ private static final String LINK_ADDRESS_KEY = "linkAddress";
+ private static final String GATEWAY_KEY = "gateway";
+ private static final String DNS_KEY = "dns";
+ private static final String PROXY_SETTINGS_KEY = "proxySettings";
+ private static final String PROXY_HOST_KEY = "proxyHost";
+ private static final String PROXY_PORT_KEY = "proxyPort";
+ private static final String EXCLUSION_LIST_KEY = "exclusionList";
+ private static final String EOS = "eos";
+
/**
* Initialize context, fetch the list of configured networks
* and enable all stored networks in supplicant.
@@ -370,25 +387,61 @@ class WifiConfigStore {
}
/**
- * Fetch the IP configuration for a given network id
+ * Fetch the link properties for a given network id
*/
- static DhcpInfo getIpConfiguration(int netId) {
+ static LinkProperties getLinkProperties(int netId) {
synchronized (sConfiguredNetworks) {
WifiConfiguration config = sConfiguredNetworks.get(netId);
- if (config != null) return new DhcpInfo(config.ipConfig);
+ if (config != null) return new LinkProperties(config.linkProperties);
}
return null;
}
/**
+ * get IP configuration for a given network id
+ * TODO: We cannot handle IPv6 addresses for configuration
+ * right now until NetworkUtils is fixed. When we do
+ * that, we should remove handling DhcpInfo and move
+ * to using LinkProperties
+ */
+ static DhcpInfo getIpConfiguration(int netId) {
+ DhcpInfo dhcpInfo = new DhcpInfo();
+ LinkProperties linkProperties = getLinkProperties(netId);
+
+ if (linkProperties != null) {
+ Iterator<LinkAddress> iter = linkProperties.getLinkAddresses().iterator();
+ if (iter.hasNext()) {
+ try {
+ LinkAddress linkAddress = iter.next();
+ dhcpInfo.ipAddress = NetworkUtils.inetAddressToInt(
+ linkAddress.getAddress());
+ dhcpInfo.gateway = NetworkUtils.inetAddressToInt(
+ linkProperties.getGateway());
+ dhcpInfo.netmask = NetworkUtils.prefixLengthToNetmaskInt(
+ linkAddress.getNetworkPrefixLength());
+ Iterator<InetAddress> dnsIterator = linkProperties.getDnses().iterator();
+ dhcpInfo.dns1 = NetworkUtils.inetAddressToInt(dnsIterator.next());
+ if (dnsIterator.hasNext()) {
+ dhcpInfo.dns2 = NetworkUtils.inetAddressToInt(dnsIterator.next());
+ }
+ } catch (IllegalArgumentException e1) {
+ Log.e(TAG, "IPv6 address cannot be handled " + e1);
+ } catch (NullPointerException e2) {
+ /* Should not happen since a stored static config should be valid */
+ Log.e(TAG, "Invalid partial IP configuration " + e2);
+ }
+ }
+ }
+ return dhcpInfo;
+ }
+
+ /**
* Fetch the proxy properties for a given network id
*/
static ProxyProperties getProxyProperties(int netId) {
- synchronized (sConfiguredNetworks) {
- WifiConfiguration config = sConfiguredNetworks.get(netId);
- if (config != null && config.proxySettings == ProxySettings.STATIC) {
- return new ProxyProperties(config.proxyProperties);
- }
+ LinkProperties linkProperties = getLinkProperties(netId);
+ if (linkProperties != null) {
+ return new ProxyProperties(linkProperties.getHttpProxy());
}
return null;
}
@@ -484,71 +537,75 @@ class WifiConfigStore {
for(WifiConfiguration config : sConfiguredNetworks.values()) {
boolean writeToFile = false;
- switch (config.ipAssignment) {
- case STATIC:
- out.writeUTF("ipAssignment");
- out.writeUTF(config.ipAssignment.toString());
- out.writeUTF("ipAddress");
- out.writeInt(config.ipConfig.ipAddress);
- out.writeUTF("gateway");
- out.writeInt(config.ipConfig.gateway);
- out.writeUTF("netmask");
- out.writeInt(config.ipConfig.netmask);
- out.writeUTF("dns1");
- out.writeInt(config.ipConfig.dns1);
- out.writeUTF("dns2");
- out.writeInt(config.ipConfig.dns2);
- writeToFile = true;
- break;
- case DHCP:
- out.writeUTF("ipAssignment");
- out.writeUTF(config.ipAssignment.toString());
- writeToFile = true;
- break;
- case UNASSIGNED:
- /* Ignore */
- break;
- default:
- Log.e(TAG, "Ignore invalid ip assignment while writing");
- break;
- }
-
- switch (config.proxySettings) {
- case STATIC:
- out.writeUTF("proxySettings");
- out.writeUTF(config.proxySettings.toString());
- InetSocketAddress proxy = config.proxyProperties.getSocketAddress();
- if (proxy != null) {
- out.writeUTF("proxyHost");
- out.writeUTF(proxy.getHostName());
- out.writeUTF("proxyPort");
- out.writeInt(proxy.getPort());
- String exclusionList = config.proxyProperties.getExclusionList();
- if (exclusionList != null && exclusionList.length() > 0) {
- out.writeUTF("exclusionList");
- out.writeUTF(exclusionList);
+ try {
+ LinkProperties linkProperties = config.linkProperties;
+ switch (config.ipAssignment) {
+ case STATIC:
+ out.writeUTF(IP_ASSIGNMENT_KEY);
+ out.writeUTF(config.ipAssignment.toString());
+ for (LinkAddress linkAddr : linkProperties.getLinkAddresses()) {
+ out.writeUTF(LINK_ADDRESS_KEY);
+ out.writeUTF(linkAddr.getAddress().getHostAddress());
+ out.writeInt(linkAddr.getNetworkPrefixLength());
}
- }
- writeToFile = true;
- break;
- case NONE:
- out.writeUTF("proxySettings");
- out.writeUTF(config.proxySettings.toString());
- writeToFile = true;
- break;
- case UNASSIGNED:
- /* Ignore */
- break;
- default:
- Log.e(TAG, "Ignore invalid proxy settings while writing");
- break;
- }
+ InetAddress gateway = linkProperties.getGateway();
+ if (gateway != null) {
+ out.writeUTF(GATEWAY_KEY);
+ out.writeUTF(gateway.getHostAddress());
+ }
+ for (InetAddress inetAddr : linkProperties.getDnses()) {
+ out.writeUTF(DNS_KEY);
+ out.writeUTF(inetAddr.getHostAddress());
+ }
+ writeToFile = true;
+ break;
+ case DHCP:
+ out.writeUTF(IP_ASSIGNMENT_KEY);
+ out.writeUTF(config.ipAssignment.toString());
+ writeToFile = true;
+ break;
+ case UNASSIGNED:
+ /* Ignore */
+ break;
+ default:
+ Log.e(TAG, "Ignore invalid ip assignment while writing");
+ break;
+ }
- if (writeToFile) {
- out.writeUTF("id");
- out.writeInt(configKey(config));
- out.writeUTF("EOS");
+ switch (config.proxySettings) {
+ case STATIC:
+ ProxyProperties proxyProperties = linkProperties.getHttpProxy();
+ String exclusionList = proxyProperties.getExclusionList();
+ out.writeUTF(PROXY_SETTINGS_KEY);
+ out.writeUTF(config.proxySettings.toString());
+ out.writeUTF(PROXY_HOST_KEY);
+ out.writeUTF(proxyProperties.getSocketAddress().getHostName());
+ out.writeUTF(PROXY_PORT_KEY);
+ out.writeInt(proxyProperties.getSocketAddress().getPort());
+ out.writeUTF(EXCLUSION_LIST_KEY);
+ out.writeUTF(exclusionList);
+ writeToFile = true;
+ break;
+ case NONE:
+ out.writeUTF(PROXY_SETTINGS_KEY);
+ out.writeUTF(config.proxySettings.toString());
+ writeToFile = true;
+ break;
+ case UNASSIGNED:
+ /* Ignore */
+ break;
+ default:
+ Log.e(TAG, "Ignore invalid proxy settings while writing");
+ break;
+ }
+ if (writeToFile) {
+ out.writeUTF(ID_KEY);
+ out.writeInt(configKey(config));
+ }
+ } catch (NullPointerException e) {
+ Log.e(TAG, "Failure in writing " + config.linkProperties + e);
}
+ out.writeUTF(EOS);
}
}
@@ -578,8 +635,8 @@ class WifiConfigStore {
while (true) {
int id = -1;
IpAssignment ipAssignment = IpAssignment.UNASSIGNED;
- DhcpInfo ipConfig = new DhcpInfo();
ProxySettings proxySettings = ProxySettings.UNASSIGNED;
+ LinkProperties linkProperties = new LinkProperties();
String proxyHost = null;
int proxyPort = -1;
String exclusionList = null;
@@ -587,32 +644,34 @@ class WifiConfigStore {
do {
key = in.readUTF();
- if (key.equals("id")) {
- id = in.readInt();
- } else if (key.equals("ipAssignment")) {
- ipAssignment = IpAssignment.valueOf(in.readUTF());
- } else if (key.equals("ipAddress")) {
- ipConfig.ipAddress = in.readInt();
- } else if (key.equals("gateway")) {
- ipConfig.gateway = in.readInt();
- } else if (key.equals("netmask")) {
- ipConfig.netmask = in.readInt();
- } else if (key.equals("dns1")) {
- ipConfig.dns1 = in.readInt();
- } else if (key.equals("dns2")) {
- ipConfig.dns2 = in.readInt();
- } else if (key.equals("proxySettings")) {
- proxySettings = ProxySettings.valueOf(in.readUTF());
- } else if (key.equals("proxyHost")) {
- proxyHost = in.readUTF();
- } else if (key.equals("proxyPort")) {
- proxyPort = in.readInt();
- } else if (key.equals("exclusionList")) {
- exclusionList = in.readUTF();
- } else if (key.equals("EOS")) {
- break;
- } else {
- Log.e(TAG, "Ignore unknown key " + key + "while reading");
+ try {
+ if (key.equals(ID_KEY)) {
+ id = in.readInt();
+ } else if (key.equals(IP_ASSIGNMENT_KEY)) {
+ ipAssignment = IpAssignment.valueOf(in.readUTF());
+ } else if (key.equals(LINK_ADDRESS_KEY)) {
+ LinkAddress linkAddr = new LinkAddress(InetAddress.getByName(
+ in.readUTF()), in.readInt());
+ linkProperties.addLinkAddress(linkAddr);
+ } else if (key.equals(GATEWAY_KEY)) {
+ linkProperties.setGateway(InetAddress.getByName(in.readUTF()));
+ } else if (key.equals(DNS_KEY)) {
+ linkProperties.addDns(InetAddress.getByName(in.readUTF()));
+ } else if (key.equals(PROXY_SETTINGS_KEY)) {
+ proxySettings = ProxySettings.valueOf(in.readUTF());
+ } else if (key.equals(PROXY_HOST_KEY)) {
+ proxyHost = in.readUTF();
+ } else if (key.equals(PROXY_PORT_KEY)) {
+ proxyPort = in.readInt();
+ } else if (key.equals(EXCLUSION_LIST_KEY)) {
+ exclusionList = in.readUTF();
+ } else if (key.equals(EOS)) {
+ break;
+ } else {
+ Log.e(TAG, "Ignore unknown key " + key + "while reading");
+ }
+ } catch (UnknownHostException e) {
+ Log.e(TAG, "Ignore invalid address while reading" + e);
}
} while (true);
@@ -624,11 +683,9 @@ class WifiConfigStore {
if (config == null) {
Log.e(TAG, "configuration found for missing network, ignored");
} else {
+ config.linkProperties = linkProperties;
switch (ipAssignment) {
case STATIC:
- config.ipAssignment = ipAssignment;
- config.ipConfig = ipConfig;
- break;
case DHCP:
config.ipAssignment = ipAssignment;
break;
@@ -647,7 +704,7 @@ class WifiConfigStore {
proxyProperties.setSocketAddress(
new InetSocketAddress(proxyHost, proxyPort));
proxyProperties.setExclusionList(exclusionList);
- config.proxyProperties = proxyProperties;
+ linkProperties.setHttpProxy(proxyProperties);
break;
case NONE:
config.proxySettings = proxySettings;
@@ -662,11 +719,12 @@ class WifiConfigStore {
}
}
} else {
- Log.e(TAG,"Missing id while parsing configuration");
+ Log.e(TAG, "Missing id while parsing configuration");
}
}
+ } catch (EOFException ignore) {
} catch (IOException e) {
- Log.e(TAG, "Error parsing configuration");
+ Log.e(TAG, "Error parsing configuration" + e);
} finally {
if (in != null) {
try {
@@ -894,63 +952,140 @@ class WifiConfigStore {
/* Compare current and new configuration and write to file on change */
private static void writeIpAndProxyConfigurationsOnChange(WifiConfiguration currentConfig,
WifiConfiguration newConfig) {
- boolean newNetwork = (newConfig.networkId == INVALID_NETWORK_ID);
- boolean writeConfigToFile = false;
-
- if (newConfig.ipAssignment != IpAssignment.UNASSIGNED) {
- if (newNetwork ||
- (currentConfig.ipAssignment != newConfig.ipAssignment) ||
- (currentConfig.ipConfig.ipAddress != newConfig.ipConfig.ipAddress) ||
- (currentConfig.ipConfig.gateway != newConfig.ipConfig.gateway) ||
- (currentConfig.ipConfig.netmask != newConfig.ipConfig.netmask) ||
- (currentConfig.ipConfig.dns1 != newConfig.ipConfig.dns1) ||
- (currentConfig.ipConfig.dns2 != newConfig.ipConfig.dns2)) {
- currentConfig.ipAssignment = newConfig.ipAssignment;
- currentConfig.ipConfig = newConfig.ipConfig;
- writeConfigToFile = true;
- }
+ boolean ipChanged = false;
+ boolean proxyChanged = false;
+ LinkProperties linkProperties = new LinkProperties();
+
+ switch (newConfig.ipAssignment) {
+ case STATIC:
+ Collection<LinkAddress> currentLinkAddresses = currentConfig.linkProperties
+ .getLinkAddresses();
+ Collection<LinkAddress> newLinkAddresses = newConfig.linkProperties
+ .getLinkAddresses();
+ Collection<InetAddress> currentDnses = currentConfig.linkProperties.getDnses();
+ Collection<InetAddress> newDnses = newConfig.linkProperties.getDnses();
+ InetAddress currentGateway = currentConfig.linkProperties.getGateway();
+ InetAddress newGateway = newConfig.linkProperties.getGateway();
+
+ boolean linkAddressesDiffer = !currentLinkAddresses.containsAll(newLinkAddresses) ||
+ (currentLinkAddresses.size() != newLinkAddresses.size());
+ boolean dnsesDiffer = !currentDnses.containsAll(newDnses) ||
+ (currentDnses.size() != newDnses.size());
+ boolean gatewaysDiffer = (currentGateway == null) ||
+ !currentGateway.equals(newGateway);
+
+ if ((currentConfig.ipAssignment != newConfig.ipAssignment) ||
+ linkAddressesDiffer ||
+ dnsesDiffer ||
+ gatewaysDiffer) {
+ ipChanged = true;
+ }
+ break;
+ case DHCP:
+ if (currentConfig.ipAssignment != newConfig.ipAssignment) {
+ ipChanged = true;
+ }
+ break;
+ case UNASSIGNED:
+ /* Ignore */
+ break;
+ default:
+ Log.e(TAG, "Ignore invalid ip assignment during write");
+ break;
}
- if (newConfig.proxySettings != ProxySettings.UNASSIGNED) {
- InetSocketAddress newSockAddr = newConfig.proxyProperties.getSocketAddress();
- String newExclusionList = newConfig.proxyProperties.getExclusionList();
+ switch (newConfig.proxySettings) {
+ case STATIC:
+ InetSocketAddress newSockAddr = null;
+ String newExclusionList = null;
+ InetSocketAddress currentSockAddr = null;
+ String currentExclusionList = null;
+
+ ProxyProperties newHttpProxy = newConfig.linkProperties.getHttpProxy();
+ if (newHttpProxy != null) {
+ newSockAddr = newHttpProxy.getSocketAddress();
+ newExclusionList = newHttpProxy.getExclusionList();
+ }
- InetSocketAddress currentSockAddr = currentConfig.proxyProperties.getSocketAddress();
- String currentExclusionList = currentConfig.proxyProperties.getExclusionList();
+ ProxyProperties currentHttpProxy = currentConfig.linkProperties.getHttpProxy();
+ if (currentHttpProxy != null) {
+ currentSockAddr = currentHttpProxy.getSocketAddress();
+ currentExclusionList = currentHttpProxy.getExclusionList();
+ }
- boolean socketAddressDiffers = false;
- boolean exclusionListDiffers = false;
+ boolean socketAddressDiffers = false;
+ boolean exclusionListDiffers = false;
- if (newSockAddr != null && currentSockAddr != null ) {
- socketAddressDiffers = !currentSockAddr.equals(newSockAddr);
- } else if (newSockAddr != null || currentSockAddr != null) {
- socketAddressDiffers = true;
- }
+ if (newSockAddr != null && currentSockAddr != null ) {
+ socketAddressDiffers = !currentSockAddr.equals(newSockAddr);
+ } else if (newSockAddr != null || currentSockAddr != null) {
+ socketAddressDiffers = true;
+ }
- if (newExclusionList != null && currentExclusionList != null) {
- exclusionListDiffers = currentExclusionList.equals(newExclusionList);
- } else if (newExclusionList != null || currentExclusionList != null) {
- exclusionListDiffers = true;
- }
+ if (newExclusionList != null && currentExclusionList != null) {
+ exclusionListDiffers = !currentExclusionList.equals(newExclusionList);
+ } else if (newExclusionList != null || currentExclusionList != null) {
+ exclusionListDiffers = true;
+ }
+
+ if ((currentConfig.proxySettings != newConfig.proxySettings) ||
+ socketAddressDiffers ||
+ exclusionListDiffers) {
+ proxyChanged = true;
+ }
+ break;
+ case NONE:
+ if (currentConfig.proxySettings != newConfig.proxySettings) {
+ proxyChanged = true;
+ }
+ break;
+ case UNASSIGNED:
+ /* Ignore */
+ break;
+ default:
+ Log.e(TAG, "Ignore invalid proxy configuration during write");
+ break;
+ }
- if (newNetwork ||
- (currentConfig.proxySettings != newConfig.proxySettings) ||
- socketAddressDiffers ||
- exclusionListDiffers) {
- currentConfig.proxySettings = newConfig.proxySettings;
- currentConfig.proxyProperties = newConfig.proxyProperties;
- Log.d(TAG, "proxy change SSID = " + currentConfig.SSID + " proxyProperties: " +
- currentConfig.proxyProperties.toString());
- writeConfigToFile = true;
+ if (!ipChanged) {
+ addIpSettingsFromConfig(linkProperties, currentConfig);
+ } else {
+ currentConfig.ipAssignment = newConfig.ipAssignment;
+ addIpSettingsFromConfig(linkProperties, newConfig);
+ Log.d(TAG, "IP config changed SSID = " + currentConfig.SSID + " linkProperties: " +
+ linkProperties.toString());
+ }
+
+
+ if (!proxyChanged) {
+ linkProperties.setHttpProxy(currentConfig.linkProperties.getHttpProxy());
+ } else {
+ currentConfig.proxySettings = newConfig.proxySettings;
+ linkProperties.setHttpProxy(newConfig.linkProperties.getHttpProxy());
+ Log.d(TAG, "proxy changed SSID = " + currentConfig.SSID);
+ if (linkProperties.getHttpProxy() != null) {
+ Log.d(TAG, " proxyProperties: " + linkProperties.getHttpProxy().toString());
}
}
- if (writeConfigToFile) {
+ if (ipChanged || proxyChanged) {
+ currentConfig.linkProperties = linkProperties;
writeIpAndProxyConfigurations();
sendConfigChangeBroadcast();
}
}
+ private static void addIpSettingsFromConfig(LinkProperties linkProperties,
+ WifiConfiguration config) {
+ for (LinkAddress linkAddr : config.linkProperties.getLinkAddresses()) {
+ linkProperties.addLinkAddress(linkAddr);
+ }
+ linkProperties.setGateway(config.linkProperties.getGateway());
+ for (InetAddress dns : config.linkProperties.getDnses()) {
+ linkProperties.addDns(dns);
+ }
+ }
+
/**
* Read the variables from the supplicant daemon that are needed to
* fill in the WifiConfiguration object.
diff --git a/wifi/java/android/net/wifi/WifiConfiguration.java b/wifi/java/android/net/wifi/WifiConfiguration.java
index c4a1310..d5fb63e 100644
--- a/wifi/java/android/net/wifi/WifiConfiguration.java
+++ b/wifi/java/android/net/wifi/WifiConfiguration.java
@@ -16,8 +16,7 @@
package android.net.wifi;
-import android.net.DhcpInfo;
-import android.net.ProxyProperties;
+import android.net.LinkProperties;
import android.os.Parcelable;
import android.os.Parcel;
@@ -303,7 +302,7 @@ public class WifiConfiguration implements Parcelable {
*/
public enum IpAssignment {
/* Use statically configured IP settings. Configuration can be accessed
- * with ipConfig */
+ * with linkProperties */
STATIC,
/* Use dynamically configured IP settigns */
DHCP,
@@ -315,10 +314,6 @@ public class WifiConfiguration implements Parcelable {
* @hide
*/
public IpAssignment ipAssignment;
- /**
- * @hide
- */
- public DhcpInfo ipConfig;
/**
* @hide
@@ -328,7 +323,7 @@ public class WifiConfiguration implements Parcelable {
* should be cleared. */
NONE,
/* Use statically configured proxy. Configuration can be accessed
- * with proxyProperties */
+ * with linkProperties */
STATIC,
/* no proxy details are assigned, this is used to indicate
* that any existing proxy settings should be retained */
@@ -341,7 +336,7 @@ public class WifiConfiguration implements Parcelable {
/**
* @hide
*/
- public ProxyProperties proxyProperties;
+ public LinkProperties linkProperties;
public WifiConfiguration() {
networkId = INVALID_NETWORK_ID;
@@ -361,9 +356,8 @@ public class WifiConfiguration implements Parcelable {
field.setValue(null);
}
ipAssignment = IpAssignment.UNASSIGNED;
- ipConfig = new DhcpInfo();
proxySettings = ProxySettings.UNASSIGNED;
- proxyProperties = new ProxyProperties();
+ linkProperties = new LinkProperties();
}
public String toString() {
@@ -445,17 +439,13 @@ public class WifiConfiguration implements Parcelable {
if (value != null) sbuf.append(value);
}
sbuf.append('\n');
- if (ipAssignment == IpAssignment.STATIC) {
- sbuf.append(" ").append("Static IP configuration:").append('\n');
- sbuf.append(" ").append(ipConfig);
- }
- sbuf.append('\n');
+ sbuf.append("IP assignment: " + ipAssignment.toString());
+ sbuf.append("\n");
+ sbuf.append("Proxy settings: " + proxySettings.toString());
+ sbuf.append("\n");
+ sbuf.append(linkProperties.toString());
+ sbuf.append("\n");
- if (proxySettings == ProxySettings.STATIC) {
- sbuf.append(" ").append("Proxy configuration:").append('\n');
- sbuf.append(" ").append(proxyProperties);
- }
- sbuf.append('\n');
return sbuf.toString();
}
@@ -521,9 +511,8 @@ public class WifiConfiguration implements Parcelable {
enterpriseFields[i].setValue(source.enterpriseFields[i].value());
}
ipAssignment = source.ipAssignment;
- ipConfig = new DhcpInfo(source.ipConfig);
proxySettings = source.proxySettings;
- proxyProperties = new ProxyProperties(source.proxyProperties);
+ linkProperties = new LinkProperties(source.linkProperties);
}
}
@@ -550,15 +539,8 @@ public class WifiConfiguration implements Parcelable {
dest.writeString(field.value());
}
dest.writeString(ipAssignment.name());
- dest.writeInt(ipConfig.ipAddress);
- dest.writeInt(ipConfig.netmask);
- dest.writeInt(ipConfig.gateway);
- dest.writeInt(ipConfig.dns1);
- dest.writeInt(ipConfig.dns2);
- dest.writeInt(ipConfig.serverAddress);
- dest.writeInt(ipConfig.leaseDuration);
dest.writeString(proxySettings.name());
- dest.writeParcelable(proxyProperties, flags);
+ dest.writeParcelable(linkProperties, flags);
}
/** Implement the Parcelable interface {@hide} */
@@ -587,15 +569,8 @@ public class WifiConfiguration implements Parcelable {
}
config.ipAssignment = IpAssignment.valueOf(in.readString());
- config.ipConfig.ipAddress = in.readInt();
- config.ipConfig.netmask = in.readInt();
- config.ipConfig.gateway = in.readInt();
- config.ipConfig.dns1 = in.readInt();
- config.ipConfig.dns2 = in.readInt();
- config.ipConfig.serverAddress = in.readInt();
- config.ipConfig.leaseDuration = in.readInt();
config.proxySettings = ProxySettings.valueOf(in.readString());
- config.proxyProperties = in.readParcelable(null);
+ config.linkProperties = in.readParcelable(null);
return config;
}
diff --git a/wifi/java/android/net/wifi/WifiStateMachine.java b/wifi/java/android/net/wifi/WifiStateMachine.java
index 572abc0..efd0e0a 100644
--- a/wifi/java/android/net/wifi/WifiStateMachine.java
+++ b/wifi/java/android/net/wifi/WifiStateMachine.java
@@ -1253,25 +1253,22 @@ public class WifiStateMachine extends HierarchicalStateMachine {
}
private void configureLinkProperties() {
-
- mLinkProperties.setInterfaceName(mInterfaceName);
-
- // TODO - fix this for v6
- synchronized (mDhcpInfo) {
- mLinkProperties.addLinkAddress(new LinkAddress(
- NetworkUtils.intToInetAddress(mDhcpInfo.ipAddress),
- NetworkUtils.intToInetAddress(mDhcpInfo.netmask)));
- mLinkProperties.setGateway(NetworkUtils.intToInetAddress(mDhcpInfo.gateway));
- mLinkProperties.addDns(NetworkUtils.intToInetAddress(mDhcpInfo.dns1));
- mLinkProperties.addDns(NetworkUtils.intToInetAddress(mDhcpInfo.dns2));
- }
-
- ProxyProperties proxyProperties = WifiConfigStore.getProxyProperties(mLastNetworkId);
- if (proxyProperties != null) {
- mLinkProperties.setHttpProxy(proxyProperties);
- Log.d(TAG, "netId=" + mLastNetworkId + " proxy configured: "
- + proxyProperties.toString());
+ if (WifiConfigStore.isUsingStaticIp(mLastNetworkId)) {
+ mLinkProperties = WifiConfigStore.getLinkProperties(mLastNetworkId);
+ } else {
+ // TODO - fix this for v6
+ synchronized (mDhcpInfo) {
+ mLinkProperties.addLinkAddress(new LinkAddress(
+ NetworkUtils.intToInetAddress(mDhcpInfo.ipAddress),
+ NetworkUtils.intToInetAddress(mDhcpInfo.netmask)));
+ mLinkProperties.setGateway(NetworkUtils.intToInetAddress(mDhcpInfo.gateway));
+ mLinkProperties.addDns(NetworkUtils.intToInetAddress(mDhcpInfo.dns1));
+ mLinkProperties.addDns(NetworkUtils.intToInetAddress(mDhcpInfo.dns2));
+ }
+ mLinkProperties.setHttpProxy(WifiConfigStore.getProxyProperties(mLastNetworkId));
}
+ mLinkProperties.setInterfaceName(mInterfaceName);
+ Log.d(TAG, "netId=" + mLastNetworkId + " Link configured: " + mLinkProperties.toString());
}
private int getMaxDhcpRetries() {
@@ -2571,7 +2568,6 @@ public class WifiStateMachine extends HierarchicalStateMachine {
mLastSignalLevel = -1; // force update of signal strength
synchronized (mDhcpInfo) {
mWifiInfo.setIpAddress(mDhcpInfo.ipAddress);
- Log.d(TAG, "IP configuration: " + mDhcpInfo);
}
configureLinkProperties();
setDetailedState(DetailedState.CONNECTED);