Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(261)

Unified Diff: components/history/core/browser/typed_url_sync_metadata_database.cc

Issue 2721713002: [sync] Add typed url sync metadata to the history db (Closed)
Patch Set: brettw review Created 3 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: components/history/core/browser/typed_url_sync_metadata_database.cc
diff --git a/components/history/core/browser/typed_url_sync_metadata_database.cc b/components/history/core/browser/typed_url_sync_metadata_database.cc
new file mode 100644
index 0000000000000000000000000000000000000000..dbeb548f59c695eeb1cf67e1fbdc72282dade592
--- /dev/null
+++ b/components/history/core/browser/typed_url_sync_metadata_database.cc
@@ -0,0 +1,148 @@
+// Copyright 2017 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/history/core/browser/typed_url_sync_metadata_database.h"
+
+#include "sql/statement.h"
+
+namespace history {
+
+// Description of database table:
+//
+// typed_url_sync_metadata
+// storage_key the rowid of an entry in urls table, used by service to
+// look up native data with sync metadata records.
+// value Serialize sync EntityMetadata, which is for tracking sync
+// state of each typed url.
+//
+// typed_url_model_type_state
+// id should only one record in the table and record's id should
+// always be 1.
+// value Serialization of sync ModelTypeState, which is for
+// tracking sync state of typed url datatype.
+
+TypedURLSyncMetadataDatabase::TypedURLSyncMetadataDatabase() {}
+
+TypedURLSyncMetadataDatabase::~TypedURLSyncMetadataDatabase() {}
+
+bool TypedURLSyncMetadataDatabase::GetAllSyncMetadata(
+ syncer::MetadataBatch* metadata_batch) {
+ syncer::EntityMetadataMap metadata_records_map;
+ if (GetAllSyncEntityMetadata(&metadata_records_map)) {
+ for (const auto& storayge_key_to_metadata : metadata_records_map)
brettw 2017/03/14 19:24:43 It's a little bit hard for me to give good suggest
Gang Wu 2017/03/15 08:02:43 This is really a good suggestion! But since add t
brettw 2017/03/20 17:27:06 Following up with another patch for this is OK to
Gang Wu 2017/03/20 21:34:47 yes, I talked with team, I think I will fix this i
+ metadata_batch->AddMetadata(storayge_key_to_metadata.first,
+ storayge_key_to_metadata.second);
+ } else {
+ return false;
+ }
+
+ sync_pb::ModelTypeState model_type_state;
+ if (GetModelTypeState(&model_type_state)) {
+ metadata_batch->SetModelTypeState(model_type_state);
+ } else {
+ return false;
+ }
+
+ return true;
+}
+
+bool TypedURLSyncMetadataDatabase::UpdateSyncMetadata(
+ const std::string& storage_key,
+ const sync_pb::EntityMetadata& metadata) {
+ sql::Statement s(GetDB().GetUniqueStatement(
+ "INSERT OR REPLACE INTO typed_url_sync_metadata "
+ "(storage_key, value) VALUES(?, ?)"));
+ s.BindString(0, storage_key);
+ s.BindString(1, metadata.SerializeAsString());
+
+ return s.Run();
+}
+
+bool TypedURLSyncMetadataDatabase::ClearSyncMetadata(
+ const std::string& storage_key) {
+ sql::Statement s(GetDB().GetUniqueStatement(
+ "DELETE FROM typed_url_sync_metadata WHERE storage_key=?"));
+ s.BindString(0, storage_key);
+
+ return s.Run();
+}
+
+bool TypedURLSyncMetadataDatabase::UpdateModelTypeState(
+ const sync_pb::ModelTypeState& model_type_state) {
+ // Hardcode the id to force a collision, ensuring that there remains only a
+ // single entry.
+ sql::Statement s(GetDB().GetUniqueStatement(
+ "INSERT OR REPLACE INTO typed_url_model_type_state (id, value) "
+ "VALUES(1,?)"));
+ s.BindString(0, model_type_state.SerializeAsString());
+
+ return s.Run();
+}
+
+bool TypedURLSyncMetadataDatabase::ClearModelTypeState() {
+ sql::Statement s(GetDB().GetUniqueStatement(
+ "DELETE FROM typed_url_model_type_state WHERE id=1"));
+
+ return s.Run();
+}
+
+bool TypedURLSyncMetadataDatabase::InitSyncTable() {
+ return InitTypedURLSyncMetadataTable() && InitModelTypeStateTable();
+}
+
+bool TypedURLSyncMetadataDatabase::InitTypedURLSyncMetadataTable() {
+ if (!GetDB().DoesTableExist("typed_url_sync_metadata")) {
+ if (!GetDB().Execute("CREATE TABLE typed_url_sync_metadata ("
+ "storage_key VARCHAR PRIMARY KEY NOT NULL,"
+ "value BLOB)")) {
+ NOTREACHED();
+ return false;
+ }
+ }
+ return true;
+}
+
+bool TypedURLSyncMetadataDatabase::InitModelTypeStateTable() {
+ if (!GetDB().DoesTableExist("typed_url_model_type_state")) {
+ if (!GetDB().Execute("CREATE TABLE typed_url_model_type_state (id INTEGER "
+ "PRIMARY KEY, value BLOB)")) {
+ NOTREACHED();
+ return false;
+ }
+ }
+ return true;
+}
+
+bool TypedURLSyncMetadataDatabase::GetAllSyncEntityMetadata(
+ syncer::EntityMetadataMap* metadata_records) {
+ sql::Statement s(GetDB().GetUniqueStatement(
+ "SELECT storage_key, value FROM typed_url_sync_metadata"));
+
+ while (s.Step()) {
+ std::string storage_key = s.ColumnString(0);
+ std::string serialized_metadata = s.ColumnString(1);
+ sync_pb::EntityMetadata metadata_record;
+ if (metadata_record.ParseFromString(serialized_metadata)) {
+ metadata_records->insert(std::make_pair(storage_key, metadata_record));
+ } else {
+ return false;
+ }
+ }
+ return true;
+}
+
+bool TypedURLSyncMetadataDatabase::GetModelTypeState(
+ sync_pb::ModelTypeState* state) {
+ sql::Statement s(GetDB().GetUniqueStatement(
+ "SELECT value FROM typed_url_model_type_state WHERE id=1"));
+
+ if (!s.Step()) {
+ return true;
+ }
+
+ std::string serialized_state = s.ColumnString(0);
+ return state->ParseFromString(serialized_state);
+}
+
+} // namespace history

Powered by Google App Engine
This is Rietveld 408576698