OLD | NEW |
---|---|
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 "chrome/renderer/extensions/extension_dispatcher.h" | 5 #include "chrome/renderer/extensions/extension_dispatcher.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
8 #include "chrome/common/child_process_logging.h" | 8 #include "chrome/common/child_process_logging.h" |
9 #include "chrome/common/chrome_switches.h" | 9 #include "chrome/common/chrome_switches.h" |
10 #include "chrome/common/extensions/extension.h" | 10 #include "chrome/common/extensions/extension.h" |
(...skipping 13 matching lines...) Expand all Loading... | |
24 #include "chrome/renderer/extensions/user_script_slave.h" | 24 #include "chrome/renderer/extensions/user_script_slave.h" |
25 #include "content/public/renderer/render_thread.h" | 25 #include "content/public/renderer/render_thread.h" |
26 #include "grit/renderer_resources.h" | 26 #include "grit/renderer_resources.h" |
27 #include "third_party/WebKit/Source/WebKit/chromium/public/WebDataSource.h" | 27 #include "third_party/WebKit/Source/WebKit/chromium/public/WebDataSource.h" |
28 #include "third_party/WebKit/Source/WebKit/chromium/public/WebFrame.h" | 28 #include "third_party/WebKit/Source/WebKit/chromium/public/WebFrame.h" |
29 #include "third_party/WebKit/Source/WebKit/chromium/public/WebSecurityPolicy.h" | 29 #include "third_party/WebKit/Source/WebKit/chromium/public/WebSecurityPolicy.h" |
30 #include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h" | 30 #include "third_party/WebKit/Source/WebKit/chromium/public/WebString.h" |
31 #include "third_party/WebKit/Source/WebKit/chromium/public/WebURLRequest.h" | 31 #include "third_party/WebKit/Source/WebKit/chromium/public/WebURLRequest.h" |
32 #include "v8/include/v8.h" | 32 #include "v8/include/v8.h" |
33 | 33 |
34 namespace { | |
35 static const int64 kInitialExtensionIdleHandlerDelayMs = 5*1000; | |
36 static const int64 kMaxExtensionIdleHandlerDelayMs = 5*60*1000; | |
37 } | |
38 | |
39 using extensions::MiscellaneousBindings; | 34 using extensions::MiscellaneousBindings; |
40 using extensions::SchemaGeneratedBindings; | 35 using extensions::SchemaGeneratedBindings; |
41 using WebKit::WebDataSource; | 36 using WebKit::WebDataSource; |
42 using WebKit::WebFrame; | 37 using WebKit::WebFrame; |
43 using WebKit::WebSecurityPolicy; | 38 using WebKit::WebSecurityPolicy; |
44 using WebKit::WebString; | 39 using WebKit::WebString; |
45 using content::RenderThread; | 40 using content::RenderThread; |
46 | 41 |
47 ExtensionDispatcher::ExtensionDispatcher() | 42 ExtensionDispatcher::ExtensionDispatcher() |
48 : is_webkit_initialized_(false), | 43 : is_webkit_initialized_(false), |
49 webrequest_adblock_(false), | 44 webrequest_adblock_(false), |
50 webrequest_adblock_plus_(false), | 45 webrequest_adblock_plus_(false), |
51 webrequest_other_(false) { | 46 webrequest_other_(false) { |
52 const CommandLine& command_line = *(CommandLine::ForCurrentProcess()); | 47 const CommandLine& command_line = *(CommandLine::ForCurrentProcess()); |
53 is_extension_process_ = | 48 is_extension_process_ = |
54 command_line.HasSwitch(switches::kExtensionProcess) || | 49 command_line.HasSwitch(switches::kExtensionProcess) || |
55 command_line.HasSwitch(switches::kSingleProcess); | 50 command_line.HasSwitch(switches::kSingleProcess); |
56 | 51 |
57 if (is_extension_process_) { | |
58 RenderThread::Get()->SetIdleNotificationDelayInMs( | |
59 kInitialExtensionIdleHandlerDelayMs); | |
60 } | |
61 | |
62 user_script_slave_.reset(new UserScriptSlave(&extensions_)); | 52 user_script_slave_.reset(new UserScriptSlave(&extensions_)); |
63 } | 53 } |
64 | 54 |
65 ExtensionDispatcher::~ExtensionDispatcher() { | 55 ExtensionDispatcher::~ExtensionDispatcher() { |
66 } | 56 } |
67 | 57 |
68 bool ExtensionDispatcher::OnControlMessageReceived( | 58 bool ExtensionDispatcher::OnControlMessageReceived( |
69 const IPC::Message& message) { | 59 const IPC::Message& message) { |
70 bool handled = true; | 60 bool handled = true; |
71 IPC_BEGIN_MESSAGE_MAP(ExtensionDispatcher, message) | 61 IPC_BEGIN_MESSAGE_MAP(ExtensionDispatcher, message) |
72 IPC_MESSAGE_HANDLER(ExtensionMsg_MessageInvoke, OnMessageInvoke) | 62 IPC_MESSAGE_HANDLER(ExtensionMsg_MessageInvoke, OnMessageInvoke) |
73 IPC_MESSAGE_HANDLER(ExtensionMsg_DeliverMessage, OnDeliverMessage) | 63 IPC_MESSAGE_HANDLER(ExtensionMsg_DeliverMessage, OnDeliverMessage) |
74 IPC_MESSAGE_HANDLER(ExtensionMsg_SetFunctionNames, OnSetFunctionNames) | 64 IPC_MESSAGE_HANDLER(ExtensionMsg_SetFunctionNames, OnSetFunctionNames) |
75 IPC_MESSAGE_HANDLER(ExtensionMsg_Loaded, OnLoaded) | 65 IPC_MESSAGE_HANDLER(ExtensionMsg_Loaded, OnLoaded) |
76 IPC_MESSAGE_HANDLER(ExtensionMsg_Unloaded, OnUnloaded) | 66 IPC_MESSAGE_HANDLER(ExtensionMsg_Unloaded, OnUnloaded) |
77 IPC_MESSAGE_HANDLER(ExtensionMsg_SetScriptingWhitelist, | 67 IPC_MESSAGE_HANDLER(ExtensionMsg_SetScriptingWhitelist, |
78 OnSetScriptingWhitelist) | 68 OnSetScriptingWhitelist) |
79 IPC_MESSAGE_HANDLER(ExtensionMsg_ActivateExtension, OnActivateExtension) | 69 IPC_MESSAGE_HANDLER(ExtensionMsg_ActivateExtension, OnActivateExtension) |
80 IPC_MESSAGE_HANDLER(ExtensionMsg_ActivateApplication, OnActivateApplication) | 70 IPC_MESSAGE_HANDLER(ExtensionMsg_ActivateApplication, OnActivateApplication) |
81 IPC_MESSAGE_HANDLER(ExtensionMsg_UpdatePermissions, OnUpdatePermissions) | 71 IPC_MESSAGE_HANDLER(ExtensionMsg_UpdatePermissions, OnUpdatePermissions) |
82 IPC_MESSAGE_HANDLER(ExtensionMsg_UpdateUserScripts, OnUpdateUserScripts) | 72 IPC_MESSAGE_HANDLER(ExtensionMsg_UpdateUserScripts, OnUpdateUserScripts) |
83 IPC_MESSAGE_HANDLER(ExtensionMsg_UsingWebRequestAPI, OnUsingWebRequestAPI) | 73 IPC_MESSAGE_HANDLER(ExtensionMsg_UsingWebRequestAPI, OnUsingWebRequestAPI) |
84 IPC_MESSAGE_UNHANDLED(handled = false) | 74 IPC_MESSAGE_UNHANDLED(handled = false) |
85 IPC_END_MESSAGE_MAP() | 75 IPC_END_MESSAGE_MAP() |
86 | 76 |
87 return handled; | 77 return handled; |
88 } | 78 } |
89 | 79 |
90 void ExtensionDispatcher::WebKitInitialized() { | 80 void ExtensionDispatcher::WebKitInitialized() { |
91 // For extensions, we want to ensure we call the IdleHandler every so often, | |
92 // even if the extension keeps up activity. | |
93 if (is_extension_process_) { | |
94 forced_idle_timer_.Start(FROM_HERE, | |
95 base::TimeDelta::FromMilliseconds(kMaxExtensionIdleHandlerDelayMs), | |
96 RenderThread::Get(), &RenderThread::IdleHandler); | |
97 } | |
98 | |
99 RegisterExtension(new AppBindings(this), false); | 81 RegisterExtension(new AppBindings(this), false); |
100 RegisterExtension(ChromeWebstoreExtension::Get(), false); | 82 RegisterExtension(ChromeWebstoreExtension::Get(), false); |
101 | 83 |
102 // Add v8 extensions related to chrome extensions. | 84 // Add v8 extensions related to chrome extensions. |
103 RegisterExtension(new ChromeV8Extension( | 85 RegisterExtension(new ChromeV8Extension( |
104 "extensions/json_schema.js", IDR_JSON_SCHEMA_JS, NULL), true); | 86 "extensions/json_schema.js", IDR_JSON_SCHEMA_JS, NULL), true); |
105 RegisterExtension(EventBindings::Get(this), true); | 87 RegisterExtension(EventBindings::Get(this), true); |
106 RegisterExtension(new FileBrowserPrivateBindings(), true); | 88 RegisterExtension(new FileBrowserPrivateBindings(), true); |
107 RegisterExtension(MiscellaneousBindings::Get(this), true); | 89 RegisterExtension(MiscellaneousBindings::Get(this), true); |
108 RegisterExtension(SchemaGeneratedBindings::Get(this), true); | 90 RegisterExtension(SchemaGeneratedBindings::Get(this), true); |
109 RegisterExtension(new ChromeV8Extension( | 91 RegisterExtension(new ChromeV8Extension( |
110 "extensions/apitest.js", IDR_EXTENSION_APITEST_JS, NULL), true); | 92 "extensions/apitest.js", IDR_EXTENSION_APITEST_JS, NULL), true); |
111 | 93 |
112 // Initialize host permissions for any extensions that were activated before | 94 // Initialize host permissions for any extensions that were activated before |
113 // WebKit was initialized. | 95 // WebKit was initialized. |
114 for (std::set<std::string>::iterator iter = active_extension_ids_.begin(); | 96 for (std::set<std::string>::iterator iter = active_extension_ids_.begin(); |
115 iter != active_extension_ids_.end(); ++iter) { | 97 iter != active_extension_ids_.end(); ++iter) { |
116 const Extension* extension = extensions_.GetByID(*iter); | 98 const Extension* extension = extensions_.GetByID(*iter); |
117 if (extension) | 99 if (extension) |
118 InitOriginPermissions(extension); | 100 InitOriginPermissions(extension); |
119 } | 101 } |
120 | 102 |
121 is_webkit_initialized_ = true; | 103 is_webkit_initialized_ = true; |
122 } | 104 } |
123 | 105 |
124 void ExtensionDispatcher::IdleNotification() { | |
125 if (is_extension_process_) { | |
126 // Dampen the forced delay as well if the extension stays idle for long | |
127 // periods of time. | |
128 int64 forced_delay_ms = std::max( | |
129 RenderThread::Get()->GetIdleNotificationDelayInMs(), | |
130 kMaxExtensionIdleHandlerDelayMs); | |
131 forced_idle_timer_.Stop(); | |
132 forced_idle_timer_.Start(FROM_HERE, | |
133 base::TimeDelta::FromMilliseconds(forced_delay_ms), | |
134 RenderThread::Get(), &RenderThread::IdleHandler); | |
135 } | |
136 } | |
137 | |
138 void ExtensionDispatcher::OnSetFunctionNames( | 106 void ExtensionDispatcher::OnSetFunctionNames( |
139 const std::vector<std::string>& names) { | 107 const std::vector<std::string>& names) { |
140 function_names_.clear(); | 108 function_names_.clear(); |
141 for (size_t i = 0; i < names.size(); ++i) | 109 for (size_t i = 0; i < names.size(); ++i) |
142 function_names_.insert(names[i]); | 110 function_names_.insert(names[i]); |
143 } | 111 } |
144 | 112 |
145 void ExtensionDispatcher::OnMessageInvoke(const std::string& extension_id, | 113 void ExtensionDispatcher::OnMessageInvoke(const std::string& extension_id, |
146 const std::string& function_name, | 114 const std::string& function_name, |
147 const ListValue& args, | 115 const ListValue& args, |
148 const GURL& event_url) { | 116 const GURL& event_url) { |
149 v8_context_set_.DispatchChromeHiddenMethod( | 117 v8_context_set_.DispatchChromeHiddenMethod( |
150 extension_id, function_name, args, NULL, event_url); | 118 extension_id, function_name, args, NULL, event_url); |
151 | 119 |
152 // Reset the idle handler each time there's any activity like event or message | 120 // Reset the idle handler each time there's any activity like event or message |
153 // dispatch, for which Invoke is the chokepoint. | 121 // dispatch, for which Invoke is the chokepoint. |
154 if (is_extension_process_) { | 122 if (is_extension_process_) { |
Aaron Boodman
2011/11/23 22:52:20
Nit: the braces can go away now.
| |
155 RenderThread::Get()->ScheduleIdleHandler( | 123 RenderThread::Get()->ResetIdleTimer(); |
156 kInitialExtensionIdleHandlerDelayMs); | |
Matt Perry
2011/11/15 23:44:33
The point of this code was to prevent the idle han
| |
157 } | 124 } |
158 | 125 |
159 // Tell the browser process that the event is dispatched and we're idle. | 126 // Tell the browser process that the event is dispatched and we're idle. |
160 if (CommandLine::ForCurrentProcess()->HasSwitch( | 127 if (CommandLine::ForCurrentProcess()->HasSwitch( |
161 switches::kEnableLazyBackgroundPages) && | 128 switches::kEnableLazyBackgroundPages) && |
162 function_name == "Event.dispatchJSON") { // may always be true | 129 function_name == "Event.dispatchJSON") { // may always be true |
163 RenderThread::Get()->Send( | 130 RenderThread::Get()->Send( |
164 new ExtensionHostMsg_ExtensionEventAck(extension_id)); | 131 new ExtensionHostMsg_ExtensionEventAck(extension_id)); |
165 CheckIdleStatus(extension_id); | 132 CheckIdleStatus(extension_id); |
166 } | 133 } |
(...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
294 const std::string& extension_id) { | 261 const std::string& extension_id) { |
295 active_application_ids_.insert(extension_id); | 262 active_application_ids_.insert(extension_id); |
296 } | 263 } |
297 | 264 |
298 void ExtensionDispatcher::OnActivateExtension( | 265 void ExtensionDispatcher::OnActivateExtension( |
299 const std::string& extension_id) { | 266 const std::string& extension_id) { |
300 active_extension_ids_.insert(extension_id); | 267 active_extension_ids_.insert(extension_id); |
301 | 268 |
302 // This is called when starting a new extension page, so start the idle | 269 // This is called when starting a new extension page, so start the idle |
303 // handler ticking. | 270 // handler ticking. |
304 RenderThread::Get()->ScheduleIdleHandler(kInitialExtensionIdleHandlerDelayMs); | 271 RenderThread::Get()->ResetIdleTimer(); |
305 | 272 |
306 UpdateActiveExtensions(); | 273 UpdateActiveExtensions(); |
307 | 274 |
308 const Extension* extension = extensions_.GetByID(extension_id); | 275 const Extension* extension = extensions_.GetByID(extension_id); |
309 if (!extension) | 276 if (!extension) |
310 return; | 277 return; |
311 | 278 |
312 if (is_webkit_initialized_) | 279 if (is_webkit_initialized_) |
313 InitOriginPermissions(extension); | 280 InitOriginPermissions(extension); |
314 } | 281 } |
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
409 | 376 |
410 RenderThread::Get()->RegisterExtension(extension); | 377 RenderThread::Get()->RegisterExtension(extension); |
411 } | 378 } |
412 | 379 |
413 void ExtensionDispatcher::OnUsingWebRequestAPI( | 380 void ExtensionDispatcher::OnUsingWebRequestAPI( |
414 bool adblock, bool adblock_plus, bool other) { | 381 bool adblock, bool adblock_plus, bool other) { |
415 webrequest_adblock_ = adblock; | 382 webrequest_adblock_ = adblock; |
416 webrequest_adblock_plus_ = adblock_plus; | 383 webrequest_adblock_plus_ = adblock_plus; |
417 webrequest_other_ = other; | 384 webrequest_other_ = other; |
418 } | 385 } |
OLD | NEW |