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
|
// Copyright 2014 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "components/sync/engine/events/normal_get_updates_request_event.h"
#include "base/strings/stringprintf.h"
#include "base/values.h"
#include "components/sync/engine/cycle/nudge_tracker.h"
#include "components/sync/protocol/proto_value_conversions.h"
namespace syncer {
NormalGetUpdatesRequestEvent::NormalGetUpdatesRequestEvent(
base::Time timestamp,
const NudgeTracker& nudge_tracker,
const sync_pb::ClientToServerMessage& request)
: NormalGetUpdatesRequestEvent(timestamp,
nudge_tracker.GetNudgedTypes(),
nudge_tracker.GetNotifiedTypes(),
nudge_tracker.GetRefreshRequestedTypes(),
request) {}
NormalGetUpdatesRequestEvent::NormalGetUpdatesRequestEvent(
base::Time timestamp,
DataTypeSet nudged_types,
DataTypeSet notified_types,
DataTypeSet refresh_requested_types,
sync_pb::ClientToServerMessage request)
: timestamp_(timestamp),
nudged_types_(nudged_types),
notified_types_(notified_types),
refresh_requested_types_(refresh_requested_types),
request_(request) {}
std::unique_ptr<ProtocolEvent> NormalGetUpdatesRequestEvent::Clone() const {
return std::make_unique<NormalGetUpdatesRequestEvent>(
timestamp_, nudged_types_, notified_types_, refresh_requested_types_,
request_);
}
NormalGetUpdatesRequestEvent::~NormalGetUpdatesRequestEvent() = default;
base::Time NormalGetUpdatesRequestEvent::GetTimestamp() const {
return timestamp_;
}
std::string NormalGetUpdatesRequestEvent::GetType() const {
return "Normal GetUpdate request";
}
std::string NormalGetUpdatesRequestEvent::GetDetails() const {
std::string details;
if (!nudged_types_.empty()) {
if (!details.empty()) {
details.append("\n");
}
details.append(base::StringPrintf(
"Nudged types: %s", DataTypeSetToDebugString(nudged_types_).c_str()));
}
if (!notified_types_.empty()) {
if (!details.empty()) {
details.append("\n");
}
details.append(
base::StringPrintf("Notified types: %s",
DataTypeSetToDebugString(notified_types_).c_str()));
}
if (!refresh_requested_types_.empty()) {
if (!details.empty()) {
details.append("\n");
}
details.append(base::StringPrintf(
"Refresh requested types: %s",
DataTypeSetToDebugString(refresh_requested_types_).c_str()));
}
return details;
}
base::Value::Dict NormalGetUpdatesRequestEvent::GetProtoMessage(
bool include_specifics) const {
return ClientToServerMessageToValue(
request_, {.include_specifics = include_specifics,
.include_full_get_update_triggers = false})
.TakeDict();
}
} // namespace syncer
|