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 877 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
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 Loading... |
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 Loading... |
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 |
OLD | NEW |