blob: 52a7af7ca728e27f486304569564dc74b3f8fbc9 [file] [log] [blame]
// 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_SYNC_ENGINE_IMPL_COMMIT_CONTRIBUTION_IMPL_H_
#define COMPONENTS_SYNC_ENGINE_IMPL_COMMIT_CONTRIBUTION_IMPL_H_
#include <stddef.h>
#include <stdint.h>
#include <vector>
#include "base/macros.h"
#include "components/sync/base/passphrase_enums.h"
#include "components/sync/engine/commit_and_get_updates_types.h"
#include "components/sync/engine_impl/commit_contribution.h"
#include "components/sync/engine_impl/cycle/data_type_debug_info_emitter.h"
#include "components/sync/protocol/sync.pb.h"
namespace syncer {
class Cryptographer;
class ModelTypeWorker;
// A sync type's contribution to an outgoing commit message.
//
// Helps build a commit message and process its response. It collaborates
// closely with the ModelTypeWorker.
class CommitContributionImpl : public CommitContribution {
public:
// Note: only one of |on_commit_response_callback| and
// |on_full_commit_failure_callback| will be called.
// TODO(rushans): there is still possible rare case when both of these
// callbacks are never called, i.e. if get updates from the server fails.
CommitContributionImpl(
ModelType type,
const sync_pb::DataTypeContext& context,
CommitRequestDataList commit_requests,
base::OnceCallback<void(const CommitResponseDataList&,
const FailedCommitResponseDataList&)>
on_commit_response_callback,
base::OnceCallback<void(SyncCommitError)> on_full_commit_failure_callback,
Cryptographer* cryptographer,
PassphraseType passphrase_type,
DataTypeDebugInfoEmitter* debug_info_emitter,
bool only_commit_specifics);
~CommitContributionImpl() override;
// Implementation of CommitContribution
void AddToCommitMessage(sync_pb::ClientToServerMessage* msg) override;
SyncerError ProcessCommitResponse(
const sync_pb::ClientToServerResponse& response,
StatusController* status) override;
void ProcessCommitFailure(SyncCommitError commit_error) override;
void CleanUp() override;
size_t GetNumEntries() const override;
// Public for testing.
// Copies data to be committed from CommitRequestData into SyncEntity proto.
static void PopulateCommitProto(ModelType type,
const CommitRequestData& commit_entity,
sync_pb::SyncEntity* commit_proto);
private:
// Generates id for new entities and encrypts entity if needed.
void AdjustCommitProto(sync_pb::SyncEntity* commit_proto);
const ModelType type_;
// A callback to inform the object that created this contribution about commit
// result.
base::OnceCallback<void(const CommitResponseDataList&,
const FailedCommitResponseDataList&)>
on_commit_response_callback_;
// A callback to inform the object that created this contribution about commit
// failure. This callback differs from |on_commit_response_callback_| and will
// be called when the server respond with any error code or do not respond at
// all (i.e. there is no internet connection).
base::OnceCallback<void(SyncCommitError)> on_full_commit_failure_callback_;
// A non-owned pointer to cryptographer to encrypt entities.
Cryptographer* const cryptographer_;
const PassphraseType passphrase_type_;
// The type-global context information.
const sync_pb::DataTypeContext context_;
// The list of entities to be committed.
CommitRequestDataList commit_requests_;
// The index in the commit message where this contribution's entities are
// added. Used to correlate per-item requests with per-item responses.
size_t entries_start_index_;
// A flag used to ensure this object's contract is respected. Helps to check
// that CleanUp() is called before the object is destructed.
bool cleaned_up_;
DataTypeDebugInfoEmitter* debug_info_emitter_;
// Don't send any metadata to server, only specifics. This is needed for
// commit only types to save bandwidth.
bool only_commit_specifics_;
DISALLOW_COPY_AND_ASSIGN(CommitContributionImpl);
};
} // namespace syncer
#endif // COMPONENTS_SYNC_ENGINE_IMPL_COMMIT_CONTRIBUTION_IMPL_H_