| 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_version.h" | 5 #include "content/browser/service_worker/service_worker_version.h" |
| 6 | 6 |
| 7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/location.h" | 8 #include "base/location.h" |
| 9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
| 10 #include "base/metrics/histogram_macros.h" | 10 #include "base/metrics/histogram_macros.h" |
| 11 #include "base/single_thread_task_runner.h" | 11 #include "base/single_thread_task_runner.h" |
| 12 #include "base/stl_util.h" | 12 #include "base/stl_util.h" |
| 13 #include "base/strings/string16.h" | 13 #include "base/strings/string16.h" |
| 14 #include "base/strings/utf_string_conversions.h" | 14 #include "base/strings/utf_string_conversions.h" |
| 15 #include "base/thread_task_runner_handle.h" | 15 #include "base/thread_task_runner_handle.h" |
| 16 #include "base/time/time.h" | 16 #include "base/time/time.h" |
| 17 #include "content/browser/bad_message.h" | 17 #include "content/browser/bad_message.h" |
| 18 #include "content/browser/child_process_security_policy_impl.h" | 18 #include "content/browser/child_process_security_policy_impl.h" |
| 19 #include "content/browser/message_port_message_filter.h" | 19 #include "content/browser/message_port_message_filter.h" |
| 20 #include "content/browser/message_port_service.h" | 20 #include "content/browser/message_port_service.h" |
| 21 #include "content/browser/service_worker/embedded_worker_instance.h" | 21 #include "content/browser/service_worker/embedded_worker_instance.h" |
| 22 #include "content/browser/service_worker/embedded_worker_registry.h" | 22 #include "content/browser/service_worker/embedded_worker_registry.h" |
| 23 #include "content/browser/service_worker/service_worker_context_core.h" | 23 #include "content/browser/service_worker/service_worker_context_core.h" |
| 24 #include "content/browser/service_worker/service_worker_context_wrapper.h" | 24 #include "content/browser/service_worker/service_worker_context_wrapper.h" |
| 25 #include "content/browser/service_worker/service_worker_metrics.h" | 25 #include "content/browser/service_worker/service_worker_metrics.h" |
| 26 #include "content/browser/service_worker/service_worker_mojo_event_dispatcher.h" |
| 26 #include "content/browser/service_worker/service_worker_registration.h" | 27 #include "content/browser/service_worker/service_worker_registration.h" |
| 27 #include "content/browser/service_worker/service_worker_utils.h" | 28 #include "content/browser/service_worker/service_worker_utils.h" |
| 28 #include "content/browser/service_worker/stashed_port_manager.h" | 29 #include "content/browser/service_worker/stashed_port_manager.h" |
| 29 #include "content/browser/storage_partition_impl.h" | 30 #include "content/browser/storage_partition_impl.h" |
| 30 #include "content/common/service_worker/service_worker_messages.h" | 31 #include "content/common/service_worker/service_worker_messages.h" |
| 31 #include "content/public/browser/browser_thread.h" | 32 #include "content/public/browser/browser_thread.h" |
| 32 #include "content/public/browser/content_browser_client.h" | 33 #include "content/public/browser/content_browser_client.h" |
| 33 #include "content/public/browser/page_navigator.h" | 34 #include "content/public/browser/page_navigator.h" |
| 34 #include "content/public/browser/render_frame_host.h" | 35 #include "content/public/browser/render_frame_host.h" |
| 35 #include "content/public/browser/render_process_host.h" | 36 #include "content/public/browser/render_process_host.h" |
| 36 #include "content/public/browser/web_contents.h" | 37 #include "content/public/browser/web_contents.h" |
| 37 #include "content/public/browser/web_contents_observer.h" | 38 #include "content/public/browser/web_contents_observer.h" |
| 38 #include "content/public/common/child_process_host.h" | 39 #include "content/public/common/child_process_host.h" |
| 39 #include "content/public/common/content_client.h" | 40 #include "content/public/common/content_client.h" |
| 40 #include "content/public/common/content_switches.h" | 41 #include "content/public/common/content_switches.h" |
| 41 #include "content/public/common/result_codes.h" | 42 #include "content/public/common/result_codes.h" |
| 43 #include "content/public/common/service_registry.h" |
| 42 #include "net/http/http_response_headers.h" | 44 #include "net/http/http_response_headers.h" |
| 43 #include "net/http/http_response_info.h" | 45 #include "net/http/http_response_info.h" |
| 44 | 46 |
| 45 namespace content { | 47 namespace content { |
| 46 | 48 |
| 47 using StatusCallback = ServiceWorkerVersion::StatusCallback; | 49 using StatusCallback = ServiceWorkerVersion::StatusCallback; |
| 48 using ServiceWorkerClients = std::vector<ServiceWorkerClientInfo>; | 50 using ServiceWorkerClients = std::vector<ServiceWorkerClientInfo>; |
| 49 using GetClientsCallback = | 51 using GetClientsCallback = |
| 50 base::Callback<void(scoped_ptr<ServiceWorkerClients>)>; | 52 base::Callback<void(scoped_ptr<ServiceWorkerClients>)>; |
| 51 | 53 |
| (...skipping 737 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 789 // Schedule calling this method after starting the worker. | 791 // Schedule calling this method after starting the worker. |
| 790 StartWorker(base::Bind(&RunTaskAfterStartWorker, | 792 StartWorker(base::Bind(&RunTaskAfterStartWorker, |
| 791 weak_factory_.GetWeakPtr(), callback, | 793 weak_factory_.GetWeakPtr(), callback, |
| 792 base::Bind(&self::DispatchSyncEvent, | 794 base::Bind(&self::DispatchSyncEvent, |
| 793 weak_factory_.GetWeakPtr(), | 795 weak_factory_.GetWeakPtr(), |
| 794 callback))); | 796 callback))); |
| 795 return; | 797 return; |
| 796 } | 798 } |
| 797 | 799 |
| 798 int request_id = AddRequest(callback, &sync_callbacks_, REQUEST_SYNC); | 800 int request_id = AddRequest(callback, &sync_callbacks_, REQUEST_SYNC); |
| 799 ServiceWorkerStatusCode status = embedded_worker_->SendMessage( | 801 ServiceWorkerMojoEventDispatcher* mojo_event_dispatcher = |
| 800 ServiceWorkerMsg_SyncEvent(request_id)); | 802 context_->GetMojoEventDispatcher(embedded_worker_->process_id()); |
| 801 if (status != SERVICE_WORKER_OK) { | 803 DCHECK(mojo_event_dispatcher); |
| 802 sync_callbacks_.Remove(request_id); | 804 mojo_event_dispatcher->DispatchSyncEvent( |
| 803 RunSoon(base::Bind(callback, status)); | 805 embedded_worker_->thread_id(), |
| 804 } | 806 base::Bind(&self::OnSyncEventFinished, weak_factory_.GetWeakPtr(), |
| 807 request_id)); |
| 805 } | 808 } |
| 806 | 809 |
| 807 void ServiceWorkerVersion::DispatchNotificationClickEvent( | 810 void ServiceWorkerVersion::DispatchNotificationClickEvent( |
| 808 const StatusCallback& callback, | 811 const StatusCallback& callback, |
| 809 int64_t persistent_notification_id, | 812 int64_t persistent_notification_id, |
| 810 const PlatformNotificationData& notification_data) { | 813 const PlatformNotificationData& notification_data) { |
| 811 DCHECK_EQ(ACTIVATED, status()) << status(); | 814 DCHECK_EQ(ACTIVATED, status()) << status(); |
| 812 if (running_status() != RUNNING) { | 815 if (running_status() != RUNNING) { |
| 813 // Schedule calling this method after starting the worker. | 816 // Schedule calling this method after starting the worker. |
| 814 StartWorker(base::Bind( | 817 StartWorker(base::Bind( |
| (...skipping 356 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1171 bool handled = true; | 1174 bool handled = true; |
| 1172 IPC_BEGIN_MESSAGE_MAP(ServiceWorkerVersion, message) | 1175 IPC_BEGIN_MESSAGE_MAP(ServiceWorkerVersion, message) |
| 1173 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_GetClients, | 1176 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_GetClients, |
| 1174 OnGetClients) | 1177 OnGetClients) |
| 1175 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_ActivateEventFinished, | 1178 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_ActivateEventFinished, |
| 1176 OnActivateEventFinished) | 1179 OnActivateEventFinished) |
| 1177 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_InstallEventFinished, | 1180 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_InstallEventFinished, |
| 1178 OnInstallEventFinished) | 1181 OnInstallEventFinished) |
| 1179 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_FetchEventFinished, | 1182 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_FetchEventFinished, |
| 1180 OnFetchEventFinished) | 1183 OnFetchEventFinished) |
| 1181 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_SyncEventFinished, | |
| 1182 OnSyncEventFinished) | |
| 1183 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_NotificationClickEventFinished, | 1184 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_NotificationClickEventFinished, |
| 1184 OnNotificationClickEventFinished) | 1185 OnNotificationClickEventFinished) |
| 1185 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_PushEventFinished, | 1186 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_PushEventFinished, |
| 1186 OnPushEventFinished) | 1187 OnPushEventFinished) |
| 1187 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_GeofencingEventFinished, | 1188 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_GeofencingEventFinished, |
| 1188 OnGeofencingEventFinished) | 1189 OnGeofencingEventFinished) |
| 1189 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_CrossOriginConnectEventFinished, | 1190 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_CrossOriginConnectEventFinished, |
| 1190 OnCrossOriginConnectEventFinished) | 1191 OnCrossOriginConnectEventFinished) |
| 1191 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_OpenWindow, | 1192 IPC_MESSAGE_HANDLER(ServiceWorkerHostMsg_OpenWindow, |
| 1192 OnOpenWindow) | 1193 OnOpenWindow) |
| (...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1344 | 1345 |
| 1345 // TODO(kinuko): Record other event statuses too. | 1346 // TODO(kinuko): Record other event statuses too. |
| 1346 const bool handled = (result == SERVICE_WORKER_FETCH_EVENT_RESULT_RESPONSE); | 1347 const bool handled = (result == SERVICE_WORKER_FETCH_EVENT_RESULT_RESPONSE); |
| 1347 metrics_->RecordEventStatus(handled); | 1348 metrics_->RecordEventStatus(handled); |
| 1348 | 1349 |
| 1349 scoped_refptr<ServiceWorkerVersion> protect(this); | 1350 scoped_refptr<ServiceWorkerVersion> protect(this); |
| 1350 callback->Run(SERVICE_WORKER_OK, result, response); | 1351 callback->Run(SERVICE_WORKER_OK, result, response); |
| 1351 RemoveCallbackAndStopIfRedundant(&fetch_callbacks_, request_id); | 1352 RemoveCallbackAndStopIfRedundant(&fetch_callbacks_, request_id); |
| 1352 } | 1353 } |
| 1353 | 1354 |
| 1354 void ServiceWorkerVersion::OnSyncEventFinished( | 1355 void ServiceWorkerVersion::OnSyncEventFinished(int request_id, |
| 1355 int request_id, | 1356 ServiceWorkerStatusCode status) { |
| 1356 blink::WebServiceWorkerEventResult result) { | |
| 1357 TRACE_EVENT1("ServiceWorker", | 1357 TRACE_EVENT1("ServiceWorker", |
| 1358 "ServiceWorkerVersion::OnSyncEventFinished", | 1358 "ServiceWorkerVersion::OnSyncEventFinished", |
| 1359 "Request id", request_id); | 1359 "Request id", request_id); |
| 1360 StatusCallback* callback = sync_callbacks_.Lookup(request_id); | 1360 StatusCallback* callback = sync_callbacks_.Lookup(request_id); |
| 1361 if (!callback) { | 1361 if (!callback) { |
| 1362 NOTREACHED() << "Got unexpected message: " << request_id; | 1362 NOTREACHED() << "Got unexpected message: " << request_id; |
| 1363 return; | 1363 return; |
| 1364 } | 1364 } |
| 1365 | 1365 |
| 1366 ServiceWorkerStatusCode status = SERVICE_WORKER_OK; | |
| 1367 if (result == blink::WebServiceWorkerEventResultRejected) { | |
| 1368 status = SERVICE_WORKER_ERROR_EVENT_WAITUNTIL_REJECTED; | |
| 1369 } | |
| 1370 | |
| 1371 scoped_refptr<ServiceWorkerVersion> protect(this); | 1366 scoped_refptr<ServiceWorkerVersion> protect(this); |
| 1372 callback->Run(status); | 1367 callback->Run(status); |
| 1373 RemoveCallbackAndStopIfRedundant(&sync_callbacks_, request_id); | 1368 RemoveCallbackAndStopIfRedundant(&sync_callbacks_, request_id); |
| 1374 } | 1369 } |
| 1375 | 1370 |
| 1376 void ServiceWorkerVersion::OnNotificationClickEventFinished( | 1371 void ServiceWorkerVersion::OnNotificationClickEventFinished( |
| 1377 int request_id) { | 1372 int request_id) { |
| 1378 TRACE_EVENT1("ServiceWorker", | 1373 TRACE_EVENT1("ServiceWorker", |
| 1379 "ServiceWorkerVersion::OnNotificationClickEventFinished", | 1374 "ServiceWorkerVersion::OnNotificationClickEventFinished", |
| 1380 "Request id", request_id); | 1375 "Request id", request_id); |
| (...skipping 777 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2158 | 2153 |
| 2159 streaming_url_request_jobs_.clear(); | 2154 streaming_url_request_jobs_.clear(); |
| 2160 | 2155 |
| 2161 FOR_EACH_OBSERVER(Listener, listeners_, OnRunningStateChanged(this)); | 2156 FOR_EACH_OBSERVER(Listener, listeners_, OnRunningStateChanged(this)); |
| 2162 | 2157 |
| 2163 if (should_restart) | 2158 if (should_restart) |
| 2164 StartWorkerInternal(false /* pause_after_download */); | 2159 StartWorkerInternal(false /* pause_after_download */); |
| 2165 } | 2160 } |
| 2166 | 2161 |
| 2167 } // namespace content | 2162 } // namespace content |
| OLD | NEW |