| 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/renderer/service_worker/embedded_worker_context_client.h" | 5 #include "content/renderer/service_worker/embedded_worker_context_client.h" |
| 6 | 6 |
| 7 #include "base/lazy_instance.h" | 7 #include "base/lazy_instance.h" |
| 8 #include "base/message_loop/message_loop_proxy.h" | 8 #include "base/message_loop/message_loop_proxy.h" |
| 9 #include "base/pickle.h" | 9 #include "base/pickle.h" |
| 10 #include "base/strings/string16.h" |
| 11 #include "base/strings/utf_string_conversions.h" |
| 10 #include "base/threading/thread_local.h" | 12 #include "base/threading/thread_local.h" |
| 11 #include "content/child/request_extra_data.h" | 13 #include "content/child/request_extra_data.h" |
| 12 #include "content/child/service_worker/service_worker_network_provider.h" | 14 #include "content/child/service_worker/service_worker_network_provider.h" |
| 13 #include "content/child/thread_safe_sender.h" | 15 #include "content/child/thread_safe_sender.h" |
| 14 #include "content/child/worker_task_runner.h" | 16 #include "content/child/worker_task_runner.h" |
| 15 #include "content/child/worker_thread_task_runner.h" | 17 #include "content/child/worker_thread_task_runner.h" |
| 16 #include "content/common/devtools_messages.h" | 18 #include "content/common/devtools_messages.h" |
| 17 #include "content/common/service_worker/embedded_worker_messages.h" | 19 #include "content/common/service_worker/embedded_worker_messages.h" |
| 18 #include "content/common/service_worker/service_worker_types.h" | 20 #include "content/common/service_worker/service_worker_types.h" |
| 19 #include "content/public/renderer/document_state.h" | 21 #include "content/public/renderer/document_state.h" |
| (...skipping 213 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 233 script_context_->DidHandleFetchEvent( | 235 script_context_->DidHandleFetchEvent( |
| 234 request_id, | 236 request_id, |
| 235 SERVICE_WORKER_FETCH_EVENT_RESULT_FALLBACK, | 237 SERVICE_WORKER_FETCH_EVENT_RESULT_FALLBACK, |
| 236 ServiceWorkerResponse()); | 238 ServiceWorkerResponse()); |
| 237 } | 239 } |
| 238 | 240 |
| 239 void EmbeddedWorkerContextClient::didHandleFetchEvent( | 241 void EmbeddedWorkerContextClient::didHandleFetchEvent( |
| 240 int request_id, | 242 int request_id, |
| 241 const blink::WebServiceWorkerResponse& web_response) { | 243 const blink::WebServiceWorkerResponse& web_response) { |
| 242 DCHECK(script_context_); | 244 DCHECK(script_context_); |
| 245 #ifdef NEW_SERVICE_WORKER_RESPONSE_INTERFACE |
| 246 std::map<std::string, std::string> headers; |
| 247 const blink::WebVector<blink::WebString>& header_keys = |
| 248 web_response.getHeaderKeys(); |
| 249 for (size_t i = 0; i < header_keys.size(); ++i) { |
| 250 const base::string16& key = header_keys[i]; |
| 251 headers[base::UTF16ToUTF8(key)] = |
| 252 base::UTF16ToUTF8(web_response.getHeader(key)); |
| 253 } |
| 254 ServiceWorkerResponse response(web_response.status(), |
| 255 web_response.statusText().utf8(), |
| 256 std::string(), |
| 257 headers); |
| 258 #else |
| 259 // TODO(kinuko): Cleanup this once blink side patch is rolled. |
| 243 ServiceWorkerResponse response(web_response.statusCode(), | 260 ServiceWorkerResponse response(web_response.statusCode(), |
| 244 web_response.statusText().utf8(), | 261 web_response.statusText().utf8(), |
| 245 web_response.method().utf8(), | 262 web_response.method().utf8(), |
| 246 std::map<std::string, std::string>()); | 263 std::map<std::string, std::string>()); |
| 264 #endif |
| 247 script_context_->DidHandleFetchEvent( | 265 script_context_->DidHandleFetchEvent( |
| 248 request_id, SERVICE_WORKER_FETCH_EVENT_RESULT_RESPONSE, response); | 266 request_id, SERVICE_WORKER_FETCH_EVENT_RESULT_RESPONSE, response); |
| 249 } | 267 } |
| 250 | 268 |
| 251 void EmbeddedWorkerContextClient::didHandleSyncEvent(int request_id) { | 269 void EmbeddedWorkerContextClient::didHandleSyncEvent(int request_id) { |
| 252 DCHECK(script_context_); | 270 DCHECK(script_context_); |
| 253 script_context_->DidHandleSyncEvent(request_id); | 271 script_context_->DidHandleSyncEvent(request_id); |
| 254 } | 272 } |
| 255 | 273 |
| 256 blink::WebServiceWorkerNetworkProvider* | 274 blink::WebServiceWorkerNetworkProvider* |
| (...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 295 } | 313 } |
| 296 | 314 |
| 297 void EmbeddedWorkerContextClient::SendWorkerStarted() { | 315 void EmbeddedWorkerContextClient::SendWorkerStarted() { |
| 298 DCHECK(worker_task_runner_->RunsTasksOnCurrentThread()); | 316 DCHECK(worker_task_runner_->RunsTasksOnCurrentThread()); |
| 299 Send(new EmbeddedWorkerHostMsg_WorkerStarted( | 317 Send(new EmbeddedWorkerHostMsg_WorkerStarted( |
| 300 WorkerTaskRunner::Instance()->CurrentWorkerId(), | 318 WorkerTaskRunner::Instance()->CurrentWorkerId(), |
| 301 embedded_worker_id_)); | 319 embedded_worker_id_)); |
| 302 } | 320 } |
| 303 | 321 |
| 304 } // namespace content | 322 } // namespace content |
| OLD | NEW |