blob: b421d44d92cde9de51dfc9111ce5575bd3ff6452 [file] [log] [blame]
// Copyright 2022 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_SEGMENTATION_PLATFORM_INTERNAL_DATABASE_SEGMENT_INFO_CACHE_H_
#define COMPONENTS_SEGMENTATION_PLATFORM_INTERNAL_DATABASE_SEGMENT_INFO_CACHE_H_
#include <memory>
#include "base/callback.h"
#include "base/containers/flat_map.h"
#include "base/containers/flat_set.h"
#include "components/segmentation_platform/internal/proto/model_prediction.pb.h"
#include "components/segmentation_platform/public/proto/model_metadata.pb.h"
#include "components/segmentation_platform/public/proto/segmentation_platform.pb.h"
#include "third_party/abseil-cpp/absl/types/optional.h"
namespace segmentation_platform {
using proto::SegmentId;
using proto::SegmentInfo;
// Represents a cache layer wrapped over the DB layer that stores
// used SegmentId and SegmentInfo to be cached, inorder to decrease
// the time to read from DB in consecutive calls
class SegmentInfoCache {
public:
using SegmentInfoList = std::vector<std::pair<SegmentId, proto::SegmentInfo>>;
enum class CachedItemState {
// SegmentId was never checked in database or cache before, hence was not
// cached.
kNotCached = 0,
// SegmentId is checked in database and not found result was cached.
kCachedAndNotFound = 1,
// SegmentId is present in database and was cached.
kCachedAndFound = 2,
};
explicit SegmentInfoCache(bool cache_enabled);
~SegmentInfoCache();
// Disallow copy/assign.
SegmentInfoCache(const SegmentInfoCache&) = delete;
SegmentInfoCache& operator=(const SegmentInfoCache&) = delete;
// Returns CachedItemState and SegmentInfo for a `segment_id`.
std::pair<CachedItemState, absl::optional<SegmentInfo>> GetSegmentInfo(
SegmentId segment_id) const;
// Returns list of segment info for list of `segment_ids` with state
// `kCachedAndFound` and adds the remaining list of `segment_ids` with state
// `kNotCached` to `ids_needing_update`. If cached item state of segment id is
// `kCachedAndNotFound`, nothing is returned for it.
std::unique_ptr<SegmentInfoList> GetSegmentInfoForSegments(
const base::flat_set<SegmentId>& segment_ids,
base::flat_set<SegmentId>& ids_needing_update) const;
// Updates cache with `segment_info` for a `segment_id`.
// It saves the entry in cache with cached item state `kCachedAndNotFound` if
// `segment_info` is null or is erased.
void UpdateSegmentInfo(SegmentId segment_id,
absl::optional<SegmentInfo> segment_info);
private:
// Map storing CachedItemState and SegmentInfo for a SegmentId.
base::flat_map<SegmentId,
std::pair<CachedItemState, absl::optional<SegmentInfo>>>
segment_info_cache_;
// Flag representing if cache is enabled or not.
const bool cache_enabled_;
};
} // namespace segmentation_platform
#endif // COMPONENTS_SEGMENTATION_PLATFORM_INTERNAL_DATABASE_SEGMENT_INFO_CACHE_H_