Add multipath preference, background status API

Add APIs for getMultipathPreference and getRestrictBackgroundStatus.
Both are used by Connectivity to back the external
ConnectivityManager.getRestrictBackgroundStatus, and
ConnectivityManager.getMultipathPreference APIs.

Test: atest CtsNetTestCases
      atest ConnectivityServiceTests
      atest NetworkPolicyManagerServiceTest
Bug: 176289731
Change-Id: I8a03162b2f6691086bb64e75ffd354cdfca7f86a
Merged-In: I8a03162b2f6691086bb64e75ffd354cdfca7f86a
This commit is contained in:
Remi NGUYEN VAN
2021-03-18 14:23:12 +09:00
committed by Lorenzo Colitti
parent 3a5b922890
commit e62e7ff645
2 changed files with 3 additions and 14 deletions

View File

@@ -62,7 +62,6 @@ import android.os.PersistableBundle;
import android.os.Process; import android.os.Process;
import android.os.RemoteException; import android.os.RemoteException;
import android.os.ResultReceiver; import android.os.ResultReceiver;
import android.os.ServiceManager;
import android.os.ServiceSpecificException; import android.os.ServiceSpecificException;
import android.os.UserHandle; import android.os.UserHandle;
import android.provider.Settings; import android.provider.Settings;
@@ -842,7 +841,6 @@ public class ConnectivityManager {
private final Context mContext; private final Context mContext;
private INetworkPolicyManager mNPManager;
private final TetheringManager mTetheringManager; private final TetheringManager mTetheringManager;
/** /**
@@ -4794,17 +4792,6 @@ public class ConnectivityManager {
public @interface RestrictBackgroundStatus { public @interface RestrictBackgroundStatus {
} }
private INetworkPolicyManager getNetworkPolicyManager() {
synchronized (this) {
if (mNPManager != null) {
return mNPManager;
}
mNPManager = INetworkPolicyManager.Stub.asInterface(ServiceManager
.getService(Context.NETWORK_POLICY_SERVICE));
return mNPManager;
}
}
/** /**
* Determines if the calling application is subject to metered network restrictions while * Determines if the calling application is subject to metered network restrictions while
* running on background. * running on background.
@@ -4815,7 +4802,7 @@ public class ConnectivityManager {
*/ */
public @RestrictBackgroundStatus int getRestrictBackgroundStatus() { public @RestrictBackgroundStatus int getRestrictBackgroundStatus() {
try { try {
return getNetworkPolicyManager().getRestrictBackgroundByCaller(); return mService.getRestrictBackgroundStatusByCaller();
} catch (RemoteException e) { } catch (RemoteException e) {
throw e.rethrowFromSystemServer(); throw e.rethrowFromSystemServer();
} }

View File

@@ -220,4 +220,6 @@ interface IConnectivityManager
void setProfileNetworkPreference(in UserHandle profile, int preference, void setProfileNetworkPreference(in UserHandle profile, int preference,
in IOnCompleteListener listener); in IOnCompleteListener listener);
int getRestrictBackgroundStatusByCaller();
} }