Merge "Downgrade list of subIds in NetworkCapabilities to @SystemApi" am: 42d706acfc

Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1652974

Change-Id: I4dc51bf65af853a7510586169caa12b083c2f94b
This commit is contained in:
Benedict Wong
2021-04-02 23:10:21 +00:00
committed by Automerger Merge Worker
4 changed files with 20 additions and 2 deletions

View File

@@ -298,7 +298,6 @@ package android.net {
method @Nullable public android.net.NetworkSpecifier getNetworkSpecifier(); method @Nullable public android.net.NetworkSpecifier getNetworkSpecifier();
method public int getOwnerUid(); method public int getOwnerUid();
method public int getSignalStrength(); method public int getSignalStrength();
method @NonNull public java.util.Set<java.lang.Integer> getSubIds();
method @Nullable public android.net.TransportInfo getTransportInfo(); method @Nullable public android.net.TransportInfo getTransportInfo();
method public boolean hasCapability(int); method public boolean hasCapability(int);
method public boolean hasTransport(int); method public boolean hasTransport(int);
@@ -408,7 +407,6 @@ package android.net {
method public android.net.NetworkRequest.Builder removeTransportType(int); method public android.net.NetworkRequest.Builder removeTransportType(int);
method @Deprecated public android.net.NetworkRequest.Builder setNetworkSpecifier(String); method @Deprecated public android.net.NetworkRequest.Builder setNetworkSpecifier(String);
method public android.net.NetworkRequest.Builder setNetworkSpecifier(android.net.NetworkSpecifier); method public android.net.NetworkRequest.Builder setNetworkSpecifier(android.net.NetworkSpecifier);
method @NonNull public android.net.NetworkRequest.Builder setSubIds(@NonNull java.util.Set<java.lang.Integer>);
} }
public class ParseException extends java.lang.RuntimeException { public class ParseException extends java.lang.RuntimeException {

View File

@@ -275,6 +275,7 @@ package android.net {
method @NonNull public int[] getAdministratorUids(); method @NonNull public int[] getAdministratorUids();
method @Nullable public static String getCapabilityCarrierName(int); method @Nullable public static String getCapabilityCarrierName(int);
method @Nullable public String getSsid(); method @Nullable public String getSsid();
method @NonNull public java.util.Set<java.lang.Integer> getSubIds();
method @NonNull public int[] getTransportTypes(); method @NonNull public int[] getTransportTypes();
method public boolean isPrivateDnsBroken(); method public boolean isPrivateDnsBroken();
method public boolean satisfiedByNetworkCapabilities(@Nullable android.net.NetworkCapabilities); method public boolean satisfiedByNetworkCapabilities(@Nullable android.net.NetworkCapabilities);
@@ -328,6 +329,7 @@ package android.net {
public static class NetworkRequest.Builder { public static class NetworkRequest.Builder {
method @NonNull @RequiresPermission(android.Manifest.permission.NETWORK_SIGNAL_STRENGTH_WAKEUP) public android.net.NetworkRequest.Builder setSignalStrength(int); method @NonNull @RequiresPermission(android.Manifest.permission.NETWORK_SIGNAL_STRENGTH_WAKEUP) public android.net.NetworkRequest.Builder setSignalStrength(int);
method @NonNull public android.net.NetworkRequest.Builder setSubIds(@NonNull java.util.Set<java.lang.Integer>);
} }
public final class NetworkScore implements android.os.Parcelable { public final class NetworkScore implements android.os.Parcelable {

View File

@@ -2363,9 +2363,15 @@ public final class NetworkCapabilities implements Parcelable {
/** /**
* Gets the subscription ID set that associated to this network or request. * Gets the subscription ID set that associated to this network or request.
*
* <p>Instances of NetworkCapabilities will only have this field populated by the system if the
* receiver holds the NETWORK_FACTORY permission. In all other cases, it will be the empty set.
*
* @return * @return
* @hide
*/ */
@NonNull @NonNull
@SystemApi
public Set<Integer> getSubIds() { public Set<Integer> getSubIds() {
return new ArraySet<>(mSubIds); return new ArraySet<>(mSubIds);
} }
@@ -2730,10 +2736,17 @@ public final class NetworkCapabilities implements Parcelable {
/** /**
* Set the subscription ID set. * Set the subscription ID set.
* *
* <p>SubIds are populated in NetworkCapability instances from the system only for callers
* that hold the NETWORK_FACTORY permission. Similarly, the system will reject any
* NetworkRequests filed with a non-empty set of subIds unless the caller holds the
* NETWORK_FACTORY permission.
*
* @param subIds a set that represent the subscription IDs. Empty if clean up. * @param subIds a set that represent the subscription IDs. Empty if clean up.
* @return this builder. * @return this builder.
* @hide
*/ */
@NonNull @NonNull
@SystemApi
public Builder setSubIds(@NonNull final Set<Integer> subIds) { public Builder setSubIds(@NonNull final Set<Integer> subIds) {
mCaps.setSubIds(subIds); mCaps.setSubIds(subIds);
return this; return this;

View File

@@ -501,9 +501,14 @@ public class NetworkRequest implements Parcelable {
* A network will satisfy this request only if it matches one of the subIds in this set. * A network will satisfy this request only if it matches one of the subIds in this set.
* An empty set matches all networks, including those without a subId. * An empty set matches all networks, including those without a subId.
* *
* <p>Registering a NetworkRequest with a non-empty set of subIds requires the
* NETWORK_FACTORY permission.
*
* @param subIds A {@code Set} that represents subscription IDs. * @param subIds A {@code Set} that represents subscription IDs.
* @hide
*/ */
@NonNull @NonNull
@SystemApi
public Builder setSubIds(@NonNull Set<Integer> subIds) { public Builder setSubIds(@NonNull Set<Integer> subIds) {
mNetworkCapabilities.setSubIds(subIds); mNetworkCapabilities.setSubIds(subIds);
return this; return this;