blob: 368510208dd1a96a133cf12d75412e191862eaf9 [file] [log] [blame]
Alex Deymoaea4c1c2015-08-19 20:24:43 -07001//
2// Copyright (C) 2013 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//
Jay Srinivasan1c0fe792013-03-28 16:45:25 -070016
Alex Deymo39910dc2015-11-09 17:04:30 -080017#ifndef UPDATE_ENGINE_COMMON_CONSTANTS_H_
18#define UPDATE_ENGINE_COMMON_CONSTANTS_H_
Jay Srinivasan1c0fe792013-03-28 16:45:25 -070019
20namespace chromeos_update_engine {
21
Jae Hoon Kim38de3b12020-04-29 19:41:23 -070022// The root path of all exclusion prefs.
23extern const char kExclusionPrefsSubDir[];
24
Andrew065d78d2020-04-07 15:43:07 -070025// The root path of all DLC metadata.
26extern const char kDlcPrefsSubDir[];
Andrewe045aef2020-01-08 16:29:22 -080027
Chris Sosaaa18e162013-06-20 13:20:30 -070028// Directory for AU prefs that are preserved across powerwash.
Alex Deymodd132f32015-09-14 19:12:07 -070029extern const char kPowerwashSafePrefsSubDirectory[];
Chris Sosaaa18e162013-06-20 13:20:30 -070030
31// The location where we store the AU preferences (state etc).
Alex Deymodd132f32015-09-14 19:12:07 -070032extern const char kPrefsSubDirectory[];
Chris Sosaaa18e162013-06-20 13:20:30 -070033
Alex Deymo390efed2016-02-18 11:00:40 -080034// Path to the post install command, relative to the partition.
35extern const char kPostinstallDefaultScript[];
36
Chris Sosabe45bef2013-04-09 18:25:12 -070037// Path to the stateful partition on the root filesystem.
38extern const char kStatefulPartition[];
39
Jay Srinivasand29695d2013-04-08 15:08:05 -070040// Constants related to preferences.
David Zeuthen4e1d1492014-04-25 13:12:27 -070041extern const char kPrefsAttemptInProgress[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070042extern const char kPrefsBackoffExpiryTime[];
Alex Deymodd132f32015-09-14 19:12:07 -070043extern const char kPrefsBootId[];
Jay Srinivasan19409b72013-04-12 19:23:36 -070044extern const char kPrefsCurrentBytesDownloaded[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070045extern const char kPrefsCurrentResponseSignature[];
46extern const char kPrefsCurrentUrlFailureCount[];
47extern const char kPrefsCurrentUrlIndex[];
David Zeuthen985b1122013-10-09 12:13:15 -070048extern const char kPrefsDailyMetricsLastReportedAt[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070049extern const char kPrefsDeltaUpdateFailures[];
Tao Bao3406c772019-01-02 15:34:35 -080050extern const char kPrefsDynamicPartitionMetadataUpdated[];
Alex Deymo820cc702013-06-28 15:43:46 -070051extern const char kPrefsFullPayloadAttemptNumber[];
David Zeuthen639aa362014-02-03 16:23:44 -080052extern const char kPrefsInstallDateDays[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070053extern const char kPrefsLastActivePingDay[];
54extern const char kPrefsLastRollCallPingDay[];
55extern const char kPrefsManifestMetadataSize[];
Alex Deymof25eb492016-02-26 00:20:08 -080056extern const char kPrefsManifestSignatureSize[];
David Zeuthen33bae492014-02-25 16:16:18 -080057extern const char kPrefsMetricsAttemptLastReportingTime[];
58extern const char kPrefsMetricsCheckLastReportingTime[];
Amin Hassaniffb6d802018-03-30 11:43:57 -070059extern const char kPrefsNoIgnoreBackoff[];
Chris Sosabe45bef2013-04-09 18:25:12 -070060extern const char kPrefsNumReboots[];
David Zeuthena573d6f2013-06-14 16:13:36 -070061extern const char kPrefsNumResponsesSeen[];
Alex Deymo8e18f932015-03-27 16:16:59 -070062extern const char kPrefsOmahaCohort[];
63extern const char kPrefsOmahaCohortHint[];
64extern const char kPrefsOmahaCohortName[];
Jae Hoon Kim051627a2019-09-03 12:56:32 -070065extern const char kPrefsOmahaEolDate[];
David Zeuthen27a48bc2013-08-06 12:06:29 -070066extern const char kPrefsP2PEnabled[];
David Zeuthen639aa362014-02-03 16:23:44 -080067extern const char kPrefsP2PFirstAttemptTimestamp[];
68extern const char kPrefsP2PNumAttempts[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070069extern const char kPrefsPayloadAttemptNumber[];
Amin Hassani03277de2020-07-28 12:32:49 -070070extern const char kPrefsTestUpdateCheckIntervalTimeout[];
Andrewe045aef2020-01-08 16:29:22 -080071extern const char kPrefsPingActive[];
72extern const char kPrefsPingLastActive[];
73extern const char kPrefsPingLastRollcall[];
Sen Jiang02c49422017-10-31 15:14:11 -070074extern const char kPrefsPostInstallSucceeded[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070075extern const char kPrefsPreviousVersion[];
76extern const char kPrefsResumedUpdateFailures[];
Marton Hunyadye58bddb2018-04-10 20:27:26 +020077extern const char kPrefsRollbackHappened[];
Chris Sosaaa18e162013-06-20 13:20:30 -070078extern const char kPrefsRollbackVersion[];
Alex Deymo85616652015-10-15 18:48:31 -070079extern const char kPrefsChannelOnSlotPrefix[];
David Zeuthene4c58bf2013-06-18 17:26:50 -070080extern const char kPrefsSystemUpdatedMarker[];
Alex Deymo42432912013-07-12 20:21:15 -070081extern const char kPrefsTargetVersionAttempt[];
82extern const char kPrefsTargetVersionInstalledFrom[];
83extern const char kPrefsTargetVersionUniqueId[];
Jay Srinivasan19409b72013-04-12 19:23:36 -070084extern const char kPrefsTotalBytesDownloaded[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070085extern const char kPrefsUpdateCheckCount[];
86extern const char kPrefsUpdateCheckResponseHash[];
Alex Deymo906191f2015-10-12 12:22:44 -070087extern const char kPrefsUpdateCompletedBootTime[];
88extern const char kPrefsUpdateCompletedOnBootId[];
David Zeuthencc6f9962013-04-18 11:57:24 -070089extern const char kPrefsUpdateDurationUptime[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070090extern const char kPrefsUpdateFirstSeenAt[];
Alex Deymof4867c42013-06-28 14:41:39 -070091extern const char kPrefsUpdateOverCellularPermission[];
Weidong Guo421ff332017-04-17 10:08:38 -070092extern const char kPrefsUpdateOverCellularTargetVersion[];
93extern const char kPrefsUpdateOverCellularTargetSize[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070094extern const char kPrefsUpdateServerCertificate[];
David Zeuthen41996ad2013-09-24 15:43:24 -070095extern const char kPrefsUpdateStateNextDataLength[];
David Zeuthen639aa362014-02-03 16:23:44 -080096extern const char kPrefsUpdateStateNextDataOffset[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070097extern const char kPrefsUpdateStateNextOperation[];
Sen Jiang0affc2c2017-02-10 15:55:05 -080098extern const char kPrefsUpdateStatePayloadIndex[];
Jay Srinivasand29695d2013-04-08 15:08:05 -070099extern const char kPrefsUpdateStateSHA256Context[];
100extern const char kPrefsUpdateStateSignatureBlob[];
101extern const char kPrefsUpdateStateSignedSHA256Context[];
Tianjie Xu2a0ea632018-08-06 12:59:23 -0700102extern const char kPrefsUpdateBootTimestampStart[];
David Zeuthen9a017f22013-04-11 16:10:26 -0700103extern const char kPrefsUpdateTimestampStart[];
David Zeuthencc6f9962013-04-18 11:57:24 -0700104extern const char kPrefsUrlSwitchCount[];
Sen Jiang3eeaf7d2018-10-11 13:55:32 -0700105extern const char kPrefsVerityWritten[];
Adolfo Victoriad3a1e352018-07-16 11:40:47 -0700106extern const char kPrefsWallClockScatteringWaitPeriod[];
107extern const char kPrefsWallClockStagingWaitPeriod[];
Kelvin Zhangcc011d32020-07-10 18:20:08 -0400108extern const char kPrefsManifestBytes[];
Jay Srinivasand29695d2013-04-08 15:08:05 -0700109
Alex Deymo98e691c2016-02-04 21:05:45 -0800110// Keys used when storing and loading payload properties.
111extern const char kPayloadPropertyFileSize[];
112extern const char kPayloadPropertyFileHash[];
113extern const char kPayloadPropertyMetadataSize[];
114extern const char kPayloadPropertyMetadataHash[];
Alex Deymofdd6dec2016-03-03 22:35:43 -0800115extern const char kPayloadPropertyAuthorization[];
116extern const char kPayloadPropertyUserAgent[];
Alex Deymofb905d92016-06-03 19:26:58 -0700117extern const char kPayloadPropertyPowerwash[];
Alex Deymo87792ea2016-07-25 15:40:36 -0700118extern const char kPayloadPropertyNetworkId[];
Sen Jiang02c49422017-10-31 15:14:11 -0700119extern const char kPayloadPropertySwitchSlotOnReboot[];
120extern const char kPayloadPropertyRunPostInstall[];
Alex Deymo98e691c2016-02-04 21:05:45 -0800121
Amin Hassani7fca2862019-03-28 16:09:22 -0700122extern const char kOmahaUpdaterVersion[];
123
Jae Hoon Kim0ae8fe12019-06-26 14:32:50 -0700124// X-Goog-Update headers.
125extern const char kXGoogleUpdateInteractivity[];
126extern const char kXGoogleUpdateAppId[];
127extern const char kXGoogleUpdateUpdater[];
128extern const char kXGoogleUpdateSessionId[];
129
Jay Srinivasan19409b72013-04-12 19:23:36 -0700130// A download source is any combination of protocol and server (that's of
131// interest to us when looking at UMA metrics) using which we may download
132// the payload.
133typedef enum {
Alex Vakulenkod2779df2014-06-16 13:19:00 -0700134 kDownloadSourceHttpsServer, // UMA Binary representation: 0001
135 kDownloadSourceHttpServer, // UMA Binary representation: 0010
136 kDownloadSourceHttpPeer, // UMA Binary representation: 0100
Jay Srinivasan19409b72013-04-12 19:23:36 -0700137
138 // Note: Add new sources only above this line.
139 kNumDownloadSources
140} DownloadSource;
141
Alex Deymo1c656c42013-06-28 11:02:14 -0700142// A payload can be a Full or Delta payload. In some cases, a Full payload is
143// used even when a Delta payload was available for the update, called here
144// ForcedFull. The PayloadType enum is only used to send UMA metrics about the
145// successfully applied payload.
146typedef enum {
147 kPayloadTypeFull,
148 kPayloadTypeDelta,
149 kPayloadTypeForcedFull,
150
151 // Note: Add new payload types only above this line.
152 kNumPayloadTypes
153} PayloadType;
154
David Zeuthen8f191b22013-08-06 12:27:50 -0700155// Maximum number of times we'll allow using p2p for the same update payload.
David Zeuthendcba8092013-08-06 12:16:35 -0700156const int kMaxP2PAttempts = 10;
157
David Zeuthen8f191b22013-08-06 12:27:50 -0700158// Maximum wallclock time we allow attempting to update using p2p for
David Zeuthen472b2052014-02-25 16:27:04 -0800159// the same update payload - five days.
160const int kMaxP2PAttemptTimeSeconds = 5 * 24 * 60 * 60;
David Zeuthen8f191b22013-08-06 12:27:50 -0700161
162// The maximum amount of time to spend waiting for p2p-client(1) to
163// return while waiting in line to use the LAN - six hours.
164const int kMaxP2PNetworkWaitTimeSeconds = 6 * 60 * 60;
David Zeuthendcba8092013-08-06 12:16:35 -0700165
David Zeuthen526cb582013-08-06 12:26:18 -0700166// The maximum number of payload files to keep in /var/cache/p2p.
167const int kMaxP2PFilesToKeep = 3;
168
David Zeuthen41f2cf52014-11-05 12:29:45 -0500169// The maximum number of days to keep a p2p file;
170const int kMaxP2PFileAgeDays = 5;
171
Jay Srinivasan19409b72013-04-12 19:23:36 -0700172// The default number of UMA buckets for metrics.
173const int kNumDefaultUmaBuckets = 50;
174
175// General constants
176const int kNumBytesInOneMiB = 1024 * 1024;
177
David Zeuthen34135a92013-08-06 11:16:16 -0700178// Number of redirects allowed when downloading.
179const int kDownloadMaxRedirects = 10;
180
David Zeuthena641be52013-09-12 10:59:57 -0700181// The minimum average speed that downloads must sustain...
David Zeuthen34135a92013-08-06 11:16:16 -0700182//
183// This is set low because some devices may have very poor
Alex Vakulenko072359c2014-07-18 11:41:07 -0700184// connectivity and we want to make as much forward progress as
David Zeuthena641be52013-09-12 10:59:57 -0700185// possible. For p2p this is high (25 kB/second) since we can assume
David Zeuthen34135a92013-08-06 11:16:16 -0700186// high bandwidth (same LAN) and we want to fail fast.
187const int kDownloadLowSpeedLimitBps = 1;
David Zeuthena641be52013-09-12 10:59:57 -0700188const int kDownloadP2PLowSpeedLimitBps = 25 * 1000;
David Zeuthen34135a92013-08-06 11:16:16 -0700189
190// ... measured over this period.
191//
192// For non-official builds (e.g. typically built on a developer's
193// workstation and served via devserver) bump this since it takes time
Aaron Wood22290592018-03-09 09:19:15 -0800194// for the workstation to generate the payload. For normal operation
195// and p2p, make this relatively low since we want to fail fast in
196// those cases.
197const int kDownloadLowSpeedTimeSeconds = 30;
David Zeuthen34135a92013-08-06 11:16:16 -0700198const int kDownloadDevModeLowSpeedTimeSeconds = 180;
David Zeuthena641be52013-09-12 10:59:57 -0700199const int kDownloadP2PLowSpeedTimeSeconds = 60;
David Zeuthen34135a92013-08-06 11:16:16 -0700200
201// The maximum amount of HTTP server reconnect attempts.
202//
203// This is set high in order to maximize the attempt's chance of
204// succeeding. When using p2p, this is low in order to fail fast.
205const int kDownloadMaxRetryCount = 20;
206const int kDownloadMaxRetryCountOobeNotComplete = 3;
Sen Jiangee174a12017-12-21 17:38:08 -0800207const int kDownloadMaxRetryCountInteractive = 3;
David Zeuthena641be52013-09-12 10:59:57 -0700208const int kDownloadP2PMaxRetryCount = 5;
David Zeuthen34135a92013-08-06 11:16:16 -0700209
210// The connect timeout, in seconds.
211//
212// This is set high because some devices may have very poor
213// connectivity and we may be using HTTPS which involves complicated
214// multi-roundtrip setup. For p2p, this is set low because we can
215// the server is on the same LAN and we want to fail fast.
216const int kDownloadConnectTimeoutSeconds = 30;
217const int kDownloadP2PConnectTimeoutSeconds = 5;
218
xunchangcda3c032019-03-26 15:41:14 -0700219// Size in bytes of SHA256 hash.
220const int kSHA256Size = 32;
221
Jay Srinivasan1c0fe792013-03-28 16:45:25 -0700222} // namespace chromeos_update_engine
223
Alex Deymo39910dc2015-11-09 17:04:30 -0800224#endif // UPDATE_ENGINE_COMMON_CONSTANTS_H_