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 #include "components/domain_reliability/config.h" | 5 #include "components/domain_reliability/config.h" |
| 6 | 6 |
| 7 #include "base/json/json_reader.h" | 7 #include "base/json/json_reader.h" |
| 8 #include "base/json/json_value_converter.h" | 8 #include "base/json/json_value_converter.h" |
| 9 #include "base/rand_util.h" | 9 #include "base/rand_util.h" |
| 10 #include "base/strings/string_util.h" | 10 #include "base/strings/string_util.h" |
| 11 | 11 |
| 12 namespace { | 12 namespace { |
| 13 | 13 |
| 14 bool ConvertURL(const base::StringPiece& string_piece, GURL* url) { | 14 bool ConvertURL(const base::StringPiece& string_piece, GURL* url) { |
| 15 *url = GURL(string_piece.as_string()); | 15 *url = GURL(string_piece.as_string()); |
| 16 return url->is_valid(); | 16 return url->is_valid(); |
| 17 } | 17 } |
| 18 | 18 |
| 19 bool IsValidSampleRate(double p) { return p >= 0.0 && p <= 1.0; } | 19 bool IsValidSampleRate(double p) { return p >= 0.0 && p <= 1.0; } |
| 20 | 20 |
| 21 } // namespace | 21 } // namespace |
| 22 | 22 |
| 23 namespace domain_reliability { | 23 namespace domain_reliability { |
| 24 | 24 |
| 25 DomainReliabilityConfig::Resource::Resource() {} | 25 DomainReliabilityConfig::Resource::Resource() {} |
| 26 | |
| 27 DomainReliabilityConfig::Resource::~Resource() {} | 26 DomainReliabilityConfig::Resource::~Resource() {} |
| 28 | 27 |
| 29 bool DomainReliabilityConfig::Resource::MatchesUrlString( | 28 bool DomainReliabilityConfig::Resource::MatchesUrlString( |
| 30 const std::string& url_string) const { | 29 const std::string& url_string) const { |
| 31 ScopedVector<std::string>::const_iterator it; | 30 ScopedVector<std::string>::const_iterator it; |
| 32 | 31 |
| 33 for (it = url_patterns.begin(); it != url_patterns.end(); it++) { | 32 for (it = url_patterns.begin(); it != url_patterns.end(); it++) { |
| 34 if (MatchPattern(url_string, **it)) | 33 if (MatchPattern(url_string, **it)) |
| 35 return true; | 34 return true; |
| 36 } | 35 } |
| 37 | 36 |
| 38 return false; | 37 return false; |
| 39 } | 38 } |
|
Ryan Sleevi
2014/04/25 01:00:02
You should have unittests that cover this - in par
Deprecated (see juliatuttle)
2014/04/28 22:01:13
I don't think they're security-relevant, but I hav
| |
| 40 | 39 |
| 41 bool DomainReliabilityConfig::Resource::DecideIfShouldReportRequest( | 40 bool DomainReliabilityConfig::Resource::DecideIfShouldReportRequest( |
| 42 bool success) const { | 41 bool success) const { |
| 43 double sample_rate = success ? success_sample_rate : failure_sample_rate; | 42 double sample_rate = success ? success_sample_rate : failure_sample_rate; |
| 44 return base::RandDouble() < sample_rate; | 43 return base::RandDouble() < sample_rate; |
| 45 } | 44 } |
|
Ryan Sleevi
2014/04/25 01:00:02
API design: It's worth noting that calling this mu
Deprecated (see juliatuttle)
2014/04/28 22:01:13
We shouldn't have TOCTOU issues; once the config i
| |
| 46 | 45 |
| 47 // static | 46 // static |
| 48 void DomainReliabilityConfig::Resource::RegisterJSONConverter( | 47 void DomainReliabilityConfig::Resource::RegisterJSONConverter( |
| 49 base::JSONValueConverter<DomainReliabilityConfig::Resource>* converter) { | 48 base::JSONValueConverter<DomainReliabilityConfig::Resource>* converter) { |
| 50 converter->RegisterStringField("resource_name", &Resource::name); | 49 converter->RegisterStringField("resource_name", &Resource::name); |
| 51 converter->RegisterRepeatedString("url_patterns", &Resource::url_patterns); | 50 converter->RegisterRepeatedString("url_patterns", &Resource::url_patterns); |
| 52 converter->RegisterDoubleField("success_sample_rate", | 51 converter->RegisterDoubleField("success_sample_rate", |
| 53 &Resource::success_sample_rate); | 52 &Resource::success_sample_rate); |
| 54 converter->RegisterDoubleField("failure_sample_rate", | 53 converter->RegisterDoubleField("failure_sample_rate", |
| 55 &Resource::failure_sample_rate); | 54 &Resource::failure_sample_rate); |
| 56 } | 55 } |
| 57 | 56 |
| 58 bool DomainReliabilityConfig::Resource::IsValid() const { | 57 bool DomainReliabilityConfig::Resource::IsValid() const { |
| 59 return !name.empty() && !url_patterns.empty() && | 58 return !name.empty() && !url_patterns.empty() && |
| 60 IsValidSampleRate(success_sample_rate) && | 59 IsValidSampleRate(success_sample_rate) && |
| 61 IsValidSampleRate(failure_sample_rate); | 60 IsValidSampleRate(failure_sample_rate); |
| 62 } | 61 } |
| 63 | 62 |
| 64 DomainReliabilityConfig::Collector::Collector() {} | 63 DomainReliabilityConfig::Collector::Collector() {} |
| 65 | |
| 66 DomainReliabilityConfig::Collector::~Collector() {} | 64 DomainReliabilityConfig::Collector::~Collector() {} |
| 67 | 65 |
| 68 // static | 66 // static |
| 69 void DomainReliabilityConfig::Collector::RegisterJSONConverter( | 67 void DomainReliabilityConfig::Collector::RegisterJSONConverter( |
| 70 base::JSONValueConverter<DomainReliabilityConfig::Collector>* converter) { | 68 base::JSONValueConverter<DomainReliabilityConfig::Collector>* converter) { |
| 71 converter->RegisterCustomField<GURL>("upload_url", &Collector::upload_url, | 69 converter->RegisterCustomField<GURL>("upload_url", &Collector::upload_url, |
| 72 &ConvertURL); | 70 &ConvertURL); |
| 73 } | 71 } |
| 74 | 72 |
| 75 bool DomainReliabilityConfig::Collector::IsValid() const { | 73 bool DomainReliabilityConfig::Collector::IsValid() const { |
| 76 return upload_url.is_valid(); | 74 return upload_url.is_valid(); |
| 77 } | 75 } |
| 78 | 76 |
| 79 DomainReliabilityConfig::DomainReliabilityConfig() : valid_until(0.0) {} | 77 DomainReliabilityConfig::DomainReliabilityConfig() : valid_until(0.0) {} |
| 80 | |
| 81 DomainReliabilityConfig::~DomainReliabilityConfig() {} | 78 DomainReliabilityConfig::~DomainReliabilityConfig() {} |
| 82 | 79 |
| 83 // static | 80 // static |
| 84 scoped_ptr<const DomainReliabilityConfig> DomainReliabilityConfig::FromJSON( | 81 scoped_ptr<const DomainReliabilityConfig> DomainReliabilityConfig::FromJSON( |
| 85 const base::StringPiece& json) { | 82 const base::StringPiece& json) { |
| 86 scoped_ptr<base::Value> value(base::JSONReader::Read(json)); | 83 scoped_ptr<base::Value> value(base::JSONReader::Read(json)); |
| 87 if (!value) | 84 if (!value) |
| 88 return scoped_ptr<const DomainReliabilityConfig>(); | 85 return scoped_ptr<const DomainReliabilityConfig>(); |
| 89 | 86 |
| 90 DomainReliabilityConfig* config = new DomainReliabilityConfig(); | 87 DomainReliabilityConfig* config = new DomainReliabilityConfig(); |
| 91 base::JSONValueConverter<DomainReliabilityConfig> converter; | 88 base::JSONValueConverter<DomainReliabilityConfig> converter; |
| 92 if (!converter.Convert(*value, config)) { | 89 if (!converter.Convert(*value, config)) { |
| 93 return scoped_ptr<const DomainReliabilityConfig>(); | 90 return scoped_ptr<const DomainReliabilityConfig>(); |
| 94 } | 91 } |
|
Ryan Sleevi
2014/04/25 01:00:02
style: inconsistent bracing (compare 93/94 and 84/
Deprecated (see juliatuttle)
2014/04/28 22:01:13
Done.
| |
| 95 | 92 |
| 96 if (!config->IsValid()) | 93 if (!config->IsValid()) |
| 97 return scoped_ptr<const DomainReliabilityConfig>(); | 94 return scoped_ptr<const DomainReliabilityConfig>(); |
| 98 | 95 |
| 99 return scoped_ptr<const DomainReliabilityConfig>(config); | 96 return scoped_ptr<const DomainReliabilityConfig>(config); |
| 100 } | 97 } |
| 101 | 98 |
| 102 bool DomainReliabilityConfig::IsValid() const { | 99 bool DomainReliabilityConfig::IsValid() const { |
| 103 if (valid_until == 0.0 || domain.empty() || version.empty() || | 100 if (valid_until == 0.0 || domain.empty() || version.empty() || |
|
Ryan Sleevi
2014/04/25 01:00:02
What about negative values in valid_until ?
Deprecated (see juliatuttle)
2014/04/28 22:01:13
They are very expired. I would not suggest provid
| |
| 104 resources.empty() || collectors.empty()) { | 101 resources.empty() || collectors.empty()) { |
| 105 return false; | 102 return false; |
| 106 } | 103 } |
| 107 | 104 |
| 108 for (size_t i = 0; i < resources.size(); ++i) { | 105 for (size_t i = 0; i < resources.size(); ++i) { |
| 109 if (!resources[i]->IsValid()) | 106 if (!resources[i]->IsValid()) |
| 110 return false; | 107 return false; |
| 111 } | 108 } |
| 112 | 109 |
| 113 for (size_t i = 0; i < collectors.size(); ++i) { | 110 for (size_t i = 0; i < collectors.size(); ++i) { |
| 114 if (!collectors[i]->IsValid()) | 111 if (!collectors[i]->IsValid()) |
| 115 return false; | 112 return false; |
| 116 } | 113 } |
| 117 | 114 |
| 118 return true; | 115 return true; |
| 119 } | 116 } |
| 120 | 117 |
| 121 bool DomainReliabilityConfig::IsExpired(base::Time now) const { | 118 bool DomainReliabilityConfig::IsExpired(base::Time now) const { |
| 122 base::Time valid_until_time = base::Time::FromDoubleT(valid_until); | 119 base::Time valid_until_time = base::Time::FromDoubleT(valid_until); |
|
Ryan Sleevi
2014/04/25 01:00:02
Note that this can fail if IsValid() isn't checked
Deprecated (see juliatuttle)
2014/04/28 22:01:13
Added DCHECK.
| |
| 123 return now > valid_until_time; | 120 return now > valid_until_time; |
| 124 } | 121 } |
| 125 | 122 |
| 126 int DomainReliabilityConfig::GetResourceIndexForUrl(const GURL& url) const { | 123 int DomainReliabilityConfig::GetResourceIndexForUrl(const GURL& url) const { |
| 127 const std::string& url_string = url.spec(); | 124 const std::string& url_string = url.spec(); |
|
Ryan Sleevi
2014/04/25 01:00:02
Can this potentially allow sites to perform userna
Deprecated (see juliatuttle)
2014/04/28 22:01:13
I think by the time the URL hits here, it doesn't
| |
| 128 | 125 |
| 129 for (size_t i = 0; i < resources.size(); ++i) { | 126 for (size_t i = 0; i < resources.size(); ++i) { |
| 130 if (resources[i]->MatchesUrlString(url_string)) | 127 if (resources[i]->MatchesUrlString(url_string)) |
| 131 return static_cast<int>(i); | 128 return static_cast<int>(i); |
| 132 } | 129 } |
| 133 | 130 |
| 134 return -1; | 131 return -1; |
| 135 } | 132 } |
| 136 | 133 |
| 137 // static | 134 // static |
| 138 void DomainReliabilityConfig::RegisterJSONConverter( | 135 void DomainReliabilityConfig::RegisterJSONConverter( |
| 139 base::JSONValueConverter<DomainReliabilityConfig>* converter) { | 136 base::JSONValueConverter<DomainReliabilityConfig>* converter) { |
| 140 converter->RegisterStringField("config_version", | 137 converter->RegisterStringField("config_version", |
| 141 &DomainReliabilityConfig::version); | 138 &DomainReliabilityConfig::version); |
| 142 converter->RegisterDoubleField("config_valid_until", | 139 converter->RegisterDoubleField("config_valid_until", |
| 143 &DomainReliabilityConfig::valid_until); | 140 &DomainReliabilityConfig::valid_until); |
| 144 converter->RegisterStringField("monitored_domain", | 141 converter->RegisterStringField("monitored_domain", |
| 145 &DomainReliabilityConfig::domain); | 142 &DomainReliabilityConfig::domain); |
| 146 converter->RegisterRepeatedMessage("monitored_resources", | 143 converter->RegisterRepeatedMessage("monitored_resources", |
| 147 &DomainReliabilityConfig::resources); | 144 &DomainReliabilityConfig::resources); |
| 148 converter->RegisterRepeatedMessage("collectors", | 145 converter->RegisterRepeatedMessage("collectors", |
| 149 &DomainReliabilityConfig::collectors); | 146 &DomainReliabilityConfig::collectors); |
| 150 } | 147 } |
| 151 | 148 |
| 152 } // namespace domain_reliability | 149 } // namespace domain_reliability |
| OLD | NEW |