Chromium Code Reviews| Index: chrome/browser/extensions/external_component_loader.cc |
| diff --git a/chrome/browser/extensions/external_component_loader.cc b/chrome/browser/extensions/external_component_loader.cc |
| index bec5d2f9e99b90529eaa13f90df9723e127d6370..6ccfec488c45f04a59bde31ab7db51f1e8ea2661 100644 |
| --- a/chrome/browser/extensions/external_component_loader.cc |
| +++ b/chrome/browser/extensions/external_component_loader.cc |
| @@ -4,20 +4,53 @@ |
| #include "chrome/browser/extensions/external_component_loader.h" |
| +#include "base/command_line.h" |
| +#include "base/metrics/field_trial.h" |
| #include "base/values.h" |
| +#include "chrome/common/chrome_switches.h" |
| #include "chrome/common/extensions/extension_constants.h" |
| +#include "components/variations/variations_associated_data.h" |
| +#include "extensions/common/features/feature.h" |
| +#include "extensions/common/features/feature_provider.h" |
| namespace extensions { |
| +const char kFieldTrialName[] = "EnhancedBookmarks"; |
| + |
| ExternalComponentLoader::ExternalComponentLoader() {} |
| ExternalComponentLoader::~ExternalComponentLoader() {} |
| +// This function will be removed after experiment goes to all users or go away. |
| +bool ExternalComponentLoader::IsEnhancedBookmarksExperimentEnabled() { |
| + const char kFieldTrialDefaultGroupName[] = "Default"; |
| + std::string field_trial_group_name = |
| + base::FieldTrialList::FindFullName(kFieldTrialName); |
| + if (field_trial_group_name.empty() || |
| + field_trial_group_name == kFieldTrialDefaultGroupName) { |
| + return false; |
| + } |
| + std::string app_id = |
| + chrome_variations::GetVariationParamValue(kFieldTrialName, "id"); |
| + FeatureProvider* feature_provider = FeatureProvider::GetPermissionFeatures(); |
| + Feature* feature = feature_provider->GetFeature("metricsPrivate"); |
| + return (feature && feature->IsIdInWhitelist(app_id)); |
| +} |
| + |
| void ExternalComponentLoader::StartLoading() { |
| prefs_.reset(new base::DictionaryValue()); |
| std::string appId = extension_misc::kInAppPaymentsSupportAppId; |
| prefs_->SetString(appId + ".external_update_url", |
| extension_urls::GetWebstoreUpdateUrl().spec()); |
| + |
| + if (IsEnhancedBookmarksExperimentEnabled() && |
| + (CommandLine::ForCurrentProcess()-> |
| + GetSwitchValueASCII(switches::kEnableEnhancedBookmarks) != "0")) { |
| + std::string app_id = |
| + chrome_variations::GetVariationParamValue(kFieldTrialName, "id"); |
| + prefs_->SetString(app_id + ".external_update_url", |
|
meacer
2013/11/26 01:32:03
Can we restrict the update url to Web Store for al
|
| + extension_urls::GetWebstoreUpdateUrl().spec()); |
| + } |
| LoadFinished(); |
| } |