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

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: Fix indent Created 7 years, 2 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 1046 matching lines...) Expand 10 before | Expand all | Expand 10 after
1100 } else { 1099 } else {
1101 handler.reset(new AsyncResourceHandler(request, this)); 1100 handler.reset(new AsyncResourceHandler(request, this));
1102 } 1101 }
1103 1102
1104 // The RedirectToFileResourceHandler depends on being next in the chain. 1103 // The RedirectToFileResourceHandler depends on being next in the chain.
1105 if (request_data.download_to_file) { 1104 if (request_data.download_to_file) {
1106 handler.reset( 1105 handler.reset(
1107 new RedirectToFileResourceHandler(handler.Pass(), request, this)); 1106 new RedirectToFileResourceHandler(handler.Pass(), request, this));
1108 } 1107 }
1109 1108
1110 // Install a CrossSiteResourceHandler if this request is coming from a 1109 // Install a CrossSiteResourceHandler for all main frame requests. This will
1111 // RenderViewHost with a pending cross-site request. We only check this for 1110 // let us check whether a transfer is required and pause for the unload
1112 // MAIN_FRAME requests. Unblock requests only come from a blocked page, do 1111 // handler either if so or if a cross-process navigation is already under way.
1113 // not count as cross-site, otherwise it gets blocked indefinitely. 1112 if (request_data.resource_type == ResourceType::MAIN_FRAME &&
1114 if (request_data.resource_type == ResourceType::MAIN_FRAME && 1113 process_type == PROCESS_TYPE_RENDERER) {
1115 process_type == PROCESS_TYPE_RENDERER &&
1116 CrossSiteRequestManager::GetInstance()->
1117 HasPendingCrossSiteRequest(child_id, route_id)) {
1118 // Wrap the event handler to be sure the current page's onunload handler
1119 // has a chance to run before we render the new page.
1120 handler.reset(new CrossSiteResourceHandler(handler.Pass(), request)); 1114 handler.reset(new CrossSiteResourceHandler(handler.Pass(), request));
1121 } 1115 }
1122 1116
1123 // Insert a buffered event handler before the actual one. 1117 // Insert a buffered event handler before the actual one.
1124 handler.reset( 1118 handler.reset(
1125 new BufferedResourceHandler(handler.Pass(), this, request)); 1119 new BufferedResourceHandler(handler.Pass(), this, request));
1126 1120
1127 ScopedVector<ResourceThrottle> throttles; 1121 ScopedVector<ResourceThrottle> throttles;
1128 if (delegate_) { 1122 if (delegate_) {
1129 delegate_->RequestBeginning(request, 1123 delegate_->RequestBeginning(request,
1130 resource_context, 1124 resource_context,
1131 filter_->appcache_service(), 1125 filter_->appcache_service(),
1132 request_data.resource_type, 1126 request_data.resource_type,
1133 child_id, 1127 child_id,
1134 route_id, 1128 route_id,
1135 &throttles); 1129 &throttles);
1136 } 1130 }
1137 1131
1138 if (request->has_upload()) { 1132 if (request->has_upload()) {
1139 // Block power save while uploading data. 1133 // Block power save while uploading data.
1140 throttles.push_back(new PowerSaveBlockResourceThrottle()); 1134 throttles.push_back(new PowerSaveBlockResourceThrottle());
1141 } 1135 }
1142 1136
1143 if (request_data.resource_type == ResourceType::MAIN_FRAME) {
1144 throttles.insert(
1145 throttles.begin(),
1146 new TransferNavigationResourceThrottle(request));
1147 }
1148
1149 throttles.push_back( 1137 throttles.push_back(
1150 scheduler_->ScheduleRequest(child_id, route_id, request).release()); 1138 scheduler_->ScheduleRequest(child_id, route_id, request).release());
1151 1139
1152 handler.reset( 1140 handler.reset(
1153 new ThrottlingResourceHandler(handler.Pass(), request, throttles.Pass())); 1141 new ThrottlingResourceHandler(handler.Pass(), request, throttles.Pass()));
1154 1142
1155 BeginRequestInternal(new_request.Pass(), handler.Pass()); 1143 BeginRequestInternal(new_request.Pass(), handler.Pass());
1156 } 1144 }
1157 1145
1158 void ResourceDispatcherHostImpl::OnReleaseDownloadedFile(int request_id) { 1146 void ResourceDispatcherHostImpl::OnReleaseDownloadedFile(int request_id) {
(...skipping 762 matching lines...) Expand 10 before | Expand all | Expand 10 after
1921 if ((load_flags & net::LOAD_REPORT_RAW_HEADERS) 1909 if ((load_flags & net::LOAD_REPORT_RAW_HEADERS)
1922 && !policy->CanReadRawCookies(child_id)) { 1910 && !policy->CanReadRawCookies(child_id)) {
1923 VLOG(1) << "Denied unauthorized request for raw headers"; 1911 VLOG(1) << "Denied unauthorized request for raw headers";
1924 load_flags &= ~net::LOAD_REPORT_RAW_HEADERS; 1912 load_flags &= ~net::LOAD_REPORT_RAW_HEADERS;
1925 } 1913 }
1926 1914
1927 return load_flags; 1915 return load_flags;
1928 } 1916 }
1929 1917
1930 } // namespace content 1918 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698