blob: 50b945723ceceb489170cece4ccc75023e7ec922 [file] [log] [blame]
Thieu Le3426c8f2012-01-11 17:35:11 -08001// Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
Thieu Le48e6d6d2011-12-06 00:40:27 +00002// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
Wade Guthrie60a37062013-04-02 11:39:09 -07005#ifndef SHILL_METRICS_H_
6#define SHILL_METRICS_H_
Thieu Le48e6d6d2011-12-06 00:40:27 +00007
8#include <list>
Alex Vakulenko8a532292014-06-16 17:18:44 -07009#include <map>
Ben Chancd477322014-10-17 14:19:30 -070010#include <memory>
Alex Vakulenko8a532292014-06-16 17:18:44 -070011#include <string>
Thieu Le48e6d6d2011-12-06 00:40:27 +000012
Thieu Le48e6d6d2011-12-06 00:40:27 +000013#include <base/memory/scoped_vector.h>
14#include <metrics/metrics_library.h>
15#include <metrics/timer.h>
16
Rebecca Silberstein3d49ea42014-08-21 11:20:50 -070017#include "shill/connectivity_trial.h"
Thieu Le6c1e3bb2013-02-06 15:20:35 -080018#include "shill/event_dispatcher.h"
Peter Qiu02e3dc32014-10-31 10:15:00 -070019#include "shill/net/ieee80211.h"
Thieu Le85e050b2012-03-13 15:04:38 -070020#include "shill/portal_detector.h"
Thieu Leb84ba342012-03-02 15:15:19 -080021#include "shill/power_manager.h"
Thieu Le48e6d6d2011-12-06 00:40:27 +000022#include "shill/refptr_types.h"
23#include "shill/service.h"
24
25namespace shill {
26
Gaurav Shah6d2c72d2012-10-16 16:30:44 -070027class WiFiMainTest;
Thieu Le48e6d6d2011-12-06 00:40:27 +000028class WiFiService;
29
30class Metrics {
31 public:
32 enum WiFiChannel {
33 kWiFiChannelUndef = 0,
34 kWiFiChannel2412 = 1,
35 kWiFiChannel2417 = 2,
36 kWiFiChannel2422 = 3,
37 kWiFiChannel2427 = 4,
38 kWiFiChannel2432 = 5,
39 kWiFiChannel2437 = 6,
40 kWiFiChannel2442 = 7,
41 kWiFiChannel2447 = 8,
42 kWiFiChannel2452 = 9,
43 kWiFiChannel2457 = 10,
44 kWiFiChannel2462 = 11,
45 kWiFiChannel2467 = 12,
46 kWiFiChannel2472 = 13,
47 kWiFiChannel2484 = 14,
48
49 kWiFiChannel5180 = 15,
50 kWiFiChannel5200 = 16,
51 kWiFiChannel5220 = 17,
52 kWiFiChannel5240 = 18,
53 kWiFiChannel5260 = 19,
54 kWiFiChannel5280 = 20,
55 kWiFiChannel5300 = 21,
56 kWiFiChannel5320 = 22,
57
58 kWiFiChannel5500 = 23,
59 kWiFiChannel5520 = 24,
60 kWiFiChannel5540 = 25,
61 kWiFiChannel5560 = 26,
62 kWiFiChannel5580 = 27,
63 kWiFiChannel5600 = 28,
64 kWiFiChannel5620 = 29,
65 kWiFiChannel5640 = 30,
66 kWiFiChannel5660 = 31,
67 kWiFiChannel5680 = 32,
68 kWiFiChannel5700 = 33,
69
70 kWiFiChannel5745 = 34,
71 kWiFiChannel5765 = 35,
72 kWiFiChannel5785 = 36,
73 kWiFiChannel5805 = 37,
74 kWiFiChannel5825 = 38,
75
76 kWiFiChannel5170 = 39,
77 kWiFiChannel5190 = 40,
78 kWiFiChannel5210 = 41,
79 kWiFiChannel5230 = 42,
80
81 /* NB: ignore old 11b bands 2312..2372 and 2512..2532 */
82 /* NB: ignore regulated bands 4920..4980 and 5020..5160 */
83 kWiFiChannelMax
84 };
85
Thieu Lead1ec2c2012-01-05 23:39:48 +000086 enum WiFiNetworkPhyMode {
87 kWiFiNetworkPhyModeUndef = 0, // Unknown/undefined
88 kWiFiNetworkPhyMode11a = 1, // 802.11a
89 kWiFiNetworkPhyMode11b = 2, // 802.11b
90 kWiFiNetworkPhyMode11g = 3, // 802.11g
91 kWiFiNetworkPhyMode11n = 4, // 802.11n
92 kWiFiNetworkPhyModeHalf = 5, // PSB Half-width
93 kWiFiNetworkPhyModeQuarter = 6, // PSB Quarter-width
94 kWiFiNetworkPhyModeTurbo = 7, // Atheros Turbo mode
95
96 kWiFiNetworkPhyModeMax
97 };
98
Paul Stewart21f40962013-03-01 14:27:28 -080099 enum EapOuterProtocol {
100 kEapOuterProtocolUnknown = 0,
101 kEapOuterProtocolLeap = 1,
102 kEapOuterProtocolPeap = 2,
103 kEapOuterProtocolTls = 3,
104 kEapOuterProtocolTtls = 4,
105
106 kEapOuterProtocolMax
107 };
108
109 enum EapInnerProtocol {
110 kEapInnerProtocolUnknown = 0,
111 kEapInnerProtocolNone = 1,
112 kEapInnerProtocolPeapMd5 = 2,
113 kEapInnerProtocolPeapMschapv2 = 3,
114 kEapInnerProtocolTtlsEapMd5 = 4,
115 kEapInnerProtocolTtlsEapMschapv2 = 5,
116 kEapInnerProtocolTtlsMschapv2 = 6,
117 kEapInnerProtocolTtlsMschap = 7,
118 kEapInnerProtocolTtlsPap = 8,
119 kEapInnerProtocolTtlsChap = 9,
120
121 kEapInnerProtocolMax
122 };
123
Thieu Lead1ec2c2012-01-05 23:39:48 +0000124 enum WiFiSecurity {
125 kWiFiSecurityUnknown = 0,
126 kWiFiSecurityNone = 1,
127 kWiFiSecurityWep = 2,
128 kWiFiSecurityWpa = 3,
129 kWiFiSecurityRsn = 4,
130 kWiFiSecurity8021x = 5,
131 kWiFiSecurityPsk = 6,
132
133 kWiFiSecurityMax
134 };
135
Paul Stewarte4cedde2013-07-17 08:56:44 -0700136 enum WiFiApMode {
137 kWiFiApModeUnknown = 0,
138 kWiFiApModeManaged = 1,
139 kWiFiApModeAdHoc = 2,
140
141 kWiFiApModeMax
142 };
143
Thieu Le85e050b2012-03-13 15:04:38 -0700144 enum PortalResult {
145 kPortalResultSuccess = 0,
146 kPortalResultDNSFailure = 1,
147 kPortalResultDNSTimeout = 2,
148 kPortalResultConnectionFailure = 3,
149 kPortalResultConnectionTimeout = 4,
150 kPortalResultHTTPFailure = 5,
151 kPortalResultHTTPTimeout = 6,
152 kPortalResultContentFailure = 7,
153 kPortalResultContentTimeout = 8,
154 kPortalResultUnknown = 9,
155
156 kPortalResultMax
157 };
158
Paul Stewartff845fc2012-08-07 07:28:44 -0700159 enum LinkMonitorFailure {
160 kLinkMonitorMacAddressNotFound = 0,
161 kLinkMonitorClientStartFailure = 1,
162 kLinkMonitorTransmitFailure = 2,
163 kLinkMonitorFailureThresholdReached = 3,
164
165 kLinkMonitorFailureMax
166 };
167
Wade Guthried4977f22012-08-22 12:37:54 -0700168 enum WiFiStatusType {
169 kStatusCodeTypeByAp,
170 kStatusCodeTypeByClient,
171 kStatusCodeTypeByUser,
172 kStatusCodeTypeConsideredDead,
173 kStatusCodeTypeMax
174 };
175
176 enum WiFiDisconnectByWhom {
177 kDisconnectedByAp,
178 kDisconnectedNotByAp
179 };
180
Wade Guthrieb9e0ee72013-05-31 09:23:30 -0700181 enum WiFiScanResult {
182 kScanResultProgressiveConnected,
183 kScanResultProgressiveErrorAndFullFoundNothing,
184 kScanResultProgressiveErrorButFullConnected,
185 kScanResultProgressiveAndFullFoundNothing,
186 kScanResultProgressiveAndFullConnected,
187 kScanResultFullScanFoundNothing,
188 kScanResultFullScanConnected,
189 kScanResultInternalError,
190 kScanResultMax
191 };
192
Paul Stewart85aea152013-01-22 09:31:56 -0800193 enum ServiceFixupProfileType {
194 kMetricServiceFixupDefaultProfile,
195 kMetricServiceFixupUserProfile,
196 kMetricServiceFixupMax
197 };
198
Arman Uguray6d528f12012-09-13 13:44:55 -0700199 enum TerminationActionResult {
Arman Ugurayab22c162012-10-08 19:08:38 -0700200 kTerminationActionResultSuccess,
201 kTerminationActionResultFailure,
Arman Uguray6d528f12012-09-13 13:44:55 -0700202 kTerminationActionResultMax
203 };
204
Samuel Tanfbe8d2b2014-09-15 20:23:59 -0700205 enum SuspendActionResult {
206 kSuspendActionResultSuccess,
207 kSuspendActionResultFailure,
208 kSuspendActionResultMax
Arman Ugurayab22c162012-10-08 19:08:38 -0700209 };
210
Samuel Tan68b73d22014-10-28 17:00:56 -0700211 enum DarkResumeActionResult {
212 kDarkResumeActionResultSuccess,
213 kDarkResumeActionResultFailure,
214 kDarkResumeActionResultMax
215 };
216
Samuel Tan0e0ac0d2014-12-29 16:03:42 -0800217 enum DarkResumeUnmatchedScanResultReceived {
218 kDarkResumeUnmatchedScanResultsReceivedFalse = 0,
219 kDarkResumeUnmatchedScanResultsReceivedTrue = 1,
220 kDarkResumeUnmatchedScanResultsReceivedMax
221 };
222
Samuel Tanf144d5d2014-11-25 18:18:01 -0800223 enum VerifyWakeOnWiFiSettingsResult {
224 kVerifyWakeOnWiFiSettingsResultSuccess,
225 kVerifyWakeOnWiFiSettingsResultFailure,
226 kVerifyWakeOnWiFiSettingsResultMax
227 };
228
Samuel Tan1964b5d2014-12-02 10:11:21 -0800229 enum WiFiConnectionStatusAfterWake {
230 kWiFiConnetionStatusAfterWakeOnWiFiEnabledWakeConnected = 0,
231 kWiFiConnetionStatusAfterWakeOnWiFiEnabledWakeNotConnected = 1,
232 kWiFiConnetionStatusAfterWakeOnWiFiDisabledWakeConnected = 2,
233 kWiFiConnetionStatusAfterWakeOnWiFiDisabledWakeNotConnected = 3,
234 kWiFiConnetionStatusAfterWakeMax
235 };
236
Prathmesh Prabhu08757aa2013-05-15 17:17:33 -0700237 enum Cellular3GPPRegistrationDelayedDrop {
238 kCellular3GPPRegistrationDelayedDropPosted = 0,
239 kCellular3GPPRegistrationDelayedDropCanceled = 1,
240 kCellular3GPPRegistrationDelayedDropMax
241 };
242
Thieu Le26fc01b2013-01-28 12:08:48 -0800243 enum CellularDropTechnology {
244 kCellularDropTechnology1Xrtt = 0,
245 kCellularDropTechnologyEdge = 1,
246 kCellularDropTechnologyEvdo = 2,
247 kCellularDropTechnologyGprs = 3,
248 kCellularDropTechnologyGsm = 4,
249 kCellularDropTechnologyHspa = 5,
250 kCellularDropTechnologyHspaPlus = 6,
251 kCellularDropTechnologyLte = 7,
252 kCellularDropTechnologyUmts = 8,
253 kCellularDropTechnologyUnknown = 9,
254 kCellularDropTechnologyMax
255 };
256
Thieu Le91fccf62013-04-22 15:23:16 -0700257 enum CellularOutOfCreditsReason {
258 kCellularOutOfCreditsReasonConnectDisconnectLoop = 0,
259 kCellularOutOfCreditsReasonTxCongested = 1,
260 kCellularOutOfCreditsReasonElongatedTimeWait = 2,
261 kCellularOutOfCreditsReasonMax
262 };
263
Thieu Le5133b712013-02-19 14:47:21 -0800264 enum CorruptedProfile {
265 kCorruptedProfile = 1,
266 kCorruptedProfileMax
267 };
268
Paul Stewart91a43cb2013-03-02 21:34:15 -0800269 enum VpnDriver {
270 kVpnDriverOpenVpn = 0,
271 kVpnDriverL2tpIpsec = 1,
272 kVpnDriverMax
273 };
274
275 enum VpnRemoteAuthenticationType {
276 kVpnRemoteAuthenticationTypeOpenVpnDefault = 0,
277 kVpnRemoteAuthenticationTypeOpenVpnCertificate = 1,
278 kVpnRemoteAuthenticationTypeL2tpIpsecDefault = 2,
279 kVpnRemoteAuthenticationTypeL2tpIpsecCertificate = 3,
280 kVpnRemoteAuthenticationTypeL2tpIpsecPsk = 4,
281 kVpnRemoteAuthenticationTypeMax
282 };
283
284 enum VpnUserAuthenticationType {
285 kVpnUserAuthenticationTypeOpenVpnNone = 0,
286 kVpnUserAuthenticationTypeOpenVpnCertificate = 1,
287 kVpnUserAuthenticationTypeOpenVpnUsernamePassword = 2,
288 kVpnUserAuthenticationTypeOpenVpnUsernamePasswordOtp = 3,
Paul Stewartb5768232014-02-27 07:21:34 -0800289 kVpnUserAuthenticationTypeOpenVpnUsernameToken = 7,
Paul Stewart91a43cb2013-03-02 21:34:15 -0800290 kVpnUserAuthenticationTypeL2tpIpsecNone = 4,
291 kVpnUserAuthenticationTypeL2tpIpsecCertificate = 5,
292 kVpnUserAuthenticationTypeL2tpIpsecUsernamePassword = 6,
293 kVpnUserAuthenticationTypeMax
294 };
295
Peter Qiue783f1c2014-05-02 11:42:33 -0700296 enum UserInitiatedEvent {
297 kUserInitiatedEventWifiScan = 0,
Peter Qiu6b56cad2014-08-06 14:11:19 -0700298 kUserInitiatedEventReserved,
Peter Qiue783f1c2014-05-02 11:42:33 -0700299 kUserInitiatedEventMax
Paul Stewartdded0072013-10-24 12:38:54 -0700300 };
301
Peter Qiudc4e0992014-05-01 10:02:52 -0700302 enum UserInitiatedConnectionResult {
303 kUserInitiatedConnectionResultSuccess = 0,
304 kUserInitiatedConnectionResultFailure = 1,
305 kUserInitiatedConnectionResultAborted = 2,
306 kUserInitiatedConnectionResultMax
307 };
308
Peter Qiub9256f32014-05-09 15:27:29 -0700309 enum DNSTestResult {
Peter Qiuf18e7712014-05-20 09:59:46 -0700310 kFallbackDNSTestResultSuccess = 0,
311 kFallbackDNSTestResultFailure,
312 kFallbackDNSTestResultMax
Peter Qiub9256f32014-05-09 15:27:29 -0700313 };
314
Peter Qiudc335f82014-05-15 10:33:17 -0700315 // Network problem detected by traffic monitor.
316 enum NetworkProblem {
317 kNetworkProblemCongestedTCPTxQueue = 0,
318 kNetworkProblemDNSFailure,
319 kNetworkProblemMax
320 };
321
Peter Qiu700de642014-07-14 16:31:30 -0700322 // Device's connection status.
323 enum ConnectionStatus {
324 kConnectionStatusOffline = 0,
325 kConnectionStatusConnected = 1,
326 kConnectionStatusOnline = 2,
327 kConnectionStatusMax
328 };
329
Peter Qiud87179e2014-07-10 18:29:22 -0700330 enum UserInitiatedConnectionFailureReason {
331 kUserInitiatedConnectionFailureReasonUnknown = 0,
332 kUserInitiatedConnectionFailureReasonBadPassphrase = 1,
333 kUserInitiatedConnectionFailureReasonBadWEPKey = 2,
334 kUserInitiatedConnectionFailureReasonConnect = 3,
335 kUserInitiatedConnectionFailureReasonDHCP = 4,
336 kUserInitiatedConnectionFailureReasonDNSLookup = 5,
337 kUserInitiatedConnectionFailureReasonEAPAuthentication = 6,
338 kUserInitiatedConnectionFailureReasonEAPLocalTLS = 7,
339 kUserInitiatedConnectionFailureReasonEAPRemoteTLS = 8,
340 kUserInitiatedConnectionFailureReasonOutOfRange = 9,
341 kUserInitiatedConnectionFailureReasonPinMissing = 10,
342 kUserInitiatedConnectionFailureReasonMax
343 };
344
Paul Stewart3bdf1ab2014-07-17 19:22:26 -0700345 enum DhcpClientStatus {
Paul Stewarta72a79c2014-07-21 13:52:03 -0700346 kDhcpClientStatusArpGateway = 0,
347 kDhcpClientStatusArpSelf = 1,
348 kDhcpClientStatusBound = 2,
349 kDhcpClientStatusDiscover = 3,
350 kDhcpClientStatusIgnoreAdditionalOffer = 4,
351 kDhcpClientStatusIgnoreFailedOffer = 5,
352 kDhcpClientStatusIgnoreInvalidOffer = 6,
353 kDhcpClientStatusIgnoreNonOffer = 7,
354 kDhcpClientStatusInform = 8,
355 kDhcpClientStatusInit = 9,
356 kDhcpClientStatusNakDefer = 10,
357 kDhcpClientStatusRebind = 11,
358 kDhcpClientStatusReboot = 12,
359 kDhcpClientStatusRelease = 13,
360 kDhcpClientStatusRenew = 14,
361 kDhcpClientStatusRequest = 15,
Paul Stewart3bdf1ab2014-07-17 19:22:26 -0700362 kDhcpClientStatusMax
363 };
364
Peter Qiu300769e2014-08-27 11:48:45 -0700365 enum NetworkConnectionIPType {
366 kNetworkConnectionIPTypeIPv4 = 0,
367 kNetworkConnectionIPTypeIPv6 = 1,
368 kNetworkConnectionIPTypeMax
369 };
370
371 enum IPv6ConnectivityStatus {
372 kIPv6ConnectivityStatusNo = 0,
373 kIPv6ConnectivityStatusYes = 1,
374 kIPv6ConnectivityStatusMax
375 };
376
Peter Qiu94d18af2014-09-11 15:54:15 -0700377 enum DevicePresenceStatus {
378 kDevicePresenceStatusNo = 0,
379 kDevicePresenceStatusYes = 1,
380 kDevicePresenceStatusMax
381 };
382
Peter Qiu9f5159e2014-09-12 16:50:14 -0700383 enum DeviceTechnologyType {
384 kDeviceTechnologyTypeUnknown = 0,
385 kDeviceTechnologyTypeEthernet = 1,
386 kDeviceTechnologyTypeWifi = 2,
387 kDeviceTechnologyTypeWimax = 3,
388 kDeviceTechnologyTypeCellular = 4,
389 kDeviceTechnologyTypeMax
390 };
391
Peter Qiu27df3642014-09-19 09:50:54 -0700392 enum NetworkServiceError {
393 kNetworkServiceErrorUnknown = 0,
394 kNetworkServiceErrorAAA = 1,
395 kNetworkServiceErrorActivation = 2,
396 kNetworkServiceErrorBadPassphrase = 3,
397 kNetworkServiceErrorBadWEPKey = 4,
398 kNetworkServiceErrorConnect = 5,
399 kNetworkServiceErrorDHCP = 6,
400 kNetworkServiceErrorDNSLookup = 7,
401 kNetworkServiceErrorEAPAuthentication = 8,
402 kNetworkServiceErrorEAPLocalTLS = 9,
403 kNetworkServiceErrorEAPRemoteTLS = 10,
404 kNetworkServiceErrorHTTPGet = 11,
405 kNetworkServiceErrorIPSecCertAuth = 12,
406 kNetworkServiceErrorIPSecPSKAuth = 13,
407 kNetworkServiceErrorInternal = 14,
408 kNetworkServiceErrorNeedEVDO = 15,
409 kNetworkServiceErrorNeedHomeNetwork = 16,
410 kNetworkServiceErrorOTASP = 17,
411 kNetworkServiceErrorOutOfRange = 18,
412 kNetworkServiceErrorPPPAuth = 19,
413 kNetworkServiceErrorPinMissing = 20,
414 kNetworkServiceErrorMax
415 };
416
Samuel Tan66bddc62014-11-13 20:01:04 -0800417 enum WakeOnWiFiFeaturesEnabledState {
418 kWakeOnWiFiFeaturesEnabledStateNone = 0,
419 kWakeOnWiFiFeaturesEnabledStatePacket = 1,
420 kWakeOnWiFiFeaturesEnabledStateSSID = 2,
421 kWakeOnWiFiFeaturesEnabledStatePacketSSID = 3,
422 kWakeOnWiFiFeaturesEnabledStateMax
423 };
424
Samuel Tanc36b4102015-01-26 19:34:35 -0800425 enum WakeOnWiFiThrottled {
426 kWakeOnWiFiThrottledFalse = 0,
427 kWakeOnWiFiThrottledTrue = 1,
428 kWakeOnWiFiThrottledMax
429 };
430
mukesh agrawal132e96f2014-04-24 11:49:42 -0700431 static const char kMetricDisconnectSuffix[];
Thieu Le67370f62012-02-14 23:01:42 +0000432 static const int kMetricDisconnectMax;
433 static const int kMetricDisconnectMin;
434 static const int kMetricDisconnectNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700435 static const char kMetricSignalAtDisconnectSuffix[];
Wade Guthrie9ec08062013-09-25 15:22:24 -0700436 static const int kMetricSignalAtDisconnectMin;
437 static const int kMetricSignalAtDisconnectMax;
438 static const int kMetricSignalAtDisconnectNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700439 static const char kMetricNetworkApModeSuffix[];
440 static const char kMetricNetworkChannelSuffix[];
Thieu Le48e6d6d2011-12-06 00:40:27 +0000441 static const int kMetricNetworkChannelMax;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700442 static const char kMetricNetworkEapInnerProtocolSuffix[];
Paul Stewart21f40962013-03-01 14:27:28 -0800443 static const int kMetricNetworkEapInnerProtocolMax;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700444 static const char kMetricNetworkEapOuterProtocolSuffix[];
Paul Stewart21f40962013-03-01 14:27:28 -0800445 static const int kMetricNetworkEapOuterProtocolMax;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700446 static const char kMetricNetworkPhyModeSuffix[];
Thieu Lead1ec2c2012-01-05 23:39:48 +0000447 static const int kMetricNetworkPhyModeMax;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700448 static const char kMetricNetworkSecuritySuffix[];
Thieu Lead1ec2c2012-01-05 23:39:48 +0000449 static const int kMetricNetworkSecurityMax;
Thieu Le48e6d6d2011-12-06 00:40:27 +0000450 static const char kMetricNetworkServiceErrors[];
mukesh agrawal132e96f2014-04-24 11:49:42 -0700451 static const char kMetricNetworkSignalStrengthSuffix[];
Paul Stewart23b393a2012-09-25 21:21:06 -0700452 static const int kMetricNetworkSignalStrengthMin;
453 static const int kMetricNetworkSignalStrengthMax;
454 static const int kMetricNetworkSignalStrengthNumBuckets;
mukesh agrawalfacf7ad2014-09-30 15:25:44 -0700455 // Histogram parameters for next two are the same as for
456 // kMetricRememberedWiFiNetworkCount. Must be constexpr, for static
457 // checking of format string. Must be defined inline, for constexpr.
458 static constexpr char
459 kMetricRememberedSystemWiFiNetworkCountBySecurityModeFormat[] =
460 "Network.Shill.WiFi.RememberedSystemNetworkCount.%s";
461 static constexpr char
462 kMetricRememberedUserWiFiNetworkCountBySecurityModeFormat[] =
463 "Network.Shill.WiFi.RememberedUserNetworkCount.%s";
Paul Stewart4ef524d2014-07-23 13:11:29 -0700464 static const char kMetricRememberedWiFiNetworkCount[];
465 static const int kMetricRememberedWiFiNetworkCountMin;
466 static const int kMetricRememberedWiFiNetworkCountMax;
467 static const int kMetricRememberedWiFiNetworkCountNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700468 static const char kMetricTimeOnlineSecondsSuffix[];
Thieu Lea20cbc22012-01-09 22:01:43 +0000469 static const int kMetricTimeOnlineSecondsMax;
470 static const int kMetricTimeOnlineSecondsMin;
471 static const int kMetricTimeOnlineSecondsNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700472 static const char kMetricTimeResumeToReadyMillisecondsSuffix[];
473 static const char kMetricTimeToConfigMillisecondsSuffix[];
474 static const char kMetricTimeToConnectMillisecondsSuffix[];
Thieu Lecdb5a212013-01-25 11:17:18 -0800475 static const int kMetricTimeToConnectMillisecondsMax;
476 static const int kMetricTimeToConnectMillisecondsMin;
477 static const int kMetricTimeToConnectMillisecondsNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700478 static const char kMetricTimeToScanAndConnectMillisecondsSuffix[];
Thieu Lea20cbc22012-01-09 22:01:43 +0000479 static const char kMetricTimeToDropSeconds[];
480 static const int kMetricTimeToDropSecondsMax;
481 static const int kMetricTimeToDropSecondsMin;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700482 static const char kMetricTimeToDisableMillisecondsSuffix[];
Thieu Lea2519bf2013-01-23 16:51:54 -0800483 static const int kMetricTimeToDisableMillisecondsMax;
484 static const int kMetricTimeToDisableMillisecondsMin;
485 static const int kMetricTimeToDisableMillisecondsNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700486 static const char kMetricTimeToEnableMillisecondsSuffix[];
Thieu Lece4483e2013-01-23 15:12:03 -0800487 static const int kMetricTimeToEnableMillisecondsMax;
488 static const int kMetricTimeToEnableMillisecondsMin;
489 static const int kMetricTimeToEnableMillisecondsNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700490 static const char kMetricTimeToInitializeMillisecondsSuffix[];
Thieu Lec8078a62013-01-22 18:01:12 -0800491 static const int kMetricTimeToInitializeMillisecondsMax;
Thieu Lece4483e2013-01-23 15:12:03 -0800492 static const int kMetricTimeToInitializeMillisecondsMin;
Thieu Lec8078a62013-01-22 18:01:12 -0800493 static const int kMetricTimeToInitializeMillisecondsNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700494 static const char kMetricTimeToJoinMillisecondsSuffix[];
495 static const char kMetricTimeToOnlineMillisecondsSuffix[];
496 static const char kMetricTimeToPortalMillisecondsSuffix[];
497 static const char kMetricTimeToScanMillisecondsSuffix[];
Thieu Le18c11072013-01-28 17:21:37 -0800498 static const int kMetricTimeToScanMillisecondsMax;
499 static const int kMetricTimeToScanMillisecondsMin;
500 static const int kMetricTimeToScanMillisecondsNumBuckets;
Thieu Lea20cbc22012-01-09 22:01:43 +0000501 static const int kTimerHistogramMillisecondsMax;
502 static const int kTimerHistogramMillisecondsMin;
Thieu Le48e6d6d2011-12-06 00:40:27 +0000503 static const int kTimerHistogramNumBuckets;
504
Thieu Le85e050b2012-03-13 15:04:38 -0700505 // The number of portal detections attempted for each pass.
506 // This includes both failure/timeout attempts and successful attempt
507 // (if any).
mukesh agrawal132e96f2014-04-24 11:49:42 -0700508 static const char kMetricPortalAttemptsSuffix[];
Thieu Le85e050b2012-03-13 15:04:38 -0700509 static const int kMetricPortalAttemptsMax;
510 static const int kMetricPortalAttemptsMin;
511 static const int kMetricPortalAttemptsNumBuckets;
512
513 // The total number of portal detections attempted between the Connected
514 // state and the Online state. This includes both failure/timeout attempts
515 // and the final successful attempt.
mukesh agrawal132e96f2014-04-24 11:49:42 -0700516 static const char kMetricPortalAttemptsToOnlineSuffix[];
Thieu Le85e050b2012-03-13 15:04:38 -0700517 static const int kMetricPortalAttemptsToOnlineMax;
518 static const int kMetricPortalAttemptsToOnlineMin;
519 static const int kMetricPortalAttemptsToOnlineNumBuckets;
520
521 // The result of the portal detection.
mukesh agrawal132e96f2014-04-24 11:49:42 -0700522 static const char kMetricPortalResultSuffix[];
Thieu Le85e050b2012-03-13 15:04:38 -0700523
Wade Guthrie60a37062013-04-02 11:39:09 -0700524 // Wifi connection frequencies.
525 static const char kMetricFrequenciesConnectedEver[];
526 static const int kMetricFrequenciesConnectedMax;
527 static const int kMetricFrequenciesConnectedMin;
528 static const int kMetricFrequenciesConnectedNumBuckets;
529
Wade Guthrieb9e0ee72013-05-31 09:23:30 -0700530 static const char kMetricScanResult[];
Wade Guthrief22681f2013-05-31 11:46:31 -0700531 static const char kMetricWiFiScanTimeInEbusyMilliseconds[];
532
Thieu Leb84ba342012-03-02 15:15:19 -0800533 static const char kMetricPowerManagerKey[];
534
Paul Stewartff845fc2012-08-07 07:28:44 -0700535 // LinkMonitor statistics.
mukesh agrawal132e96f2014-04-24 11:49:42 -0700536 static const char kMetricLinkMonitorFailureSuffix[];
537 static const char kMetricLinkMonitorResponseTimeSampleSuffix[];
Paul Stewartf1961f82012-09-11 20:45:39 -0700538 static const int kMetricLinkMonitorResponseTimeSampleMin;
539 static const int kMetricLinkMonitorResponseTimeSampleMax;
Paul Stewartff845fc2012-08-07 07:28:44 -0700540 static const int kMetricLinkMonitorResponseTimeSampleNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700541 static const char kMetricLinkMonitorSecondsToFailureSuffix[];
Paul Stewartf1961f82012-09-11 20:45:39 -0700542 static const int kMetricLinkMonitorSecondsToFailureMin;
543 static const int kMetricLinkMonitorSecondsToFailureMax;
Paul Stewart0443aa52012-08-09 10:43:50 -0700544 static const int kMetricLinkMonitorSecondsToFailureNumBuckets;
mukesh agrawal132e96f2014-04-24 11:49:42 -0700545 static const char kMetricLinkMonitorBroadcastErrorsAtFailureSuffix[];
546 static const char kMetricLinkMonitorUnicastErrorsAtFailureSuffix[];
Paul Stewartf1961f82012-09-11 20:45:39 -0700547 static const int kMetricLinkMonitorErrorCountMin;
548 static const int kMetricLinkMonitorErrorCountMax;
Paul Stewart0443aa52012-08-09 10:43:50 -0700549 static const int kMetricLinkMonitorErrorCountNumBuckets;
Paul Stewartff845fc2012-08-07 07:28:44 -0700550
Peter Qiua0572032014-09-26 10:07:37 -0700551 // Signal strength when link becomes unreliable (multiple link monitor
552 // failures in short period of time).
553 static const char kMetricUnreliableLinkSignalStrengthSuffix[];
554 static const int kMetricSerivceSignalStrengthMin;
555 static const int kMetricServiceSignalStrengthMax;
556 static const int kMetricServiceSignalStrengthNumBuckets;
557
Wade Guthried4977f22012-08-22 12:37:54 -0700558 static const char kMetricLinkClientDisconnectReason[];
559 static const char kMetricLinkApDisconnectReason[];
560 static const char kMetricLinkClientDisconnectType[];
561 static const char kMetricLinkApDisconnectType[];
562
Arman Uguray6d528f12012-09-13 13:44:55 -0700563 // Shill termination action statistics.
Samuel Tanea7dcda2015-01-05 14:32:50 -0800564 static const char kMetricTerminationActionTimeTaken[];
Samuel Tanfbe8d2b2014-09-15 20:23:59 -0700565 static const char kMetricTerminationActionResult[];
Samuel Tanea7dcda2015-01-05 14:32:50 -0800566 static const int kMetricTerminationActionTimeTakenMillisecondsMax;
567 static const int kMetricTerminationActionTimeTakenMillisecondsMin;
Arman Uguray6d528f12012-09-13 13:44:55 -0700568
Samuel Tanfbe8d2b2014-09-15 20:23:59 -0700569 // Shill suspend action statistics.
Samuel Tanea7dcda2015-01-05 14:32:50 -0800570 static const char kMetricSuspendActionTimeTaken[];
Samuel Tanfbe8d2b2014-09-15 20:23:59 -0700571 static const char kMetricSuspendActionResult[];
Samuel Tanea7dcda2015-01-05 14:32:50 -0800572 static const int kMetricSuspendActionTimeTakenMillisecondsMax;
573 static const int kMetricSuspendActionTimeTakenMillisecondsMin;
Samuel Tanfbe8d2b2014-09-15 20:23:59 -0700574
Samuel Tan68b73d22014-10-28 17:00:56 -0700575 // Shill dark resume action statistics.
Samuel Tanea7dcda2015-01-05 14:32:50 -0800576 static const char kMetricDarkResumeActionTimeTaken[];
Samuel Tan68b73d22014-10-28 17:00:56 -0700577 static const char kMetricDarkResumeActionResult[];
Samuel Tanea7dcda2015-01-05 14:32:50 -0800578 static const int kMetricDarkResumeActionTimeTakenMillisecondsMax;
579 static const int kMetricDarkResumeActionTimeTakenMillisecondsMin;
Samuel Tan0e0ac0d2014-12-29 16:03:42 -0800580 static const char kMetricDarkResumeUnmatchedScanResultReceived[];
Samuel Tan68b73d22014-10-28 17:00:56 -0700581
Samuel Tan66bddc62014-11-13 20:01:04 -0800582 // Shill wake on WiFi feature state statistics.
583 static const char kMetricWakeOnWiFiFeaturesEnabledState[];
584
Paul Stewart85aea152013-01-22 09:31:56 -0800585 // WiFiService Entry Fixup.
mukesh agrawal132e96f2014-04-24 11:49:42 -0700586 static const char kMetricServiceFixupEntriesSuffix[];
Paul Stewart85aea152013-01-22 09:31:56 -0800587
Thieu Le26fc01b2013-01-28 12:08:48 -0800588 // Cellular specific statistics.
Prathmesh Prabhu08757aa2013-05-15 17:17:33 -0700589 static const char kMetricCellular3GPPRegistrationDelayedDrop[];
Thieu Le7cf36b02013-01-30 17:15:56 -0800590 static const char kMetricCellularAutoConnectTries[];
591 static const int kMetricCellularAutoConnectTriesMax;
592 static const int kMetricCellularAutoConnectTriesMin;
593 static const int kMetricCellularAutoConnectTriesNumBuckets;
594 static const char kMetricCellularAutoConnectTotalTime[];
595 static const int kMetricCellularAutoConnectTotalTimeMax;
596 static const int kMetricCellularAutoConnectTotalTimeMin;
597 static const int kMetricCellularAutoConnectTotalTimeNumBuckets;
Thieu Le91fccf62013-04-22 15:23:16 -0700598 static const char kMetricCellularDrop[];
599 static const char kMetricCellularDropsPerHour[];
600 static const int kMetricCellularDropsPerHourMax;
601 static const int kMetricCellularDropsPerHourMin;
602 static const int kMetricCellularDropsPerHourNumBuckets;
603 static const char kMetricCellularFailureReason[];
604 static const char kMetricCellularOutOfCreditsReason[];
605 static const char kMetricCellularSignalStrengthBeforeDrop[];
606 static const int kMetricCellularSignalStrengthBeforeDropMax;
607 static const int kMetricCellularSignalStrengthBeforeDropMin;
608 static const int kMetricCellularSignalStrengthBeforeDropNumBuckets;
Thieu Le26fc01b2013-01-28 12:08:48 -0800609
Thieu Le5133b712013-02-19 14:47:21 -0800610 // Profile statistics.
611 static const char kMetricCorruptedProfile[];
612
Paul Stewart91a43cb2013-03-02 21:34:15 -0800613 // VPN connection statistics.
614 static const char kMetricVpnDriver[];
615 static const int kMetricVpnDriverMax;
616 static const char kMetricVpnRemoteAuthenticationType[];
617 static const int kMetricVpnRemoteAuthenticationTypeMax;
618 static const char kMetricVpnUserAuthenticationType[];
619 static const int kMetricVpnUserAuthenticationTypeMax;
620
Paul Stewart1f916e42013-12-23 09:52:54 -0800621 // The length in seconds of a lease that has expired while the DHCP
622 // client was attempting to renew the lease..
mukesh agrawal132e96f2014-04-24 11:49:42 -0700623 static const char kMetricExpiredLeaseLengthSecondsSuffix[];
Paul Stewart1f916e42013-12-23 09:52:54 -0800624 static const int kMetricExpiredLeaseLengthSecondsMax;
625 static const int kMetricExpiredLeaseLengthSecondsMin;
626 static const int kMetricExpiredLeaseLengthSecondsNumBuckets;
627
Peter Qiu574996a2014-04-04 10:55:47 -0700628 // Number of wifi services available when auto-connect is initiated.
629 static const char kMetricWifiAutoConnectableServices[];
630 static const int kMetricWifiAutoConnectableServicesMax;
631 static const int kMetricWifiAutoConnectableServicesMin;
632 static const int kMetricWifiAutoConnectableServicesNumBuckets;
633
634 // Number of BSSes available for a wifi service when we attempt to connect
635 // to that service.
636 static const char kMetricWifiAvailableBSSes[];
637 static const int kMetricWifiAvailableBSSesMax;
638 static const int kMetricWifiAvailableBSSesMin;
639 static const int kMetricWifiAvailableBSSesNumBuckets;
640
mukesh agrawalf7348732014-08-06 18:08:56 -0700641 // Reason that the mac80211 TX queue is stopped.
642 static const char kMetricWifiStoppedTxQueueReason[];
643
644 // Maximal queue length amongst all stopped mac80211 TX queues.
645 static const char kMetricWifiStoppedTxQueueLength[];
646 static const int kMetricWifiStoppedTxQueueLengthMax;
647 static const int kMetricWifiStoppedTxQueueLengthMin;
648 static const int kMetricWifiStoppedTxQueueLengthNumBuckets;
649
Peter Qiu39d4af02014-04-14 12:24:01 -0700650 // Number of services associated with currently connected network.
651 static const char kMetricServicesOnSameNetwork[];
652 static const int kMetricServicesOnSameNetworkMax;
653 static const int kMetricServicesOnSameNetworkMin;
654 static const int kMetricServicesOnSameNetworkNumBuckets;
655
Peter Qiue783f1c2014-05-02 11:42:33 -0700656 // Metric for user-initiated events.
657 static const char kMetricUserInitiatedEvents[];
658
Peter Qiu8e430582014-04-30 14:12:37 -0700659 // Wifi TX bitrate in Mbps.
660 static const char kMetricWifiTxBitrate[];
661 static const int kMetricWifiTxBitrateMax;
662 static const int kMetricWifiTxBitrateMin;
663 static const int kMetricWifiTxBitrateNumBuckets;
664
Peter Qiudc4e0992014-05-01 10:02:52 -0700665 // User-initiated wifi connection attempt result.
666 static const char kMetricWifiUserInitiatedConnectionResult[];
667
Peter Qiud87179e2014-07-10 18:29:22 -0700668 // The reason of failed user-initiated wifi connection attempt.
669 static const char kMetricWifiUserInitiatedConnectionFailureReason[];
670
Peter Qiub9256f32014-05-09 15:27:29 -0700671 // DNS test result.
Peter Qiuf18e7712014-05-20 09:59:46 -0700672 static const char kMetricFallbackDNSTestResultSuffix[];
Peter Qiub9256f32014-05-09 15:27:29 -0700673
Peter Qiudc335f82014-05-15 10:33:17 -0700674 // Network problem detected by traffic monitor
675 static const char kMetricNetworkProblemDetectedSuffix[];
676
Peter Qiu700de642014-07-14 16:31:30 -0700677 // Device's connection status.
678 static const char kMetricDeviceConnectionStatus[];
679
Paul Stewart3bdf1ab2014-07-17 19:22:26 -0700680 // DHCP client status.
681 static const char kMetricDhcpClientStatus[];
682
Peter Qiu300769e2014-08-27 11:48:45 -0700683 // Network connection IP type.
684 static const char kMetricNetworkConnectionIPTypeSuffix[];
685
686 // IPv6 connectivity status.
687 static const char kMetricIPv6ConnectivityStatusSuffix[];
688
Peter Qiu94d18af2014-09-11 15:54:15 -0700689 // Device presence.
690 static const char kMetricDevicePresenceStatusSuffix[];
691
Peter Qiu9f5159e2014-09-12 16:50:14 -0700692 // Device removal event.
693 static const char kMetricDeviceRemovedEvent[];
694
Samuel Tanf144d5d2014-11-25 18:18:01 -0800695 // The result of NIC wake on WiFi settings verification.
696 static const char kMetricVerifyWakeOnWiFiSettingsResult[];
697
Samuel Tan1964b5d2014-12-02 10:11:21 -0800698 // WiFi device connection status after waking from suspend.
699 static const char kMetricWiFiConnectionStatusAfterWake[];
700
Samuel Tanc36b4102015-01-26 19:34:35 -0800701 // Whether or not wake on WiFi was throttled during the last suspend.
702 static const char kMetricWakeOnWiFiThrottled[];
703
Thieu Le6c1e3bb2013-02-06 15:20:35 -0800704 explicit Metrics(EventDispatcher *dispatcher);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000705 virtual ~Metrics();
706
Thieu Le48e6d6d2011-12-06 00:40:27 +0000707 // Converts the WiFi frequency into the associated UMA channel enumerator.
Ben Chan7fab8972014-08-10 17:14:46 -0700708 static WiFiChannel WiFiFrequencyToChannel(uint16_t frequency);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000709
Thieu Lead1ec2c2012-01-05 23:39:48 +0000710 // Converts a flimflam security string into its UMA security enumerator.
711 static WiFiSecurity WiFiSecurityStringToEnum(const std::string &security);
712
Paul Stewarte4cedde2013-07-17 08:56:44 -0700713 // Converts a flimflam AP mode string into its UMA AP mode enumerator.
714 static WiFiApMode WiFiApModeStringToEnum(const std::string &ap_mode);
715
Paul Stewart21f40962013-03-01 14:27:28 -0800716 // Converts a flimflam EAP outer protocol string into its UMA enumerator.
717 static EapOuterProtocol EapOuterProtocolStringToEnum(
718 const std::string &outer);
719
720 // Converts a flimflam EAP inner protocol string into its UMA enumerator.
721 static EapInnerProtocol EapInnerProtocolStringToEnum(
722 const std::string &inner);
723
Thieu Le85e050b2012-03-13 15:04:38 -0700724 // Converts portal detection result to UMA portal result enumerator.
725 static PortalResult PortalDetectionResultToEnum(
726 const PortalDetector::Result &result);
727
Thieu Le6c1e3bb2013-02-06 15:20:35 -0800728 // Starts this object. Call this during initialization.
729 virtual void Start();
730
731 // Stops this object. Call this during cleanup.
732 virtual void Stop();
733
Thieu Le48e6d6d2011-12-06 00:40:27 +0000734 // Registers a service with this object so it can use the timers to track
735 // state transition metrics.
Wade Guthrie7ac610b2013-10-01 17:48:14 -0700736 void RegisterService(const Service &service);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000737
738 // Deregisters the service from this class. All state transition timers
739 // will be removed.
Wade Guthrie7ac610b2013-10-01 17:48:14 -0700740 void DeregisterService(const Service &service);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000741
742 // Tracks the time it takes |service| to go from |start_state| to
743 // |stop_state|. When |stop_state| is reached, the time is sent to UMA.
mukesh agrawal6cfe53f2013-08-13 13:39:01 -0700744 virtual void AddServiceStateTransitionTimer(
Wade Guthrie7ac610b2013-10-01 17:48:14 -0700745 const Service &service, const std::string &histogram_name,
mukesh agrawal6cfe53f2013-08-13 13:39:01 -0700746 Service::ConnectState start_state, Service::ConnectState stop_state);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000747
mukesh agrawal132e96f2014-04-24 11:49:42 -0700748 // Specializes |metric_suffix| for the specified |technology_id|.
749 std::string GetFullMetricName(const char *metric_suffix,
Thieu Le48e6d6d2011-12-06 00:40:27 +0000750 Technology::Identifier technology_id);
751
752 // Notifies this object that the default service has changed.
753 // |service| is the new default service.
Thieu Lea20cbc22012-01-09 22:01:43 +0000754 virtual void NotifyDefaultServiceChanged(const Service *service);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000755
756 // Notifies this object that |service| state has changed.
Wade Guthrie7ac610b2013-10-01 17:48:14 -0700757 virtual void NotifyServiceStateChanged(const Service &service,
Thieu Le48e6d6d2011-12-06 00:40:27 +0000758 Service::ConnectState new_state);
759
Thieu Le67370f62012-02-14 23:01:42 +0000760 // Notifies this object that |service| has been disconnected.
Wade Guthrie7ac610b2013-10-01 17:48:14 -0700761 void NotifyServiceDisconnect(const Service &service);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000762
Wade Guthrie9ec08062013-09-25 15:22:24 -0700763 // Notifies this object of power at disconnect.
764 void NotifySignalAtDisconnect(const Service &service,
765 int16_t signal_strength);
766
Daniel Eratfac09532014-04-17 20:25:59 -0700767 // Notifies this object of the end of a suspend attempt.
768 void NotifySuspendDone();
Thieu Le48e6d6d2011-12-06 00:40:27 +0000769
Samuel Tan66bddc62014-11-13 20:01:04 -0800770 // Notifies this object of the current wake on WiFi features enabled
771 // represented by the WakeOnWiFiFeaturesEnabledState |state|.
Samuel Tanf144d5d2014-11-25 18:18:01 -0800772 void NotifyWakeOnWiFiFeaturesEnabledState(
Samuel Tan66bddc62014-11-13 20:01:04 -0800773 WakeOnWiFiFeaturesEnabledState state);
774
Samuel Tanf144d5d2014-11-25 18:18:01 -0800775 // Notifies this object of the result of NIC wake on WiFi settings
776 // verification.
777 virtual void NotifyVerifyWakeOnWiFiSettingsResult(
778 VerifyWakeOnWiFiSettingsResult result);
779
Samuel Tan1964b5d2014-12-02 10:11:21 -0800780 // Notifies this object of whether or not the WiFi device is connected to a
781 // service after waking from suspend.
782 virtual void NotifyConnectedToServiceAfterWake(
783 WiFiConnectionStatusAfterWake status);
784
Arman Ugurayab22c162012-10-08 19:08:38 -0700785 // Notifies this object that termination actions started executing.
Samuel Tanfbe8d2b2014-09-15 20:23:59 -0700786 void NotifyTerminationActionsStarted();
Arman Ugurayab22c162012-10-08 19:08:38 -0700787
788 // Notifies this object that termination actions have been completed.
789 // |success| is true, if the termination actions completed successfully.
Samuel Tanfbe8d2b2014-09-15 20:23:59 -0700790 void NotifyTerminationActionsCompleted(bool success);
791
792 // Notifies this object that suspend actions started executing.
793 void NotifySuspendActionsStarted();
794
795 // Notifies this object that suspend actions have been completed.
796 // |success| is true, if the suspend actions completed successfully.
797 void NotifySuspendActionsCompleted(bool success);
Arman Ugurayab22c162012-10-08 19:08:38 -0700798
Samuel Tan68b73d22014-10-28 17:00:56 -0700799 // Notifies this object that dark resume actions started executing.
800 void NotifyDarkResumeActionsStarted();
801
802 // Notifies this object that dark resume actions have been completed.
803 // |success| is true, if the dark resume actions completed successfully.
804 void NotifyDarkResumeActionsCompleted(bool success);
805
Samuel Tan0e0ac0d2014-12-29 16:03:42 -0800806 // Notifies this object that a scan has been initiated while in dark resume.
807 void NotifyDarkResumeInitiateScan();
808
809 // Notifies this object that a scan results have been received in dark resume.
810 void NotifyDarkResumeScanResultsReceived();
811
Paul Stewartff845fc2012-08-07 07:28:44 -0700812 // Notifies this object of a failure in LinkMonitor.
813 void NotifyLinkMonitorFailure(
Paul Stewart0443aa52012-08-09 10:43:50 -0700814 Technology::Identifier technology,
815 LinkMonitorFailure failure,
Paul Stewartf1961f82012-09-11 20:45:39 -0700816 int seconds_to_failure,
817 int broadcast_error_count,
818 int unicast_error_count);
Paul Stewartff845fc2012-08-07 07:28:44 -0700819
820 // Notifies this object that LinkMonitor has added a response time sample
821 // for |connection| with a value of |response_time_milliseconds|.
822 void NotifyLinkMonitorResponseTimeSampleAdded(
823 Technology::Identifier technology,
Paul Stewartf1961f82012-09-11 20:45:39 -0700824 int response_time_milliseconds);
Paul Stewartff845fc2012-08-07 07:28:44 -0700825
Wade Guthried4977f22012-08-22 12:37:54 -0700826 // Notifies this object of WiFi disconnect.
Wade Guthriec2728962013-07-10 09:32:16 -0700827 virtual void Notify80211Disconnect(WiFiDisconnectByWhom by_whom,
828 IEEE_80211::WiFiReasonCode reason);
Wade Guthried4977f22012-08-22 12:37:54 -0700829
Thieu Lec8078a62013-01-22 18:01:12 -0800830 // Registers a device with this object so the device can use the timers to
831 // track state transition metrics.
832 void RegisterDevice(int interface_index,
833 Technology::Identifier technology);
834
Thieu Le9abd6742013-01-23 23:35:37 -0800835 // Checks to see if the device has already been registered.
836 bool IsDeviceRegistered(int interface_index,
837 Technology::Identifier technology);
838
Thieu Lec8078a62013-01-22 18:01:12 -0800839 // Deregisters the device from this class. All state transition timers
840 // will be removed.
Peter Qiu9f5159e2014-09-12 16:50:14 -0700841 virtual void DeregisterDevice(int interface_index);
Thieu Lec8078a62013-01-22 18:01:12 -0800842
843 // Notifies this object that a device has been initialized.
844 void NotifyDeviceInitialized(int interface_index);
845
Thieu Lece4483e2013-01-23 15:12:03 -0800846 // Notifies this object that a device has started the enable process.
847 void NotifyDeviceEnableStarted(int interface_index);
848
849 // Notifies this object that a device has completed the enable process.
850 void NotifyDeviceEnableFinished(int interface_index);
851
Thieu Lea2519bf2013-01-23 16:51:54 -0800852 // Notifies this object that a device has started the disable process.
853 void NotifyDeviceDisableStarted(int interface_index);
854
855 // Notifies this object that a device has completed the disable process.
856 void NotifyDeviceDisableFinished(int interface_index);
857
Thieu Le18c11072013-01-28 17:21:37 -0800858 // Notifies this object that a device has started the scanning process.
Wade Guthrie44f290d2013-05-28 10:16:25 -0700859 virtual void NotifyDeviceScanStarted(int interface_index);
Thieu Le18c11072013-01-28 17:21:37 -0800860
861 // Notifies this object that a device has completed the scanning process.
Wade Guthrie5a4e2ef2013-04-30 12:51:39 -0700862 virtual void NotifyDeviceScanFinished(int interface_index);
Thieu Le18c11072013-01-28 17:21:37 -0800863
Wade Guthrie9ec08062013-09-25 15:22:24 -0700864 // Terminates an underway scan (does nothing if a scan wasn't underway).
Wade Guthriea5995cf2013-07-30 09:31:16 -0700865 virtual void ResetScanTimer(int interface_index);
Wade Guthrie44f290d2013-05-28 10:16:25 -0700866
Thieu Lecdb5a212013-01-25 11:17:18 -0800867 // Notifies this object that a device has started the connect process.
Wade Guthrie44f290d2013-05-28 10:16:25 -0700868 virtual void NotifyDeviceConnectStarted(int interface_index,
869 bool is_auto_connecting);
Thieu Lecdb5a212013-01-25 11:17:18 -0800870
871 // Notifies this object that a device has completed the connect process.
Wade Guthrie44f290d2013-05-28 10:16:25 -0700872 virtual void NotifyDeviceConnectFinished(int interface_index);
873
874 // Resets both the connect_timer and the scan_connect_timer the timer (the
875 // latter so that a future connect will not erroneously be associated with
876 // the previous scan).
877 virtual void ResetConnectTimer(int interface_index);
Thieu Lecdb5a212013-01-25 11:17:18 -0800878
Thieu Le26fc01b2013-01-28 12:08:48 -0800879 // Notifies this object that a cellular device has been dropped by the
880 // network.
mukesh agrawal09e08112013-08-16 13:26:44 -0700881 void NotifyCellularDeviceDrop(const std::string &network_technology,
Ben Chan7fab8972014-08-10 17:14:46 -0700882 uint16_t signal_strength);
Thieu Le26fc01b2013-01-28 12:08:48 -0800883
Prathmesh Prabhu08757aa2013-05-15 17:17:33 -0700884 // Notifies this object about 3GPP registration drop events.
885 virtual void Notify3GPPRegistrationDelayedDropPosted();
886 virtual void Notify3GPPRegistrationDelayedDropCanceled();
887
Thieu Leb7aa5f72013-01-31 15:57:48 -0800888 // Notifies this object about a cellular device failure code.
889 void NotifyCellularDeviceFailure(const Error &error);
890
Thieu Le91fccf62013-04-22 15:23:16 -0700891 // Notifies this object that a cellular service has been marked as
892 // out-of-credits.
893 void NotifyCellularOutOfCredits(Metrics::CellularOutOfCreditsReason reason);
894
Peter Qiu574996a2014-04-04 10:55:47 -0700895 // Notifies this object about number of wifi services available for auto
896 // connect when auto-connect is initiated.
897 virtual void NotifyWifiAutoConnectableServices(int num_services);
898
899 // Notifies this object about number of BSSes available for a wifi service
900 // when attempt to connect to that service.
901 virtual void NotifyWifiAvailableBSSes(int num_services);
902
Peter Qiu39d4af02014-04-14 12:24:01 -0700903 // Notifies this object about number of services associated to the
904 // currently connected network.
905 virtual void NotifyServicesOnSameNetwork(int num_services);
906
Peter Qiu8e430582014-04-30 14:12:37 -0700907 // Notifies this object about WIFI TX bitrate in Mbps.
908 virtual void NotifyWifiTxBitrate(int bitrate);
909
Peter Qiudc4e0992014-05-01 10:02:52 -0700910 // Notifies this object about the result of user-initiated connection
911 // attempt.
912 virtual void NotifyUserInitiatedConnectionResult(const std::string &name,
913 int result);
914
Peter Qiud87179e2014-07-10 18:29:22 -0700915 // Notifies this object about the reason of failed user-initiated connection
916 // attempt.
917 virtual void NotifyUserInitiatedConnectionFailureReason(
918 const std::string &name, const Service::ConnectFailure failure);
919
Thieu Le5133b712013-02-19 14:47:21 -0800920 // Notifies this object about a corrupted profile.
921 virtual void NotifyCorruptedProfile();
922
Peter Qiue783f1c2014-05-02 11:42:33 -0700923 // Notifies this object about user-initiated event.
924 virtual void NotifyUserInitiatedEvent(int event);
925
Peter Qiub9256f32014-05-09 15:27:29 -0700926 // Notifies this object about the result of the fallback DNS test.
Peter Qiuf18e7712014-05-20 09:59:46 -0700927 virtual void NotifyFallbackDNSTestResult(Technology::Identifier technology_id,
928 int result);
Peter Qiub9256f32014-05-09 15:27:29 -0700929
Peter Qiudc335f82014-05-15 10:33:17 -0700930 // Notifies this object about a network problem detected on the currently
931 // connected network.
932 virtual void NotifyNetworkProblemDetected(
933 Technology::Identifier technology_id, int reason);
934
Peter Qiu700de642014-07-14 16:31:30 -0700935 // Notifies this object about current connection status (online vs offline).
936 virtual void NotifyDeviceConnectionStatus(Metrics::ConnectionStatus status);
937
Paul Stewart3bdf1ab2014-07-17 19:22:26 -0700938 // Notifies this object about the DHCP client status.
939 virtual void NotifyDhcpClientStatus(Metrics::DhcpClientStatus status);
940
Peter Qiu300769e2014-08-27 11:48:45 -0700941 // Notifies this object about the IP type of the current network connection.
942 virtual void NotifyNetworkConnectionIPType(
943 Technology::Identifier technology_id, NetworkConnectionIPType type);
944
945 // Notifies this object about the IPv6 connectivity status.
946 virtual void NotifyIPv6ConnectivityStatus(
947 Technology::Identifier technology_id, bool status);
948
Peter Qiu94d18af2014-09-11 15:54:15 -0700949 // Notifies this object about the presence of given technology type device.
950 virtual void NotifyDevicePresenceStatus(Technology::Identifier technology_id,
951 bool status);
952
Peter Qiua0572032014-09-26 10:07:37 -0700953 // Notifies this object about the signal strength when link is unreliable.
954 virtual void NotifyUnreliableLinkSignalStrength(
955 Technology::Identifier technology_id, int signal_strength);
956
Thieu Le48e6d6d2011-12-06 00:40:27 +0000957 // Sends linear histogram data to UMA.
Thieu Le85e050b2012-03-13 15:04:38 -0700958 virtual bool SendEnumToUMA(const std::string &name, int sample, int max);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000959
Thieu Lea20cbc22012-01-09 22:01:43 +0000960 // Send histogram data to UMA.
Thieu Le85e050b2012-03-13 15:04:38 -0700961 virtual bool SendToUMA(const std::string &name, int sample, int min,
962 int max, int num_buckets);
Thieu Lea20cbc22012-01-09 22:01:43 +0000963
Samuel Tanc36b4102015-01-26 19:34:35 -0800964 // Notifies this object that wake on WiFi has been disabled because of
965 // excessive dark resume wakes.
966 virtual void NotifyWakeOnWiFiThrottled();
967
968 // Notifies this object that shill has resumed from a period of suspension
969 // where wake on WiFi functionality was enabled on the NIC.
970 virtual void NotifySuspendWithWakeOnWiFiEnabledDone();
971
Thieu Le48e6d6d2011-12-06 00:40:27 +0000972 private:
Thieu Le48e6d6d2011-12-06 00:40:27 +0000973 friend class MetricsTest;
Thieu Le6c1e3bb2013-02-06 15:20:35 -0800974 FRIEND_TEST(MetricsTest, CellularDropsPerHour);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000975 FRIEND_TEST(MetricsTest, FrequencyToChannel);
Wade Guthrie44f290d2013-05-28 10:16:25 -0700976 FRIEND_TEST(MetricsTest, ResetConnectTimer);
Thieu Leb84ba342012-03-02 15:15:19 -0800977 FRIEND_TEST(MetricsTest, ServiceFailure);
Thieu Lea20cbc22012-01-09 22:01:43 +0000978 FRIEND_TEST(MetricsTest, TimeOnlineTimeToDrop);
Thieu Leb84ba342012-03-02 15:15:19 -0800979 FRIEND_TEST(MetricsTest, TimeToConfig);
980 FRIEND_TEST(MetricsTest, TimeToOnline);
981 FRIEND_TEST(MetricsTest, TimeToPortal);
Thieu Le18c11072013-01-28 17:21:37 -0800982 FRIEND_TEST(MetricsTest, TimeToScanIgnore);
Thieu Leb84ba342012-03-02 15:15:19 -0800983 FRIEND_TEST(MetricsTest, WiFiServiceChannel);
984 FRIEND_TEST(MetricsTest, WiFiServicePostReady);
Samuel Tanc36b4102015-01-26 19:34:35 -0800985 FRIEND_TEST(MetricsTest, NotifySuspendWithWakeOnWiFiEnabledDone);
986 FRIEND_TEST(MetricsTest, NotifyWakeOnWiFiThrottled);
Gaurav Shah6d2c72d2012-10-16 16:30:44 -0700987 FRIEND_TEST(WiFiMainTest, GetGeolocationObjects);
Thieu Le48e6d6d2011-12-06 00:40:27 +0000988
989 typedef ScopedVector<chromeos_metrics::TimerReporter> TimerReporters;
990 typedef std::list<chromeos_metrics::TimerReporter *> TimerReportersList;
991 typedef std::map<Service::ConnectState, TimerReportersList>
992 TimerReportersByState;
993 struct ServiceMetrics {
Thieu Le48e6d6d2011-12-06 00:40:27 +0000994 // All TimerReporter objects are stored in |timers| which owns the objects.
995 // |start_on_state| and |stop_on_state| contain pointers to the
996 // TimerReporter objects and control when to start and stop the timers.
997 TimerReporters timers;
998 TimerReportersByState start_on_state;
999 TimerReportersByState stop_on_state;
1000 };
Ben Chane2ee5e02014-09-19 19:29:42 -07001001 typedef std::map<const Service *, std::shared_ptr<ServiceMetrics>>
Thieu Le48e6d6d2011-12-06 00:40:27 +00001002 ServiceMetricsLookupMap;
1003
Thieu Lec8078a62013-01-22 18:01:12 -08001004 struct DeviceMetrics {
mukesh agrawal09e08112013-08-16 13:26:44 -07001005 DeviceMetrics() : auto_connect_tries(0) {}
Thieu Le9abd6742013-01-23 23:35:37 -08001006 Technology::Identifier technology;
Ben Chancd477322014-10-17 14:19:30 -07001007 std::unique_ptr<chromeos_metrics::TimerReporter> initialization_timer;
1008 std::unique_ptr<chromeos_metrics::TimerReporter> enable_timer;
1009 std::unique_ptr<chromeos_metrics::TimerReporter> disable_timer;
1010 std::unique_ptr<chromeos_metrics::TimerReporter> scan_timer;
1011 std::unique_ptr<chromeos_metrics::TimerReporter> connect_timer;
1012 std::unique_ptr<chromeos_metrics::TimerReporter> scan_connect_timer;
1013 std::unique_ptr<chromeos_metrics::TimerReporter> auto_connect_timer;
Thieu Le6c1e3bb2013-02-06 15:20:35 -08001014 int auto_connect_tries;
Thieu Lec8078a62013-01-22 18:01:12 -08001015 };
Ben Chane2ee5e02014-09-19 19:29:42 -07001016 typedef std::map<const int, std::shared_ptr<DeviceMetrics>>
Thieu Lec8078a62013-01-22 18:01:12 -08001017 DeviceMetricsLookupMap;
1018
Ben Chan7fab8972014-08-10 17:14:46 -07001019 static const uint16_t kWiFiBandwidth5MHz;
1020 static const uint16_t kWiFiBandwidth20MHz;
1021 static const uint16_t kWiFiFrequency2412;
1022 static const uint16_t kWiFiFrequency2472;
1023 static const uint16_t kWiFiFrequency2484;
1024 static const uint16_t kWiFiFrequency5170;
1025 static const uint16_t kWiFiFrequency5180;
1026 static const uint16_t kWiFiFrequency5230;
1027 static const uint16_t kWiFiFrequency5240;
1028 static const uint16_t kWiFiFrequency5320;
1029 static const uint16_t kWiFiFrequency5500;
1030 static const uint16_t kWiFiFrequency5700;
1031 static const uint16_t kWiFiFrequency5745;
1032 static const uint16_t kWiFiFrequency5825;
Thieu Le48e6d6d2011-12-06 00:40:27 +00001033
Wade Guthrie7ac610b2013-10-01 17:48:14 -07001034 void InitializeCommonServiceMetrics(const Service &service);
Thieu Le48e6d6d2011-12-06 00:40:27 +00001035 void UpdateServiceStateTransitionMetrics(ServiceMetrics *service_metrics,
1036 Service::ConnectState new_state);
Wade Guthrie7ac610b2013-10-01 17:48:14 -07001037 void SendServiceFailure(const Service &service);
Thieu Le48e6d6d2011-12-06 00:40:27 +00001038
Wade Guthrie60a37062013-04-02 11:39:09 -07001039 DeviceMetrics *GetDeviceMetrics(int interface_index) const;
Thieu Le7cf36b02013-01-30 17:15:56 -08001040 void AutoConnectMetricsReset(DeviceMetrics *device_metrics);
Thieu Lece4483e2013-01-23 15:12:03 -08001041
Peter Qiu9f5159e2014-09-12 16:50:14 -07001042 // Notifies this object about the removal/resetting of a device with given
1043 // technology type.
1044 void NotifyDeviceRemovedEvent(Technology::Identifier technology_id);
1045
Thieu Le48e6d6d2011-12-06 00:40:27 +00001046 // For unit test purposes.
1047 void set_library(MetricsLibraryInterface *library);
Thieu Lea20cbc22012-01-09 22:01:43 +00001048 void set_time_online_timer(chromeos_metrics::Timer *timer) {
1049 time_online_timer_.reset(timer); // Passes ownership
1050 }
1051 void set_time_to_drop_timer(chromeos_metrics::Timer *timer) {
1052 time_to_drop_timer_.reset(timer); // Passes ownership
1053 }
Thieu Leb84ba342012-03-02 15:15:19 -08001054 void set_time_resume_to_ready_timer(chromeos_metrics::Timer *timer) {
1055 time_resume_to_ready_timer_.reset(timer); // Passes ownership
1056 }
Arman Ugurayab22c162012-10-08 19:08:38 -07001057 void set_time_termination_actions_timer(
1058 chromeos_metrics::Timer *timer) {
1059 time_termination_actions_timer.reset(timer); // Passes ownership
1060 }
Samuel Tanfbe8d2b2014-09-15 20:23:59 -07001061 void set_time_suspend_actions_timer(
1062 chromeos_metrics::Timer *timer) {
1063 time_suspend_actions_timer.reset(timer); // Passes ownership
1064 }
Thieu Le18c11072013-01-28 17:21:37 -08001065 void set_time_to_scan_timer(int interface_index,
1066 chromeos_metrics::TimerReporter *timer) {
1067 DeviceMetrics *device_metrics = GetDeviceMetrics(interface_index);
1068 device_metrics->scan_timer.reset(timer); // Passes ownership
1069 }
Wade Guthrie44f290d2013-05-28 10:16:25 -07001070 void set_time_to_connect_timer(int interface_index,
1071 chromeos_metrics::TimerReporter *timer) {
1072 DeviceMetrics *device_metrics = GetDeviceMetrics(interface_index);
1073 device_metrics->connect_timer.reset(timer); // Passes ownership
1074 }
1075 void set_time_to_scan_connect_timer(int interface_index,
1076 chromeos_metrics::TimerReporter *timer) {
1077 DeviceMetrics *device_metrics = GetDeviceMetrics(interface_index);
1078 device_metrics->scan_connect_timer.reset(timer); // Passes ownership
1079 }
Thieu Le48e6d6d2011-12-06 00:40:27 +00001080
1081 // |library_| points to |metrics_library_| when shill runs normally.
1082 // However, in order to allow for unit testing, we point |library_| to a
1083 // MetricsLibraryMock object instead.
Thieu Le6c1e3bb2013-02-06 15:20:35 -08001084 EventDispatcher *dispatcher_;
Thieu Le48e6d6d2011-12-06 00:40:27 +00001085 MetricsLibrary metrics_library_;
1086 MetricsLibraryInterface *library_;
1087 ServiceMetricsLookupMap services_metrics_;
Thieu Lea20cbc22012-01-09 22:01:43 +00001088 Technology::Identifier last_default_technology_;
1089 bool was_online_;
Ben Chancd477322014-10-17 14:19:30 -07001090 std::unique_ptr<chromeos_metrics::Timer> time_online_timer_;
1091 std::unique_ptr<chromeos_metrics::Timer> time_to_drop_timer_;
1092 std::unique_ptr<chromeos_metrics::Timer> time_resume_to_ready_timer_;
1093 std::unique_ptr<chromeos_metrics::Timer> time_termination_actions_timer;
1094 std::unique_ptr<chromeos_metrics::Timer> time_suspend_actions_timer;
Samuel Tan68b73d22014-10-28 17:00:56 -07001095 std::unique_ptr<chromeos_metrics::Timer> time_dark_resume_actions_timer;
Darin Petkov58f0b6d2012-06-12 12:52:30 +02001096 bool collect_bootstats_;
Thieu Lec8078a62013-01-22 18:01:12 -08001097 DeviceMetricsLookupMap devices_metrics_;
Samuel Tan0e0ac0d2014-12-29 16:03:42 -08001098 int num_scan_results_expected_in_dark_resume_;
Samuel Tanc36b4102015-01-26 19:34:35 -08001099 bool wake_on_wifi_throttled_;
Thieu Le48e6d6d2011-12-06 00:40:27 +00001100
1101 DISALLOW_COPY_AND_ASSIGN(Metrics);
1102};
1103
1104} // namespace shill
1105
Wade Guthrie60a37062013-04-02 11:39:09 -07001106#endif // SHILL_METRICS_H_