| OLD | NEW | 
|---|
| 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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 #ifndef NET_PROXY_PROXY_SERVICE_H_ | 5 #ifndef NET_PROXY_PROXY_SERVICE_H_ | 
| 6 #define NET_PROXY_PROXY_SERVICE_H_ | 6 #define NET_PROXY_PROXY_SERVICE_H_ | 
| 7 | 7 | 
| 8 #include <map> | 8 #include <map> | 
| 9 #include <vector> | 9 #include <vector> | 
| 10 | 10 | 
| (...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 58   bool Equals(const ProxyConfig& other) const; | 58   bool Equals(const ProxyConfig& other) const; | 
| 59 | 59 | 
| 60  private: | 60  private: | 
| 61   static int last_id_; | 61   static int last_id_; | 
| 62   int id_; | 62   int id_; | 
| 63 }; | 63 }; | 
| 64 | 64 | 
| 65 // Contains the information about when to retry a proxy server. | 65 // Contains the information about when to retry a proxy server. | 
| 66 struct ProxyRetryInfo { | 66 struct ProxyRetryInfo { | 
| 67   // We should not retry until this time. | 67   // We should not retry until this time. | 
| 68   TimeTicks bad_until; | 68   base::TimeTicks bad_until; | 
| 69 | 69 | 
| 70   // This is the current delay. If the proxy is still bad, we need to increase | 70   // This is the current delay. If the proxy is still bad, we need to increase | 
| 71   // this delay. | 71   // this delay. | 
| 72   TimeDelta current_delay; | 72   base::TimeDelta current_delay; | 
| 73 }; | 73 }; | 
| 74 | 74 | 
| 75 // Map of proxy servers with the associated RetryInfo structures. | 75 // Map of proxy servers with the associated RetryInfo structures. | 
| 76 typedef std::map<std::string, ProxyRetryInfo> ProxyRetryInfoMap; | 76 typedef std::map<std::string, ProxyRetryInfo> ProxyRetryInfoMap; | 
| 77 | 77 | 
| 78 // This class can be used to resolve the proxy server to use when loading a | 78 // This class can be used to resolve the proxy server to use when loading a | 
| 79 // HTTP(S) URL.  It uses to the given ProxyResolver to handle the actual proxy | 79 // HTTP(S) URL.  It uses to the given ProxyResolver to handle the actual proxy | 
| 80 // resolution.  See ProxyResolverWinHttp for example.  The consumer of this | 80 // resolution.  See ProxyResolverWinHttp for example.  The consumer of this | 
| 81 // class is responsible for ensuring that the ProxyResolver instance remains | 81 // class is responsible for ensuring that the ProxyResolver instance remains | 
| 82 // valid for the lifetime of the ProxyService. | 82 // valid for the lifetime of the ProxyService. | 
| (...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 154   scoped_ptr<base::Thread> pac_thread_; | 154   scoped_ptr<base::Thread> pac_thread_; | 
| 155 | 155 | 
| 156   // We store the IE proxy config and a counter that is incremented each time | 156   // We store the IE proxy config and a counter that is incremented each time | 
| 157   // the config changes. | 157   // the config changes. | 
| 158   ProxyConfig config_; | 158   ProxyConfig config_; | 
| 159 | 159 | 
| 160   // Indicates that the configuration is bad and should be ignored. | 160   // Indicates that the configuration is bad and should be ignored. | 
| 161   bool config_is_bad_; | 161   bool config_is_bad_; | 
| 162 | 162 | 
| 163   // The time when the proxy configuration was last read from the system. | 163   // The time when the proxy configuration was last read from the system. | 
| 164   TimeTicks config_last_update_time_; | 164   base::TimeTicks config_last_update_time_; | 
| 165 | 165 | 
| 166   // Map of the known bad proxies and the information about the retry time. | 166   // Map of the known bad proxies and the information about the retry time. | 
| 167   ProxyRetryInfoMap proxy_retry_info_; | 167   ProxyRetryInfoMap proxy_retry_info_; | 
| 168 | 168 | 
| 169   DISALLOW_COPY_AND_ASSIGN(ProxyService); | 169   DISALLOW_COPY_AND_ASSIGN(ProxyService); | 
| 170 }; | 170 }; | 
| 171 | 171 | 
| 172 // This class is used to hold a list of proxies returned by GetProxyForUrl or | 172 // This class is used to hold a list of proxies returned by GetProxyForUrl or | 
| 173 // manually configured. It handles proxy fallback if multiple servers are | 173 // manually configured. It handles proxy fallback if multiple servers are | 
| 174 // specified. | 174 // specified. | 
| (...skipping 97 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 272   // code if otherwise. | 272   // code if otherwise. | 
| 273   virtual int GetProxyForURL(const std::string& query_url, | 273   virtual int GetProxyForURL(const std::string& query_url, | 
| 274                              const std::string& pac_url, | 274                              const std::string& pac_url, | 
| 275                              ProxyInfo* results) = 0; | 275                              ProxyInfo* results) = 0; | 
| 276 }; | 276 }; | 
| 277 | 277 | 
| 278 }  // namespace net | 278 }  // namespace net | 
| 279 | 279 | 
| 280 #endif  // NET_PROXY_PROXY_SERVICE_H_ | 280 #endif  // NET_PROXY_PROXY_SERVICE_H_ | 
| 281 | 281 | 
| OLD | NEW | 
|---|