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 967d83349bdd2e849f5d185176bb40e86ec16f07..bf9e96c63518e899b483077594c11db8cc75ddab 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,25 @@ void DriveFileSyncService::DidInitializeMetadataStore( |
return; |
} |
+ // TODO(calvinlo): Move the code to delete legacy batch_sync_origin keys from |
+ // DB into DriveMetadataStore.InitializeDBOnFileThread. |
+ 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 +412,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,27 +518,35 @@ 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( |
const GURL& origin, |
const SyncStatusCallback& callback) { |
- if (!metadata_store_->IsBatchSyncOrigin(origin) && |
- !metadata_store_->IsIncrementalSyncOrigin(origin)) { |
+ pending_batch_sync_origins_.erase(origin); |
+ if (!metadata_store_->IsIncrementalSyncOrigin(origin)) { |
callback.Run(SYNC_STATUS_OK); |
return; |
} |
remote_change_handler_.RemoveChangesForOrigin(origin); |
- pending_batch_sync_origins_.erase(origin); |
metadata_store_->DisableOrigin(origin, callback); |
} |
void DriveFileSyncService::DoUninstallOrigin( |
const GURL& origin, |
const SyncStatusCallback& callback) { |
+ // Because origin management is now split between DriveFileSyncService and |
+ // DriveMetadataStore, resource_id 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 |
@@ -618,11 +634,15 @@ void DriveFileSyncService::DoApplyLocalChange( |
void DriveFileSyncService::UpdateRegisteredOrigins() { |
ExtensionService* extension_service = |
extensions::ExtensionSystem::Get(profile_)->extension_service(); |
+ DCHECK(pending_batch_sync_origins_.empty()); |
+ DCHECK(metadata_store_->batch_sync_origins().empty()); |
if (!extension_service) |
return; |
std::vector<GURL> origins; |
metadata_store_->GetAllOrigins(&origins); |
+ |
+ // 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(); |
@@ -632,16 +652,16 @@ void DriveFileSyncService::UpdateRegisteredOrigins() { |
if (!extension_service->GetInstalledExtension(extension_id)) { |
// Extension has been uninstalled. |
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 +669,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)); |
@@ -695,11 +711,8 @@ void DriveFileSyncService::DidGetDriveDirectoryForOrigin( |
return; |
} |
- // Add this origin to batch sync origin if it hasn't been already. |
- if (!metadata_store_->IsKnownOrigin(origin)) { |
- metadata_store_->AddBatchSyncOrigin(origin, resource_id); |
- pending_batch_sync_origins_.insert(origin); |
- } |
+ if (!metadata_store_->IsKnownOrigin(origin)) |
+ pending_batch_sync_origins_.insert(std::make_pair(origin, resource_id)); |
callback.Run(SYNC_STATUS_OK); |
} |
@@ -726,7 +739,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 +757,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 +777,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 +806,12 @@ 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); |
- } |
- |
+ metadata_store_->AddIncrementalSyncOrigin(origin, resource_id); |
may_have_unfetched_changes_ = true; |
callback.Run(SYNC_STATUS_OK); |
} |
@@ -1366,12 +1394,7 @@ bool DriveFileSyncService::AppendRemoteChangeInternal( |
void DriveFileSyncService::RemoveRemoteChange( |
const FileSystemURL& url) { |
- if (!remote_change_handler_.RemoveChangeForURL(url)) |
- return; |
- if (metadata_store_->IsBatchSyncOrigin(url.origin()) && |
- !remote_change_handler_.HasChangesForOrigin(url.origin())) { |
- metadata_store_->MoveBatchSyncOriginToIncremental(url.origin()); |
- } |
+ remote_change_handler_.RemoveChangeForURL(url); |
} |
void DriveFileSyncService::MarkConflict( |
@@ -1708,8 +1731,6 @@ void DriveFileSyncService::DidEnsureOriginRoot( |
if (status == SYNC_STATUS_OK && |
metadata_store_->IsKnownOrigin(origin)) { |
metadata_store_->SetOriginRootDirectory(origin, resource_id); |
- if (metadata_store_->IsBatchSyncOrigin(origin)) |
- pending_batch_sync_origins_.insert(origin); |
} |
callback.Run(status, resource_id); |
} |