| 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 #include "chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.
h" | 5 #include "chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.
h" |
| 6 | 6 |
| 7 #include "base/logging.h" | 7 #include "base/logging.h" |
| 8 #include "chrome/browser/browser_process.h" | 8 #include "chrome/browser/browser_process.h" |
| 9 #include "chrome/browser/content_settings/host_content_settings_map.h" | 9 #include "chrome/browser/content_settings/host_content_settings_map.h" |
| 10 #include "chrome/browser/download/download_request_limiter.h" | 10 #include "chrome/browser/download/download_request_limiter.h" |
| (...skipping 12 matching lines...) Expand all Loading... |
| 23 #include "chrome/browser/renderer_host/safe_browsing_resource_throttle.h" | 23 #include "chrome/browser/renderer_host/safe_browsing_resource_throttle.h" |
| 24 #include "chrome/browser/renderer_host/transfer_navigation_resource_throttle.h" | 24 #include "chrome/browser/renderer_host/transfer_navigation_resource_throttle.h" |
| 25 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 25 #include "chrome/browser/safe_browsing/safe_browsing_service.h" |
| 26 #include "chrome/browser/ui/auto_login_prompter.h" | 26 #include "chrome/browser/ui/auto_login_prompter.h" |
| 27 #include "chrome/browser/ui/login/login_prompt.h" | 27 #include "chrome/browser/ui/login/login_prompt.h" |
| 28 #include "chrome/common/chrome_notification_types.h" | 28 #include "chrome/common/chrome_notification_types.h" |
| 29 #include "chrome/common/extensions/user_script.h" | 29 #include "chrome/common/extensions/user_script.h" |
| 30 #include "chrome/common/render_messages.h" | 30 #include "chrome/common/render_messages.h" |
| 31 #include "content/browser/renderer_host/render_view_host.h" | 31 #include "content/browser/renderer_host/render_view_host.h" |
| 32 #include "content/browser/renderer_host/resource_dispatcher_host.h" | 32 #include "content/browser/renderer_host/resource_dispatcher_host.h" |
| 33 #include "content/browser/renderer_host/resource_dispatcher_host_request_info.h" | |
| 34 #include "content/public/browser/browser_thread.h" | 33 #include "content/public/browser/browser_thread.h" |
| 35 #include "content/public/browser/notification_service.h" | 34 #include "content/public/browser/notification_service.h" |
| 36 #include "content/public/browser/resource_context.h" | 35 #include "content/public/browser/resource_context.h" |
| 36 #include "content/public/browser/resource_request_info.h" |
| 37 #include "net/base/load_flags.h" | 37 #include "net/base/load_flags.h" |
| 38 #include "net/base/ssl_config_service.h" | 38 #include "net/base/ssl_config_service.h" |
| 39 | 39 |
| 40 // TODO(oshima): Enable this for other platforms. | 40 // TODO(oshima): Enable this for other platforms. |
| 41 #if defined(OS_CHROMEOS) | 41 #if defined(OS_CHROMEOS) |
| 42 #include "chrome/browser/renderer_host/offline_resource_throttle.h" | 42 #include "chrome/browser/renderer_host/offline_resource_throttle.h" |
| 43 #endif | 43 #endif |
| 44 | 44 |
| 45 using content::BrowserThread; | 45 using content::BrowserThread; |
| 46 using content::ResourceDispatcherHostLoginDelegate; | 46 using content::ResourceDispatcherHostLoginDelegate; |
| 47 using content::ResourceRequestInfo; |
| 47 | 48 |
| 48 namespace { | 49 namespace { |
| 49 | 50 |
| 50 void AddPrerenderOnUI( | 51 void AddPrerenderOnUI( |
| 51 int render_process_id, int render_view_id, | 52 int render_process_id, int render_view_id, |
| 52 const GURL& url, const content::Referrer& referrer) { | 53 const GURL& url, const content::Referrer& referrer) { |
| 53 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 54 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 54 prerender::PrerenderManager* prerender_manager = | 55 prerender::PrerenderManager* prerender_manager = |
| 55 prerender::FindPrerenderManagerUsingRenderProcessId(render_process_id); | 56 prerender::FindPrerenderManagerUsingRenderProcessId(render_process_id); |
| 56 if (!prerender_manager || !prerender_manager->is_enabled()) | 57 if (!prerender_manager || !prerender_manager->is_enabled()) |
| (...skipping 149 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 206 } | 207 } |
| 207 | 208 |
| 208 bool ChromeResourceDispatcherHostDelegate::AcceptSSLClientCertificateRequest( | 209 bool ChromeResourceDispatcherHostDelegate::AcceptSSLClientCertificateRequest( |
| 209 net::URLRequest* request, net::SSLCertRequestInfo* cert_request_info) { | 210 net::URLRequest* request, net::SSLCertRequestInfo* cert_request_info) { |
| 210 if (request->load_flags() & net::LOAD_PREFETCH) | 211 if (request->load_flags() & net::LOAD_PREFETCH) |
| 211 return false; | 212 return false; |
| 212 | 213 |
| 213 ChromeURLRequestUserData* user_data = ChromeURLRequestUserData::Get(request); | 214 ChromeURLRequestUserData* user_data = ChromeURLRequestUserData::Get(request); |
| 214 if (user_data && user_data->is_prerender()) { | 215 if (user_data && user_data->is_prerender()) { |
| 215 int child_id, route_id; | 216 int child_id, route_id; |
| 216 if (ResourceDispatcherHost::RenderViewForRequest( | 217 if (ResourceRequestInfo::ForRequest(request)->GetAssociatedRenderView( |
| 217 request, &child_id, &route_id)) { | 218 &child_id, &route_id)) { |
| 218 if (prerender_tracker_->TryCancel( | 219 if (prerender_tracker_->TryCancel( |
| 219 child_id, route_id, | 220 child_id, route_id, |
| 220 prerender::FINAL_STATUS_SSL_CLIENT_CERTIFICATE_REQUESTED)) { | 221 prerender::FINAL_STATUS_SSL_CLIENT_CERTIFICATE_REQUESTED)) { |
| 221 return false; | 222 return false; |
| 222 } | 223 } |
| 223 } | 224 } |
| 224 } | 225 } |
| 225 | 226 |
| 226 return true; | 227 return true; |
| 227 } | 228 } |
| 228 | 229 |
| 229 bool ChromeResourceDispatcherHostDelegate::AcceptAuthRequest( | 230 bool ChromeResourceDispatcherHostDelegate::AcceptAuthRequest( |
| 230 net::URLRequest* request, | 231 net::URLRequest* request, |
| 231 net::AuthChallengeInfo* auth_info) { | 232 net::AuthChallengeInfo* auth_info) { |
| 232 ChromeURLRequestUserData* user_data = ChromeURLRequestUserData::Get(request); | 233 ChromeURLRequestUserData* user_data = ChromeURLRequestUserData::Get(request); |
| 233 if (!user_data || !user_data->is_prerender()) | 234 if (!user_data || !user_data->is_prerender()) |
| 234 return true; | 235 return true; |
| 235 | 236 |
| 236 int child_id, route_id; | 237 int child_id, route_id; |
| 237 if (!ResourceDispatcherHost::RenderViewForRequest( | 238 if (!ResourceRequestInfo::ForRequest(request)->GetAssociatedRenderView( |
| 238 request, &child_id, &route_id)) { | 239 &child_id, &route_id)) { |
| 239 NOTREACHED(); | 240 NOTREACHED(); |
| 240 return true; | 241 return true; |
| 241 } | 242 } |
| 242 | 243 |
| 243 if (!prerender_tracker_->TryCancelOnIOThread( | 244 if (!prerender_tracker_->TryCancelOnIOThread( |
| 244 child_id, route_id, prerender::FINAL_STATUS_AUTH_NEEDED)) { | 245 child_id, route_id, prerender::FINAL_STATUS_AUTH_NEEDED)) { |
| 245 return true; | 246 return true; |
| 246 } | 247 } |
| 247 | 248 |
| 248 return false; | 249 return false; |
| (...skipping 53 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 302 // Special-case user scripts to get downloaded instead of viewed. | 303 // Special-case user scripts to get downloaded instead of viewed. |
| 303 return UserScript::IsURLUserScript(url, mime_type); | 304 return UserScript::IsURLUserScript(url, mime_type); |
| 304 } | 305 } |
| 305 | 306 |
| 306 void ChromeResourceDispatcherHostDelegate::OnResponseStarted( | 307 void ChromeResourceDispatcherHostDelegate::OnResponseStarted( |
| 307 net::URLRequest* request, | 308 net::URLRequest* request, |
| 308 content::ResourceResponse* response, | 309 content::ResourceResponse* response, |
| 309 IPC::Message::Sender* sender) { | 310 IPC::Message::Sender* sender) { |
| 310 LoadTimingObserver::PopulateTimingInfo(request, response); | 311 LoadTimingObserver::PopulateTimingInfo(request, response); |
| 311 | 312 |
| 312 ResourceDispatcherHostRequestInfo* info = | 313 const ResourceRequestInfo* info = ResourceRequestInfo::ForRequest(request); |
| 313 resource_dispatcher_host_->InfoForRequest(request); | |
| 314 | 314 |
| 315 if (request->url().SchemeIsSecure()) { | 315 if (request->url().SchemeIsSecure()) { |
| 316 const net::URLRequestContext* context = request->context(); | 316 const net::URLRequestContext* context = request->context(); |
| 317 net::TransportSecurityState* state = context->transport_security_state(); | 317 net::TransportSecurityState* state = context->transport_security_state(); |
| 318 if (state) { | 318 if (state) { |
| 319 net::TransportSecurityState::DomainState domain_state; | 319 net::TransportSecurityState::DomainState domain_state; |
| 320 bool has_sni = net::SSLConfigService::IsSNIAvailable( | 320 bool has_sni = net::SSLConfigService::IsSNIAvailable( |
| 321 context->ssl_config_service()); | 321 context->ssl_config_service()); |
| 322 if (state->GetDomainState( | 322 if (state->GetDomainState( |
| 323 &domain_state, request->url().host(), has_sni)) { | 323 &domain_state, request->url().host(), has_sni)) { |
| 324 sender->Send(new ChromeViewMsg_AddStrictSecurityHost( | 324 sender->Send(new ChromeViewMsg_AddStrictSecurityHost( |
| 325 info->route_id(), request->url().host())); | 325 info->route_id(), request->url().host())); |
| 326 } | 326 } |
| 327 } | 327 } |
| 328 } | 328 } |
| 329 | 329 |
| 330 // See if the response contains the X-Auto-Login header. If so, this was | 330 // See if the response contains the X-Auto-Login header. If so, this was |
| 331 // a request for a login page, and the server is allowing the browser to | 331 // a request for a login page, and the server is allowing the browser to |
| 332 // suggest auto-login, if available. | 332 // suggest auto-login, if available. |
| 333 AutoLoginPrompter::ShowInfoBarIfPossible(request, info->child_id(), | 333 AutoLoginPrompter::ShowInfoBarIfPossible(request, info->child_id(), |
| 334 info->route_id()); | 334 info->route_id()); |
| 335 } | 335 } |
| 336 | 336 |
| 337 void ChromeResourceDispatcherHostDelegate::OnRequestRedirected( | 337 void ChromeResourceDispatcherHostDelegate::OnRequestRedirected( |
| 338 net::URLRequest* request, | 338 net::URLRequest* request, |
| 339 content::ResourceResponse* response) { | 339 content::ResourceResponse* response) { |
| 340 LoadTimingObserver::PopulateTimingInfo(request, response); | 340 LoadTimingObserver::PopulateTimingInfo(request, response); |
| 341 } | 341 } |
| OLD | NEW |