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

Unified Diff: components/offline_pages/background/request_queue_store_sql.cc

Issue 2410903003: [Offline pages] Adding capability to query a subset of requests based on IDs (Closed)
Patch Set: Addressing remaining feedback Created 4 years, 2 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/offline_pages/background/request_queue_store_sql.cc
diff --git a/components/offline_pages/background/request_queue_store_sql.cc b/components/offline_pages/background/request_queue_store_sql.cc
index f88872be361b2960580f1682d6668b23844ade69..b008ed33141baa5df5742c5f733adf80a979f99b 100644
--- a/components/offline_pages/background/request_queue_store_sql.cc
+++ b/components/offline_pages/background/request_queue_store_sql.cc
@@ -4,6 +4,8 @@
#include "components/offline_pages/background/request_queue_store_sql.h"
+#include <unordered_set>
+
#include "base/bind.h"
#include "base/files/file_path.h"
#include "base/files/file_util.h"
@@ -22,7 +24,6 @@ template class StoreUpdateResult<SavePageRequest>;
namespace {
-using UpdateStatus = RequestQueueStore::UpdateStatus;
using StoreStateCallback = base::Callback<void(StoreState)>;
// This is a macro instead of a const so that
@@ -109,8 +110,9 @@ std::unique_ptr<SavePageRequest> GetOneRequest(sql::Connection* db,
sql::Statement statement(db->GetCachedStatement(SQL_FROM_HERE, kSql));
statement.BindInt64(0, request_id);
- statement.Run();
- return MakeSavePageRequest(statement);
+ if (statement.Step())
+ return MakeSavePageRequest(statement);
+ return std::unique_ptr<SavePageRequest>(nullptr);
}
ItemActionStatus DeleteRequestById(sql::Connection* db, int64_t request_id) {
@@ -247,6 +249,44 @@ void GetRequestsSync(sql::Connection* db,
base::Passed(&requests)));
}
+void GetRequestsByIdsSync(sql::Connection* db,
+ scoped_refptr<base::SingleThreadTaskRunner> runner,
+ const std::vector<int64_t>& request_ids,
+ const RequestQueueStore::UpdateCallback& callback) {
+ // TODO(fgorski): Perhaps add metrics here.
+ std::unique_ptr<UpdateRequestsResult> result(
+ new UpdateRequestsResult(StoreState::LOADED));
+
+ // If you create a transaction but don't Commit() it is automatically
+ // rolled back by its destructor when it falls out of scope.
+ sql::Transaction transaction(db);
+ if (!transaction.Begin()) {
+ PostStoreErrorForAllIds(runner, request_ids, callback);
+ return;
+ }
+
+ // Make sure not to include the same request multiple times, preserving the
+ // order of non-duplicated IDs in the result.
+ std::unordered_set<int64_t> processed_ids;
+ for (int64_t request_id : request_ids) {
+ if (!processed_ids.insert(request_id).second)
+ continue;
+ std::unique_ptr<SavePageRequest> request = GetOneRequest(db, request_id);
+ if (request.get())
+ result->updated_items.push_back(*request);
+ ItemActionStatus status =
+ request.get() ? ItemActionStatus::SUCCESS : ItemActionStatus::NOT_FOUND;
+ result->item_statuses.push_back(std::make_pair(request_id, status));
+ }
+
+ if (!transaction.Commit()) {
+ PostStoreErrorForAllIds(runner, request_ids, callback);
+ return;
+ }
+
+ runner->PostTask(FROM_HERE, base::Bind(callback, base::Passed(&result)));
+}
+
void AddRequestSync(sql::Connection* db,
scoped_refptr<base::SingleThreadTaskRunner> runner,
const SavePageRequest& request,
@@ -385,6 +425,21 @@ void RequestQueueStoreSQL::GetRequests(const GetRequestsCallback& callback) {
base::ThreadTaskRunnerHandle::Get(), callback));
}
+void RequestQueueStoreSQL::GetRequestsByIds(
+ const std::vector<int64_t>& request_ids,
+ const UpdateCallback& callback) {
+ if (!db_.get()) {
+ PostStoreErrorForAllIds(base::ThreadTaskRunnerHandle::Get(), request_ids,
+ callback);
+ return;
+ }
+
+ background_task_runner_->PostTask(
+ FROM_HERE,
+ base::Bind(&GetRequestsByIdsSync, db_.get(),
+ base::ThreadTaskRunnerHandle::Get(), request_ids, callback));
+}
+
void RequestQueueStoreSQL::AddRequest(const SavePageRequest& request,
const AddCallback& callback) {
if (!CheckDb(base::Bind(callback, ItemActionStatus::STORE_ERROR)))

Powered by Google App Engine
This is Rietveld 408576698