diff options
| author | junyulai <junyulai@google.com> | 2021-01-11 16:53:38 +0800 |
|---|---|---|
| committer | junyulai <junyulai@google.com> | 2021-01-12 19:55:00 +0800 |
| commit | 11fb36ea132cc0f12656187342446488ee235dfd (patch) | |
| tree | 52cefebfabaa3611be4439d0015ba38d49bbe474 /core/java/android/net/ConnectivityManager.java | |
| parent | 5b322f10bebfaa3e3f2bc7b91da9006e81f8757f (diff) | |
[VCN05] Pass request type when requesting network
Currently, ConnectivityService decides the request type by
whether NetworkCapabilities is null when handling request
network. However, to fulfill the need of firing background
request via ConnectivityManager in the follow-up patches,
the request type is needed to pass into ConnectivityService.
This change also make ConnectivityService utilizes the passed
request type.
Test: atest ConnectivityManagerTest#testRequestType
Bug: 175662146
Change-Id: I3bc172bca1217c8020db45057a621d0745d43b3c
Diffstat (limited to 'core/java/android/net/ConnectivityManager.java')
| -rw-r--r-- | core/java/android/net/ConnectivityManager.java | 19 |
1 files changed, 10 insertions, 9 deletions
diff --git a/core/java/android/net/ConnectivityManager.java b/core/java/android/net/ConnectivityManager.java index 06c159804a45..8742ecbd2570 100644 --- a/core/java/android/net/ConnectivityManager.java +++ b/core/java/android/net/ConnectivityManager.java @@ -16,6 +16,9 @@ package android.net; import static android.net.IpSecManager.INVALID_RESOURCE_ID; +import static android.net.NetworkRequest.Type.LISTEN; +import static android.net.NetworkRequest.Type.REQUEST; +import static android.net.NetworkRequest.Type.TRACK_DEFAULT; import android.annotation.CallbackExecutor; import android.annotation.IntDef; @@ -3730,14 +3733,12 @@ public class ConnectivityManager { private static final HashMap<NetworkRequest, NetworkCallback> sCallbacks = new HashMap<>(); private static CallbackHandler sCallbackHandler; - private static final int LISTEN = 1; - private static final int REQUEST = 2; - private NetworkRequest sendRequestForNetwork(NetworkCapabilities need, NetworkCallback callback, - int timeoutMs, int action, int legacyType, CallbackHandler handler) { + int timeoutMs, NetworkRequest.Type reqType, int legacyType, CallbackHandler handler) { printStackTrace(); checkCallbackNotNull(callback); - Preconditions.checkArgument(action == REQUEST || need != null, "null NetworkCapabilities"); + Preconditions.checkArgument( + reqType == TRACK_DEFAULT || need != null, "null NetworkCapabilities"); final NetworkRequest request; final String callingPackageName = mContext.getOpPackageName(); try { @@ -3750,13 +3751,13 @@ public class ConnectivityManager { } Messenger messenger = new Messenger(handler); Binder binder = new Binder(); - if (action == LISTEN) { + if (reqType == LISTEN) { request = mService.listenForNetwork( need, messenger, binder, callingPackageName); } else { request = mService.requestNetwork( - need, messenger, timeoutMs, binder, legacyType, callingPackageName, - getAttributionTag()); + need, reqType.ordinal(), messenger, timeoutMs, binder, legacyType, + callingPackageName, getAttributionTag()); } if (request != null) { sCallbacks.put(request, callback); @@ -4260,7 +4261,7 @@ public class ConnectivityManager { // request, i.e., the system default network. CallbackHandler cbHandler = new CallbackHandler(handler); sendRequestForNetwork(null /* NetworkCapabilities need */, networkCallback, 0, - REQUEST, TYPE_NONE, cbHandler); + TRACK_DEFAULT, TYPE_NONE, cbHandler); } /** |
