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 void DataReductionProxySettings::SetDataReductionProxyStatisticsPrefs( |
| 155 DataReductionProxyStatisticsPrefs* statistics_prefs) { |
| 156 statistics_prefs_ = statistics_prefs; |
| 157 } |
| 158 |
160 void DataReductionProxySettings::SetOnDataReductionEnabledCallback( | 159 void DataReductionProxySettings::SetOnDataReductionEnabledCallback( |
161 const base::Callback<void(bool)>& on_data_reduction_proxy_enabled) { | 160 const base::Callback<void(bool)>& on_data_reduction_proxy_enabled) { |
162 on_data_reduction_proxy_enabled_ = on_data_reduction_proxy_enabled; | 161 on_data_reduction_proxy_enabled_ = on_data_reduction_proxy_enabled; |
163 on_data_reduction_proxy_enabled_.Run(IsDataReductionProxyEnabled()); | 162 on_data_reduction_proxy_enabled_.Run(IsDataReductionProxyEnabled()); |
164 } | 163 } |
165 | 164 |
166 void DataReductionProxySettings::SetProxyConfigurator( | 165 void DataReductionProxySettings::SetProxyConfigurator( |
167 DataReductionProxyConfigurator* configurator) { | 166 DataReductionProxyConfigurator* configurator) { |
168 DCHECK(configurator); | 167 DCHECK(configurator); |
169 configurator_ = configurator; | 168 configurator_ = configurator; |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
201 if (!params_->alternative_allowed()) | 200 if (!params_->alternative_allowed()) |
202 return; | 201 return; |
203 if (data_reduction_proxy_alternative_enabled_.GetValue() != enabled) { | 202 if (data_reduction_proxy_alternative_enabled_.GetValue() != enabled) { |
204 data_reduction_proxy_alternative_enabled_.SetValue(enabled); | 203 data_reduction_proxy_alternative_enabled_.SetValue(enabled); |
205 OnProxyAlternativeEnabledPrefChange(); | 204 OnProxyAlternativeEnabledPrefChange(); |
206 } | 205 } |
207 } | 206 } |
208 | 207 |
209 int64 DataReductionProxySettings::GetDataReductionLastUpdateTime() { | 208 int64 DataReductionProxySettings::GetDataReductionLastUpdateTime() { |
210 DCHECK(thread_checker_.CalledOnValidThread()); | 209 DCHECK(thread_checker_.CalledOnValidThread()); |
211 PrefService* local_state = GetLocalStatePrefs(); | 210 DCHECK(statistics_prefs_); |
212 int64 last_update_internal = | 211 int64 last_update_internal = |
213 local_state->GetInt64(prefs::kDailyHttpContentLengthLastUpdateDate); | 212 statistics_prefs_->GetInt64(prefs::kDailyHttpContentLengthLastUpdateDate); |
214 base::Time last_update = base::Time::FromInternalValue(last_update_internal); | 213 base::Time last_update = base::Time::FromInternalValue(last_update_internal); |
215 return static_cast<int64>(last_update.ToJsTime()); | 214 return static_cast<int64>(last_update.ToJsTime()); |
216 } | 215 } |
217 | 216 |
218 DataReductionProxySettings::ContentLengthList | 217 DataReductionProxySettings::ContentLengthList |
219 DataReductionProxySettings::GetDailyOriginalContentLengths() { | 218 DataReductionProxySettings::GetDailyOriginalContentLengths() { |
220 DCHECK(thread_checker_.CalledOnValidThread()); | 219 DCHECK(thread_checker_.CalledOnValidThread()); |
221 return GetDailyContentLengths(prefs::kDailyHttpOriginalContentLength); | 220 return GetDailyContentLengths(prefs::kDailyHttpOriginalContentLength); |
222 } | 221 } |
223 | 222 |
(...skipping 69 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
293 } | 292 } |
294 } | 293 } |
295 restricted_by_carrier_ = true; | 294 restricted_by_carrier_ = true; |
296 } | 295 } |
297 | 296 |
298 PrefService* DataReductionProxySettings::GetOriginalProfilePrefs() { | 297 PrefService* DataReductionProxySettings::GetOriginalProfilePrefs() { |
299 DCHECK(thread_checker_.CalledOnValidThread()); | 298 DCHECK(thread_checker_.CalledOnValidThread()); |
300 return prefs_; | 299 return prefs_; |
301 } | 300 } |
302 | 301 |
303 PrefService* DataReductionProxySettings::GetLocalStatePrefs() { | |
304 DCHECK(thread_checker_.CalledOnValidThread()); | |
305 return local_state_prefs_; | |
306 } | |
307 | |
308 void DataReductionProxySettings::AddDefaultProxyBypassRules() { | 302 void DataReductionProxySettings::AddDefaultProxyBypassRules() { |
309 // localhost | 303 // localhost |
310 DCHECK(configurator_); | 304 DCHECK(configurator_); |
311 configurator_->AddHostPatternToBypass("<local>"); | 305 configurator_->AddHostPatternToBypass("<local>"); |
312 // RFC1918 private addresses. | 306 // RFC1918 private addresses. |
313 configurator_->AddHostPatternToBypass("10.0.0.0/8"); | 307 configurator_->AddHostPatternToBypass("10.0.0.0/8"); |
314 configurator_->AddHostPatternToBypass("172.16.0.0/12"); | 308 configurator_->AddHostPatternToBypass("172.16.0.0/12"); |
315 configurator_->AddHostPatternToBypass("192.168.0.0/16"); | 309 configurator_->AddHostPatternToBypass("192.168.0.0/16"); |
316 // RFC4193 private addresses. | 310 // RFC4193 private addresses. |
317 configurator_->AddHostPatternToBypass("fc00::/7"); | 311 configurator_->AddHostPatternToBypass("fc00::/7"); |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
360 | 354 |
361 void DataReductionProxySettings::OnProxyAlternativeEnabledPrefChange() { | 355 void DataReductionProxySettings::OnProxyAlternativeEnabledPrefChange() { |
362 DCHECK(thread_checker_.CalledOnValidThread()); | 356 DCHECK(thread_checker_.CalledOnValidThread()); |
363 if (!params_->alternative_allowed()) | 357 if (!params_->alternative_allowed()) |
364 return; | 358 return; |
365 MaybeActivateDataReductionProxy(false); | 359 MaybeActivateDataReductionProxy(false); |
366 } | 360 } |
367 | 361 |
368 void DataReductionProxySettings::ResetDataReductionStatistics() { | 362 void DataReductionProxySettings::ResetDataReductionStatistics() { |
369 DCHECK(thread_checker_.CalledOnValidThread()); | 363 DCHECK(thread_checker_.CalledOnValidThread()); |
370 PrefService* prefs = GetLocalStatePrefs(); | 364 DCHECK(statistics_prefs_); |
371 if (!prefs) | 365 base::ListValue* original_update = |
372 return; | 366 statistics_prefs_->GetList(prefs::kDailyHttpOriginalContentLength); |
373 ListPrefUpdate original_update(prefs, prefs::kDailyHttpOriginalContentLength); | 367 base::ListValue* received_update = |
374 ListPrefUpdate received_update(prefs, prefs::kDailyHttpReceivedContentLength); | 368 statistics_prefs_->GetList(prefs::kDailyHttpReceivedContentLength); |
375 original_update->Clear(); | 369 original_update->Clear(); |
376 received_update->Clear(); | 370 received_update->Clear(); |
377 for (size_t i = 0; i < kNumDaysInHistory; ++i) { | 371 for (size_t i = 0; i < kNumDaysInHistory; ++i) { |
378 original_update->AppendString(base::Int64ToString(0)); | 372 original_update->AppendString(base::Int64ToString(0)); |
379 received_update->AppendString(base::Int64ToString(0)); | 373 received_update->AppendString(base::Int64ToString(0)); |
380 } | 374 } |
381 } | 375 } |
382 | 376 |
383 void DataReductionProxySettings::MaybeActivateDataReductionProxy( | 377 void DataReductionProxySettings::MaybeActivateDataReductionProxy( |
384 bool at_startup) { | 378 bool at_startup) { |
(...skipping 83 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
468 | 462 |
469 void DataReductionProxySettings::ResetParamsForTest( | 463 void DataReductionProxySettings::ResetParamsForTest( |
470 DataReductionProxyParams* params) { | 464 DataReductionProxyParams* params) { |
471 params_.reset(params); | 465 params_.reset(params); |
472 } | 466 } |
473 | 467 |
474 DataReductionProxySettings::ContentLengthList | 468 DataReductionProxySettings::ContentLengthList |
475 DataReductionProxySettings::GetDailyContentLengths(const char* pref_name) { | 469 DataReductionProxySettings::GetDailyContentLengths(const char* pref_name) { |
476 DCHECK(thread_checker_.CalledOnValidThread()); | 470 DCHECK(thread_checker_.CalledOnValidThread()); |
477 DataReductionProxySettings::ContentLengthList content_lengths; | 471 DataReductionProxySettings::ContentLengthList content_lengths; |
478 const base::ListValue* list_value = GetLocalStatePrefs()->GetList(pref_name); | 472 DCHECK(statistics_prefs_); |
| 473 const base::ListValue* list_value = statistics_prefs_->GetList(pref_name); |
479 if (list_value->GetSize() == kNumDaysInHistory) { | 474 if (list_value->GetSize() == kNumDaysInHistory) { |
480 for (size_t i = 0; i < kNumDaysInHistory; ++i) { | 475 for (size_t i = 0; i < kNumDaysInHistory; ++i) { |
481 content_lengths.push_back(GetInt64PrefValue(*list_value, i)); | 476 content_lengths.push_back(GetInt64PrefValue(*list_value, i)); |
482 } | 477 } |
483 } | 478 } |
484 return content_lengths; | 479 return content_lengths; |
485 } | 480 } |
486 | 481 |
487 void DataReductionProxySettings::GetContentLengths( | 482 void DataReductionProxySettings::GetContentLengths( |
488 unsigned int days, | 483 unsigned int days, |
489 int64* original_content_length, | 484 int64* original_content_length, |
490 int64* received_content_length, | 485 int64* received_content_length, |
491 int64* last_update_time) { | 486 int64* last_update_time) { |
492 DCHECK(thread_checker_.CalledOnValidThread()); | 487 DCHECK(thread_checker_.CalledOnValidThread()); |
493 DCHECK_LE(days, kNumDaysInHistory); | 488 DCHECK_LE(days, kNumDaysInHistory); |
494 PrefService* local_state = GetLocalStatePrefs(); | 489 DCHECK(statistics_prefs_); |
495 if (!local_state) { | |
496 *original_content_length = 0L; | |
497 *received_content_length = 0L; | |
498 *last_update_time = 0L; | |
499 return; | |
500 } | |
501 | 490 |
502 const base::ListValue* original_list = | 491 const base::ListValue* original_list = |
503 local_state->GetList(prefs::kDailyHttpOriginalContentLength); | 492 statistics_prefs_->GetList(prefs::kDailyHttpOriginalContentLength); |
504 const base::ListValue* received_list = | 493 const base::ListValue* received_list = |
505 local_state->GetList(prefs::kDailyHttpReceivedContentLength); | 494 statistics_prefs_->GetList(prefs::kDailyHttpReceivedContentLength); |
506 | 495 |
507 if (original_list->GetSize() != kNumDaysInHistory || | 496 if (original_list->GetSize() != kNumDaysInHistory || |
508 received_list->GetSize() != kNumDaysInHistory) { | 497 received_list->GetSize() != kNumDaysInHistory) { |
509 *original_content_length = 0L; | 498 *original_content_length = 0L; |
510 *received_content_length = 0L; | 499 *received_content_length = 0L; |
511 *last_update_time = 0L; | 500 *last_update_time = 0L; |
512 return; | 501 return; |
513 } | 502 } |
514 | 503 |
515 int64 orig = 0L; | 504 int64 orig = 0L; |
516 int64 recv = 0L; | 505 int64 recv = 0L; |
517 // Include days from the end of the list going backwards. | 506 // Include days from the end of the list going backwards. |
518 for (size_t i = kNumDaysInHistory - days; | 507 for (size_t i = kNumDaysInHistory - days; |
519 i < kNumDaysInHistory; ++i) { | 508 i < kNumDaysInHistory; ++i) { |
520 orig += GetInt64PrefValue(*original_list, i); | 509 orig += GetInt64PrefValue(*original_list, i); |
521 recv += GetInt64PrefValue(*received_list, i); | 510 recv += GetInt64PrefValue(*received_list, i); |
522 } | 511 } |
523 *original_content_length = orig; | 512 *original_content_length = orig; |
524 *received_content_length = recv; | 513 *received_content_length = recv; |
525 *last_update_time = | 514 *last_update_time = |
526 local_state->GetInt64(prefs::kDailyHttpContentLengthLastUpdateDate); | 515 statistics_prefs_->GetInt64(prefs::kDailyHttpContentLengthLastUpdateDate); |
527 } | 516 } |
528 | 517 |
529 net::URLFetcher* DataReductionProxySettings::GetBaseURLFetcher( | 518 net::URLFetcher* DataReductionProxySettings::GetBaseURLFetcher( |
530 const GURL& gurl, | 519 const GURL& gurl, |
531 int load_flags) { | 520 int load_flags) { |
532 | 521 |
533 net::URLFetcher* fetcher = net::URLFetcher::Create(gurl, | 522 net::URLFetcher* fetcher = net::URLFetcher::Create(gurl, |
534 net::URLFetcher::GET, | 523 net::URLFetcher::GET, |
535 this); | 524 this); |
536 fetcher->SetLoadFlags(load_flags); | 525 fetcher->SetLoadFlags(load_flags); |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
585 SetProxyConfigs(enabled_by_user_, | 574 SetProxyConfigs(enabled_by_user_, |
586 IsDataReductionProxyAlternativeEnabled(), | 575 IsDataReductionProxyAlternativeEnabled(), |
587 restricted_by_carrier_, | 576 restricted_by_carrier_, |
588 false); | 577 false); |
589 } | 578 } |
590 disabled_on_vpn_ = false; | 579 disabled_on_vpn_ = false; |
591 return false; | 580 return false; |
592 } | 581 } |
593 | 582 |
594 } // namespace data_reduction_proxy | 583 } // namespace data_reduction_proxy |
OLD | NEW |