Merge "Add new netd event callback for changes to private DNS validation state." into pi-dev

This commit is contained in:
TreeHugger Robot
2018-03-13 15:49:47 +00:00
committed by Android (Google) Code Review
3 changed files with 40 additions and 4 deletions

View File

@@ -20,8 +20,9 @@ package android.net;
oneway interface INetdEventCallback {
// Possible addNetdEventCallback callers.
const int CALLBACK_CALLER_DEVICE_POLICY = 0;
const int CALLBACK_CALLER_NETWORK_WATCHLIST = 1;
const int CALLBACK_CALLER_CONNECTIVITY_SERVICE = 0;
const int CALLBACK_CALLER_DEVICE_POLICY = 1;
const int CALLBACK_CALLER_NETWORK_WATCHLIST = 2;
/**
* Reports a single DNS lookup function call.
@@ -38,6 +39,18 @@ oneway interface INetdEventCallback {
void onDnsEvent(String hostname, in String[] ipAddresses, int ipAddressesCount, long timestamp,
int uid);
/**
* Represents a private DNS validation success or failure.
* This method must not block or perform long-running operations.
*
* @param netId the ID of the network the validation was performed on.
* @param ipAddress the IP address for which validation was performed.
* @param hostname the hostname for which validation was performed.
* @param validated whether or not validation was successful.
*/
void onPrivateDnsValidationEvent(int netId, String ipAddress, String hostname,
boolean validated);
/**
* Reports a single connect library call.
* This method must not block or perform long-running operations.

View File

@@ -31,6 +31,12 @@ public class BaseNetdEventCallback extends INetdEventCallback.Stub {
// default no-op
}
@Override
public void onPrivateDnsValidationEvent(int netId, String ipAddress,
String hostname, boolean validated) {
// default no-op
}
@Override
public void onConnectEvent(String ipAddr, int port, long timestamp, int uid) {
// default no-op

View File

@@ -102,9 +102,12 @@ public class NetdEventListenerService extends INetdEventListener.Stub {
/**
* There are only 2 possible callbacks.
* There are only 3 possible callbacks.
*
* mNetdEventCallbackList[CALLBACK_CALLER_DEVICE_POLICY].
* mNetdEventCallbackList[CALLBACK_CALLER_CONNECTIVITY_SERVICE]
* Callback registered/unregistered by ConnectivityService.
*
* mNetdEventCallbackList[CALLBACK_CALLER_DEVICE_POLICY]
* Callback registered/unregistered when logging is being enabled/disabled in DPM
* by the device owner. It's DevicePolicyManager's responsibility to ensure that.
*
@@ -113,6 +116,7 @@ public class NetdEventListenerService extends INetdEventListener.Stub {
*/
@GuardedBy("this")
private static final int[] ALLOWED_CALLBACK_TYPES = {
INetdEventCallback.CALLBACK_CALLER_CONNECTIVITY_SERVICE,
INetdEventCallback.CALLBACK_CALLER_DEVICE_POLICY,
INetdEventCallback.CALLBACK_CALLER_NETWORK_WATCHLIST
};
@@ -209,6 +213,19 @@ public class NetdEventListenerService extends INetdEventListener.Stub {
}
}
@Override
// Called concurrently by multiple binder threads.
// This method must not block or perform long-running operations.
public synchronized void onPrivateDnsValidationEvent(int netId,
String ipAddress, String hostname, boolean validated)
throws RemoteException {
for (INetdEventCallback callback : mNetdEventCallbackList) {
if (callback != null) {
callback.onPrivateDnsValidationEvent(netId, ipAddress, hostname, validated);
}
}
}
@Override
// Called concurrently by multiple binder threads.
// This method must not block or perform long-running operations.