Merge changes I16418791,I210f5ddc
* changes: [MS37.1] Expose APIs which is used by NPMS [MS55] Remove INetworkStats dependency from DataIdleTest
This commit is contained in:
@@ -18,6 +18,7 @@ package android.app.usage;
|
|||||||
|
|
||||||
import static android.annotation.SystemApi.Client.MODULE_LIBRARIES;
|
import static android.annotation.SystemApi.Client.MODULE_LIBRARIES;
|
||||||
|
|
||||||
|
import android.Manifest;
|
||||||
import android.annotation.NonNull;
|
import android.annotation.NonNull;
|
||||||
import android.annotation.Nullable;
|
import android.annotation.Nullable;
|
||||||
import android.annotation.RequiresPermission;
|
import android.annotation.RequiresPermission;
|
||||||
@@ -150,7 +151,13 @@ public class NetworkStatsManager {
|
|||||||
* @param pollOnOpen true if poll is needed.
|
* @param pollOnOpen true if poll is needed.
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
// @SystemApi(client = MODULE_LIBRARIES)
|
// The system will ignore any non-default values for non-privileged
|
||||||
|
// processes, so processes that don't hold the appropriate permissions
|
||||||
|
// can make no use of this API.
|
||||||
|
@SystemApi(client = MODULE_LIBRARIES)
|
||||||
|
@RequiresPermission(anyOf = {
|
||||||
|
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
||||||
|
android.Manifest.permission.NETWORK_STACK})
|
||||||
public void setPollOnOpen(boolean pollOnOpen) {
|
public void setPollOnOpen(boolean pollOnOpen) {
|
||||||
if (pollOnOpen) {
|
if (pollOnOpen) {
|
||||||
mFlags |= FLAG_POLL_ON_OPEN;
|
mFlags |= FLAG_POLL_ON_OPEN;
|
||||||
@@ -877,7 +884,7 @@ public class NetworkStatsManager {
|
|||||||
*
|
*
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
// @SystemApi
|
@SystemApi(client = MODULE_LIBRARIES)
|
||||||
@RequiresPermission(anyOf = {
|
@RequiresPermission(anyOf = {
|
||||||
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
||||||
android.Manifest.permission.NETWORK_STACK})
|
android.Manifest.permission.NETWORK_STACK})
|
||||||
@@ -890,17 +897,18 @@ public class NetworkStatsManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Advise persistence threshold; may be overridden internally.
|
* Set default value of global alert bytes, the value will be clamped to [128kB, 2MB].
|
||||||
*
|
*
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
// @SystemApi
|
@SystemApi(client = MODULE_LIBRARIES)
|
||||||
@RequiresPermission(anyOf = {
|
@RequiresPermission(anyOf = {
|
||||||
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
||||||
android.Manifest.permission.NETWORK_STACK})
|
Manifest.permission.NETWORK_STACK})
|
||||||
public void advisePersistThreshold(long thresholdBytes) {
|
public void setDefaultGlobalAlert(long alertBytes) {
|
||||||
try {
|
try {
|
||||||
mService.advisePersistThreshold(thresholdBytes);
|
// TODO: Sync internal naming with the API surface.
|
||||||
|
mService.advisePersistThreshold(alertBytes);
|
||||||
} catch (RemoteException e) {
|
} catch (RemoteException e) {
|
||||||
throw e.rethrowFromSystemServer();
|
throw e.rethrowFromSystemServer();
|
||||||
}
|
}
|
||||||
@@ -911,7 +919,7 @@ public class NetworkStatsManager {
|
|||||||
*
|
*
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
// @SystemApi
|
@SystemApi(client = MODULE_LIBRARIES)
|
||||||
@RequiresPermission(anyOf = {
|
@RequiresPermission(anyOf = {
|
||||||
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
||||||
android.Manifest.permission.NETWORK_STACK})
|
android.Manifest.permission.NETWORK_STACK})
|
||||||
@@ -927,9 +935,17 @@ public class NetworkStatsManager {
|
|||||||
* Set the warning and limit to all registered custom network stats providers.
|
* Set the warning and limit to all registered custom network stats providers.
|
||||||
* Note that invocation of any interface will be sent to all providers.
|
* Note that invocation of any interface will be sent to all providers.
|
||||||
*
|
*
|
||||||
|
* Asynchronicity notes : because traffic may be happening on the device at the same time, it
|
||||||
|
* doesn't make sense to wait for the warning and limit to be set – a caller still wouldn't
|
||||||
|
* know when exactly it was effective. All that can matter is that it's done quickly. Also,
|
||||||
|
* this method can't fail, so there is no status to return. All providers will see the new
|
||||||
|
* values soon.
|
||||||
|
* As such, this method returns immediately and sends the warning and limit to all providers
|
||||||
|
* as soon as possible through a one-way binder call.
|
||||||
|
*
|
||||||
* @hide
|
* @hide
|
||||||
*/
|
*/
|
||||||
// @SystemApi
|
@SystemApi(client = MODULE_LIBRARIES)
|
||||||
@RequiresPermission(anyOf = {
|
@RequiresPermission(anyOf = {
|
||||||
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
||||||
android.Manifest.permission.NETWORK_STACK})
|
android.Manifest.permission.NETWORK_STACK})
|
||||||
|
|||||||
@@ -707,12 +707,25 @@ public class NetworkStatsService extends INetworkStatsService.Stub {
|
|||||||
return now - lastCallTime < POLL_RATE_LIMIT_MS;
|
return now - lastCallTime < POLL_RATE_LIMIT_MS;
|
||||||
}
|
}
|
||||||
|
|
||||||
private INetworkStatsSession openSessionInternal(final int flags, final String callingPackage) {
|
private int restrictFlagsForCaller(int flags) {
|
||||||
|
// All non-privileged callers are not allowed to turn off POLL_ON_OPEN.
|
||||||
|
final boolean isPrivileged = PermissionUtils.checkAnyPermissionOf(mContext,
|
||||||
|
NetworkStack.PERMISSION_MAINLINE_NETWORK_STACK,
|
||||||
|
android.Manifest.permission.NETWORK_STACK);
|
||||||
|
if (!isPrivileged) {
|
||||||
|
flags |= NetworkStatsManager.FLAG_POLL_ON_OPEN;
|
||||||
|
}
|
||||||
|
// Non-system uids are rate limited for POLL_ON_OPEN.
|
||||||
final int callingUid = Binder.getCallingUid();
|
final int callingUid = Binder.getCallingUid();
|
||||||
final int usedFlags = isRateLimitedForPoll(callingUid)
|
flags = isRateLimitedForPoll(callingUid)
|
||||||
? flags & (~NetworkStatsManager.FLAG_POLL_ON_OPEN)
|
? flags & (~NetworkStatsManager.FLAG_POLL_ON_OPEN)
|
||||||
: flags;
|
: flags;
|
||||||
if ((usedFlags & (NetworkStatsManager.FLAG_POLL_ON_OPEN
|
return flags;
|
||||||
|
}
|
||||||
|
|
||||||
|
private INetworkStatsSession openSessionInternal(final int flags, final String callingPackage) {
|
||||||
|
final int restrictedFlags = restrictFlagsForCaller(flags);
|
||||||
|
if ((restrictedFlags & (NetworkStatsManager.FLAG_POLL_ON_OPEN
|
||||||
| NetworkStatsManager.FLAG_POLL_FORCE)) != 0) {
|
| NetworkStatsManager.FLAG_POLL_FORCE)) != 0) {
|
||||||
final long ident = Binder.clearCallingIdentity();
|
final long ident = Binder.clearCallingIdentity();
|
||||||
try {
|
try {
|
||||||
@@ -726,7 +739,7 @@ public class NetworkStatsService extends INetworkStatsService.Stub {
|
|||||||
// for its lifetime; when caller closes only weak references remain.
|
// for its lifetime; when caller closes only weak references remain.
|
||||||
|
|
||||||
return new INetworkStatsSession.Stub() {
|
return new INetworkStatsSession.Stub() {
|
||||||
private final int mCallingUid = callingUid;
|
private final int mCallingUid = Binder.getCallingUid();
|
||||||
private final String mCallingPackage = callingPackage;
|
private final String mCallingPackage = callingPackage;
|
||||||
private final @NetworkStatsAccess.Level int mAccessLevel = checkAccessLevel(
|
private final @NetworkStatsAccess.Level int mAccessLevel = checkAccessLevel(
|
||||||
callingPackage);
|
callingPackage);
|
||||||
@@ -760,21 +773,21 @@ public class NetworkStatsService extends INetworkStatsService.Stub {
|
|||||||
@Override
|
@Override
|
||||||
public NetworkStats getDeviceSummaryForNetwork(
|
public NetworkStats getDeviceSummaryForNetwork(
|
||||||
NetworkTemplate template, long start, long end) {
|
NetworkTemplate template, long start, long end) {
|
||||||
return internalGetSummaryForNetwork(template, usedFlags, start, end, mAccessLevel,
|
return internalGetSummaryForNetwork(template, restrictedFlags, start, end,
|
||||||
mCallingUid);
|
mAccessLevel, mCallingUid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public NetworkStats getSummaryForNetwork(
|
public NetworkStats getSummaryForNetwork(
|
||||||
NetworkTemplate template, long start, long end) {
|
NetworkTemplate template, long start, long end) {
|
||||||
return internalGetSummaryForNetwork(template, usedFlags, start, end, mAccessLevel,
|
return internalGetSummaryForNetwork(template, restrictedFlags, start, end,
|
||||||
mCallingUid);
|
mAccessLevel, mCallingUid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public NetworkStatsHistory getHistoryForNetwork(NetworkTemplate template, int fields) {
|
public NetworkStatsHistory getHistoryForNetwork(NetworkTemplate template, int fields) {
|
||||||
return internalGetHistoryForNetwork(template, usedFlags, fields, mAccessLevel,
|
return internalGetHistoryForNetwork(template, restrictedFlags, fields,
|
||||||
mCallingUid);
|
mAccessLevel, mCallingUid);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|||||||
Reference in New Issue
Block a user