blob: 55e3be269487cd242b5a759ecdee46b5c354e687 [file] [log] [blame]
[email protected]cce15bb2014-06-17 13:43:511// Copyright 2014 The Chromium Authors. All rights reserved.
[email protected]0850e842013-01-19 03:44:312// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
[email protected]cce15bb2014-06-17 13:43:515#ifndef CHROME_BROWSER_SUPERVISED_USER_SUPERVISED_USER_SERVICE_H_
6#define CHROME_BROWSER_SUPERVISED_USER_SUPERVISED_USER_SERVICE_H_
[email protected]0850e842013-01-19 03:44:317
treib950c6e82014-09-23 13:07:298#include <map>
[email protected]0d9a1da82013-03-14 21:52:079#include <set>
treib950c6e82014-09-23 13:07:2910#include <string>
[email protected]0850e842013-01-19 03:44:3111#include <vector>
12
[email protected]438f7e12013-08-07 06:59:0013#include "base/callback.h"
[email protected]076ebeda2014-06-06 21:47:2614#include "base/gtest_prod_util.h"
[email protected]a581ea22013-05-06 12:34:1915#include "base/memory/scoped_ptr.h"
treibab0a39e2014-09-24 14:48:2816#include "base/observer_list.h"
[email protected]1ab137b2013-03-21 03:33:1817#include "base/prefs/pref_change_registrar.h"
[email protected]f2253ac2014-05-28 08:37:2118#include "base/scoped_observer.h"
[email protected]f9b294362013-06-10 20:22:3119#include "base/strings/string16.h"
treib4edbded2014-09-05 08:43:5520#include "chrome/browser/supervised_user/experimental/supervised_user_blacklist.h"
[email protected]cce15bb2014-06-17 13:43:5121#include "chrome/browser/supervised_user/supervised_user_url_filter.h"
22#include "chrome/browser/supervised_user/supervised_users.h"
[email protected]a243d644c2013-06-20 18:37:5523#include "chrome/browser/sync/profile_sync_service_observer.h"
[email protected]3a276ff2014-08-12 14:22:0924#include "chrome/browser/sync/sync_type_preference_provider.h"
[email protected]514fcf22013-08-13 06:37:2425#include "chrome/browser/ui/browser_list_observer.h"
[email protected]12b7af32014-03-13 05:28:2026#include "components/keyed_service/core/keyed_service.h"
[email protected]bfd8cf982013-03-04 15:24:0027#include "content/public/browser/web_contents.h"
[email protected]c14a6802014-07-11 21:51:1228
29#if defined(ENABLE_EXTENSIONS)
[email protected]f2253ac2014-05-28 08:37:2130#include "extensions/browser/extension_registry_observer.h"
[email protected]301116c62013-11-26 10:37:4531#include "extensions/browser/management_policy.h"
[email protected]c14a6802014-07-11 21:51:1232#endif
[email protected]0850e842013-01-19 03:44:3133
[email protected]509ad1a92013-03-19 21:41:0634class Browser;
[email protected]acfcfbb2013-05-13 18:01:2735class GoogleServiceAuthError;
[email protected]4db65f952014-05-20 15:46:3036class PermissionRequestCreator;
[email protected]0850e842013-01-19 03:44:3137class Profile;
treibf136dfb2014-09-25 17:37:4738class SupervisedUserBlacklistDownloader;
[email protected]cce15bb2014-06-17 13:43:5139class SupervisedUserRegistrationUtility;
treibab0a39e2014-09-24 14:48:2840class SupervisedUserServiceObserver;
[email protected]cce15bb2014-06-17 13:43:5141class SupervisedUserSettingsService;
42class SupervisedUserSiteList;
43class SupervisedUserURLFilter;
[email protected]0850e842013-01-19 03:44:3144
treibdaece84f2014-09-05 12:58:1545namespace base {
46class FilePath;
47}
48
[email protected]f2253ac2014-05-28 08:37:2149namespace extensions {
50class ExtensionRegistry;
51}
52
[email protected]443e9312013-05-06 06:17:3453namespace user_prefs {
54class PrefRegistrySyncable;
55}
56
[email protected]cce15bb2014-06-17 13:43:5157// This class handles all the information related to a given supervised profile
[email protected]0850e842013-01-19 03:44:3158// (e.g. the installed content packs, the default URL filtering behavior, or
59// manual whitelist/blacklist overrides).
[email protected]cce15bb2014-06-17 13:43:5160class SupervisedUserService : public KeyedService,
[email protected]c14a6802014-07-11 21:51:1261#if defined(ENABLE_EXTENSIONS)
[email protected]cce15bb2014-06-17 13:43:5162 public extensions::ManagementPolicy::Provider,
[email protected]cce15bb2014-06-17 13:43:5163 public extensions::ExtensionRegistryObserver,
[email protected]c14a6802014-07-11 21:51:1264#endif
[email protected]3a276ff2014-08-12 14:22:0965 public SyncTypePreferenceProvider,
[email protected]c14a6802014-07-11 21:51:1266 public ProfileSyncServiceObserver,
[email protected]cce15bb2014-06-17 13:43:5167 public chrome::BrowserListObserver {
[email protected]0850e842013-01-19 03:44:3168 public:
[email protected]d2065e062013-12-12 23:49:5269 typedef std::vector<base::string16> CategoryList;
[email protected]438f7e12013-08-07 06:59:0070 typedef base::Callback<void(content::WebContents*)> NavigationBlockedCallback;
[email protected]514fcf22013-08-13 06:37:2471 typedef base::Callback<void(const GoogleServiceAuthError&)> AuthErrorCallback;
[email protected]0850e842013-01-19 03:44:3172
[email protected]5e022292013-02-06 16:42:1773 enum ManualBehavior {
74 MANUAL_NONE = 0,
75 MANUAL_ALLOW,
76 MANUAL_BLOCK
77 };
78
[email protected]f085fdd52014-06-11 18:09:2079 class Delegate {
80 public:
81 virtual ~Delegate() {}
82 // Returns true to indicate that the delegate handled the (de)activation, or
[email protected]cce15bb2014-06-17 13:43:5183 // false to indicate that the SupervisedUserService itself should handle it.
[email protected]f085fdd52014-06-11 18:09:2084 virtual bool SetActive(bool active) = 0;
treibdaece84f2014-09-05 12:58:1585 // Returns the path to a blacklist file to load, or an empty path to
86 // indicate "none".
87 virtual base::FilePath GetBlacklistPath() const = 0;
treibf136dfb2014-09-25 17:37:4788 // Returns the URL from which to download a blacklist if no local one exists
89 // yet. The blacklist file will be stored at |GetBlacklistPath()|.
90 virtual GURL GetBlacklistURL() const = 0;
[email protected]f085fdd52014-06-11 18:09:2091 };
92
[email protected]cce15bb2014-06-17 13:43:5193 virtual ~SupervisedUserService();
[email protected]0850e842013-01-19 03:44:3194
[email protected]a243d644c2013-06-20 18:37:5595 // ProfileKeyedService override:
96 virtual void Shutdown() OVERRIDE;
97
[email protected]37ca3fe02013-07-05 15:32:4498 static void RegisterProfilePrefs(user_prefs::PrefRegistrySyncable* registry);
[email protected]0850e842013-01-19 03:44:3199
[email protected]f085fdd52014-06-11 18:09:20100 void SetDelegate(Delegate* delegate);
101
[email protected]0850e842013-01-19 03:44:31102 // Returns the URL filter for the IO thread, for filtering network requests
[email protected]cce15bb2014-06-17 13:43:51103 // (in SupervisedUserResourceThrottle).
104 scoped_refptr<const SupervisedUserURLFilter> GetURLFilterForIOThread();
[email protected]0850e842013-01-19 03:44:31105
106 // Returns the URL filter for the UI thread, for filtering navigations and
107 // classifying sites in the history view.
[email protected]cce15bb2014-06-17 13:43:51108 SupervisedUserURLFilter* GetURLFilterForUIThread();
[email protected]0850e842013-01-19 03:44:31109
110 // Returns the URL's category, obtained from the installed content packs.
111 int GetCategory(const GURL& url);
112
113 // Returns the list of all known human-readable category names, sorted by ID
114 // number. Called in the critical path of drawing the history UI, so needs to
115 // be fast.
116 void GetCategoryNames(CategoryList* list);
117
[email protected]0369d6ab2013-08-09 01:52:59118 // Whether the user can request access to blocked URLs.
119 bool AccessRequestsEnabled();
120
[email protected]4db65f952014-05-20 15:46:30121 void OnPermissionRequestIssued();
122
[email protected]e861bba2013-06-17 15:20:54123 // Adds an access request for the given URL. The requests are stored using
124 // a prefix followed by a URIEncoded version of the URL. Each entry contains
125 // a dictionary which currently has the timestamp of the request in it.
126 void AddAccessRequest(const GURL& url);
127
[email protected]a9c2d642013-05-31 14:37:14128 // Returns the email address of the custodian.
129 std::string GetCustodianEmailAddress() const;
130
[email protected]fae057a2013-06-21 22:46:08131 // Returns the name of the custodian, or the email address if the name is
132 // empty.
133 std::string GetCustodianName() const;
134
[email protected]5e022292013-02-06 16:42:17135 // These methods allow querying and modifying the manual filtering behavior.
136 // The manual behavior is set by the user and overrides all other settings
137 // (whitelists or the default behavior).
[email protected]0850e842013-01-19 03:44:31138
[email protected]5e022292013-02-06 16:42:17139 // Returns the manual behavior for the given host.
140 ManualBehavior GetManualBehaviorForHost(const std::string& hostname);
[email protected]0850e842013-01-19 03:44:31141
[email protected]5e022292013-02-06 16:42:17142 // Returns the manual behavior for the given URL.
143 ManualBehavior GetManualBehaviorForURL(const GURL& url);
[email protected]0850e842013-01-19 03:44:31144
[email protected]43257902013-03-26 20:59:37145 // Returns all URLS on the given host that have exceptions.
146 void GetManualExceptionsForHost(const std::string& host,
147 std::vector<GURL>* urls);
148
[email protected]0850e842013-01-19 03:44:31149 // Initializes this object. This method does nothing if the profile is not
[email protected]cce15bb2014-06-17 13:43:51150 // supervised.
[email protected]0850e842013-01-19 03:44:31151 void Init();
152
[email protected]a243d644c2013-06-20 18:37:55153 // Initializes this profile for syncing, using the provided |refresh_token| to
154 // mint access tokens for Sync.
155 void InitSync(const std::string& refresh_token);
[email protected]acfcfbb2013-05-13 18:01:27156
[email protected]cce15bb2014-06-17 13:43:51157 // Convenience method that registers this supervised user using
[email protected]458d59442013-08-01 14:19:32158 // |registration_utility| and initializes sync with the returned token.
159 // The |callback| will be called when registration is complete,
[email protected]3a276ff2014-08-12 14:22:09160 // whether it succeeded or not -- unless registration was cancelled manually,
[email protected]458d59442013-08-01 14:19:32161 // in which case the callback will be ignored.
[email protected]cce15bb2014-06-17 13:43:51162 void RegisterAndInitSync(
163 SupervisedUserRegistrationUtility* registration_utility,
164 Profile* custodian_profile,
165 const std::string& supervised_user_id,
166 const AuthErrorCallback& callback);
[email protected]acfcfbb2013-05-13 18:01:27167
[email protected]4f02aac12013-05-20 05:19:06168 void set_elevated_for_testing(bool skip) {
169 elevated_for_testing_ = skip;
[email protected]849749d2013-05-06 17:30:45170 }
171
[email protected]438f7e12013-08-07 06:59:00172 void AddNavigationBlockedCallback(const NavigationBlockedCallback& callback);
173 void DidBlockNavigation(content::WebContents* web_contents);
174
treibab0a39e2014-09-24 14:48:28175 void AddObserver(SupervisedUserServiceObserver* observer);
176 void RemoveObserver(SupervisedUserServiceObserver* observer);
177
[email protected]c14a6802014-07-11 21:51:12178#if defined(ENABLE_EXTENSIONS)
[email protected]ce019142013-02-12 18:08:10179 // extensions::ManagementPolicy::Provider implementation:
[email protected]0850e842013-01-19 03:44:31180 virtual std::string GetDebugPolicyProviderName() const OVERRIDE;
181 virtual bool UserMayLoad(const extensions::Extension* extension,
[email protected]0085863a2013-12-06 21:19:03182 base::string16* error) const OVERRIDE;
[email protected]0850e842013-01-19 03:44:31183 virtual bool UserMayModifySettings(const extensions::Extension* extension,
[email protected]0085863a2013-12-06 21:19:03184 base::string16* error) const OVERRIDE;
[email protected]0850e842013-01-19 03:44:31185
[email protected]f2253ac2014-05-28 08:37:21186 // extensions::ExtensionRegistryObserver implementation.
187 virtual void OnExtensionLoaded(
188 content::BrowserContext* browser_context,
189 const extensions::Extension* extension) OVERRIDE;
190 virtual void OnExtensionUnloaded(
191 content::BrowserContext* browser_context,
192 const extensions::Extension* extension,
193 extensions::UnloadedExtensionInfo::Reason reason) OVERRIDE;
[email protected]c14a6802014-07-11 21:51:12194#endif
195
[email protected]3a276ff2014-08-12 14:22:09196 // SyncTypePreferenceProvider implementation:
197 virtual syncer::ModelTypeSet GetPreferredDataTypes() const OVERRIDE;
198
[email protected]c14a6802014-07-11 21:51:12199 // ProfileSyncServiceObserver implementation:
200 virtual void OnStateChanged() OVERRIDE;
[email protected]0850e842013-01-19 03:44:31201
[email protected]dfddd022013-07-10 17:29:48202 // chrome::BrowserListObserver implementation:
203 virtual void OnBrowserSetLastActive(Browser* browser) OVERRIDE;
204
[email protected]0850e842013-01-19 03:44:31205 private:
[email protected]cce15bb2014-06-17 13:43:51206 friend class SupervisedUserServiceExtensionTestBase;
207 friend class SupervisedUserServiceFactory;
208 FRIEND_TEST_ALL_PREFIXES(SupervisedUserServiceTest, ClearOmitOnRegistration);
[email protected]0850e842013-01-19 03:44:31209
[email protected]cce15bb2014-06-17 13:43:51210 // A bridge from the UI thread to the SupervisedUserURLFilters, one of which
211 // lives on the IO thread. This class mediates access to them and makes sure
212 // they are kept in sync.
[email protected]0850e842013-01-19 03:44:31213 class URLFilterContext {
214 public:
215 URLFilterContext();
216 ~URLFilterContext();
217
[email protected]cce15bb2014-06-17 13:43:51218 SupervisedUserURLFilter* ui_url_filter() const;
219 SupervisedUserURLFilter* io_url_filter() const;
[email protected]0850e842013-01-19 03:44:31220
221 void SetDefaultFilteringBehavior(
[email protected]cce15bb2014-06-17 13:43:51222 SupervisedUserURLFilter::FilteringBehavior behavior);
223 void LoadWhitelists(ScopedVector<SupervisedUserSiteList> site_lists);
treib4edbded2014-09-05 08:43:55224 void LoadBlacklist(const base::FilePath& path);
[email protected]5e022292013-02-06 16:42:17225 void SetManualHosts(scoped_ptr<std::map<std::string, bool> > host_map);
226 void SetManualURLs(scoped_ptr<std::map<GURL, bool> > url_map);
[email protected]0850e842013-01-19 03:44:31227
228 private:
treib4edbded2014-09-05 08:43:55229 void OnBlacklistLoaded();
230
[email protected]cce15bb2014-06-17 13:43:51231 // SupervisedUserURLFilter is refcounted because the IO thread filter is
232 // used both by ProfileImplIOData and OffTheRecordProfileIOData (to filter
[email protected]0850e842013-01-19 03:44:31233 // network requests), so they both keep a reference to it.
234 // Clients should not keep references to the UI thread filter, however
235 // (the filter will live as long as the profile lives, and afterwards it
236 // should not be used anymore either).
[email protected]cce15bb2014-06-17 13:43:51237 scoped_refptr<SupervisedUserURLFilter> ui_url_filter_;
238 scoped_refptr<SupervisedUserURLFilter> io_url_filter_;
[email protected]0850e842013-01-19 03:44:31239
treib4edbded2014-09-05 08:43:55240 SupervisedUserBlacklist blacklist_;
241
[email protected]0850e842013-01-19 03:44:31242 DISALLOW_COPY_AND_ASSIGN(URLFilterContext);
243 };
244
[email protected]cce15bb2014-06-17 13:43:51245 // Use |SupervisedUserServiceFactory::GetForProfile(..)| to get
[email protected]3bf45d02013-07-10 00:03:41246 // an instance of this service.
[email protected]cce15bb2014-06-17 13:43:51247 explicit SupervisedUserService(Profile* profile);
[email protected]3bf45d02013-07-10 00:03:41248
[email protected]f085fdd52014-06-11 18:09:20249 void SetActive(bool active);
250
[email protected]0085863a2013-12-06 21:19:03251 void OnCustodianProfileDownloaded(const base::string16& full_name);
[email protected]200729f82013-06-22 07:05:55252
[email protected]cce15bb2014-06-17 13:43:51253 void OnSupervisedUserRegistered(const AuthErrorCallback& callback,
254 Profile* custodian_profile,
255 const GoogleServiceAuthError& auth_error,
256 const std::string& token);
[email protected]acfcfbb2013-05-13 18:01:27257
[email protected]a243d644c2013-06-20 18:37:55258 void SetupSync();
[email protected]6e08b9a62014-07-08 00:32:48259 void StartSetupSync();
260 void FinishSetupSyncWhenReady();
261 void FinishSetupSync();
[email protected]a243d644c2013-06-20 18:37:55262
[email protected]cce15bb2014-06-17 13:43:51263 bool ProfileIsSupervised() const;
[email protected]e000daf2013-07-31 16:50:58264
treib3fce4e92014-09-26 16:06:25265 void OnCustodianInfoChanged();
266
[email protected]c14a6802014-07-11 21:51:12267#if defined(ENABLE_EXTENSIONS)
[email protected]0850e842013-01-19 03:44:31268 // Internal implementation for ExtensionManagementPolicy::Delegate methods.
269 // If |error| is not NULL, it will be filled with an error message if the
270 // requested extension action (install, modify status, etc.) is not permitted.
[email protected]38b7fb92013-07-26 16:32:26271 bool ExtensionManagementPolicyImpl(const extensions::Extension* extension,
[email protected]0085863a2013-12-06 21:19:03272 base::string16* error) const;
[email protected]0850e842013-01-19 03:44:31273
274 // Returns a list of all installed and enabled site lists in the current
[email protected]cce15bb2014-06-17 13:43:51275 // supervised profile.
276 ScopedVector<SupervisedUserSiteList> GetActiveSiteLists();
[email protected]0850e842013-01-19 03:44:31277
[email protected]c14a6802014-07-11 21:51:12278 // Extensions helper to SetActive().
279 void SetExtensionsActive();
280#endif
281
[email protected]cce15bb2014-06-17 13:43:51282 SupervisedUserSettingsService* GetSettingsService();
[email protected]e861bba2013-06-17 15:20:54283
[email protected]cce15bb2014-06-17 13:43:51284 void OnSupervisedUserIdChanged();
[email protected]f085fdd52014-06-11 18:09:20285
[email protected]0850e842013-01-19 03:44:31286 void OnDefaultFilteringBehaviorChanged();
287
288 void UpdateSiteLists();
289
treibf136dfb2014-09-25 17:37:47290 // Asynchronously downloads a static blacklist file from |url|, stores it at
291 // |path|, loads it, and applies it to the URL filters. If |url| is not valid
292 // (e.g. empty), directly tries to load from |path|.
293 void LoadBlacklist(const base::FilePath& path, const GURL& url);
294
treib4edbded2014-09-05 08:43:55295 // Asynchronously loads a static blacklist from a binary file at |path| and
296 // applies it to the URL filters.
treibf136dfb2014-09-25 17:37:47297 void LoadBlacklistFromFile(const base::FilePath& path);
298
299 void OnBlacklistDownloadDone(const base::FilePath& path, bool success);
treib4edbded2014-09-05 08:43:55300
[email protected]5e022292013-02-06 16:42:17301 // Updates the manual overrides for hosts in the URL filters when the
302 // corresponding preference is changed.
303 void UpdateManualHosts();
[email protected]0850e842013-01-19 03:44:31304
[email protected]5e022292013-02-06 16:42:17305 // Updates the manual overrides for URLs in the URL filters when the
306 // corresponding preference is changed.
307 void UpdateManualURLs();
[email protected]0850e842013-01-19 03:44:31308
[email protected]0b4c6b22014-08-04 09:46:31309 // Returns the human readable name of the supervised user.
310 std::string GetSupervisedUserName() const;
311
[email protected]12b7af32014-03-13 05:28:20312 // Owns us via the KeyedService mechanism.
[email protected]0850e842013-01-19 03:44:31313 Profile* profile_;
314
[email protected]f085fdd52014-06-11 18:09:20315 bool active_;
316
317 Delegate* delegate_;
318
[email protected]c14a6802014-07-11 21:51:12319#if defined(ENABLE_EXTENSIONS)
[email protected]f2253ac2014-05-28 08:37:21320 ScopedObserver<extensions::ExtensionRegistry,
321 extensions::ExtensionRegistryObserver>
322 extension_registry_observer_;
[email protected]c14a6802014-07-11 21:51:12323#endif
[email protected]f2253ac2014-05-28 08:37:21324
[email protected]0850e842013-01-19 03:44:31325 PrefChangeRegistrar pref_change_registrar_;
326
[email protected]a243d644c2013-06-20 18:37:55327 // True iff we're waiting for the Sync service to be initialized.
328 bool waiting_for_sync_initialization_;
[email protected]dfddd022013-07-10 17:29:48329 bool is_profile_active_;
[email protected]a243d644c2013-06-20 18:37:55330
[email protected]438f7e12013-08-07 06:59:00331 std::vector<NavigationBlockedCallback> navigation_blocked_callbacks_;
332
[email protected]4f02aac12013-05-20 05:19:06333 // Sets a profile in elevated state for testing if set to true.
334 bool elevated_for_testing_;
[email protected]849749d2013-05-06 17:30:45335
[email protected]3a276ff2014-08-12 14:22:09336 // True only when |Init()| method has been called.
337 bool did_init_;
338
[email protected]3bf45d02013-07-10 00:03:41339 // True only when |Shutdown()| method has been called.
340 bool did_shutdown_;
341
[email protected]0850e842013-01-19 03:44:31342 URLFilterContext url_filter_context_;
treibf136dfb2014-09-25 17:37:47343 scoped_ptr<SupervisedUserBlacklistDownloader> blacklist_downloader_;
[email protected]8052b242013-11-15 16:40:55344
[email protected]4db65f952014-05-20 15:46:30345 // Used to create permission requests.
346 scoped_ptr<PermissionRequestCreator> permissions_creator_;
347
treibab0a39e2014-09-24 14:48:28348 ObserverList<SupervisedUserServiceObserver> observer_list_;
349
[email protected]cce15bb2014-06-17 13:43:51350 base::WeakPtrFactory<SupervisedUserService> weak_ptr_factory_;
[email protected]0850e842013-01-19 03:44:31351};
352
[email protected]cce15bb2014-06-17 13:43:51353#endif // CHROME_BROWSER_SUPERVISED_USER_SUPERVISED_USER_SERVICE_H_