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

Unified Diff: components/data_reduction_proxy/browser/data_reduction_proxy_params.cc

Issue 390533003: Bypassed Bytes UMAs (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Addressed bengr comments Created 6 years, 5 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 side-by-side diff with in-line comments
Download patch
Index: components/data_reduction_proxy/browser/data_reduction_proxy_params.cc
diff --git a/components/data_reduction_proxy/browser/data_reduction_proxy_params.cc b/components/data_reduction_proxy/browser/data_reduction_proxy_params.cc
index 64b2ec1040c4cc533310f3826651f2c22525cdbd..49596e190453ce8f22e90b4fbb101db8c19ebfa5 100644
--- a/components/data_reduction_proxy/browser/data_reduction_proxy_params.cc
+++ b/components/data_reduction_proxy/browser/data_reduction_proxy_params.cc
@@ -6,11 +6,16 @@
#include "base/command_line.h"
#include "base/metrics/field_trial.h"
+#include "base/time/time.h"
#include "components/data_reduction_proxy/common/data_reduction_proxy_switches.h"
+#include "net/base/host_port_pair.h"
#include "net/proxy/proxy_info.h"
+#include "net/proxy/proxy_retry_info.h"
+#include "net/proxy/proxy_server.h"
#include "net/proxy/proxy_service.h"
#include "net/url_request/url_request.h"
#include "net/url_request/url_request_context.h"
+#include "url/url_constants.h"
using base::FieldTrialList;
@@ -161,7 +166,6 @@ bool DataReductionProxyParams::Init(
}
-
void DataReductionProxyParams::InitWithoutChecks() {
const CommandLine& command_line = *CommandLine::ForCurrentProcess();
std::string origin;
@@ -329,6 +333,83 @@ std::string DataReductionProxyParams::GetDefaultDevOrigin() const {
return std::string();
}
+bool DataReductionProxyParams::AreDataReductionProxiesBypassed(
+ const net::URLRequest& request, base::TimeDelta* min_retry_delay) const {
+ if (request.context() != NULL &&
+ request.context()->proxy_service() != NULL) {
+ return AreProxiesBypassed(
+ request.context()->proxy_service()->proxy_retry_info(),
+ request.url().SchemeIs(url::kHttpsScheme),
+ min_retry_delay);
+ }
+
+ return false;
+}
+
+bool DataReductionProxyParams::AreProxiesBypassed(
+ const net::ProxyRetryInfoMap& retry_map,
+ bool is_https,
+ base::TimeDelta* min_retry_delay) const {
+ if (retry_map.size() == 0)
+ return false;
+
+ if (is_https && alt_allowed_)
Alexei Svitkine (slow) 2014/07/22 13:57:21 Nit: Add {}'s
megjablon 2014/07/22 18:40:45 Done.
+ return ArePrimaryAndFallbackBypassed(
+ retry_map, ssl_origin_, GURL(), min_retry_delay);
+
+ if (allowed_) {
+ if (ArePrimaryAndFallbackBypassed(
Alexei Svitkine (slow) 2014/07/22 13:57:21 Nit: Merge with if above.
megjablon 2014/07/22 18:40:45 Done.
+ retry_map, origin_, fallback_origin_, min_retry_delay)) {
+ return true;
+ }
+ }
+
+ if (alt_allowed_) {
+ if (ArePrimaryAndFallbackBypassed(
Alexei Svitkine (slow) 2014/07/22 13:57:21 Nit: Merge with if above.
megjablon 2014/07/22 18:40:45 Done.
+ retry_map, alt_origin_, alt_fallback_origin_, min_retry_delay)) {
+ return true;
+ }
+ }
+
+ return false;
+}
+
+bool DataReductionProxyParams::ArePrimaryAndFallbackBypassed(
+ const net::ProxyRetryInfoMap& retry_map,
+ const GURL& primary,
+ const GURL& fallback,
+ base::TimeDelta* min_retry_delay) const {
+ base::TimeDelta min_delay;
+ net::ProxyRetryInfoMap::const_iterator found;
+
+ found = retry_map.find(
+ net::ProxyServer(primary.SchemeIs(url::kHttpsScheme) ?
+ net::ProxyServer::SCHEME_HTTPS : net::ProxyServer::SCHEME_HTTP,
+ net::HostPortPair::FromURL(primary)).ToURI());
+ if (!(found == retry_map.end())) {
Alexei Svitkine (slow) 2014/07/22 13:57:21 Nit: Change to !=
megjablon 2014/07/22 18:40:45 Done.
+ min_delay = found->second.current_delay;
+ if (fallback_allowed_ && fallback.is_valid()) {
+ found = retry_map.find(
+ net::ProxyServer(fallback.SchemeIs(url::kHttpsScheme) ?
+ net::ProxyServer::SCHEME_HTTPS : net::ProxyServer::SCHEME_HTTP,
+ net::HostPortPair::FromURL(fallback)).ToURI());
+ if (!(found == retry_map.end())) {
+ if(min_delay > found->second.current_delay)
Alexei Svitkine (slow) 2014/07/22 13:57:21 Nit: Add space after if
megjablon 2014/07/22 18:40:45 Done.
+ min_delay = found->second.current_delay;
+ if (min_retry_delay != NULL)
+ *min_retry_delay = min_delay;
+ return true;
+ }
+ } else {
Alexei Svitkine (slow) 2014/07/22 13:57:21 Nit: Reverse the cond of the if (make it check for
megjablon 2014/07/22 18:40:45 Done.
+ if (min_retry_delay != NULL)
+ *min_retry_delay = min_delay;
+ return true;
+ }
+ }
+
+ return false;
+}
+
std::string DataReductionProxyParams::GetDefaultOrigin() const {
#if defined(SPDY_PROXY_AUTH_ORIGIN)
return SPDY_PROXY_AUTH_ORIGIN;

Powered by Google App Engine
This is Rietveld 408576698