// 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.
#include "components/invalidation/ack_handle.h"
#include <cstddef>
#include "base/rand_util.h"
#include "base/strings/string_number_conversions.h"
#include "base/values.h"
namespace syncer {
namespace {
// Hopefully enough bytes for uniqueness.
const size_t kBytesInHandle = 16;
} // namespace
AckHandle AckHandle::CreateUnique() {
// This isn't a valid UUID, so we don't attempt to format it like one.
uint8 random_bytes[kBytesInHandle];
base::RandBytes(random_bytes, sizeof(random_bytes));
return AckHandle(base::HexEncode(random_bytes, sizeof(random_bytes)),
base::Time::Now());
}
AckHandle AckHandle::InvalidAckHandle() {
return AckHandle(std::string(), base::Time());
}
bool AckHandle::Equals(const AckHandle& other) const {
return state_ == other.state_ && timestamp_ == other.timestamp_;
}
scoped_ptr<base::DictionaryValue> AckHandle::ToValue() const {
scoped_ptr<base::DictionaryValue> value(new base::DictionaryValue());
value->SetString("state", state_);
value->SetString("timestamp",
base::Int64ToString(timestamp_.ToInternalValue()));
return value.Pass();
}
bool AckHandle::ResetFromValue(const base::DictionaryValue& value) {
if (!value.GetString("state", &state_))
return false;
std::string timestamp_as_string;
if (!value.GetString("timestamp", ×tamp_as_string))
return false;
int64 timestamp_value;
if (!base::StringToInt64(timestamp_as_string, ×tamp_value))
return false;
timestamp_ = base::Time::FromInternalValue(timestamp_value);
return true;
}
bool AckHandle::IsValid() const {
return !state_.empty();
}
AckHandle::AckHandle(const std::string& state, base::Time timestamp)
: state_(state), timestamp_(timestamp) {
}
AckHandle::~AckHandle() {
}
} // namespace syncer