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/data_reduction_proxy/browser/data_reduction_proxy_settings.
h" | 5 #include "components/data_reduction_proxy/browser/data_reduction_proxy_settings.
h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/command_line.h" | 8 #include "base/command_line.h" |
9 #include "base/metrics/field_trial.h" | 9 #include "base/metrics/field_trial.h" |
10 #include "base/metrics/histogram.h" | 10 #include "base/metrics/histogram.h" |
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
86 | 86 |
87 namespace data_reduction_proxy { | 87 namespace data_reduction_proxy { |
88 | 88 |
89 DataReductionProxySettings::DataReductionProxySettings( | 89 DataReductionProxySettings::DataReductionProxySettings( |
90 DataReductionProxyParams* params) | 90 DataReductionProxyParams* params) |
91 : restricted_by_carrier_(false), | 91 : restricted_by_carrier_(false), |
92 enabled_by_user_(false), | 92 enabled_by_user_(false), |
93 disabled_on_vpn_(false), | 93 disabled_on_vpn_(false), |
94 unreachable_(false), | 94 unreachable_(false), |
95 prefs_(NULL), | 95 prefs_(NULL), |
96 local_state_prefs_(NULL), | |
97 url_request_context_getter_(NULL), | 96 url_request_context_getter_(NULL), |
98 configurator_(NULL) { | 97 configurator_(NULL) { |
99 DCHECK(params); | 98 DCHECK(params); |
100 params_.reset(params); | 99 params_.reset(params); |
101 } | 100 } |
102 | 101 |
103 DataReductionProxySettings::~DataReductionProxySettings() { | 102 DataReductionProxySettings::~DataReductionProxySettings() { |
104 if (params_->allowed()) | 103 if (params_->allowed()) |
105 spdy_proxy_auth_enabled_.Destroy(); | 104 spdy_proxy_auth_enabled_.Destroy(); |
106 net::NetworkChangeNotifier::RemoveIPAddressObserver(this); | 105 net::NetworkChangeNotifier::RemoveIPAddressObserver(this); |
107 } | 106 } |
108 | 107 |
109 void DataReductionProxySettings::InitPrefMembers() { | 108 void DataReductionProxySettings::InitPrefMembers() { |
110 DCHECK(thread_checker_.CalledOnValidThread()); | 109 DCHECK(thread_checker_.CalledOnValidThread()); |
111 spdy_proxy_auth_enabled_.Init( | 110 spdy_proxy_auth_enabled_.Init( |
112 prefs::kDataReductionProxyEnabled, | 111 prefs::kDataReductionProxyEnabled, |
113 GetOriginalProfilePrefs(), | 112 GetOriginalProfilePrefs(), |
114 base::Bind(&DataReductionProxySettings::OnProxyEnabledPrefChange, | 113 base::Bind(&DataReductionProxySettings::OnProxyEnabledPrefChange, |
115 base::Unretained(this))); | 114 base::Unretained(this))); |
116 data_reduction_proxy_alternative_enabled_.Init( | 115 data_reduction_proxy_alternative_enabled_.Init( |
117 prefs::kDataReductionProxyAltEnabled, | 116 prefs::kDataReductionProxyAltEnabled, |
118 GetOriginalProfilePrefs(), | 117 GetOriginalProfilePrefs(), |
119 base::Bind( | 118 base::Bind( |
120 &DataReductionProxySettings::OnProxyAlternativeEnabledPrefChange, | 119 &DataReductionProxySettings::OnProxyAlternativeEnabledPrefChange, |
121 base::Unretained(this))); | 120 base::Unretained(this))); |
122 } | 121 } |
123 | 122 |
124 void DataReductionProxySettings::InitDataReductionProxySettings( | 123 void DataReductionProxySettings::InitDataReductionProxySettings( |
125 PrefService* prefs, | 124 PrefService* prefs, |
126 PrefService* local_state_prefs, | |
127 net::URLRequestContextGetter* url_request_context_getter) { | 125 net::URLRequestContextGetter* url_request_context_getter) { |
128 DCHECK(thread_checker_.CalledOnValidThread()); | 126 DCHECK(thread_checker_.CalledOnValidThread()); |
129 DCHECK(prefs); | 127 DCHECK(prefs); |
130 DCHECK(local_state_prefs); | |
131 DCHECK(url_request_context_getter); | 128 DCHECK(url_request_context_getter); |
132 prefs_ = prefs; | 129 prefs_ = prefs; |
133 local_state_prefs_ = local_state_prefs; | |
134 url_request_context_getter_ = url_request_context_getter; | 130 url_request_context_getter_ = url_request_context_getter; |
135 InitPrefMembers(); | 131 InitPrefMembers(); |
136 RecordDataReductionInit(); | 132 RecordDataReductionInit(); |
137 | 133 |
138 // Disable the proxy if it is not allowed to be used. | 134 // Disable the proxy if it is not allowed to be used. |
139 if (!params_->allowed()) | 135 if (!params_->allowed()) |
140 return; | 136 return; |
141 | 137 |
142 AddDefaultProxyBypassRules(); | 138 AddDefaultProxyBypassRules(); |
143 net::NetworkChangeNotifier::AddIPAddressObserver(this); | 139 net::NetworkChangeNotifier::AddIPAddressObserver(this); |
144 | 140 |
145 // We set or reset the proxy pref at startup. | 141 // We set or reset the proxy pref at startup. |
146 MaybeActivateDataReductionProxy(true); | 142 MaybeActivateDataReductionProxy(true); |
147 } | 143 } |
148 | 144 |
149 void DataReductionProxySettings::InitDataReductionProxySettings( | 145 void DataReductionProxySettings::InitDataReductionProxySettings( |
150 PrefService* prefs, | 146 PrefService* prefs, |
151 PrefService* local_state_prefs, | |
152 net::URLRequestContextGetter* url_request_context_getter, | 147 net::URLRequestContextGetter* url_request_context_getter, |
153 DataReductionProxyConfigurator* configurator) { | 148 DataReductionProxyConfigurator* configurator) { |
154 InitDataReductionProxySettings(prefs, | 149 InitDataReductionProxySettings(prefs, |
155 local_state_prefs, | |
156 url_request_context_getter); | 150 url_request_context_getter); |
157 SetProxyConfigurator(configurator); | 151 SetProxyConfigurator(configurator); |
158 } | 152 } |
159 | 153 |
| 154 |
| 155 void DataReductionProxySettings::SetDataReductionProxyStatisticsPrefs( |
| 156 DataReductionProxyStatisticsPrefs* statistics_prefs) { |
| 157 statistics_prefs_ = statistics_prefs; |
| 158 } |
| 159 |
160 void DataReductionProxySettings::SetOnDataReductionEnabledCallback( | 160 void DataReductionProxySettings::SetOnDataReductionEnabledCallback( |
161 const base::Callback<void(bool)>& on_data_reduction_proxy_enabled) { | 161 const base::Callback<void(bool)>& on_data_reduction_proxy_enabled) { |
162 on_data_reduction_proxy_enabled_ = on_data_reduction_proxy_enabled; | 162 on_data_reduction_proxy_enabled_ = on_data_reduction_proxy_enabled; |
163 on_data_reduction_proxy_enabled_.Run(IsDataReductionProxyEnabled()); | 163 on_data_reduction_proxy_enabled_.Run(IsDataReductionProxyEnabled()); |
164 } | 164 } |
165 | 165 |
166 void DataReductionProxySettings::SetProxyConfigurator( | 166 void DataReductionProxySettings::SetProxyConfigurator( |
167 DataReductionProxyConfigurator* configurator) { | 167 DataReductionProxyConfigurator* configurator) { |
168 DCHECK(configurator); | 168 DCHECK(configurator); |
169 configurator_ = configurator; | 169 configurator_ = configurator; |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
201 if (!params_->alternative_allowed()) | 201 if (!params_->alternative_allowed()) |
202 return; | 202 return; |
203 if (data_reduction_proxy_alternative_enabled_.GetValue() != enabled) { | 203 if (data_reduction_proxy_alternative_enabled_.GetValue() != enabled) { |
204 data_reduction_proxy_alternative_enabled_.SetValue(enabled); | 204 data_reduction_proxy_alternative_enabled_.SetValue(enabled); |
205 OnProxyAlternativeEnabledPrefChange(); | 205 OnProxyAlternativeEnabledPrefChange(); |
206 } | 206 } |
207 } | 207 } |
208 | 208 |
209 int64 DataReductionProxySettings::GetDataReductionLastUpdateTime() { | 209 int64 DataReductionProxySettings::GetDataReductionLastUpdateTime() { |
210 DCHECK(thread_checker_.CalledOnValidThread()); | 210 DCHECK(thread_checker_.CalledOnValidThread()); |
211 PrefService* local_state = GetLocalStatePrefs(); | 211 if (!statistics_prefs_) { |
| 212 return 0; |
| 213 } |
212 int64 last_update_internal = | 214 int64 last_update_internal = |
213 local_state->GetInt64(prefs::kDailyHttpContentLengthLastUpdateDate); | 215 statistics_prefs_->GetInt64(prefs::kDailyHttpContentLengthLastUpdateDate); |
214 base::Time last_update = base::Time::FromInternalValue(last_update_internal); | 216 base::Time last_update = base::Time::FromInternalValue(last_update_internal); |
215 return static_cast<int64>(last_update.ToJsTime()); | 217 return static_cast<int64>(last_update.ToJsTime()); |
216 } | 218 } |
217 | 219 |
218 DataReductionProxySettings::ContentLengthList | 220 DataReductionProxySettings::ContentLengthList |
219 DataReductionProxySettings::GetDailyOriginalContentLengths() { | 221 DataReductionProxySettings::GetDailyOriginalContentLengths() { |
220 DCHECK(thread_checker_.CalledOnValidThread()); | 222 DCHECK(thread_checker_.CalledOnValidThread()); |
221 return GetDailyContentLengths(prefs::kDailyHttpOriginalContentLength); | 223 return GetDailyContentLengths(prefs::kDailyHttpOriginalContentLength); |
222 } | 224 } |
223 | 225 |
(...skipping 74 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
298 } | 300 } |
299 } | 301 } |
300 restricted_by_carrier_ = true; | 302 restricted_by_carrier_ = true; |
301 } | 303 } |
302 | 304 |
303 PrefService* DataReductionProxySettings::GetOriginalProfilePrefs() { | 305 PrefService* DataReductionProxySettings::GetOriginalProfilePrefs() { |
304 DCHECK(thread_checker_.CalledOnValidThread()); | 306 DCHECK(thread_checker_.CalledOnValidThread()); |
305 return prefs_; | 307 return prefs_; |
306 } | 308 } |
307 | 309 |
308 PrefService* DataReductionProxySettings::GetLocalStatePrefs() { | |
309 DCHECK(thread_checker_.CalledOnValidThread()); | |
310 return local_state_prefs_; | |
311 } | |
312 | |
313 void DataReductionProxySettings::AddDefaultProxyBypassRules() { | 310 void DataReductionProxySettings::AddDefaultProxyBypassRules() { |
314 // localhost | 311 // localhost |
315 DCHECK(configurator_); | 312 DCHECK(configurator_); |
316 configurator_->AddHostPatternToBypass("<local>"); | 313 configurator_->AddHostPatternToBypass("<local>"); |
317 // RFC1918 private addresses. | 314 // RFC1918 private addresses. |
318 configurator_->AddHostPatternToBypass("10.0.0.0/8"); | 315 configurator_->AddHostPatternToBypass("10.0.0.0/8"); |
319 configurator_->AddHostPatternToBypass("172.16.0.0/12"); | 316 configurator_->AddHostPatternToBypass("172.16.0.0/12"); |
320 configurator_->AddHostPatternToBypass("192.168.0.0/16"); | 317 configurator_->AddHostPatternToBypass("192.168.0.0/16"); |
321 // RFC4193 private addresses. | 318 // RFC4193 private addresses. |
322 configurator_->AddHostPatternToBypass("fc00::/7"); | 319 configurator_->AddHostPatternToBypass("fc00::/7"); |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
366 | 363 |
367 void DataReductionProxySettings::OnProxyAlternativeEnabledPrefChange() { | 364 void DataReductionProxySettings::OnProxyAlternativeEnabledPrefChange() { |
368 DCHECK(thread_checker_.CalledOnValidThread()); | 365 DCHECK(thread_checker_.CalledOnValidThread()); |
369 if (!params_->alternative_allowed()) | 366 if (!params_->alternative_allowed()) |
370 return; | 367 return; |
371 MaybeActivateDataReductionProxy(false); | 368 MaybeActivateDataReductionProxy(false); |
372 } | 369 } |
373 | 370 |
374 void DataReductionProxySettings::ResetDataReductionStatistics() { | 371 void DataReductionProxySettings::ResetDataReductionStatistics() { |
375 DCHECK(thread_checker_.CalledOnValidThread()); | 372 DCHECK(thread_checker_.CalledOnValidThread()); |
376 PrefService* prefs = GetLocalStatePrefs(); | 373 if (!statistics_prefs_) |
377 if (!prefs) | |
378 return; | 374 return; |
379 ListPrefUpdate original_update(prefs, prefs::kDailyHttpOriginalContentLength); | 375 base::ListValue* original_update = |
380 ListPrefUpdate received_update(prefs, prefs::kDailyHttpReceivedContentLength); | 376 statistics_prefs_->GetList(prefs::kDailyHttpOriginalContentLength); |
| 377 base::ListValue* received_update = |
| 378 statistics_prefs_->GetList(prefs::kDailyHttpReceivedContentLength); |
381 original_update->Clear(); | 379 original_update->Clear(); |
382 received_update->Clear(); | 380 received_update->Clear(); |
383 for (size_t i = 0; i < kNumDaysInHistory; ++i) { | 381 for (size_t i = 0; i < kNumDaysInHistory; ++i) { |
384 original_update->AppendString(base::Int64ToString(0)); | 382 original_update->AppendString(base::Int64ToString(0)); |
385 received_update->AppendString(base::Int64ToString(0)); | 383 received_update->AppendString(base::Int64ToString(0)); |
386 } | 384 } |
387 } | 385 } |
388 | 386 |
389 void DataReductionProxySettings::MaybeActivateDataReductionProxy( | 387 void DataReductionProxySettings::MaybeActivateDataReductionProxy( |
390 bool at_startup) { | 388 bool at_startup) { |
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
475 | 473 |
476 void DataReductionProxySettings::ResetParamsForTest( | 474 void DataReductionProxySettings::ResetParamsForTest( |
477 DataReductionProxyParams* params) { | 475 DataReductionProxyParams* params) { |
478 params_.reset(params); | 476 params_.reset(params); |
479 } | 477 } |
480 | 478 |
481 DataReductionProxySettings::ContentLengthList | 479 DataReductionProxySettings::ContentLengthList |
482 DataReductionProxySettings::GetDailyContentLengths(const char* pref_name) { | 480 DataReductionProxySettings::GetDailyContentLengths(const char* pref_name) { |
483 DCHECK(thread_checker_.CalledOnValidThread()); | 481 DCHECK(thread_checker_.CalledOnValidThread()); |
484 DataReductionProxySettings::ContentLengthList content_lengths; | 482 DataReductionProxySettings::ContentLengthList content_lengths; |
485 const base::ListValue* list_value = GetLocalStatePrefs()->GetList(pref_name); | 483 if (!statistics_prefs_) { |
| 484 return content_lengths; |
| 485 } |
| 486 const base::ListValue* list_value = statistics_prefs_->GetList(pref_name); |
486 if (list_value->GetSize() == kNumDaysInHistory) { | 487 if (list_value->GetSize() == kNumDaysInHistory) { |
487 for (size_t i = 0; i < kNumDaysInHistory; ++i) { | 488 for (size_t i = 0; i < kNumDaysInHistory; ++i) { |
488 content_lengths.push_back(GetInt64PrefValue(*list_value, i)); | 489 content_lengths.push_back(GetInt64PrefValue(*list_value, i)); |
489 } | 490 } |
490 } | 491 } |
491 return content_lengths; | 492 return content_lengths; |
492 } | 493 } |
493 | 494 |
494 void DataReductionProxySettings::GetContentLengths( | 495 void DataReductionProxySettings::GetContentLengths( |
495 unsigned int days, | 496 unsigned int days, |
496 int64* original_content_length, | 497 int64* original_content_length, |
497 int64* received_content_length, | 498 int64* received_content_length, |
498 int64* last_update_time) { | 499 int64* last_update_time) { |
499 DCHECK(thread_checker_.CalledOnValidThread()); | 500 DCHECK(thread_checker_.CalledOnValidThread()); |
500 DCHECK_LE(days, kNumDaysInHistory); | 501 DCHECK_LE(days, kNumDaysInHistory); |
501 PrefService* local_state = GetLocalStatePrefs(); | 502 if (!statistics_prefs_) { |
502 if (!local_state) { | |
503 *original_content_length = 0L; | 503 *original_content_length = 0L; |
504 *received_content_length = 0L; | 504 *received_content_length = 0L; |
505 *last_update_time = 0L; | 505 *last_update_time = 0L; |
506 return; | 506 return; |
507 } | 507 } |
508 | 508 |
509 const base::ListValue* original_list = | 509 const base::ListValue* original_list = |
510 local_state->GetList(prefs::kDailyHttpOriginalContentLength); | 510 statistics_prefs_->GetList(prefs::kDailyHttpOriginalContentLength); |
511 const base::ListValue* received_list = | 511 const base::ListValue* received_list = |
512 local_state->GetList(prefs::kDailyHttpReceivedContentLength); | 512 statistics_prefs_->GetList(prefs::kDailyHttpReceivedContentLength); |
513 | 513 |
514 if (original_list->GetSize() != kNumDaysInHistory || | 514 if (original_list->GetSize() != kNumDaysInHistory || |
515 received_list->GetSize() != kNumDaysInHistory) { | 515 received_list->GetSize() != kNumDaysInHistory) { |
516 *original_content_length = 0L; | 516 *original_content_length = 0L; |
517 *received_content_length = 0L; | 517 *received_content_length = 0L; |
518 *last_update_time = 0L; | 518 *last_update_time = 0L; |
519 return; | 519 return; |
520 } | 520 } |
521 | 521 |
522 int64 orig = 0L; | 522 int64 orig = 0L; |
523 int64 recv = 0L; | 523 int64 recv = 0L; |
524 // Include days from the end of the list going backwards. | 524 // Include days from the end of the list going backwards. |
525 for (size_t i = kNumDaysInHistory - days; | 525 for (size_t i = kNumDaysInHistory - days; |
526 i < kNumDaysInHistory; ++i) { | 526 i < kNumDaysInHistory; ++i) { |
527 orig += GetInt64PrefValue(*original_list, i); | 527 orig += GetInt64PrefValue(*original_list, i); |
528 recv += GetInt64PrefValue(*received_list, i); | 528 recv += GetInt64PrefValue(*received_list, i); |
529 } | 529 } |
530 *original_content_length = orig; | 530 *original_content_length = orig; |
531 *received_content_length = recv; | 531 *received_content_length = recv; |
532 *last_update_time = | 532 *last_update_time = |
533 local_state->GetInt64(prefs::kDailyHttpContentLengthLastUpdateDate); | 533 statistics_prefs_->GetInt64(prefs::kDailyHttpContentLengthLastUpdateDate); |
534 } | 534 } |
535 | 535 |
536 net::URLFetcher* DataReductionProxySettings::GetBaseURLFetcher( | 536 net::URLFetcher* DataReductionProxySettings::GetBaseURLFetcher( |
537 const GURL& gurl, | 537 const GURL& gurl, |
538 int load_flags) { | 538 int load_flags) { |
539 | 539 |
540 net::URLFetcher* fetcher = net::URLFetcher::Create(gurl, | 540 net::URLFetcher* fetcher = net::URLFetcher::Create(gurl, |
541 net::URLFetcher::GET, | 541 net::URLFetcher::GET, |
542 this); | 542 this); |
543 fetcher->SetLoadFlags(load_flags); | 543 fetcher->SetLoadFlags(load_flags); |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
604 SetProxyConfigs(enabled_by_user_, | 604 SetProxyConfigs(enabled_by_user_, |
605 IsDataReductionProxyAlternativeEnabled(), | 605 IsDataReductionProxyAlternativeEnabled(), |
606 restricted_by_carrier_, | 606 restricted_by_carrier_, |
607 false); | 607 false); |
608 } | 608 } |
609 disabled_on_vpn_ = false; | 609 disabled_on_vpn_ = false; |
610 return false; | 610 return false; |
611 } | 611 } |
612 | 612 |
613 } // namespace data_reduction_proxy | 613 } // namespace data_reduction_proxy |
OLD | NEW |