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> | 7 #include <string> |
8 #include <utility> | 8 #include <utility> |
9 | 9 |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
11 #include "base/macros.h" | 11 #include "base/macros.h" |
12 #include "base/memory/ptr_util.h" | 12 #include "base/memory/ptr_util.h" |
13 #include "base/stl_util.h" | 13 #include "base/stl_util.h" |
14 #include "content/browser/service_worker/service_worker_context_wrapper.h" | 14 #include "content/browser/service_worker/service_worker_context_wrapper.h" |
15 #include "content/browser/service_worker/service_worker_response_info.h" | 15 #include "content/browser/service_worker/service_worker_response_info.h" |
16 #include "content/browser/service_worker/service_worker_url_request_job.h" | 16 #include "content/browser/service_worker/service_worker_url_request_job.h" |
17 #include "content/common/resource_request_body_impl.h" | |
18 #include "content/common/service_worker/service_worker_types.h" | 17 #include "content/common/service_worker/service_worker_types.h" |
19 #include "content/common/service_worker/service_worker_utils.h" | 18 #include "content/common/service_worker/service_worker_utils.h" |
20 #include "content/public/browser/content_browser_client.h" | 19 #include "content/public/browser/content_browser_client.h" |
21 #include "content/public/browser/resource_request_info.h" | 20 #include "content/public/browser/resource_request_info.h" |
22 #include "content/public/common/content_client.h" | 21 #include "content/public/common/content_client.h" |
23 #include "content/public/common/content_switches.h" | 22 #include "content/public/common/content_switches.h" |
24 #include "content/public/common/origin_trial_policy.h" | 23 #include "content/public/common/origin_trial_policy.h" |
| 24 #include "content/public/common/resource_request_body.h" |
25 #include "net/url_request/url_request.h" | 25 #include "net/url_request/url_request.h" |
26 #include "net/url_request/url_request_interceptor.h" | 26 #include "net/url_request/url_request_interceptor.h" |
27 #include "storage/browser/blob/blob_storage_context.h" | 27 #include "storage/browser/blob/blob_storage_context.h" |
28 | 28 |
29 namespace content { | 29 namespace content { |
30 | 30 |
31 namespace { | 31 namespace { |
32 | 32 |
33 int kUserDataKey; // Only address is used. | 33 int kUserDataKey; // Only address is used. |
34 | 34 |
(...skipping 37 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
72 storage::BlobStorageContext* blob_storage_context, | 72 storage::BlobStorageContext* blob_storage_context, |
73 int process_id, | 73 int process_id, |
74 int provider_id, | 74 int provider_id, |
75 ServiceWorkerMode service_worker_mode, | 75 ServiceWorkerMode service_worker_mode, |
76 FetchRequestMode request_mode, | 76 FetchRequestMode request_mode, |
77 FetchCredentialsMode credentials_mode, | 77 FetchCredentialsMode credentials_mode, |
78 FetchRedirectMode redirect_mode, | 78 FetchRedirectMode redirect_mode, |
79 ResourceType resource_type, | 79 ResourceType resource_type, |
80 RequestContextType request_context_type, | 80 RequestContextType request_context_type, |
81 RequestContextFrameType frame_type, | 81 RequestContextFrameType frame_type, |
82 scoped_refptr<ResourceRequestBodyImpl> body, | 82 scoped_refptr<ResourceRequestBody> body, |
83 bool initiated_in_secure_context) { | 83 bool initiated_in_secure_context) { |
84 if (!IsForeignFetchEnabled()) | 84 if (!IsForeignFetchEnabled()) |
85 return; | 85 return; |
86 | 86 |
87 if (!context_wrapper || !context_wrapper->context() || | 87 if (!context_wrapper || !context_wrapper->context() || |
88 provider_id == kInvalidServiceWorkerProviderId) { | 88 provider_id == kInvalidServiceWorkerProviderId) { |
89 return; | 89 return; |
90 } | 90 } |
91 | 91 |
92 if (service_worker_mode == ServiceWorkerMode::NONE) | 92 if (service_worker_mode == ServiceWorkerMode::NONE) |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
197 | 197 |
198 ForeignFetchRequestHandler::ForeignFetchRequestHandler( | 198 ForeignFetchRequestHandler::ForeignFetchRequestHandler( |
199 ServiceWorkerContextWrapper* context, | 199 ServiceWorkerContextWrapper* context, |
200 base::WeakPtr<storage::BlobStorageContext> blob_storage_context, | 200 base::WeakPtr<storage::BlobStorageContext> blob_storage_context, |
201 FetchRequestMode request_mode, | 201 FetchRequestMode request_mode, |
202 FetchCredentialsMode credentials_mode, | 202 FetchCredentialsMode credentials_mode, |
203 FetchRedirectMode redirect_mode, | 203 FetchRedirectMode redirect_mode, |
204 ResourceType resource_type, | 204 ResourceType resource_type, |
205 RequestContextType request_context_type, | 205 RequestContextType request_context_type, |
206 RequestContextFrameType frame_type, | 206 RequestContextFrameType frame_type, |
207 scoped_refptr<ResourceRequestBodyImpl> body, | 207 scoped_refptr<ResourceRequestBody> body, |
208 const base::Optional<base::TimeDelta>& timeout) | 208 const base::Optional<base::TimeDelta>& timeout) |
209 : context_(context), | 209 : context_(context), |
210 blob_storage_context_(blob_storage_context), | 210 blob_storage_context_(blob_storage_context), |
211 resource_type_(resource_type), | 211 resource_type_(resource_type), |
212 request_mode_(request_mode), | 212 request_mode_(request_mode), |
213 credentials_mode_(credentials_mode), | 213 credentials_mode_(credentials_mode), |
214 redirect_mode_(redirect_mode), | 214 redirect_mode_(redirect_mode), |
215 request_context_type_(request_context_type), | 215 request_context_type_(request_context_type), |
216 frame_type_(frame_type), | 216 frame_type_(frame_type), |
217 body_(body), | 217 body_(body), |
(...skipping 87 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
305 // The worker entry in the database was written by old version Chrome (< M56) | 305 // The worker entry in the database was written by old version Chrome (< M56) |
306 // and the main script was not loaded yet. In this case, we can't check the | 306 // and the main script was not loaded yet. In this case, we can't check the |
307 // origin trial token. | 307 // origin trial token. |
308 if (!active_version->origin_trial_tokens()) | 308 if (!active_version->origin_trial_tokens()) |
309 return true; | 309 return true; |
310 const auto& token_map = *active_version->origin_trial_tokens(); | 310 const auto& token_map = *active_version->origin_trial_tokens(); |
311 return base::ContainsKey(token_map, "ForeignFetch"); | 311 return base::ContainsKey(token_map, "ForeignFetch"); |
312 } | 312 } |
313 | 313 |
314 } // namespace content | 314 } // namespace content |
OLD | NEW |