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_dispatcher_host.h" | 5 #include "content/browser/service_worker/service_worker_dispatcher_host.h" |
6 | 6 |
7 #include "base/debug/trace_event.h" | 7 #include "base/debug/trace_event.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
9 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
10 #include "content/browser/message_port_message_filter.h" | 10 #include "content/browser/message_port_message_filter.h" |
(...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
162 if (channel_ready_) { | 162 if (channel_ready_) { |
163 BrowserMessageFilter::Send(message); | 163 BrowserMessageFilter::Send(message); |
164 // Don't bother passing through Send()'s result: it's not reliable. | 164 // Don't bother passing through Send()'s result: it's not reliable. |
165 return true; | 165 return true; |
166 } | 166 } |
167 | 167 |
168 pending_messages_.push_back(message); | 168 pending_messages_.push_back(message); |
169 return true; | 169 return true; |
170 } | 170 } |
171 | 171 |
| 172 ServiceWorkerRegistrationHandle* |
| 173 ServiceWorkerDispatcherHost::GetOrCreateRegistrationHandle( |
| 174 int provider_id, |
| 175 ServiceWorkerRegistration* registration) { |
| 176 ServiceWorkerRegistrationHandle* handle = |
| 177 FindRegistrationHandle(provider_id, registration->id()); |
| 178 if (handle) { |
| 179 handle->IncrementRefCount(); |
| 180 return handle; |
| 181 } |
| 182 |
| 183 scoped_ptr<ServiceWorkerRegistrationHandle> new_handle( |
| 184 new ServiceWorkerRegistrationHandle( |
| 185 GetContext()->AsWeakPtr(), this, provider_id, registration)); |
| 186 handle = new_handle.get(); |
| 187 RegisterServiceWorkerRegistrationHandle(new_handle.Pass()); |
| 188 return handle; |
| 189 } |
| 190 |
172 void ServiceWorkerDispatcherHost::RegisterServiceWorkerHandle( | 191 void ServiceWorkerDispatcherHost::RegisterServiceWorkerHandle( |
173 scoped_ptr<ServiceWorkerHandle> handle) { | 192 scoped_ptr<ServiceWorkerHandle> handle) { |
174 int handle_id = handle->handle_id(); | 193 int handle_id = handle->handle_id(); |
175 handles_.AddWithID(handle.release(), handle_id); | 194 handles_.AddWithID(handle.release(), handle_id); |
176 } | 195 } |
177 | 196 |
178 void ServiceWorkerDispatcherHost::RegisterServiceWorkerRegistrationHandle( | 197 void ServiceWorkerDispatcherHost::RegisterServiceWorkerRegistrationHandle( |
179 scoped_ptr<ServiceWorkerRegistrationHandle> handle) { | 198 scoped_ptr<ServiceWorkerRegistrationHandle> handle) { |
180 int handle_id = handle->handle_id(); | 199 int handle_id = handle->handle_id(); |
181 registration_handles_.AddWithID(handle.release(), handle_id); | 200 registration_handles_.AddWithID(handle.release(), handle_id); |
(...skipping 202 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
384 if (status != SERVICE_WORKER_OK) { | 403 if (status != SERVICE_WORKER_OK) { |
385 SendRegistrationError(thread_id, request_id, status); | 404 SendRegistrationError(thread_id, request_id, status); |
386 return; | 405 return; |
387 } | 406 } |
388 | 407 |
389 ServiceWorkerRegistration* registration = | 408 ServiceWorkerRegistration* registration = |
390 GetContext()->GetLiveRegistration(registration_id); | 409 GetContext()->GetLiveRegistration(registration_id); |
391 DCHECK(registration); | 410 DCHECK(registration); |
392 | 411 |
393 ServiceWorkerRegistrationHandle* handle = | 412 ServiceWorkerRegistrationHandle* handle = |
394 FindRegistrationHandle(provider_id, registration_id); | 413 GetOrCreateRegistrationHandle(provider_id, registration); |
395 ServiceWorkerRegistrationObjectInfo info; | |
396 if (handle) { | |
397 handle->IncrementRefCount(); | |
398 info = handle->GetObjectInfo(); | |
399 } else { | |
400 scoped_ptr<ServiceWorkerRegistrationHandle> new_handle( | |
401 new ServiceWorkerRegistrationHandle( | |
402 GetContext()->AsWeakPtr(), this, provider_id, registration)); | |
403 info = new_handle->GetObjectInfo(); | |
404 handle = new_handle.get(); | |
405 RegisterServiceWorkerRegistrationHandle(new_handle.Pass()); | |
406 } | |
407 | 414 |
408 ServiceWorkerVersionAttributes attrs; | 415 ServiceWorkerVersionAttributes attrs; |
409 attrs.installing = handle->CreateServiceWorkerHandleAndPass( | 416 attrs.installing = handle->CreateServiceWorkerHandleAndPass( |
410 registration->installing_version()); | 417 registration->installing_version()); |
411 attrs.waiting = handle->CreateServiceWorkerHandleAndPass( | 418 attrs.waiting = handle->CreateServiceWorkerHandleAndPass( |
412 registration->waiting_version()); | 419 registration->waiting_version()); |
413 attrs.active = handle->CreateServiceWorkerHandleAndPass( | 420 attrs.active = handle->CreateServiceWorkerHandleAndPass( |
414 registration->active_version()); | 421 registration->active_version()); |
415 | 422 |
416 Send(new ServiceWorkerMsg_ServiceWorkerRegistered( | 423 Send(new ServiceWorkerMsg_ServiceWorkerRegistered( |
417 thread_id, request_id, info, attrs)); | 424 thread_id, request_id, handle->GetObjectInfo(), attrs)); |
418 TRACE_EVENT_ASYNC_END2("ServiceWorker", | 425 TRACE_EVENT_ASYNC_END2("ServiceWorker", |
419 "ServiceWorkerDispatcherHost::RegisterServiceWorker", | 426 "ServiceWorkerDispatcherHost::RegisterServiceWorker", |
420 request_id, | 427 request_id, |
421 "Registration ID", registration_id, | 428 "Registration ID", registration_id, |
422 "Version ID", version_id); | 429 "Version ID", version_id); |
423 } | 430 } |
424 | 431 |
425 void ServiceWorkerDispatcherHost::OnWorkerReadyForInspection( | 432 void ServiceWorkerDispatcherHost::OnWorkerReadyForInspection( |
426 int embedded_worker_id) { | 433 int embedded_worker_id) { |
427 TRACE_EVENT0("ServiceWorker", | 434 TRACE_EVENT0("ServiceWorker", |
(...skipping 195 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
623 status, &error_type, &error_message); | 630 status, &error_type, &error_message); |
624 Send(new ServiceWorkerMsg_ServiceWorkerUnregistrationError( | 631 Send(new ServiceWorkerMsg_ServiceWorkerUnregistrationError( |
625 thread_id, request_id, error_type, error_message)); | 632 thread_id, request_id, error_type, error_message)); |
626 } | 633 } |
627 | 634 |
628 ServiceWorkerContextCore* ServiceWorkerDispatcherHost::GetContext() { | 635 ServiceWorkerContextCore* ServiceWorkerDispatcherHost::GetContext() { |
629 return context_wrapper_->context(); | 636 return context_wrapper_->context(); |
630 } | 637 } |
631 | 638 |
632 } // namespace content | 639 } // namespace content |
OLD | NEW |