Chromium Code Reviews| Index: components/data_reduction_proxy/core/browser/data_reduction_proxy_io_data.cc |
| diff --git a/components/data_reduction_proxy/core/browser/data_reduction_proxy_io_data.cc b/components/data_reduction_proxy/core/browser/data_reduction_proxy_io_data.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..37bffcc4174933982e4474b39314650604135ee6 |
| --- /dev/null |
| +++ b/components/data_reduction_proxy/core/browser/data_reduction_proxy_io_data.cc |
| @@ -0,0 +1,115 @@ |
| +// Copyright 2014 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| + |
| +#include "components/data_reduction_proxy/core/browser/data_reduction_proxy_io_data.h" |
| + |
| +#include "base/bind.h" |
| +#include "base/command_line.h" |
| +#include "base/prefs/pref_member.h" |
| +#include "base/single_thread_task_runner.h" |
| +#include "components/data_reduction_proxy/core/browser/data_reduction_proxy_auth_request_handler.h" |
| +#include "components/data_reduction_proxy/core/browser/data_reduction_proxy_delegate.h" |
| +#include "components/data_reduction_proxy/core/browser/data_reduction_proxy_interceptor.h" |
| +#include "components/data_reduction_proxy/core/browser/data_reduction_proxy_network_delegate.h" |
| +#include "components/data_reduction_proxy/core/browser/data_reduction_proxy_protocol.h" |
| +#include "components/data_reduction_proxy/core/browser/data_reduction_proxy_usage_stats.h" |
| +#include "components/data_reduction_proxy/core/common/data_reduction_proxy_params.h" |
| +#include "components/data_reduction_proxy/core/common/data_reduction_proxy_switches.h" |
| + |
| +namespace data_reduction_proxy { |
| +DataReductionProxyIOData::DataReductionProxyIOData( |
| + const Client& client, |
| + scoped_ptr<DataReductionProxyParams> params, |
| + scoped_ptr<DataReductionProxyConfigurator> configurator, |
| + scoped_ptr<DataReductionProxyStatisticsPrefs> statistics_prefs, |
| + scoped_ptr<DataReductionProxyEventStore> event_store, |
| + const DataReductionProxyNetworkDelegate::ProxyConfigGetter& |
| + proxy_config_getter, |
| + const base::Callback<void(bool)>& unavailable_callback, |
| + scoped_refptr<base::SingleThreadTaskRunner> io_task_runner, |
| + scoped_refptr<base::SingleThreadTaskRunner> ui_task_runner) |
| + : client_(client), |
| + params_(params.Pass()), |
| + configurator_(configurator.Pass()), |
| + statistics_prefs_(statistics_prefs.Pass()), |
| + event_store_(event_store.Pass()), |
| + proxy_config_getter_(proxy_config_getter), |
| + unavailable_callback_(unavailable_callback), |
| + io_task_runner_(io_task_runner), |
| + ui_task_runner_(ui_task_runner) { |
| +} |
| + |
| + |
| +DataReductionProxyIOData::~DataReductionProxyIOData() { |
| +} |
| + |
| +void DataReductionProxyIOData::InitPrefsOnUIThread( |
| + PrefService* pref_service, |
| + scoped_refptr<base::SingleThreadTaskRunner> io_task_runner) { |
| + enabled_.Init(prefs::kDataReductionProxyEnabled, pref_service); |
| + enabled_.MoveToThread(io_task_runner); |
| +} |
| + |
| +void DataReductionProxyIOData::DestroyPrefsOnUIThread() { |
| + if (statistics_prefs_.get()) |
| + statistics_prefs_->WritePrefs(); |
| + enabled_.Destroy(); |
| +} |
| + |
| +void DataReductionProxyIOData::ShutdownStatisicsPrefsOnUIThread() { |
| + if (statistics_prefs_.get()) |
| + statistics_prefs_->ShutdownOnUIThread(); |
| +} |
| + |
| +bool DataReductionProxyIOData::IsEnabled() const { |
| + return enabled_.GetValue() || CommandLine::ForCurrentProcess()->HasSwitch( |
| + switches::kEnableDataReductionProxy); |
| +} |
| + |
| +net::URLRequestInterceptor* DataReductionProxyIOData::CreateInterceptor() { |
| + return new DataReductionProxyInterceptor(params_.get(), usage_stats_.get(), |
| + event_store_.get()); |
| +} |
| + |
| +void DataReductionProxyIOData::CreateStatisticsPrefs( |
|
mmenke
2014/12/17 21:37:22
I'd suggest calling this EnableStatisticsLogging.
bengr
2014/12/19 20:05:58
Done.
|
| + PrefService* prefs, |
| + const base::TimeDelta& commit_delay) { |
| + DCHECK(ui_task_runner_.get()); |
| + statistics_prefs_.reset( |
| + new DataReductionProxyStatisticsPrefs( |
| + prefs, ui_task_runner_, commit_delay)); |
| +} |
| + |
| +void DataReductionProxyIOData::Init( |
| + scoped_ptr<net::NetworkDelegate> wrapped_network_delegate, |
| + bool allow_proxy_config_overrides, |
| + bool capture_statistics, |
| + bool create_proxy_delegate) { |
| + auth_request_handler_.reset(new DataReductionProxyAuthRequestHandler( |
| + client_, params_.get(), io_task_runner_)); |
| + usage_stats_.reset(new data_reduction_proxy::DataReductionProxyUsageStats( |
| + params_.get(), ui_task_runner_)); |
| + usage_stats_->set_unavailable_callback(unavailable_callback_); |
| + network_delegate_.reset( |
| + new DataReductionProxyNetworkDelegate( |
| + wrapped_network_delegate.Pass(), params_.get(), |
| + auth_request_handler_.get(), proxy_config_getter_)); |
| + if (allow_proxy_config_overrides) { |
| + network_delegate_->InitProxyConfigOverrider( |
| + base::Bind(data_reduction_proxy::OnResolveProxyHandler)); |
| + } |
| + if (capture_statistics) { |
|
mmenke
2014/12/17 21:37:22
Can we just automatically do this if we have a sta
bengr
2014/12/19 20:05:58
No. This is for UMA, the other is for metrics that
|
| + network_delegate_->InitStatisticsPrefsAndUMA( |
| + ui_task_runner_, statistics_prefs_.get(), &enabled_, |
| + usage_stats_.get()); |
| + } |
| + if (create_proxy_delegate) { |
| + proxy_delegate_.reset( |
| + new data_reduction_proxy::DataReductionProxyDelegate( |
| + auth_request_handler_.get(), params_.get())); |
| + } |
| +} |
| + |
| +} // namespace data_reduction_proxy |