// 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 <string> #include "base/basictypes.h" #include "base/memory/ref_counted.h" #include "chrome/browser/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: explicit FaviconSource(Profile* profile); // 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<int, 0> cancelable_consumer_; // Raw PNG representation of the favicon to show when the favicon // database doesn't have a favicon for a webpage. scoped_refptr<RefCountedMemory> default_favicon_; DISALLOW_COPY_AND_ASSIGN(FaviconSource); }; #endif // CHROME_BROWSER_UI_WEBUI_FAVICON_SOURCE_H_