OLD | NEW |
1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/browser/service_worker/service_worker_provider_host.h" | 5 #include "content/browser/service_worker/service_worker_provider_host.h" |
6 | 6 |
7 #include "base/stl_util.h" | 7 #include "base/stl_util.h" |
| 8 #include "content/browser/frame_host/frame_tree.h" |
| 9 #include "content/browser/frame_host/frame_tree_node.h" |
8 #include "content/browser/frame_host/render_frame_host_impl.h" | 10 #include "content/browser/frame_host/render_frame_host_impl.h" |
9 #include "content/browser/message_port_message_filter.h" | 11 #include "content/browser/message_port_message_filter.h" |
10 #include "content/browser/service_worker/service_worker_context_core.h" | 12 #include "content/browser/service_worker/service_worker_context_core.h" |
11 #include "content/browser/service_worker/service_worker_context_request_handler.
h" | 13 #include "content/browser/service_worker/service_worker_context_request_handler.
h" |
12 #include "content/browser/service_worker/service_worker_controllee_request_handl
er.h" | 14 #include "content/browser/service_worker/service_worker_controllee_request_handl
er.h" |
13 #include "content/browser/service_worker/service_worker_dispatcher_host.h" | 15 #include "content/browser/service_worker/service_worker_dispatcher_host.h" |
14 #include "content/browser/service_worker/service_worker_handle.h" | 16 #include "content/browser/service_worker/service_worker_handle.h" |
15 #include "content/browser/service_worker/service_worker_registration_handle.h" | 17 #include "content/browser/service_worker/service_worker_registration_handle.h" |
16 #include "content/browser/service_worker/service_worker_utils.h" | 18 #include "content/browser/service_worker/service_worker_utils.h" |
17 #include "content/browser/service_worker/service_worker_version.h" | 19 #include "content/browser/service_worker/service_worker_version.h" |
| 20 #include "content/browser/web_contents/web_contents_impl.h" |
18 #include "content/common/resource_request_body.h" | 21 #include "content/common/resource_request_body.h" |
19 #include "content/common/service_worker/service_worker_messages.h" | 22 #include "content/common/service_worker/service_worker_messages.h" |
20 #include "content/common/service_worker/service_worker_types.h" | 23 #include "content/common/service_worker/service_worker_types.h" |
21 #include "content/public/browser/render_frame_host.h" | 24 #include "content/public/browser/render_frame_host.h" |
| 25 #include "content/public/browser/render_widget_host_view.h" |
22 #include "content/public/browser/web_contents.h" | 26 #include "content/public/browser/web_contents.h" |
23 #include "content/public/browser/web_contents_delegate.h" | |
24 #include "content/public/common/child_process_host.h" | 27 #include "content/public/common/child_process_host.h" |
25 | 28 |
26 namespace content { | 29 namespace content { |
27 | 30 |
28 namespace { | 31 namespace { |
29 | 32 |
30 void FocusOnUIThread(int render_process_id, | |
31 int render_frame_id, | |
32 const ServiceWorkerProviderHost::FocusCallback& callback) { | |
33 WebContents* web_contents = WebContents::FromRenderFrameHost( | |
34 RenderFrameHost::FromID(render_process_id, render_frame_id)); | |
35 | |
36 bool result = false; | |
37 | |
38 if (web_contents && web_contents->GetDelegate()) { | |
39 result = true; | |
40 web_contents->GetDelegate()->ActivateContents(web_contents); | |
41 } | |
42 | |
43 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, | |
44 base::Bind(callback, result)); | |
45 } | |
46 | |
47 void GetClientInfoOnUIThread( | 33 void GetClientInfoOnUIThread( |
48 int render_process_id, | 34 int render_process_id, |
49 int render_frame_id, | 35 int render_frame_id, |
50 const ServiceWorkerProviderHost::GetClientInfoCallback& callback) { | 36 const ServiceWorkerProviderHost::GetClientInfoCallback& callback) { |
51 RenderFrameHostImpl* render_frame_host = | 37 RenderFrameHostImpl* render_frame_host = |
52 RenderFrameHostImpl::FromID(render_process_id, render_frame_id); | 38 RenderFrameHostImpl::FromID(render_process_id, render_frame_id); |
53 if (!render_frame_host) { | 39 if (!render_frame_host) { |
54 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, | 40 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, |
55 base::Bind(callback, ServiceWorkerClientInfo())); | 41 base::Bind(callback, ServiceWorkerClientInfo())); |
56 return; | 42 return; |
57 } | 43 } |
58 | 44 |
59 // TODO(mlamouri,michaeln): it is possible to end up collecting information | 45 // TODO(mlamouri,michaeln): it is possible to end up collecting information |
60 // for a frame that is actually being navigated and isn't exactly what we are | 46 // for a frame that is actually being navigated and isn't exactly what we are |
61 // expecting. | 47 // expecting. |
62 ServiceWorkerClientInfo client_info( | 48 ServiceWorkerClientInfo client_info( |
63 render_frame_host->GetVisibilityState(), | 49 render_frame_host->GetVisibilityState(), |
64 render_frame_host->IsFocused(), | 50 render_frame_host->IsFocused(), |
65 render_frame_host->GetLastCommittedURL(), | 51 render_frame_host->GetLastCommittedURL(), |
66 render_frame_host->GetParent() ? REQUEST_CONTEXT_FRAME_TYPE_NESTED | 52 render_frame_host->GetParent() ? REQUEST_CONTEXT_FRAME_TYPE_NESTED |
67 : REQUEST_CONTEXT_FRAME_TYPE_TOP_LEVEL); | 53 : REQUEST_CONTEXT_FRAME_TYPE_TOP_LEVEL); |
68 | 54 |
69 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, | 55 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, |
70 base::Bind(callback, client_info)); | 56 base::Bind(callback, client_info)); |
71 } | 57 } |
72 | 58 |
| 59 void FocusOnUIThread( |
| 60 int render_process_id, |
| 61 int render_frame_id, |
| 62 const ServiceWorkerProviderHost::GetClientInfoCallback& callback) { |
| 63 RenderFrameHostImpl* render_frame_host = |
| 64 RenderFrameHostImpl::FromID(render_process_id, render_frame_id); |
| 65 WebContentsImpl* web_contents = static_cast<WebContentsImpl*>( |
| 66 WebContents::FromRenderFrameHost(render_frame_host)); |
| 67 |
| 68 if (!render_frame_host || !web_contents) { |
| 69 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, |
| 70 base::Bind(callback, ServiceWorkerClientInfo())); |
| 71 return; |
| 72 } |
| 73 |
| 74 FrameTreeNode* frame_tree_node = render_frame_host->frame_tree_node(); |
| 75 |
| 76 // Focus the frame in the frame tree node, in case it has changed. |
| 77 frame_tree_node->frame_tree()->SetFocusedFrame(frame_tree_node); |
| 78 |
| 79 // Focus the frame's view to make sure the frame is now considered as focused. |
| 80 render_frame_host->GetView()->Focus(); |
| 81 |
| 82 // Move the web contents to the foreground. |
| 83 web_contents->Activate(); |
| 84 |
| 85 GetClientInfoOnUIThread(render_process_id, render_frame_id, callback); |
| 86 } |
| 87 |
73 } // anonymous namespace | 88 } // anonymous namespace |
74 | 89 |
75 ServiceWorkerProviderHost::ServiceWorkerProviderHost( | 90 ServiceWorkerProviderHost::ServiceWorkerProviderHost( |
76 int render_process_id, | 91 int render_process_id, |
77 int render_frame_id, | 92 int render_frame_id, |
78 int provider_id, | 93 int provider_id, |
79 base::WeakPtr<ServiceWorkerContextCore> context, | 94 base::WeakPtr<ServiceWorkerContextCore> context, |
80 ServiceWorkerDispatcherHost* dispatcher_host) | 95 ServiceWorkerDispatcherHost* dispatcher_host) |
81 : render_process_id_(render_process_id), | 96 : render_process_id_(render_process_id), |
82 render_frame_id_(render_frame_id), | 97 render_frame_id_(render_frame_id), |
(...skipping 195 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
278 UpdateMessagePortsWithNewRoutes(sent_message_port_ids, | 293 UpdateMessagePortsWithNewRoutes(sent_message_port_ids, |
279 &new_routing_ids); | 294 &new_routing_ids); |
280 | 295 |
281 Send(new ServiceWorkerMsg_MessageToDocument( | 296 Send(new ServiceWorkerMsg_MessageToDocument( |
282 kDocumentMainThreadId, provider_id(), | 297 kDocumentMainThreadId, provider_id(), |
283 message, | 298 message, |
284 sent_message_port_ids, | 299 sent_message_port_ids, |
285 new_routing_ids)); | 300 new_routing_ids)); |
286 } | 301 } |
287 | 302 |
288 void ServiceWorkerProviderHost::Focus(const FocusCallback& callback) { | 303 void ServiceWorkerProviderHost::Focus(const GetClientInfoCallback& callback) { |
289 BrowserThread::PostTask( | 304 BrowserThread::PostTask( |
290 BrowserThread::UI, FROM_HERE, | 305 BrowserThread::UI, FROM_HERE, |
291 base::Bind(&FocusOnUIThread, | 306 base::Bind(&FocusOnUIThread, |
292 render_process_id_, | 307 render_process_id_, |
293 render_frame_id_, | 308 render_frame_id_, |
294 callback)); | 309 callback)); |
295 } | 310 } |
296 | 311 |
297 void ServiceWorkerProviderHost::GetClientInfo( | 312 void ServiceWorkerProviderHost::GetClientInfo( |
298 const GetClientInfoCallback& callback) const { | 313 const GetClientInfoCallback& callback) const { |
(...skipping 199 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
498 return context_ != NULL; | 513 return context_ != NULL; |
499 } | 514 } |
500 | 515 |
501 void ServiceWorkerProviderHost::Send(IPC::Message* message) const { | 516 void ServiceWorkerProviderHost::Send(IPC::Message* message) const { |
502 DCHECK(dispatcher_host_); | 517 DCHECK(dispatcher_host_); |
503 DCHECK(IsReadyToSendMessages()); | 518 DCHECK(IsReadyToSendMessages()); |
504 dispatcher_host_->Send(message); | 519 dispatcher_host_->Send(message); |
505 } | 520 } |
506 | 521 |
507 } // namespace content | 522 } // namespace content |
OLD | NEW |