Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 COMPONENTS_DATA_REDUCTION_PROXY_BROWSER_DATA_REDUCTION_PROXY_PROTOCOL_H_ | 5 #ifndef COMPONENTS_DATA_REDUCTION_PROXY_BROWSER_DATA_REDUCTION_PROXY_PROTOCOL_H_ |
| 6 #define COMPONENTS_DATA_REDUCTION_PROXY_BROWSER_DATA_REDUCTION_PROXY_PROTOCOL_H_ | 6 #define COMPONENTS_DATA_REDUCTION_PROXY_BROWSER_DATA_REDUCTION_PROXY_PROTOCOL_H_ |
| 7 | 7 |
| 8 #include "base/macros.h" | 8 #include "base/macros.h" |
| 9 #include "base/memory/ref_counted.h" | 9 #include "base/memory/ref_counted.h" |
| 10 | 10 |
| 11 namespace base { | 11 namespace base { |
| 12 class TimeDelta; | 12 class TimeDelta; |
| 13 } | 13 } |
| 14 | 14 |
| 15 namespace net { | 15 namespace net { |
| 16 class HttpResponseHeaders; | 16 class HttpResponseHeaders; |
| 17 class ProxyInfo; | |
| 17 class ProxyServer; | 18 class ProxyServer; |
| 18 class URLRequest; | 19 class URLRequest; |
| 19 } | 20 } |
| 20 | 21 |
| 21 class GURL; | 22 class GURL; |
| 22 | 23 |
| 23 namespace data_reduction_proxy { | 24 namespace data_reduction_proxy { |
| 24 | 25 |
| 25 class DataReductionProxyParams; | 26 class DataReductionProxyParams; |
| 26 | 27 |
| 27 // Decides whether to mark the data reduction proxy as temporarily bad and | 28 // Decides whether to mark the data reduction proxy as temporarily bad and |
| 28 // put it on the proxy retry list. Returns true if the request should be | 29 // put it on the proxy retry list. Returns true if the request should be |
| 29 // retried. Sets |override_response_headers| to redirect if so. | 30 // retried. Sets |override_response_headers| to redirect if so. |
| 30 bool MaybeBypassProxyAndPrepareToRetry( | 31 bool MaybeBypassProxyAndPrepareToRetry( |
| 31 const DataReductionProxyParams* params, | 32 const DataReductionProxyParams* params, |
| 32 net::URLRequest* request, | 33 net::URLRequest* request, |
| 33 const net::HttpResponseHeaders* original_response_headers, | 34 const net::HttpResponseHeaders* original_response_headers, |
| 34 scoped_refptr<net::HttpResponseHeaders>* override_response_headers); | 35 scoped_refptr<net::HttpResponseHeaders>* override_response_headers); |
| 35 | 36 |
| 37 // Upon |ProxyService.ResolveProxy()|, bypass if the effective proxy is the data | |
|
bengr
2014/07/07 16:28:14
Say something about when this method is called. E.
| |
| 38 // reduction proxy, the |net::LOAD_BYPASS_DATA_REDUCTION_PROXY| |load_flag| is | |
| 39 // set, and the DataCompressionProxyCriticalBypass Finch trial is set. | |
| 40 void OnResolveProxyHandler(const GURL& url, | |
| 41 int load_flags, | |
| 42 const DataReductionProxyParams* params, | |
| 43 net::ProxyInfo* result); | |
| 44 | |
| 36 // Returns true if the request method is idempotent. Only idempotent requests | 45 // Returns true if the request method is idempotent. Only idempotent requests |
| 37 // are retried on a bypass. Visible as part of the public API for testing. | 46 // are retried on a bypass. Visible as part of the public API for testing. |
| 38 bool IsRequestIdempotent(const net::URLRequest* request); | 47 bool IsRequestIdempotent(const net::URLRequest* request); |
| 39 | 48 |
| 40 // Sets the override headers to contain a status line that indicates a | 49 // Sets the override headers to contain a status line that indicates a |
| 41 // redirect (a 302), a "Location:" header that points to the request url, | 50 // redirect (a 302), a "Location:" header that points to the request url, |
| 42 // and sets load flags to bypass proxies. | 51 // and sets load flags to bypass proxies. |
| 43 // Visible as part of the public API for testing. | 52 // Visible as part of the public API for testing. |
| 44 void OverrideResponseAsRedirect( | 53 void OverrideResponseAsRedirect( |
| 45 net::URLRequest* request, | 54 net::URLRequest* request, |
| 46 const net::HttpResponseHeaders* original_response_headers, | 55 const net::HttpResponseHeaders* original_response_headers, |
| 47 scoped_refptr<net::HttpResponseHeaders>* override_response_headers); | 56 scoped_refptr<net::HttpResponseHeaders>* override_response_headers); |
| 48 | 57 |
| 49 // Adds non-empty entries in |data_reduction_proxies| to the retry map | 58 // Adds non-empty entries in |data_reduction_proxies| to the retry map |
| 50 // maintained by the proxy service of the request. Adds | 59 // maintained by the proxy service of the request. Adds |
| 51 // |data_reduction_proxies.second| to the retry list only if |bypass_all| is | 60 // |data_reduction_proxies.second| to the retry list only if |bypass_all| is |
| 52 // true. Visible as part of the public API for testing. | 61 // true. Visible as part of the public API for testing. |
| 53 void MarkProxiesAsBadUntil(net::URLRequest* request, | 62 void MarkProxiesAsBadUntil(net::URLRequest* request, |
| 54 base::TimeDelta& bypass_duration, | 63 base::TimeDelta& bypass_duration, |
| 55 bool bypass_all, | 64 bool bypass_all, |
| 56 const std::pair<GURL, GURL>& data_reduction_proxies); | 65 const std::pair<GURL, GURL>& data_reduction_proxies); |
| 57 | 66 |
| 58 } // namespace data_reduction_proxy | 67 } // namespace data_reduction_proxy |
| 59 #endif // COMPONENTS_DATA_REDUCTION_PROXY_BROWSER_DATA_REDUCTION_PROXY_PROTOCOL _H_ | 68 #endif // COMPONENTS_DATA_REDUCTION_PROXY_BROWSER_DATA_REDUCTION_PROXY_PROTOCOL _H_ |
| OLD | NEW |