Instrumental test for BookmarksBridge. It currently tests these functionalities:...
[chromium-blink-merge.git] / extensions / renderer / dispatcher.h
blob418f4065cc736f630ae703c6b03ca9906c82f713
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.
5 #ifndef EXTENSIONS_RENDERER_DISPATCHER_H_
6 #define EXTENSIONS_RENDERER_DISPATCHER_H_
8 #include <map>
9 #include <set>
10 #include <string>
11 #include <utility>
12 #include <vector>
14 #include "base/scoped_observer.h"
15 #include "base/timer/timer.h"
16 #include "content/public/renderer/render_process_observer.h"
17 #include "extensions/common/event_filter.h"
18 #include "extensions/common/extension_set.h"
19 #include "extensions/common/extensions_client.h"
20 #include "extensions/common/features/feature.h"
21 #include "extensions/renderer/resource_bundle_source_map.h"
22 #include "extensions/renderer/script_context.h"
23 #include "extensions/renderer/script_context_set.h"
24 #include "extensions/renderer/user_script_set_manager.h"
25 #include "extensions/renderer/v8_schema_registry.h"
26 #include "third_party/WebKit/public/platform/WebString.h"
27 #include "third_party/WebKit/public/platform/WebVector.h"
28 #include "v8/include/v8.h"
30 class ChromeRenderViewTest;
31 class GURL;
32 class ModuleSystem;
33 class URLPattern;
34 struct ExtensionMsg_ExternalConnectionInfo;
35 struct ExtensionMsg_Loaded_Params;
36 struct ExtensionMsg_UpdatePermissions_Params;
38 namespace blink {
39 class WebFrame;
40 class WebSecurityOrigin;
43 namespace base {
44 class DictionaryValue;
45 class ListValue;
48 namespace content {
49 class RenderThread;
52 namespace extensions {
53 class ContentWatcher;
54 class DispatcherDelegate;
55 class Extension;
56 class FilteredEventRouter;
57 class ManifestPermissionSet;
58 class RequestSender;
59 class ScriptContext;
60 class ScriptInjectionManager;
61 struct Message;
63 // Dispatches extension control messages sent to the renderer and stores
64 // renderer extension related state.
65 class Dispatcher : public content::RenderProcessObserver,
66 public UserScriptSetManager::Observer {
67 public:
68 explicit Dispatcher(DispatcherDelegate* delegate);
69 virtual ~Dispatcher();
71 const std::set<std::string>& function_names() const {
72 return function_names_;
75 bool is_extension_process() const { return is_extension_process_; }
77 const ExtensionSet* extensions() const { return &extensions_; }
79 const ScriptContextSet& script_context_set() const {
80 return script_context_set_;
83 V8SchemaRegistry* v8_schema_registry() { return v8_schema_registry_.get(); }
85 ContentWatcher* content_watcher() { return content_watcher_.get(); }
87 RequestSender* request_sender() { return request_sender_.get(); }
89 void OnRenderViewCreated(content::RenderView* render_view);
91 bool IsExtensionActive(const std::string& extension_id) const;
93 // Finds the extension for the JavaScript context associated with the
94 // specified |frame| and isolated world. If |world_id| is zero, finds the
95 // extension ID associated with the main world's JavaScript context. If the
96 // JavaScript context isn't from an extension, returns empty string.
97 const Extension* GetExtensionFromFrameAndWorld(const blink::WebFrame* frame,
98 int world_id,
99 bool use_effective_url);
101 void DidCreateScriptContext(blink::WebFrame* frame,
102 const v8::Handle<v8::Context>& context,
103 int extension_group,
104 int world_id);
106 void WillReleaseScriptContext(blink::WebFrame* frame,
107 const v8::Handle<v8::Context>& context,
108 int world_id);
110 void DidCreateDocumentElement(blink::WebFrame* frame);
112 void DidMatchCSS(
113 blink::WebFrame* frame,
114 const blink::WebVector<blink::WebString>& newly_matching_selectors,
115 const blink::WebVector<blink::WebString>& stopped_matching_selectors);
117 void OnExtensionResponse(int request_id,
118 bool success,
119 const base::ListValue& response,
120 const std::string& error);
122 // Checks that the current context contains an extension that has permission
123 // to execute the specified function. If it does not, a v8 exception is thrown
124 // and the method returns false. Otherwise returns true.
125 bool CheckContextAccessToExtensionAPI(const std::string& function_name,
126 ScriptContext* context) const;
128 // Dispatches the event named |event_name| to all render views.
129 void DispatchEvent(const std::string& extension_id,
130 const std::string& event_name) const;
132 // Shared implementation of the various MessageInvoke IPCs.
133 void InvokeModuleSystemMethod(content::RenderView* render_view,
134 const std::string& extension_id,
135 const std::string& module_name,
136 const std::string& function_name,
137 const base::ListValue& args,
138 bool user_gesture);
140 void ClearPortData(int port_id);
142 // Returns a list of (module name, resource id) pairs for the JS modules to
143 // add to the source map.
144 static std::vector<std::pair<std::string, int> > GetJsResources();
145 static void RegisterNativeHandlers(ModuleSystem* module_system,
146 ScriptContext* context,
147 Dispatcher* dispatcher,
148 RequestSender* request_sender,
149 V8SchemaRegistry* v8_schema_registry);
151 private:
152 friend class ::ChromeRenderViewTest;
153 FRIEND_TEST_ALL_PREFIXES(RendererPermissionsPolicyDelegateTest,
154 CannotScriptWebstore);
156 // RenderProcessObserver implementation:
157 virtual bool OnControlMessageReceived(const IPC::Message& message) OVERRIDE;
158 virtual void WebKitInitialized() OVERRIDE;
159 virtual void IdleNotification() OVERRIDE;
160 virtual void OnRenderProcessShutdown() OVERRIDE;
162 void OnActivateExtension(const std::string& extension_id);
163 void OnCancelSuspend(const std::string& extension_id);
164 void OnClearTabSpecificPermissions(
165 int tab_id,
166 const std::vector<std::string>& extension_ids);
167 void OnDeliverMessage(int target_port_id, const Message& message);
168 void OnDispatchOnConnect(int target_port_id,
169 const std::string& channel_name,
170 const base::DictionaryValue& source_tab,
171 const ExtensionMsg_ExternalConnectionInfo& info,
172 const std::string& tls_channel_id);
173 void OnDispatchOnDisconnect(int port_id, const std::string& error_message);
174 void OnLoaded(
175 const std::vector<ExtensionMsg_Loaded_Params>& loaded_extensions);
176 void OnLoadedInternal(scoped_refptr<const Extension> extension);
177 void OnMessageInvoke(const std::string& extension_id,
178 const std::string& module_name,
179 const std::string& function_name,
180 const base::ListValue& args,
181 bool user_gesture);
182 void OnSetChannel(int channel);
183 void OnSetFunctionNames(const std::vector<std::string>& names);
184 void OnSetScriptingWhitelist(
185 const ExtensionsClient::ScriptingWhitelist& extension_ids);
186 void OnSetSystemFont(const std::string& font_family,
187 const std::string& font_size);
188 void OnShouldSuspend(const std::string& extension_id, uint64 sequence_id);
189 void OnSuspend(const std::string& extension_id);
190 void OnTransferBlobs(const std::vector<std::string>& blob_uuids);
191 void OnUnloaded(const std::string& id);
192 void OnUpdatePermissions(const ExtensionMsg_UpdatePermissions_Params& params);
193 void OnUpdateTabSpecificPermissions(const GURL& url,
194 int tab_id,
195 const std::string& extension_id,
196 const URLPatternSet& origin_set);
197 void OnUsingWebRequestAPI(bool webrequest_used);
199 // UserScriptSetManager::Observer implementation.
200 virtual void OnUserScriptsUpdated(
201 const std::set<std::string>& changed_extensions,
202 const std::vector<UserScript*>& scripts) OVERRIDE;
204 void UpdateActiveExtensions();
206 // Sets up the host permissions for |extension|.
207 void InitOriginPermissions(const Extension* extension);
209 // Updates the host permissions for extension to include only those in
210 // |new_patterns|, and remove from |old_patterns| that are no longer allowed.
211 void UpdateOriginPermissions(const Extension* extension,
212 const URLPatternSet& old_patterns,
213 const URLPatternSet& new_patterns);
215 // Enable custom element whitelist in Apps.
216 void EnableCustomElementWhiteList();
218 // Adds or removes bindings for every context belonging to |extension_id|, or
219 // or all contexts if |extension_id| is empty.
220 void UpdateBindings(const std::string& extension_id);
222 void UpdateBindingsForContext(ScriptContext* context);
224 void RegisterBinding(const std::string& api_name, ScriptContext* context);
226 void RegisterNativeHandlers(ModuleSystem* module_system,
227 ScriptContext* context);
229 // Inserts static source code into |source_map_|.
230 void PopulateSourceMap();
232 // Returns whether the current renderer hosts a platform app.
233 bool IsWithinPlatformApp();
235 bool IsSandboxedPage(const GURL& url) const;
237 // Returns the Feature::Context type of context for a JavaScript context.
238 Feature::Context ClassifyJavaScriptContext(
239 const Extension* extension,
240 int extension_group,
241 const GURL& url,
242 const blink::WebSecurityOrigin& origin);
244 // Gets |field| from |object| or creates it as an empty object if it doesn't
245 // exist.
246 v8::Handle<v8::Object> GetOrCreateObject(const v8::Handle<v8::Object>& object,
247 const std::string& field,
248 v8::Isolate* isolate);
250 v8::Handle<v8::Object> GetOrCreateBindObjectIfAvailable(
251 const std::string& api_name,
252 std::string* bind_name,
253 ScriptContext* context);
255 // The delegate for this dispatcher. Not owned, but must extend beyond the
256 // Dispatcher's own lifetime.
257 DispatcherDelegate* delegate_;
259 // True if this renderer is running extensions.
260 bool is_extension_process_;
262 // Contains all loaded extensions. This is essentially the renderer
263 // counterpart to ExtensionService in the browser. It contains information
264 // about all extensions currently loaded by the browser.
265 ExtensionSet extensions_;
267 // The IDs of extensions that failed to load, mapped to the error message
268 // generated on failure.
269 std::map<std::string, std::string> extension_load_errors_;
271 // All the bindings contexts that are currently loaded for this renderer.
272 // There is zero or one for each v8 context.
273 ScriptContextSet script_context_set_;
275 scoped_ptr<ContentWatcher> content_watcher_;
277 scoped_ptr<UserScriptSetManager> user_script_set_manager_;
279 scoped_ptr<ScriptInjectionManager> script_injection_manager_;
281 // Same as above, but on a longer timer and will run even if the process is
282 // not idle, to ensure that IdleHandle gets called eventually.
283 scoped_ptr<base::RepeatingTimer<content::RenderThread> > forced_idle_timer_;
285 // All declared function names.
286 std::set<std::string> function_names_;
288 // The extensions and apps that are active in this process.
289 std::set<std::string> active_extension_ids_;
291 ResourceBundleSourceMap source_map_;
293 // Cache for the v8 representation of extension API schemas.
294 scoped_ptr<V8SchemaRegistry> v8_schema_registry_;
296 // Sends API requests to the extension host.
297 scoped_ptr<RequestSender> request_sender_;
299 // The platforms system font family and size;
300 std::string system_font_family_;
301 std::string system_font_size_;
303 // Mapping of port IDs to tabs. If there is no tab, the value would be -1.
304 std::map<int, int> port_to_tab_id_map_;
306 // True once WebKit has been initialized (and it is therefore safe to poke).
307 bool is_webkit_initialized_;
309 // It is important for this to come after the ScriptInjectionManager, so that
310 // the observer is destroyed before the UserScriptSet.
311 ScopedObserver<UserScriptSetManager, UserScriptSetManager::Observer>
312 user_script_set_manager_observer_;
314 DISALLOW_COPY_AND_ASSIGN(Dispatcher);
317 } // namespace extensions
319 #endif // EXTENSIONS_RENDERER_DISPATCHER_H_