// 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 "sync/test/fake_server/bookmark_entity.h"
#include <string>
#include "base/basictypes.h"
#include "base/guid.h"
#include "sync/internal_api/public/base/model_type.h"
#include "sync/protocol/sync.pb.h"
#include "sync/test/fake_server/fake_server_entity.h"
using std::string;
namespace fake_server {
namespace {
// Returns true if and only if |client_entity| is a bookmark.
bool IsBookmark(const sync_pb::SyncEntity& client_entity) {
return syncer::GetModelType(client_entity) == syncer::BOOKMARKS;
}
} // namespace
BookmarkEntity::~BookmarkEntity() { }
// static
FakeServerEntity* BookmarkEntity::CreateNew(
const sync_pb::SyncEntity& client_entity,
const string& parent_id,
const string& client_guid) {
CHECK(client_entity.version() == 0) << "New entities must have version = 0.";
CHECK(IsBookmark(client_entity)) << "The given entity must be a bookmark.";
string id = FakeServerEntity::CreateId(syncer::BOOKMARKS,
base::GenerateGUID());
string originator_cache_guid = client_guid;
string originator_client_item_id = client_entity.id_string();
return new BookmarkEntity(id,
client_entity.version(),
client_entity.name(),
originator_cache_guid,
originator_client_item_id,
client_entity.unique_position(),
client_entity.specifics(),
client_entity.folder(),
parent_id,
client_entity.ctime(),
client_entity.mtime());
}
// static
FakeServerEntity* BookmarkEntity::CreateUpdatedVersion(
const sync_pb::SyncEntity& client_entity,
FakeServerEntity* current_server_entity,
const string& parent_id) {
CHECK(client_entity.version() != 0) << "Existing entities must not have a "
<< "version = 0.";
CHECK(IsBookmark(client_entity)) << "The given entity must be a bookmark.";
BookmarkEntity* current_bookmark_entity =
static_cast<BookmarkEntity*>(current_server_entity);
string originator_cache_guid =
current_bookmark_entity->originator_cache_guid_;
string originator_client_item_id =
current_bookmark_entity->originator_client_item_id_;
return new BookmarkEntity(client_entity.id_string(),
client_entity.version(),
client_entity.name(),
originator_cache_guid,
originator_client_item_id,
client_entity.unique_position(),
client_entity.specifics(),
client_entity.folder(),
parent_id,
client_entity.ctime(),
client_entity.mtime());
}
BookmarkEntity::BookmarkEntity(
const string& id,
int64 version,
const string& name,
const string& originator_cache_guid,
const string& originator_client_item_id,
const sync_pb::UniquePosition& unique_position,
const sync_pb::EntitySpecifics& specifics,
bool is_folder,
const string& parent_id,
int64 creation_time,
int64 last_modified_time)
: FakeServerEntity(id, syncer::BOOKMARKS, version, name),
originator_cache_guid_(originator_cache_guid),
originator_client_item_id_(originator_client_item_id),
unique_position_(unique_position),
specifics_(specifics),
is_folder_(is_folder),
parent_id_(parent_id),
creation_time_(creation_time),
last_modified_time_(last_modified_time) { }
string BookmarkEntity::GetParentId() const {
return parent_id_;
}
void BookmarkEntity::SerializeAsProto(sync_pb::SyncEntity* proto) {
FakeServerEntity::SerializeBaseProtoFields(proto);
sync_pb::EntitySpecifics* specifics = proto->mutable_specifics();
specifics->CopyFrom(specifics_);
proto->set_originator_cache_guid(originator_cache_guid_);
proto->set_originator_client_item_id(originator_client_item_id_);
proto->set_parent_id_string(parent_id_);
proto->set_ctime(creation_time_);
proto->set_mtime(last_modified_time_);
sync_pb::UniquePosition* unique_position = proto->mutable_unique_position();
unique_position->CopyFrom(unique_position_);
}
bool BookmarkEntity::IsDeleted() const {
return false;
}
bool BookmarkEntity::IsFolder() const {
return is_folder_;
}
} // namespace fake_server