Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(280)

Side by Side Diff: content/browser/loader/resource_dispatcher_host_impl.cc

Issue 15476003: Move TransferNavigationResourceThrottle into CrossSiteResourceHandler. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Get tests to pass Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
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
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698