blob: 69dd52895d1bc25434b11e743546b171d1055d5f [file] [log] [blame]
// Copyright (c) 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.
#ifndef CHROME_BROWSER_SEARCH_ENGINES_SEARCH_PROVIDER_INSTALL_DATA_H_
#define CHROME_BROWSER_SEARCH_ENGINES_SEARCH_PROVIDER_INSTALL_DATA_H_
#include <string>
#include "base/basictypes.h"
#include "base/callback.h"
#include "base/memory/ref_counted.h"
#include "base/memory/scoped_ptr.h"
#include "base/memory/scoped_vector.h"
#include "base/memory/weak_ptr.h"
#include "chrome/browser/webdata/web_data_service.h"
class GURL;
class SearchHostToURLsMap;
class TemplateURL;
namespace content {
class NotificationSource;
}
// Provides the search provider install state for the I/O thread. It works by
// loading the data on demand (when CallWhenLoaded is called) and then throwing
// away the results after the callbacks are done, so the results are always up
// to date with what is in the database.
class SearchProviderInstallData : public WebDataServiceConsumer,
public base::SupportsWeakPtr<SearchProviderInstallData> {
public:
enum State {
// The search provider is not installed.
NOT_INSTALLED = 0,
// The search provider is in the user's set but is not
INSTALLED_BUT_NOT_DEFAULT = 1,
// The search provider is set as the user's default.
INSTALLED_AS_DEFAULT = 2
};
// |ui_death_notification| and |ui_death_source| indentify a notification that
// may be observed on the UI thread to know when this class no longer needs to
// be kept up to date. (Note that this class may be deleted before or after
// that notification occurs. It doesn't matter.)
SearchProviderInstallData(Profile* profile,
int ui_death_notification,
const content::NotificationSource& ui_death_source);
virtual ~SearchProviderInstallData();
// Use to determine when the search provider information is loaded. The
// callback may happen synchronously or asynchronously. There is no need to do
// anything special to make it function (as it just relies on the normal I/O
// thread message loop).
void CallWhenLoaded(const base::Closure& closure);
// Returns the search provider install state for the given origin.
// This should only be called while a task is called back from CallWhenLoaded.
State GetInstallState(const GURL& requested_origin);
// Called when the google base url has changed.
void OnGoogleURLChange(const std::string& google_base_url);
private:
// WebDataServiceConsumer
// Notification that the keywords have been loaded.
// This is invoked from WebDataService, and should not be directly
// invoked.
virtual void OnWebDataServiceRequestDone(
WebDataService::Handle h,
const WDTypedResult* result) OVERRIDE;
// Stores information about the default search provider.
void SetDefault(const TemplateURL* template_url);
// Sets up the loaded state and then lets clients know that the search
// provider install state has been loaded.
void OnLoadFailed();
// Does notifications to let clients know that the search provider
// install state has been loaded.
void NotifyLoaded();
// The list of closures to call after the load has finished.
std::vector<base::Closure> closure_queue_;
// Service used to store entries.
scoped_refptr<WebDataService> web_service_;
// If non-zero, we're waiting on a load.
WebDataService::Handle load_handle_;
// Holds results of a load that was done using this class.
scoped_ptr<SearchHostToURLsMap> provider_map_;
// The list of template urls that are owned by the class.
ScopedVector<TemplateURL> template_urls_;
// The security origin for the default search provider.
std::string default_search_origin_;
// The google base url.
std::string google_base_url_;
DISALLOW_COPY_AND_ASSIGN(SearchProviderInstallData);
};
#endif // CHROME_BROWSER_SEARCH_ENGINES_SEARCH_PROVIDER_INSTALL_DATA_H_