Index: chrome/browser/offline_pages/offline_page_metadata_store_impl.cc |
diff --git a/chrome/browser/offline_pages/offline_page_metadata_store_impl.cc b/chrome/browser/offline_pages/offline_page_metadata_store_impl.cc |
deleted file mode 100644 |
index a6b929c6d1b8d5d713bb4e3f744e5cc62353f4d7..0000000000000000000000000000000000000000 |
--- a/chrome/browser/offline_pages/offline_page_metadata_store_impl.cc |
+++ /dev/null |
@@ -1,211 +0,0 @@ |
-// Copyright 2015 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 "chrome/browser/offline_pages/offline_page_metadata_store_impl.h" |
- |
-#include "base/bind.h" |
-#include "base/files/file_path.h" |
-#include "base/location.h" |
-#include "base/message_loop/message_loop.h" |
-#include "base/sequenced_task_runner.h" |
-#include "base/strings/utf_string_conversions.h" |
-#include "base/thread_task_runner_handle.h" |
-#include "chrome/browser/offline_pages/offline_pages.pb.h" |
-#include "components/leveldb_proto/proto_database.h" |
-#include "components/offline_pages/offline_page_item.h" |
-#include "third_party/leveldatabase/env_chromium.h" |
-#include "third_party/leveldatabase/src/include/leveldb/db.h" |
-#include "url/gurl.h" |
- |
-using leveldb_proto::ProtoDatabase; |
- |
-namespace offline_pages { |
-namespace { |
- |
-typedef std::vector<OfflinePageEntry> OfflinePageEntryVector; |
- |
-void OfflinePageItemToEntry(const OfflinePageItem& item, |
- offline_pages::OfflinePageEntry* item_proto) { |
- DCHECK(item_proto); |
- item_proto->set_url(item.url.spec()); |
- item_proto->set_title(base::UTF16ToUTF8(item.title)); |
- item_proto->set_version(item.version); |
- std::string path_string; |
-#if defined(OS_POSIX) |
- path_string = item.file_path.value(); |
-#elif defined(OS_WIN) |
- path_string = base::WideToUTF8(item.file_path.value()); |
-#endif |
- item_proto->set_file_path(path_string); |
- item_proto->set_file_size(item.file_size); |
- item_proto->set_creation_time(item.creation_time.ToInternalValue()); |
- item_proto->set_last_access_time(item.last_access_time.ToInternalValue()); |
-} |
- |
-bool OfflinePageItemFromEntry(const offline_pages::OfflinePageEntry& item_proto, |
- OfflinePageItem* item) { |
- DCHECK(item); |
- if (!item_proto.has_url() || !item_proto.has_title() || |
- !item_proto.has_version() || !item_proto.has_file_path()) { |
- return false; |
- } |
- item->url = GURL(item_proto.url()); |
- item->title = base::UTF8ToUTF16(item_proto.title()); |
- item->version = item_proto.version(); |
-#if defined(OS_POSIX) |
- item->file_path = base::FilePath(item_proto.file_path()); |
-#elif defined(OS_WIN) |
- item->file_path = base::FilePath(base::UTF8ToWide(item_proto.file_path())); |
-#endif |
- if (item_proto.has_file_size()) { |
- item->file_size = item_proto.file_size(); |
- } |
- if (item_proto.has_creation_time()) { |
- item->creation_time = |
- base::Time::FromInternalValue(item_proto.creation_time()); |
- } |
- if (item_proto.has_last_access_time()) { |
- item->last_access_time = |
- base::Time::FromInternalValue(item_proto.last_access_time()); |
- } |
- return true; |
-} |
- |
-void OnLoadDone(const OfflinePageMetadataStore::LoadCallback& callback, |
- const base::Callback<void()>& failure_callback, |
- bool success, |
- scoped_ptr<OfflinePageEntryVector> entries) { |
- if (!success) { |
- // TODO(fgorski): Add UMA for this case. |
- DVLOG(1) << "Offline pages database load failed."; |
- failure_callback.Run(); |
- base::MessageLoop::current()->PostTask( |
- FROM_HERE, base::Bind(callback, false, std::vector<OfflinePageItem>())); |
- return; |
- } |
- |
- std::vector<OfflinePageItem> result; |
- for (OfflinePageEntryVector::iterator it = entries->begin(); |
- it != entries->end(); ++it) { |
- OfflinePageItem item; |
- if (OfflinePageItemFromEntry(*it, &item)) |
- result.push_back(item); |
- else |
- DVLOG(1) << "Failed to create offline page item from proto."; |
- } |
- |
- base::MessageLoop::current()->PostTask(FROM_HERE, |
- base::Bind(callback, true, result)); |
-} |
- |
-void OnUpdateDone(const OfflinePageMetadataStore::UpdateCallback& callback, |
- const base::Callback<void()>& failure_callback, |
- bool success) { |
- if (!success) { |
- // TODO(fgorski): Add UMA for this case. |
- DVLOG(1) << "Offline pages database update failed."; |
- failure_callback.Run(); |
- } |
- |
- base::MessageLoop::current()->PostTask(FROM_HERE, |
- base::Bind(callback, success)); |
-} |
- |
-} // namespace |
- |
-OfflinePageMetadataStoreImpl::OfflinePageMetadataStoreImpl( |
- scoped_ptr<ProtoDatabase<OfflinePageEntry>> database, |
- const base::FilePath& database_dir) |
- : database_(database.Pass()), weak_ptr_factory_(this) { |
- database_->Init(database_dir, |
- base::Bind(&OfflinePageMetadataStoreImpl::OnInitDone, |
- weak_ptr_factory_.GetWeakPtr())); |
-} |
- |
-OfflinePageMetadataStoreImpl::~OfflinePageMetadataStoreImpl() { |
-} |
- |
-void OfflinePageMetadataStoreImpl::OnInitDone(bool success) { |
- if (!success) { |
- // TODO(fgorski): Add UMA for this case. |
- DVLOG(1) << "Offline pages database init failed."; |
- ResetDB(); |
- return; |
- } |
-} |
- |
-void OfflinePageMetadataStoreImpl::Load(const LoadCallback& callback) { |
- if (!database_.get()) { |
- // Failing fast here, because DB is not initialized, and there is nothing |
- // that can be done about it. |
- // Callback is invoked through message loop to avoid improper retry and |
- // simplify testing. |
- DVLOG(1) << "Offline pages database not available in Load."; |
- base::MessageLoop::current()->PostTask( |
- FROM_HERE, base::Bind(callback, false, std::vector<OfflinePageItem>())); |
- return; |
- } |
- |
- database_->LoadEntries(base::Bind( |
- &OnLoadDone, callback, base::Bind(&OfflinePageMetadataStoreImpl::ResetDB, |
- weak_ptr_factory_.GetWeakPtr()))); |
-} |
- |
-void OfflinePageMetadataStoreImpl::AddOfflinePage( |
- const OfflinePageItem& offline_page_item, |
- const UpdateCallback& callback) { |
- scoped_ptr<ProtoDatabase<OfflinePageEntry>::KeyEntryVector> entries_to_save( |
- new ProtoDatabase<OfflinePageEntry>::KeyEntryVector()); |
- scoped_ptr<std::vector<std::string>> keys_to_remove( |
- new std::vector<std::string>()); |
- |
- OfflinePageEntry offline_page_proto; |
- OfflinePageItemToEntry(offline_page_item, &offline_page_proto); |
- entries_to_save->push_back( |
- std::make_pair(offline_page_proto.url(), offline_page_proto)); |
- |
- UpdateEntries(entries_to_save.Pass(), keys_to_remove.Pass(), callback); |
-} |
- |
-void OfflinePageMetadataStoreImpl::RemoveOfflinePage( |
- const GURL& page_url, |
- const UpdateCallback& callback) { |
- scoped_ptr<ProtoDatabase<OfflinePageEntry>::KeyEntryVector> entries_to_save( |
- new ProtoDatabase<OfflinePageEntry>::KeyEntryVector()); |
- scoped_ptr<std::vector<std::string>> keys_to_remove( |
- new std::vector<std::string>()); |
- |
- keys_to_remove->push_back(page_url.spec()); |
- |
- UpdateEntries(entries_to_save.Pass(), keys_to_remove.Pass(), callback); |
-} |
- |
-void OfflinePageMetadataStoreImpl::UpdateEntries( |
- scoped_ptr<ProtoDatabase<OfflinePageEntry>::KeyEntryVector> entries_to_save, |
- scoped_ptr<std::vector<std::string>> keys_to_remove, |
- const UpdateCallback& callback) { |
- if (!database_.get()) { |
- // Failing fast here, because DB is not initialized, and there is nothing |
- // that can be done about it. |
- // Callback is invoked through message loop to avoid improper retry and |
- // simplify testing. |
- DVLOG(1) << "Offline pages database not available in UpdateEntries."; |
- base::MessageLoop::current()->PostTask(FROM_HERE, |
- base::Bind(callback, false)); |
- return; |
- } |
- |
- database_->UpdateEntries( |
- entries_to_save.Pass(), keys_to_remove.Pass(), |
- base::Bind(&OnUpdateDone, callback, |
- base::Bind(&OfflinePageMetadataStoreImpl::ResetDB, |
- weak_ptr_factory_.GetWeakPtr()))); |
-} |
- |
-void OfflinePageMetadataStoreImpl::ResetDB() { |
- database_.reset(); |
- weak_ptr_factory_.InvalidateWeakPtrs(); |
-} |
- |
-} // namespace offline_pages |