Chromium Code Reviews| OLD | NEW |
|---|---|
| 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/metrics/variations/variations_http_header_provider.h" | 5 #include "chrome/browser/metrics/variations/variations_http_header_provider.h" |
| 6 | 6 |
| 7 #include <vector> | 7 #include <vector> |
| 8 | 8 |
| 9 #include "base/base64.h" | 9 #include "base/base64.h" |
| 10 #include "base/memory/singleton.h" | 10 #include "base/memory/singleton.h" |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 23 VariationsHttpHeaderProvider* VariationsHttpHeaderProvider::GetInstance() { | 23 VariationsHttpHeaderProvider* VariationsHttpHeaderProvider::GetInstance() { |
| 24 return Singleton<VariationsHttpHeaderProvider>::get(); | 24 return Singleton<VariationsHttpHeaderProvider>::get(); |
| 25 } | 25 } |
| 26 | 26 |
| 27 void VariationsHttpHeaderProvider::AppendHeaders( | 27 void VariationsHttpHeaderProvider::AppendHeaders( |
| 28 const GURL& url, | 28 const GURL& url, |
| 29 bool incognito, | 29 bool incognito, |
| 30 bool uma_enabled, | 30 bool uma_enabled, |
| 31 net::HttpRequestHeaders* headers) { | 31 net::HttpRequestHeaders* headers) { |
| 32 // Note the criteria for attaching Chrome experiment headers: | 32 // Note the criteria for attaching Chrome experiment headers: |
| 33 // 1. We only transmit to *.google.<TLD> or *.youtube.<TLD> domains. | 33 // 1. We only transmit to Google owned domains which can evaluate experiments. |
| 34 // 1a. These include hosts which have a standard postfix such as: | |
| 35 // *.doubleclick.net or *.googlesyndication.com or | |
| 36 // exactly www.googleadservices.com or | |
| 37 // international TLD domains *.google.<TLD> or *.youtube.<TLD>. | |
| 34 // 2. Only transmit for non-Incognito profiles. | 38 // 2. Only transmit for non-Incognito profiles. |
| 35 // 3. For the X-Chrome-UMA-Enabled bit, only set it if UMA is in fact enabled | 39 // 3. For the X-Chrome-UMA-Enabled bit, only set it if UMA is in fact enabled |
| 36 // for this install of Chrome. | 40 // for this install of Chrome. |
| 37 // 4. For the X-Client-Data header, only include non-empty variation IDs. | 41 // 4. For the X-Client-Data header, only include non-empty variation IDs. |
| 38 if (incognito || !ShouldAppendHeaders(url)) | 42 if (incognito || !ShouldAppendHeaders(url)) |
| 39 return; | 43 return; |
| 40 | 44 |
| 41 if (uma_enabled) | 45 if (uma_enabled) |
| 42 headers->SetHeaderIfMissing("X-Chrome-UMA-Enabled", "1"); | 46 headers->SetHeaderIfMissing("X-Chrome-UMA-Enabled", "1"); |
| 43 | 47 |
| (...skipping 127 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 171 variation_ids_header_ = hashed; | 175 variation_ids_header_ = hashed; |
| 172 } | 176 } |
| 173 | 177 |
| 174 // static | 178 // static |
| 175 bool VariationsHttpHeaderProvider::ShouldAppendHeaders(const GURL& url) { | 179 bool VariationsHttpHeaderProvider::ShouldAppendHeaders(const GURL& url) { |
| 176 if (google_util::IsGoogleDomainUrl(url, google_util::ALLOW_SUBDOMAIN, | 180 if (google_util::IsGoogleDomainUrl(url, google_util::ALLOW_SUBDOMAIN, |
| 177 google_util::ALLOW_NON_STANDARD_PORTS)) { | 181 google_util::ALLOW_NON_STANDARD_PORTS)) { |
| 178 return true; | 182 return true; |
| 179 } | 183 } |
| 180 | 184 |
| 181 // The below mirrors logic in IsGoogleDomainUrl(), but for youtube.<TLD>. | |
| 182 if (!url.is_valid() || !url.SchemeIsHTTPOrHTTPS()) | 185 if (!url.is_valid() || !url.SchemeIsHTTPOrHTTPS()) |
| 183 return false; | 186 return false; |
| 184 | 187 |
| 188 // Some domains don't have international TLD extensions, so testing for them | |
| 189 // is very straight forward. | |
| 185 const std::string host = url.host(); | 190 const std::string host = url.host(); |
| 191 if (EndsWith(host, ".doubleclick.net", false) || | |
| 192 EndsWith(host, ".googlesyndication.com", false) || | |
| 193 LowerCaseEqualsASCII(host, "www.googleadservices.com")) | |
|
Alexei Svitkine (slow)
2014/04/01 15:16:48
Nit: {}'s
(Some reviewers disagree on this, but i
jar (doing other things)
2014/04/01 16:55:42
Done. (and I agree with the nit change... my faul
| |
| 194 return true; | |
| 195 | |
| 196 // The below mirrors logic in IsGoogleDomainUrl(), but for youtube.<TLD>. | |
| 186 const size_t tld_length = net::registry_controlled_domains::GetRegistryLength( | 197 const size_t tld_length = net::registry_controlled_domains::GetRegistryLength( |
| 187 host, | 198 host, |
| 188 net::registry_controlled_domains::EXCLUDE_UNKNOWN_REGISTRIES, | 199 net::registry_controlled_domains::EXCLUDE_UNKNOWN_REGISTRIES, |
| 189 net::registry_controlled_domains::EXCLUDE_PRIVATE_REGISTRIES); | 200 net::registry_controlled_domains::EXCLUDE_PRIVATE_REGISTRIES); |
| 190 if ((tld_length == 0) || (tld_length == std::string::npos)) | 201 if ((tld_length == 0) || (tld_length == std::string::npos)) |
| 191 return false; | 202 return false; |
| 192 | 203 |
| 193 const std::string host_minus_tld(host, 0, host.length() - tld_length); | 204 const std::string host_minus_tld(host, 0, host.length() - tld_length); |
| 194 return LowerCaseEqualsASCII(host_minus_tld, "youtube.") || | 205 return LowerCaseEqualsASCII(host_minus_tld, "youtube.") || |
| 195 EndsWith(host_minus_tld, ".youtube.", false); | 206 EndsWith(host_minus_tld, ".youtube.", false); |
| 196 } | 207 } |
| 197 | 208 |
| 198 } // namespace chrome_variations | 209 } // namespace chrome_variations |
| OLD | NEW |