| 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 <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/base64.h" | 9 #include "base/base64.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| 11 #include "chrome/browser/browser_process.h" | 11 #include "chrome/browser/browser_process.h" |
| 12 #include "chrome/browser/content_settings/host_content_settings_map.h" | 12 #include "chrome/browser/content_settings/host_content_settings_map.h" |
| 13 #include "chrome/browser/download/download_request_limiter.h" | 13 #include "chrome/browser/download/download_request_limiter.h" |
| 14 #include "chrome/browser/download/download_resource_throttle.h" | 14 #include "chrome/browser/download/download_resource_throttle.h" |
| 15 #include "chrome/browser/download/download_util.h" | 15 #include "chrome/browser/download/download_util.h" |
| 16 #include "chrome/browser/extensions/user_script_listener.h" | 16 #include "chrome/browser/extensions/user_script_listener.h" |
| 17 #include "chrome/browser/external_protocol/external_protocol_handler.h" | 17 #include "chrome/browser/external_protocol/external_protocol_handler.h" |
| 18 #include "chrome/browser/google/google_util.h" | 18 #include "chrome/browser/google/google_util.h" |
| 19 #include "chrome/browser/instant/instant_loader.h" | 19 #include "chrome/browser/instant/instant_loader.h" |
| 20 #include "chrome/browser/net/load_timing_observer.h" | 20 #include "chrome/browser/net/load_timing_observer.h" |
| 21 #include "chrome/browser/net/resource_prefetch_predictor_observer.h" |
| 21 #include "chrome/browser/prerender/prerender_manager.h" | 22 #include "chrome/browser/prerender/prerender_manager.h" |
| 22 #include "chrome/browser/prerender/prerender_tracker.h" | 23 #include "chrome/browser/prerender/prerender_tracker.h" |
| 23 #include "chrome/browser/profiles/profile_io_data.h" | 24 #include "chrome/browser/profiles/profile_io_data.h" |
| 24 #include "chrome/browser/renderer_host/chrome_url_request_user_data.h" | 25 #include "chrome/browser/renderer_host/chrome_url_request_user_data.h" |
| 25 #include "chrome/browser/renderer_host/safe_browsing_resource_throttle.h" | 26 #include "chrome/browser/renderer_host/safe_browsing_resource_throttle.h" |
| 26 #include "chrome/browser/safe_browsing/safe_browsing_service.h" | 27 #include "chrome/browser/safe_browsing/safe_browsing_service.h" |
| 27 #include "chrome/browser/ui/auto_login_prompter.h" | 28 #include "chrome/browser/ui/auto_login_prompter.h" |
| 28 #include "chrome/browser/ui/login/login_prompt.h" | 29 #include "chrome/browser/ui/login/login_prompt.h" |
| 29 #include "chrome/browser/ui/sync/one_click_signin_helper.h" | 30 #include "chrome/browser/ui/sync/one_click_signin_helper.h" |
| 30 #include "chrome/common/chrome_notification_types.h" | 31 #include "chrome/common/chrome_notification_types.h" |
| (...skipping 111 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 142 #endif | 143 #endif |
| 143 | 144 |
| 144 AppendChromeMetricsHeaders(request, resource_context, resource_type); | 145 AppendChromeMetricsHeaders(request, resource_context, resource_type); |
| 145 | 146 |
| 146 AppendStandardResourceThrottles(request, | 147 AppendStandardResourceThrottles(request, |
| 147 resource_context, | 148 resource_context, |
| 148 child_id, | 149 child_id, |
| 149 route_id, | 150 route_id, |
| 150 resource_type, | 151 resource_type, |
| 151 throttles); | 152 throttles); |
| 153 |
| 154 ProfileIOData* io_data = ProfileIOData::FromResourceContext(resource_context); |
| 155 if (io_data->resource_prefetch_predictor_observer()) |
| 156 io_data->resource_prefetch_predictor_observer()->OnRequestStarted( |
| 157 request, resource_type, child_id, route_id); |
| 152 } | 158 } |
| 153 | 159 |
| 154 void ChromeResourceDispatcherHostDelegate::DownloadStarting( | 160 void ChromeResourceDispatcherHostDelegate::DownloadStarting( |
| 155 net::URLRequest* request, | 161 net::URLRequest* request, |
| 156 content::ResourceContext* resource_context, | 162 content::ResourceContext* resource_context, |
| 157 int child_id, | 163 int child_id, |
| 158 int route_id, | 164 int route_id, |
| 159 int request_id, | 165 int request_id, |
| 160 bool is_content_initiated, | 166 bool is_content_initiated, |
| 161 ScopedVector<content::ResourceThrottle>* throttles) { | 167 ScopedVector<content::ResourceThrottle>* throttles) { |
| (...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 307 } | 313 } |
| 308 | 314 |
| 309 bool ChromeResourceDispatcherHostDelegate::ShouldForceDownloadResource( | 315 bool ChromeResourceDispatcherHostDelegate::ShouldForceDownloadResource( |
| 310 const GURL& url, const std::string& mime_type) { | 316 const GURL& url, const std::string& mime_type) { |
| 311 // Special-case user scripts to get downloaded instead of viewed. | 317 // Special-case user scripts to get downloaded instead of viewed. |
| 312 return UserScript::IsURLUserScript(url, mime_type); | 318 return UserScript::IsURLUserScript(url, mime_type); |
| 313 } | 319 } |
| 314 | 320 |
| 315 void ChromeResourceDispatcherHostDelegate::OnResponseStarted( | 321 void ChromeResourceDispatcherHostDelegate::OnResponseStarted( |
| 316 net::URLRequest* request, | 322 net::URLRequest* request, |
| 323 content::ResourceContext* resource_context, |
| 317 content::ResourceResponse* response, | 324 content::ResourceResponse* response, |
| 318 IPC::Message::Sender* sender) { | 325 IPC::Message::Sender* sender) { |
| 319 LoadTimingObserver::PopulateTimingInfo(request, response); | 326 LoadTimingObserver::PopulateTimingInfo(request, response); |
| 320 | 327 |
| 321 const ResourceRequestInfo* info = ResourceRequestInfo::ForRequest(request); | 328 const ResourceRequestInfo* info = ResourceRequestInfo::ForRequest(request); |
| 322 | 329 |
| 323 if (request->url().SchemeIsSecure()) { | 330 if (request->url().SchemeIsSecure()) { |
| 324 const net::URLRequestContext* context = request->context(); | 331 const net::URLRequestContext* context = request->context(); |
| 325 net::TransportSecurityState* state = context->transport_security_state(); | 332 net::TransportSecurityState* state = context->transport_security_state(); |
| 326 if (state) { | 333 if (state) { |
| 327 net::TransportSecurityState::DomainState domain_state; | 334 net::TransportSecurityState::DomainState domain_state; |
| 328 bool has_sni = net::SSLConfigService::IsSNIAvailable( | 335 bool has_sni = net::SSLConfigService::IsSNIAvailable( |
| 329 context->ssl_config_service()); | 336 context->ssl_config_service()); |
| 330 if (state->GetDomainState( | 337 if (state->GetDomainState( |
| 331 request->url().host(), has_sni, &domain_state)) { | 338 request->url().host(), has_sni, &domain_state)) { |
| 332 sender->Send(new ChromeViewMsg_AddStrictSecurityHost( | 339 sender->Send(new ChromeViewMsg_AddStrictSecurityHost( |
| 333 info->GetRouteID(), request->url().host())); | 340 info->GetRouteID(), request->url().host())); |
| 334 } | 341 } |
| 335 } | 342 } |
| 336 } | 343 } |
| 337 | 344 |
| 338 // See if the response contains the X-Auto-Login header. If so, this was | 345 // See if the response contains the X-Auto-Login header. If so, this was |
| 339 // a request for a login page, and the server is allowing the browser to | 346 // a request for a login page, and the server is allowing the browser to |
| 340 // suggest auto-login, if available. | 347 // suggest auto-login, if available. |
| 341 AutoLoginPrompter::ShowInfoBarIfPossible(request, info->GetChildID(), | 348 AutoLoginPrompter::ShowInfoBarIfPossible(request, info->GetChildID(), |
| 342 info->GetRouteID()); | 349 info->GetRouteID()); |
| 350 |
| 351 ProfileIOData* io_data = ProfileIOData::FromResourceContext(resource_context); |
| 352 if (io_data->resource_prefetch_predictor_observer()) |
| 353 io_data->resource_prefetch_predictor_observer()->OnResponseStarted(request); |
| 343 } | 354 } |
| 344 | 355 |
| 345 void ChromeResourceDispatcherHostDelegate::OnRequestRedirected( | 356 void ChromeResourceDispatcherHostDelegate::OnRequestRedirected( |
| 346 net::URLRequest* request, | 357 net::URLRequest* request, |
| 358 content::ResourceContext* resource_context, |
| 347 content::ResourceResponse* response) { | 359 content::ResourceResponse* response) { |
| 348 LoadTimingObserver::PopulateTimingInfo(request, response); | 360 LoadTimingObserver::PopulateTimingInfo(request, response); |
| 349 | 361 |
| 350 #if defined(ENABLE_ONE_CLICK_SIGNIN) | 362 #if defined(ENABLE_ONE_CLICK_SIGNIN) |
| 351 const ResourceRequestInfo* info = ResourceRequestInfo::ForRequest(request); | 363 const ResourceRequestInfo* info = ResourceRequestInfo::ForRequest(request); |
| 352 | 364 |
| 353 // See if the response contains the Google-Accounts-SignIn header. If so, | 365 // See if the response contains the Google-Accounts-SignIn header. If so, |
| 354 // then the user has just finished signing in, and the server is allowing the | 366 // then the user has just finished signing in, and the server is allowing the |
| 355 // browser to suggest connecting the user's profile to the account. | 367 // browser to suggest connecting the user's profile to the account. |
| 356 OneClickSigninHelper::ShowInfoBarIfPossible(request, info->GetChildID(), | 368 OneClickSigninHelper::ShowInfoBarIfPossible(request, info->GetChildID(), |
| 357 info->GetRouteID()); | 369 info->GetRouteID()); |
| 358 #endif | 370 #endif |
| 371 |
| 372 ProfileIOData* io_data = ProfileIOData::FromResourceContext(resource_context); |
| 373 if (io_data->resource_prefetch_predictor_observer()) |
| 374 io_data->resource_prefetch_predictor_observer()->OnRequestRedirected( |
| 375 request); |
| 359 } | 376 } |
| 360 | 377 |
| 361 void ChromeResourceDispatcherHostDelegate::OnFieldTrialGroupFinalized( | 378 void ChromeResourceDispatcherHostDelegate::OnFieldTrialGroupFinalized( |
| 362 const std::string& trial_name, | 379 const std::string& trial_name, |
| 363 const std::string& group_name) { | 380 const std::string& group_name) { |
| 364 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 381 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 365 chrome_variations::ID new_id = | 382 chrome_variations::ID new_id = |
| 366 experiments_helper::GetGoogleVariationID(trial_name, group_name); | 383 experiments_helper::GetGoogleVariationID(trial_name, group_name); |
| 367 if (new_id == chrome_variations::kEmptyID) | 384 if (new_id == chrome_variations::kEmptyID) |
| 368 return; | 385 return; |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 410 if (base::Base64Encode(serialized, &hashed)) { | 427 if (base::Base64Encode(serialized, &hashed)) { |
| 411 // If successful, swap the header value with the new one. | 428 // If successful, swap the header value with the new one. |
| 412 // Note that the list of IDs and the header could be temporarily out of sync | 429 // Note that the list of IDs and the header could be temporarily out of sync |
| 413 // if IDs are added as we are recreating the header, but we're OK with those | 430 // if IDs are added as we are recreating the header, but we're OK with those |
| 414 // descrepancies. | 431 // descrepancies. |
| 415 variation_ids_header_ = hashed; | 432 variation_ids_header_ = hashed; |
| 416 } else { | 433 } else { |
| 417 DVLOG(1) << "Failed to base64 encode Variation IDs value: " << serialized; | 434 DVLOG(1) << "Failed to base64 encode Variation IDs value: " << serialized; |
| 418 } | 435 } |
| 419 } | 436 } |
| OLD | NEW |