// Copyright (c) 2011 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_ #pragma once #include <string> #include "base/basictypes.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 "base/task_queue.h" #include "chrome/browser/webdata/web_data_service.h" class GURL; class NotificationSource; class NotificationType; class SearchHostToURLsMap; class Task; class TemplateURL; // 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(WebDataService* web_service, NotificationType ui_death_notification, const NotificationSource& ui_death_source); virtual ~SearchProviderInstallData(); // Use to determine when the search provider information is loaded. The // callback may happen synchronously or asynchronously. This takes ownership // of |task|. 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(Task* task); // 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); // 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 tasks to call after the load has finished. TaskQueue task_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<const 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_