OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 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 | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "extensions/browser/warning_service.h" | 5 #include "extensions/browser/warning_service.h" |
6 | 6 |
7 #include "content/public/browser/browser_thread.h" | 7 #include "content/public/browser/browser_thread.h" |
8 #include "extensions/browser/extension_registry.h" | 8 #include "extensions/browser/extension_registry.h" |
9 #include "extensions/browser/extension_system.h" | |
10 #include "extensions/browser/extensions_browser_client.h" | 9 #include "extensions/browser/extensions_browser_client.h" |
| 10 #include "extensions/browser/warning_service_factory.h" |
11 #include "extensions/common/extension_set.h" | 11 #include "extensions/common/extension_set.h" |
12 | 12 |
13 using content::BrowserThread; | 13 using content::BrowserThread; |
14 | 14 |
15 namespace extensions { | 15 namespace extensions { |
16 | 16 |
17 WarningService::WarningService(content::BrowserContext* browser_context) | 17 WarningService::WarningService(content::BrowserContext* browser_context) |
18 : browser_context_(browser_context), extension_registry_observer_(this) { | 18 : browser_context_(browser_context), extension_registry_observer_(this) { |
19 DCHECK(CalledOnValidThread()); | 19 DCHECK(CalledOnValidThread()); |
20 if (browser_context_) { | 20 if (browser_context_) { |
21 extension_registry_observer_.Add(ExtensionRegistry::Get( | 21 extension_registry_observer_.Add(ExtensionRegistry::Get( |
22 ExtensionsBrowserClient::Get()->GetOriginalContext(browser_context_))); | 22 ExtensionsBrowserClient::Get()->GetOriginalContext(browser_context_))); |
23 } | 23 } |
24 } | 24 } |
25 | 25 |
26 WarningService::~WarningService() {} | 26 WarningService::~WarningService() {} |
27 | 27 |
| 28 // static |
| 29 WarningService* WarningService::Get(content::BrowserContext* browser_context) { |
| 30 return WarningServiceFactory::GetForBrowserContext(browser_context); |
| 31 } |
| 32 |
28 void WarningService::ClearWarnings( | 33 void WarningService::ClearWarnings( |
29 const std::set<Warning::WarningType>& types) { | 34 const std::set<Warning::WarningType>& types) { |
30 DCHECK(CalledOnValidThread()); | 35 DCHECK(CalledOnValidThread()); |
31 bool deleted_anything = false; | 36 bool deleted_anything = false; |
32 for (WarningSet::iterator i = warnings_.begin(); | 37 for (WarningSet::iterator i = warnings_.begin(); |
33 i != warnings_.end();) { | 38 i != warnings_.end();) { |
34 if (types.find(i->warning_type()) != types.end()) { | 39 if (types.find(i->warning_type()) != types.end()) { |
35 deleted_anything = true; | 40 deleted_anything = true; |
36 warnings_.erase(i++); | 41 warnings_.erase(i++); |
37 } else { | 42 } else { |
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
88 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 93 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
89 content::BrowserContext* browser_context = | 94 content::BrowserContext* browser_context = |
90 reinterpret_cast<content::BrowserContext*>(profile_id); | 95 reinterpret_cast<content::BrowserContext*>(profile_id); |
91 | 96 |
92 if (!browser_context || | 97 if (!browser_context || |
93 !ExtensionsBrowserClient::Get() || | 98 !ExtensionsBrowserClient::Get() || |
94 !ExtensionsBrowserClient::Get()->IsValidContext(browser_context)) { | 99 !ExtensionsBrowserClient::Get()->IsValidContext(browser_context)) { |
95 return; | 100 return; |
96 } | 101 } |
97 | 102 |
98 WarningService* warning_service = | 103 WarningService* warning_service = WarningService::Get(browser_context); |
99 ExtensionSystem::Get(browser_context)->warning_service(); | |
100 | 104 |
101 warning_service->AddWarnings(warnings); | 105 warning_service->AddWarnings(warnings); |
102 } | 106 } |
103 | 107 |
104 void WarningService::AddObserver(Observer* observer) { | 108 void WarningService::AddObserver(Observer* observer) { |
105 observer_list_.AddObserver(observer); | 109 observer_list_.AddObserver(observer); |
106 } | 110 } |
107 | 111 |
108 void WarningService::RemoveObserver(Observer* observer) { | 112 void WarningService::RemoveObserver(Observer* observer) { |
109 observer_list_.RemoveObserver(observer); | 113 observer_list_.RemoveObserver(observer); |
110 } | 114 } |
111 | 115 |
112 void WarningService::NotifyWarningsChanged() { | 116 void WarningService::NotifyWarningsChanged() { |
113 FOR_EACH_OBSERVER(Observer, observer_list_, ExtensionWarningsChanged()); | 117 FOR_EACH_OBSERVER(Observer, observer_list_, ExtensionWarningsChanged()); |
114 } | 118 } |
115 | 119 |
116 void WarningService::OnExtensionUnloaded( | 120 void WarningService::OnExtensionUnloaded( |
117 content::BrowserContext* browser_context, | 121 content::BrowserContext* browser_context, |
118 const Extension* extension, | 122 const Extension* extension, |
119 UnloadedExtensionInfo::Reason reason) { | 123 UnloadedExtensionInfo::Reason reason) { |
120 // Unloading one extension might have solved the problems of others. | 124 // Unloading one extension might have solved the problems of others. |
121 // Therefore, we clear warnings of this type for all extensions. | 125 // Therefore, we clear warnings of this type for all extensions. |
122 std::set<Warning::WarningType> warning_types = | 126 std::set<Warning::WarningType> warning_types = |
123 GetWarningTypesAffectingExtension(extension->id()); | 127 GetWarningTypesAffectingExtension(extension->id()); |
124 ClearWarnings(warning_types); | 128 ClearWarnings(warning_types); |
125 } | 129 } |
126 | 130 |
127 } // namespace extensions | 131 } // namespace extensions |
OLD | NEW |