Merge "[SUBID01-0]Grow NetworkIdentity to include a new mSubId field"

This commit is contained in:
Frank Li
2022-03-02 12:26:11 +00:00
committed by Gerrit Code Review
4 changed files with 75 additions and 12 deletions

View File

@@ -20,6 +20,7 @@ import static android.annotation.SystemApi.Client.MODULE_LIBRARIES;
import static android.net.ConnectivityManager.TYPE_MOBILE; import static android.net.ConnectivityManager.TYPE_MOBILE;
import static android.net.ConnectivityManager.TYPE_WIFI; import static android.net.ConnectivityManager.TYPE_WIFI;
import static android.net.NetworkTemplate.NETWORK_TYPE_ALL; import static android.net.NetworkTemplate.NETWORK_TYPE_ALL;
import static android.telephony.SubscriptionManager.INVALID_SUBSCRIPTION_ID;
import android.annotation.IntDef; import android.annotation.IntDef;
import android.annotation.NonNull; import android.annotation.NonNull;
@@ -86,6 +87,7 @@ public class NetworkIdentity {
final int mType; final int mType;
final int mRatType; final int mRatType;
final int mSubId;
final String mSubscriberId; final String mSubscriberId;
final String mWifiNetworkKey; final String mWifiNetworkKey;
final boolean mRoaming; final boolean mRoaming;
@@ -96,7 +98,7 @@ public class NetworkIdentity {
/** @hide */ /** @hide */
public NetworkIdentity( public NetworkIdentity(
int type, int ratType, @Nullable String subscriberId, @Nullable String wifiNetworkKey, int type, int ratType, @Nullable String subscriberId, @Nullable String wifiNetworkKey,
boolean roaming, boolean metered, boolean defaultNetwork, int oemManaged) { boolean roaming, boolean metered, boolean defaultNetwork, int oemManaged, int subId) {
mType = type; mType = type;
mRatType = ratType; mRatType = ratType;
mSubscriberId = subscriberId; mSubscriberId = subscriberId;
@@ -105,12 +107,13 @@ public class NetworkIdentity {
mMetered = metered; mMetered = metered;
mDefaultNetwork = defaultNetwork; mDefaultNetwork = defaultNetwork;
mOemManaged = oemManaged; mOemManaged = oemManaged;
mSubId = subId;
} }
@Override @Override
public int hashCode() { public int hashCode() {
return Objects.hash(mType, mRatType, mSubscriberId, mWifiNetworkKey, mRoaming, mMetered, return Objects.hash(mType, mRatType, mSubscriberId, mWifiNetworkKey, mRoaming, mMetered,
mDefaultNetwork, mOemManaged); mDefaultNetwork, mOemManaged, mSubId);
} }
@Override @Override
@@ -122,7 +125,8 @@ public class NetworkIdentity {
&& Objects.equals(mWifiNetworkKey, ident.mWifiNetworkKey) && Objects.equals(mWifiNetworkKey, ident.mWifiNetworkKey)
&& mMetered == ident.mMetered && mMetered == ident.mMetered
&& mDefaultNetwork == ident.mDefaultNetwork && mDefaultNetwork == ident.mDefaultNetwork
&& mOemManaged == ident.mOemManaged; && mOemManaged == ident.mOemManaged
&& mSubId == ident.mSubId;
} }
return false; return false;
} }
@@ -150,6 +154,7 @@ public class NetworkIdentity {
builder.append(", metered=").append(mMetered); builder.append(", metered=").append(mMetered);
builder.append(", defaultNetwork=").append(mDefaultNetwork); builder.append(", defaultNetwork=").append(mDefaultNetwork);
builder.append(", oemManaged=").append(getOemManagedNames(mOemManaged)); builder.append(", oemManaged=").append(getOemManagedNames(mOemManaged));
builder.append(", subId=").append(mSubId);
return builder.append("}").toString(); return builder.append("}").toString();
} }
@@ -256,6 +261,11 @@ public class NetworkIdentity {
return mOemManaged; return mOemManaged;
} }
/** Get the SubId of this instance. */
public int getSubId() {
return mSubId;
}
/** /**
* Assemble a {@link NetworkIdentity} from the passed arguments. * Assemble a {@link NetworkIdentity} from the passed arguments.
* *
@@ -276,7 +286,8 @@ public class NetworkIdentity {
public static NetworkIdentity buildNetworkIdentity(Context context, public static NetworkIdentity buildNetworkIdentity(Context context,
@NonNull NetworkStateSnapshot snapshot, boolean defaultNetwork, int ratType) { @NonNull NetworkStateSnapshot snapshot, boolean defaultNetwork, int ratType) {
final NetworkIdentity.Builder builder = new NetworkIdentity.Builder() final NetworkIdentity.Builder builder = new NetworkIdentity.Builder()
.setNetworkStateSnapshot(snapshot).setDefaultNetwork(defaultNetwork); .setNetworkStateSnapshot(snapshot).setDefaultNetwork(defaultNetwork)
.setSubId(snapshot.getSubId());
if (snapshot.getLegacyType() == TYPE_MOBILE && ratType != NETWORK_TYPE_ALL) { if (snapshot.getLegacyType() == TYPE_MOBILE && ratType != NETWORK_TYPE_ALL) {
builder.setRatType(ratType); builder.setRatType(ratType);
} }
@@ -325,6 +336,9 @@ public class NetworkIdentity {
if (res == 0) { if (res == 0) {
res = Integer.compare(left.mOemManaged, right.mOemManaged); res = Integer.compare(left.mOemManaged, right.mOemManaged);
} }
if (res == 0) {
res = Integer.compare(left.mSubId, right.mSubId);
}
return res; return res;
} }
@@ -345,6 +359,7 @@ public class NetworkIdentity {
private boolean mMetered; private boolean mMetered;
private boolean mDefaultNetwork; private boolean mDefaultNetwork;
private int mOemManaged; private int mOemManaged;
private int mSubId;
/** /**
* Creates a new Builder. * Creates a new Builder.
@@ -359,6 +374,7 @@ public class NetworkIdentity {
mMetered = false; mMetered = false;
mDefaultNetwork = false; mDefaultNetwork = false;
mOemManaged = NetworkTemplate.OEM_MANAGED_NO; mOemManaged = NetworkTemplate.OEM_MANAGED_NO;
mSubId = INVALID_SUBSCRIPTION_ID;
} }
/** /**
@@ -537,6 +553,19 @@ public class NetworkIdentity {
return this; return this;
} }
/**
* Set the Subscription Id.
*
* @param subId the Subscription Id of the network. Or INVALID_SUBSCRIPTION_ID if not
* applicable.
* @return this builder.
*/
@NonNull
public Builder setSubId(int subId) {
mSubId = subId;
return this;
}
private void ensureValidParameters() { private void ensureValidParameters() {
// Assert non-mobile network cannot have a ratType. // Assert non-mobile network cannot have a ratType.
if (mType != TYPE_MOBILE && mRatType != NetworkTemplate.NETWORK_TYPE_ALL) { if (mType != TYPE_MOBILE && mRatType != NetworkTemplate.NETWORK_TYPE_ALL) {
@@ -559,7 +588,7 @@ public class NetworkIdentity {
public NetworkIdentity build() { public NetworkIdentity build() {
ensureValidParameters(); ensureValidParameters();
return new NetworkIdentity(mType, mRatType, mSubscriberId, mWifiNetworkKey, return new NetworkIdentity(mType, mRatType, mSubscriberId, mWifiNetworkKey,
mRoaming, mMetered, mDefaultNetwork, mOemManaged); mRoaming, mMetered, mDefaultNetwork, mOemManaged, mSubId);
} }
} }
} }

View File

@@ -17,6 +17,7 @@
package android.net; package android.net;
import static android.net.ConnectivityManager.TYPE_MOBILE; import static android.net.ConnectivityManager.TYPE_MOBILE;
import static android.telephony.SubscriptionManager.INVALID_SUBSCRIPTION_ID;
import android.annotation.NonNull; import android.annotation.NonNull;
import android.service.NetworkIdentitySetProto; import android.service.NetworkIdentitySetProto;
@@ -42,6 +43,7 @@ public class NetworkIdentitySet extends HashSet<NetworkIdentity> {
private static final int VERSION_ADD_METERED = 4; private static final int VERSION_ADD_METERED = 4;
private static final int VERSION_ADD_DEFAULT_NETWORK = 5; private static final int VERSION_ADD_DEFAULT_NETWORK = 5;
private static final int VERSION_ADD_OEM_MANAGED_NETWORK = 6; private static final int VERSION_ADD_OEM_MANAGED_NETWORK = 6;
private static final int VERSION_ADD_SUB_ID = 7;
/** /**
* Construct a {@link NetworkIdentitySet} object. * Construct a {@link NetworkIdentitySet} object.
@@ -103,8 +105,15 @@ public class NetworkIdentitySet extends HashSet<NetworkIdentity> {
oemNetCapabilities = NetworkIdentity.OEM_NONE; oemNetCapabilities = NetworkIdentity.OEM_NONE;
} }
final int subId;
if (version >= VERSION_ADD_SUB_ID) {
subId = in.readInt();
} else {
subId = INVALID_SUBSCRIPTION_ID;
}
add(new NetworkIdentity(type, ratType, subscriberId, networkId, roaming, metered, add(new NetworkIdentity(type, ratType, subscriberId, networkId, roaming, metered,
defaultNetwork, oemNetCapabilities)); defaultNetwork, oemNetCapabilities, subId));
} }
} }
@@ -113,7 +122,7 @@ public class NetworkIdentitySet extends HashSet<NetworkIdentity> {
* @hide * @hide
*/ */
public void writeToStream(DataOutput out) throws IOException { public void writeToStream(DataOutput out) throws IOException {
out.writeInt(VERSION_ADD_OEM_MANAGED_NETWORK); out.writeInt(VERSION_ADD_SUB_ID);
out.writeInt(size()); out.writeInt(size());
for (NetworkIdentity ident : this) { for (NetworkIdentity ident : this) {
out.writeInt(ident.getType()); out.writeInt(ident.getType());
@@ -124,6 +133,7 @@ public class NetworkIdentitySet extends HashSet<NetworkIdentity> {
out.writeBoolean(ident.isMetered()); out.writeBoolean(ident.isMetered());
out.writeBoolean(ident.isDefaultNetwork()); out.writeBoolean(ident.isDefaultNetwork());
out.writeInt(ident.getOemManaged()); out.writeInt(ident.getOemManaged());
out.writeInt(ident.getSubId());
} }
} }

View File

@@ -17,6 +17,8 @@
package android.net; package android.net;
import static android.annotation.SystemApi.Client.MODULE_LIBRARIES; import static android.annotation.SystemApi.Client.MODULE_LIBRARIES;
import static android.net.NetworkCapabilities.TRANSPORT_CELLULAR;
import static android.telephony.SubscriptionManager.INVALID_SUBSCRIPTION_ID;
import android.annotation.NonNull; import android.annotation.NonNull;
import android.annotation.Nullable; import android.annotation.Nullable;
@@ -98,12 +100,29 @@ public final class NetworkStateSnapshot implements Parcelable {
return mLinkProperties; return mLinkProperties;
} }
/** Get the Subscriber Id of the network associated with this snapshot. */ /**
* Get the Subscriber Id of the network associated with this snapshot.
* @deprecated Please use #getSubId, which doesn't return personally identifiable
* information.
*/
@Deprecated
@Nullable @Nullable
public String getSubscriberId() { public String getSubscriberId() {
return mSubscriberId; return mSubscriberId;
} }
/** Get the subId of the network associated with this snapshot. */
public int getSubId() {
if (mNetworkCapabilities.hasTransport(TRANSPORT_CELLULAR)) {
final NetworkSpecifier spec = mNetworkCapabilities.getNetworkSpecifier();
if (spec instanceof TelephonyNetworkSpecifier) {
return ((TelephonyNetworkSpecifier) spec).getSubscriptionId();
}
}
return INVALID_SUBSCRIPTION_ID;
}
/** /**
* Get the legacy type of the network associated with this snapshot. * Get the legacy type of the network associated with this snapshot.
* @return the legacy network type. See {@code ConnectivityManager#TYPE_*}. * @return the legacy network type. See {@code ConnectivityManager#TYPE_*}.

View File

@@ -1540,10 +1540,15 @@ public class NetworkStatsService extends INetworkStatsService.Stub {
NetworkCapabilities.NET_CAPABILITY_IMS) && !ident.isMetered()) { NetworkCapabilities.NET_CAPABILITY_IMS) && !ident.isMetered()) {
// Copy the identify from IMS one but mark it as metered. // Copy the identify from IMS one but mark it as metered.
NetworkIdentity vtIdent = new NetworkIdentity(ident.getType(), NetworkIdentity vtIdent = new NetworkIdentity.Builder()
ident.getRatType(), ident.getSubscriberId(), ident.getWifiNetworkKey(), .setType(ident.getType())
ident.isRoaming(), true /* metered */, .setRatType(ident.getRatType())
true /* onDefaultNetwork */, ident.getOemManaged()); .setSubscriberId(ident.getSubscriberId())
.setWifiNetworkKey(ident.getWifiNetworkKey())
.setRoaming(ident.isRoaming()).setMetered(true)
.setDefaultNetwork(true)
.setOemManaged(ident.getOemManaged())
.setSubId(ident.getSubId()).build();
final String ifaceVt = IFACE_VT + getSubIdForMobile(snapshot); final String ifaceVt = IFACE_VT + getSubIdForMobile(snapshot);
findOrCreateNetworkIdentitySet(mActiveIfaces, ifaceVt).add(vtIdent); findOrCreateNetworkIdentitySet(mActiveIfaces, ifaceVt).add(vtIdent);
findOrCreateNetworkIdentitySet(mActiveUidIfaces, ifaceVt).add(vtIdent); findOrCreateNetworkIdentitySet(mActiveUidIfaces, ifaceVt).add(vtIdent);