OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/foreign_fetch_request_handler.h" | 5 #include "content/browser/service_worker/foreign_fetch_request_handler.h" |
6 | 6 |
| 7 #include <string> |
| 8 |
7 #include "base/macros.h" | 9 #include "base/macros.h" |
8 #include "content/browser/service_worker/service_worker_context_wrapper.h" | 10 #include "content/browser/service_worker/service_worker_context_wrapper.h" |
9 #include "content/browser/service_worker/service_worker_url_request_job.h" | 11 #include "content/browser/service_worker/service_worker_url_request_job.h" |
10 #include "content/common/resource_request_body.h" | 12 #include "content/common/resource_request_body.h" |
11 #include "content/common/service_worker/service_worker_utils.h" | 13 #include "content/common/service_worker/service_worker_utils.h" |
12 #include "net/url_request/url_request.h" | 14 #include "net/url_request/url_request.h" |
13 #include "net/url_request/url_request_interceptor.h" | 15 #include "net/url_request/url_request_interceptor.h" |
14 #include "storage/browser/blob/blob_storage_context.h" | 16 #include "storage/browser/blob/blob_storage_context.h" |
15 | 17 |
16 namespace content { | 18 namespace content { |
(...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
113 // TODO(mek): Determine if redirects should be able to be intercepted by | 115 // TODO(mek): Determine if redirects should be able to be intercepted by |
114 // other foreign fetch service workers. | 116 // other foreign fetch service workers. |
115 return nullptr; | 117 return nullptr; |
116 } | 118 } |
117 | 119 |
118 // It's for original request (A) or redirect case (B-a or B-b). | 120 // It's for original request (A) or redirect case (B-a or B-b). |
119 DCHECK(!job_.get() || job_->ShouldForwardToServiceWorker()); | 121 DCHECK(!job_.get() || job_->ShouldForwardToServiceWorker()); |
120 | 122 |
121 ServiceWorkerURLRequestJob* job = new ServiceWorkerURLRequestJob( | 123 ServiceWorkerURLRequestJob* job = new ServiceWorkerURLRequestJob( |
122 request, network_delegate, std::string(), blob_storage_context_, | 124 request, network_delegate, std::string(), blob_storage_context_, |
123 resource_context, request_mode_, credentials_mode_, redirect_mode_, false, | 125 resource_context, request_mode_, credentials_mode_, redirect_mode_, |
124 request_context_type_, frame_type_, body_, | 126 resource_type_, request_context_type_, frame_type_, body_, |
125 ServiceWorkerFetchType::FOREIGN_FETCH, this); | 127 ServiceWorkerFetchType::FOREIGN_FETCH, this); |
126 job_ = job->GetWeakPtr(); | 128 job_ = job->GetWeakPtr(); |
127 | 129 |
128 context_->FindReadyRegistrationForDocument( | 130 context_->FindReadyRegistrationForDocument( |
129 request->url(), | 131 request->url(), |
130 base::Bind(&ForeignFetchRequestHandler::DidFindRegistration, | 132 base::Bind(&ForeignFetchRequestHandler::DidFindRegistration, |
131 weak_factory_.GetWeakPtr(), job_)); | 133 weak_factory_.GetWeakPtr(), job_)); |
132 | 134 |
133 return job_.get(); | 135 return job_.get(); |
134 } | 136 } |
(...skipping 86 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
221 } | 223 } |
222 return target_worker_.get(); | 224 return target_worker_.get(); |
223 } | 225 } |
224 | 226 |
225 void ForeignFetchRequestHandler::ClearJob() { | 227 void ForeignFetchRequestHandler::ClearJob() { |
226 job_.reset(); | 228 job_.reset(); |
227 target_worker_ = nullptr; | 229 target_worker_ = nullptr; |
228 } | 230 } |
229 | 231 |
230 } // namespace content | 232 } // namespace content |
OLD | NEW |