Merge changes from topic "del-factory-and-networkagent-wifi"
* changes: Delete NetworkFactory from frameworks/base/core. New NetworkAgentConfig API to replace NetworkInfo WiFi stuff.
This commit is contained in:
@@ -22,6 +22,8 @@ import android.annotation.SystemApi;
|
|||||||
import android.os.Parcel;
|
import android.os.Parcel;
|
||||||
import android.os.Parcelable;
|
import android.os.Parcelable;
|
||||||
|
|
||||||
|
import java.util.Objects;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Allows a network transport to provide the system with policy and configuration information about
|
* Allows a network transport to provide the system with policy and configuration information about
|
||||||
* a particular network when registering a {@link NetworkAgent}. This information cannot change once the agent is registered.
|
* a particular network when registering a {@link NetworkAgent}. This information cannot change once the agent is registered.
|
||||||
@@ -51,23 +53,47 @@ public final class NetworkAgentConfig implements Parcelable {
|
|||||||
*/
|
*/
|
||||||
public boolean explicitlySelected;
|
public boolean explicitlySelected;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return whether this network was explicitly selected by the user.
|
||||||
|
*/
|
||||||
|
public boolean isExplicitlySelected() {
|
||||||
|
return explicitlySelected;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set if the user desires to use this network even if it is unvalidated. This field has meaning
|
* Set if the user desires to use this network even if it is unvalidated. This field has meaning
|
||||||
* only if {@link explicitlySelected} is true. If it is, this field must also be set to the
|
* only if {@link explicitlySelected} is true. If it is, this field must also be set to the
|
||||||
* appropriate value based on previous user choice.
|
* appropriate value based on previous user choice.
|
||||||
*
|
*
|
||||||
|
* TODO : rename this field to match its accessor
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
public boolean acceptUnvalidated;
|
public boolean acceptUnvalidated;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return whether the system should accept this network even if it doesn't validate.
|
||||||
|
*/
|
||||||
|
public boolean isUnvalidatedConnectivityAcceptable() {
|
||||||
|
return acceptUnvalidated;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether the user explicitly set that this network should be validated even if presence of
|
* Whether the user explicitly set that this network should be validated even if presence of
|
||||||
* only partial internet connectivity.
|
* only partial internet connectivity.
|
||||||
*
|
*
|
||||||
|
* TODO : rename this field to match its accessor
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
public boolean acceptPartialConnectivity;
|
public boolean acceptPartialConnectivity;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return whether the system should validate this network even if it only offers partial
|
||||||
|
* Internet connectivity.
|
||||||
|
*/
|
||||||
|
public boolean isPartialConnectivityAcceptable() {
|
||||||
|
return acceptPartialConnectivity;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Set to avoid surfacing the "Sign in to network" notification.
|
* Set to avoid surfacing the "Sign in to network" notification.
|
||||||
* if carrier receivers/apps are registered to handle the carrier-specific provisioning
|
* if carrier receivers/apps are registered to handle the carrier-specific provisioning
|
||||||
@@ -134,9 +160,11 @@ public final class NetworkAgentConfig implements Parcelable {
|
|||||||
* Set to true if the PRIVATE_DNS_BROKEN notification has shown for this network.
|
* Set to true if the PRIVATE_DNS_BROKEN notification has shown for this network.
|
||||||
* Reset this bit when private DNS mode is changed from strict mode to opportunistic/off mode.
|
* Reset this bit when private DNS mode is changed from strict mode to opportunistic/off mode.
|
||||||
*
|
*
|
||||||
|
* This is not parceled, because it would not make sense.
|
||||||
|
*
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
public boolean hasShownBroken;
|
public transient boolean hasShownBroken;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The name of the legacy network type. It's a free-form string used in logging.
|
* The name of the legacy network type. It's a free-form string used in logging.
|
||||||
@@ -163,6 +191,7 @@ public final class NetworkAgentConfig implements Parcelable {
|
|||||||
allowBypass = nac.allowBypass;
|
allowBypass = nac.allowBypass;
|
||||||
explicitlySelected = nac.explicitlySelected;
|
explicitlySelected = nac.explicitlySelected;
|
||||||
acceptUnvalidated = nac.acceptUnvalidated;
|
acceptUnvalidated = nac.acceptUnvalidated;
|
||||||
|
acceptPartialConnectivity = nac.acceptPartialConnectivity;
|
||||||
subscriberId = nac.subscriberId;
|
subscriberId = nac.subscriberId;
|
||||||
provisioningNotificationDisabled = nac.provisioningNotificationDisabled;
|
provisioningNotificationDisabled = nac.provisioningNotificationDisabled;
|
||||||
skip464xlat = nac.skip464xlat;
|
skip464xlat = nac.skip464xlat;
|
||||||
@@ -177,6 +206,43 @@ public final class NetworkAgentConfig implements Parcelable {
|
|||||||
public static class Builder {
|
public static class Builder {
|
||||||
private final NetworkAgentConfig mConfig = new NetworkAgentConfig();
|
private final NetworkAgentConfig mConfig = new NetworkAgentConfig();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets whether the network was explicitly selected by the user.
|
||||||
|
*
|
||||||
|
* @return this builder, to facilitate chaining.
|
||||||
|
*/
|
||||||
|
@NonNull
|
||||||
|
public Builder setExplicitlySelected(final boolean explicitlySelected) {
|
||||||
|
mConfig.explicitlySelected = explicitlySelected;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets whether the system should validate this network even if it is found not to offer
|
||||||
|
* Internet connectivity.
|
||||||
|
*
|
||||||
|
* @return this builder, to facilitate chaining.
|
||||||
|
*/
|
||||||
|
@NonNull
|
||||||
|
public Builder setUnvalidatedConnectivityAcceptable(
|
||||||
|
final boolean unvalidatedConnectivityAcceptable) {
|
||||||
|
mConfig.acceptUnvalidated = unvalidatedConnectivityAcceptable;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets whether the system should validate this network even if it is found to only offer
|
||||||
|
* partial Internet connectivity.
|
||||||
|
*
|
||||||
|
* @return this builder, to facilitate chaining.
|
||||||
|
*/
|
||||||
|
@NonNull
|
||||||
|
public Builder setPartialConnectivityAcceptable(
|
||||||
|
final boolean partialConnectivityAcceptable) {
|
||||||
|
mConfig.acceptPartialConnectivity = partialConnectivityAcceptable;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the subscriber ID for this network.
|
* Sets the subscriber ID for this network.
|
||||||
*
|
*
|
||||||
@@ -244,6 +310,45 @@ public final class NetworkAgentConfig implements Parcelable {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean equals(final Object o) {
|
||||||
|
if (this == o) return true;
|
||||||
|
if (o == null || getClass() != o.getClass()) return false;
|
||||||
|
final NetworkAgentConfig that = (NetworkAgentConfig) o;
|
||||||
|
return allowBypass == that.allowBypass
|
||||||
|
&& explicitlySelected == that.explicitlySelected
|
||||||
|
&& acceptUnvalidated == that.acceptUnvalidated
|
||||||
|
&& acceptPartialConnectivity == that.acceptPartialConnectivity
|
||||||
|
&& provisioningNotificationDisabled == that.provisioningNotificationDisabled
|
||||||
|
&& skip464xlat == that.skip464xlat
|
||||||
|
&& legacyType == that.legacyType
|
||||||
|
&& Objects.equals(subscriberId, that.subscriberId)
|
||||||
|
&& Objects.equals(legacyTypeName, that.legacyTypeName);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int hashCode() {
|
||||||
|
return Objects.hash(allowBypass, explicitlySelected, acceptUnvalidated,
|
||||||
|
acceptPartialConnectivity, provisioningNotificationDisabled, subscriberId,
|
||||||
|
skip464xlat, legacyType, legacyTypeName);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public String toString() {
|
||||||
|
return "NetworkAgentConfig {"
|
||||||
|
+ " allowBypass = " + allowBypass
|
||||||
|
+ ", explicitlySelected = " + explicitlySelected
|
||||||
|
+ ", acceptUnvalidated = " + acceptUnvalidated
|
||||||
|
+ ", acceptPartialConnectivity = " + acceptPartialConnectivity
|
||||||
|
+ ", provisioningNotificationDisabled = " + provisioningNotificationDisabled
|
||||||
|
+ ", subscriberId = '" + subscriberId + '\''
|
||||||
|
+ ", skip464xlat = " + skip464xlat
|
||||||
|
+ ", legacyType = " + legacyType
|
||||||
|
+ ", hasShownBroken = " + hasShownBroken
|
||||||
|
+ ", legacyTypeName = '" + legacyTypeName + '\''
|
||||||
|
+ "}";
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int describeContents() {
|
public int describeContents() {
|
||||||
return 0;
|
return 0;
|
||||||
@@ -254,9 +359,12 @@ public final class NetworkAgentConfig implements Parcelable {
|
|||||||
out.writeInt(allowBypass ? 1 : 0);
|
out.writeInt(allowBypass ? 1 : 0);
|
||||||
out.writeInt(explicitlySelected ? 1 : 0);
|
out.writeInt(explicitlySelected ? 1 : 0);
|
||||||
out.writeInt(acceptUnvalidated ? 1 : 0);
|
out.writeInt(acceptUnvalidated ? 1 : 0);
|
||||||
|
out.writeInt(acceptPartialConnectivity ? 1 : 0);
|
||||||
out.writeString(subscriberId);
|
out.writeString(subscriberId);
|
||||||
out.writeInt(provisioningNotificationDisabled ? 1 : 0);
|
out.writeInt(provisioningNotificationDisabled ? 1 : 0);
|
||||||
out.writeInt(skip464xlat ? 1 : 0);
|
out.writeInt(skip464xlat ? 1 : 0);
|
||||||
|
out.writeInt(legacyType);
|
||||||
|
out.writeString(legacyTypeName);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static final @NonNull Creator<NetworkAgentConfig> CREATOR =
|
public static final @NonNull Creator<NetworkAgentConfig> CREATOR =
|
||||||
@@ -267,9 +375,12 @@ public final class NetworkAgentConfig implements Parcelable {
|
|||||||
networkAgentConfig.allowBypass = in.readInt() != 0;
|
networkAgentConfig.allowBypass = in.readInt() != 0;
|
||||||
networkAgentConfig.explicitlySelected = in.readInt() != 0;
|
networkAgentConfig.explicitlySelected = in.readInt() != 0;
|
||||||
networkAgentConfig.acceptUnvalidated = in.readInt() != 0;
|
networkAgentConfig.acceptUnvalidated = in.readInt() != 0;
|
||||||
|
networkAgentConfig.acceptPartialConnectivity = in.readInt() != 0;
|
||||||
networkAgentConfig.subscriberId = in.readString();
|
networkAgentConfig.subscriberId = in.readString();
|
||||||
networkAgentConfig.provisioningNotificationDisabled = in.readInt() != 0;
|
networkAgentConfig.provisioningNotificationDisabled = in.readInt() != 0;
|
||||||
networkAgentConfig.skip464xlat = in.readInt() != 0;
|
networkAgentConfig.skip464xlat = in.readInt() != 0;
|
||||||
|
networkAgentConfig.legacyType = in.readInt();
|
||||||
|
networkAgentConfig.legacyTypeName = in.readString();
|
||||||
return networkAgentConfig;
|
return networkAgentConfig;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
39
tests/net/common/java/android/net/NetworkAgentConfigTest.kt
Normal file
39
tests/net/common/java/android/net/NetworkAgentConfigTest.kt
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2019 The Android Open Source Project
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package android.net
|
||||||
|
|
||||||
|
import androidx.test.filters.SmallTest
|
||||||
|
import androidx.test.runner.AndroidJUnit4
|
||||||
|
import com.android.testutils.assertParcelSane
|
||||||
|
import org.junit.Test
|
||||||
|
import org.junit.runner.RunWith
|
||||||
|
|
||||||
|
@RunWith(AndroidJUnit4::class)
|
||||||
|
@SmallTest
|
||||||
|
class NetworkAgentConfigTest {
|
||||||
|
@Test
|
||||||
|
fun testParcelNetworkAgentConfig() {
|
||||||
|
val config = NetworkAgentConfig.Builder().apply {
|
||||||
|
setExplicitlySelected(true)
|
||||||
|
setLegacyType(ConnectivityManager.TYPE_ETHERNET)
|
||||||
|
setSubscriberId("MySubId")
|
||||||
|
setPartialConnectivityAcceptable(false)
|
||||||
|
setUnvalidatedConnectivityAcceptable(true)
|
||||||
|
}.build()
|
||||||
|
assertParcelSane(config, 9)
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user