// Copyright 2012 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/search_engines/search_terms_data.h" #include "base/command_line.h" #include "base/logging.h" #include "base/metrics/field_trial.h" #include "base/prefs/pref_service.h" #include "base/strings/string_number_conversions.h" #include "chrome/browser/browser_process.h" #include "chrome/browser/google/google_url_tracker.h" #include "chrome/browser/google/google_util.h" #include "chrome/browser/profiles/profile.h" #include "chrome/browser/search/search.h" #include "chrome/browser/themes/theme_service.h" #include "chrome/browser/themes/theme_service_factory.h" #include "chrome/common/chrome_switches.h" #include "chrome/common/pref_names.h" #include "content/public/browser/browser_thread.h" #include "url/gurl.h" #if defined(ENABLE_RLZ) #include "chrome/browser/rlz/rlz.h" #endif using content::BrowserThread; SearchTermsData::SearchTermsData() { } SearchTermsData::~SearchTermsData() { } std::string SearchTermsData::GoogleBaseURLValue() const { return GoogleURLTracker::kDefaultGoogleHomepage; } std::string SearchTermsData::GoogleBaseSuggestURLValue() const { // Start with the Google base URL. const GURL base_url(GoogleBaseURLValue()); DCHECK(base_url.is_valid()); GURL::Replacements repl; // Replace any existing path with "/complete/". // SetPathStr() requires its argument to stay in scope as long as |repl| is, // so "/complete/" can't be passed to SetPathStr() directly, it needs to be in // a variable. const std::string suggest_path("/complete/"); repl.SetPathStr(suggest_path); // Clear the query and ref. repl.ClearQuery(); repl.ClearRef(); return base_url.ReplaceComponents(repl).spec(); } std::string SearchTermsData::GetApplicationLocale() const { return "en"; } string16 SearchTermsData::GetRlzParameterValue() const { return string16(); } std::string SearchTermsData::GetSearchClient() const { return std::string(); } std::string SearchTermsData::GetSuggestClient() const { return std::string(); } std::string SearchTermsData::ForceInstantResultsParam( bool for_prerender) const { return std::string(); } std::string SearchTermsData::InstantExtendedEnabledParam() const { return std::string(); } std::string SearchTermsData::NTPIsThemedParam() const { return std::string(); } // static std::string* UIThreadSearchTermsData::google_base_url_ = NULL; UIThreadSearchTermsData::UIThreadSearchTermsData(Profile* profile) : profile_(profile) { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); } std::string UIThreadSearchTermsData::GoogleBaseURLValue() const { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); if (google_base_url_) return *google_base_url_; std::string base_url = CommandLine::ForCurrentProcess()-> GetSwitchValueASCII(switches::kGoogleBaseURL); if (!base_url.empty()) return base_url; return profile_ ? GoogleURLTracker::GoogleURL(profile_).spec() : SearchTermsData::GoogleBaseURLValue(); } std::string UIThreadSearchTermsData::GetApplicationLocale() const { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); return g_browser_process->GetApplicationLocale(); } // Android implementations are located in search_terms_data_android.cc. #if !defined(OS_ANDROID) string16 UIThreadSearchTermsData::GetRlzParameterValue() const { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); string16 rlz_string; #if defined(ENABLE_RLZ) // For organic brandcodes do not use rlz at all. Empty brandcode usually // means a chromium install. This is ok. std::string brand; if (google_util::GetBrand(&brand) && !brand.empty() && !google_util::IsOrganic(brand)) { // This call will return false the first time(s) it is called until the // value has been cached. This normally would mean that at most one omnibox // search might not send the RLZ data but this is not really a problem. RLZTracker::GetAccessPointRlz(RLZTracker::CHROME_OMNIBOX, &rlz_string); } #endif return rlz_string; } // We can enable this on non-Android if other platforms ever want a non-empty // search client string. There is already a unit test in place for Android // called TemplateURLTest::SearchClient. std::string UIThreadSearchTermsData::GetSearchClient() const { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); return std::string(); } #endif std::string UIThreadSearchTermsData::GetSuggestClient() const { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); return chrome::IsInstantExtendedAPIEnabled() ? "chrome-omni" : "chrome"; } std::string UIThreadSearchTermsData::ForceInstantResultsParam( bool for_prerender) const { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); return (for_prerender || !chrome::IsInstantExtendedAPIEnabled()) ? "ion=1&" : std::string(); } std::string UIThreadSearchTermsData::InstantExtendedEnabledParam() const { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); uint64 instant_extended_api_version = chrome::EmbeddedSearchPageVersion(); if (instant_extended_api_version) { return std::string(google_util::kInstantExtendedAPIParam) + "=" + base::Uint64ToString(instant_extended_api_version) + "&"; } return std::string(); } std::string UIThreadSearchTermsData::NTPIsThemedParam() const { DCHECK(!BrowserThread::IsThreadInitialized(BrowserThread::UI) || BrowserThread::CurrentlyOn(BrowserThread::UI)); #if defined(ENABLE_THEMES) if (!chrome::IsInstantExtendedAPIEnabled()) return std::string(); // TODO(dhollowa): Determine fraction of custom themes that don't affect the // NTP background and/or color. ThemeService* theme_service = ThemeServiceFactory::GetForProfile(profile_); // NTP is considered themed if the theme is not default and not native (GTK+). if (theme_service && !theme_service->UsingDefaultTheme() && !theme_service->UsingNativeTheme()) return "es_th=1&"; #endif // defined(ENABLE_THEMES) return std::string(); } // static void UIThreadSearchTermsData::SetGoogleBaseURL(const std::string& base_url) { delete google_base_url_; google_base_url_ = base_url.empty() ? NULL : new std::string(base_url); }