1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
|
// 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 COMPONENTS_SYNC_MODEL_PROCESSOR_ENTITY_TRACKER_H_
#define COMPONENTS_SYNC_MODEL_PROCESSOR_ENTITY_TRACKER_H_
#include <memory>
#include <optional>
#include <string>
#include <unordered_set>
#include <vector>
#include "base/containers/flat_set.h"
#include "components/sync/base/client_tag_hash.h"
#include "components/sync/engine/commit_and_get_updates_types.h"
#include "components/sync/protocol/data_type_state.pb.h"
#include "third_party/abseil-cpp/absl/container/flat_hash_map.h"
namespace sync_pb {
class EntityMetadata;
class EntitySpecifics;
} // namespace sync_pb
namespace syncer {
class ProcessorEntity;
// This component tracks entities for ClientTagBasedDataTypeProcessor.
class ProcessorEntityTracker {
public:
// Creates tracker and fills entities data from batch metadata map. This
// constructor must be used only if the `initial_sync_state` in
// `data_type_state` is at least partially-done.
ProcessorEntityTracker(
DataType type,
const sync_pb::DataTypeState& data_type_state,
std::map<std::string, std::unique_ptr<sync_pb::EntityMetadata>>
metadata_map);
~ProcessorEntityTracker();
// Returns true if all processor entities have non-empty storage keys.
// This may happen during initial merge and for some data types during any
// remote creation.
bool AllStorageKeysPopulated() const;
// Clears any in-memory sync state associated with outstanding commits
// for each entity.
void ClearTransientSyncState();
// Returns number of entities with non-deleted metadata.
size_t CountNonTombstoneEntries() const;
// Starts tracking new locally-created entity (must not be deleted outside
// current object). The entity will be created unsynced with pending commit
// data.
ProcessorEntity* AddUnsyncedLocal(
const std::string& storage_key,
std::unique_ptr<EntityData> data,
sync_pb::EntitySpecifics trimmed_specifics,
std::optional<sync_pb::UniquePosition> unique_position);
// Starts tracking new remotely-created entity (must not be deleted outside
// current object).
ProcessorEntity* AddRemote(
const std::string& storage_key,
const UpdateResponseData& update_data,
sync_pb::EntitySpecifics trimmed_specifics,
std::optional<sync_pb::UniquePosition> unique_position);
// Removes item from `entities_` and `storage_key_to_tag_hash`. If entity does
// not exist, does nothing.
void RemoveEntityForClientTagHash(const ClientTagHash& client_tag_hash);
void RemoveEntityForStorageKey(const std::string& storage_key);
// Removes items from `entities_` which are associated with a collaboration
// which is not active anymore. Returns storage keys for the deleted entities.
std::vector<std::string> RemoveInactiveCollaborations(
const base::flat_set<std::string>& active_collaborations);
// Removes `storage_key` from `storage_key_to_tag_hash_` and clears it for
// the corresponding entity. Does not remove the entity from `entities_`.
void ClearStorageKey(const std::string& storage_key);
// Returns the estimate of dynamically allocated memory in bytes.
size_t EstimateMemoryUsage() const;
// Gets the entity for the given tag hash, or null if there isn't one.
ProcessorEntity* GetEntityForTagHash(const ClientTagHash& tag_hash);
const ProcessorEntity* GetEntityForTagHash(
const ClientTagHash& tag_hash) const;
// Gets the entity for the given storage key, or null if there isn't one.
ProcessorEntity* GetEntityForStorageKey(const std::string& storage_key);
const ProcessorEntity* GetEntityForStorageKey(
const std::string& storage_key) const;
// Returns all entities including tombstones.
std::vector<const ProcessorEntity*> GetAllEntitiesIncludingTombstones() const;
// Returns all storage keys.
std::vector<std::string> GetAllStorageKeys() const;
// Returns all entities with local changes.
// TODO(rushans): make it const, at this moment returned entities must be
// initialized to commit.
std::vector<ProcessorEntity*> GetEntitiesWithLocalChanges(size_t max_entries);
// Returns true if there are any local entities to be committed.
// TODO(crbug.com/401470426): Investigate if this method can be replaced with
// `HasUnsyncedChanges()`, else rename it to something more accurate.
bool HasLocalChanges() const;
// Returns the count of entities with unsynced changes.
size_t GetUnsyncedDataCount() const;
const sync_pb::DataTypeState& data_type_state() const {
return data_type_state_;
}
void set_data_type_state(const sync_pb::DataTypeState& data_type_state) {
data_type_state_ = data_type_state;
}
// Returns number of entities, including tombstones.
size_t size() const;
// Increments sequence number for all entities except those in
// `already_updated_storage_keys`. Returns affected list of entities.
std::vector<const ProcessorEntity*> IncrementSequenceNumberForAllExcept(
const std::unordered_set<std::string>& already_updated_storage_keys);
// Assigns a new storage key to the entity for the given `client_tag_hash`.
// Clears previous storage key if entity already has one (the metadata of the
// entity must be deleted).
void UpdateOrOverrideStorageKey(const ClientTagHash& client_tag_hash,
const std::string& storage_key);
private:
// Creates a new processor entity (must not be deleted outside current
// object).
ProcessorEntity* AddInternal(const std::string& storage_key,
const EntityData& data);
// A map of client tag hash to sync entities known to this tracker. This
// should contain entries and metadata, although the entities may not always
// contain data type data/specifics.
absl::flat_hash_map<ClientTagHash, std::unique_ptr<ProcessorEntity>>
entities_;
// The data type metadata (progress marker, initial sync done, etc).
sync_pb::DataTypeState data_type_state_;
// The bridge wants to communicate entirely via storage keys that it is free
// to define and can understand more easily. All of the sync machinery wants
// to use client tag hash. This mapping allows us to convert from storage key
// to client tag hash. The other direction can use `entities_`.
// Entity is temporarily not included in this map for the duration of
// MergeFullSyncData/ApplyIncrementalSyncChanges call when the bridge doesn't
// support GetStorageKey(). In this case the bridge is responsible for
// updating storage key with UpdateStorageKey() call from within
// MergeFullSyncData/ApplyIncrementalSyncChanges.
absl::flat_hash_map<std::string, ClientTagHash> storage_key_to_tag_hash_;
};
} // namespace syncer
#endif // COMPONENTS_SYNC_MODEL_PROCESSOR_ENTITY_TRACKER_H_
|