| 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/plugin_service_impl.h" | 43 #include "content/browser/plugin_service_impl.h" |
| 45 #include "content/browser/renderer_host/render_view_host_delegate.h" | 44 #include "content/browser/renderer_host/render_view_host_delegate.h" |
| 46 #include "content/browser/renderer_host/render_view_host_impl.h" | 45 #include "content/browser/renderer_host/render_view_host_impl.h" |
| 47 #include "content/browser/resource_context_impl.h" | 46 #include "content/browser/resource_context_impl.h" |
| 48 #include "content/browser/streams/stream.h" | 47 #include "content/browser/streams/stream.h" |
| 49 #include "content/browser/streams/stream_context.h" | 48 #include "content/browser/streams/stream_context.h" |
| 50 #include "content/browser/streams/stream_registry.h" | 49 #include "content/browser/streams/stream_registry.h" |
| 51 #include "content/browser/worker_host/worker_service_impl.h" | 50 #include "content/browser/worker_host/worker_service_impl.h" |
| 52 #include "content/common/resource_messages.h" | 51 #include "content/common/resource_messages.h" |
| 53 #include "content/common/ssl_status_serialization.h" | 52 #include "content/common/ssl_status_serialization.h" |
| (...skipping 1010 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1064 handler.reset(new AsyncResourceHandler( | 1063 handler.reset(new AsyncResourceHandler( |
| 1065 filter_, route_id, request, this)); | 1064 filter_, route_id, request, this)); |
| 1066 } | 1065 } |
| 1067 | 1066 |
| 1068 // The RedirectToFileResourceHandler depends on being next in the chain. | 1067 // The RedirectToFileResourceHandler depends on being next in the chain. |
| 1069 if (request_data.download_to_file) { | 1068 if (request_data.download_to_file) { |
| 1070 handler.reset( | 1069 handler.reset( |
| 1071 new RedirectToFileResourceHandler(handler.Pass(), child_id, this)); | 1070 new RedirectToFileResourceHandler(handler.Pass(), child_id, this)); |
| 1072 } | 1071 } |
| 1073 | 1072 |
| 1074 // Install a CrossSiteResourceHandler if this request is coming from a | 1073 // Install a CrossSiteResourceHandler for all main frame requests. This will |
| 1075 // RenderViewHost with a pending cross-site request. We only check this for | 1074 // let us check whether a transfer is required and pause for the unload |
| 1076 // MAIN_FRAME requests. Unblock requests only come from a blocked page, do | 1075 // handler either if so or if a cross-process navigation is already under way. |
| 1077 // not count as cross-site, otherwise it gets blocked indefinitely. | 1076 // We skip this if we have a deferred_loader, since we have already gone |
| 1077 // through the transition in that case. |
| 1078 if (request_data.resource_type == ResourceType::MAIN_FRAME && | 1078 if (request_data.resource_type == ResourceType::MAIN_FRAME && |
| 1079 process_type == PROCESS_TYPE_RENDERER && | 1079 process_type == PROCESS_TYPE_RENDERER && |
| 1080 CrossSiteRequestManager::GetInstance()-> | 1080 !deferred_loader.get()) { |
| 1081 HasPendingCrossSiteRequest(child_id, route_id)) { | |
| 1082 // Wrap the event handler to be sure the current page's onunload handler | |
| 1083 // has a chance to run before we render the new page. | |
| 1084 handler.reset(new CrossSiteResourceHandler(handler.Pass(), child_id, | 1081 handler.reset(new CrossSiteResourceHandler(handler.Pass(), child_id, |
| 1085 route_id, request)); | 1082 route_id, request)); |
| 1086 } | 1083 } |
| 1087 | 1084 |
| 1088 // Insert a buffered event handler before the actual one. | 1085 // Insert a buffered event handler before the actual one. |
| 1089 handler.reset( | 1086 handler.reset( |
| 1090 new BufferedResourceHandler(handler.Pass(), this, request)); | 1087 new BufferedResourceHandler(handler.Pass(), this, request)); |
| 1091 | 1088 |
| 1092 ScopedVector<ResourceThrottle> throttles; | 1089 ScopedVector<ResourceThrottle> throttles; |
| 1093 if (delegate_) { | 1090 if (delegate_) { |
| 1094 bool is_continuation_of_transferred_request = | 1091 bool is_continuation_of_transferred_request = |
| 1095 (deferred_loader.get() != NULL); | 1092 (deferred_loader.get() != NULL); |
| 1096 | 1093 |
| 1097 delegate_->RequestBeginning(request, | 1094 delegate_->RequestBeginning(request, |
| 1098 resource_context, | 1095 resource_context, |
| 1099 filter_->appcache_service(), | 1096 filter_->appcache_service(), |
| 1100 request_data.resource_type, | 1097 request_data.resource_type, |
| 1101 child_id, | 1098 child_id, |
| 1102 route_id, | 1099 route_id, |
| 1103 is_continuation_of_transferred_request, | 1100 is_continuation_of_transferred_request, |
| 1104 &throttles); | 1101 &throttles); |
| 1105 } | 1102 } |
| 1106 | 1103 |
| 1107 if (request->has_upload()) { | 1104 if (request->has_upload()) { |
| 1108 // Block power save while uploading data. | 1105 // Block power save while uploading data. |
| 1109 throttles.push_back(new PowerSaveBlockResourceThrottle()); | 1106 throttles.push_back(new PowerSaveBlockResourceThrottle()); |
| 1110 } | 1107 } |
| 1111 | 1108 |
| 1112 if (request_data.resource_type == ResourceType::MAIN_FRAME) { | |
| 1113 throttles.insert( | |
| 1114 throttles.begin(), | |
| 1115 new TransferNavigationResourceThrottle(request)); | |
| 1116 } | |
| 1117 | |
| 1118 throttles.push_back( | 1109 throttles.push_back( |
| 1119 scheduler_->ScheduleRequest(child_id, route_id, request).release()); | 1110 scheduler_->ScheduleRequest(child_id, route_id, request).release()); |
| 1120 | 1111 |
| 1121 handler.reset( | 1112 handler.reset( |
| 1122 new ThrottlingResourceHandler(handler.Pass(), child_id, request_id, | 1113 new ThrottlingResourceHandler(handler.Pass(), child_id, request_id, |
| 1123 throttles.Pass())); | 1114 throttles.Pass())); |
| 1124 | 1115 |
| 1125 if (deferred_loader.get()) { | 1116 if (deferred_loader.get()) { |
| 1126 pending_loaders_[extra_info->GetGlobalRequestID()] = deferred_loader; | 1117 pending_loaders_[extra_info->GetGlobalRequestID()] = deferred_loader; |
| 1127 IncrementOutstandingRequestsMemory(1, *extra_info); | 1118 IncrementOutstandingRequestsMemory(1, *extra_info); |
| (...skipping 77 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1205 PAGE_TRANSITION_LINK, | 1196 PAGE_TRANSITION_LINK, |
| 1206 download, // is_download | 1197 download, // is_download |
| 1207 false, // is_stream | 1198 false, // is_stream |
| 1208 download, // allow_download | 1199 download, // allow_download |
| 1209 false, // has_user_gesture | 1200 false, // has_user_gesture |
| 1210 WebKit::WebReferrerPolicyDefault, | 1201 WebKit::WebReferrerPolicyDefault, |
| 1211 context, | 1202 context, |
| 1212 true); // is_async | 1203 true); // is_async |
| 1213 } | 1204 } |
| 1214 | 1205 |
| 1215 | |
| 1216 void ResourceDispatcherHostImpl::OnDidLoadResourceFromMemoryCache( | 1206 void ResourceDispatcherHostImpl::OnDidLoadResourceFromMemoryCache( |
| 1217 const GURL& url, | 1207 const GURL& url, |
| 1218 const std::string& security_info, | 1208 const std::string& security_info, |
| 1219 const std::string& http_method, | 1209 const std::string& http_method, |
| 1220 const std::string& mime_type, | 1210 const std::string& mime_type, |
| 1221 ResourceType::Type resource_type) { | 1211 ResourceType::Type resource_type) { |
| 1222 if (!url.is_valid() || !(url.SchemeIs("http") || url.SchemeIs("https"))) | 1212 if (!url.is_valid() || !(url.SchemeIs("http") || url.SchemeIs("https"))) |
| 1223 return; | 1213 return; |
| 1224 | 1214 |
| 1225 filter_->GetURLRequestContext(resource_type)->http_transaction_factory()-> | 1215 filter_->GetURLRequestContext(resource_type)->http_transaction_factory()-> |
| (...skipping 616 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1842 DelegateMap::iterator it = delegate_map_.find(id); | 1832 DelegateMap::iterator it = delegate_map_.find(id); |
| 1843 DCHECK(it->second->HasObserver(delegate)); | 1833 DCHECK(it->second->HasObserver(delegate)); |
| 1844 it->second->RemoveObserver(delegate); | 1834 it->second->RemoveObserver(delegate); |
| 1845 if (it->second->size() == 0) { | 1835 if (it->second->size() == 0) { |
| 1846 delete it->second; | 1836 delete it->second; |
| 1847 delegate_map_.erase(it); | 1837 delegate_map_.erase(it); |
| 1848 } | 1838 } |
| 1849 } | 1839 } |
| 1850 | 1840 |
| 1851 } // namespace content | 1841 } // namespace content |
| OLD | NEW |