Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5530)

Unified Diff: chrome/browser/managed_mode/managed_mode.h

Issue 11299035: Support manual (white|black)list, previewing and allowing after interstitial (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Minor changes Created 7 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « chrome/app/generated_resources.grd ('k') | chrome/browser/managed_mode/managed_mode.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/managed_mode/managed_mode.h
diff --git a/chrome/browser/managed_mode/managed_mode.h b/chrome/browser/managed_mode/managed_mode.h
index 1c8eba9228e4711ab37c2a9c968e7ab78f9b5817..b7250158b3d39a4d738f414a4110ebb6a091ea21 100644
--- a/chrome/browser/managed_mode/managed_mode.h
+++ b/chrome/browser/managed_mode/managed_mode.h
@@ -28,6 +28,10 @@ class PrefServiceSimple;
class PrefServiceSyncable;
class Profile;
+namespace policy{
+class URLBlacklist;
+}
+
// Managed mode allows one person to manage the Chrome experience for another
// person by pre-configuring and then locking a managed User profile.
// The ManagedMode class provides methods to check whether the browser is in
@@ -62,6 +66,34 @@ class ManagedMode : public chrome::BrowserListObserver,
// This method should only be called on the UI thread.
static const ManagedModeURLFilter* GetURLFilterForUIThread();
+ // The functions that handle manual whitelists use |url_pattern| or lists
+ // of "url patterns". An "url pattern" is a pattern in the format used by the
+ // policy::URLBlacklist filter. A description of the format used can be found
+ // here: http://dev.chromium.org/administrators/url-blacklist-filter-format.
+ // They all receive the |is_whitelist| parameter which dictates whether they
+ // act on the whitelist (for |is_whitelist| == true) or on the blacklist (for
+ // |is_whitelist| == false).
+
+ // Checks if the |url_pattern| is in the manual whitelist.
+ static bool IsInManualList(const bool is_whitelist,
+ const std::string& url_pattern);
+
+ // Appends |list| to the manual white/black list (according to |is_whitelist|)
+ // both in URL filter and in preferences.
+ static void AddToManualList(const bool is_whitelist,
+ const base::ListValue& list);
+
+ // Removes |list| from the manual white/black list (according to
+ // |is_whitelist|) both in URL filter and in preferences.
+ static void RemoveFromManualList(const bool is_whitelist,
+ const base::ListValue& list);
+
+ // Updates the whitelist and the blacklist from the prefs.
+ static void UpdateManualLists();
+
+ // Returns the profile blacklist.
+ static scoped_ptr<base::ListValue> GetBlacklist();
+
// ExtensionManagementPolicy::Provider implementation:
virtual std::string GetDebugPolicyProviderName() const OVERRIDE;
virtual bool UserMayLoad(const extensions::Extension* extension,
@@ -132,7 +164,29 @@ class ManagedMode : public chrome::BrowserListObserver,
void OnDefaultFilteringBehaviorChanged();
- void UpdateWhitelist();
+ void UpdateManualListsImpl();
+
+ // Returns a copy of the manual whitelist which is stored in each profile.
+ scoped_ptr<base::ListValue> GetWhitelist();
+
+ // The following functions use |is_whitelist| to select between the whitelist
+ // and the blacklist as the target of the function. If |is_whitelist| is true
+ // |url_pattern| is added to the whitelist, otherwise it is added to the
+ // blacklist.
+
+ void RemoveFromManualListImpl(const bool is_whitelist,
+ const base::ListValue& whitelist);
+
+ // Adds the |url_pattern| to the manual lists in the URL filter. This is used
+ // by AddToManualListImpl().
+ void AddURLPatternToManualList(const bool is_whitelist,
+ const std::string& url_pattern);
+
+ void AddToManualListImpl(const bool is_whitelist,
+ const base::ListValue& whitelist);
+
+ bool IsInManualListImpl(const bool is_whitelist,
+ const std::string& url_pattern);
content::NotificationRegistrar registrar_;
scoped_ptr<PrefChangeRegistrar> pref_change_registrar_;
« no previous file with comments | « chrome/app/generated_resources.grd ('k') | chrome/browser/managed_mode/managed_mode.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698