Skip to content

Commit

Permalink
Refactor database
Browse files Browse the repository at this point in the history
- removes category column
- adds visits column

Resolves brave/brave-browser#2163
  • Loading branch information
NejcZdovc committed Jan 3, 2019
1 parent 4b992d0 commit 7229bbb
Show file tree
Hide file tree
Showing 2 changed files with 94 additions and 39 deletions.
132 changes: 93 additions & 39 deletions components/brave_rewards/browser/publisher_info_database.cc
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ namespace brave_rewards {

namespace {

const int kCurrentVersionNumber = 2;
const int kCurrentVersionNumber = 3;
const int kCompatibleVersionNumber = 1;

} // namespace
Expand Down Expand Up @@ -152,10 +152,10 @@ bool PublisherInfoDatabase::CreateActivityInfoTable() {
"("
"publisher_id LONGVARCHAR NOT NULL,"
"duration INTEGER DEFAULT 0 NOT NULL,"
"visits INTEGER DEFAULT 0 NOT NULL,"
"score DOUBLE DEFAULT 0 NOT NULL,"
"percent INTEGER DEFAULT 0 NOT NULL,"
"weight DOUBLE DEFAULT 0 NOT NULL,"
"category INTEGER NOT NULL,"
"month INTEGER NOT NULL,"
"year INTEGER NOT NULL,"
"reconcile_stamp INTEGER DEFAULT 0 NOT NULL,"
Expand Down Expand Up @@ -263,33 +263,31 @@ bool PublisherInfoDatabase::InsertOrUpdatePublisherInfo(

sql::Statement activity_get(
db_.GetUniqueStatement("SELECT publisher_id FROM activity_info WHERE "
"publisher_id=? AND category=? "
"AND month=? AND year=? AND reconcile_stamp=?"));
"publisher_id=? AND month=? "
"AND year=? AND reconcile_stamp=?"));

activity_get.BindString(0, info.id);
activity_get.BindInt(1, info.category);
activity_get.BindInt(2, info.month);
activity_get.BindInt(3, info.year);
activity_get.BindInt64(4, info.reconcile_stamp);
activity_get.BindInt(1, info.month);
activity_get.BindInt(2, info.year);
activity_get.BindInt64(3, info.reconcile_stamp);

if (activity_get.Step()) {
sql::Statement activity_info_update(
GetDB().GetCachedStatement(SQL_FROM_HERE,
"UPDATE activity_info SET "
"duration=?, score=?, percent=?, "
"weight=? WHERE "
"publisher_id=? AND category=? "
"AND month=? AND year=? AND reconcile_stamp=?"));
"publisher_id=? AND month=? "
"AND year=? AND reconcile_stamp=?"));

activity_info_update.BindInt64(0, (int)info.duration);
activity_info_update.BindDouble(1, info.score);
activity_info_update.BindInt64(2, (int)info.percent);
activity_info_update.BindDouble(3, info.weight);
activity_info_update.BindString(4, info.id);
activity_info_update.BindInt(5, info.category);
activity_info_update.BindInt(6, info.month);
activity_info_update.BindInt(7, info.year);
activity_info_update.BindInt64(8, info.reconcile_stamp);
activity_info_update.BindInt(5, info.month);
activity_info_update.BindInt(6, info.year);
activity_info_update.BindInt64(7, info.reconcile_stamp);

return activity_info_update.Run();
}
Expand All @@ -298,18 +296,17 @@ bool PublisherInfoDatabase::InsertOrUpdatePublisherInfo(
GetDB().GetCachedStatement(SQL_FROM_HERE,
"INSERT INTO activity_info "
"(publisher_id, duration, score, percent, "
"weight, category, month, year, reconcile_stamp) "
"weight, month, year, reconcile_stamp) "
"VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)"));

activity_info_insert.BindString(0, info.id);
activity_info_insert.BindInt64(1, (int)info.duration);
activity_info_insert.BindDouble(2, info.score);
activity_info_insert.BindInt64(3, (int)info.percent);
activity_info_insert.BindDouble(4, info.weight);
activity_info_insert.BindInt(5, info.category);
activity_info_insert.BindInt(6, info.month);
activity_info_insert.BindInt(7, info.year);
activity_info_insert.BindInt64(8, info.reconcile_stamp);
activity_info_insert.BindInt(5, info.month);
activity_info_insert.BindInt(6, info.year);
activity_info_insert.BindInt64(7, info.reconcile_stamp);

return activity_info_insert.Run();
}
Expand Down Expand Up @@ -384,7 +381,7 @@ bool PublisherInfoDatabase::Find(int start,
return false;

std::string query = "SELECT ai.publisher_id, ai.duration, ai.score, ai.percent, "
"ai.weight, pi.verified, pi.excluded, ai.category, ai.month, ai.year, pi.name, "
"ai.weight, pi.verified, pi.excluded, ai.month, ai.year, pi.name, "
"pi.url, pi.provider, pi.favIcon, ai.reconcile_stamp "
"FROM activity_info AS ai "
"INNER JOIN publisher_info AS pi ON ai.publisher_id = pi.publisher_id "
Expand All @@ -399,8 +396,8 @@ bool PublisherInfoDatabase::Find(int start,
while (info_sql.Step()) {
std::string id(info_sql.ColumnString(0));
ledger::PUBLISHER_MONTH month(
static_cast<ledger::PUBLISHER_MONTH>(info_sql.ColumnInt(8)));
int year(info_sql.ColumnInt(9));
static_cast<ledger::PUBLISHER_MONTH>(info_sql.ColumnInt(7)));
int year(info_sql.ColumnInt(8));

ledger::PublisherInfo info(id, month, year);
info.duration = info_sql.ColumnInt64(1);
Expand All @@ -409,15 +406,13 @@ bool PublisherInfoDatabase::Find(int start,
info.percent = info_sql.ColumnInt64(3);
info.weight = info_sql.ColumnDouble(4);
info.verified = info_sql.ColumnBool(5);
info.name = info_sql.ColumnString(10);
info.url = info_sql.ColumnString(11);
info.provider = info_sql.ColumnString(12);
info.favicon_url = info_sql.ColumnString(13);
info.reconcile_stamp = info_sql.ColumnInt64(14);
info.name = info_sql.ColumnString(9);
info.url = info_sql.ColumnString(10);
info.provider = info_sql.ColumnString(11);
info.favicon_url = info_sql.ColumnString(12);
info.reconcile_stamp = info_sql.ColumnInt64(13);

info.excluded = static_cast<ledger::PUBLISHER_EXCLUDE>(info_sql.ColumnInt(6));
info.category =
static_cast<ledger::PUBLISHER_CATEGORY>(info_sql.ColumnInt(7));

list->push_back(info);
}
Expand Down Expand Up @@ -459,9 +454,6 @@ std::string PublisherInfoDatabase::BuildClauses(int start,
if (!filter.id.empty())
clauses += " AND ai.publisher_id = ?";

if (filter.category != ledger::PUBLISHER_CATEGORY::ALL_CATEGORIES)
clauses += " AND ai.category = ?";

if (filter.month != ledger::PUBLISHER_MONTH::ANY)
clauses += " AND ai.month = ?";

Expand Down Expand Up @@ -513,9 +505,6 @@ void PublisherInfoDatabase::BindFilter(sql::Statement& statement,
if (!filter.id.empty())
statement.BindString(column++, filter.id);

if (filter.category != ledger::PUBLISHER_CATEGORY::ALL_CATEGORIES)
statement.BindInt(column++, filter.category);

if (filter.month != ledger::PUBLISHER_MONTH::ANY)
statement.BindInt(column++, filter.month);

Expand Down Expand Up @@ -762,6 +751,49 @@ bool PublisherInfoDatabase::MigrateV1toV2() {
return CreateRecurringDonationIndex();
}

bool PublisherInfoDatabase::MigrateV2toV3() {
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);

// Activity info
const char* activity = "activity_info";
if (GetDB().DoesTableExist(activity)) {
std::string sql = "ALTER TABLE activity_info RENAME TO activity_info_old;";

if (!GetDB().Execute(sql.c_str())) {
return false;
}

if (!CreateActivityInfoTable()) {
return false;
}

if (!CreateActivityInfoIndex()) {
return false;
}

std::string columns = "publisher_id, "
"duration, "
"score, "
"percent, "
"weight, "
"month, "
"year, "
"reconcile_stamp";

sql = "PRAGMA foreign_keys=off;";
sql.append("INSERT INTO activity_info (" + columns + ") "
"SELECT " + columns + " "
"FROM activity_info_old;");
sql.append("UPDATE activity_info SET visits=5;");
sql.append("DROP TABLE activity_info_old;");
sql.append("PRAGMA foreign_keys=on;");

return GetDB().Execute(sql.c_str());
}

return false;
}

sql::InitStatus PublisherInfoDatabase::EnsureCurrentVersion() {
DCHECK_CALLED_ON_VALID_SEQUENCE(sequence_checker_);

Expand All @@ -774,10 +806,32 @@ sql::InitStatus PublisherInfoDatabase::EnsureCurrentVersion() {
const int old_version = meta_table_.GetVersionNumber();
const int cur_version = GetCurrentVersion();

// Migration from version 1 to version 2
if (old_version == 1 && cur_version == 2) {
if (!MigrateV1toV2()) {
LOG(ERROR) << "DB: Error with MigrateV1toV2";
// Migration from version 1
if (old_version == 1) {
// to version 2
if (cur_version < 3) {
if (!MigrateV1toV2()) {
LOG(ERROR) << "DB: Error with MigrateV1toV2";
}
}

// to version 3
if (cur_version < 4) {
if (!MigrateV2toV3()) {
LOG(ERROR) << "DB: Error with MigrateV2toV3";
}
}

meta_table_.SetVersionNumber(cur_version);
}

// Migration from version 2
if (old_version == 2) {
// to version 3
if (cur_version < 4) {
if (!MigrateV2toV3()) {
LOG(ERROR) << "DB: Error with MigrateV2toV3";
}
}

meta_table_.SetVersionNumber(cur_version);
Expand Down
1 change: 1 addition & 0 deletions components/brave_rewards/browser/publisher_info_database.h
Original file line number Diff line number Diff line change
Expand Up @@ -84,6 +84,7 @@ class PublisherInfoDatabase {

sql::InitStatus EnsureCurrentVersion();
bool MigrateV1toV2();
bool MigrateV2toV3();

sql::Database db_;
sql::MetaTable meta_table_;
Expand Down

0 comments on commit 7229bbb

Please sign in to comment.