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

Side by Side Diff: extensions/browser/api/runtime/runtime_api.h

Issue 406063002: Hook up runtime API to implement ExtensionRegistryObserver. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address code review feedback. Created 6 years, 5 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
« no previous file with comments | « no previous file | extensions/browser/api/runtime/runtime_api.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 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 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 #ifndef EXTENSIONS_BROWSER_API_RUNTIME_RUNTIME_API_H_ 5 #ifndef EXTENSIONS_BROWSER_API_RUNTIME_RUNTIME_API_H_
6 #define EXTENSIONS_BROWSER_API_RUNTIME_RUNTIME_API_H_ 6 #define EXTENSIONS_BROWSER_API_RUNTIME_RUNTIME_API_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "base/scoped_observer.h"
10 #include "content/public/browser/notification_observer.h" 11 #include "content/public/browser/notification_observer.h"
11 #include "content/public/browser/notification_registrar.h" 12 #include "content/public/browser/notification_registrar.h"
12 #include "extensions/browser/api/runtime/runtime_api_delegate.h" 13 #include "extensions/browser/api/runtime/runtime_api_delegate.h"
13 #include "extensions/browser/browser_context_keyed_api_factory.h" 14 #include "extensions/browser/browser_context_keyed_api_factory.h"
14 #include "extensions/browser/extension_function.h" 15 #include "extensions/browser/extension_function.h"
16 #include "extensions/browser/extension_registry_observer.h"
15 #include "extensions/browser/process_manager_observer.h" 17 #include "extensions/browser/process_manager_observer.h"
16 #include "extensions/browser/update_observer.h" 18 #include "extensions/browser/update_observer.h"
17 #include "extensions/common/api/runtime.h" 19 #include "extensions/common/api/runtime.h"
18 20
19 namespace base { 21 namespace base {
20 class Version; 22 class Version;
21 } 23 }
22 24
23 namespace content { 25 namespace content {
24 class BrowserContext; 26 class BrowserContext;
25 } 27 }
26 28
27 namespace extensions { 29 namespace extensions {
28 30
29 namespace core_api { 31 namespace core_api {
30 namespace runtime { 32 namespace runtime {
31 struct PlatformInfo; 33 struct PlatformInfo;
32 } 34 }
33 } 35 }
34 36
35 class Extension; 37 class Extension;
36 class ExtensionHost; 38 class ExtensionHost;
37 39
Devlin 2014/07/23 15:26:44 nit: Also forward-declare ExtensionRegistry.
rpaquay 2014/07/23 15:41:42 Done.
38 // Runtime API dispatches onStartup, onInstalled, and similar events to 40 // Runtime API dispatches onStartup, onInstalled, and similar events to
39 // extensions. There is one instance shared between a browser context and 41 // extensions. There is one instance shared between a browser context and
40 // its related incognito instance. 42 // its related incognito instance.
41 class RuntimeAPI : public BrowserContextKeyedAPI, 43 class RuntimeAPI : public BrowserContextKeyedAPI,
42 public content::NotificationObserver, 44 public content::NotificationObserver,
45 public ExtensionRegistryObserver,
43 public UpdateObserver, 46 public UpdateObserver,
44 public ProcessManagerObserver { 47 public ProcessManagerObserver {
45 public: 48 public:
46 static BrowserContextKeyedAPIFactory<RuntimeAPI>* GetFactoryInstance(); 49 static BrowserContextKeyedAPIFactory<RuntimeAPI>* GetFactoryInstance();
47 50
48 explicit RuntimeAPI(content::BrowserContext* context); 51 explicit RuntimeAPI(content::BrowserContext* context);
49 virtual ~RuntimeAPI(); 52 virtual ~RuntimeAPI();
50 53
51 // content::NotificationObserver overrides: 54 // content::NotificationObserver overrides:
52 virtual void Observe(int type, 55 virtual void Observe(int type,
53 const content::NotificationSource& source, 56 const content::NotificationSource& source,
54 const content::NotificationDetails& details) OVERRIDE; 57 const content::NotificationDetails& details) OVERRIDE;
55 58
56 void ReloadExtension(const std::string& extension_id); 59 void ReloadExtension(const std::string& extension_id);
57 bool CheckForUpdates(const std::string& extension_id, 60 bool CheckForUpdates(const std::string& extension_id,
58 const RuntimeAPIDelegate::UpdateCheckCallback& callback); 61 const RuntimeAPIDelegate::UpdateCheckCallback& callback);
59 void OpenURL(const GURL& uninstall_url); 62 void OpenURL(const GURL& uninstall_url);
60 bool GetPlatformInfo(core_api::runtime::PlatformInfo* info); 63 bool GetPlatformInfo(core_api::runtime::PlatformInfo* info);
61 bool RestartDevice(std::string* error_message); 64 bool RestartDevice(std::string* error_message);
62 65
63 private: 66 private:
64 friend class BrowserContextKeyedAPIFactory<RuntimeAPI>; 67 friend class BrowserContextKeyedAPIFactory<RuntimeAPI>;
65 68
66 void OnExtensionsReady(); 69 // ExtensionRegistryObserver implementation.
67 void OnExtensionLoaded(const Extension* extension); 70 virtual void OnExtensionLoaded(content::BrowserContext* browser_context,
68 void OnExtensionInstalled(const Extension* extension); 71 const Extension* extension) OVERRIDE;
69 void OnExtensionUninstalled(const Extension* extension); 72 virtual void OnExtensionWillBeInstalled(
73 content::BrowserContext* browser_context,
74 const Extension* extension,
75 bool is_update,
76 bool from_ephemeral,
77 const std::string& old_name) OVERRIDE;
78 virtual void OnExtensionUninstalled(content::BrowserContext* browser_context,
79 const Extension* extension,
80 UninstallReason reason) OVERRIDE;
70 81
71 // BrowserContextKeyedAPI implementation: 82 // BrowserContextKeyedAPI implementation:
72 static const char* service_name() { return "RuntimeAPI"; } 83 static const char* service_name() { return "RuntimeAPI"; }
73 static const bool kServiceRedirectedInIncognito = true; 84 static const bool kServiceRedirectedInIncognito = true;
74 static const bool kServiceIsNULLWhileTesting = true; 85 static const bool kServiceIsNULLWhileTesting = true;
75 virtual void Shutdown() OVERRIDE; 86 virtual void Shutdown() OVERRIDE;
76 87
77 // extensions::UpdateObserver overrides: 88 // extensions::UpdateObserver overrides:
78 virtual void OnAppUpdateAvailable(const Extension* extension) OVERRIDE; 89 virtual void OnAppUpdateAvailable(const Extension* extension) OVERRIDE;
79 virtual void OnChromeUpdateAvailable() OVERRIDE; 90 virtual void OnChromeUpdateAvailable() OVERRIDE;
80 91
81 // ProcessManagerObserver implementation: 92 // ProcessManagerObserver implementation:
82 virtual void OnBackgroundHostStartup(const Extension* extension) OVERRIDE; 93 virtual void OnBackgroundHostStartup(const Extension* extension) OVERRIDE;
83 94
84 scoped_ptr<RuntimeAPIDelegate> delegate_; 95 scoped_ptr<RuntimeAPIDelegate> delegate_;
85 96
86 content::BrowserContext* browser_context_; 97 content::BrowserContext* browser_context_;
87 98
88 // True if we should dispatch the chrome.runtime.onInstalled event with 99 // True if we should dispatch the chrome.runtime.onInstalled event with
89 // reason "chrome_update" upon loading each extension. 100 // reason "chrome_update" upon loading each extension.
90 bool dispatch_chrome_updated_event_; 101 bool dispatch_chrome_updated_event_;
91 102
92 content::NotificationRegistrar registrar_; 103 content::NotificationRegistrar registrar_;
93 104
105 // Listen to extension notifications.
106 ScopedObserver<ExtensionRegistry, ExtensionRegistryObserver>
107 extension_registry_observer_;
108
94 DISALLOW_COPY_AND_ASSIGN(RuntimeAPI); 109 DISALLOW_COPY_AND_ASSIGN(RuntimeAPI);
95 }; 110 };
96 111
97 class RuntimeEventRouter { 112 class RuntimeEventRouter {
98 public: 113 public:
99 // Dispatches the onStartup event to all currently-loaded extensions. 114 // Dispatches the onStartup event to all currently-loaded extensions.
100 static void DispatchOnStartupEvent(content::BrowserContext* context, 115 static void DispatchOnStartupEvent(content::BrowserContext* context,
101 const std::string& extension_id); 116 const std::string& extension_id);
102 117
103 // Dispatches the onInstalled event to the given extension. 118 // Dispatches the onInstalled event to the given extension.
(...skipping 13 matching lines...) Expand all
117 content::BrowserContext* context); 132 content::BrowserContext* context);
118 133
119 // Dispatches the onRestartRequired event to the given app. 134 // Dispatches the onRestartRequired event to the given app.
120 static void DispatchOnRestartRequiredEvent( 135 static void DispatchOnRestartRequiredEvent(
121 content::BrowserContext* context, 136 content::BrowserContext* context,
122 const std::string& app_id, 137 const std::string& app_id,
123 core_api::runtime::OnRestartRequired::Reason reason); 138 core_api::runtime::OnRestartRequired::Reason reason);
124 139
125 // Does any work needed at extension uninstall (e.g. load uninstall url). 140 // Does any work needed at extension uninstall (e.g. load uninstall url).
126 static void OnExtensionUninstalled(content::BrowserContext* context, 141 static void OnExtensionUninstalled(content::BrowserContext* context,
127 const std::string& extension_id); 142 const std::string& extension_id,
143 UninstallReason reason);
128 }; 144 };
129 145
130 class RuntimeGetBackgroundPageFunction : public UIThreadExtensionFunction { 146 class RuntimeGetBackgroundPageFunction : public UIThreadExtensionFunction {
131 public: 147 public:
132 DECLARE_EXTENSION_FUNCTION("runtime.getBackgroundPage", 148 DECLARE_EXTENSION_FUNCTION("runtime.getBackgroundPage",
133 RUNTIME_GETBACKGROUNDPAGE) 149 RUNTIME_GETBACKGROUNDPAGE)
134 150
135 protected: 151 protected:
136 virtual ~RuntimeGetBackgroundPageFunction() {} 152 virtual ~RuntimeGetBackgroundPageFunction() {}
137 virtual ResponseAction Run() OVERRIDE; 153 virtual ResponseAction Run() OVERRIDE;
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after
197 RUNTIME_GETPACKAGEDIRECTORYENTRY) 213 RUNTIME_GETPACKAGEDIRECTORYENTRY)
198 214
199 protected: 215 protected:
200 virtual ~RuntimeGetPackageDirectoryEntryFunction() {} 216 virtual ~RuntimeGetPackageDirectoryEntryFunction() {}
201 virtual ResponseAction Run() OVERRIDE; 217 virtual ResponseAction Run() OVERRIDE;
202 }; 218 };
203 219
204 } // namespace extensions 220 } // namespace extensions
205 221
206 #endif // EXTENSIONS_BROWSER_API_RUNTIME_RUNTIME_API_H_ 222 #endif // EXTENSIONS_BROWSER_API_RUNTIME_RUNTIME_API_H_
OLDNEW
« no previous file with comments | « no previous file | extensions/browser/api/runtime/runtime_api.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698