OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 // See http://dev.chromium.org/developers/design-documents/multi-process-resourc
e-loading | 5 // See http://dev.chromium.org/developers/design-documents/multi-process-resourc
e-loading |
6 | 6 |
7 #include "content/browser/loader/resource_dispatcher_host_impl.h" | 7 #include "content/browser/loader/resource_dispatcher_host_impl.h" |
8 | 8 |
9 #include <set> | 9 #include <set> |
10 #include <vector> | 10 #include <vector> |
(...skipping 22 matching lines...) Expand all Loading... |
33 #include "content/browser/loader/async_resource_handler.h" | 33 #include "content/browser/loader/async_resource_handler.h" |
34 #include "content/browser/loader/buffered_resource_handler.h" | 34 #include "content/browser/loader/buffered_resource_handler.h" |
35 #include "content/browser/loader/cross_site_resource_handler.h" | 35 #include "content/browser/loader/cross_site_resource_handler.h" |
36 #include "content/browser/loader/power_save_block_resource_throttle.h" | 36 #include "content/browser/loader/power_save_block_resource_throttle.h" |
37 #include "content/browser/loader/redirect_to_file_resource_handler.h" | 37 #include "content/browser/loader/redirect_to_file_resource_handler.h" |
38 #include "content/browser/loader/resource_message_filter.h" | 38 #include "content/browser/loader/resource_message_filter.h" |
39 #include "content/browser/loader/resource_request_info_impl.h" | 39 #include "content/browser/loader/resource_request_info_impl.h" |
40 #include "content/browser/loader/stream_resource_handler.h" | 40 #include "content/browser/loader/stream_resource_handler.h" |
41 #include "content/browser/loader/sync_resource_handler.h" | 41 #include "content/browser/loader/sync_resource_handler.h" |
42 #include "content/browser/loader/throttling_resource_handler.h" | 42 #include "content/browser/loader/throttling_resource_handler.h" |
43 #include "content/browser/loader/transfer_navigation_resource_throttle.h" | |
44 #include "content/browser/loader/upload_data_stream_builder.h" | 43 #include "content/browser/loader/upload_data_stream_builder.h" |
45 #include "content/browser/plugin_service_impl.h" | 44 #include "content/browser/plugin_service_impl.h" |
46 #include "content/browser/renderer_host/render_view_host_delegate.h" | 45 #include "content/browser/renderer_host/render_view_host_delegate.h" |
47 #include "content/browser/renderer_host/render_view_host_impl.h" | 46 #include "content/browser/renderer_host/render_view_host_impl.h" |
48 #include "content/browser/resource_context_impl.h" | 47 #include "content/browser/resource_context_impl.h" |
49 #include "content/browser/streams/stream.h" | 48 #include "content/browser/streams/stream.h" |
50 #include "content/browser/streams/stream_context.h" | 49 #include "content/browser/streams/stream_context.h" |
51 #include "content/browser/streams/stream_registry.h" | 50 #include "content/browser/streams/stream_registry.h" |
52 #include "content/browser/worker_host/worker_service_impl.h" | 51 #include "content/browser/worker_host/worker_service_impl.h" |
53 #include "content/common/resource_messages.h" | 52 #include "content/common/resource_messages.h" |
(...skipping 982 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1036 handler.reset(new AsyncResourceHandler( | 1035 handler.reset(new AsyncResourceHandler( |
1037 filter_, route_id, request, this)); | 1036 filter_, route_id, request, this)); |
1038 } | 1037 } |
1039 | 1038 |
1040 // The RedirectToFileResourceHandler depends on being next in the chain. | 1039 // The RedirectToFileResourceHandler depends on being next in the chain. |
1041 if (request_data.download_to_file) { | 1040 if (request_data.download_to_file) { |
1042 handler.reset( | 1041 handler.reset( |
1043 new RedirectToFileResourceHandler(handler.Pass(), child_id, this)); | 1042 new RedirectToFileResourceHandler(handler.Pass(), child_id, this)); |
1044 } | 1043 } |
1045 | 1044 |
1046 // Install a CrossSiteResourceHandler if this request is coming from a | 1045 // Install a CrossSiteResourceHandler for all main frame requests. This will |
1047 // RenderViewHost with a pending cross-site request. We only check this for | 1046 // let us check whether a transfer is required and pause for the unload |
1048 // MAIN_FRAME requests. Unblock requests only come from a blocked page, do | 1047 // handler either if so or if a cross-process navigation is already under way. |
1049 // not count as cross-site, otherwise it gets blocked indefinitely. | 1048 // We skip this if we have a deferred_loader, since we have already gone |
| 1049 // through the transition in that case. |
1050 if (request_data.resource_type == ResourceType::MAIN_FRAME && | 1050 if (request_data.resource_type == ResourceType::MAIN_FRAME && |
1051 process_type == PROCESS_TYPE_RENDERER && | 1051 process_type == PROCESS_TYPE_RENDERER && |
1052 CrossSiteRequestManager::GetInstance()-> | 1052 !deferred_loader.get()) { |
1053 HasPendingCrossSiteRequest(child_id, route_id)) { | |
1054 // Wrap the event handler to be sure the current page's onunload handler | |
1055 // has a chance to run before we render the new page. | |
1056 handler.reset(new CrossSiteResourceHandler(handler.Pass(), child_id, | 1053 handler.reset(new CrossSiteResourceHandler(handler.Pass(), child_id, |
1057 route_id, request)); | 1054 route_id, request)); |
1058 } | 1055 } |
1059 | 1056 |
1060 // Insert a buffered event handler before the actual one. | 1057 // Insert a buffered event handler before the actual one. |
1061 handler.reset( | 1058 handler.reset( |
1062 new BufferedResourceHandler(handler.Pass(), this, request)); | 1059 new BufferedResourceHandler(handler.Pass(), this, request)); |
1063 | 1060 |
1064 ScopedVector<ResourceThrottle> throttles; | 1061 ScopedVector<ResourceThrottle> throttles; |
1065 if (delegate_) { | 1062 if (delegate_) { |
1066 bool is_continuation_of_transferred_request = | 1063 bool is_continuation_of_transferred_request = |
1067 (deferred_loader.get() != NULL); | 1064 (deferred_loader.get() != NULL); |
1068 | 1065 |
1069 delegate_->RequestBeginning(request, | 1066 delegate_->RequestBeginning(request, |
1070 resource_context, | 1067 resource_context, |
1071 filter_->appcache_service(), | 1068 filter_->appcache_service(), |
1072 request_data.resource_type, | 1069 request_data.resource_type, |
1073 child_id, | 1070 child_id, |
1074 route_id, | 1071 route_id, |
1075 is_continuation_of_transferred_request, | 1072 is_continuation_of_transferred_request, |
1076 &throttles); | 1073 &throttles); |
1077 } | 1074 } |
1078 | 1075 |
1079 if (request->has_upload()) { | 1076 if (request->has_upload()) { |
1080 // Block power save while uploading data. | 1077 // Block power save while uploading data. |
1081 throttles.push_back(new PowerSaveBlockResourceThrottle()); | 1078 throttles.push_back(new PowerSaveBlockResourceThrottle()); |
1082 } | 1079 } |
1083 | 1080 |
1084 if (request_data.resource_type == ResourceType::MAIN_FRAME) { | |
1085 throttles.insert( | |
1086 throttles.begin(), | |
1087 new TransferNavigationResourceThrottle(request)); | |
1088 } | |
1089 | |
1090 throttles.push_back( | 1081 throttles.push_back( |
1091 scheduler_->ScheduleRequest(child_id, route_id, request).release()); | 1082 scheduler_->ScheduleRequest(child_id, route_id, request).release()); |
1092 | 1083 |
1093 handler.reset( | 1084 handler.reset( |
1094 new ThrottlingResourceHandler(handler.Pass(), child_id, request_id, | 1085 new ThrottlingResourceHandler(handler.Pass(), child_id, request_id, |
1095 throttles.Pass())); | 1086 throttles.Pass())); |
1096 | 1087 |
1097 if (deferred_loader.get()) { | 1088 if (deferred_loader.get()) { |
1098 pending_loaders_[extra_info->GetGlobalRequestID()] = deferred_loader; | 1089 pending_loaders_[extra_info->GetGlobalRequestID()] = deferred_loader; |
1099 IncrementOutstandingRequestsMemory(1, *extra_info); | 1090 IncrementOutstandingRequestsMemory(1, *extra_info); |
(...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1177 PAGE_TRANSITION_LINK, | 1168 PAGE_TRANSITION_LINK, |
1178 download, // is_download | 1169 download, // is_download |
1179 false, // is_stream | 1170 false, // is_stream |
1180 download, // allow_download | 1171 download, // allow_download |
1181 false, // has_user_gesture | 1172 false, // has_user_gesture |
1182 WebKit::WebReferrerPolicyDefault, | 1173 WebKit::WebReferrerPolicyDefault, |
1183 context, | 1174 context, |
1184 true); // is_async | 1175 true); // is_async |
1185 } | 1176 } |
1186 | 1177 |
1187 | |
1188 void ResourceDispatcherHostImpl::OnDidLoadResourceFromMemoryCache( | 1178 void ResourceDispatcherHostImpl::OnDidLoadResourceFromMemoryCache( |
1189 const GURL& url, | 1179 const GURL& url, |
1190 const std::string& security_info, | 1180 const std::string& security_info, |
1191 const std::string& http_method, | 1181 const std::string& http_method, |
1192 const std::string& mime_type, | 1182 const std::string& mime_type, |
1193 ResourceType::Type resource_type) { | 1183 ResourceType::Type resource_type) { |
1194 if (!url.is_valid() || !(url.SchemeIs("http") || url.SchemeIs("https"))) | 1184 if (!url.is_valid() || !(url.SchemeIs("http") || url.SchemeIs("https"))) |
1195 return; | 1185 return; |
1196 | 1186 |
1197 filter_->GetURLRequestContext(resource_type)->http_transaction_factory()-> | 1187 filter_->GetURLRequestContext(resource_type)->http_transaction_factory()-> |
(...skipping 673 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1871 if ((load_flags & net::LOAD_REPORT_RAW_HEADERS) | 1861 if ((load_flags & net::LOAD_REPORT_RAW_HEADERS) |
1872 && !policy->CanReadRawCookies(child_id)) { | 1862 && !policy->CanReadRawCookies(child_id)) { |
1873 VLOG(1) << "Denied unauthorized request for raw headers"; | 1863 VLOG(1) << "Denied unauthorized request for raw headers"; |
1874 load_flags &= ~net::LOAD_REPORT_RAW_HEADERS; | 1864 load_flags &= ~net::LOAD_REPORT_RAW_HEADERS; |
1875 } | 1865 } |
1876 | 1866 |
1877 return load_flags; | 1867 return load_flags; |
1878 } | 1868 } |
1879 | 1869 |
1880 } // namespace content | 1870 } // namespace content |
OLD | NEW |