| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/shared_worker/embedded_shared_worker_stub.h" | 5 #include "content/renderer/shared_worker/embedded_shared_worker_stub.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 #include <utility> | 8 #include <utility> |
| 9 | 9 |
| 10 #include "base/thread_task_runner_handle.h" | 10 #include "base/thread_task_runner_handle.h" |
| (...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 76 // Called on the main thread only and blink owns it. | 76 // Called on the main thread only and blink owns it. |
| 77 class WebServiceWorkerNetworkProviderImpl | 77 class WebServiceWorkerNetworkProviderImpl |
| 78 : public blink::WebServiceWorkerNetworkProvider { | 78 : public blink::WebServiceWorkerNetworkProvider { |
| 79 public: | 79 public: |
| 80 // Blink calls this method for each request starting with the main script, | 80 // Blink calls this method for each request starting with the main script, |
| 81 // we tag them with the provider id. | 81 // we tag them with the provider id. |
| 82 void willSendRequest(blink::WebDataSource* data_source, | 82 void willSendRequest(blink::WebDataSource* data_source, |
| 83 blink::WebURLRequest& request) override { | 83 blink::WebURLRequest& request) override { |
| 84 ServiceWorkerNetworkProvider* provider = | 84 ServiceWorkerNetworkProvider* provider = |
| 85 GetNetworkProviderFromDataSource(data_source); | 85 GetNetworkProviderFromDataSource(data_source); |
| 86 scoped_ptr<RequestExtraData> extra_data(new RequestExtraData); | 86 std::unique_ptr<RequestExtraData> extra_data(new RequestExtraData); |
| 87 extra_data->set_service_worker_provider_id(provider->provider_id()); | 87 extra_data->set_service_worker_provider_id(provider->provider_id()); |
| 88 request.setExtraData(extra_data.release()); | 88 request.setExtraData(extra_data.release()); |
| 89 // Explicitly set the SkipServiceWorker flag for subresources here if the | 89 // Explicitly set the SkipServiceWorker flag for subresources here if the |
| 90 // renderer process hasn't received SetControllerServiceWorker message. | 90 // renderer process hasn't received SetControllerServiceWorker message. |
| 91 if (request.getRequestContext() != | 91 if (request.getRequestContext() != |
| 92 blink::WebURLRequest::RequestContextSharedWorker && | 92 blink::WebURLRequest::RequestContextSharedWorker && |
| 93 !provider->IsControlledByServiceWorker()) { | 93 !provider->IsControlledByServiceWorker()) { |
| 94 request.setSkipServiceWorker(true); | 94 request.setSkipServiceWorker(true); |
| 95 } | 95 } |
| 96 } | 96 } |
| (...skipping 135 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 232 origin.isUnique(), | 232 origin.isUnique(), |
| 233 route_id_, | 233 route_id_, |
| 234 ChildThreadImpl::current()->thread_safe_sender()); | 234 ChildThreadImpl::current()->thread_safe_sender()); |
| 235 } | 235 } |
| 236 | 236 |
| 237 blink::WebServiceWorkerNetworkProvider* | 237 blink::WebServiceWorkerNetworkProvider* |
| 238 EmbeddedSharedWorkerStub::createServiceWorkerNetworkProvider( | 238 EmbeddedSharedWorkerStub::createServiceWorkerNetworkProvider( |
| 239 blink::WebDataSource* data_source) { | 239 blink::WebDataSource* data_source) { |
| 240 // Create a content::ServiceWorkerNetworkProvider for this data source so | 240 // Create a content::ServiceWorkerNetworkProvider for this data source so |
| 241 // we can observe its requests. | 241 // we can observe its requests. |
| 242 scoped_ptr<ServiceWorkerNetworkProvider> provider( | 242 std::unique_ptr<ServiceWorkerNetworkProvider> provider( |
| 243 new ServiceWorkerNetworkProvider( | 243 new ServiceWorkerNetworkProvider( |
| 244 route_id_, SERVICE_WORKER_PROVIDER_FOR_SHARED_WORKER)); | 244 route_id_, SERVICE_WORKER_PROVIDER_FOR_SHARED_WORKER)); |
| 245 | 245 |
| 246 // The provider is kept around for the lifetime of the DataSource | 246 // The provider is kept around for the lifetime of the DataSource |
| 247 // and ownership is transferred to the DataSource. | 247 // and ownership is transferred to the DataSource. |
| 248 DataSourceExtraData* extra_data = new DataSourceExtraData(); | 248 DataSourceExtraData* extra_data = new DataSourceExtraData(); |
| 249 data_source->setExtraData(extra_data); | 249 data_source->setExtraData(extra_data); |
| 250 ServiceWorkerNetworkProvider::AttachToDocumentState(extra_data, | 250 ServiceWorkerNetworkProvider::AttachToDocumentState(extra_data, |
| 251 std::move(provider)); | 251 std::move(provider)); |
| 252 | 252 |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 298 } | 298 } |
| 299 } | 299 } |
| 300 | 300 |
| 301 void EmbeddedSharedWorkerStub::OnTerminateWorkerContext() { | 301 void EmbeddedSharedWorkerStub::OnTerminateWorkerContext() { |
| 302 // After this we wouldn't get any IPC for this stub. | 302 // After this we wouldn't get any IPC for this stub. |
| 303 running_ = false; | 303 running_ = false; |
| 304 impl_->terminateWorkerContext(); | 304 impl_->terminateWorkerContext(); |
| 305 } | 305 } |
| 306 | 306 |
| 307 } // namespace content | 307 } // namespace content |
| OLD | NEW |