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

Side by Side Diff: chrome/browser/net/chrome_network_delegate.cc

Issue 11970002: Added Client-Hints. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: Changed Client Hint names to match spec Created 7 years, 10 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
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 #include "chrome/browser/net/chrome_network_delegate.h" 5 #include "chrome/browser/net/chrome_network_delegate.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/base_paths.h" 9 #include "base/base_paths.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "base/metrics/histogram.h" 11 #include "base/metrics/histogram.h"
12 #include "base/path_service.h" 12 #include "base/path_service.h"
13 #include "base/prefs/public/pref_member.h" 13 #include "base/prefs/public/pref_member.h"
14 #include "base/string_number_conversions.h" 14 #include "base/string_number_conversions.h"
15 #include "base/string_split.h" 15 #include "base/string_split.h"
16 #include "chrome/browser/browser_process.h" 16 #include "chrome/browser/browser_process.h"
17 #include "chrome/browser/content_settings/cookie_settings.h" 17 #include "chrome/browser/content_settings/cookie_settings.h"
18 #include "chrome/browser/content_settings/tab_specific_content_settings.h" 18 #include "chrome/browser/content_settings/tab_specific_content_settings.h"
19 #include "chrome/browser/custom_handlers/protocol_handler_registry.h" 19 #include "chrome/browser/custom_handlers/protocol_handler_registry.h"
20 #include "chrome/browser/extensions/api/proxy/proxy_api.h" 20 #include "chrome/browser/extensions/api/proxy/proxy_api.h"
21 #include "chrome/browser/extensions/api/web_request/web_request_api.h" 21 #include "chrome/browser/extensions/api/web_request/web_request_api.h"
22 #include "chrome/browser/extensions/event_router_forwarder.h" 22 #include "chrome/browser/extensions/event_router_forwarder.h"
23 #include "chrome/browser/extensions/extension_info_map.h" 23 #include "chrome/browser/extensions/extension_info_map.h"
24 #include "chrome/browser/extensions/extension_process_manager.h" 24 #include "chrome/browser/extensions/extension_process_manager.h"
25 #include "chrome/browser/extensions/extension_system.h" 25 #include "chrome/browser/extensions/extension_system.h"
26 #include "chrome/browser/google/google_util.h" 26 #include "chrome/browser/google/google_util.h"
27 #include "chrome/browser/net/client_hints.h"
27 #include "chrome/browser/net/connect_interceptor.h" 28 #include "chrome/browser/net/connect_interceptor.h"
28 #include "chrome/browser/net/load_time_stats.h" 29 #include "chrome/browser/net/load_time_stats.h"
29 #include "chrome/browser/performance_monitor/performance_monitor.h" 30 #include "chrome/browser/performance_monitor/performance_monitor.h"
30 #include "chrome/browser/prefs/pref_service.h" 31 #include "chrome/browser/prefs/pref_service.h"
31 #include "chrome/browser/profiles/profile_manager.h" 32 #include "chrome/browser/profiles/profile_manager.h"
32 #include "chrome/browser/task_manager/task_manager.h" 33 #include "chrome/browser/task_manager/task_manager.h"
33 #include "chrome/common/pref_names.h" 34 #include "chrome/common/pref_names.h"
34 #include "chrome/common/url_constants.h" 35 #include "chrome/common/url_constants.h"
35 #include "content/public/browser/browser_thread.h" 36 #include "content/public/browser/browser_thread.h"
36 #include "content/public/browser/render_view_host.h" 37 #include "content/public/browser/render_view_host.h"
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after
68 bool ChromeNetworkDelegate::g_allow_file_access_ = true; 69 bool ChromeNetworkDelegate::g_allow_file_access_ = true;
69 #endif 70 #endif
70 71
71 // This remains false unless the --disable-extensions-http-throttling 72 // This remains false unless the --disable-extensions-http-throttling
72 // flag is passed to the browser. 73 // flag is passed to the browser.
73 bool ChromeNetworkDelegate::g_never_throttle_requests_ = false; 74 bool ChromeNetworkDelegate::g_never_throttle_requests_ = false;
74 75
75 namespace { 76 namespace {
76 77
77 const char kDNTHeader[] = "DNT"; 78 const char kDNTHeader[] = "DNT";
79 const char kClientHintsHeader[] = "Client-Hints";
78 80
79 // If the |request| failed due to problems with a proxy, forward the error to 81 // If the |request| failed due to problems with a proxy, forward the error to
80 // the proxy extension API. 82 // the proxy extension API.
81 void ForwardProxyErrors(net::URLRequest* request, 83 void ForwardProxyErrors(net::URLRequest* request,
82 extensions::EventRouterForwarder* event_router, 84 extensions::EventRouterForwarder* event_router,
83 void* profile) { 85 void* profile) {
84 if (request->status().status() == net::URLRequestStatus::FAILED) { 86 if (request->status().status() == net::URLRequestStatus::FAILED) {
85 switch (request->status().error()) { 87 switch (request->status().error()) {
86 case net::ERR_PROXY_AUTH_UNSUPPORTED: 88 case net::ERR_PROXY_AUTH_UNSUPPORTED:
87 case net::ERR_PROXY_CONNECTION_FAILED: 89 case net::ERR_PROXY_CONNECTION_FAILED:
(...skipping 172 matching lines...) Expand 10 before | Expand all | Expand 10 after
260 original_content_length); 262 original_content_length);
261 UMA_HISTOGRAM_COUNTS("Net.HttpContentLengthDifference", 263 UMA_HISTOGRAM_COUNTS("Net.HttpContentLengthDifference",
262 original_content_length - received_content_length); 264 original_content_length - received_content_length);
263 #endif 265 #endif
264 } 266 }
265 267
266 } // namespace 268 } // namespace
267 269
268 ChromeNetworkDelegate::ChromeNetworkDelegate( 270 ChromeNetworkDelegate::ChromeNetworkDelegate(
269 extensions::EventRouterForwarder* event_router, 271 extensions::EventRouterForwarder* event_router,
270 BooleanPrefMember* enable_referrers) 272 BooleanPrefMember* enable_referrers, bool enable_client_hints)
271 : event_router_(event_router), 273 : event_router_(event_router),
272 profile_(NULL), 274 profile_(NULL),
273 enable_referrers_(enable_referrers), 275 enable_referrers_(enable_referrers),
274 enable_do_not_track_(NULL), 276 enable_do_not_track_(NULL),
275 force_google_safe_search_(NULL), 277 force_google_safe_search_(NULL),
276 url_blacklist_manager_(NULL), 278 url_blacklist_manager_(NULL),
277 load_time_stats_(NULL), 279 load_time_stats_(NULL),
278 received_content_length_(0), 280 received_content_length_(0),
279 original_content_length_(0) { 281 original_content_length_(0),
282 client_hints_(enable_client_hints ? new ClientHints() : NULL){
280 DCHECK(event_router); 283 DCHECK(event_router);
281 DCHECK(enable_referrers); 284 DCHECK(enable_referrers);
285 if (client_hints_ != NULL) {
Ryan Sleevi 2013/02/08 22:12:53 Just use a bool check, rather than NULL if (clien
bengr 2013/02/26 01:57:20 Done.
286 client_hints_->RetrieveScreenInfo();
287 }
282 } 288 }
283 289
284 ChromeNetworkDelegate::~ChromeNetworkDelegate() {} 290 ChromeNetworkDelegate::~ChromeNetworkDelegate() {}
285 291
286 void ChromeNetworkDelegate::set_extension_info_map( 292 void ChromeNetworkDelegate::set_extension_info_map(
287 ExtensionInfoMap* extension_info_map) { 293 ExtensionInfoMap* extension_info_map) {
288 extension_info_map_ = extension_info_map; 294 extension_info_map_ = extension_info_map;
289 } 295 }
290 296
291 void ChromeNetworkDelegate::set_cookie_settings( 297 void ChromeNetworkDelegate::set_cookie_settings(
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after
376 } 382 }
377 #endif 383 #endif
378 384
379 ForwardRequestStatus(REQUEST_STARTED, request, profile_); 385 ForwardRequestStatus(REQUEST_STARTED, request, profile_);
380 386
381 if (!enable_referrers_->GetValue()) 387 if (!enable_referrers_->GetValue())
382 request->set_referrer(std::string()); 388 request->set_referrer(std::string());
383 if (enable_do_not_track_ && enable_do_not_track_->GetValue()) 389 if (enable_do_not_track_ && enable_do_not_track_->GetValue())
384 request->SetExtraRequestHeaderByName(kDNTHeader, "1", true /* override */); 390 request->SetExtraRequestHeaderByName(kDNTHeader, "1", true /* override */);
385 391
392 if (client_hints_ != NULL) {
393 std::string client_hints_value = client_hints_->GetScreenInfoHints();
igrigorik 2013/02/09 17:06:30 Hmm, this would fetch screen.{width,height} on eve
bengr 2013/02/26 01:57:20 It does not fetch screen height/width on every req
394 request->SetExtraRequestHeaderByName(kClientHintsHeader,
395 client_hints_value, true);
396 DVLOG(2) << kClientHintsHeader << ": " << client_hints_value
397 << " for " << request->url().spec();
Ryan Sleevi 2013/02/08 22:12:53 Align your streams - see http://dev.chromium.org/d
bengr 2013/02/26 01:57:20 Done.
398 }
399
386 bool force_safe_search = force_google_safe_search_ && 400 bool force_safe_search = force_google_safe_search_ &&
387 force_google_safe_search_->GetValue(); 401 force_google_safe_search_->GetValue();
388 402
389 net::CompletionCallback wrapped_callback = callback; 403 net::CompletionCallback wrapped_callback = callback;
390 if (force_safe_search) { 404 if (force_safe_search) {
391 wrapped_callback = base::Bind(&ForceGoogleSafeSearchCallbackWrapper, 405 wrapped_callback = base::Bind(&ForceGoogleSafeSearchCallbackWrapper,
392 callback, 406 callback,
393 base::Unretained(request), 407 base::Unretained(request),
394 base::Unretained(new_url)); 408 base::Unretained(new_url));
395 } 409 }
(...skipping 276 matching lines...) Expand 10 before | Expand all | Expand 10 after
672 686
673 void ChromeNetworkDelegate::AccumulateContentLength( 687 void ChromeNetworkDelegate::AccumulateContentLength(
674 int64 received_content_length, int64 original_content_length) { 688 int64 received_content_length, int64 original_content_length) {
675 DCHECK_GE(received_content_length, 0); 689 DCHECK_GE(received_content_length, 0);
676 DCHECK_GE(original_content_length, 0); 690 DCHECK_GE(original_content_length, 0);
677 StoreAccumulatedContentLength(received_content_length, 691 StoreAccumulatedContentLength(received_content_length,
678 original_content_length); 692 original_content_length);
679 received_content_length_ += received_content_length; 693 received_content_length_ += received_content_length;
680 original_content_length_ += original_content_length; 694 original_content_length_ += original_content_length;
681 } 695 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698