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

Side by Side Diff: extensions/browser/extension_message_filter.cc

Issue 376033002: Adding MimeHandlerView. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@pending-zork-patch2
Patch Set: address comments from Fady Created 6 years, 3 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
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 #include "extensions/browser/extension_message_filter.h" 5 #include "extensions/browser/extension_message_filter.h"
6 6
7 #include "components/crx_file/id_util.h" 7 #include "components/crx_file/id_util.h"
8 #include "content/public/browser/browser_thread.h" 8 #include "content/public/browser/browser_thread.h"
9 #include "content/public/browser/render_frame_host.h"
9 #include "content/public/browser/render_process_host.h" 10 #include "content/public/browser/render_process_host.h"
10 #include "content/public/browser/resource_dispatcher_host.h" 11 #include "content/public/browser/resource_dispatcher_host.h"
12 #include "content/public/browser/render_view_host.h"
11 #include "extensions/browser/blob_holder.h" 13 #include "extensions/browser/blob_holder.h"
12 #include "extensions/browser/event_router.h" 14 #include "extensions/browser/event_router.h"
13 #include "extensions/browser/extension_function_dispatcher.h" 15 #include "extensions/browser/extension_function_dispatcher.h"
14 #include "extensions/browser/extension_system.h" 16 #include "extensions/browser/extension_system.h"
17 #include "extensions/browser/guest_view/guest_view_base.h"
15 #include "extensions/browser/guest_view/guest_view_manager.h" 18 #include "extensions/browser/guest_view/guest_view_manager.h"
16 #include "extensions/browser/info_map.h" 19 #include "extensions/browser/info_map.h"
17 #include "extensions/browser/process_manager.h" 20 #include "extensions/browser/process_manager.h"
18 #include "extensions/common/extension.h" 21 #include "extensions/common/extension.h"
19 #include "extensions/common/extension_messages.h" 22 #include "extensions/common/extension_messages.h"
20 #include "ipc/ipc_message_macros.h" 23 #include "ipc/ipc_message_macros.h"
21 24
22 using content::BrowserThread; 25 using content::BrowserThread;
23 using content::RenderProcessHost; 26 using content::RenderProcessHost;
24 27
(...skipping 14 matching lines...) Expand all
39 } 42 }
40 43
41 void ExtensionMessageFilter::OverrideThreadForMessage( 44 void ExtensionMessageFilter::OverrideThreadForMessage(
42 const IPC::Message& message, 45 const IPC::Message& message,
43 BrowserThread::ID* thread) { 46 BrowserThread::ID* thread) {
44 switch (message.type()) { 47 switch (message.type()) {
45 case ExtensionHostMsg_AddListener::ID: 48 case ExtensionHostMsg_AddListener::ID:
46 case ExtensionHostMsg_AttachGuest::ID: 49 case ExtensionHostMsg_AttachGuest::ID:
47 case ExtensionHostMsg_RemoveListener::ID: 50 case ExtensionHostMsg_RemoveListener::ID:
48 case ExtensionHostMsg_AddLazyListener::ID: 51 case ExtensionHostMsg_AddLazyListener::ID:
52 case ExtensionHostMsg_CreateMimeHandlerViewGuest::ID:
49 case ExtensionHostMsg_RemoveLazyListener::ID: 53 case ExtensionHostMsg_RemoveLazyListener::ID:
50 case ExtensionHostMsg_AddFilteredListener::ID: 54 case ExtensionHostMsg_AddFilteredListener::ID:
51 case ExtensionHostMsg_RemoveFilteredListener::ID: 55 case ExtensionHostMsg_RemoveFilteredListener::ID:
52 case ExtensionHostMsg_ShouldSuspendAck::ID: 56 case ExtensionHostMsg_ShouldSuspendAck::ID:
53 case ExtensionHostMsg_SuspendAck::ID: 57 case ExtensionHostMsg_SuspendAck::ID:
54 case ExtensionHostMsg_TransferBlobsAck::ID: 58 case ExtensionHostMsg_TransferBlobsAck::ID:
55 *thread = BrowserThread::UI; 59 *thread = BrowserThread::UI;
56 break; 60 break;
57 default: 61 default:
58 break; 62 break;
(...skipping 10 matching lines...) Expand all
69 bool handled = true; 73 bool handled = true;
70 IPC_BEGIN_MESSAGE_MAP(ExtensionMessageFilter, message) 74 IPC_BEGIN_MESSAGE_MAP(ExtensionMessageFilter, message)
71 IPC_MESSAGE_HANDLER(ExtensionHostMsg_AddListener, 75 IPC_MESSAGE_HANDLER(ExtensionHostMsg_AddListener,
72 OnExtensionAddListener) 76 OnExtensionAddListener)
73 IPC_MESSAGE_HANDLER(ExtensionHostMsg_RemoveListener, 77 IPC_MESSAGE_HANDLER(ExtensionHostMsg_RemoveListener,
74 OnExtensionRemoveListener) 78 OnExtensionRemoveListener)
75 IPC_MESSAGE_HANDLER(ExtensionHostMsg_AddLazyListener, 79 IPC_MESSAGE_HANDLER(ExtensionHostMsg_AddLazyListener,
76 OnExtensionAddLazyListener) 80 OnExtensionAddLazyListener)
77 IPC_MESSAGE_HANDLER(ExtensionHostMsg_AttachGuest, 81 IPC_MESSAGE_HANDLER(ExtensionHostMsg_AttachGuest,
78 OnExtensionAttachGuest) 82 OnExtensionAttachGuest)
83 IPC_MESSAGE_HANDLER(ExtensionHostMsg_CreateMimeHandlerViewGuest,
84 OnExtensionCreateMimeHandlerViewGuest)
79 IPC_MESSAGE_HANDLER(ExtensionHostMsg_RemoveLazyListener, 85 IPC_MESSAGE_HANDLER(ExtensionHostMsg_RemoveLazyListener,
80 OnExtensionRemoveLazyListener) 86 OnExtensionRemoveLazyListener)
81 IPC_MESSAGE_HANDLER(ExtensionHostMsg_AddFilteredListener, 87 IPC_MESSAGE_HANDLER(ExtensionHostMsg_AddFilteredListener,
82 OnExtensionAddFilteredListener) 88 OnExtensionAddFilteredListener)
83 IPC_MESSAGE_HANDLER(ExtensionHostMsg_RemoveFilteredListener, 89 IPC_MESSAGE_HANDLER(ExtensionHostMsg_RemoveFilteredListener,
84 OnExtensionRemoveFilteredListener) 90 OnExtensionRemoveFilteredListener)
85 IPC_MESSAGE_HANDLER(ExtensionHostMsg_ShouldSuspendAck, 91 IPC_MESSAGE_HANDLER(ExtensionHostMsg_ShouldSuspendAck,
86 OnExtensionShouldSuspendAck) 92 OnExtensionShouldSuspendAck)
87 IPC_MESSAGE_HANDLER(ExtensionHostMsg_SuspendAck, 93 IPC_MESSAGE_HANDLER(ExtensionHostMsg_SuspendAck,
88 OnExtensionSuspendAck) 94 OnExtensionSuspendAck)
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after
160 if (!manager) 166 if (!manager)
161 return; 167 return;
162 168
163 manager->AttachGuest(render_process_id_, 169 manager->AttachGuest(render_process_id_,
164 routing_id, 170 routing_id,
165 element_instance_id, 171 element_instance_id,
166 guest_instance_id, 172 guest_instance_id,
167 params); 173 params);
168 } 174 }
169 175
176 void ExtensionMessageFilter::OnExtensionCreateMimeHandlerViewGuest(
177 int render_frame_id,
178 const std::string& src,
179 const std::string& mime_type,
180 int element_instance_id) {
181 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
182 extensions::GuestViewManager* manager =
183 extensions::GuestViewManager::FromBrowserContext(browser_context_);
184 if (!manager)
185 return;
186
187 content::RenderFrameHost* rfh =
188 content::RenderFrameHost::FromID(render_process_id_, render_frame_id);
189 content::WebContents* embedder_web_contents =
190 content::WebContents::FromRenderFrameHost(rfh);
191 if (!embedder_web_contents)
192 return;
193
194 GuestViewManager::WebContentsCreatedCallback callback =
195 base::Bind(&ExtensionMessageFilter::MimeHandlerViewGuestCreatedCallback,
196 this,
197 element_instance_id,
198 render_process_id_,
199 render_frame_id,
200 src);
201 base::DictionaryValue create_params;
202 // TODO(lazyboy): "mimeType" in constant.
203 create_params.SetString("mimeType", mime_type);
204 // TODO(lazyboy): use MimeHandlerViewGuest::Type, cannot do this as
205 // MimeHandlerViewGuest is under chrome/ not extensions/.
206 manager->CreateGuest("mimehandler",
207 "",
208 embedder_web_contents,
209 create_params,
210 callback);
211 }
212
170 void ExtensionMessageFilter::OnExtensionRemoveLazyListener( 213 void ExtensionMessageFilter::OnExtensionRemoveLazyListener(
171 const std::string& extension_id, const std::string& event_name) { 214 const std::string& extension_id, const std::string& event_name) {
172 EventRouter* router = EventRouter::Get(browser_context_); 215 EventRouter* router = EventRouter::Get(browser_context_);
173 if (!router) 216 if (!router)
174 return; 217 return;
175 router->RemoveLazyEventListener(event_name, extension_id); 218 router->RemoveLazyEventListener(event_name, extension_id);
176 } 219 }
177 220
178 void ExtensionMessageFilter::OnExtensionAddFilteredListener( 221 void ExtensionMessageFilter::OnExtensionAddFilteredListener(
179 const std::string& extension_id, 222 const std::string& extension_id,
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after
245 DCHECK_CURRENTLY_ON(BrowserThread::IO); 288 DCHECK_CURRENTLY_ON(BrowserThread::IO);
246 ExtensionFunctionDispatcher::DispatchOnIOThread( 289 ExtensionFunctionDispatcher::DispatchOnIOThread(
247 extension_info_map_.get(), 290 extension_info_map_.get(),
248 browser_context_, 291 browser_context_,
249 render_process_id_, 292 render_process_id_,
250 weak_ptr_factory_.GetWeakPtr(), 293 weak_ptr_factory_.GetWeakPtr(),
251 routing_id, 294 routing_id,
252 params); 295 params);
253 } 296 }
254 297
298 void ExtensionMessageFilter::MimeHandlerViewGuestCreatedCallback(
299 int element_instance_id,
300 int embedder_render_process_id,
301 int embedder_render_frame_id,
302 const std::string& src,
303 content::WebContents* web_contents) {
304 extensions::GuestViewManager* manager =
305 extensions::GuestViewManager::FromBrowserContext(browser_context_);
306 if (!manager)
307 return;
308
309 extensions::GuestViewBase* guest_view =
310 extensions::GuestViewBase::FromWebContents(web_contents);
311 DCHECK(guest_view);
312 int guest_instance_id = guest_view->guest_instance_id();
313
314 content::RenderFrameHost* rfh =
315 content::RenderFrameHost::FromID(embedder_render_process_id,
316 embedder_render_frame_id);
317 if (!rfh)
318 return;
319
320 base::DictionaryValue attach_params;
321 attach_params.SetString("src", src);
322 manager->AttachGuest(embedder_render_process_id,
323 rfh->GetRenderViewHost()->GetRoutingID(),
324 element_instance_id,
325 guest_instance_id,
326 attach_params);
327
328 IPC::Message* msg = new ExtensionMsg_CreateMimeHandlerViewGuestACK(
329 element_instance_id);
330 msg->set_routing_id(rfh->GetRoutingID());
331 rfh->Send(msg);
332 }
333
255 } // namespace extensions 334 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698