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

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: Remove null check on cross_site_handler(). 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 877 matching lines...) Expand 10 before | Expand all | Expand 10 after
931 930
932 // Notify the delegate to allow it to update state as well. 931 // Notify the delegate to allow it to update state as well.
933 if (delegate_) { 932 if (delegate_) {
934 delegate_->WillTransferRequestToNewProcess(old_routing_id.child_id, 933 delegate_->WillTransferRequestToNewProcess(old_routing_id.child_id,
935 old_routing_id.route_id, 934 old_routing_id.route_id,
936 old_request_id.request_id, 935 old_request_id.request_id,
937 child_id, 936 child_id,
938 route_id, 937 route_id,
939 request_id); 938 request_id);
940 } 939 }
940
941 // We should have a CrossSiteResourceHandler to finish the transfer.
942 DCHECK(info->cross_site_handler());
941 } 943 }
942 944
943 void ResourceDispatcherHostImpl::BeginRequest( 945 void ResourceDispatcherHostImpl::BeginRequest(
944 int request_id, 946 int request_id,
945 const ResourceHostMsg_Request& request_data, 947 const ResourceHostMsg_Request& request_data,
946 IPC::Message* sync_result, // only valid for sync 948 IPC::Message* sync_result, // only valid for sync
947 int route_id) { 949 int route_id) {
948 int process_type = filter_->process_type(); 950 int process_type = filter_->process_type();
949 int child_id = filter_->child_id(); 951 int child_id = filter_->child_id();
950 952
(...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after
1100 } else { 1102 } else {
1101 handler.reset(new AsyncResourceHandler(request, this)); 1103 handler.reset(new AsyncResourceHandler(request, this));
1102 } 1104 }
1103 1105
1104 // The RedirectToFileResourceHandler depends on being next in the chain. 1106 // The RedirectToFileResourceHandler depends on being next in the chain.
1105 if (request_data.download_to_file) { 1107 if (request_data.download_to_file) {
1106 handler.reset( 1108 handler.reset(
1107 new RedirectToFileResourceHandler(handler.Pass(), request, this)); 1109 new RedirectToFileResourceHandler(handler.Pass(), request, this));
1108 } 1110 }
1109 1111
1110 // Install a CrossSiteResourceHandler if this request is coming from a 1112 // Install a CrossSiteResourceHandler for all main frame requests. This will
1111 // RenderViewHost with a pending cross-site request. We only check this for 1113 // 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 1114 // 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. 1115 if (request_data.resource_type == ResourceType::MAIN_FRAME &&
1114 if (request_data.resource_type == ResourceType::MAIN_FRAME && 1116 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)); 1117 handler.reset(new CrossSiteResourceHandler(handler.Pass(), request));
1121 } 1118 }
1122 1119
1123 // Insert a buffered event handler before the actual one. 1120 // Insert a buffered event handler before the actual one.
1124 handler.reset( 1121 handler.reset(
1125 new BufferedResourceHandler(handler.Pass(), this, request)); 1122 new BufferedResourceHandler(handler.Pass(), this, request));
1126 1123
1127 ScopedVector<ResourceThrottle> throttles; 1124 ScopedVector<ResourceThrottle> throttles;
1128 if (delegate_) { 1125 if (delegate_) {
1129 delegate_->RequestBeginning(request, 1126 delegate_->RequestBeginning(request,
1130 resource_context, 1127 resource_context,
1131 filter_->appcache_service(), 1128 filter_->appcache_service(),
1132 request_data.resource_type, 1129 request_data.resource_type,
1133 child_id, 1130 child_id,
1134 route_id, 1131 route_id,
1135 &throttles); 1132 &throttles);
1136 } 1133 }
1137 1134
1138 if (request->has_upload()) { 1135 if (request->has_upload()) {
1139 // Block power save while uploading data. 1136 // Block power save while uploading data.
1140 throttles.push_back(new PowerSaveBlockResourceThrottle()); 1137 throttles.push_back(new PowerSaveBlockResourceThrottle());
1141 } 1138 }
1142 1139
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( 1140 throttles.push_back(
1150 scheduler_->ScheduleRequest(child_id, route_id, request).release()); 1141 scheduler_->ScheduleRequest(child_id, route_id, request).release());
1151 1142
1152 handler.reset( 1143 handler.reset(
1153 new ThrottlingResourceHandler(handler.Pass(), request, throttles.Pass())); 1144 new ThrottlingResourceHandler(handler.Pass(), request, throttles.Pass()));
1154 1145
1155 BeginRequestInternal(new_request.Pass(), handler.Pass()); 1146 BeginRequestInternal(new_request.Pass(), handler.Pass());
1156 } 1147 }
1157 1148
1158 void ResourceDispatcherHostImpl::OnReleaseDownloadedFile(int request_id) { 1149 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) 1912 if ((load_flags & net::LOAD_REPORT_RAW_HEADERS)
1922 && !policy->CanReadRawCookies(child_id)) { 1913 && !policy->CanReadRawCookies(child_id)) {
1923 VLOG(1) << "Denied unauthorized request for raw headers"; 1914 VLOG(1) << "Denied unauthorized request for raw headers";
1924 load_flags &= ~net::LOAD_REPORT_RAW_HEADERS; 1915 load_flags &= ~net::LOAD_REPORT_RAW_HEADERS;
1925 } 1916 }
1926 1917
1927 return load_flags; 1918 return load_flags;
1928 } 1919 }
1929 1920
1930 } // namespace content 1921 } // namespace content
OLDNEW
« no previous file with comments | « content/browser/loader/cross_site_resource_handler.cc ('k') | content/browser/loader/resource_dispatcher_host_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698