Update To 11.40.268.0
[platform/framework/web/crosswalk.git] / src / chrome / browser / net / chrome_network_delegate.h
index 469d0b6..8a13b1e 100644 (file)
 #include "base/memory/ref_counted.h"
 #include "base/memory/scoped_ptr.h"
 #include "base/values.h"
+#include "components/data_reduction_proxy/core/browser/data_reduction_proxy_metrics.h"
 #include "net/base/network_delegate.h"
+#include "net/proxy/proxy_retry_info.h"
 
+class ChromeExtensionsNetworkDelegate;
 class ClientHints;
 class CookieSettings;
-class ExtensionInfoMap;
 class PrefService;
+
 template<class T> class PrefMember;
 
 typedef PrefMember<bool> BooleanPrefMember;
@@ -29,15 +32,30 @@ class Value;
 
 namespace chrome_browser_net {
 class ConnectInterceptor;
-class LoadTimeStats;
 class Predictor;
 }
 
+namespace data_reduction_proxy {
+class DataReductionProxyAuthRequestHandler;
+class DataReductionProxyParams;
+class DataReductionProxyStatisticsPrefs;
+class DataReductionProxyUsageStats;
+}
+
+namespace domain_reliability {
+class DomainReliabilityMonitor;
+}
+
 namespace extensions {
 class EventRouterForwarder;
+class InfoMap;
 }
 
 namespace net {
+class ProxyConfig;
+class ProxyInfo;
+class ProxyServer;
+class ProxyService;
 class URLRequest;
 }
 
@@ -45,31 +63,53 @@ namespace policy {
 class URLBlacklistManager;
 }
 
+namespace prerender {
+class PrerenderTracker;
+}
+
 // ChromeNetworkDelegate is the central point from within the chrome code to
 // add hooks into the network stack.
 class ChromeNetworkDelegate : public net::NetworkDelegate {
  public:
+  // Provides an opportunity to interpose on proxy resolution. Called before
+  // ProxyService.ResolveProxy() returns. Two proxy configurations are provided
+  // that specify the data reduction proxy's configuration and the effective
+  // configuration according to the proxy service, respectively. Retry info is
+  // presumed to be from the proxy service.
+  typedef base::Callback<void(
+      const GURL& url,
+      int load_flags,
+      const net::ProxyConfig& data_reduction_proxy_config,
+      const net::ProxyConfig& proxy_service_proxy_config,
+      const net::ProxyRetryInfoMap& proxy_retry_info_map,
+      const data_reduction_proxy::DataReductionProxyParams* params,
+      net::ProxyInfo* result)> OnResolveProxyHandler;
+
+  // Provides an additional proxy configuration that can be consulted after
+  // proxy resolution.
+  typedef base::Callback<const net::ProxyConfig&()> ProxyConfigGetter;
+
   // |enable_referrers| (and all of the other optional PrefMembers) should be
   // initialized on the UI thread (see below) beforehand. This object's owner is
   // responsible for cleaning them up at shutdown.
   ChromeNetworkDelegate(extensions::EventRouterForwarder* event_router,
                         BooleanPrefMember* enable_referrers);
-  virtual ~ChromeNetworkDelegate();
+  ~ChromeNetworkDelegate() override;
 
-  // Not inlined because we assign a scoped_refptr, which requires us to include
-  // the header file.
-  void set_extension_info_map(ExtensionInfoMap* extension_info_map);
+  // Pass through to ChromeExtensionsNetworkDelegate::set_extension_info_map().
+  void set_extension_info_map(extensions::InfoMap* extension_info_map);
 
+#if defined(ENABLE_CONFIGURATION_POLICY)
   void set_url_blacklist_manager(
       const policy::URLBlacklistManager* url_blacklist_manager) {
     url_blacklist_manager_ = url_blacklist_manager;
   }
+#endif
 
   // If |profile| is NULL or not set, events will be broadcast to all profiles,
   // otherwise they will only be sent to the specified profile.
-  void set_profile(void* profile) {
-    profile_ = profile;
-  }
+  // Also pass through to ChromeExtensionsNetworkDelegate::set_profile().
+  void set_profile(void* profile);
 
   // |profile_path| is used to locate the "Downloads" folder on Chrome OS. If it
   // is set, the location of the Downloads folder for the profile is added to
@@ -87,10 +127,6 @@ class ChromeNetworkDelegate : public net::NetworkDelegate {
   // Causes requested URLs to be fed to |predictor| via ConnectInterceptor.
   void set_predictor(chrome_browser_net::Predictor* predictor);
 
-  void set_load_time_stats(chrome_browser_net::LoadTimeStats* load_time_stats) {
-    load_time_stats_ = load_time_stats;
-  }
-
   void set_enable_do_not_track(BooleanPrefMember* enable_do_not_track) {
     enable_do_not_track_ = enable_do_not_track;
   }
@@ -100,6 +136,56 @@ class ChromeNetworkDelegate : public net::NetworkDelegate {
     force_google_safe_search_ = force_google_safe_search;
   }
 
+  void set_data_reduction_proxy_enabled_pref(
+      BooleanPrefMember* data_reduction_proxy_enabled) {
+    data_reduction_proxy_enabled_ = data_reduction_proxy_enabled;
+  }
+
+  void set_domain_reliability_monitor(
+      domain_reliability::DomainReliabilityMonitor* monitor) {
+    domain_reliability_monitor_ = monitor;
+  }
+
+  void set_prerender_tracker(prerender::PrerenderTracker* prerender_tracker) {
+    prerender_tracker_ = prerender_tracker;
+  }
+
+  // |data_reduction_proxy_params_| must outlive this ChromeNetworkDelegate.
+  void set_data_reduction_proxy_params(
+      data_reduction_proxy::DataReductionProxyParams* params) {
+    data_reduction_proxy_params_ = params;
+  }
+
+  // |data_reduction_proxy_usage_stats_| must outlive this
+  // ChromeNetworkDelegate.
+  void set_data_reduction_proxy_usage_stats(
+      data_reduction_proxy::DataReductionProxyUsageStats* usage_stats) {
+    data_reduction_proxy_usage_stats_ = usage_stats;
+  }
+
+  // |data_reduction_proxy_auth_request_handler_| must outlive this
+  // ChromeNetworkDelegate.
+  void set_data_reduction_proxy_auth_request_handler(
+      data_reduction_proxy::DataReductionProxyAuthRequestHandler* handler) {
+    data_reduction_proxy_auth_request_handler_ = handler;
+  }
+
+  // |data_reduction_proxy_statistics_prefs_| must outlive this
+  // ChromeNetworkDelegate.
+  void set_data_reduction_proxy_statistics_prefs(
+      data_reduction_proxy::DataReductionProxyStatisticsPrefs*
+          statistics_prefs) {
+    data_reduction_proxy_statistics_prefs_ = statistics_prefs;
+  }
+
+  void set_on_resolve_proxy_handler(OnResolveProxyHandler handler) {
+    on_resolve_proxy_handler_ = handler;
+  }
+
+  void set_proxy_config_getter(const ProxyConfigGetter& getter) {
+    proxy_config_getter_ = getter;
+  }
+
   // Adds the Client Hints header to HTTP requests.
   void SetEnableClientHints();
 
@@ -123,82 +209,91 @@ class ChromeNetworkDelegate : public net::NetworkDelegate {
   // Creates a Value summary of the persistent state of the network session.
   // The caller is responsible for deleting the returned value.
   // Must be called on the UI thread.
-  static Value* HistoricNetworkStatsInfoToValue();
+  static base::Value* HistoricNetworkStatsInfoToValue(PrefService* prefs);
 
   // Creates a Value summary of the state of the network session. The caller is
   // responsible for deleting the returned value.
-  Value* SessionNetworkStatsInfoToValue() const;
+  base::Value* SessionNetworkStatsInfoToValue() const;
 
  private:
   friend class ChromeNetworkDelegateTest;
 
   // NetworkDelegate implementation.
-  virtual int OnBeforeURLRequest(net::URLRequest* request,
-                                 const net::CompletionCallback& callback,
-                                 GURL* new_url) OVERRIDE;
-  virtual int OnBeforeSendHeaders(net::URLRequest* request,
-                                  const net::CompletionCallback& callback,
-                                  net::HttpRequestHeaders* headers) OVERRIDE;
-  virtual void OnSendHeaders(net::URLRequest* request,
-                             const net::HttpRequestHeaders& headers) OVERRIDE;
-  virtual int OnHeadersReceived(
+  int OnBeforeURLRequest(net::URLRequest* request,
+                         const net::CompletionCallback& callback,
+                         GURL* new_url) override;
+  void OnResolveProxy(const GURL& url,
+                      int load_flags,
+                      const net::ProxyService& proxy_service,
+                      net::ProxyInfo* result) override;
+  void OnProxyFallback(const net::ProxyServer& bad_proxy,
+                       int net_error) override;
+  int OnBeforeSendHeaders(net::URLRequest* request,
+                          const net::CompletionCallback& callback,
+                          net::HttpRequestHeaders* headers) override;
+  void OnBeforeSendProxyHeaders(net::URLRequest* request,
+                                const net::ProxyInfo& proxy_info,
+                                net::HttpRequestHeaders* headers) override;
+  void OnSendHeaders(net::URLRequest* request,
+                     const net::HttpRequestHeaders& headers) override;
+  int OnHeadersReceived(
       net::URLRequest* request,
       const net::CompletionCallback& callback,
       const net::HttpResponseHeaders* original_response_headers,
-      scoped_refptr<net::HttpResponseHeaders>* override_response_headers)
-      OVERRIDE;
-  virtual void OnBeforeRedirect(net::URLRequest* request,
-                                const GURL& new_location) OVERRIDE;
-  virtual void OnResponseStarted(net::URLRequest* request) OVERRIDE;
-  virtual void OnRawBytesRead(const net::URLRequest& request,
-                              int bytes_read) OVERRIDE;
-  virtual void OnCompleted(net::URLRequest* request, bool started) OVERRIDE;
-  virtual void OnURLRequestDestroyed(net::URLRequest* request) OVERRIDE;
-  virtual void OnPACScriptError(int line_number,
-                                const string16& error) OVERRIDE;
-  virtual net::NetworkDelegate::AuthRequiredResponse OnAuthRequired(
+      scoped_refptr<net::HttpResponseHeaders>* override_response_headers,
+      GURL* allowed_unsafe_redirect_url) override;
+  void OnBeforeRedirect(net::URLRequest* request,
+                        const GURL& new_location) override;
+  void OnResponseStarted(net::URLRequest* request) override;
+  void OnRawBytesRead(const net::URLRequest& request, int bytes_read) override;
+  void OnCompleted(net::URLRequest* request, bool started) override;
+  void OnURLRequestDestroyed(net::URLRequest* request) override;
+  void OnPACScriptError(int line_number, const base::string16& error) override;
+  net::NetworkDelegate::AuthRequiredResponse OnAuthRequired(
       net::URLRequest* request,
       const net::AuthChallengeInfo& auth_info,
       const AuthCallback& callback,
-      net::AuthCredentials* credentials) OVERRIDE;
-  virtual bool OnCanGetCookies(const net::URLRequest& request,
-                               const net::CookieList& cookie_list) OVERRIDE;
-  virtual bool OnCanSetCookie(const net::URLRequest& request,
-                              const std::string& cookie_line,
-                              net::CookieOptions* options) OVERRIDE;
-  virtual bool OnCanAccessFile(const net::URLRequest& request,
-                               const base::FilePath& path) const OVERRIDE;
-  virtual bool OnCanThrottleRequest(
-      const net::URLRequest& request) const OVERRIDE;
-  virtual bool OnCanEnablePrivacyMode(
+      net::AuthCredentials* credentials) override;
+  bool OnCanGetCookies(const net::URLRequest& request,
+                       const net::CookieList& cookie_list) override;
+  bool OnCanSetCookie(const net::URLRequest& request,
+                      const std::string& cookie_line,
+                      net::CookieOptions* options) override;
+  bool OnCanAccessFile(const net::URLRequest& request,
+                       const base::FilePath& path) const override;
+  bool OnCanThrottleRequest(const net::URLRequest& request) const override;
+  bool OnCanEnablePrivacyMode(
       const GURL& url,
-      const GURL& first_party_for_cookies) const OVERRIDE;
-  virtual int OnBeforeSocketStreamConnect(
-      net::SocketStream* stream,
-      const net::CompletionCallback& callback) OVERRIDE;
-  virtual void OnRequestWaitStateChange(const net::URLRequest& request,
-                                        RequestWaitState state) OVERRIDE;
+      const GURL& first_party_for_cookies) const override;
+  bool OnCancelURLRequestWithPolicyViolatingReferrerHeader(
+      const net::URLRequest& request,
+      const GURL& target_url,
+      const GURL& referrer_url) const override;
 
   void AccumulateContentLength(
-      int64 received_payload_byte_count, int64 original_payload_byte_count,
-      bool data_reduction_proxy_was_used);
+      int64 received_payload_byte_count,
+      int64 original_payload_byte_count,
+      data_reduction_proxy::DataReductionProxyRequestType request_type);
+
+  scoped_ptr<ChromeExtensionsNetworkDelegate> extensions_delegate_;
 
-  scoped_refptr<extensions::EventRouterForwarder> event_router_;
   void* profile_;
   base::FilePath profile_path_;
   scoped_refptr<CookieSettings> cookie_settings_;
 
-  scoped_refptr<ExtensionInfoMap> extension_info_map_;
-
   scoped_ptr<chrome_browser_net::ConnectInterceptor> connect_interceptor_;
 
   // Weak, owned by our owner.
   BooleanPrefMember* enable_referrers_;
   BooleanPrefMember* enable_do_not_track_;
   BooleanPrefMember* force_google_safe_search_;
+  BooleanPrefMember* data_reduction_proxy_enabled_;
 
   // Weak, owned by our owner.
+#if defined(ENABLE_CONFIGURATION_POLICY)
   const policy::URLBlacklistManager* url_blacklist_manager_;
+#endif
+  domain_reliability::DomainReliabilityMonitor* domain_reliability_monitor_;
 
   // When true, allow access to all file:// URLs.
   static bool g_allow_file_access_;
@@ -211,9 +306,6 @@ class ChromeNetworkDelegate : public net::NetworkDelegate {
   // static anyway since it is based on a command-line flag.
   static bool g_never_throttle_requests_;
 
-  // Pointer to IOThread global, should outlive ChromeNetworkDelegate.
-  chrome_browser_net::LoadTimeStats* load_time_stats_;
-
   // Total size of all content (excluding headers) that has been received
   // over the network.
   int64 received_content_length_;
@@ -223,6 +315,24 @@ class ChromeNetworkDelegate : public net::NetworkDelegate {
 
   scoped_ptr<ClientHints> client_hints_;
 
+  bool first_request_;
+
+  prerender::PrerenderTracker* prerender_tracker_;
+
+  // |data_reduction_proxy_params_| must outlive this ChromeNetworkDelegate.
+  data_reduction_proxy::DataReductionProxyParams* data_reduction_proxy_params_;
+  // |data_reduction_proxy_usage_stats_| must outlive this
+  // ChromeNetworkDelegate.
+  data_reduction_proxy::DataReductionProxyUsageStats*
+      data_reduction_proxy_usage_stats_;
+  data_reduction_proxy::DataReductionProxyAuthRequestHandler*
+      data_reduction_proxy_auth_request_handler_;
+  data_reduction_proxy::DataReductionProxyStatisticsPrefs*
+      data_reduction_proxy_statistics_prefs_;
+
+  OnResolveProxyHandler on_resolve_proxy_handler_;
+  ProxyConfigGetter proxy_config_getter_;
+
   DISALLOW_COPY_AND_ASSIGN(ChromeNetworkDelegate);
 };