// 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_UI_WEBUI_FAVICON_SOURCE_H_ #define CHROME_BROWSER_UI_WEBUI_FAVICON_SOURCE_H_ #pragma once #include #include "base/basictypes.h" #include "base/memory/ref_counted.h" #include "chrome/browser/favicon/favicon_service.h" #include "chrome/browser/ui/webui/chrome_url_data_manager.h" class GURL; class Profile; // FaviconSource is the gateway between network-level chrome: // requests for favicons and the history backend that serves these. class FaviconSource : public ChromeURLDataManager::DataSource { public: // Defines the type of icon the FaviconSource will provide. enum IconType { FAVICON, // Any available icon in the priority of TOUCH_ICON_PRECOMPOSED, TOUCH_ICON, // FAVICON, and default favicon. ANY }; // |type| is the type of icon this FaviconSource will provide. FaviconSource(Profile* profile, IconType type); // Called when the network layer has requested a resource underneath // the path we registered. virtual void StartDataRequest(const std::string& path, bool is_incognito, int request_id); virtual std::string GetMimeType(const std::string&) const; virtual bool ShouldReplaceExistingSource() const; private: // Called when favicon data is available from the history backend. void OnFaviconDataAvailable(FaviconService::Handle request_handle, history::FaviconData favicon); // Sends the default favicon. void SendDefaultResponse(int request_id); virtual ~FaviconSource(); Profile* profile_; CancelableRequestConsumerT cancelable_consumer_; // Raw PNG representation of the favicon to show when the favicon // database doesn't have a favicon for a webpage. scoped_refptr default_favicon_; // The history::IconTypes of icon that this FaviconSource handles. const int icon_types_; DISALLOW_COPY_AND_ASSIGN(FaviconSource); }; #endif // CHROME_BROWSER_UI_WEBUI_FAVICON_SOURCE_H_