| /* |
| * Copyright (C) 2016 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| package android.net; |
| |
| import android.annotation.SystemApi; |
| import android.os.Bundle; |
| import android.os.Parcelable; |
| import android.os.RemoteException; |
| import android.os.ServiceManager; |
| import android.util.Log; |
| |
| /** {@hide} */ |
| @SystemApi |
| public class ConnectivityMetricsLogger { |
| private static String TAG = "ConnectivityMetricsLogger"; |
| private static final boolean DBG = true; |
| |
| public static final String CONNECTIVITY_METRICS_LOGGER_SERVICE = "connectivity_metrics_logger"; |
| |
| // Component Tags |
| public static final int COMPONENT_TAG_CONNECTIVITY = 0; |
| public static final int COMPONENT_TAG_BLUETOOTH = 1; |
| public static final int COMPONENT_TAG_WIFI = 2; |
| public static final int COMPONENT_TAG_TELECOM = 3; |
| public static final int COMPONENT_TAG_TELEPHONY = 4; |
| |
| public static final int NUMBER_OF_COMPONENTS = 5; |
| |
| // Event Tag |
| public static final int TAG_SKIPPED_EVENTS = -1; |
| |
| public static final String DATA_KEY_EVENTS_COUNT = "count"; |
| |
| private IConnectivityMetricsLogger mService; |
| |
| private long mServiceUnblockedTimestampMillis = 0; |
| private int mNumSkippedEvents = 0; |
| |
| public ConnectivityMetricsLogger() { |
| mService = IConnectivityMetricsLogger.Stub.asInterface(ServiceManager.getService( |
| CONNECTIVITY_METRICS_LOGGER_SERVICE)); |
| } |
| |
| public void logEvent(long timestamp, int componentTag, int eventTag, Parcelable data) { |
| if (mService == null) { |
| if (DBG) { |
| Log.d(TAG, "logEvent(" + componentTag + "," + eventTag + ") Service not ready"); |
| } |
| return; |
| } |
| |
| if (mServiceUnblockedTimestampMillis > 0) { |
| if (System.currentTimeMillis() < mServiceUnblockedTimestampMillis) { |
| // Service is throttling events. |
| // Don't send new events because they will be dropped. |
| mNumSkippedEvents++; |
| return; |
| } |
| } |
| |
| ConnectivityMetricsEvent skippedEventsEvent = null; |
| if (mNumSkippedEvents > 0) { |
| // Log number of skipped events |
| Bundle b = new Bundle(); |
| b.putInt(DATA_KEY_EVENTS_COUNT, mNumSkippedEvents); |
| skippedEventsEvent = new ConnectivityMetricsEvent(mServiceUnblockedTimestampMillis, |
| componentTag, TAG_SKIPPED_EVENTS, b); |
| |
| mServiceUnblockedTimestampMillis = 0; |
| } |
| |
| ConnectivityMetricsEvent event = new ConnectivityMetricsEvent(timestamp, componentTag, |
| eventTag, data); |
| |
| try { |
| long result; |
| if (skippedEventsEvent == null) { |
| result = mService.logEvent(event); |
| } else { |
| result = mService.logEvents(new ConnectivityMetricsEvent[] |
| {skippedEventsEvent, event}); |
| } |
| |
| if (result == 0) { |
| mNumSkippedEvents = 0; |
| } else { |
| mNumSkippedEvents++; |
| if (result > 0) { // events are throttled |
| mServiceUnblockedTimestampMillis = result; |
| } |
| } |
| } catch (RemoteException e) { |
| Log.e(TAG, "Error logging event " + e.getMessage()); |
| } |
| } |
| } |