Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(435)

Side by Side Diff: chrome/browser/net/spdyproxy/data_reduction_proxy_settings_android.cc

Issue 286013002: Added alternative configuration for the data reduction proxy (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: DCHECK fix Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/net/spdyproxy/data_reduction_proxy_settings_android.h" 5 #include "chrome/browser/net/spdyproxy/data_reduction_proxy_settings_android.h"
6 6
7 #include "base/android/build_info.h" 7 #include "base/android/build_info.h"
8 #include "base/android/jni_android.h" 8 #include "base/android/jni_android.h"
9 #include "base/android/jni_string.h" 9 #include "base/android/jni_string.h"
10 #include "base/bind.h" 10 #include "base/bind.h"
11 #include "base/command_line.h" 11 #include "base/command_line.h"
12 #include "base/memory/scoped_ptr.h" 12 #include "base/memory/scoped_ptr.h"
13 #include "base/metrics/field_trial.h" 13 #include "base/metrics/field_trial.h"
14 #include "base/metrics/histogram.h" 14 #include "base/metrics/histogram.h"
15 #include "base/prefs/pref_member.h" 15 #include "base/prefs/pref_member.h"
16 #include "base/prefs/pref_service.h" 16 #include "base/prefs/pref_service.h"
17 #include "base/strings/string_number_conversions.h" 17 #include "base/strings/string_number_conversions.h"
18 #include "base/strings/utf_string_conversions.h" 18 #include "base/strings/utf_string_conversions.h"
19 #include "chrome/browser/browser_process.h" 19 #include "chrome/browser/browser_process.h"
20 #include "chrome/browser/net/spdyproxy/data_reduction_proxy_chrome_configurator. h" 20 #include "chrome/browser/net/spdyproxy/data_reduction_proxy_chrome_configurator. h"
21 #include "chrome/browser/net/spdyproxy/data_reduction_proxy_settings_factory_and roid.h"
21 #include "chrome/browser/prefs/proxy_prefs.h" 22 #include "chrome/browser/prefs/proxy_prefs.h"
22 #include "chrome/browser/profiles/profile.h" 23 #include "chrome/browser/profiles/profile.h"
23 #include "chrome/browser/profiles/profile_manager.h" 24 #include "chrome/browser/profiles/profile_manager.h"
24 #include "chrome/common/chrome_switches.h" 25 #include "chrome/common/chrome_switches.h"
25 #include "chrome/common/pref_names.h" 26 #include "chrome/common/pref_names.h"
26 #include "components/data_reduction_proxy/browser/data_reduction_proxy_configura tor.h" 27 #include "components/data_reduction_proxy/browser/data_reduction_proxy_configura tor.h"
28 #include "components/data_reduction_proxy/browser/data_reduction_proxy_params.h"
27 #include "components/data_reduction_proxy/browser/data_reduction_proxy_settings. h" 29 #include "components/data_reduction_proxy/browser/data_reduction_proxy_settings. h"
28 #include "jni/DataReductionProxySettings_jni.h" 30 #include "jni/DataReductionProxySettings_jni.h"
29 #include "net/base/auth.h" 31 #include "net/base/auth.h"
30 #include "net/base/host_port_pair.h" 32 #include "net/base/host_port_pair.h"
31 #include "net/base/load_flags.h" 33 #include "net/base/load_flags.h"
32 #include "net/base/net_errors.h" 34 #include "net/base/net_errors.h"
33 #include "net/url_request/url_fetcher.h" 35 #include "net/url_request/url_fetcher.h"
34 #include "net/url_request/url_fetcher_delegate.h" 36 #include "net/url_request/url_fetcher_delegate.h"
35 #include "net/url_request/url_request_status.h" 37 #include "net/url_request/url_request_status.h"
36 38
37 using base::android::CheckException; 39 using base::android::CheckException;
38 using base::android::ConvertJavaStringToUTF8; 40 using base::android::ConvertJavaStringToUTF8;
39 using base::android::ConvertUTF16ToJavaString; 41 using base::android::ConvertUTF16ToJavaString;
40 using base::android::ConvertUTF8ToJavaString; 42 using base::android::ConvertUTF8ToJavaString;
41 using base::android::ScopedJavaLocalRef; 43 using base::android::ScopedJavaLocalRef;
44 using data_reduction_proxy::DataReductionProxyParams;
42 using data_reduction_proxy::DataReductionProxySettings; 45 using data_reduction_proxy::DataReductionProxySettings;
43 46
44 namespace { 47 namespace {
45 48
46 // The C++ definition of enum SpdyProxyAuthState defined in 49 // The C++ definition of enum SpdyProxyAuthState defined in
47 // tools/histograms/histograms.xml. 50 // tools/histograms/histograms.xml.
48 // New values should be added at the end before |NUM_SPDY_PROXY_AUTH_STATE|. 51 // New values should be added at the end before |NUM_SPDY_PROXY_AUTH_STATE|.
49 enum { 52 enum {
50 CHROME_STARTUP, 53 CHROME_STARTUP,
51 SPDY_PROXY_AUTH_ON_AT_STARTUP, 54 SPDY_PROXY_AUTH_ON_AT_STARTUP,
52 SPDY_PROXY_AUTH_ON_BY_USER, 55 SPDY_PROXY_AUTH_ON_BY_USER,
53 SPDY_PROXY_AUTH_OFF_BY_USER, 56 SPDY_PROXY_AUTH_OFF_BY_USER,
54 // Used by UMA histograms and should always be the last value. 57 // Used by UMA histograms and should always be the last value.
55 NUM_SPDY_PROXY_AUTH_STATE 58 NUM_SPDY_PROXY_AUTH_STATE
56 }; 59 };
57 60
58 const char kEnabled[] = "Enabled";
59
60 } // namespace 61 } // namespace
61 62
62 DataReductionProxySettingsAndroid::DataReductionProxySettingsAndroid( 63 DataReductionProxySettingsAndroid::DataReductionProxySettingsAndroid(
63 JNIEnv* env, jobject obj) : DataReductionProxySettings() { 64 data_reduction_proxy::DataReductionProxyParams* params)
64 #if defined(SPDY_PROXY_AUTH_VALUE) 65 : DataReductionProxySettings(params) {
65 set_key(SPDY_PROXY_AUTH_VALUE);
66 #endif
67 SetAllowed(IsIncludedInFieldTrialOrFlags());
68 SetPromoAllowed(base::FieldTrialList::FindFullName(
69 "DataCompressionProxyPromoVisibility") == kEnabled);
70 }
71
72 DataReductionProxySettingsAndroid::DataReductionProxySettingsAndroid() {
73 #if defined(SPDY_PROXY_AUTH_VALUE)
74 set_key(SPDY_PROXY_AUTH_VALUE);
75 #endif
76 } 66 }
77 67
78 DataReductionProxySettingsAndroid::~DataReductionProxySettingsAndroid() { 68 DataReductionProxySettingsAndroid::~DataReductionProxySettingsAndroid() {
79 } 69 }
80 70
81 void DataReductionProxySettingsAndroid::InitDataReductionProxySettings( 71 void DataReductionProxySettingsAndroid::InitDataReductionProxySettings(
82 JNIEnv* env, 72 Profile* profile) {
83 jobject obj) { 73 DCHECK(profile);
84 PrefService* prefs = ProfileManager::GetActiveUserProfile()->GetPrefs(); 74 PrefService* prefs = profile->GetPrefs();
85 75
86 scoped_ptr<data_reduction_proxy::DataReductionProxyConfigurator> 76 scoped_ptr<data_reduction_proxy::DataReductionProxyConfigurator>
87 configurator(new DataReductionProxyChromeConfigurator(prefs)); 77 configurator(new DataReductionProxyChromeConfigurator(prefs));
88 SetProxyConfigurator(configurator.Pass()); 78 SetProxyConfigurator(configurator.Pass());
89 DataReductionProxySettings::InitDataReductionProxySettings( 79 DataReductionProxySettings::InitDataReductionProxySettings(
90 prefs, 80 prefs,
91 g_browser_process->local_state(), 81 g_browser_process->local_state(),
92 ProfileManager::GetActiveUserProfile()->GetRequestContext()); 82 ProfileManager::GetActiveUserProfile()->GetRequestContext());
83 DataReductionProxySettings::SetDataReductionProxyAlternativeEnabled(
84 DataReductionProxyParams::IsIncludedInAlternativeFieldTrial());
93 } 85 }
94 86
95 void DataReductionProxySettingsAndroid::BypassHostPattern( 87 void DataReductionProxySettingsAndroid::BypassHostPattern(
96 JNIEnv* env, jobject obj, jstring pattern) { 88 JNIEnv* env, jobject obj, jstring pattern) {
97 config()->AddHostPatternToBypass( 89 configurator()->AddHostPatternToBypass(
98 ConvertJavaStringToUTF8(env, pattern)); 90 ConvertJavaStringToUTF8(env, pattern));
99 } 91 }
100 void DataReductionProxySettingsAndroid::BypassURLPattern( 92 void DataReductionProxySettingsAndroid::BypassURLPattern(
101 JNIEnv* env, jobject obj, jstring pattern) { 93 JNIEnv* env, jobject obj, jstring pattern) {
102 config()->AddURLPatternToBypass(ConvertJavaStringToUTF8(env, pattern)); 94 configurator()->AddURLPatternToBypass(ConvertJavaStringToUTF8(env, pattern));
103 } 95 }
104 96
105 jboolean DataReductionProxySettingsAndroid::IsDataReductionProxyAllowed( 97 jboolean DataReductionProxySettingsAndroid::IsDataReductionProxyAllowed(
106 JNIEnv* env, jobject obj) { 98 JNIEnv* env, jobject obj) {
107 return DataReductionProxySettings::IsDataReductionProxyAllowed(); 99 return params()->allowed();
108 } 100 }
109 101
110 jboolean DataReductionProxySettingsAndroid::IsDataReductionProxyPromoAllowed( 102 jboolean DataReductionProxySettingsAndroid::IsDataReductionProxyPromoAllowed(
111 JNIEnv* env, jobject obj) { 103 JNIEnv* env, jobject obj) {
112 return DataReductionProxySettings::IsDataReductionProxyPromoAllowed(); 104 return params()->promo_allowed();
113 } 105 }
114 106
115 ScopedJavaLocalRef<jstring> 107 ScopedJavaLocalRef<jstring>
116 DataReductionProxySettingsAndroid::GetDataReductionProxyOrigin( 108 DataReductionProxySettingsAndroid::GetDataReductionProxyOrigin(
117 JNIEnv* env, jobject obj) { 109 JNIEnv* env, jobject obj) {
118 return ConvertUTF8ToJavaString( 110 return ConvertUTF8ToJavaString(env, params()->origin().spec());
119 env, DataReductionProxySettings::GetDataReductionProxyOrigin());
120 } 111 }
121 112
122 jboolean DataReductionProxySettingsAndroid::IsDataReductionProxyEnabled( 113 jboolean DataReductionProxySettingsAndroid::IsDataReductionProxyEnabled(
123 JNIEnv* env, jobject obj) { 114 JNIEnv* env, jobject obj) {
124 return DataReductionProxySettings::IsDataReductionProxyEnabled(); 115 return DataReductionProxySettings::IsDataReductionProxyEnabled();
125 } 116 }
126 117
127 jboolean DataReductionProxySettingsAndroid::IsDataReductionProxyManaged( 118 jboolean DataReductionProxySettingsAndroid::IsDataReductionProxyManaged(
128 JNIEnv* env, jobject obj) { 119 JNIEnv* env, jobject obj) {
129 return DataReductionProxySettings::IsDataReductionProxyManaged(); 120 return DataReductionProxySettings::IsDataReductionProxyManaged();
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after
203 // static 194 // static
204 bool DataReductionProxySettingsAndroid::Register(JNIEnv* env) { 195 bool DataReductionProxySettingsAndroid::Register(JNIEnv* env) {
205 bool register_natives_impl_result = RegisterNativesImpl(env); 196 bool register_natives_impl_result = RegisterNativesImpl(env);
206 return register_natives_impl_result; 197 return register_natives_impl_result;
207 } 198 }
208 199
209 void DataReductionProxySettingsAndroid::AddDefaultProxyBypassRules() { 200 void DataReductionProxySettingsAndroid::AddDefaultProxyBypassRules() {
210 DataReductionProxySettings::AddDefaultProxyBypassRules(); 201 DataReductionProxySettings::AddDefaultProxyBypassRules();
211 // Chrome cannot authenticate with the data reduction proxy when fetching URLs 202 // Chrome cannot authenticate with the data reduction proxy when fetching URLs
212 // from the settings menu. 203 // from the settings menu.
213 config()->AddURLPatternToBypass("http://www.google.com/policies/privacy*"); 204 configurator()->AddURLPatternToBypass(
205 "http://www.google.com/policies/privacy*");
214 } 206 }
215 207
216 void DataReductionProxySettingsAndroid::SetProxyConfigs(bool enabled, 208 void DataReductionProxySettingsAndroid::SetProxyConfigs(
217 bool restricted, 209 bool enabled,
218 bool at_startup) { 210 bool alternative_enabled,
211 bool restricted,
212 bool at_startup) {
219 // Sanity check: If there's no fallback proxy, we can't do a restricted mode. 213 // Sanity check: If there's no fallback proxy, we can't do a restricted mode.
220 std::string fallback = GetDataReductionProxyFallback(); 214 std::string fallback = params()->fallback_origin().spec();
221 if (fallback.empty() && enabled && restricted) 215 if (fallback.empty() && enabled && restricted)
222 enabled = false; 216 enabled = false;
223 217
224 LogProxyState(enabled, restricted, at_startup); 218 LogProxyState(enabled, restricted, at_startup);
225 219
226 if (enabled) { 220 if (enabled) {
227 config()->Enable(restricted, 221 if (alternative_enabled) {
228 !fallback_allowed(), 222 configurator()->Enable(restricted,
229 DataReductionProxySettings::GetDataReductionProxyOrigin(), 223 !params()->fallback_allowed(),
230 GetDataReductionProxyFallback()); 224 params()->alt_origin().spec(),
225 params()->alt_fallback_origin().spec(),
226 params()->ssl_origin().spec());
227 } else {
228 configurator()->Enable(restricted,
229 !params()->fallback_allowed(),
230 params()->origin().spec(),
231 params()->fallback_origin().spec(),
232 std::string());
233 }
231 } else { 234 } else {
232 config()->Disable(); 235 configurator()->Disable();
233 } 236 }
234 } 237 }
235 238
236 ScopedJavaLocalRef<jlongArray> 239 ScopedJavaLocalRef<jlongArray>
237 DataReductionProxySettingsAndroid::GetDailyContentLengths( 240 DataReductionProxySettingsAndroid::GetDailyContentLengths(
238 JNIEnv* env, const char* pref_name) { 241 JNIEnv* env, const char* pref_name) {
239 jlongArray result = env->NewLongArray( 242 jlongArray result = env->NewLongArray(
240 data_reduction_proxy::kNumDaysInHistory); 243 data_reduction_proxy::kNumDaysInHistory);
241 244
242 DataReductionProxySettings::ContentLengthList lengths = 245 DataReductionProxySettings::ContentLengthList lengths =
243 DataReductionProxySettings::GetDailyContentLengths(pref_name); 246 DataReductionProxySettings::GetDailyContentLengths(pref_name);
244 247
245 if (!lengths.empty()) { 248 if (!lengths.empty()) {
246 DCHECK_EQ(lengths.size(), data_reduction_proxy::kNumDaysInHistory); 249 DCHECK_EQ(lengths.size(), data_reduction_proxy::kNumDaysInHistory);
247 env->SetLongArrayRegion(result, 0, lengths.size(), &lengths[0]); 250 env->SetLongArrayRegion(result, 0, lengths.size(), &lengths[0]);
248 return ScopedJavaLocalRef<jlongArray>(env, result); 251 return ScopedJavaLocalRef<jlongArray>(env, result);
249 } 252 }
250 253
251 return ScopedJavaLocalRef<jlongArray>(env, result); 254 return ScopedJavaLocalRef<jlongArray>(env, result);
252 } 255 }
253 256
254 257
255 258
256 // Used by generated jni code. 259 // Used by generated jni code.
257 static jlong Init(JNIEnv* env, jobject obj) { 260 static jlong Init(JNIEnv* env, jobject obj) {
258 DataReductionProxySettingsAndroid* settings = 261 DataReductionProxySettingsAndroid* settings =
259 new DataReductionProxySettingsAndroid(env, obj); 262 DataReductionProxySettingsFactoryAndroid::GetForBrowserContext(
263 ProfileManager::GetActiveUserProfile());
260 return reinterpret_cast<intptr_t>(settings); 264 return reinterpret_cast<intptr_t>(settings);
261 } 265 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698