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

Unified Diff: chrome/browser/sync_file_system/drive_file_sync_service.cc

Issue 15023022: Add to be fetched files instead of DriveMetadataStore.batch_sync_origins_ (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: tzik review #4 Created 7 years, 7 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: chrome/browser/sync_file_system/drive_file_sync_service.cc
diff --git a/chrome/browser/sync_file_system/drive_file_sync_service.cc b/chrome/browser/sync_file_system/drive_file_sync_service.cc
index 3e25e35f9c13ce1610b772a1ce98e4867bc61ad3..6e0ec914641149a763d2348eb2c94fc457bcacd9 100644
--- a/chrome/browser/sync_file_system/drive_file_sync_service.cc
+++ b/chrome/browser/sync_file_system/drive_file_sync_service.cc
@@ -380,21 +380,24 @@ void DriveFileSyncService::DidInitializeMetadataStore(
return;
}
+ // Guarantee that metadata_store_->batch_sync_origins is not used.
+ std::vector<GURL> batch_origins_to_delete;
+ typedef std::map<GURL, std::string>::const_iterator origin_itr;
+ for (origin_itr itr = metadata_store_->batch_sync_origins().begin();
+ itr != metadata_store_->batch_sync_origins().end(); ++itr) {
+ batch_origins_to_delete.push_back(itr->first);
+ }
+ for (std::vector<GURL>::const_iterator itr = batch_origins_to_delete.begin();
+ itr != batch_origins_to_delete.end(); ++itr) {
+ metadata_store_->RemoveOrigin(*itr, base::Bind(&EmptyStatusCallback));
+ }
+
DCHECK(pending_batch_sync_origins_.empty());
UpdateRegisteredOrigins();
largest_fetched_changestamp_ = metadata_store_->GetLargestChangeStamp();
- // Mark all the batch sync origins as 'pending' so that we can start
- // batch sync when we're ready.
- for (std::map<GURL, std::string>::const_iterator itr =
- metadata_store_->batch_sync_origins().begin();
- itr != metadata_store_->batch_sync_origins().end();
- ++itr) {
- pending_batch_sync_origins_.insert(itr->first);
- }
-
DriveMetadataStore::URLAndDriveMetadataList to_be_fetched_files;
status = metadata_store_->GetToBeFetchedFiles(&to_be_fetched_files);
DCHECK_EQ(SYNC_STATUS_OK, status);
@@ -408,6 +411,10 @@ void DriveFileSyncService::DidInitializeMetadataStore(
SyncFileType file_type = SYNC_FILE_TYPE_FILE;
if (metadata.type() == DriveMetadata::RESOURCE_TYPE_FOLDER)
file_type = SYNC_FILE_TYPE_DIRECTORY;
+ if (!metadata_store_->IsIncrementalSyncOrigin(url.origin())) {
+ metadata_store_->DeleteEntry(url, base::Bind(&EmptyStatusCallback));
+ continue;
+ }
AppendFetchChange(url.origin(), url.path(), resource_id, file_type);
}
@@ -510,7 +517,8 @@ void DriveFileSyncService::DoEnableOriginForTrackingChanges(
}
metadata_store_->EnableOrigin(origin, callback);
- pending_batch_sync_origins_.insert(origin);
+ pending_batch_sync_origins_.insert(
+ *metadata_store_->disabled_origins().find(origin));
}
void DriveFileSyncService::DoDisableOriginForTrackingChanges(
@@ -530,7 +538,15 @@ void DriveFileSyncService::DoDisableOriginForTrackingChanges(
void DriveFileSyncService::DoUninstallOrigin(
const GURL& origin,
const SyncStatusCallback& callback) {
+ // Because origin management is now split between DriveFileSyncService and
+ // DriveMetadataStore, it must be checked for in two places.
std::string resource_id = metadata_store_->GetResourceIdForOrigin(origin);
+ if (resource_id.empty()) {
+ std::map<GURL, std::string>::const_iterator iterator =
+ pending_batch_sync_origins_.find(origin);
+ if (iterator != pending_batch_sync_origins_.end())
+ resource_id = iterator->second;
+ }
// An empty resource_id indicates either one of following two cases:
// 1) origin is not in metadata_store_ because the extension was never
@@ -621,27 +637,47 @@ void DriveFileSyncService::UpdateRegisteredOrigins() {
if (!extension_service)
return;
+ // Must combine batch sync origins with incremental and disabled origins since
+ // batch origins are tracked in DriveFileSyncService but the others are in
+ // DriveMetaDataStore.
std::vector<GURL> origins;
metadata_store_->GetAllOrigins(&origins);
+ typedef std::map<GURL, std::string>::const_iterator iterator;
+ for (iterator itr = pending_batch_sync_origins_.begin();
+ itr != pending_batch_sync_origins_.end(); ++itr) {
+ DCHECK(!metadata_store_->IsKnownOrigin(itr->first));
+ origins.push_back(itr->first);
+ }
kinuko 2013/05/20 15:31:50 We seem to be checking pending_batch_sync_origins_
calvinlo 2013/05/21 07:12:26 Thanks for catching this. I have removed the error
+
+ // Update the status of every origin using status from ExtensionService.
for (std::vector<GURL>::const_iterator itr = origins.begin();
itr != origins.end(); ++itr) {
std::string extension_id = itr->host();
GURL origin =
extensions::Extension::GetBaseURLFromExtensionId(extension_id);
+ bool is_pending_batch_sync_origin = (pending_batch_sync_origins_.find(
+ origin) != pending_batch_sync_origins_.end());
if (!extension_service->GetInstalledExtension(extension_id)) {
// Extension has been uninstalled.
+ pending_batch_sync_origins_.erase(origin);
+ UninstallOrigin(origin, base::Bind(&EmptyStatusCallback));
+ } else if ((is_pending_batch_sync_origin ||
+ metadata_store_->IsBatchSyncOrigin(origin)) &&
kinuko 2013/05/20 15:31:50 IsBatchSyncOrigin(origin) is always false, right?
calvinlo 2013/05/21 07:12:26 I have added DCHECKS at the beginning to ensure th
+ !extension_service->IsExtensionEnabled(extension_id)) {
+ // pending batch sync origin has been disabled
+ pending_batch_sync_origins_.erase(origin);
UninstallOrigin(origin, base::Bind(&EmptyStatusCallback));
- } else if ((metadata_store_->IsBatchSyncOrigin(origin) ||
- metadata_store_->IsIncrementalSyncOrigin(origin)) &&
+ } else if (metadata_store_->IsIncrementalSyncOrigin(origin) &&
!extension_service->IsExtensionEnabled(extension_id)) {
- // Extension has been disabled.
+ // Incremental Extension has been disabled.
metadata_store_->DisableOrigin(origin, base::Bind(&EmptyStatusCallback));
} else if (metadata_store_->IsOriginDisabled(origin) &&
extension_service->IsExtensionEnabled(extension_id)) {
// Extension has been re-enabled.
+ pending_batch_sync_origins_.insert(
+ *metadata_store_->disabled_origins().find(origin));
metadata_store_->EnableOrigin(origin, base::Bind(&EmptyStatusCallback));
- pending_batch_sync_origins_.insert(origin);
}
}
}
@@ -649,16 +685,12 @@ void DriveFileSyncService::UpdateRegisteredOrigins() {
void DriveFileSyncService::StartBatchSync(
const SyncStatusCallback& callback) {
DCHECK(GetCurrentState() == REMOTE_SERVICE_OK || may_have_unfetched_changes_);
+ DCHECK(!pending_batch_sync_origins_.empty());
- if (pending_batch_sync_origins_.empty()) {
- callback.Run(SYNC_STATUS_OK);
- return;
- }
-
- GURL origin = *pending_batch_sync_origins_.begin();
- pending_batch_sync_origins_.erase(pending_batch_sync_origins_.begin());
- std::string resource_id = metadata_store_->GetResourceIdForOrigin(origin);
+ GURL origin = pending_batch_sync_origins_.begin()->first;
+ std::string resource_id = pending_batch_sync_origins_.begin()->second;
DCHECK(!resource_id.empty());
+ pending_batch_sync_origins_.erase(pending_batch_sync_origins_.begin());
DCHECK(!metadata_store_->IsOriginDisabled(origin));
@@ -696,9 +728,10 @@ void DriveFileSyncService::DidGetDriveDirectoryForOrigin(
}
// Add this origin to batch sync origin if it hasn't been already.
+ // TODO(calvinlo): Added files to file metadata mapping, this can be removed
+ // next when batch_sync_origins is removed from DriveMetadataStore.
if (!metadata_store_->IsKnownOrigin(origin)) {
- metadata_store_->AddBatchSyncOrigin(origin, resource_id);
- pending_batch_sync_origins_.insert(origin);
+ pending_batch_sync_origins_.insert(std::make_pair(origin, resource_id));
}
kinuko 2013/05/20 15:31:50 nit: no { } for one-line body
calvinlo 2013/05/21 07:12:26 Done.
callback.Run(SYNC_STATUS_OK);
@@ -726,7 +759,7 @@ void DriveFileSyncService::DidGetLargestChangeStampForBatchSync(
google_apis::GDataErrorCode error,
int64 largest_changestamp) {
if (error != google_apis::HTTP_SUCCESS) {
- pending_batch_sync_origins_.insert(origin);
+ pending_batch_sync_origins_.insert(std::make_pair(origin, resource_id));
callback.Run(GDataErrorCodeToSyncStatusCodeWrapper(error));
return;
}
@@ -744,17 +777,19 @@ void DriveFileSyncService::DidGetLargestChangeStampForBatchSync(
AsWeakPtr(),
callback,
origin,
+ resource_id,
largest_changestamp));
}
void DriveFileSyncService::DidGetDirectoryContentForBatchSync(
const SyncStatusCallback& callback,
const GURL& origin,
+ const std::string& resource_id,
int64 largest_changestamp,
google_apis::GDataErrorCode error,
scoped_ptr<google_apis::ResourceList> feed) {
if (error != google_apis::HTTP_SUCCESS) {
- pending_batch_sync_origins_.insert(origin);
+ pending_batch_sync_origins_.insert(std::make_pair(origin, resource_id));
callback.Run(GDataErrorCodeToSyncStatusCodeWrapper(error));
return;
}
@@ -762,8 +797,25 @@ void DriveFileSyncService::DidGetDirectoryContentForBatchSync(
typedef ScopedVector<google_apis::ResourceEntry>::const_iterator iterator;
for (iterator itr = feed->entries().begin();
itr != feed->entries().end(); ++itr) {
- AppendRemoteChange(origin, **itr, largest_changestamp,
+ const google_apis::ResourceEntry& entry = **itr;
+ AppendRemoteChange(origin, entry, largest_changestamp,
RemoteChangeHandler::REMOTE_SYNC_TYPE_BATCH);
+
+ // Save to be fetched file to DB for restore in case of crash.
+ DriveMetadata metadata;
+ metadata.set_resource_id(entry.resource_id());
+ metadata.set_md5_checksum(entry.file_md5());
+ metadata.set_conflicted(false);
+ metadata.set_to_be_fetched(true);
+
+ base::FilePath path = TitleToPath(entry.title());
+ fileapi::FileSystemURL url(CreateSyncableFileSystemURL(
+ origin, kServiceName, path));
+ // TODO(calvinlo): Write metadata and origin data as single batch command
+ // so it's not possible for the DB to contain a DriveMetadata with an
+ // unknown origin.
+ metadata_store_->UpdateEntry(url, metadata,
+ base::Bind(&EmptyStatusCallback));
}
GURL next_feed_url;
@@ -774,16 +826,15 @@ void DriveFileSyncService::DidGetDirectoryContentForBatchSync(
AsWeakPtr(),
callback,
origin,
+ resource_id,
largest_changestamp));
return;
}
- // Move |origin| to the incremental sync origin set if the origin has no file.
- if (metadata_store_->IsBatchSyncOrigin(origin) &&
- !remote_change_handler_.HasChangesForOrigin(origin)) {
- metadata_store_->MoveBatchSyncOriginToIncremental(origin);
- }
-
+ // TODO(calvinlo): Eliminate batch_sync_origins so
+ // MoveBatchSyncOriginToIncremental() happens directly.
+ metadata_store_->AddBatchSyncOrigin(origin, resource_id);
+ metadata_store_->MoveBatchSyncOriginToIncremental(origin);
may_have_unfetched_changes_ = true;
callback.Run(SYNC_STATUS_OK);
}
@@ -1709,7 +1760,7 @@ void DriveFileSyncService::DidEnsureOriginRoot(
metadata_store_->IsKnownOrigin(origin)) {
metadata_store_->SetOriginRootDirectory(origin, resource_id);
if (metadata_store_->IsBatchSyncOrigin(origin))
- pending_batch_sync_origins_.insert(origin);
+ pending_batch_sync_origins_.insert(std::make_pair(origin, resource_id));
kinuko 2013/05/20 15:31:50 These 2 lines are not needed anymore?
calvinlo 2013/05/21 07:12:26 Done.
}
callback.Run(status, resource_id);
}

Powered by Google App Engine
This is Rietveld 408576698