Add more checks to investigate SupervisedUserPrefStore crash at startup.
[chromium-blink-merge.git] / chrome / browser / prefs / incognito_mode_prefs.h
blob0837cb43e452a2f2475d3a70a5b364705a6041ae
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 #ifndef CHROME_BROWSER_PREFS_INCOGNITO_MODE_PREFS_H_
6 #define CHROME_BROWSER_PREFS_INCOGNITO_MODE_PREFS_H_
8 #include "base/basictypes.h"
10 class PrefService;
11 class Profile;
13 namespace base {
14 class CommandLine;
17 namespace user_prefs {
18 class PrefRegistrySyncable;
21 // Specifies Incognito mode availability preferences.
22 class IncognitoModePrefs {
23 public:
24 // Possible values for Incognito mode availability. Please, do not change
25 // the order of entries since numeric values are exposed to users.
26 enum Availability {
27 // Incognito mode enabled. Users may open pages in both Incognito mode and
28 // normal mode (the default behaviour).
29 ENABLED = 0,
30 // Incognito mode disabled. Users may not open pages in Incognito mode.
31 // Only normal mode is available for browsing.
32 DISABLED,
33 // Incognito mode forced. Users may open pages *ONLY* in Incognito mode.
34 // Normal mode is not available for browsing.
35 FORCED,
37 AVAILABILITY_NUM_TYPES
40 // Register incognito related preferences.
41 static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry);
43 // Returns kIncognitoModeAvailability preference value stored
44 // in the given pref service.
45 static Availability GetAvailability(const PrefService* prefs);
47 // Sets kIncognitoModeAvailability preference to the specified availability
48 // value.
49 static void SetAvailability(PrefService* prefs,
50 const Availability availability);
52 // Converts in_value into the corresponding Availability value. Returns true
53 // if conversion is successful (in_value is valid). Otherwise, returns false
54 // and *out_value is set to ENABLED.
55 static bool IntToAvailability(int in_value, Availability* out_value);
57 // Returns true if the browser should start in incognito mode.
58 static bool ShouldLaunchIncognito(const base::CommandLine& command_line,
59 const PrefService* prefs);
61 // Returns true if |profile| can open a new Browser. This checks the incognito
62 // availability policies and verifies if the |profile| type is allowed to
63 // open new windows.
64 static bool CanOpenBrowser(Profile* profile);
66 // Returns whether parental controls have been enabled on the platform. This
67 // method simply returns a cached value and thus the result may be stale. May
68 // be called on any thread.
69 static bool ArePlatformParentalControlsEnabledCached();
71 #if defined(OS_WIN)
72 // Initializes the parental control settings. Must be called on UI thread and
73 // before |ArePlatformParentalControlsEnabled|.
74 static void InitializePlatformParentalControls();
75 #endif // OS_WIN
77 private:
78 // Returns whether parental controls have been enabled on the platform, which
79 // if enabled will overrule the Availability as configured in prefs.
80 static bool ArePlatformParentalControlsEnabled();
82 DISALLOW_IMPLICIT_CONSTRUCTORS(IncognitoModePrefs);
85 #endif // CHROME_BROWSER_PREFS_INCOGNITO_MODE_PREFS_H_