1 /** 2 * Copyright (c) 2017, The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package android.os; 18 19 import android.os.IPendingIntentRef; 20 import android.os.IPullAtomCallback; 21 import android.os.ParcelFileDescriptor; 22 23 /** 24 * Binder interface to communicate with the statistics management service. 25 * {@hide} 26 */ 27 interface IStatsd { 28 /** 29 * Tell the stats daemon that the android system server is up and running. 30 */ 31 oneway void systemRunning(); 32 33 /** 34 * Tell the stats daemon that the android system has finished booting. 35 */ 36 oneway void bootCompleted(); 37 38 /** 39 * Tell the stats daemon that the StatsCompanionService is up and running. 40 * Two-way binder call so that caller knows message received. 41 */ 42 void statsCompanionReady(); 43 44 /** 45 * Tells statsd that an anomaly may have occurred, so statsd can check whether this is so and 46 * act accordingly. 47 * Two-way binder call so that caller's method (and corresponding wakelocks) will linger. 48 */ 49 void informAnomalyAlarmFired(); 50 51 /** 52 * Tells statsd that it is time to poll some stats. Statsd will be responsible for determing 53 * what stats to poll and initiating the polling. 54 * Two-way binder call so that caller's method (and corresponding wakelocks) will linger. 55 */ 56 void informPollAlarmFired(); 57 58 /** 59 * Tells statsd that it is time to handle periodic alarms. Statsd will be responsible for 60 * determing what alarm subscriber to trigger. 61 * Two-way binder call so that caller's method (and corresponding wakelocks) will linger. 62 */ 63 void informAlarmForSubscriberTriggeringFired(); 64 65 /** 66 * Tells statsd that the device is about to shutdown. 67 */ 68 void informDeviceShutdown(); 69 70 /** 71 * Inform statsd about a file descriptor for a pipe through which we will pipe version 72 * and package information for each uid. 73 * Versions and package information are supplied via UidData proto where info for each app 74 * is captured in its own element of a repeated ApplicationInfo message. 75 */ 76 oneway void informAllUidData(in ParcelFileDescriptor fd); 77 78 /** 79 * Inform statsd what the uid, version, version_string, and installer are for one app that was 80 * updated. 81 */ 82 oneway void informOnePackage(in String app, in int uid, in long version, 83 in String version_string, in String installer); 84 85 /** 86 * Inform stats that an app was removed. 87 */ 88 oneway void informOnePackageRemoved(in String app, in int uid); 89 90 /** 91 * Fetches data for the specified configuration key. Returns a byte array representing proto 92 * wire-encoded of ConfigMetricsReportList. 93 * 94 * Requires Manifest.permission.DUMP. 95 */ 96 byte[] getData(in long key, int callingUid); 97 98 /** 99 * Fetches metadata across statsd. Returns byte array representing wire-encoded proto. 100 * 101 * Requires Manifest.permission.DUMP. 102 */ 103 byte[] getMetadata(); 104 105 /** 106 * Sets a configuration with the specified config id and subscribes to updates for this 107 * configuration key. Broadcasts will be sent if this configuration needs to be collected. 108 * The configuration must be a wire-encoded StatsdConfig. The receiver for this data is 109 * registered in a separate function. 110 * 111 * Requires Manifest.permission.DUMP. 112 */ 113 void addConfiguration(in long configId, in byte[] config, in int callingUid); 114 115 /** 116 * Registers the given pending intent for this config key. This intent is invoked when the 117 * memory consumed by the metrics for this configuration approach the pre-defined limits. There 118 * can be at most one listener per config key. 119 * 120 * Requires Manifest.permission.DUMP. 121 */ 122 void setDataFetchOperation(long configId, in IPendingIntentRef pendingIntentRef, 123 int callingUid); 124 125 /** 126 * Removes the data fetch operation for the specified configuration. 127 * 128 * Requires Manifest.permission.DUMP. 129 */ 130 void removeDataFetchOperation(long configId, int callingUid); 131 132 /** 133 * Registers the given pending intent for this packagename. This intent is invoked when the 134 * active status of any of the configs sent by this package changes and will contain a list of 135 * config ids that are currently active. It also returns the list of configs that are currently 136 * active. There can be at most one active configs changed listener per package. 137 * 138 * Requires Manifest.permission.DUMP and Manifest.permission.PACKAGE_USAGE_STATS. 139 */ 140 long[] setActiveConfigsChangedOperation(in IPendingIntentRef pendingIntentRef, int callingUid); 141 142 /** 143 * Removes the active configs changed operation for the specified package name. 144 * 145 * Requires Manifest.permission.DUMP and Manifest.permission.PACKAGE_USAGE_STATS. 146 */ 147 void removeActiveConfigsChangedOperation(int callingUid); 148 149 /** 150 * Removes the configuration with the matching config id. No-op if this config id does not 151 * exist. 152 * 153 * Requires Manifest.permission.DUMP. 154 */ 155 void removeConfiguration(in long configId, in int callingUid); 156 157 /** 158 * Set the PendingIntentRef to be used when broadcasting subscriber 159 * information to the given subscriberId within the given config. 160 * 161 * Suppose that the calling uid has added a config with key configId, and that in this config 162 * it is specified that when a particular anomaly is detected, a broadcast should be sent to 163 * a BroadcastSubscriber with id subscriberId. This function links the given pendingIntent with 164 * that subscriberId (for that config), so that this pendingIntent is used to send the broadcast 165 * when the anomaly is detected. 166 * 167 * This function can only be called by the owner (uid) of the config. It must be called each 168 * time statsd starts. Later calls overwrite previous calls; only one pendingIntent is stored. 169 * 170 * Requires Manifest.permission.DUMP. 171 */ 172 void setBroadcastSubscriber(long configId, long subscriberId, in IPendingIntentRef pir, 173 int callingUid); 174 175 /** 176 * Undoes setBroadcastSubscriber() for the (configId, subscriberId) pair. 177 * Any broadcasts associated with subscriberId will henceforth not be sent. 178 * No-op if this (configKey, subscriberId) pair was not associated with an PendingIntentRef. 179 * 180 * Requires Manifest.permission.DUMP. 181 */ 182 void unsetBroadcastSubscriber(long configId, long subscriberId, int callingUid); 183 184 /** 185 * Tell the stats daemon that all the pullers registered during boot have been sent. 186 */ 187 oneway void allPullersFromBootRegistered(); 188 189 /** 190 * Registers a puller callback function that, when invoked, pulls the data 191 * for the specified atom tag. 192 */ 193 oneway void registerPullAtomCallback(int uid, int atomTag, long coolDownMillis, 194 long timeoutMillis,in int[] additiveFields, 195 IPullAtomCallback pullerCallback); 196 197 /** 198 * Registers a puller callback function that, when invoked, pulls the data 199 * for the specified atom tag. 200 * 201 * Enforces the REGISTER_STATS_PULL_ATOM permission. 202 */ 203 oneway void registerNativePullAtomCallback(int atomTag, long coolDownMillis, long timeoutMillis, 204 in int[] additiveFields, IPullAtomCallback pullerCallback); 205 206 /** 207 * Unregisters any pullAtomCallback for the given uid/atom. 208 */ 209 oneway void unregisterPullAtomCallback(int uid, int atomTag); 210 211 /** 212 * Unregisters any pullAtomCallback for the given atom + caller. 213 * 214 * Enforces the REGISTER_STATS_PULL_ATOM permission. 215 */ 216 oneway void unregisterNativePullAtomCallback(int atomTag); 217 218 /** 219 * The install requires staging. 220 */ 221 const int FLAG_REQUIRE_STAGING = 0x01; 222 223 /** 224 * Rollback is enabled with this install. 225 */ 226 const int FLAG_ROLLBACK_ENABLED = 0x02; 227 228 /** 229 * Requires low latency monitoring. 230 */ 231 const int FLAG_REQUIRE_LOW_LATENCY_MONITOR = 0x04; 232 233 /** 234 * Returns the most recently registered experiment IDs. 235 */ 236 long[] getRegisteredExperimentIds(); 237 } 238