| // Copyright 2017 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 COMPONENTS_NTP_TILES_ICON_CACHER_H_ |
| #define COMPONENTS_NTP_TILES_ICON_CACHER_H_ |
| |
| #include "base/callback.h" |
| #include "components/ntp_tiles/popular_sites.h" |
| |
| namespace ntp_tiles { |
| |
| // Ensures that Popular Sites icons and MostLikely icons are cached, downloading |
| // and saving them if not. |
| // |
| // Does not provide any way to get a fetched favicon; use the FaviconService / |
| // LargeIconService for that. All this interface guarantees is that |
| // FaviconService will be able to get you an icon (if it exists). |
| class IconCacher { |
| public: |
| virtual ~IconCacher() = default; |
| |
| // Fetches the icon if necessary. If a new icon was fetched, the optional |
| // |icon_available| callback will be invoked. |
| // If there are preliminary icons (e.g. provided by static resources), the |
| // optional |preliminary_icon_available| callback will be invoked in addition. |
| // TODO(fhorschig): In case we keep these, make them OnceClosures. |
| virtual void StartFetchPopularSites( |
| PopularSites::Site site, |
| const base::Closure& icon_available, |
| const base::Closure& preliminary_icon_available) = 0; |
| |
| // Fetches the icon if necessary, then invokes |done| with true if it was |
| // newly fetched (false if it was already cached or could not be fetched). |
| virtual void StartFetchMostLikely(const GURL& page_url, |
| const base::Closure& icon_available) = 0; |
| }; |
| |
| } // namespace ntp_tiles |
| |
| #endif // COMPONENTS_NTP_TILES_ICON_CACHER_H_ |