Update the docs for NetworkCapabilities

Preparing for ConnectivityService API update

Change-Id: I397e375b9254d4271183cf34c4a689deea1e198e
This commit is contained in:
Robert Greenwalt
2014-05-18 15:24:21 -07:00
parent 8b57c411e4
commit 37546d8177

View File

@@ -30,13 +30,31 @@ import java.util.Map.Entry;
import java.util.Set; import java.util.Set;
/** /**
* A class representing the capabilities of a network * This class represents the capabilities of a network. This is used both to specify
* @hide * needs to {@link ConnectivityManager} and when inspecting a network.
*
* Note that this replaces the old {@link ConnectivityManager#TYPE_MOBILE} method
* of network selection. Rather than indicate a need for Wi-Fi because an application
* needs high bandwidth and risk obselence when a new, fast network appears (like LTE),
* the application should specify it needs high bandwidth. Similarly if an application
* needs an unmetered network for a bulk transfer it can specify that rather than assuming
* all cellular based connections are metered and all Wi-Fi based connections are not.
*/ */
public final class NetworkCapabilities implements Parcelable { public final class NetworkCapabilities implements Parcelable {
private static final String TAG = "NetworkCapabilities"; private static final String TAG = "NetworkCapabilities";
private static final boolean DBG = false; private static final boolean DBG = false;
public NetworkCapabilities() {
}
public NetworkCapabilities(NetworkCapabilities nc) {
if (nc != null) {
mNetworkCapabilities = nc.mNetworkCapabilities;
mTransportTypes = nc.mTransportTypes;
mLinkUpBandwidthKbps = nc.mLinkUpBandwidthKbps;
mLinkDownBandwidthKbps = nc.mLinkDownBandwidthKbps;
}
}
/** /**
* Represents the network's capabilities. If any are specified they will be satisfied * Represents the network's capabilities. If any are specified they will be satisfied
@@ -45,28 +63,99 @@ public final class NetworkCapabilities implements Parcelable {
private long mNetworkCapabilities = (1 << NET_CAPABILITY_NOT_RESTRICTED); private long mNetworkCapabilities = (1 << NET_CAPABILITY_NOT_RESTRICTED);
/** /**
* Values for NetworkCapabilities. Roughly matches/extends deprecated * Indicates this is a network that has the ability to reach the
* ConnectivityManager TYPE_* * carrier's MMSC for sending and receiving MMS messages.
*/ */
public static final int NET_CAPABILITY_MMS = 0; public static final int NET_CAPABILITY_MMS = 0;
/**
* Indicates this is a network that has the ability to reach the carrier's
* SUPL server, used to retrieve GPS information.
*/
public static final int NET_CAPABILITY_SUPL = 1; public static final int NET_CAPABILITY_SUPL = 1;
/**
* Indicates this is a network that has the ability to reach the carrier's
* DUN or tethering gateway.
*/
public static final int NET_CAPABILITY_DUN = 2; public static final int NET_CAPABILITY_DUN = 2;
/**
* Indicates this is a network that has the ability to reach the carrier's
* FOTA portal, used for over the air updates.
*/
public static final int NET_CAPABILITY_FOTA = 3; public static final int NET_CAPABILITY_FOTA = 3;
/**
* Indicates this is a network that has the ability to reach the carrier's
* IMS servers, used for network registration and signaling.
*/
public static final int NET_CAPABILITY_IMS = 4; public static final int NET_CAPABILITY_IMS = 4;
/**
* Indicates this is a network that has the ability to reach the carrier's
* CBS servers, used for carrier specific services.
*/
public static final int NET_CAPABILITY_CBS = 5; public static final int NET_CAPABILITY_CBS = 5;
/**
* Indicates this is a network that has the ability to reach a Wi-Fi direct
* peer.
*/
public static final int NET_CAPABILITY_WIFI_P2P = 6; public static final int NET_CAPABILITY_WIFI_P2P = 6;
/**
* Indicates this is a network that has the ability to reach a carrier's
* Initial Attach servers.
*/
public static final int NET_CAPABILITY_IA = 7; public static final int NET_CAPABILITY_IA = 7;
/**
* Indicates this is a network that has the ability to reach a carrier's
* RCS servers, used for Rich Communication Services.
*/
public static final int NET_CAPABILITY_RCS = 8; public static final int NET_CAPABILITY_RCS = 8;
/**
* Indicates this is a network that has the ability to reach a carrier's
* XCAP servers, used for configuration and control.
*/
public static final int NET_CAPABILITY_XCAP = 9; public static final int NET_CAPABILITY_XCAP = 9;
/**
* Indicates this is a network that has the ability to reach a carrier's
* Emergency IMS servers, used for network signaling during emergency calls.
*/
public static final int NET_CAPABILITY_EIMS = 10; public static final int NET_CAPABILITY_EIMS = 10;
/**
* Indicates that this network is unmetered.
*/
public static final int NET_CAPABILITY_NOT_METERED = 11; public static final int NET_CAPABILITY_NOT_METERED = 11;
/**
* Indicates that this network should be able to reach the internet.
*/
public static final int NET_CAPABILITY_INTERNET = 12; public static final int NET_CAPABILITY_INTERNET = 12;
/** Set by default */
/**
* Indicates that this network is available for general use. If this is not set
* applications should not attempt to communicate on this network. Note that this
* is simply informative and not enforcement - enforcement is handled via other means.
* Set by default.
*/
public static final int NET_CAPABILITY_NOT_RESTRICTED = 13; public static final int NET_CAPABILITY_NOT_RESTRICTED = 13;
private static final int MIN_NET_CAPABILITY = NET_CAPABILITY_MMS; private static final int MIN_NET_CAPABILITY = NET_CAPABILITY_MMS;
private static final int MAX_NET_CAPABILITY = NET_CAPABILITY_NOT_RESTRICTED; private static final int MAX_NET_CAPABILITY = NET_CAPABILITY_NOT_RESTRICTED;
/**
* Adds the given capability to this {@code NetworkCapability} instance.
* Multiple capabilities may be applied sequentially. Note that when searching
* for a network to satisfy a request, all capabilities requested must be satisfied.
*
* @param networkCapability the {@code NetworkCapabilities.NET_CAPABILITY_*} to be added.
*/
public void addNetworkCapability(int networkCapability) { public void addNetworkCapability(int networkCapability) {
if (networkCapability < MIN_NET_CAPABILITY || if (networkCapability < MIN_NET_CAPABILITY ||
networkCapability > MAX_NET_CAPABILITY) { networkCapability > MAX_NET_CAPABILITY) {
@@ -74,6 +163,12 @@ public final class NetworkCapabilities implements Parcelable {
} }
mNetworkCapabilities |= 1 << networkCapability; mNetworkCapabilities |= 1 << networkCapability;
} }
/**
* Removes (if found) the given capability from this {@code NetworkCapability} instance.
*
* @param networkCapability the {@code NetworkCapabilities.NET_CAPABILTIY_*} to be removed.
*/
public void removeNetworkCapability(int networkCapability) { public void removeNetworkCapability(int networkCapability) {
if (networkCapability < MIN_NET_CAPABILITY || if (networkCapability < MIN_NET_CAPABILITY ||
networkCapability > MAX_NET_CAPABILITY) { networkCapability > MAX_NET_CAPABILITY) {
@@ -81,9 +176,23 @@ public final class NetworkCapabilities implements Parcelable {
} }
mNetworkCapabilities &= ~(1 << networkCapability); mNetworkCapabilities &= ~(1 << networkCapability);
} }
/**
* Gets all the capabilities set on this {@code NetworkCapability} instance.
*
* @return a {@link Collection} of {@code NetworkCapabilities.NET_CAPABILITY_*} values
* for this instance.
*/
public Collection<Integer> getNetworkCapabilities() { public Collection<Integer> getNetworkCapabilities() {
return enumerateBits(mNetworkCapabilities); return enumerateBits(mNetworkCapabilities);
} }
/**
* Tests for the presence of a capabilitity on this instance.
*
* @param networkCapability the {@code NetworkCapabilities.NET_CAPABILITY_*} to be tested for.
* @return {@code true} if set on this instance.
*/
public boolean hasCapability(int networkCapability) { public boolean hasCapability(int networkCapability) {
if (networkCapability < MIN_NET_CAPABILITY || if (networkCapability < MIN_NET_CAPABILITY ||
networkCapability > MAX_NET_CAPABILITY) { networkCapability > MAX_NET_CAPABILITY) {
@@ -124,31 +233,74 @@ public final class NetworkCapabilities implements Parcelable {
private long mTransportTypes; private long mTransportTypes;
/** /**
* Values for TransportType * Indicates this network uses a Cellular transport.
*/ */
public static final int TRANSPORT_CELLULAR = 0; public static final int TRANSPORT_CELLULAR = 0;
/**
* Indicates this network uses a Wi-Fi transport.
*/
public static final int TRANSPORT_WIFI = 1; public static final int TRANSPORT_WIFI = 1;
/**
* Indicates this network uses a Bluetooth transport.
*/
public static final int TRANSPORT_BLUETOOTH = 2; public static final int TRANSPORT_BLUETOOTH = 2;
/**
* Indicates this network uses an Ethernet transport.
*/
public static final int TRANSPORT_ETHERNET = 3; public static final int TRANSPORT_ETHERNET = 3;
private static final int MIN_TRANSPORT = TRANSPORT_CELLULAR; private static final int MIN_TRANSPORT = TRANSPORT_CELLULAR;
private static final int MAX_TRANSPORT = TRANSPORT_ETHERNET; private static final int MAX_TRANSPORT = TRANSPORT_ETHERNET;
/**
* Adds the given transport type to this {@code NetworkCapability} instance.
* Multiple transports may be applied sequentially. Note that when searching
* for a network to satisfy a request, any listed in the request will satisfy the request.
* For example {@code TRANSPORT_WIFI} and {@code TRANSPORT_ETHERNET} added to a
* {@code NetworkCapabilities} would cause either a Wi-Fi network or an Ethernet network
* to be selected. This is logically different than
* {@code NetworkCapabilities.NET_CAPABILITY_*} listed above.
*
* @param transportType the {@code NetworkCapabilities.TRANSPORT_*} to be added.
*/
public void addTransportType(int transportType) { public void addTransportType(int transportType) {
if (transportType < MIN_TRANSPORT || transportType > MAX_TRANSPORT) { if (transportType < MIN_TRANSPORT || transportType > MAX_TRANSPORT) {
throw new IllegalArgumentException("TransportType out of range"); throw new IllegalArgumentException("TransportType out of range");
} }
mTransportTypes |= 1 << transportType; mTransportTypes |= 1 << transportType;
} }
/**
* Removes (if found) the given transport from this {@code NetworkCapability} instance.
*
* @param transportType the {@code NetworkCapabilities.TRANSPORT_*} to be removed.
*/
public void removeTransportType(int transportType) { public void removeTransportType(int transportType) {
if (transportType < MIN_TRANSPORT || transportType > MAX_TRANSPORT) { if (transportType < MIN_TRANSPORT || transportType > MAX_TRANSPORT) {
throw new IllegalArgumentException("TransportType out of range"); throw new IllegalArgumentException("TransportType out of range");
} }
mTransportTypes &= ~(1 << transportType); mTransportTypes &= ~(1 << transportType);
} }
/**
* Gets all the transports set on this {@code NetworkCapability} instance.
*
* @return a {@link Collection} of {@code NetworkCapabilities.TRANSPORT_*} values
* for this instance.
*/
public Collection<Integer> getTransportTypes() { public Collection<Integer> getTransportTypes() {
return enumerateBits(mTransportTypes); return enumerateBits(mTransportTypes);
} }
/**
* Tests for the presence of a transport on this instance.
*
* @param transportType the {@code NetworkCapabilities.TRANSPORT_*} to be tested for.
* @return {@code true} if set on this instance.
*/
public boolean hasTransport(int transportType) { public boolean hasTransport(int transportType) {
if (transportType < MIN_TRANSPORT || transportType > MAX_TRANSPORT) { if (transportType < MIN_TRANSPORT || transportType > MAX_TRANSPORT) {
return false; return false;
@@ -175,15 +327,58 @@ public final class NetworkCapabilities implements Parcelable {
private int mLinkUpBandwidthKbps; private int mLinkUpBandwidthKbps;
private int mLinkDownBandwidthKbps; private int mLinkDownBandwidthKbps;
/**
* Sets the upstream bandwidth for this network in Kbps. This always only refers to
* the estimated first hop transport bandwidth.
* <p>
* Note that when used to request a network, this specifies the minimum acceptable.
* When received as the state of an existing network this specifies the typical
* first hop bandwidth expected. This is never measured, but rather is inferred
* from technology type and other link parameters. It could be used to differentiate
* between very slow 1xRTT cellular links and other faster networks or even between
* 802.11b vs 802.11AC wifi technologies. It should not be used to differentiate between
* fast backhauls and slow backhauls.
*
* @param upKbps the estimated first hop upstream (device to network) bandwidth.
*/
public void setLinkUpstreamBandwidthKbps(int upKbps) { public void setLinkUpstreamBandwidthKbps(int upKbps) {
mLinkUpBandwidthKbps = upKbps; mLinkUpBandwidthKbps = upKbps;
} }
/**
* Retrieves the upstream bandwidth for this network in Kbps. This always only refers to
* the estimated first hop transport bandwidth.
*
* @return The estimated first hop upstream (device to network) bandwidth.
*/
public int getLinkUpstreamBandwidthKbps() { public int getLinkUpstreamBandwidthKbps() {
return mLinkUpBandwidthKbps; return mLinkUpBandwidthKbps;
} }
/**
* Sets the downstream bandwidth for this network in Kbps. This always only refers to
* the estimated first hop transport bandwidth.
* <p>
* Note that when used to request a network, this specifies the minimum acceptable.
* When received as the state of an existing network this specifies the typical
* first hop bandwidth expected. This is never measured, but rather is inferred
* from technology type and other link parameters. It could be used to differentiate
* between very slow 1xRTT cellular links and other faster networks or even between
* 802.11b vs 802.11AC wifi technologies. It should not be used to differentiate between
* fast backhauls and slow backhauls.
*
* @param downKbps the estimated first hop downstream (network to device) bandwidth.
*/
public void setLinkDownstreamBandwidthKbps(int downKbps) { public void setLinkDownstreamBandwidthKbps(int downKbps) {
mLinkDownBandwidthKbps = downKbps; mLinkDownBandwidthKbps = downKbps;
} }
/**
* Retrieves the downstream bandwidth for this network in Kbps. This always only refers to
* the estimated first hop transport bandwidth.
*
* @return The estimated first hop downstream (network to device) bandwidth.
*/
public int getLinkDownstreamBandwidthKbps() { public int getLinkDownstreamBandwidthKbps() {
return mLinkDownBandwidthKbps; return mLinkDownBandwidthKbps;
} }
@@ -243,19 +438,6 @@ public final class NetworkCapabilities implements Parcelable {
(mLinkDownBandwidthKbps * 13)); (mLinkDownBandwidthKbps * 13));
} }
public NetworkCapabilities() {
}
public NetworkCapabilities(NetworkCapabilities nc) {
if (nc != null) {
mNetworkCapabilities = nc.mNetworkCapabilities;
mTransportTypes = nc.mTransportTypes;
mLinkUpBandwidthKbps = nc.mLinkUpBandwidthKbps;
mLinkDownBandwidthKbps = nc.mLinkDownBandwidthKbps;
}
}
// Parcelable
public int describeContents() { public int describeContents() {
return 0; return 0;
} }