// Copyright 2014 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_SEARCH_PROVIDER_LOGOS_LOGO_COMMON_H_ #define COMPONENTS_SEARCH_PROVIDER_LOGOS_LOGO_COMMON_H_ #include <string> #include "base/memory/ref_counted.h" #include "base/memory/ref_counted_memory.h" #include "base/time/time.h" #include "third_party/skia/include/core/SkBitmap.h" namespace search_provider_logos { // The maximum number of milliseconds that a logo can be cached. extern const int64 kMaxTimeToLiveMS; struct LogoMetadata { LogoMetadata(); ~LogoMetadata(); // For use by the client ---------------------------------------------------- // The URL to load when the logo is clicked. std::string on_click_url; // The accessibility text for the logo. std::string alt_text; // The mime type of the logo image. std::string mime_type; // For use by LogoTracker --------------------------------------------------- // The URL from which the logo was downloaded (without the fingerprint param). std::string source_url; // A fingerprint (i.e. hash) identifying the logo. Used when revalidating the // logo with the server. std::string fingerprint; // Whether the logo can be shown optimistically after it's expired while a // fresh logo is being downloaded. bool can_show_after_expiration; // When the logo expires. After this time, the logo will not be used and will // be deleted. base::Time expiration_time; }; struct EncodedLogo { EncodedLogo(); ~EncodedLogo(); // The jpeg- or png-encoded image. scoped_refptr<base::RefCountedString> encoded_image; // Metadata about the logo. LogoMetadata metadata; }; struct Logo { Logo(); ~Logo(); // The logo image. SkBitmap image; // Metadata about the logo. LogoMetadata metadata; }; } // namespace search_provider_logos #endif // COMPONENTS_SEARCH_PROVIDER_LOGOS_LOGO_COMMON_H_