blob: 33cf760f2795f7c2518dcf3143353a0f5aff22ae [file] [log] [blame]
// 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 "chrome/browser/google/google_brand.h"
#include <algorithm>
#include <string>
#include "base/macros.h"
#include "base/strings/string_util.h"
#include "base/strings/utf_string_conversions.h"
#include "build/build_config.h"
#include "chrome/installer/util/google_update_settings.h"
#if defined(OS_MACOSX)
#include "chrome/browser/mac/keystone_glue.h"
#elif defined(OS_CHROMEOS)
#include "chrome/browser/google/google_brand_chromeos.h"
#endif
// Helpers --------------------------------------------------------------------
namespace {
const char* g_brand_for_testing = NULL;
} // namespace
namespace google_brand {
// Global functions -----------------------------------------------------------
#if defined(OS_WIN)
bool GetBrand(std::string* brand) {
if (g_brand_for_testing) {
brand->assign(g_brand_for_testing);
return true;
}
base::string16 brand16;
bool ret = GoogleUpdateSettings::GetBrand(&brand16);
if (ret)
brand->assign(base::UTF16ToASCII(brand16));
return ret;
}
bool GetReactivationBrand(std::string* brand) {
base::string16 brand16;
bool ret = GoogleUpdateSettings::GetReactivationBrand(&brand16);
if (ret)
brand->assign(base::UTF16ToASCII(brand16));
return ret;
}
#else
bool GetBrand(std::string* brand) {
if (g_brand_for_testing) {
brand->assign(g_brand_for_testing);
return true;
}
#if defined(OS_MACOSX)
brand->assign(keystone_glue::BrandCode());
#elif defined(OS_CHROMEOS)
brand->assign(google_brand::chromeos::GetBrand());
#else
brand->clear();
#endif
return true;
}
bool GetReactivationBrand(std::string* brand) {
brand->clear();
return true;
}
#endif
bool IsOrganic(const std::string& brand) {
#if defined(OS_MACOSX)
if (brand.empty()) {
// An empty brand string on Mac is used for channels other than stable,
// which are always organic.
return true;
}
#endif
const char* const kOrganicBrands[] = {
"CHCA", "CHCB", "CHCG", "CHCH", "CHCI", "CHCJ", "CHCK", "CHCL", "CHFO",
"CHFT", "CHHS", "CHHM", "CHMA", "CHMB", "CHME", "CHMF", "CHMG", "CHMH",
"CHMI", "CHMQ", "CHMV", "CHNB", "CHNC", "CHNG", "CHNH", "CHNI", "CHOA",
"CHOB", "CHOC", "CHON", "CHOO", "CHOP", "CHOQ", "CHOR", "CHOS", "CHOT",
"CHOU", "CHOX", "CHOY", "CHOZ", "CHPD", "CHPE", "CHPF", "CHPG", "ECBA",
"ECBB", "ECDA", "ECDB", "ECSA", "ECSB", "ECVA", "ECVB", "ECWA", "ECWB",
"ECWC", "ECWD", "ECWE", "ECWF", "EUBB", "EUBC", "GGLA", "GGLS"};
const char* const* end = &kOrganicBrands[arraysize(kOrganicBrands)];
if (std::binary_search(&kOrganicBrands[0], end, brand))
return true;
// The Chrome enterprise brand code is the only GGR* brand to be non-organic.
if (brand == "GGRV")
return false;
return base::StartsWith(brand, "EUB", base::CompareCase::SENSITIVE) ||
base::StartsWith(brand, "EUC", base::CompareCase::SENSITIVE) ||
base::StartsWith(brand, "GGR", base::CompareCase::SENSITIVE);
}
bool IsOrganicFirstRun(const std::string& brand) {
#if defined(OS_MACOSX)
if (brand.empty()) {
// An empty brand string on Mac is used for channels other than stable,
// which are always organic.
return true;
}
#endif
return base::StartsWith(brand, "GG", base::CompareCase::SENSITIVE) ||
base::StartsWith(brand, "EU", base::CompareCase::SENSITIVE);
}
bool IsInternetCafeBrandCode(const std::string& brand) {
const char* const kBrands[] = {
"CHIQ", "CHSG", "HLJY", "NTMO", "OOBA", "OOBB", "OOBC", "OOBD", "OOBE",
"OOBF", "OOBG", "OOBH", "OOBI", "OOBJ", "IDCM",
};
const char* const* end = &kBrands[arraysize(kBrands)];
const char* const* found = std::find(&kBrands[0], end, brand);
return found != end;
}
// BrandForTesting ------------------------------------------------------------
BrandForTesting::BrandForTesting(const std::string& brand) : brand_(brand) {
DCHECK(g_brand_for_testing == NULL);
g_brand_for_testing = brand_.c_str();
}
BrandForTesting::~BrandForTesting() {
g_brand_for_testing = NULL;
}
} // namespace google_brand