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

Side by Side Diff: chrome/browser/extensions/api/content_settings/content_settings_service.cc

Issue 220353002: Remove //chrome dependency from ExtensionPrefs (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: ContentSettingsService factory does not in fact depend on ExtensionPrefsFactory. Created 6 years, 8 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright 2014 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.
4
5 #include "chrome/browser/extensions/api/content_settings/content_settings_servic e.h"
6
7 #include "base/lazy_instance.h"
8 #include "chrome/browser/extensions/api/content_settings/content_settings_store. h"
9 #include "extensions/browser/extension_prefs_scope.h"
10 #include "extensions/browser/pref_names.h"
11
12 namespace extensions {
13
14 ContentSettingsService::ContentSettingsService(content::BrowserContext* context)
15 : content_settings_store_(new ContentSettingsStore()) {}
16
17 ContentSettingsService::~ContentSettingsService() {}
18
19 // static
20 ContentSettingsService* ContentSettingsService::Get(
21 content::BrowserContext* context) {
22 return BrowserContextKeyedAPIFactory<ContentSettingsService>::Get(context);
23 }
24
25 // BrowserContextKeyedAPI implementation.
26 BrowserContextKeyedAPIFactory<ContentSettingsService>*
27 ContentSettingsService::GetFactoryInstance() {
28 static base::LazyInstance<
29 BrowserContextKeyedAPIFactory<ContentSettingsService> > factory =
30 LAZY_INSTANCE_INITIALIZER;
31 return factory.Pointer();
32 }
33
34 void ContentSettingsService::OnExtensionRegistered(
35 const std::string& extension_id,
36 const base::Time& install_time,
37 bool is_enabled) {
38 content_settings_store_->RegisterExtension(
39 extension_id, install_time, is_enabled);
40 }
41
42 void ContentSettingsService::OnExtensionPrefsLoaded(
43 const std::string& extension_id,
44 const ExtensionPrefs* prefs) {
45 const base::ListValue* content_settings = NULL;
46 if (prefs->ReadPrefAsList(
47 extension_id, pref_names::kPrefContentSettings, &content_settings)) {
48 content_settings_store_->SetExtensionContentSettingFromList(
49 extension_id, content_settings, kExtensionPrefsScopeRegular);
50 }
51 if (prefs->ReadPrefAsList(extension_id,
52 pref_names::kPrefIncognitoContentSettings,
53 &content_settings)) {
54 content_settings_store_->SetExtensionContentSettingFromList(
55 extension_id,
56 content_settings,
57 kExtensionPrefsScopeIncognitoPersistent);
58 }
59 }
60
61 void ContentSettingsService::OnExtensionPrefsDeleted(
62 const std::string& extension_id) {
63 content_settings_store_->UnregisterExtension(extension_id);
64 }
65
66 void ContentSettingsService::OnExtensionStateChanged(
67 const std::string& extension_id,
68 bool state) {
69 content_settings_store_->SetExtensionState(extension_id, state);
70 }
71
72 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698