OLD | NEW |
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/bookmarks/enhanced_bookmarks_features.h" | 5 #include "chrome/browser/bookmarks/enhanced_bookmarks_features.h" |
6 | 6 |
7 #include "base/command_line.h" | 7 #include "base/command_line.h" |
| 8 #include "base/metrics/histogram.h" |
8 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
9 #include "base/prefs/scoped_user_pref_update.h" | 10 #include "base/prefs/scoped_user_pref_update.h" |
10 #include "base/sha1.h" | 11 #include "base/sha1.h" |
11 #include "base/strings/string_number_conversions.h" | 12 #include "base/strings/string_number_conversions.h" |
12 #include "chrome/common/chrome_switches.h" | 13 #include "chrome/common/chrome_switches.h" |
13 #include "chrome/common/pref_names.h" | 14 #include "chrome/common/pref_names.h" |
| 15 #include "components/sync_driver/pref_names.h" |
14 #include "components/variations/variations_associated_data.h" | 16 #include "components/variations/variations_associated_data.h" |
15 #include "extensions/common/features/feature.h" | 17 #include "extensions/common/features/feature.h" |
16 #include "extensions/common/features/feature_provider.h" | 18 #include "extensions/common/features/feature_provider.h" |
17 | 19 |
18 namespace { | 20 namespace { |
19 | 21 |
20 const char kFieldTrialName[] = "EnhancedBookmarks"; | 22 const char kFieldTrialName[] = "EnhancedBookmarks"; |
21 | 23 |
| 24 // Get extension id from Finch EnhancedBookmarks group parameters. |
| 25 std::string GetEnhancedBookmarksExtensionIdFromFinch() { |
| 26 return chrome_variations::GetVariationParamValue(kFieldTrialName, "id"); |
| 27 } |
| 28 |
| 29 // Returns true if enhanced bookmarks experiment is enabled from Finch. |
| 30 bool IsEnhancedBookmarksExperimentEnabledFromFinch() { |
| 31 std::string ext_id = GetEnhancedBookmarksExtensionIdFromFinch(); |
| 32 extensions::FeatureProvider* feature_provider = |
| 33 extensions::FeatureProvider::GetPermissionFeatures(); |
| 34 extensions::Feature* feature = feature_provider->GetFeature("metricsPrivate"); |
| 35 return feature && feature->IsIdInWhitelist(ext_id); |
| 36 } |
| 37 |
22 }; // namespace | 38 }; // namespace |
23 | 39 |
24 void UpdateBookmarksExperiment( | 40 bool GetBookmarksExperimentExtensionID(const PrefService* user_prefs, |
| 41 std::string* extension_id) { |
| 42 BookmarksExperimentState bookmarks_experiment_state = |
| 43 static_cast<BookmarksExperimentState>(user_prefs->GetInteger( |
| 44 sync_driver::prefs::kEnhancedBookmarksExperimentEnabled)); |
| 45 if (bookmarks_experiment_state == kBookmarksExperimentEnabledFromFinch) { |
| 46 *extension_id = GetEnhancedBookmarksExtensionIdFromFinch(); |
| 47 return !extension_id->empty(); |
| 48 } |
| 49 if (bookmarks_experiment_state == kBookmarksExperimentEnabled) { |
| 50 *extension_id = user_prefs->GetString( |
| 51 sync_driver::prefs::kEnhancedBookmarksExtensionId); |
| 52 return !extension_id->empty(); |
| 53 } |
| 54 |
| 55 return false; |
| 56 } |
| 57 |
| 58 void UpdateBookmarksExperimentState(const PrefService* user_prefs, |
| 59 PrefService* local_state, |
| 60 bool user_signed_in) { |
| 61 BookmarksExperimentState bookmarks_experiment_state_before = |
| 62 static_cast<BookmarksExperimentState>(user_prefs->GetInteger( |
| 63 sync_driver::prefs::kEnhancedBookmarksExperimentEnabled)); |
| 64 // If user signed out, clear possible previous state. |
| 65 if (!user_signed_in) { |
| 66 bookmarks_experiment_state_before = kNoBookmarksExperiment; |
| 67 ForceFinchBoomarkExperimentIfNeeded(local_state, kNoBookmarksExperiment); |
| 68 } |
| 69 |
| 70 // kEnhancedBookmarksExperiment flag could have values "", "1" and "0". |
| 71 // "0" - user opted out. |
| 72 bool opt_out = CommandLine::ForCurrentProcess()->GetSwitchValueASCII( |
| 73 switches::kEnhancedBookmarksExperiment) == "0"; |
| 74 |
| 75 BookmarksExperimentState bookmarks_experiment_new_state = |
| 76 kNoBookmarksExperiment; |
| 77 bool enabled_from_finch = false; |
| 78 if (IsEnhancedBookmarksExperimentEnabledFromFinch()) { |
| 79 enabled_from_finch = !user_signed_in; |
| 80 if (user_signed_in) { |
| 81 bookmarks_experiment_new_state = |
| 82 kBookmarksExperimentEnabledFromFinchUserSignedIn; |
| 83 } |
| 84 } |
| 85 |
| 86 if (enabled_from_finch) { |
| 87 if (opt_out) { |
| 88 // Experiment enabled but user opted out. |
| 89 bookmarks_experiment_new_state = kBookmarksExperimentOptOutFromFinch; |
| 90 } else { |
| 91 // Experiment enabled. |
| 92 bookmarks_experiment_new_state = kBookmarksExperimentEnabledFromFinch; |
| 93 } |
| 94 } else if (bookmarks_experiment_state_before == kBookmarksExperimentEnabled) { |
| 95 if (opt_out) { |
| 96 // Experiment enabled but user opted out. |
| 97 bookmarks_experiment_new_state = kBookmarksExperimentEnabledUserOptOut; |
| 98 } else { |
| 99 bookmarks_experiment_new_state = kBookmarksExperimentEnabled; |
| 100 } |
| 101 } else if (bookmarks_experiment_state_before == |
| 102 kBookmarksExperimentEnabledUserOptOut) { |
| 103 if (opt_out) { |
| 104 bookmarks_experiment_new_state = kBookmarksExperimentEnabledUserOptOut; |
| 105 } else { |
| 106 // User opted in again. |
| 107 bookmarks_experiment_new_state = kBookmarksExperimentEnabled; |
| 108 } |
| 109 } |
| 110 |
| 111 UMA_HISTOGRAM_ENUMERATION("EnhancedBookmarks.SyncExperimentState", |
| 112 bookmarks_experiment_new_state, |
| 113 kBookmarksExperimentEnumSize); |
| 114 if (bookmarks_experiment_state_before != bookmarks_experiment_new_state) |
| 115 ForceFinchBoomarkExperimentIfNeeded(local_state, |
| 116 bookmarks_experiment_new_state); |
| 117 } |
| 118 |
| 119 void ForceFinchBoomarkExperimentIfNeeded( |
25 PrefService* local_state, | 120 PrefService* local_state, |
26 BookmarksExperimentState bookmarks_experiment_state) { | 121 BookmarksExperimentState bookmarks_experiment_state) { |
27 ListPrefUpdate update(local_state, prefs::kEnabledLabsExperiments); | 122 ListPrefUpdate update(local_state, prefs::kEnabledLabsExperiments); |
28 base::ListValue* experiments_list = update.Get(); | 123 base::ListValue* experiments_list = update.Get(); |
29 size_t index; | 124 size_t index; |
30 if (bookmarks_experiment_state == kNoBookmarksExperiment) { | 125 if (bookmarks_experiment_state == kNoBookmarksExperiment) { |
31 experiments_list->Remove( | 126 experiments_list->Remove( |
32 base::StringValue(switches::kManualEnhancedBookmarks), &index); | 127 base::StringValue(switches::kManualEnhancedBookmarks), &index); |
33 experiments_list->Remove( | 128 experiments_list->Remove( |
34 base::StringValue(switches::kManualEnhancedBookmarksOptout), &index); | 129 base::StringValue(switches::kManualEnhancedBookmarksOptout), &index); |
(...skipping 11 matching lines...) Expand all Loading... |
46 } | 141 } |
47 } | 142 } |
48 | 143 |
49 bool IsEnhancedBookmarksExperimentEnabled() { | 144 bool IsEnhancedBookmarksExperimentEnabled() { |
50 CommandLine* command_line = CommandLine::ForCurrentProcess(); | 145 CommandLine* command_line = CommandLine::ForCurrentProcess(); |
51 if (command_line->HasSwitch(switches::kManualEnhancedBookmarks) || | 146 if (command_line->HasSwitch(switches::kManualEnhancedBookmarks) || |
52 command_line->HasSwitch(switches::kManualEnhancedBookmarksOptout)) { | 147 command_line->HasSwitch(switches::kManualEnhancedBookmarksOptout)) { |
53 return true; | 148 return true; |
54 } | 149 } |
55 | 150 |
56 std::string ext_id = GetEnhancedBookmarksExtensionIdFromFinch(); | 151 return IsEnhancedBookmarksExperimentEnabledFromFinch(); |
57 extensions::FeatureProvider* feature_provider = | |
58 extensions::FeatureProvider::GetPermissionFeatures(); | |
59 extensions::Feature* feature = feature_provider->GetFeature("metricsPrivate"); | |
60 return feature && feature->IsIdInWhitelist(ext_id); | |
61 } | 152 } |
62 | 153 |
63 bool IsEnableDomDistillerSet() { | 154 bool IsEnableDomDistillerSet() { |
64 if (CommandLine::ForCurrentProcess()-> | 155 if (CommandLine::ForCurrentProcess()-> |
65 HasSwitch(switches::kEnableDomDistiller)) { | 156 HasSwitch(switches::kEnableDomDistiller)) { |
66 return true; | 157 return true; |
67 } | 158 } |
68 if (chrome_variations::GetVariationParamValue( | 159 if (chrome_variations::GetVariationParamValue( |
69 kFieldTrialName, "enable-dom-distiller") == "1") | 160 kFieldTrialName, "enable-dom-distiller") == "1") |
70 return true; | 161 return true; |
71 | 162 |
72 return false; | 163 return false; |
73 } | 164 } |
74 | 165 |
75 bool IsEnableSyncArticlesSet() { | 166 bool IsEnableSyncArticlesSet() { |
76 if (CommandLine::ForCurrentProcess()-> | 167 if (CommandLine::ForCurrentProcess()-> |
77 HasSwitch(switches::kEnableSyncArticles)) { | 168 HasSwitch(switches::kEnableSyncArticles)) { |
78 return true; | 169 return true; |
79 } | 170 } |
80 if (chrome_variations::GetVariationParamValue( | 171 if (chrome_variations::GetVariationParamValue( |
81 kFieldTrialName, "enable-sync-articles") == "1") | 172 kFieldTrialName, "enable-sync-articles") == "1") |
82 return true; | 173 return true; |
83 | 174 |
84 return false; | 175 return false; |
85 } | 176 } |
86 | |
87 std::string GetEnhancedBookmarksExtensionIdFromFinch() { | |
88 return chrome_variations::GetVariationParamValue(kFieldTrialName, "id"); | |
89 } | |
OLD | NEW |