| 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/render_frame_host_impl.h" |
| 8 #include "content/browser/message_port_message_filter.h" | 9 #include "content/browser/message_port_message_filter.h" |
| 9 #include "content/browser/service_worker/service_worker_context_core.h" | 10 #include "content/browser/service_worker/service_worker_context_core.h" |
| 10 #include "content/browser/service_worker/service_worker_context_request_handler.
h" | 11 #include "content/browser/service_worker/service_worker_context_request_handler.
h" |
| 11 #include "content/browser/service_worker/service_worker_controllee_request_handl
er.h" | 12 #include "content/browser/service_worker/service_worker_controllee_request_handl
er.h" |
| 12 #include "content/browser/service_worker/service_worker_dispatcher_host.h" | 13 #include "content/browser/service_worker/service_worker_dispatcher_host.h" |
| 13 #include "content/browser/service_worker/service_worker_handle.h" | 14 #include "content/browser/service_worker/service_worker_handle.h" |
| 14 #include "content/browser/service_worker/service_worker_registration_handle.h" | 15 #include "content/browser/service_worker/service_worker_registration_handle.h" |
| 15 #include "content/browser/service_worker/service_worker_utils.h" | 16 #include "content/browser/service_worker/service_worker_utils.h" |
| 16 #include "content/browser/service_worker/service_worker_version.h" | 17 #include "content/browser/service_worker/service_worker_version.h" |
| 17 #include "content/common/resource_request_body.h" | 18 #include "content/common/resource_request_body.h" |
| (...skipping 18 matching lines...) Expand all Loading... |
| 36 | 37 |
| 37 if (web_contents && web_contents->GetDelegate()) { | 38 if (web_contents && web_contents->GetDelegate()) { |
| 38 result = true; | 39 result = true; |
| 39 web_contents->GetDelegate()->ActivateContents(web_contents); | 40 web_contents->GetDelegate()->ActivateContents(web_contents); |
| 40 } | 41 } |
| 41 | 42 |
| 42 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, | 43 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, |
| 43 base::Bind(callback, result)); | 44 base::Bind(callback, result)); |
| 44 } | 45 } |
| 45 | 46 |
| 47 void GetClientInfoOnUIThread( |
| 48 int render_process_id, |
| 49 int render_frame_id, |
| 50 const ServiceWorkerProviderHost::GetClientInfoCallback& callback) { |
| 51 RenderFrameHostImpl* render_frame_host = |
| 52 RenderFrameHostImpl::FromID(render_process_id, render_frame_id); |
| 53 if (!render_frame_host) { |
| 54 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, |
| 55 base::Bind(callback, ServiceWorkerClientInfo())); |
| 56 return; |
| 57 } |
| 58 |
| 59 // 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 |
| 61 // expecting. |
| 62 ServiceWorkerClientInfo client_info( |
| 63 render_frame_host->GetVisibilityState(), |
| 64 render_frame_host->IsFocused(), |
| 65 render_frame_host->GetLastCommittedURL(), |
| 66 render_frame_host->GetParent() ? REQUEST_CONTEXT_FRAME_TYPE_NESTED |
| 67 : REQUEST_CONTEXT_FRAME_TYPE_TOP_LEVEL); |
| 68 |
| 69 BrowserThread::PostTask(BrowserThread::IO, FROM_HERE, |
| 70 base::Bind(callback, client_info)); |
| 71 } |
| 72 |
| 46 } // anonymous namespace | 73 } // anonymous namespace |
| 47 | 74 |
| 48 ServiceWorkerProviderHost::ServiceWorkerProviderHost( | 75 ServiceWorkerProviderHost::ServiceWorkerProviderHost( |
| 49 int render_process_id, | 76 int render_process_id, |
| 50 int render_frame_id, | 77 int render_frame_id, |
| 51 int provider_id, | 78 int provider_id, |
| 52 base::WeakPtr<ServiceWorkerContextCore> context, | 79 base::WeakPtr<ServiceWorkerContextCore> context, |
| 53 ServiceWorkerDispatcherHost* dispatcher_host) | 80 ServiceWorkerDispatcherHost* dispatcher_host) |
| 54 : render_process_id_(render_process_id), | 81 : render_process_id_(render_process_id), |
| 55 render_frame_id_(render_frame_id), | 82 render_frame_id_(render_frame_id), |
| (...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 263 void ServiceWorkerProviderHost::Focus(const FocusCallback& callback) { | 290 void ServiceWorkerProviderHost::Focus(const FocusCallback& callback) { |
| 264 BrowserThread::PostTask( | 291 BrowserThread::PostTask( |
| 265 BrowserThread::UI, FROM_HERE, | 292 BrowserThread::UI, FROM_HERE, |
| 266 base::Bind(&FocusOnUIThread, | 293 base::Bind(&FocusOnUIThread, |
| 267 render_process_id_, | 294 render_process_id_, |
| 268 render_frame_id_, | 295 render_frame_id_, |
| 269 callback)); | 296 callback)); |
| 270 } | 297 } |
| 271 | 298 |
| 272 void ServiceWorkerProviderHost::GetClientInfo( | 299 void ServiceWorkerProviderHost::GetClientInfo( |
| 273 int embedded_worker_id, | 300 const GetClientInfoCallback& callback) { |
| 274 int request_id) { | 301 BrowserThread::PostTask(BrowserThread::UI, FROM_HERE, |
| 275 Send(new ServiceWorkerMsg_GetClientInfo( | 302 base::Bind(&GetClientInfoOnUIThread, |
| 276 kDocumentMainThreadId, embedded_worker_id, request_id, provider_id())); | 303 render_process_id_, |
| 304 render_frame_id_, |
| 305 callback)); |
| 277 } | 306 } |
| 278 | 307 |
| 279 void ServiceWorkerProviderHost::AddScopedProcessReferenceToPattern( | 308 void ServiceWorkerProviderHost::AddScopedProcessReferenceToPattern( |
| 280 const GURL& pattern) { | 309 const GURL& pattern) { |
| 281 associated_patterns_.push_back(pattern); | 310 associated_patterns_.push_back(pattern); |
| 282 IncreaseProcessReference(pattern); | 311 IncreaseProcessReference(pattern); |
| 283 } | 312 } |
| 284 | 313 |
| 285 void ServiceWorkerProviderHost::PrepareForCrossSiteTransfer() { | 314 void ServiceWorkerProviderHost::PrepareForCrossSiteTransfer() { |
| 286 DCHECK_NE(ChildProcessHost::kInvalidUniqueID, render_process_id_); | 315 DCHECK_NE(ChildProcessHost::kInvalidUniqueID, render_process_id_); |
| (...skipping 171 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 458 return context_ != NULL; | 487 return context_ != NULL; |
| 459 } | 488 } |
| 460 | 489 |
| 461 void ServiceWorkerProviderHost::Send(IPC::Message* message) const { | 490 void ServiceWorkerProviderHost::Send(IPC::Message* message) const { |
| 462 DCHECK(dispatcher_host_); | 491 DCHECK(dispatcher_host_); |
| 463 DCHECK(IsReadyToSendMessages()); | 492 DCHECK(IsReadyToSendMessages()); |
| 464 dispatcher_host_->Send(message); | 493 dispatcher_host_->Send(message); |
| 465 } | 494 } |
| 466 | 495 |
| 467 } // namespace content | 496 } // namespace content |
| OLD | NEW |