blob: 23472478909f5a0406874ffcb1e7a294bd1d857e [file] [log] [blame]
// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef ASH_AMBIENT_AMBIENT_PHOTO_CACHE_H_
#define ASH_AMBIENT_AMBIENT_PHOTO_CACHE_H_
#include <memory>
#include <string>
#include "ash/ash_export.h"
#include "ash/public/cpp/ambient/proto/photo_cache_entry.pb.h"
#include "base/files/file_path.h"
#include "base/functional/callback_forward.h"
namespace gfx {
class ImageSkia;
} // namespace gfx
namespace ash {
class AmbientClient;
class AmbientAccessTokenController;
// Interface for downloading and decoding photos for Ambient mode. Mocked for
// testing to isolate from network and file system.
// Each cache entry is written to disk as three files in the |root_path|, with
// filenames prefixed by |cache_index|.
class ASH_EXPORT AmbientPhotoCache {
public:
AmbientPhotoCache() = default;
AmbientPhotoCache(const AmbientPhotoCache&) = delete;
AmbientPhotoCache& operator=(const AmbientPhotoCache&) = delete;
virtual ~AmbientPhotoCache() = default;
// `root_path` is where the cached photos stored on disk.
// `ambient_client` and `access_token_controller` are used to obtain url
// loader factory and access tokens to fetch the online images.
static std::unique_ptr<AmbientPhotoCache> Create(
base::FilePath root_path,
AmbientClient& ambient_client,
AmbientAccessTokenController& access_token_controller);
// Overrides the output of |Create()| for testing. This is global and can be
// reset back to a null callback to disable the override.
static void SetFactoryForTesting(
base::RepeatingCallback<std::unique_ptr<AmbientPhotoCache>()> factory_fn);
virtual void DownloadPhoto(
const std::string& url,
base::OnceCallback<void(std::string&&)> callback) = 0;
// Saves the photo at |url| to |cache_index| and calls |callback| with a
// boolean that indicates success.
virtual void DownloadPhotoToFile(const std::string& url,
int cache_index,
base::OnceCallback<void(bool)> callback) = 0;
virtual void DecodePhoto(
const std::string& data,
base::OnceCallback<void(const gfx::ImageSkia&)> callback) = 0;
// Write photo cache to disk at |cache_index| and call |callback| when
// complete.
virtual void WritePhotoCache(int cache_index,
const ::ambient::PhotoCacheEntry& cache_entry,
base::OnceClosure callback) = 0;
// Read the photo cache at |cache_index| and call |callback| when complete.
// If a particular cache fails to be read, |cache_entry| will be empty.
virtual void ReadPhotoCache(
int cache_index,
base::OnceCallback<void(::ambient::PhotoCacheEntry cache_entry)>
callback) = 0;
// Erase all stored files from disk.
virtual void Clear() = 0;
};
} // namespace ash
#endif // ASH_AMBIENT_AMBIENT_PHOTO_CACHE_H_