|  | // | 
|  | // Copyright (C) 2017 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. | 
|  | // | 
|  |  | 
|  | #ifndef UPDATE_ENGINE_COMMON_METRICS_CONSTANTS_H_ | 
|  | #define UPDATE_ENGINE_COMMON_METRICS_CONSTANTS_H_ | 
|  |  | 
|  | namespace chromeos_update_engine { | 
|  |  | 
|  | namespace metrics { | 
|  | // The possible outcomes when checking for updates. | 
|  | // | 
|  | // This is used in the UpdateEngine.Check.Result histogram. | 
|  | enum class CheckResult { | 
|  | kUpdateAvailable,    // Response indicates an update is available. | 
|  | kNoUpdateAvailable,  // Response indicates no updates are available. | 
|  | kDownloadError,      // Error downloading response from Omaha. | 
|  | kParsingError,       // Error parsing response. | 
|  | kRebootPending,      // No update check was performed a reboot is pending. | 
|  |  | 
|  | kNumConstants, | 
|  | kUnset = -1 | 
|  | }; | 
|  |  | 
|  | // Possible ways a device can react to a new update being available. | 
|  | // | 
|  | // This is used in the UpdateEngine.Check.Reaction histogram. | 
|  | enum class CheckReaction { | 
|  | kUpdating,    // Device proceeds to download and apply update. | 
|  | kIgnored,     // Device-policy dictates ignoring the update. | 
|  | kDeferring,   // Device-policy dictates waiting. | 
|  | kBackingOff,  // Previous errors dictates waiting. | 
|  |  | 
|  | kNumConstants, | 
|  | kUnset = -1 | 
|  | }; | 
|  |  | 
|  | // The possible ways that downloading from a HTTP or HTTPS server can fail. | 
|  | // | 
|  | // This is used in the UpdateEngine.Check.DownloadErrorCode and | 
|  | // UpdateEngine.Attempt.DownloadErrorCode histograms. | 
|  | enum class DownloadErrorCode { | 
|  | // Errors that can happen in the field. See http://crbug.com/355745 | 
|  | // for how we plan to add more detail in the future. | 
|  | kDownloadError = 0,  // Error downloading data from server. | 
|  |  | 
|  | // IMPORTANT: When adding a new error code, add at the bottom of the | 
|  | // above block and before the kInputMalformed field. This | 
|  | // is to ensure that error codes are not reordered. | 
|  |  | 
|  | // This error is reported when libcurl returns CURLE_COULDNT_RESOLVE_HOST and | 
|  | // calling res_init() can recover. | 
|  | kUnresolvedHostRecovered = 97, | 
|  | // This error is reported when libcurl returns CURLE_COULDNT_RESOLVE_HOST. | 
|  | kUnresolvedHostError = 98, | 
|  | // This error is reported when libcurl has an internal error that | 
|  | // update_engine can't recover from. | 
|  | kInternalLibCurlError = 99, | 
|  |  | 
|  | // This error code is used to convey that malformed input was given | 
|  | // to the utils::GetDownloadErrorCode() function. This should never | 
|  | // happen but if it does it's because of an internal update_engine | 
|  | // error and we're interested in knowing this. | 
|  | kInputMalformed = 100, | 
|  |  | 
|  | // Bucket for capturing HTTP status codes not in the 200-599 | 
|  | // range. This should never happen in practice but if it does we | 
|  | // want to know. | 
|  | kHttpStatusOther = 101, | 
|  |  | 
|  | // Above 200 and below 600, the value is the HTTP status code. | 
|  | kHttpStatus200 = 200, | 
|  |  | 
|  | kNumConstants = 600, | 
|  |  | 
|  | kUnset = -1 | 
|  | }; | 
|  |  | 
|  | // Possible ways an update attempt can end. | 
|  | // | 
|  | // This is used in the UpdateEngine.Attempt.Result histogram. | 
|  | enum class AttemptResult { | 
|  | kUpdateSucceeded,             // The update succeeded. | 
|  | kInternalError,               // An internal error occurred. | 
|  | kPayloadDownloadError,        // Failure while downloading payload. | 
|  | kMetadataMalformed,           // Metadata was malformed. | 
|  | kOperationMalformed,          // An operation was malformed. | 
|  | kOperationExecutionError,     // An operation failed to execute. | 
|  | kMetadataVerificationFailed,  // Metadata verification failed. | 
|  | kPayloadVerificationFailed,   // Payload verification failed. | 
|  | kVerificationFailed,          // Root or Kernel partition verification failed. | 
|  | kPostInstallFailed,           // The postinstall step failed. | 
|  | kAbnormalTermination,         // The attempt ended abnormally. | 
|  | kUpdateCanceled,              // Update canceled by the user. | 
|  | kUpdateSucceededNotActive,    // Update succeeded but the new slot is not | 
|  | // active. | 
|  | kUpdateSkipped,               // Current update skipped. | 
|  | kNumConstants, | 
|  |  | 
|  | kUnset = -1 | 
|  | }; | 
|  |  | 
|  | // Possible ways the device is connected to the Internet. | 
|  | // | 
|  | // This is used in the UpdateEngine.Attempt.ConnectionType histogram. | 
|  | enum class ConnectionType { | 
|  | kUnknown = 0,           // Unknown. | 
|  | kEthernet = 1,          // Ethernet. | 
|  | kWifi = 2,              // Wireless. | 
|  | kCellular = 5,          // Cellular. | 
|  | kTetheredEthernet = 6,  // Tethered (Ethernet). | 
|  | kTetheredWifi = 7,      // Tethered (Wifi). | 
|  | kDisconnected = 8,      // Disconnected. | 
|  | // deprecated: kWimax = 3, | 
|  | // deprecated: kBluetooth = 4, | 
|  |  | 
|  | kNumConstants, | 
|  | kUnset = -1 | 
|  | }; | 
|  |  | 
|  | // Possible ways a rollback can end. | 
|  | // | 
|  | // This is used in the UpdateEngine.Rollback histogram. | 
|  | enum class RollbackResult { | 
|  | kFailed, | 
|  | kSuccess, | 
|  |  | 
|  | kNumConstants | 
|  | }; | 
|  |  | 
|  | }  // namespace metrics | 
|  |  | 
|  | }  // namespace chromeos_update_engine | 
|  |  | 
|  | #endif  // UPDATE_ENGINE_COMMON_METRICS_CONSTANTS_H_ |