NetworkAgentInfo.java revision d3b8a3e77696ecd90ce59a869aaadf1e7804a9c8
17b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt/* 27b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * Copyright (C) 2014 The Android Open Source Project 37b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * 47b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * Licensed under the Apache License, Version 2.0 (the "License"); 57b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * you may not use this file except in compliance with the License. 67b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * You may obtain a copy of the License at 77b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * 87b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * http://www.apache.org/licenses/LICENSE-2.0 97b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * 107b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * Unless required by applicable law or agreed to in writing, software 117b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * distributed under the License is distributed on an "AS IS" BASIS, 127b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 137b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * See the License for the specific language governing permissions and 147b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * limitations under the License. 157b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt */ 167b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 177b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltpackage com.android.server.connectivity; 187b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 19ca8f16ad14819ba17f5ff3d2e2bf6fbc9bbaa9f7Paul Jensenimport android.content.Context; 207b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport android.net.LinkProperties; 217b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport android.net.Network; 227b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport android.net.NetworkCapabilities; 237b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport android.net.NetworkInfo; 248cd33ed84e94036a5e1201485af7603dc6fb0d9bSreeram Ramachandranimport android.net.NetworkMisc; 257b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport android.net.NetworkRequest; 26ca8f16ad14819ba17f5ff3d2e2bf6fbc9bbaa9f7Paul Jensenimport android.os.Handler; 277b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport android.os.Messenger; 287b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport android.util.SparseArray; 297b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 307b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport com.android.internal.util.AsyncChannel; 31ca8f16ad14819ba17f5ff3d2e2bf6fbc9bbaa9f7Paul Jensenimport com.android.server.connectivity.NetworkMonitor; 327b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 337b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltimport java.util.ArrayList; 347b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 357b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt/** 367b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * A bag class used by ConnectivityService for holding a collection of most recent 377b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * information published by a particular NetworkAgent as well as the 387b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * AsyncChannel/messenger for reaching that NetworkAgent and lists of NetworkRequests 397b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt * interested in using it. 407b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt */ 417b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwaltpublic class NetworkAgentInfo { 427b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt public NetworkInfo networkInfo; 4360061a6ebf4ef758c4a47d210de0e5be2484be5bPaul Jensen public Network network; 447b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt public LinkProperties linkProperties; 457b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt public NetworkCapabilities networkCapabilities; 46ca8f16ad14819ba17f5ff3d2e2bf6fbc9bbaa9f7Paul Jensen public final NetworkMonitor networkMonitor; 478cd33ed84e94036a5e1201485af7603dc6fb0d9bSreeram Ramachandran public final NetworkMisc networkMisc; 4871b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // Indicates if netd has been told to create this Network. Once created the appropriate routing 4971b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // rules are setup and routes are added so packets can begin flowing over the Network. 5071b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // NOTE: This is a sticky bit; once set it is never cleared. 51eec75412a971a5ccb769364120c769c331946eb3Paul Jensen public boolean created; 5271b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // Set to true if this Network successfully passed validation or if it did not satisfy the 5371b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // default NetworkRequest in which case validation will not be attempted. 5471b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // NOTE: This is a sticky bit; once set it is never cleared even if future validation attempts 5571b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // fail. 56d3b8a3e77696ecd90ce59a869aaadf1e7804a9c8Lorenzo Colitti public boolean everValidated; 57ca8f16ad14819ba17f5ff3d2e2bf6fbc9bbaa9f7Paul Jensen 582161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen // This represents the last score received from the NetworkAgent. 592161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen private int currentScore; 602161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen // Penalty applied to scores of Networks that have not been validated. 612161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen private static final int UNVALIDATED_SCORE_PENALTY = 40; 622161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen 63e73cc4646bed3926024c9f54ca59e3a82a97b56cRobert Greenwalt // Score for explicitly connected network. 64e73cc4646bed3926024c9f54ca59e3a82a97b56cRobert Greenwalt private static final int EXPLICITLY_SELECTED_NETWORK_SCORE = 100; 65e73cc4646bed3926024c9f54ca59e3a82a97b56cRobert Greenwalt 667b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt // The list of NetworkRequests being satisfied by this Network. 677b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt public final SparseArray<NetworkRequest> networkRequests = new SparseArray<NetworkRequest>(); 6871b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // The list of NetworkRequests that this Network previously satisfied with the highest 6971b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // score. A non-empty list indicates that if this Network was validated it is lingered. 7071b645fe9cb8106dfcbf025a3fd7f58698c051bbPaul Jensen // NOTE: This list is only used for debugging. 719258c64bef1a01fe89bc7c1fa402c44c0e6a1255Robert Greenwalt public final ArrayList<NetworkRequest> networkLingered = new ArrayList<NetworkRequest>(); 727b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 737b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt public final Messenger messenger; 747b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt public final AsyncChannel asyncChannel; 757b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 76954394653dad05838235f48244a4320893e0f0cfLorenzo Colitti // Used by ConnectivityService to keep track of 464xlat. 77954394653dad05838235f48244a4320893e0f0cfLorenzo Colitti public Nat464Xlat clatd; 78954394653dad05838235f48244a4320893e0f0cfLorenzo Colitti 7960061a6ebf4ef758c4a47d210de0e5be2484be5bPaul Jensen public NetworkAgentInfo(Messenger messenger, AsyncChannel ac, NetworkInfo info, 808cd33ed84e94036a5e1201485af7603dc6fb0d9bSreeram Ramachandran LinkProperties lp, NetworkCapabilities nc, int score, Context context, Handler handler, 812c311d61eaf331818e601f97485f88c4cf26384dPaul Jensen NetworkMisc misc, NetworkRequest defaultRequest) { 827b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt this.messenger = messenger; 837b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt asyncChannel = ac; 8460061a6ebf4ef758c4a47d210de0e5be2484be5bPaul Jensen network = null; 857b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt networkInfo = info; 867b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt linkProperties = lp; 877b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt networkCapabilities = nc; 887b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt currentScore = score; 892c311d61eaf331818e601f97485f88c4cf26384dPaul Jensen networkMonitor = new NetworkMonitor(context, handler, this, defaultRequest); 908cd33ed84e94036a5e1201485af7603dc6fb0d9bSreeram Ramachandran networkMisc = misc; 91eec75412a971a5ccb769364120c769c331946eb3Paul Jensen created = false; 92d3b8a3e77696ecd90ce59a869aaadf1e7804a9c8Lorenzo Colitti everValidated = false; 937b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt } 947b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 9571bf33a02f49444fbfa35b267c70592f3b07a07dRobert Greenwalt public void addRequest(NetworkRequest networkRequest) { 9671bf33a02f49444fbfa35b267c70592f3b07a07dRobert Greenwalt networkRequests.put(networkRequest.requestId, networkRequest); 9771bf33a02f49444fbfa35b267c70592f3b07a07dRobert Greenwalt } 9871bf33a02f49444fbfa35b267c70592f3b07a07dRobert Greenwalt 990cc1732cfb9d68779449b4c12661b4df6bfc720bPaul Jensen // Does this network satisfy request? 1000cc1732cfb9d68779449b4c12661b4df6bfc720bPaul Jensen public boolean satisfies(NetworkRequest request) { 1010cc1732cfb9d68779449b4c12661b4df6bfc720bPaul Jensen return created && 1020cc1732cfb9d68779449b4c12661b4df6bfc720bPaul Jensen request.networkCapabilities.satisfiedByNetworkCapabilities(networkCapabilities); 1030cc1732cfb9d68779449b4c12661b4df6bfc720bPaul Jensen } 1040cc1732cfb9d68779449b4c12661b4df6bfc720bPaul Jensen 1056bc2c2c34f2b23eae79ad733c97a691734055c4fPaul Jensen public boolean isVPN() { 1066bc2c2c34f2b23eae79ad733c97a691734055c4fPaul Jensen return networkCapabilities.hasTransport(NetworkCapabilities.TRANSPORT_VPN); 1076bc2c2c34f2b23eae79ad733c97a691734055c4fPaul Jensen } 1086bc2c2c34f2b23eae79ad733c97a691734055c4fPaul Jensen 109b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen private int getCurrentScore(boolean pretendValidated) { 1102161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen // TODO: We may want to refactor this into a NetworkScore class that takes a base score from 1112161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen // the NetworkAgent and signals from the NetworkAgent and uses those signals to modify the 1122161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen // score. The NetworkScore class would provide a nice place to centralize score constants 1132161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen // so they are not scattered about the transports. 1142161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen 1152161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen int score = currentScore; 1162161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen 117d3b8a3e77696ecd90ce59a869aaadf1e7804a9c8Lorenzo Colitti if (!everValidated && !pretendValidated) score -= UNVALIDATED_SCORE_PENALTY; 1182161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen if (score < 0) score = 0; 1192161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen 120e73cc4646bed3926024c9f54ca59e3a82a97b56cRobert Greenwalt if (networkMisc.explicitlySelected) score = EXPLICITLY_SELECTED_NETWORK_SCORE; 121e73cc4646bed3926024c9f54ca59e3a82a97b56cRobert Greenwalt 1222161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen return score; 1232161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen } 1242161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen 125b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen // Get the current score for this Network. This may be modified from what the 126b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen // NetworkAgent sent, as it has modifiers applied to it. 127b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen public int getCurrentScore() { 128b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen return getCurrentScore(false); 129b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen } 130b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen 131b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen // Get the current score for this Network as if it was validated. This may be modified from 132b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen // what the NetworkAgent sent, as it has modifiers applied to it. 133b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen public int getCurrentScoreAsValidated() { 134b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen return getCurrentScore(true); 135b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen } 136b10e37fd1c3a95f7e621eed234c2491eb71241e2Paul Jensen 1372161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen public void setCurrentScore(int newScore) { 1382161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen currentScore = newScore; 1392161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen } 1402161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen 1417b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt public String toString() { 1427b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt return "NetworkAgentInfo{ ni{" + networkInfo + "} network{" + 1437b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt network + "} lp{" + 1447b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt linkProperties + "} nc{" + 1452161a8ea123134ee3f9a10c0f8f56aabd8289f69Paul Jensen networkCapabilities + "} Score{" + getCurrentScore() + "} " + 146d3b8a3e77696ecd90ce59a869aaadf1e7804a9c8Lorenzo Colitti "everValidated{" + everValidated + "} created{" + created + "} " + 147e73cc4646bed3926024c9f54ca59e3a82a97b56cRobert Greenwalt "explicitlySelected{" + networkMisc.explicitlySelected + "} }"; 1487b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt } 1497b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt 1507b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt public String name() { 1517b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt return "NetworkAgentInfo [" + networkInfo.getTypeName() + " (" + 15260061a6ebf4ef758c4a47d210de0e5be2484be5bPaul Jensen networkInfo.getSubtypeName() + ") - " + 15360061a6ebf4ef758c4a47d210de0e5be2484be5bPaul Jensen (network == null ? "null" : network.toString()) + "]"; 1547b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt } 1557b81602f3c18df8a4ca0342c514af8f7e394c0d7Robert Greenwalt} 156