Merge changes I16418791,I210f5ddc am: a079336270

Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1948617

Change-Id: I255850295426742033b60d16f30f676e96f6bb4d
This commit is contained in:
Junyu Lai
2022-01-19 07:28:49 +00:00
committed by Automerger Merge Worker
2 changed files with 48 additions and 19 deletions

View File

@@ -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})

View File

@@ -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