Implement multiple alternative services per origin.
[chromium-blink-merge.git] / chrome / common / pref_names.cc
blob472b75dbcc09b766fad017192bb5a4da488fee25
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #include "chrome/common/pref_names.h"
7 #include "base/basictypes.h"
8 #include "chrome/common/pref_font_webkit_names.h"
10 namespace prefs {
12 // *************** PROFILE PREFS ***************
13 // These are attached to the user profile
16 // A bool pref that keeps whether the child status for this profile was already
17 // successfully checked via ChildAccountService.
18 const char kChildAccountStatusKnown[] = "child_account_status_known";
20 // A string property indicating whether default apps should be installed
21 // in this profile. Use the value "install" to enable defaults apps, or
22 // "noinstall" to disable them. This property is usually set in the
23 // master_preferences and copied into the profile preferences on first run.
24 // Defaults apps are installed only when creating a new profile.
25 const char kDefaultApps[] = "default_apps";
27 // Disables screenshot accelerators and extension APIs.
28 // This setting resides both in profile prefs and local state. Accelerator
29 // handling code reads local state, while extension APIs use profile pref.
30 const char kDisableScreenshots[] = "disable_screenshots";
32 // If set to true profiles are created in ephemeral mode and do not store their
33 // data in the profile folder on disk but only in memory.
34 const char kForceEphemeralProfiles[] = "profile.ephemeral_mode";
36 // A boolean specifying whether the New Tab page is the home page or not.
37 const char kHomePageIsNewTabPage[] = "homepage_is_newtabpage";
39 // This is the URL of the page to load when opening new tabs.
40 const char kHomePage[] = "homepage";
42 // An integer that keeps track of the profile icon version. This allows us to
43 // determine the state of the profile icon for icon format changes.
44 const char kProfileIconVersion[] = "profile.icon_version";
46 // Used to determine if the last session exited cleanly. Set to false when
47 // first opened, and to true when closing. On startup if the value is false,
48 // it means the profile didn't exit cleanly.
49 // DEPRECATED: this is replaced by kSessionExitType and exists for backwards
50 // compatibility.
51 const char kSessionExitedCleanly[] = "profile.exited_cleanly";
53 // A string pref whose values is one of the values defined by
54 // |ProfileImpl::kPrefExitTypeXXX|. Set to |kPrefExitTypeCrashed| on startup and
55 // one of |kPrefExitTypeNormal| or |kPrefExitTypeSessionEnded| during
56 // shutdown. Used to determine the exit type the last time the profile was open.
57 const char kSessionExitType[] = "profile.exit_type";
59 // An integer pref. Holds one of several values:
60 // 0: (deprecated) open the homepage on startup.
61 // 1: restore the last session.
62 // 2: this was used to indicate a specific session should be restored. It is
63 // no longer used, but saved to avoid conflict with old preferences.
64 // 3: unused, previously indicated the user wants to restore a saved session.
65 // 4: restore the URLs defined in kURLsToRestoreOnStartup.
66 // 5: open the New Tab Page on startup.
67 const char kRestoreOnStartup[] = "session.restore_on_startup";
69 // A preference to keep track of whether we have already checked whether we
70 // need to migrate the user from kRestoreOnStartup=0 to kRestoreOnStartup=4.
71 // We only need to do this check once, on upgrade from m18 or lower to m19 or
72 // higher.
73 const char kRestoreOnStartupMigrated[] = "session.restore_on_startup_migrated";
75 // Serialized migration time of kURLsToRestoreOnStartup (see
76 // base::Time::ToInternalValue for details on serialization format).
77 const char kRestoreStartupURLsMigrationTime[] =
78 "session.startup_urls_migration_time";
80 // The URLs to restore on startup or when the home button is pressed. The URLs
81 // are only restored on startup if kRestoreOnStartup is 4.
82 const char kURLsToRestoreOnStartup[] = "session.startup_urls";
84 // Old startup url pref name for kURLsToRestoreOnStartup.
85 const char kURLsToRestoreOnStartupOld[] = "session.urls_to_restore_on_startup";
87 // Stores the email address associated with the google account of the custodian
88 // of the supervised user, set when the supervised user is created.
89 const char kSupervisedUserCustodianEmail[] = "profile.managed.custodian_email";
91 // Stores the display name associated with the google account of the custodian
92 // of the supervised user, updated (if possible) each time the supervised user
93 // starts a session.
94 const char kSupervisedUserCustodianName[] = "profile.managed.custodian_name";
96 // Stores the URL of the profile image associated with the google account of the
97 // custodian of the supervised user.
98 const char kSupervisedUserCustodianProfileImageURL[] =
99 "profile.managed.custodian_profile_image_url";
101 // Stores the URL of the profile associated with the google account of the
102 // custodian of the supervised user.
103 const char kSupervisedUserCustodianProfileURL[] =
104 "profile.managed.custodian_profile_url";
106 // Maps host names to whether the host is manually allowed or blocked.
107 const char kSupervisedUserManualHosts[] = "profile.managed.manual_hosts";
109 // Maps URLs to whether the URL is manually allowed or blocked.
110 const char kSupervisedUserManualURLs[] = "profile.managed.manual_urls";
112 // Stores the email address associated with the google account of the secondary
113 // custodian of the supervised user, set when the supervised user is created.
114 const char kSupervisedUserSecondCustodianEmail[] =
115 "profile.managed.second_custodian_email";
117 // Stores the display name associated with the google account of the secondary
118 // custodian of the supervised user, updated (if possible) each time the
119 // supervised user starts a session.
120 const char kSupervisedUserSecondCustodianName[] =
121 "profile.managed.second_custodian_name";
123 // Stores the URL of the profile image associated with the google account of the
124 // secondary custodian of the supervised user.
125 const char kSupervisedUserSecondCustodianProfileImageURL[] =
126 "profile.managed.second_custodian_profile_image_url";
128 // Stores the URL of the profile associated with the google account of the
129 // secondary custodian of the supervised user.
130 const char kSupervisedUserSecondCustodianProfileURL[] =
131 "profile.managed.second_custodian_profile_url";
133 // Stores settings that can be modified both by a supervised user and their
134 // manager. See SupervisedUserSharedSettingsService for a description of
135 // the format.
136 const char kSupervisedUserSharedSettings[] = "profile.managed.shared_settings";
138 // A dictionary storing whitelists for a supervised user. The key is the CRX ID
139 // of the whitelist, the value a dictionary containing whitelist properties
140 // (currently the name).
141 const char kSupervisedUserWhitelists[] = "profile.managed.whitelists";
143 // The application locale.
144 // For OS_CHROMEOS we maintain kApplicationLocale property in both local state
145 // and user's profile. Global property determines locale of login screen,
146 // while user's profile determines his personal locale preference.
147 const char kApplicationLocale[] = "intl.app_locale";
148 #if defined(OS_CHROMEOS)
149 // Locale preference of device' owner. ChromeOS device appears in this locale
150 // after startup/wakeup/signout.
151 const char kOwnerLocale[] = "intl.owner_locale";
152 // Locale accepted by user. Non-syncable.
153 // Used to determine whether we need to show Locale Change notification.
154 const char kApplicationLocaleAccepted[] = "intl.app_locale_accepted";
155 // Non-syncable item.
156 // It is used in two distinct ways.
157 // (1) Used for two-step initialization of locale in ChromeOS
158 // because synchronization of kApplicationLocale is not instant.
159 // (2) Used to detect locale change. Locale change is detected by
160 // LocaleChangeGuard in case values of kApplicationLocaleBackup and
161 // kApplicationLocale are both non-empty and differ.
162 // Following is a table showing how state of those prefs may change upon
163 // common real-life use cases:
164 // AppLocale Backup Accepted
165 // Initial login - A -
166 // Sync B A -
167 // Accept (B) B B B
168 // -----------------------------------------------------------
169 // Initial login - A -
170 // No sync and second login A A -
171 // Change options B B -
172 // -----------------------------------------------------------
173 // Initial login - A -
174 // Sync A A -
175 // Locale changed on login screen A C -
176 // Accept (A) A A A
177 // -----------------------------------------------------------
178 // Initial login - A -
179 // Sync B A -
180 // Revert A A -
181 const char kApplicationLocaleBackup[] = "intl.app_locale_backup";
182 #endif
184 // The default character encoding to assume for a web page in the
185 // absence of MIME charset specification
186 const char kDefaultCharset[] = "intl.charset_default";
188 // The value to use for Accept-Languages HTTP header when making an HTTP
189 // request.
190 const char kAcceptLanguages[] = "intl.accept_languages";
192 // The value to use for showing locale-dependent encoding list for different
193 // locale, it's initialized from the corresponding string resource that is
194 // stored in non-translatable part of the resource bundle.
195 const char kStaticEncodings[] = "intl.static_encodings";
197 // If these change, the corresponding enums in the extension API
198 // experimental.fontSettings.json must also change.
199 const char* const kWebKitScriptsForFontFamilyMaps[] = {
200 #define EXPAND_SCRIPT_FONT(x, script_name) script_name ,
201 #include "chrome/common/pref_font_script_names-inl.h"
202 ALL_FONT_SCRIPTS("unused param")
203 #undef EXPAND_SCRIPT_FONT
206 const size_t kWebKitScriptsForFontFamilyMapsLength =
207 arraysize(kWebKitScriptsForFontFamilyMaps);
209 // Strings for WebKit font family preferences. If these change, the pref prefix
210 // in pref_names_util.cc and the pref format in font_settings_api.cc must also
211 // change.
212 const char kWebKitStandardFontFamilyMap[] =
213 WEBKIT_WEBPREFS_FONTS_STANDARD;
214 const char kWebKitFixedFontFamilyMap[] =
215 WEBKIT_WEBPREFS_FONTS_FIXED;
216 const char kWebKitSerifFontFamilyMap[] =
217 WEBKIT_WEBPREFS_FONTS_SERIF;
218 const char kWebKitSansSerifFontFamilyMap[] =
219 WEBKIT_WEBPREFS_FONTS_SANSERIF;
220 const char kWebKitCursiveFontFamilyMap[] =
221 WEBKIT_WEBPREFS_FONTS_CURSIVE;
222 const char kWebKitFantasyFontFamilyMap[] =
223 WEBKIT_WEBPREFS_FONTS_FANTASY;
224 const char kWebKitPictographFontFamilyMap[] =
225 WEBKIT_WEBPREFS_FONTS_PICTOGRAPH;
226 const char kWebKitStandardFontFamilyArabic[] =
227 "webkit.webprefs.fonts.standard.Arab";
228 #if defined(OS_WIN)
229 const char kWebKitFixedFontFamilyArabic[] =
230 "webkit.webprefs.fonts.fixed.Arab";
231 #endif
232 const char kWebKitSerifFontFamilyArabic[] =
233 "webkit.webprefs.fonts.serif.Arab";
234 const char kWebKitSansSerifFontFamilyArabic[] =
235 "webkit.webprefs.fonts.sansserif.Arab";
236 #if defined(OS_WIN)
237 const char kWebKitStandardFontFamilyCyrillic[] =
238 "webkit.webprefs.fonts.standard.Cyrl";
239 const char kWebKitFixedFontFamilyCyrillic[] =
240 "webkit.webprefs.fonts.fixed.Cyrl";
241 const char kWebKitSerifFontFamilyCyrillic[] =
242 "webkit.webprefs.fonts.serif.Cyrl";
243 const char kWebKitSansSerifFontFamilyCyrillic[] =
244 "webkit.webprefs.fonts.sansserif.Cyrl";
245 const char kWebKitStandardFontFamilyGreek[] =
246 "webkit.webprefs.fonts.standard.Grek";
247 const char kWebKitFixedFontFamilyGreek[] =
248 "webkit.webprefs.fonts.fixed.Grek";
249 const char kWebKitSerifFontFamilyGreek[] =
250 "webkit.webprefs.fonts.serif.Grek";
251 const char kWebKitSansSerifFontFamilyGreek[] =
252 "webkit.webprefs.fonts.sansserif.Grek";
253 #endif
254 const char kWebKitStandardFontFamilyJapanese[] =
255 "webkit.webprefs.fonts.standard.Jpan";
256 const char kWebKitFixedFontFamilyJapanese[] =
257 "webkit.webprefs.fonts.fixed.Jpan";
258 const char kWebKitSerifFontFamilyJapanese[] =
259 "webkit.webprefs.fonts.serif.Jpan";
260 const char kWebKitSansSerifFontFamilyJapanese[] =
261 "webkit.webprefs.fonts.sansserif.Jpan";
262 const char kWebKitStandardFontFamilyKorean[] =
263 "webkit.webprefs.fonts.standard.Hang";
264 const char kWebKitFixedFontFamilyKorean[] =
265 "webkit.webprefs.fonts.fixed.Hang";
266 const char kWebKitSerifFontFamilyKorean[] =
267 "webkit.webprefs.fonts.serif.Hang";
268 const char kWebKitSansSerifFontFamilyKorean[] =
269 "webkit.webprefs.fonts.sansserif.Hang";
270 #if defined(OS_WIN)
271 const char kWebKitCursiveFontFamilyKorean[] =
272 "webkit.webprefs.fonts.cursive.Hang";
273 #endif
274 const char kWebKitStandardFontFamilySimplifiedHan[] =
275 "webkit.webprefs.fonts.standard.Hans";
276 const char kWebKitFixedFontFamilySimplifiedHan[] =
277 "webkit.webprefs.fonts.fixed.Hans";
278 const char kWebKitSerifFontFamilySimplifiedHan[] =
279 "webkit.webprefs.fonts.serif.Hans";
280 const char kWebKitSansSerifFontFamilySimplifiedHan[] =
281 "webkit.webprefs.fonts.sansserif.Hans";
282 const char kWebKitStandardFontFamilyTraditionalHan[] =
283 "webkit.webprefs.fonts.standard.Hant";
284 const char kWebKitFixedFontFamilyTraditionalHan[] =
285 "webkit.webprefs.fonts.fixed.Hant";
286 const char kWebKitSerifFontFamilyTraditionalHan[] =
287 "webkit.webprefs.fonts.serif.Hant";
288 const char kWebKitSansSerifFontFamilyTraditionalHan[] =
289 "webkit.webprefs.fonts.sansserif.Hant";
291 // WebKit preferences.
292 const char kWebKitWebSecurityEnabled[] = "webkit.webprefs.web_security_enabled";
293 const char kWebKitDomPasteEnabled[] = "webkit.webprefs.dom_paste_enabled";
294 const char kWebKitUsesUniversalDetector[] =
295 "webkit.webprefs.uses_universal_detector";
296 const char kWebKitTextAreasAreResizable[] =
297 "webkit.webprefs.text_areas_are_resizable";
298 const char kWebKitJavaEnabled[] = "webkit.webprefs.java_enabled";
299 const char kWebkitTabsToLinks[] = "webkit.webprefs.tabs_to_links";
300 const char kWebKitAllowDisplayingInsecureContent[] =
301 "webkit.webprefs.allow_displaying_insecure_content";
302 const char kWebKitAllowRunningInsecureContent[] =
303 "webkit.webprefs.allow_running_insecure_content";
304 #if defined(OS_ANDROID)
305 const char kWebKitFontScaleFactor[] = "webkit.webprefs.font_scale_factor";
306 const char kWebKitForceEnableZoom[] = "webkit.webprefs.force_enable_zoom";
307 const char kWebKitPasswordEchoEnabled[] =
308 "webkit.webprefs.password_echo_enabled";
309 #endif
311 const char kWebKitCommonScript[] = "Zyyy";
312 const char kWebKitStandardFontFamily[] = "webkit.webprefs.fonts.standard.Zyyy";
313 const char kWebKitFixedFontFamily[] = "webkit.webprefs.fonts.fixed.Zyyy";
314 const char kWebKitSerifFontFamily[] = "webkit.webprefs.fonts.serif.Zyyy";
315 const char kWebKitSansSerifFontFamily[] =
316 "webkit.webprefs.fonts.sansserif.Zyyy";
317 const char kWebKitCursiveFontFamily[] = "webkit.webprefs.fonts.cursive.Zyyy";
318 const char kWebKitFantasyFontFamily[] = "webkit.webprefs.fonts.fantasy.Zyyy";
319 const char kWebKitPictographFontFamily[] =
320 "webkit.webprefs.fonts.pictograph.Zyyy";
321 const char kWebKitDefaultFontSize[] = "webkit.webprefs.default_font_size";
322 const char kWebKitDefaultFixedFontSize[] =
323 "webkit.webprefs.default_fixed_font_size";
324 const char kWebKitMinimumFontSize[] = "webkit.webprefs.minimum_font_size";
325 const char kWebKitMinimumLogicalFontSize[] =
326 "webkit.webprefs.minimum_logical_font_size";
327 const char kWebKitJavascriptEnabled[] = "webkit.webprefs.javascript_enabled";
328 const char kWebKitJavascriptCanOpenWindowsAutomatically[] =
329 "webkit.webprefs.javascript_can_open_windows_automatically";
330 const char kWebKitLoadsImagesAutomatically[] =
331 "webkit.webprefs.loads_images_automatically";
332 const char kWebKitPluginsEnabled[] = "webkit.webprefs.plugins_enabled";
334 // Boolean that is true when SafeBrowsing is enabled.
335 const char kSafeBrowsingEnabled[] = "safebrowsing.enabled";
337 // Boolean that tell us whether Safe Browsing extended reporting is enabled.
338 const char kSafeBrowsingExtendedReportingEnabled[] =
339 "safebrowsing.extended_reporting_enabled";
341 // Boolean that is true when the SafeBrowsing interstitial should not allow
342 // users to proceed anyway.
343 const char kSafeBrowsingProceedAnywayDisabled[] =
344 "safebrowsing.proceed_anyway_disabled";
346 // A dictionary mapping incident types to a dict of incident key:digest pairs.
347 const char kSafeBrowsingIncidentsSent[] = "safebrowsing.incidents_sent";
349 // Boolean that tells us whether users are given the option to opt in to Safe
350 // Browsing extended reporting.
351 const char kSafeBrowsingExtendedReportingOptInAllowed[] =
352 "safebrowsing.extended_reporting_opt_in_allowed";
354 // Boolean that is true when the SSL interstitial should allow users to
355 // proceed anyway. Otherwise, proceeding is not possible.
356 const char kSSLErrorOverrideAllowed[] = "ssl.error_override_allowed";
358 // Enum that specifies whether Incognito mode is:
359 // 0 - Enabled. Default behaviour. Default mode is available on demand.
360 // 1 - Disabled. Used cannot browse pages in Incognito mode.
361 // 2 - Forced. All pages/sessions are forced into Incognito.
362 const char kIncognitoModeAvailability[] = "incognito.mode_availability";
364 // Boolean that is true when Suggest support is enabled.
365 const char kSearchSuggestEnabled[] = "search.suggest_enabled";
367 #if defined(OS_ANDROID)
368 // String indicating the Contextual Search enabled state.
369 // "false" - opt-out (disabled)
370 // "" (empty string) - undecided
371 // "true" - opt-in (enabled)
372 const char kContextualSearchEnabled[] = "search.contextual_search_enabled";
373 #endif
375 #if defined(OS_MACOSX)
376 // Boolean that indicates whether the browser should put up a confirmation
377 // window when the user is attempting to quit. Mac only.
378 const char kConfirmToQuitEnabled[] = "browser.confirm_to_quit";
379 #endif
381 // Boolean which specifies whether we should ask the user if we should download
382 // a file (true) or just download it automatically.
383 const char kPromptForDownload[] = "download.prompt_for_download";
385 // A boolean pref set to true if we're using Link Doctor error pages.
386 const char kAlternateErrorPagesEnabled[] = "alternate_error_pages.enabled";
388 // An adaptively identified list of domain names to be pre-fetched during the
389 // next startup, based on what was actually needed during this startup.
390 const char kDnsPrefetchingStartupList[] = "dns_prefetching.startup_list";
392 // A list of host names used to fetch web pages, and their commonly used
393 // sub-resource hostnames (and expected latency benefits from pre-resolving, or
394 // preconnecting to, such sub-resource hostnames).
395 // This list is adaptively grown and pruned.
396 const char kDnsPrefetchingHostReferralList[] =
397 "dns_prefetching.host_referral_list";
399 // Disables the SPDY protocol.
400 const char kDisableSpdy[] = "spdy.disabled";
402 // Prefs for persisting HttpServerProperties.
403 const char kHttpServerProperties[] = "net.http_server_properties";
405 #if defined(OS_ANDROID) || defined(OS_IOS)
406 // Last time that a check for cloud policy management was done. This time is
407 // recorded on Android so that retries aren't attempted on every startup.
408 // Instead the cloud policy registration is retried at least 1 or 3 days later.
409 const char kLastPolicyCheckTime[] = "policy.last_policy_check_time";
410 #endif
412 // Prefix URL for the experimental Instant ZeroSuggest provider.
413 const char kInstantUIZeroSuggestUrlPrefix[] =
414 "instant_ui.zero_suggest_url_prefix";
416 // A boolean pref set to true if prediction of network actions is allowed.
417 // Actions include DNS prefetching, TCP and SSL preconnection, prerendering
418 // of web pages, and resource prefetching.
419 // NOTE: The "dns_prefetching.enabled" value is used so that historical user
420 // preferences are not lost.
421 // TODO(bnc): Remove kNetworkPredictionEnabled once kNetworkPredictionOptions
422 // is functioning as per crbug.com/334602.
423 const char kNetworkPredictionEnabled[] = "dns_prefetching.enabled";
425 // A preference of enum chrome_browser_net::NetworkPredictionOptions shows
426 // if prediction of network actions is allowed, depending on network type.
427 // Actions include DNS prefetching, TCP and SSL preconnection, prerendering
428 // of web pages, and resource prefetching.
429 // TODO(bnc): Implement this preference as per crbug.com/334602.
430 const char kNetworkPredictionOptions[] = "net.network_prediction_options";
432 // An integer representing the state of the default apps installation process.
433 // This value is persisted in the profile's user preferences because the process
434 // is async, and the user may have stopped chrome in the middle. The next time
435 // the profile is opened, the process will continue from where it left off.
437 // See possible values in external_provider_impl.cc.
438 const char kDefaultAppsInstallState[] = "default_apps_install_state";
440 // A boolean pref set to true if the Chrome Web Store icons should be hidden
441 // from the New Tab Page and app launcher.
442 const char kHideWebStoreIcon[] = "hide_web_store_icon";
444 #if defined(OS_CHROMEOS)
445 // A boolean pref set to true if touchpad tap-to-click is enabled.
446 const char kTapToClickEnabled[] = "settings.touchpad.enable_tap_to_click";
448 // A boolean pref set to true if touchpad tap-dragging is enabled.
449 const char kTapDraggingEnabled[] = "settings.touchpad.enable_tap_dragging";
451 // A boolean pref set to true if touchpad three-finger-click is enabled.
452 const char kEnableTouchpadThreeFingerClick[] =
453 "settings.touchpad.enable_three_finger_click";
455 // A boolean pref set to true if touchpad natural scrolling is enabled.
456 const char kNaturalScroll[] = "settings.touchpad.natural_scroll";
458 // A boolean pref set to true if primary mouse button is the left button.
459 const char kPrimaryMouseButtonRight[] = "settings.mouse.primary_right";
461 // A integer pref for the touchpad sensitivity.
462 const char kMouseSensitivity[] = "settings.mouse.sensitivity2";
464 // A integer pref for the touchpad sensitivity.
465 const char kTouchpadSensitivity[] = "settings.touchpad.sensitivity2";
467 // A boolean pref set to true if time should be displayed in 24-hour clock.
468 const char kUse24HourClock[] = "settings.clock.use_24hour_clock";
470 // This setting disables manual timezone selection and starts periodic timezone
471 // refresh.
472 const char kResolveTimezoneByGeolocation[] =
473 "settings.resolve_timezone_by_geolocation";
475 // A string pref set to the current input method.
476 const char kLanguageCurrentInputMethod[] =
477 "settings.language.current_input_method";
479 // A string pref set to the previous input method.
480 const char kLanguagePreviousInputMethod[] =
481 "settings.language.previous_input_method";
483 // A string pref (comma-separated list) set to the preferred language IDs
484 // (ex. "en-US,fr,ko").
485 const char kLanguagePreferredLanguages[] =
486 "settings.language.preferred_languages";
487 const char kLanguagePreferredLanguagesSyncable[] =
488 "settings.language.preferred_languages_syncable";
490 // A string pref (comma-separated list) set to the preloaded (active) input
491 // method IDs (ex. "pinyin,mozc").
492 const char kLanguagePreloadEngines[] = "settings.language.preload_engines";
493 const char kLanguagePreloadEnginesSyncable[] =
494 "settings.language.preload_engines_syncable";
496 // A string pref (comma-separated list) set to the extension IMEs to be enabled.
497 const char kLanguageEnabledExtensionImes[] =
498 "settings.language.enabled_extension_imes";
499 const char kLanguageEnabledExtensionImesSyncable[] =
500 "settings.language.enabled_extension_imes_syncable";
502 // A boolean pref to indicate whether we still need to add the globally synced
503 // input methods. False after the initial post-OOBE sync.
504 const char kLanguageShouldMergeInputMethods[] =
505 "settings.language.merge_input_methods";
507 // Integer prefs which determine how we remap modifier keys (e.g. swap Alt and
508 // Control.) Possible values for these prefs are 0-4. See ModifierKey enum in
509 // src/chrome/browser/chromeos/input_method/xkeyboard.h
510 const char kLanguageRemapSearchKeyTo[] =
511 // Note: we no longer use XKB for remapping these keys, but we can't change
512 // the pref names since the names are already synced with the cloud.
513 "settings.language.xkb_remap_search_key_to";
514 const char kLanguageRemapControlKeyTo[] =
515 "settings.language.xkb_remap_control_key_to";
516 const char kLanguageRemapAltKeyTo[] =
517 "settings.language.xkb_remap_alt_key_to";
518 const char kLanguageRemapCapsLockKeyTo[] =
519 "settings.language.remap_caps_lock_key_to";
520 const char kLanguageRemapDiamondKeyTo[] =
521 "settings.language.remap_diamond_key_to";
523 // A boolean pref that causes top-row keys to be interpreted as function keys
524 // instead of as media keys.
525 const char kLanguageSendFunctionKeys[] =
526 "settings.language.send_function_keys";
528 // A boolean pref which determines whether key repeat is enabled.
529 const char kLanguageXkbAutoRepeatEnabled[] =
530 "settings.language.xkb_auto_repeat_enabled_r2";
531 // A integer pref which determines key repeat delay (in ms).
532 const char kLanguageXkbAutoRepeatDelay[] =
533 "settings.language.xkb_auto_repeat_delay_r2";
534 // A integer pref which determines key repeat interval (in ms).
535 const char kLanguageXkbAutoRepeatInterval[] =
536 "settings.language.xkb_auto_repeat_interval_r2";
537 // "_r2" suffixes were added to the three prefs above when we changed the
538 // preferences to not be user-configurable or sync with the cloud. The prefs are
539 // now user-configurable and syncable again, but we don't want to overwrite the
540 // current values with the old synced values, so we continue to use this suffix.
542 // A boolean pref which determines whether the large cursor feature is enabled.
543 const char kAccessibilityLargeCursorEnabled[] =
544 "settings.a11y.large_cursor_enabled";
546 // A boolean pref which determines whether the sticky keys feature is enabled.
547 const char kAccessibilityStickyKeysEnabled[] =
548 "settings.a11y.sticky_keys_enabled";
549 // A boolean pref which determines whether spoken feedback is enabled.
550 const char kAccessibilitySpokenFeedbackEnabled[] = "settings.accessibility";
551 // A boolean pref which determines whether high conrast is enabled.
552 const char kAccessibilityHighContrastEnabled[] =
553 "settings.a11y.high_contrast_enabled";
554 // A boolean pref which determines whether screen magnifier is enabled.
555 const char kAccessibilityScreenMagnifierEnabled[] =
556 "settings.a11y.screen_magnifier";
557 // A boolean pref which determines whether screen magnifier should center
558 // the text input focus.
559 const char kAccessibilityScreenMagnifierCenterFocus[] =
560 "settings.a11y.screen_magnifier_center_focus";
561 // A integer pref which determines what type of screen magnifier is enabled.
562 // Note that: 'screen_magnifier_type' had been used as string pref. Hence,
563 // we are using another name pref here.
564 const char kAccessibilityScreenMagnifierType[] =
565 "settings.a11y.screen_magnifier_type2";
566 // A double pref which determines a zooming scale of the screen magnifier.
567 const char kAccessibilityScreenMagnifierScale[] =
568 "settings.a11y.screen_magnifier_scale";
569 // A boolean pref which determines whether the virtual keyboard is enabled for
570 // accessibility. This feature is separate from displaying an onscreen keyboard
571 // due to lack of a physical keyboard.
572 const char kAccessibilityVirtualKeyboardEnabled[] =
573 "settings.a11y.virtual_keyboard";
574 // A boolean pref which determines whether autoclick is enabled.
575 const char kAccessibilityAutoclickEnabled[] = "settings.a11y.autoclick";
576 // An integer pref which determines time in ms between when the mouse cursor
577 // stops and when an autoclick is triggered.
578 const char kAccessibilityAutoclickDelayMs[] =
579 "settings.a11y.autoclick_delay_ms";
580 // A boolean pref which determines whether the accessibility menu shows
581 // regardless of the state of a11y features.
582 const char kShouldAlwaysShowAccessibilityMenu[] = "settings.a11y.enable_menu";
584 // A boolean pref which turns on Advanced Filesystem
585 // (USB support, SD card, etc).
586 const char kLabsAdvancedFilesystemEnabled[] =
587 "settings.labs.advanced_filesystem";
589 // A boolean pref which turns on the mediaplayer.
590 const char kLabsMediaplayerEnabled[] = "settings.labs.mediaplayer";
592 // A boolean pref that turns on automatic screen locking.
593 const char kEnableAutoScreenLock[] = "settings.enable_screen_lock";
595 // A boolean pref of whether to show mobile plan notifications.
596 const char kShowPlanNotifications[] =
597 "settings.internet.mobile.show_plan_notifications";
599 // A boolean pref of whether to show 3G promo notification.
600 const char kShow3gPromoNotification[] =
601 "settings.internet.mobile.show_3g_promo_notification";
603 // An integer pref counting times Data Saver prompt has been shown.
604 const char kDataSaverPromptsShown[] =
605 "settings.internet.mobile.datasaver_prompts_shown";
607 // A string pref that contains version where "What's new" promo was shown.
608 const char kChromeOSReleaseNotesVersion[] = "settings.release_notes.version";
610 // A boolean pref that controls whether proxy settings from shared network
611 // settings (accordingly from device policy) are applied or ignored.
612 const char kUseSharedProxies[] = "settings.use_shared_proxies";
614 // Power state of the current displays from the last run.
615 const char kDisplayPowerState[] = "settings.display.power_state";
616 // A dictionary pref that stores per display preferences.
617 const char kDisplayProperties[] = "settings.display.properties";
619 // A dictionary pref that specifies per-display layout/offset information.
620 // Its key is the ID of the display and its value is a dictionary for the
621 // layout/offset information.
622 const char kSecondaryDisplays[] = "settings.display.secondary_displays";
624 // A dictionary pref that specifies the state of the rotation lock, and the
625 // display orientation, for the internal display.
626 const char kDisplayRotationLock[] = "settings.display.rotation_lock";
628 // A boolean pref indicating whether user activity has been observed in the
629 // current session already. The pref is used to restore information about user
630 // activity after browser crashes.
631 const char kSessionUserActivitySeen[] = "session.user_activity_seen";
633 // A preference to keep track of the session start time. If the session length
634 // limit is configured to start running after initial user activity has been
635 // observed, the pref is set after the first user activity in a session.
636 // Otherwise, it is set immediately after session start. The pref is used to
637 // restore the session start time after browser crashes. The time is expressed
638 // as the serialization obtained from base::TimeTicks::ToInternalValue().
639 const char kSessionStartTime[] = "session.start_time";
641 // Holds the maximum session time in milliseconds. If this pref is set, the
642 // user is logged out when the maximum session time is reached. The user is
643 // informed about the remaining time by a countdown timer shown in the ash
644 // system tray.
645 const char kSessionLengthLimit[] = "session.length_limit";
647 // Whether the session length limit should start running only after the first
648 // user activity has been observed in a session.
649 const char kSessionWaitForInitialUserActivity[] =
650 "session.wait_for_initial_user_activity";
652 // Inactivity time in milliseconds while the system is on AC power before
653 // the screen should be dimmed, turned off, or locked, before an
654 // IdleActionImminent D-Bus signal should be sent, or before
655 // kPowerAcIdleAction should be performed. 0 disables the delay (N/A for
656 // kPowerAcIdleDelayMs).
657 const char kPowerAcScreenDimDelayMs[] = "power.ac_screen_dim_delay_ms";
658 const char kPowerAcScreenOffDelayMs[] = "power.ac_screen_off_delay_ms";
659 const char kPowerAcScreenLockDelayMs[] = "power.ac_screen_lock_delay_ms";
660 const char kPowerAcIdleWarningDelayMs[] = "power.ac_idle_warning_delay_ms";
661 const char kPowerAcIdleDelayMs[] = "power.ac_idle_delay_ms";
663 // Similar delays while the system is on battery power.
664 const char kPowerBatteryScreenDimDelayMs[] =
665 "power.battery_screen_dim_delay_ms";
666 const char kPowerBatteryScreenOffDelayMs[] =
667 "power.battery_screen_off_delay_ms";
668 const char kPowerBatteryScreenLockDelayMs[] =
669 "power.battery_screen_lock_delay_ms";
670 const char kPowerBatteryIdleWarningDelayMs[] =
671 "power.battery_idle_warning_delay_ms";
672 const char kPowerBatteryIdleDelayMs[] =
673 "power.battery_idle_delay_ms";
675 // Inactivity delays used to dim the screen or turn it off while the screen is
676 // locked.
677 const char kPowerLockScreenDimDelayMs[] = "power.lock_screen_dim_delay_ms";
678 const char kPowerLockScreenOffDelayMs[] = "power.lock_screen_off_delay_ms";
680 // Action that should be performed when the idle delay is reached while the
681 // system is on AC power or battery power.
682 // Values are from the chromeos::PowerPolicyController::Action enum.
683 const char kPowerAcIdleAction[] = "power.ac_idle_action";
684 const char kPowerBatteryIdleAction[] = "power.battery_idle_action";
686 // Action that should be performed when the lid is closed.
687 // Values are from the chromeos::PowerPolicyController::Action enum.
688 const char kPowerLidClosedAction[] = "power.lid_closed_action";
690 // Should audio and video activity be used to disable the above delays?
691 const char kPowerUseAudioActivity[] = "power.use_audio_activity";
692 const char kPowerUseVideoActivity[] = "power.use_video_activity";
694 // Should extensions be able to use the chrome.power API to override
695 // screen-related power management (including locking)?
696 const char kPowerAllowScreenWakeLocks[] = "power.allow_screen_wake_locks";
698 // Amount by which the screen-dim delay should be scaled while the system
699 // is in presentation mode. Values are limited to a minimum of 1.0.
700 const char kPowerPresentationScreenDimDelayFactor[] =
701 "power.presentation_screen_dim_delay_factor";
703 // Amount by which the screen-dim delay should be scaled when user activity is
704 // observed while the screen is dimmed or soon after the screen has been turned
705 // off. Values are limited to a minimum of 1.0.
706 const char kPowerUserActivityScreenDimDelayFactor[] =
707 "power.user_activity_screen_dim_delay_factor";
709 // Whether the power management delays should start running only after the first
710 // user activity has been observed in a session.
711 const char kPowerWaitForInitialUserActivity[] =
712 "power.wait_for_initial_user_activity";
714 // Boolean controlling whether the panel backlight should be forced to a
715 // nonzero level when user activity is observed.
716 const char kPowerForceNonzeroBrightnessForUserActivity[] =
717 "power.force_nonzero_brightness_for_user_activity";
719 // The URL from which the Terms of Service can be downloaded. The value is only
720 // honored for public accounts.
721 const char kTermsOfServiceURL[] = "terms_of_service.url";
723 // Indicates that the Profile has made navigations that used a certificate
724 // installed by the system administrator. If that is true then the local cache
725 // of remote data is tainted (e.g. shared scripts), and future navigations
726 // show a warning indicating that the organization may track the browsing
727 // session.
728 const char kUsedPolicyCertificatesOnce[] = "used_policy_certificates_once";
730 // Indicates whether the remote attestation is enabled for the user.
731 const char kAttestationEnabled[] = "attestation.enabled";
732 // The list of extensions allowed to use the platformKeysPrivate API for
733 // remote attestation.
734 const char kAttestationExtensionWhitelist[] = "attestation.extension_whitelist";
736 // A boolean pref indicating whether the projection touch HUD is enabled or not.
737 const char kTouchHudProjectionEnabled[] = "touch_hud.projection_enabled";
739 // A pref to configure networks. Its value must be a list of
740 // NetworkConfigurations according to the OpenNetworkConfiguration
741 // specification.
742 // Currently, this pref is only used to store the policy. The user's
743 // configuration is still stored in Shill.
744 const char kOpenNetworkConfiguration[] = "onc";
746 // A boolean pref recording whether user has dismissed the multiprofile
747 // itroduction dialog show.
748 const char kMultiProfileNeverShowIntro[] =
749 "settings.multi_profile_never_show_intro";
751 // A boolean pref recording whether user has dismissed the multiprofile
752 // teleport warning dialog show.
753 const char kMultiProfileWarningShowDismissed[] =
754 "settings.multi_profile_warning_show_dismissed";
756 // A string pref that holds string enum values of how the user should behave
757 // in a multiprofile session. See ChromeOsMultiProfileUserBehavior policy
758 // for more details of the valid values.
759 const char kMultiProfileUserBehavior[] = "settings.multiprofile_user_behavior";
761 // A boolean preference indicating whether user has seen first-run tutorial
762 // already.
763 const char kFirstRunTutorialShown[] = "settings.first_run_tutorial_shown";
765 // Indicates the amount of time for which a user authenticated via SAML can use
766 // offline authentication against a cached password before being forced to go
767 // through online authentication against GAIA again. The time is expressed in
768 // seconds. A value of -1 indicates no limit, allowing the user to use offline
769 // authentication indefinitely. The limit is in effect only if GAIA redirected
770 // the user to a SAML IdP during the last online authentication.
771 const char kSAMLOfflineSigninTimeLimit[] = "saml.offline_signin_time_limit";
773 // A preference to keep track of the last time the user authenticated against
774 // GAIA using SAML. The preference is updated whenever the user authenticates
775 // against GAIA: If GAIA redirects to a SAML IdP, the preference is set to the
776 // current time. If GAIA performs the authentication itself, the preference is
777 // cleared. The time is expressed as the serialization obtained from
778 // base::Time::ToInternalValue().
779 const char kSAMLLastGAIASignInTime[] = "saml.last_gaia_sign_in_time";
781 // The total number of seconds that the machine has spent sitting on the
782 // OOBE screen.
783 const char kTimeOnOobe[] = "settings.time_on_oobe";
785 // The app/extension name who sets the current wallpaper. If current wallpaper
786 // is set by the component wallpaper picker, it is set to an empty string.
787 const char kCurrentWallpaperAppName[] = "wallpaper.app.name";
789 // List of mounted file systems via the File System Provider API. Used to
790 // restore them after a reboot.
791 const char kFileSystemProviderMounted[] = "file_system_provider.mounted";
793 // A boolean pref set to true if the virtual keyboard should be enabled.
794 const char kTouchVirtualKeyboardEnabled[] = "ui.touch_virtual_keyboard_enabled";
796 // A boolean pref that controls whether wake on SSID is enabled.
797 const char kWakeOnWifiSsid[] = "settings.internet.wake_on_wifi_ssid";
799 // This is the policy CaptivePortalAuthenticationIgnoresProxy that allows to
800 // open captive portal authentication pages in a separate window under
801 // a temporary incognito profile ("signin profile" is used for this purpose),
802 // which allows to bypass the user's proxy for captive portal authentication.
803 const char kCaptivePortalAuthenticationIgnoresProxy[] =
804 "proxy.captive_portal_ignores_proxy";
806 // This boolean controls whether the first window shown on first run should be
807 // unconditionally maximized, overriding the heuristic that normally chooses the
808 // window size.
809 const char kForceMaximizeOnFirstRun[] = "ui.force_maximize_on_first_run";
811 // A dictionary pref mapping public keys that identify platform keys to its
812 // properties like whether it's meant for corporate usage.
813 const char kPlatformKeys[] = "platform_keys";
814 #endif // defined(OS_CHROMEOS)
816 // A boolean pref set to true if a Home button to open the Home pages should be
817 // visible on the toolbar.
818 const char kShowHomeButton[] = "browser.show_home_button";
820 // A string value which saves short list of recently user selected encodings
821 // separated with comma punctuation mark.
822 const char kRecentlySelectedEncoding[] = "profile.recently_selected_encodings";
824 // Clear Browsing Data dialog preferences.
825 const char kDeleteBrowsingHistory[] = "browser.clear_data.browsing_history";
826 const char kDeleteDownloadHistory[] = "browser.clear_data.download_history";
827 const char kDeleteCache[] = "browser.clear_data.cache";
828 const char kDeleteCookies[] = "browser.clear_data.cookies";
829 const char kDeletePasswords[] = "browser.clear_data.passwords";
830 const char kDeleteFormData[] = "browser.clear_data.form_data";
831 const char kDeleteHostedAppsData[] = "browser.clear_data.hosted_apps_data";
832 const char kDeauthorizeContentLicenses[] =
833 "browser.clear_data.content_licenses";
834 const char kDeleteTimePeriod[] = "browser.clear_data.time_period";
835 const char kLastClearBrowsingDataTime[] =
836 "browser.last_clear_browsing_data_time";
838 // Boolean pref to define the default values for using spellchecker.
839 const char kEnableContinuousSpellcheck[] = "browser.enable_spellchecking";
841 // List of names of the enabled labs experiments (see chrome/browser/labs.cc).
842 const char kEnabledLabsExperiments[] = "browser.enabled_labs_experiments";
844 // Boolean pref to define the default values for using auto spell correct.
845 const char kEnableAutoSpellCorrect[] = "browser.enable_autospellcorrect";
847 // Boolean pref to define the default setting for "block offensive words".
848 // The old key value is kept to avoid unnecessary migration code.
849 const char kSpeechRecognitionFilterProfanities[] =
850 "browser.speechinput_censor_results";
852 // Boolean controlling whether history saving is disabled.
853 const char kSavingBrowserHistoryDisabled[] = "history.saving_disabled";
855 // Boolean controlling whether deleting browsing and download history is
856 // permitted.
857 const char kAllowDeletingBrowserHistory[] = "history.deleting_enabled";
859 // Boolean controlling whether SafeSearch is mandatory for Google Web Searches.
860 const char kForceGoogleSafeSearch[] = "settings.force_google_safesearch";
862 // Boolean controlling whether Safety Mode is mandatory on YouTube.
863 const char kForceYouTubeSafetyMode[] = "settings.force_youtube_safety_mode";
865 // Boolean controlling whether History is recorded and synced for
866 // supervised users.
867 const char kRecordHistory[] = "settings.history_recorded";
869 #if defined(OS_LINUX) && !defined(OS_CHROMEOS)
870 // Linux specific preference on whether we should match the system theme.
871 const char kUsesSystemTheme[] = "extensions.theme.use_system";
872 #endif
873 const char kCurrentThemePackFilename[] = "extensions.theme.pack";
874 const char kCurrentThemeID[] = "extensions.theme.id";
875 const char kCurrentThemeImages[] = "extensions.theme.images";
876 const char kCurrentThemeColors[] = "extensions.theme.colors";
877 const char kCurrentThemeTints[] = "extensions.theme.tints";
878 const char kCurrentThemeDisplayProperties[] = "extensions.theme.properties";
880 // Boolean pref which persists whether the extensions_ui is in developer mode
881 // (showing developer packing tools and extensions details)
882 const char kExtensionsUIDeveloperMode[] = "extensions.ui.developer_mode";
884 // Boolean pref which indicates whether the Chrome Apps & Extensions Developer
885 // Tool promotion has been dismissed by the user.
886 const char kExtensionsUIDismissedADTPromo[] =
887 "extensions.ui.dismissed_adt_promo";
889 // Dictionary pref that tracks which command belongs to which
890 // extension + named command pair.
891 const char kExtensionCommands[] = "extensions.commands";
893 // Pref containing the directory for internal plugins as written to the plugins
894 // list (below).
895 const char kPluginsLastInternalDirectory[] = "plugins.last_internal_directory";
897 // List pref containing information (dictionaries) on plugins.
898 const char kPluginsPluginsList[] = "plugins.plugins_list";
900 // List pref containing names of plugins that are disabled by policy.
901 const char kPluginsDisabledPlugins[] = "plugins.plugins_disabled";
903 // List pref containing exceptions to the list of plugins disabled by policy.
904 const char kPluginsDisabledPluginsExceptions[] =
905 "plugins.plugins_disabled_exceptions";
907 // List pref containing names of plugins that are enabled by policy.
908 const char kPluginsEnabledPlugins[] = "plugins.plugins_enabled";
910 // When bundled NPAPI Flash is removed, if at that point it is enabled while
911 // Pepper Flash is disabled, we would like to turn on Pepper Flash. And we will
912 // want to do so only once.
913 const char kPluginsMigratedToPepperFlash[] = "plugins.migrated_to_pepper_flash";
915 // In the early stage of component-updated PPAPI Flash, we did field trials in
916 // which it was set to disabled by default. The corresponding settings item may
917 // remain in some users' profiles. Currently it affects both the bundled and
918 // component-updated PPAPI Flash (since the two share the same enable/disable
919 // state). We want to remove this item to get those users to use PPAPI Flash.
920 // We will want to do so only once.
921 const char kPluginsRemovedOldComponentPepperFlashSettings[] =
922 "plugins.removed_old_component_pepper_flash_settings";
924 #if !defined(OS_ANDROID)
925 // Whether about:plugins is shown in the details mode or not.
926 const char kPluginsShowDetails[] = "plugins.show_details";
927 #endif
929 // Boolean that indicates whether outdated plugins are allowed or not.
930 const char kPluginsAllowOutdated[] = "plugins.allow_outdated";
932 // Boolean that indicates whether plugins that require authorization should
933 // be always allowed or not.
934 const char kPluginsAlwaysAuthorize[] = "plugins.always_authorize";
936 #if defined(ENABLE_PLUGIN_INSTALLATION)
937 // Dictionary holding plugins metadata.
938 const char kPluginsMetadata[] = "plugins.metadata";
940 // Last update time of plugins resource cache.
941 const char kPluginsResourceCacheUpdate[] = "plugins.resource_cache_update";
942 #endif
944 // Boolean that indicates whether we should check if we are the default browser
945 // on start-up.
946 const char kCheckDefaultBrowser[] = "browser.check_default_browser";
948 // Policy setting whether default browser check should be disabled and default
949 // browser registration should take place.
950 const char kDefaultBrowserSettingEnabled[] =
951 "browser.default_browser_setting_enabled";
953 #if defined(OS_MACOSX)
954 // Boolean that indicates whether the application should show the info bar
955 // asking the user to set up automatic updates when Keystone promotion is
956 // required.
957 const char kShowUpdatePromotionInfoBar[] =
958 "browser.show_update_promotion_info_bar";
959 #endif
961 // Boolean that is false if we should show window manager decorations. If
962 // true, we draw a custom chrome frame (thicker title bar and blue border).
963 const char kUseCustomChromeFrame[] = "browser.custom_chrome_frame";
965 #if !defined(OS_ANDROID)
966 // Which plugins have been whitelisted manually by the user.
967 const char kContentSettingsPluginWhitelist[] =
968 "profile.content_settings.plugin_whitelist";
969 #endif
971 // Boolean that is true when all locally stored site data (e.g. cookies, local
972 // storage, etc..) should be deleted on exit.
973 const char kClearSiteDataOnExit[] = "profile.clear_site_data_on_exit";
975 // Double that indicates the default zoom level.
976 const char kPartitionDefaultZoomLevel[] = "partition.default_zoom_level";
977 // TODO(wjmaclean): Remove this once sufficient users have migrated to the
978 // per-StoragePartition zoom levels. http://crbug.com/420643.
979 const char kDefaultZoomLevelDeprecated[] = "profile.default_zoom_level";
981 // Dictionary that maps hostnames to zoom levels. Hosts not in this pref will
982 // be displayed at the default zoom level.
983 const char kPartitionPerHostZoomLevels[] = "partition.per_host_zoom_levels";
984 // TODO(wjmaclean): Remove this.
985 const char kPerHostZoomLevelsDeprecated[] = "profile.per_host_zoom_levels";
987 // A dictionary that tracks the default data model to use for each section of
988 // the dialog.
989 const char kAutofillDialogAutofillDefault[] = "autofill.data_model_default";
991 // Whether a user opted out of making purchases with Google Wallet; changed via
992 // the autofill dialog's account chooser and set explicitly on dialog submission
993 // (but not cancel). If this isn't set, the dialog assumes it's the first run.
994 const char kAutofillDialogPayWithoutWallet[] = "autofill.pay_without_wallet";
996 // Which GAIA users have accepted that use of Google Wallet implies their
997 // location will be shared with fraud protection services.
998 const char kAutofillDialogWalletLocationAcceptance[] =
999 "autofill.wallet_location_disclosure";
1001 // Whether a user wants to save data locally in Autofill.
1002 const char kAutofillDialogSaveData[] = "autofill.save_data";
1004 // Whether the user has selected "Same as billing" for the shipping address when
1005 // using Google Wallet.
1006 const char kAutofillDialogWalletShippingSameAsBilling[] =
1007 "autofill.wallet_shipping_same_as_billing";
1009 // The number of times the generated credit card bubble has been shown.
1010 const char kAutofillGeneratedCardBubbleTimesShown[] =
1011 "autofill.generated_card_bubble_times_shown";
1013 #if defined(OS_ANDROID)
1014 // A dictionary that tracks the defaults to be set on the next invocation
1015 // of the requestAutocomplete dialog.
1016 const char kAutofillDialogDefaults[] = "autofill.rac_dialog_defaults";
1017 #endif
1019 #if !defined(OS_ANDROID)
1020 const char kPinnedTabs[] = "pinned_tabs";
1021 #endif
1023 // Preference to disable 3D APIs (WebGL, Pepper 3D).
1024 const char kDisable3DAPIs[] = "disable_3d_apis";
1026 const char kEnableDeprecatedWebPlatformFeatures[] =
1027 "enable_deprecated_web_platform_features";
1029 // Whether to enable hyperlink auditing ("<a ping>").
1030 const char kEnableHyperlinkAuditing[] = "enable_a_ping";
1032 // Whether to enable sending referrers.
1033 const char kEnableReferrers[] = "enable_referrers";
1035 // Whether to send the DNT header.
1036 const char kEnableDoNotTrack[] = "enable_do_not_track";
1038 // GL_VENDOR string.
1039 const char kGLVendorString[] = "gl_vendor_string";
1041 // GL_RENDERER string.
1042 const char kGLRendererString[] = "gl_renderer_string";
1044 // GL_VERSION string.
1045 const char kGLVersionString[] = "gl_version_string";
1047 // Boolean that specifies whether to import the form data for autofill from the
1048 // default browser on first run.
1049 const char kImportAutofillFormData[] = "import_autofill_form_data";
1051 // Boolean that specifies whether to import bookmarks from the default browser
1052 // on first run.
1053 const char kImportBookmarks[] = "import_bookmarks";
1055 // Boolean that specifies whether to import the browsing history from the
1056 // default browser on first run.
1057 const char kImportHistory[] = "import_history";
1059 // Boolean that specifies whether to import the homepage from the default
1060 // browser on first run.
1061 const char kImportHomepage[] = "import_home_page";
1063 // Boolean that specifies whether to import the saved passwords from the default
1064 // browser on first run.
1065 const char kImportSavedPasswords[] = "import_saved_passwords";
1067 // Boolean that specifies whether to import the search engine from the default
1068 // browser on first run.
1069 const char kImportSearchEngine[] = "import_search_engine";
1071 // Profile avatar and name
1072 const char kProfileAvatarIndex[] = "profile.avatar_index";
1073 const char kProfileName[] = "profile.name";
1074 // Whether a profile is using a default avatar name (eg. Pickles or Person 1)
1075 // because it was randomly assigned at profile creation time.
1076 const char kProfileUsingDefaultName[] = "profile.using_default_name";
1077 // Whether a profile is using an avatar without having explicitely chosen it
1078 // (i.e. was assigned by default by legacy profile creation).
1079 const char kProfileUsingDefaultAvatar[] = "profile.using_default_avatar";
1080 const char kProfileUsingGAIAAvatar[] = "profile.using_gaia_avatar";
1082 // The supervised user ID.
1083 const char kSupervisedUserId[] = "profile.managed_user_id";
1085 // 64-bit integer serialization of the base::Time when the user's GAIA info
1086 // was last updated.
1087 const char kProfileGAIAInfoUpdateTime[] = "profile.gaia_info_update_time";
1089 // The URL from which the GAIA profile picture was downloaded. This is cached to
1090 // prevent the same picture from being downloaded multiple times.
1091 const char kProfileGAIAInfoPictureURL[] = "profile.gaia_info_picture_url";
1093 // Integer that specifies the number of times that we have shown the upgrade
1094 // tutorial card in the avatar menu bubble.
1095 const char kProfileAvatarTutorialShown[] =
1096 "profile.avatar_bubble_tutorial_shown";
1098 // Boolean that specifies if the user has already dismissed the right-click user
1099 // switching tutorial.
1100 const char kProfileAvatarRightClickTutorialDismissed[] =
1101 "profile.avatar_bubble_right_click_tutorial_dismissed";
1103 // Indicates if we've already shown a notification that high contrast
1104 // mode is on, recommending high-contrast extensions and themes.
1105 const char kInvertNotificationShown[] = "invert_notification_version_2_shown";
1107 // Boolean controlling whether printing is enabled.
1108 const char kPrintingEnabled[] = "printing.enabled";
1110 // Boolean controlling whether print preview is disabled.
1111 const char kPrintPreviewDisabled[] = "printing.print_preview_disabled";
1113 // An integer pref specifying the fallback behavior for sites outside of content
1114 // packs. One of:
1115 // 0: Allow (does nothing)
1116 // 1: Warn.
1117 // 2: Block.
1118 const char kDefaultSupervisedUserFilteringBehavior[] =
1119 "profile.managed.default_filtering_behavior";
1121 // Whether this user is permitted to create supervised users.
1122 const char kSupervisedUserCreationAllowed[] =
1123 "profile.managed_user_creation_allowed";
1125 // List pref containing the users supervised by this user.
1126 const char kSupervisedUsers[] = "profile.managed_users";
1128 // String that indicates that the profile reset prompt has already been shown to
1129 // the user (profile).
1130 const char kProfileResetPromptMementoInProfilePrefs[] =
1131 "profile.reset_prompt_memento";
1133 // List pref containing the extension ids which are not allowed to send
1134 // notifications to the message center.
1135 const char kMessageCenterDisabledExtensionIds[] =
1136 "message_center.disabled_extension_ids";
1138 // List pref containing the system component ids which are not allowed to send
1139 // notifications to the message center.
1140 const char kMessageCenterDisabledSystemComponentIds[] =
1141 "message_center.disabled_system_component_ids";
1143 // Boolean pref indicating the Chrome Now welcome notification was dismissed
1144 // by the user. Syncable.
1145 // Note: This is now read-only. The welcome notification writes the _local
1146 // version, below.
1147 const char kWelcomeNotificationDismissed[] =
1148 "message_center.welcome_notification_dismissed";
1150 // Boolean pref indicating the Chrome Now welcome notification was dismissed
1151 // by the user on this machine.
1152 const char kWelcomeNotificationDismissedLocal[] =
1153 "message_center.welcome_notification_dismissed_local";
1155 // Boolean pref indicating the welcome notification was previously popped up.
1156 const char kWelcomeNotificationPreviouslyPoppedUp[] =
1157 "message_center.welcome_notification_previously_popped_up";
1159 // Integer pref containing the expiration timestamp of the welcome notification.
1160 const char kWelcomeNotificationExpirationTimestamp[] =
1161 "message_center.welcome_notification_expiration_timestamp";
1163 // Boolean pref that determines whether the user can enter fullscreen mode.
1164 // Disabling fullscreen mode also makes kiosk mode unavailable on desktop
1165 // platforms.
1166 const char kFullscreenAllowed[] = "fullscreen.allowed";
1168 // Enable notifications for new devices on the local network that can be
1169 // registered to the user's account, e.g. Google Cloud Print printers.
1170 const char kLocalDiscoveryNotificationsEnabled[] =
1171 "local_discovery.notifications_enabled";
1173 // A timestamp (stored in base::Time::ToInternalValue format) of the last time
1174 // a preference was reset.
1175 const char kPreferenceResetTime[] = "prefs.preference_reset_time";
1177 // How many Service Workers are registered with the Push API (could be zero).
1178 const char kPushMessagingRegistrationCount[] =
1179 "gcm.push_messaging_registration_count";
1181 // Maps from app ids to origin + Service Worker registration ID.
1182 const char kPushMessagingAppIdentifierMap[] =
1183 "gcm.push_messaging_application_id_map";
1185 // Whether a user is allowed to use Easy Unlock.
1186 const char kEasyUnlockAllowed[] = "easy_unlock.allowed";
1188 // Whether Easy Unlock is enabled.
1189 const char kEasyUnlockEnabled[] = "easy_unlock.enabled";
1191 // Preference storing Easy Unlock pairing data.
1192 const char kEasyUnlockPairing[] = "easy_unlock.pairing";
1194 // Whether close proximity between the remote and the local device is required
1195 // in order to use Easy Unlock.
1196 const char kEasyUnlockProximityRequired[] = "easy_unlock.proximity_required";
1198 #if defined(ENABLE_EXTENSIONS) && !defined(OS_ANDROID) && !defined(OS_IOS)
1199 // These device IDs are used by the copresence component, to uniquely identify
1200 // this device to the server. For privacy, authenticated and unauthenticated
1201 // calls are made using different device IDs.
1202 const char kCopresenceAuthenticatedDeviceId[] =
1203 "apps.copresence.auth_device_id";
1204 const char kCopresenceAnonymousDeviceId[] = "apps.copresence.unauth_device_id";
1206 // Used to indicate whether or not the toolbar redesign bubble has been shown
1207 // and acknowledged, and the last time the bubble was shown.
1208 const char kToolbarIconSurfacingBubbleAcknowledged[] =
1209 "toolbar_icon_surfacing_bubble_acknowledged";
1210 const char kToolbarIconSurfacingBubbleLastShowTime[] =
1211 "toolbar_icon_surfacing_bubble_show_time";
1212 #endif
1214 // Whether WebRTC should bind to individual NICs to explore all possible routing
1215 // options. Default is true.
1216 #if defined(ENABLE_WEBRTC)
1217 const char kWebRTCMultipleRoutesEnabled[] = "webrtc.multiple_routes_enabled";
1218 #endif
1220 // *************** LOCAL STATE ***************
1221 // These are attached to the machine/installation
1223 // A pref to configure networks device-wide. Its value must be a list of
1224 // NetworkConfigurations according to the OpenNetworkConfiguration
1225 // specification.
1226 // Currently, this pref is only used to store the policy. The user's
1227 // configuration is still stored in Shill.
1228 const char kDeviceOpenNetworkConfiguration[] = "device_onc";
1230 // Directory of the last profile used.
1231 const char kProfileLastUsed[] = "profile.last_used";
1233 // List of directories of the profiles last active.
1234 const char kProfilesLastActive[] = "profile.last_active_profiles";
1236 // Total number of profiles created for this Chrome build. Used to tag profile
1237 // directories.
1238 const char kProfilesNumCreated[] = "profile.profiles_created";
1240 // String containing the version of Chrome that the profile was created by.
1241 // If profile was created before this feature was added, this pref will default
1242 // to "1.0.0.0".
1243 const char kProfileCreatedByVersion[] = "profile.created_by_version";
1245 // A map of profile data directory to cached information. This cache can be
1246 // used to display information about profiles without actually having to load
1247 // them.
1248 const char kProfileInfoCache[] = "profile.info_cache";
1250 // Dictionary that maps profile keys to strings that indicate that the profile
1251 // reset prompt has already been shown to the corresponding user (profile).
1252 // This is semantically similar to kProfileResetPromptMementoInProfilePrefs, see
1253 // chrome/browser/profile_resetter/automatic_profile_resetter_mementos.h for an
1254 // explanation of why this redundancy is needed.
1255 const char kProfileResetPromptMementosInLocalState[] =
1256 "profile.reset_prompt_mementos";
1258 // Prefs for SSLConfigServicePref.
1259 const char kCertRevocationCheckingEnabled[] = "ssl.rev_checking.enabled";
1260 const char kCertRevocationCheckingRequiredLocalAnchors[] =
1261 "ssl.rev_checking.required_for_local_anchors";
1262 const char kSSLVersionMin[] = "ssl.version_min";
1263 const char kSSLVersionMax[] = "ssl.version_max";
1264 const char kSSLVersionFallbackMin[] = "ssl.version_fallback_min";
1265 const char kCipherSuiteBlacklist[] = "ssl.cipher_suites.blacklist";
1266 const char kDisableSSLRecordSplitting[] = "ssl.ssl_record_splitting.disabled";
1268 // Boolean that specifies whether or not crash reporting and metrics reporting
1269 // are sent over the network for analysis.
1270 const char kMetricsReportingEnabled[] =
1271 "user_experience_metrics.reporting_enabled";
1273 // Boolean that specifies whether or not crash reports are sent
1274 // over the network for analysis.
1275 #if defined(OS_ANDROID)
1276 const char kCrashReportingEnabled[] =
1277 "user_experience_metrics_crash.reporting_enabled";
1278 #endif
1280 // Base64-encoded compressed serialized form of the variations seed protobuf.
1281 const char kVariationsCompressedSeed[] = "variations_compressed_seed";
1283 // 64-bit integer serialization of the base::Time from the last successful seed
1284 // fetch (i.e. when the Variations server responds with 200 or 304).
1285 const char kVariationsLastFetchTime[] = "variations_last_fetch_time";
1287 // Pair of <Chrome version string, country code string> representing the country
1288 // used for filtering permanent consistency studies until the next time Chrome
1289 // is updated.
1290 const char kVariationsPermanentConsistencyCountry[] =
1291 "variations_permanent_consistency_country";
1293 // String for the restrict parameter to be appended to the variations URL.
1294 const char kVariationsRestrictParameter[] = "variations_restrict_parameter";
1296 // Base64-encoded serialized form of the variations seed protobuf.
1297 const char kVariationsSeed[] = "variations_seed";
1299 // 64-bit integer serialization of the base::Time from the last seed received.
1300 const char kVariationsSeedDate[] = "variations_seed_date";
1302 // Digital signature of the binary variations seed data, base64-encoded.
1303 const char kVariationsSeedSignature[] = "variations_seed_signature";
1305 // Number of times a page load event occurred since the last report.
1306 const char kStabilityPageLoadCount[] =
1307 "user_experience_metrics.stability.page_load_count";
1309 // Number of times a renderer process crashed since the last report.
1310 const char kStabilityRendererCrashCount[] =
1311 "user_experience_metrics.stability.renderer_crash_count";
1313 // Number of times an extension renderer process crashed since the last report.
1314 const char kStabilityExtensionRendererCrashCount[] =
1315 "user_experience_metrics.stability.extension_renderer_crash_count";
1317 // This is the location of a list of dictionaries of plugin stability stats.
1318 const char kStabilityPluginStats[] =
1319 "user_experience_metrics.stability.plugin_stats2";
1321 // Number of times the renderer has become non-responsive since the last
1322 // report.
1323 const char kStabilityRendererHangCount[] =
1324 "user_experience_metrics.stability.renderer_hang_count";
1326 // Total number of child process crashes (other than renderer / extension
1327 // renderer ones, and plugin children, which are counted separately) since the
1328 // last report.
1329 const char kStabilityChildProcessCrashCount[] =
1330 "user_experience_metrics.stability.child_process_crash_count";
1332 // On Chrome OS, total number of non-Chrome user process crashes
1333 // since the last report.
1334 const char kStabilityOtherUserCrashCount[] =
1335 "user_experience_metrics.stability.other_user_crash_count";
1337 // On Chrome OS, total number of kernel crashes since the last report.
1338 const char kStabilityKernelCrashCount[] =
1339 "user_experience_metrics.stability.kernel_crash_count";
1341 // On Chrome OS, total number of unclean system shutdowns since the
1342 // last report.
1343 const char kStabilitySystemUncleanShutdownCount[] =
1344 "user_experience_metrics.stability.system_unclean_shutdowns";
1346 #if defined(OS_ANDROID)
1347 // Activity type that is currently in the foreground for the UMA session.
1348 // Uses the ActivityTypeIds::Type enum.
1349 const char kStabilityForegroundActivityType[] =
1350 "user_experience_metrics.stability.current_foreground_activity_type";
1352 // Tracks which Activities were launched during the last session.
1353 // See |metrics_service_android.cc| for its usage.
1354 const char kStabilityLaunchedActivityFlags[] =
1355 "user_experience_metrics.stability.launched_activity_flags";
1357 // List pref: Counts how many times each Activity was launched.
1358 // Indexed into by ActivityTypeIds::Type.
1359 const char kStabilityLaunchedActivityCounts[] =
1360 "user_experience_metrics.stability.launched_activity_counts";
1362 // List pref: Counts how many times each Activity type was in the foreground
1363 // when a UMA session failed to be shut down properly.
1364 // Indexed into by ActivityTypeIds::Type.
1365 const char kStabilityCrashedActivityCounts[] =
1366 "user_experience_metrics.stability.crashed_activity_counts";
1367 #endif
1369 // The keys below are used for the dictionaries in the
1370 // kStabilityPluginStats list.
1371 const char kStabilityPluginName[] = "name";
1372 const char kStabilityPluginLaunches[] = "launches";
1373 const char kStabilityPluginInstances[] = "instances";
1374 const char kStabilityPluginCrashes[] = "crashes";
1375 const char kStabilityPluginLoadingErrors[] = "loading_errors";
1377 // The keys below are strictly increasing counters over the lifetime of
1378 // a chrome installation. They are (optionally) sent up to the uninstall
1379 // survey in the event of uninstallation.
1380 const char kUninstallMetricsPageLoadCount[] =
1381 "uninstall_metrics.page_load_count";
1382 const char kUninstallLastLaunchTimeSec[] =
1383 "uninstall_metrics.last_launch_time_sec";
1384 const char kUninstallLastObservedRunTimeSec[] =
1385 "uninstall_metrics.last_observed_running_time_sec";
1387 // String containing the version of Chrome for which Chrome will not prompt the
1388 // user about setting Chrome as the default browser.
1389 const char kBrowserSuppressDefaultBrowserPrompt[] =
1390 "browser.suppress_default_browser_prompt_for_version";
1392 // A collection of position, size, and other data relating to the browser
1393 // window to restore on startup.
1394 const char kBrowserWindowPlacement[] = "browser.window_placement";
1396 // Browser window placement for popup windows.
1397 const char kBrowserWindowPlacementPopup[] = "browser.window_placement_popup";
1399 // A collection of position, size, and other data relating to the task
1400 // manager window to restore on startup.
1401 const char kTaskManagerWindowPlacement[] = "task_manager.window_placement";
1403 // A collection of position, size, and other data relating to app windows to
1404 // restore on startup.
1405 const char kAppWindowPlacement[] = "browser.app_window_placement";
1407 // String which specifies where to download files to by default.
1408 const char kDownloadDefaultDirectory[] = "download.default_directory";
1410 // Boolean that records if the download directory was changed by an
1411 // upgrade a unsafe location to a safe location.
1412 const char kDownloadDirUpgraded[] = "download.directory_upgrade";
1414 #if defined(OS_WIN) || defined(OS_LINUX) || \
1415 (defined(OS_MACOSX) && !defined(OS_IOS))
1416 const char kOpenPdfDownloadInSystemReader[] =
1417 "download.open_pdf_in_system_reader";
1418 #endif
1420 // String which specifies where to save html files to by default.
1421 const char kSaveFileDefaultDirectory[] = "savefile.default_directory";
1423 // The type used to save the page. See the enum SavePackage::SavePackageType in
1424 // the chrome/browser/download/save_package.h for the possible values.
1425 const char kSaveFileType[] = "savefile.type";
1427 // String which specifies the last directory that was chosen for uploading
1428 // or opening a file.
1429 const char kSelectFileLastDirectory[] = "selectfile.last_directory";
1431 // Boolean that specifies if file selection dialogs are shown.
1432 const char kAllowFileSelectionDialogs[] = "select_file_dialogs.allowed";
1434 // Map of default tasks, associated by MIME type.
1435 const char kDefaultTasksByMimeType[] =
1436 "filebrowser.tasks.default_by_mime_type";
1438 // Map of default tasks, associated by file suffix.
1439 const char kDefaultTasksBySuffix[] =
1440 "filebrowser.tasks.default_by_suffix";
1442 // Extensions which should be opened upon completion.
1443 const char kDownloadExtensionsToOpen[] = "download.extensions_to_open";
1445 // Integer which specifies the frequency in milliseconds for detecting whether
1446 // plugin windows are hung.
1447 const char kHungPluginDetectFrequency[] = "browser.hung_plugin_detect_freq";
1449 // Integer which specifies the timeout value to be used for SendMessageTimeout
1450 // to detect a hung plugin window.
1451 const char kPluginMessageResponseTimeout[] =
1452 "browser.plugin_message_response_timeout";
1454 // String which represents the dictionary name for our spell-checker.
1455 // This is an old preference that is being migrated to kSpellCheckDictionaries.
1456 const char kSpellCheckDictionary[] = "spellcheck.dictionary";
1458 // List of strings representing the dictionary names for our spell-checker.
1459 const char kSpellCheckDictionaries[] = "spellcheck.dictionaries";
1461 // String which represents whether we use the spelling service.
1462 const char kSpellCheckUseSpellingService[] = "spellcheck.use_spelling_service";
1464 // Dictionary of schemes used by the external protocol handler.
1465 // The value is true if the scheme must be ignored.
1466 const char kExcludedSchemes[] = "protocol_handler.excluded_schemes";
1468 // Integer that specifies the index of the tab the user was on when they
1469 // last visited the options window.
1470 const char kOptionsWindowLastTabIndex[] = "options_window.last_tab_index";
1472 // Integer that specifies if the first run bubble should be shown.
1473 // This preference is only registered by the first-run procedure.
1474 const char kShowFirstRunBubbleOption[] = "show-first-run-bubble-option";
1476 // String containing the last known intranet redirect URL, if any. See
1477 // intranet_redirect_detector.h for more information.
1478 const char kLastKnownIntranetRedirectOrigin[] = "browser.last_redirect_origin";
1480 // An enum value of how the browser was shut down (see browser_shutdown.h).
1481 const char kShutdownType[] = "shutdown.type";
1482 // Number of processes that were open when the user shut down.
1483 const char kShutdownNumProcesses[] = "shutdown.num_processes";
1484 // Number of processes that were shut down using the slow path.
1485 const char kShutdownNumProcessesSlow[] = "shutdown.num_processes_slow";
1487 // Whether to restart the current Chrome session automatically as the last thing
1488 // before shutting everything down.
1489 const char kRestartLastSessionOnShutdown[] = "restart.last.session.on.shutdown";
1491 // Set before autorestarting Chrome, cleared on clean exit.
1492 const char kWasRestarted[] = "was.restarted";
1494 #if defined(OS_WIN)
1495 // Preference to be used while relaunching Chrome. This preference dictates if
1496 // Chrome should be launched in Metro or Desktop mode.
1497 // For more info take a look at ChromeRelaunchMode enum.
1498 const char kRelaunchMode[] = "relaunch.mode";
1499 #endif
1501 // Whether Extensions are enabled.
1502 const char kDisableExtensions[] = "extensions.disabled";
1504 // Whether the plugin finder that lets you install missing plugins is enabled.
1505 const char kDisablePluginFinder[] = "plugins.disable_plugin_finder";
1507 // Customized app page names that appear on the New Tab Page.
1508 const char kNtpAppPageNames[] = "ntp.app_page_names";
1510 #if defined(OS_ANDROID)
1511 // Keeps track of currently open tabs collapsed state in the Other Devices menu.
1512 const char kNtpCollapsedCurrentlyOpenTabs[] = "ntp.collapsed_open_tabs";
1513 #endif
1515 // Keeps track of which sessions are collapsed in the Other Devices menu.
1516 const char kNtpCollapsedForeignSessions[] = "ntp.collapsed_foreign_sessions";
1518 #if defined(OS_ANDROID)
1519 // Keeps track of recently closed tabs collapsed state in the Other Devices
1520 // menu.
1521 const char kNtpCollapsedRecentlyClosedTabs[] =
1522 "ntp.collapsed_recently_closed_tabs";
1524 // Keeps track of snapshot documents collapsed state in the Other Devices menu.
1525 const char kNtpCollapsedSnapshotDocument[] = "ntp.collapsed_snapshot_document";
1527 // Keeps track of sync promo collapsed state in the Other Devices menu.
1528 const char kNtpCollapsedSyncPromo[] = "ntp.collapsed_sync_promo";
1529 #endif
1531 // Which page should be visible on the new tab page v4
1532 const char kNtpShownPage[] = "ntp.shown_page";
1534 // A private RSA key for ADB handshake.
1535 const char kDevToolsAdbKey[] = "devtools.adb_key";
1537 const char kDevToolsDisabled[] = "devtools.disabled";
1539 // Determines whether devtools should be discovering usb devices for
1540 // remote debugging at chrome://inspect.
1541 const char kDevToolsDiscoverUsbDevicesEnabled[] =
1542 "devtools.discover_usb_devices";
1544 // Maps of files edited locally using DevTools.
1545 const char kDevToolsEditedFiles[] = "devtools.edited_files";
1547 // List of file system paths added in DevTools.
1548 const char kDevToolsFileSystemPaths[] = "devtools.file_system_paths";
1550 // A boolean specifying whether port forwarding should be enabled.
1551 const char kDevToolsPortForwardingEnabled[] =
1552 "devtools.port_forwarding_enabled";
1554 // A boolean specifying whether default port forwarding configuration has been
1555 // set.
1556 const char kDevToolsPortForwardingDefaultSet[] =
1557 "devtools.port_forwarding_default_set";
1559 // A dictionary of port->location pairs for port forwarding.
1560 const char kDevToolsPortForwardingConfig[] = "devtools.port_forwarding_config";
1562 // A dictionary with generic DevTools settings.
1563 const char kDevToolsPreferences[] = "devtools.preferences";
1565 #if defined(OS_ANDROID)
1566 // A boolean specifying whether remote dev tools debugging is enabled.
1567 const char kDevToolsRemoteEnabled[] = "devtools.remote_enabled";
1568 #endif
1570 // Boolean indicating that TiclInvalidationService should use GCM channel.
1571 // False or lack of settings means XMPPPushClient channel.
1572 const char kInvalidationServiceUseGCMChannel[] =
1573 "invalidation_service.use_gcm_channel";
1575 // Local hash of authentication password, used for off-line authentication
1576 // when on-line authentication is not available.
1577 const char kGoogleServicesPasswordHash[] = "google.services.password_hash";
1579 #if !defined(OS_ANDROID) && !defined(OS_IOS)
1580 // Tracks the number of times that we have shown the sign in promo at startup.
1581 const char kSignInPromoStartupCount[] = "sync_promo.startup_count";
1583 // Boolean tracking whether the user chose to skip the sign in promo.
1584 const char kSignInPromoUserSkipped[] = "sync_promo.user_skipped";
1586 // Boolean that specifies if the sign in promo is allowed to show on first run.
1587 // This preference is specified in the master preference file to suppress the
1588 // sign in promo for some installations.
1589 const char kSignInPromoShowOnFirstRunAllowed[] =
1590 "sync_promo.show_on_first_run_allowed";
1592 // Boolean that specifies if we should show a bubble in the new tab page.
1593 // The bubble is used to confirm that the user is signed into sync.
1594 const char kSignInPromoShowNTPBubble[] = "sync_promo.show_ntp_bubble";
1595 #endif
1597 #if !defined(OS_CHROMEOS) && !defined(OS_ANDROID) && !defined(OS_IOS)
1598 // Boolean tracking whether the user chose to opt out of the x-device promo.
1599 const char kCrossDevicePromoOptedOut[] = "x_device_promo.opted_out";
1601 // Boolean tracking whether the x-device promo should be shown.
1602 const char kCrossDevicePromoShouldBeShown[] = "x_device_promo.should_be_shown";
1604 // Int64, representing the time when we first observed a single GAIA account in
1605 // the cookie. If the most recent observation does not contain exactly one
1606 // account, this pref does not exist.
1607 const char kCrossDevicePromoObservedSingleAccountCookie[] =
1608 "x_device_promo.single_account_observed";
1610 // Int64, representing the time to next call the ListDevices endpoint.
1611 const char kCrossDevicePromoNextFetchListDevicesTime[] =
1612 "x_device_promo.next_list_devices_fetch";
1614 // Int containing the number of other devices where the profile's account syncs.
1615 const char kCrossDevicePromoNumDevices[] = "x_device_promo.num_devices";
1617 // Int64, representing the time when we last saw activity on another device.
1618 const char kCrossDevicePromoLastDeviceActiveTime[] =
1619 "x_device_promo.last_device_active_time";
1620 #endif
1622 // Create web application shortcut dialog preferences.
1623 const char kWebAppCreateOnDesktop[] = "browser.web_app.create_on_desktop";
1624 const char kWebAppCreateInAppsMenu[] = "browser.web_app.create_in_apps_menu";
1625 const char kWebAppCreateInQuickLaunchBar[] =
1626 "browser.web_app.create_in_quick_launch_bar";
1628 // Dictionary that maps Geolocation network provider server URLs to
1629 // corresponding access token.
1630 const char kGeolocationAccessToken[] = "geolocation.access_token";
1632 #if defined(OS_ANDROID)
1633 // Boolean that controls the enabled-state of Geolocation in content.
1634 const char kGeolocationEnabled[] = "geolocation.enabled";
1635 #endif
1637 #if defined(ENABLE_GOOGLE_NOW)
1638 // Boolean that is true when Google services can use the user's location.
1639 const char kGoogleGeolocationAccessEnabled[] =
1640 "googlegeolocationaccess.enabled";
1641 #endif
1643 // Boolean that specifies whether to enable the Google Now Launcher extension.
1644 // Note: This is not the notifications component gated by ENABLE_GOOGLE_NOW.
1645 const char kGoogleNowLauncherEnabled[] = "google_now_launcher.enabled";
1647 // The default audio capture device used by the Media content setting.
1648 const char kDefaultAudioCaptureDevice[] = "media.default_audio_capture_device";
1650 // The default video capture device used by the Media content setting.
1651 const char kDefaultVideoCaptureDevice[] = "media.default_video_capture_Device";
1653 // The salt used for creating random MediaSource IDs.
1654 const char kMediaDeviceIdSalt[] = "media.device_id_salt";
1656 // The last used printer and its settings.
1657 const char kPrintPreviewStickySettings[] =
1658 "printing.print_preview_sticky_settings";
1660 // The list of BackgroundContents that should be loaded when the browser
1661 // launches.
1662 const char kRegisteredBackgroundContents[] = "background_contents.registered";
1664 #if defined(OS_WIN)
1665 // An int that stores how often we've shown the "Chrome is configured to
1666 // auto-launch" infobar.
1667 const char kShownAutoLaunchInfobar[] = "browser.shown_autolaunch_infobar";
1668 #endif
1670 // String that lists supported HTTP authentication schemes.
1671 const char kAuthSchemes[] = "auth.schemes";
1673 // Boolean that specifies whether to disable CNAME lookups when generating
1674 // Kerberos SPN.
1675 const char kDisableAuthNegotiateCnameLookup[] =
1676 "auth.disable_negotiate_cname_lookup";
1678 // Boolean that specifies whether to include the port in a generated Kerberos
1679 // SPN.
1680 const char kEnableAuthNegotiatePort[] = "auth.enable_negotiate_port";
1682 // Whitelist containing servers for which Integrated Authentication is enabled.
1683 const char kAuthServerWhitelist[] = "auth.server_whitelist";
1685 // Whitelist containing servers Chrome is allowed to do Kerberos delegation
1686 // with.
1687 const char kAuthNegotiateDelegateWhitelist[] =
1688 "auth.negotiate_delegate_whitelist";
1690 // String that specifies the name of a custom GSSAPI library to load.
1691 const char kGSSAPILibraryName[] = "auth.gssapi_library_name";
1693 // Boolean that specifies whether to allow basic auth prompting on cross-
1694 // domain sub-content requests.
1695 const char kAllowCrossOriginAuthPrompt[] = "auth.allow_cross_origin_prompt";
1697 // Boolean that specifies whether the built-in asynchronous DNS client is used.
1698 const char kBuiltInDnsClientEnabled[] = "async_dns.enabled";
1700 // A pref holding the value of the policy used to explicitly allow or deny
1701 // access to audio capture devices. When enabled or not set, the user is
1702 // prompted for device access. When disabled, access to audio capture devices
1703 // is not allowed and no prompt will be shown.
1704 // See also kAudioCaptureAllowedUrls.
1705 const char kAudioCaptureAllowed[] = "hardware.audio_capture_enabled";
1706 // Holds URL patterns that specify URLs that will be granted access to audio
1707 // capture devices without prompt. NOTE: This whitelist is currently only
1708 // supported when running in kiosk mode.
1709 // TODO(tommi): Update comment when this is supported for all modes.
1710 const char kAudioCaptureAllowedUrls[] = "hardware.audio_capture_allowed_urls";
1712 // A pref holding the value of the policy used to explicitly allow or deny
1713 // access to video capture devices. When enabled or not set, the user is
1714 // prompted for device access. When disabled, access to video capture devices
1715 // is not allowed and no prompt will be shown.
1716 const char kVideoCaptureAllowed[] = "hardware.video_capture_enabled";
1717 // Holds URL patterns that specify URLs that will be granted access to video
1718 // capture devices without prompt. NOTE: This whitelist is currently only
1719 // supported when running in kiosk mode.
1720 // TODO(tommi): Update comment when this is supported for all modes.
1721 const char kVideoCaptureAllowedUrls[] = "hardware.video_capture_allowed_urls";
1723 // A boolean pref that controls the enabled-state of hotword search voice
1724 // trigger.
1725 const char kHotwordSearchEnabled[] = "hotword.search_enabled_2";
1727 // A boolean pref that controls the enabled-state of hotword search voice
1728 // trigger from any screen.
1729 const char kHotwordAlwaysOnSearchEnabled[] = "hotword.always_on_search_enabled";
1731 // A boolean pref that indicates whether the hotword always-on notification
1732 // has been seen already.
1733 const char kHotwordAlwaysOnNotificationSeen[] =
1734 "hotword.always_on_notification_seen";
1736 // A boolean pref that controls whether the sound of "Ok, Google" plus a few
1737 // seconds of audio data before and the spoken query are sent back to be stored
1738 // in a user's Voice & Audio Activity. Updated whenever the user opens
1739 // chrome://settings and also polled for every 24 hours.
1740 const char kHotwordAudioLoggingEnabled[] = "hotword.audio_logging_enabled";
1742 // A string holding the locale information under which Hotword was installed.
1743 // It is used for comparison since the hotword voice search trigger must be
1744 // reinstalled to handle a new language.
1745 const char kHotwordPreviousLanguage[] = "hotword.previous_language";
1747 #if defined(OS_ANDROID)
1748 // Boolean that controls the global enabled-state of protected media identifier.
1749 const char kProtectedMediaIdentifierEnabled[] =
1750 "protected_media_identifier.enabled";
1751 #endif
1753 #if defined(OS_CHROMEOS)
1754 // Dictionary for transient storage of settings that should go into device
1755 // settings storage before owner has been assigned.
1756 const char kDeviceSettingsCache[] = "signed_settings_cache";
1758 // The hardware keyboard layout of the device. This should look like
1759 // "xkb:us::eng".
1760 const char kHardwareKeyboardLayout[] = "intl.hardware_keyboard";
1762 // An integer pref which shows number of times carrier deal promo
1763 // notification has been shown to user.
1764 const char kCarrierDealPromoShown[] =
1765 "settings.internet.mobile.carrier_deal_promo_shown";
1767 // A boolean pref of the auto-enrollment decision. Its value is only valid if
1768 // it's not the default value; otherwise, no auto-enrollment decision has been
1769 // made yet.
1770 const char kShouldAutoEnroll[] = "ShouldAutoEnroll";
1772 // An integer pref with the maximum number of bits used by the client in a
1773 // previous auto-enrollment request. If the client goes through an auto update
1774 // during OOBE and reboots into a version of the OS with a larger maximum
1775 // modulus, then it will retry auto-enrollment using the updated value.
1776 const char kAutoEnrollmentPowerLimit[] = "AutoEnrollmentPowerLimit";
1778 // The local state pref that stores device activity times before reporting
1779 // them to the policy server.
1780 const char kDeviceActivityTimes[] = "device_status.activity_times";
1782 // A pref holding the last known location when device location reporting is
1783 // enabled.
1784 const char kDeviceLocation[] = "device_status.location";
1786 // A pref holding the value of the policy used to disable mounting of external
1787 // storage for the user.
1788 const char kExternalStorageDisabled[] = "hardware.external_storage_disabled";
1790 // Copy of owner swap mouse buttons option to use on login screen.
1791 const char kOwnerPrimaryMouseButtonRight[] = "owner.mouse.primary_right";
1793 // Copy of owner tap-to-click option to use on login screen.
1794 const char kOwnerTapToClickEnabled[] = "owner.touchpad.enable_tap_to_click";
1796 // The length of device uptime after which an automatic reboot is scheduled,
1797 // expressed in seconds.
1798 const char kUptimeLimit[] = "automatic_reboot.uptime_limit";
1800 // Whether an automatic reboot should be scheduled when an update has been
1801 // applied and a reboot is required to complete the update process.
1802 const char kRebootAfterUpdate[] = "automatic_reboot.reboot_after_update";
1804 // An any-api scoped refresh token for enterprise-enrolled devices. Allows
1805 // for connection to Google APIs when the user isn't logged in. Currently used
1806 // for for getting a cloudprint scoped token to allow printing in Guest mode,
1807 // Public Accounts and kiosks.
1808 const char kDeviceRobotAnyApiRefreshToken[] =
1809 "device_robot_refresh_token.any-api";
1811 // Device requisition for enterprise enrollment.
1812 const char kDeviceEnrollmentRequisition[] = "enrollment.device_requisition";
1814 // Whether to automatically start the enterprise enrollment step during OOBE.
1815 const char kDeviceEnrollmentAutoStart[] = "enrollment.auto_start";
1817 // Whether the user may exit enrollment.
1818 const char kDeviceEnrollmentCanExit[] = "enrollment.can_exit";
1820 // How many times HID detection OOBE dialog was shown.
1821 const char kTimesHIDDialogShown[] = "HIDDialog.shown_how_many_times";
1823 // Dictionary of per-user Least Recently Used input method (used at login
1824 // screen).
1825 const char kUsersLRUInputMethod[] = "UsersLRUInputMethod";
1827 // A dictionary pref of the echo offer check flag. It sets offer info when
1828 // an offer is checked.
1829 const char kEchoCheckedOffers[] = "EchoCheckedOffers";
1831 // Key name of a dictionary in local state to store cached multiprofle user
1832 // behavior policy value.
1833 const char kCachedMultiProfileUserBehavior[] = "CachedMultiProfileUserBehavior";
1835 // A string pref with initial locale set in VPD or manifest.
1836 const char kInitialLocale[] = "intl.initial_locale";
1838 // A boolean pref of the OOBE complete flag (first OOBE part before login).
1839 const char kOobeComplete[] = "OobeComplete";
1841 // The name of the screen that has to be shown if OOBE has been interrupted.
1842 const char kOobeScreenPending[] = "OobeScreenPending";
1844 // A boolean pref of the device registered flag (second part after first login).
1845 const char kDeviceRegistered[] = "DeviceRegistered";
1847 // Boolean pref to signal corrupted enrollment to force the device through
1848 // enrollment recovery flow upon next boot.
1849 const char kEnrollmentRecoveryRequired[] = "EnrollmentRecoveryRequired";
1851 // List of usernames that used certificates pushed by policy before.
1852 // This is used to prevent these users from joining multiprofile sessions.
1853 const char kUsedPolicyCertificates[] = "policy.used_policy_certificates";
1855 // A dictionary containing server-provided device state pulled form the cloud
1856 // after recovery.
1857 const char kServerBackedDeviceState[] = "server_backed_device_state";
1859 // Customized wallpaper URL, which is already downloaded and scaled.
1860 // The URL from this preference must never be fetched. It is compared to the
1861 // URL from customization document to check if wallpaper URL has changed
1862 // since wallpaper was cached.
1863 const char kCustomizationDefaultWallpaperURL[] =
1864 "customization.default_wallpaper_url";
1866 // System uptime, when last logout started.
1867 // This is saved to file and cleared after chrome process starts.
1868 const char kLogoutStartedLast[] = "chromeos.logout-started";
1870 // An integer pref of the current consumer management stage. The meaning of the
1871 // value is defined in:
1872 // chrome/browser/chromeos/policy/consumer_management_stage.h
1873 const char kConsumerManagementStage[] = "consumer_management.stage";
1875 // A boolean pref. If set to true, experimental webview based signin flow
1876 // is deactivated.
1877 const char kWebviewSigninDisabled[] = "webview_signin_disabled";
1879 // A boolean pref. If set to true, then on the network screen we should display
1880 // whether the WebView-based sign-in flow is active.
1881 const char kNewLoginUIPopup[] = "new_login_ui_popup";
1882 #endif // defined(OS_CHROMEOS)
1884 // Whether there is a Flash version installed that supports clearing LSO data.
1885 const char kClearPluginLSODataEnabled[] = "browser.clear_lso_data_enabled";
1887 // Whether we should show Pepper Flash-specific settings.
1888 const char kPepperFlashSettingsEnabled[] =
1889 "browser.pepper_flash_settings_enabled";
1891 // String which specifies where to store the disk cache.
1892 const char kDiskCacheDir[] = "browser.disk_cache_dir";
1893 // Pref name for the policy specifying the maximal cache size.
1894 const char kDiskCacheSize[] = "browser.disk_cache_size";
1895 // Pref name for the policy specifying the maximal media cache size.
1896 const char kMediaCacheSize[] = "browser.media_cache_size";
1898 // Specifies the release channel that the device should be locked to.
1899 // Possible values: "stable-channel", "beta-channel", "dev-channel", or an
1900 // empty string, in which case the value will be ignored.
1901 // TODO(dubroy): This preference may not be necessary once
1902 // http://crosbug.com/17015 is implemented and the update engine can just
1903 // fetch the correct value from the policy.
1904 const char kChromeOsReleaseChannel[] = "cros.system.releaseChannel";
1906 const char kPerformanceTracingEnabled[] =
1907 "feedback.performance_tracing_enabled";
1909 // Boolean indicating whether tabstrip uses stacked layout (on touch devices).
1910 // Defaults to false.
1911 const char kTabStripStackedLayout[] = "tab-strip-stacked-layout";
1913 // Indicates that factory reset was requested from options page or reset screen.
1914 const char kFactoryResetRequested[] = "FactoryResetRequested";
1916 // Indicates that debugging features were requested from oobe screen.
1917 const char kDebuggingFeaturesRequested[] = "DebuggingFeaturesRequested";
1919 // Boolean recording whether we have showed a balloon that calls out the message
1920 // center for desktop notifications.
1921 const char kMessageCenterShowedFirstRunBalloon[] =
1922 "message_center.showed_first_run_balloon";
1924 // Boolean recording whether the user has disabled the notifications
1925 // menubar or systray icon.
1926 const char kMessageCenterShowIcon[] = "message_center.show_icon";
1928 const char kMessageCenterForcedOnTaskbar[] =
1929 "message_center.was_forced_on_taskbar";
1931 #if defined(OS_CHROMEOS)
1932 // This setting starts periodic timezone refresh when not in user session.
1933 // (user session is controlled by user profile preference
1934 // kResolveTimezoneByGeolocation
1935 const char kResolveDeviceTimezoneByGeolocation[] =
1936 "settings.resolve_device_timezone_by_geolocation";
1937 #endif // defined(OS_CHROMEOS)
1939 // *************** SERVICE PREFS ***************
1940 // These are attached to the service process.
1942 const char kCloudPrintRoot[] = "cloud_print";
1943 const char kCloudPrintProxyEnabled[] = "cloud_print.enabled";
1944 // The unique id for this instance of the cloud print proxy.
1945 const char kCloudPrintProxyId[] = "cloud_print.proxy_id";
1946 // The GAIA auth token for Cloud Print
1947 const char kCloudPrintAuthToken[] = "cloud_print.auth_token";
1948 // The email address of the account used to authenticate with the Cloud Print
1949 // server.
1950 const char kCloudPrintEmail[] = "cloud_print.email";
1951 // Settings specific to underlying print system.
1952 const char kCloudPrintPrintSystemSettings[] =
1953 "cloud_print.print_system_settings";
1954 // A boolean indicating whether we should poll for print jobs when don't have
1955 // an XMPP connection (false by default).
1956 const char kCloudPrintEnableJobPoll[] = "cloud_print.enable_job_poll";
1957 const char kCloudPrintRobotRefreshToken[] = "cloud_print.robot_refresh_token";
1958 const char kCloudPrintRobotEmail[] = "cloud_print.robot_email";
1959 // A boolean indicating whether we should connect to cloud print new printers.
1960 const char kCloudPrintConnectNewPrinters[] =
1961 "cloud_print.user_settings.connectNewPrinters";
1962 // A boolean indicating whether we should ping XMPP connection.
1963 const char kCloudPrintXmppPingEnabled[] = "cloud_print.xmpp_ping_enabled";
1964 // An int value indicating the average timeout between xmpp pings.
1965 const char kCloudPrintXmppPingTimeout[] = "cloud_print.xmpp_ping_timeout_sec";
1966 // Dictionary with settings stored by connector setup page.
1967 const char kCloudPrintUserSettings[] = "cloud_print.user_settings";
1968 // List of printers settings.
1969 const char kCloudPrintPrinters[] = "cloud_print.user_settings.printers";
1970 // A boolean indicating whether submitting jobs to Google Cloud Print is
1971 // blocked by policy.
1972 const char kCloudPrintSubmitEnabled[] = "cloud_print.submit_enabled";
1974 // Preference to store proxy settings.
1975 const char kProxy[] = "proxy";
1976 const char kMaxConnectionsPerProxy[] = "net.max_connections_per_proxy";
1978 #if defined(OS_MACOSX)
1979 // Set to true if the user removed our login item so we should not create a new
1980 // one when uninstalling background apps.
1981 const char kUserRemovedLoginItem[] = "background_mode.user_removed_login_item";
1983 // Set to true if Chrome already created a login item, so there's no need to
1984 // create another one.
1985 const char kChromeCreatedLoginItem[] =
1986 "background_mode.chrome_created_login_item";
1988 // Set to true once we've initialized kChromeCreatedLoginItem for the first
1989 // time.
1990 const char kMigratedLoginItemPref[] =
1991 "background_mode.migrated_login_item_pref";
1993 // A boolean that tracks whether to show a notification when trying to quit
1994 // while there are apps running.
1995 const char kNotifyWhenAppsKeepChromeAlive[] =
1996 "apps.notify-when-apps-keep-chrome-alive";
1997 #endif
1999 // Set to true if background mode is enabled on this browser.
2000 const char kBackgroundModeEnabled[] = "background_mode.enabled";
2002 // Set to true if hardware acceleration mode is enabled on this browser.
2003 const char kHardwareAccelerationModeEnabled[] =
2004 "hardware_acceleration_mode.enabled";
2006 // Hardware acceleration mode from previous browser launch.
2007 const char kHardwareAccelerationModePrevious[] =
2008 "hardware_acceleration_mode_previous";
2010 // List of protocol handlers.
2011 const char kRegisteredProtocolHandlers[] =
2012 "custom_handlers.registered_protocol_handlers";
2014 // List of protocol handlers the user has requested not to be asked about again.
2015 const char kIgnoredProtocolHandlers[] =
2016 "custom_handlers.ignored_protocol_handlers";
2018 // List of protocol handlers registered by policy.
2019 const char kPolicyRegisteredProtocolHandlers[] =
2020 "custom_handlers.policy.registered_protocol_handlers";
2022 // List of protocol handlers the policy has requested to be ignored.
2023 const char kPolicyIgnoredProtocolHandlers[] =
2024 "custom_handlers.policy.ignored_protocol_handlers";
2026 // Whether user-specified handlers for protocols and content types can be
2027 // specified.
2028 const char kCustomHandlersEnabled[] = "custom_handlers.enabled";
2030 // Integer that specifies the policy refresh rate for device-policy in
2031 // milliseconds. Not all values are meaningful, so it is clamped to a sane range
2032 // by the cloud policy subsystem.
2033 const char kDevicePolicyRefreshRate[] = "policy.device_refresh_rate";
2035 // A boolean where true means that the browser has previously attempted to
2036 // enable autoupdate and failed, so the next out-of-date browser start should
2037 // not prompt the user to enable autoupdate, it should offer to reinstall Chrome
2038 // instead.
2039 const char kAttemptedToEnableAutoupdate[] =
2040 "browser.attempted_to_enable_autoupdate";
2042 // The next media gallery ID to assign.
2043 const char kMediaGalleriesUniqueId[] = "media_galleries.gallery_id";
2045 // A list of dictionaries, where each dictionary represents a known media
2046 // gallery.
2047 const char kMediaGalleriesRememberedGalleries[] =
2048 "media_galleries.remembered_galleries";
2050 // The last time a media scan completed.
2051 const char kMediaGalleriesLastScanTime[] = "media_galleries.last_scan_time";
2053 #if defined(USE_ASH)
2054 // |kShelfAlignment| and |kShelfAutoHideBehavior| have a local variant. The
2055 // local variant is not synced and is used if set. If the local variant is not
2056 // set its value is set from the synced value (once prefs have been
2057 // synced). This gives a per-machine setting that is initialized from the last
2058 // set value.
2059 // These values are default on the machine but can be overridden by per-display
2060 // values in kShelfPreferences (unless overridden by managed policy).
2061 // String value corresponding to ash::Shell::ShelfAlignment.
2062 const char kShelfAlignment[] = "shelf_alignment";
2063 const char kShelfAlignmentLocal[] = "shelf_alignment_local";
2064 // String value corresponding to ash::Shell::ShelfAutoHideBehavior.
2065 const char kShelfAutoHideBehavior[] = "auto_hide_behavior";
2066 const char kShelfAutoHideBehaviorLocal[] = "auto_hide_behavior_local";
2067 // This value stores chrome icon's index in the launcher. This should be handled
2068 // separately with app shortcut's index because of ShelfModel's backward
2069 // compatibility. If we add chrome icon index to |kPinnedLauncherApps|, its
2070 // index is also stored in the |kPinnedLauncherApp| pref. It may causes
2071 // creating two chrome icons.
2072 const char kShelfChromeIconIndex[] = "shelf_chrome_icon_index";
2073 // Dictionary value that holds per-display preference of shelf alignment and
2074 // auto-hide behavior. Key of the dictionary is the id of the display, and
2075 // its value is a dictionary whose keys are kShelfAlignment and
2076 // kShelfAutoHideBehavior.
2077 const char kShelfPreferences[] = "shelf_preferences";
2079 // Integer value in milliseconds indicating the length of time for which a
2080 // confirmation dialog should be shown when the user presses the logout button.
2081 // A value of 0 indicates that logout should happen immediately, without showing
2082 // a confirmation dialog.
2083 const char kLogoutDialogDurationMs[] = "logout_dialog_duration_ms";
2084 const char kPinnedLauncherApps[] = "pinned_launcher_apps";
2085 // Boolean value indicating whether to show a logout button in the ash tray.
2086 const char kShowLogoutButtonInTray[] = "show_logout_button_in_tray";
2087 #endif
2089 #if defined(USE_AURA)
2090 // Tuning settings for gestures.
2091 const char kMaxSeparationForGestureTouchesInPixels[] =
2092 "gesture.max_separation_for_gesture_touches_in_pixels";
2093 const char kSemiLongPressTimeInMs[] = "gesture.semi_long_press_time_in_ms";
2094 const char kTabScrubActivationDelayInMs[] =
2095 "gesture.tab_scrub_activation_delay_in_ms";
2096 const char kFlingMaxCancelToDownTimeInMs[] =
2097 "gesture.fling_max_cancel_to_down_time_in_ms";
2098 const char kFlingMaxTapGapTimeInMs[] = "gesture.fling_max_tap_gap_time_in_ms";
2099 const char kOverscrollHorizontalThresholdComplete[] =
2100 "overscroll.horizontal_threshold_complete";
2101 const char kOverscrollVerticalThresholdComplete[] =
2102 "overscroll.vertical_threshold_complete";
2103 const char kOverscrollMinimumThresholdStart[] =
2104 "overscroll.minimum_threshold_start";
2105 const char kOverscrollMinimumThresholdStartTouchpad[] =
2106 "overscroll.minimum_threshold_start_touchpad";
2107 const char kOverscrollVerticalThresholdStart[] =
2108 "overscroll.vertical_threshold_start";
2109 const char kOverscrollHorizontalResistThreshold[] =
2110 "overscroll.horizontal_resist_threshold";
2111 const char kOverscrollVerticalResistThreshold[] =
2112 "overscroll.vertical_resist_threshold";
2113 #endif
2115 #if defined(OS_WIN)
2116 // Counts how many more times the 'profile on a network share' warning should be
2117 // shown to the user before the next silence period.
2118 const char kNetworkProfileWarningsLeft[] = "network_profile.warnings_left";
2119 // Tracks the time of the last shown warning. Used to reset
2120 // |network_profile.warnings_left| after a silence period.
2121 const char kNetworkProfileLastWarningTime[] =
2122 "network_profile.last_warning_time";
2123 #endif
2125 #if defined(OS_CHROMEOS)
2126 // The RLZ brand code, if enabled.
2127 const char kRLZBrand[] = "rlz.brand";
2128 // Whether RLZ pings are disabled.
2129 const char kRLZDisabled[] = "rlz.disabled";
2130 #endif
2132 #if defined(ENABLE_APP_LIST)
2133 // The directory in user data dir that contains the profile to be used with the
2134 // app launcher.
2135 const char kAppListProfile[] = "app_list.profile";
2137 // The number of times the app launcher was launched since last ping and
2138 // the time of the last ping.
2139 const char kAppListLaunchCount[] = "app_list.launch_count";
2140 const char kLastAppListLaunchPing[] = "app_list.last_launch_ping";
2142 // The number of times the an app was launched from the app launcher since last
2143 // ping and the time of the last ping.
2144 const char kAppListAppLaunchCount[] = "app_list.app_launch_count";
2145 const char kLastAppListAppLaunchPing[] = "app_list.last_app_launch_ping";
2147 // A boolean that tracks whether the user has ever enabled the app launcher.
2148 const char kAppLauncherHasBeenEnabled[] =
2149 "apps.app_launcher.has_been_enabled";
2151 // An enum indicating how the app launcher was enabled. E.g., via webstore, app
2152 // install, command line, etc. For UMA.
2153 const char kAppListEnableMethod[] = "app_list.how_enabled";
2155 // The time that the app launcher was enabled. Cleared when UMA is recorded.
2156 const char kAppListEnableTime[] = "app_list.when_enabled";
2158 // The last time the app list was launched.
2159 const char kAppListLastLaunchTime[] = "app_list.last_launch";
2161 #if defined(OS_MACOSX)
2162 // Integer representing the version of the app launcher shortcut installed on
2163 // the system. Incremented, e.g., when embedded icons change.
2164 const char kAppLauncherShortcutVersion[] = "apps.app_launcher.shortcut_version";
2165 #endif
2167 // A boolean identifying if we should show the app launcher promo or not.
2168 const char kShowAppLauncherPromo[] = "app_launcher.show_promo";
2170 // A dictionary that tracks the Drive app to Chrome app mapping. The key is
2171 // a Drive app id and the value is the corresponding Chrome app id. The pref
2172 // is unsynable and used to track local mappings only.
2173 const char kAppLauncherDriveAppMapping[] =
2174 "apps.app_launcher.drive_app_mapping";
2176 // A list of Drive app ids that tracks the uninstallable Drive apps.
2177 const char kAppLauncherUninstalledDriveApps[] =
2178 "apps.app_launcher.uninstalled_drive_apps";
2179 #endif // defined(ENABLE_APP_LIST)
2181 #if defined(OS_WIN)
2182 // If set, the user requested to launch the app with this extension id while
2183 // in Metro mode, and then relaunched to Desktop mode to start it.
2184 const char kAppLaunchForMetroRestart[] = "apps.app_launch_for_metro_restart";
2186 // Set with |kAppLaunchForMetroRestart|, the profile whose loading triggers
2187 // launch of the specified app when restarting Chrome in desktop mode.
2188 const char kAppLaunchForMetroRestartProfile[] =
2189 "apps.app_launch_for_metro_restart_profile";
2190 #endif
2192 // An integer that is incremented whenever changes are made to app shortcuts.
2193 // Increasing this causes all app shortcuts to be recreated.
2194 const char kAppShortcutsVersion[] = "apps.shortcuts_version";
2196 // How often the bubble has been shown.
2197 const char kModuleConflictBubbleShown[] = "module_conflict.bubble_shown";
2199 // A string pref for storing the salt used to compute the pepper device ID.
2200 const char kDRMSalt[] = "settings.privacy.drm_salt";
2201 // A boolean pref that enables the (private) pepper GetDeviceID() call and
2202 // enables the use of remote attestation for content protection.
2203 const char kEnableDRM[] = "settings.privacy.drm_enabled";
2205 // An integer per-profile pref that signals if the watchdog extension is
2206 // installed and active. We need to know if the watchdog extension active for
2207 // ActivityLog initialization before the extension system is initialized.
2208 const char kWatchdogExtensionActive[] =
2209 "profile.extensions.activity_log.num_consumers_active";
2211 #if defined(OS_ANDROID)
2212 // A list of partner bookmark rename/remove mappings.
2213 // Each list item is a dictionary containing a "url", a "provider_title" and
2214 // "mapped_title" entries, detailing the bookmark target URL (if any), the title
2215 // given by the PartnerBookmarksProvider and either the user-visible renamed
2216 // title or an empty string if the bookmark node was removed.
2217 const char kPartnerBookmarkMappings[] = "partnerbookmarks.mappings";
2218 #endif
2220 // Whether DNS Quick Check is disabled in proxy resolution.
2221 const char kQuickCheckEnabled[] = "proxy.quick_check_enabled";
2223 // Whether Guest Mode is enabled within the browser.
2224 const char kBrowserGuestModeEnabled[] = "profile.browser_guest_enabled";
2226 // Whether Adding a new Person is enabled within the user manager.
2227 const char kBrowserAddPersonEnabled[] = "profile.add_person_enabled";
2229 // Device identifier used by Easy Unlock stored in local state. This id will be
2230 // combined with a user id, before being registered with the CryptAuth server,
2231 // so it can't correlate users on the same device.
2232 const char kEasyUnlockDeviceId[] = "easy_unlock.device_id";
2234 // A dictionary that maps user id to hardlock state.
2235 const char kEasyUnlockHardlockState[] = "easy_unlock.hardlock_state";
2237 // A dictionary that maps user id to public part of RSA key pair used by
2238 // Easy Sign-in for the user.
2239 const char kEasyUnlockLocalStateTpmKeys[] = "easy_unlock.public_tpm_keys";
2241 // A dictionary in local state containing each user's Easy Unlock profile
2242 // preferences, so they can be accessed outside of the user's profile. The value
2243 // is a dictionary containing an entry for each user. Each user's entry mirrors
2244 // their profile's Easy Unlock preferences.
2245 const char kEasyUnlockLocalStateUserPrefs[] = "easy_unlock.user_prefs";
2247 // Boolean that indicates whether elevation is needed to recover Chrome upgrade.
2248 const char kRecoveryComponentNeedsElevation[] =
2249 "recovery_component.needs_elevation";
2251 // A dictionary that maps from supervised user whitelist IDs to their properties
2252 // (name and a list of clients that registered the whitelist).
2253 const char kRegisteredSupervisedUserWhitelists[] =
2254 "supervised_users.whitelists";
2256 #if defined(ENABLE_EXTENSIONS)
2257 // Policy that indicates how to handle animated images.
2258 const char kAnimationPolicy[] = "settings.a11y.animation_policy";
2259 #endif
2261 const char kBackgroundTracingLastUpload[] = "background_tracing.last_upload";
2263 } // namespace prefs