| Index: chrome/browser/chromeos/drive/sync/remove_performer.cc
|
| diff --git a/chrome/browser/chromeos/drive/sync/remove_performer.cc b/chrome/browser/chromeos/drive/sync/remove_performer.cc
|
| deleted file mode 100644
|
| index 3e24ce041c6f0f174681a44092dd7a02545377ee..0000000000000000000000000000000000000000
|
| --- a/chrome/browser/chromeos/drive/sync/remove_performer.cc
|
| +++ /dev/null
|
| @@ -1,255 +0,0 @@
|
| -// Copyright 2013 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/chromeos/drive/sync/remove_performer.h"
|
| -
|
| -#include "base/sequenced_task_runner.h"
|
| -#include "chrome/browser/chromeos/drive/sync/entry_revert_performer.h"
|
| -#include "components/drive/drive.pb.h"
|
| -#include "components/drive/drive_api_util.h"
|
| -#include "components/drive/file_system/operation_delegate.h"
|
| -#include "components/drive/file_system_core_util.h"
|
| -#include "components/drive/job_scheduler.h"
|
| -#include "components/drive/resource_entry_conversion.h"
|
| -#include "components/drive/resource_metadata.h"
|
| -#include "google_apis/drive/drive_api_parser.h"
|
| -
|
| -namespace drive {
|
| -namespace internal {
|
| -
|
| -namespace {
|
| -
|
| -// Updates local metadata and after remote unparenting.
|
| -FileError UpdateLocalStateAfterUnparent(ResourceMetadata* metadata,
|
| - const std::string& local_id) {
|
| - ResourceEntry entry;
|
| - FileError error = metadata->GetResourceEntryById(local_id, &entry);
|
| - if (error != FILE_ERROR_OK)
|
| - return error;
|
| - entry.set_parent_local_id(util::kDriveOtherDirLocalId);
|
| - return metadata->RefreshEntry(entry);
|
| -}
|
| -
|
| -// Utility function to run ResourceMetadata::RemoveEntry from UI thread.
|
| -void RemoveEntryOnUIThread(base::SequencedTaskRunner* blocking_task_runner,
|
| - ResourceMetadata* metadata,
|
| - const std::string& local_id,
|
| - const FileOperationCallback& callback) {
|
| - base::PostTaskAndReplyWithResult(
|
| - blocking_task_runner,
|
| - FROM_HERE,
|
| - base::Bind(&ResourceMetadata::RemoveEntry,
|
| - base::Unretained(metadata), local_id),
|
| - callback);
|
| -}
|
| -
|
| -} // namespace
|
| -
|
| -RemovePerformer::RemovePerformer(
|
| - base::SequencedTaskRunner* blocking_task_runner,
|
| - file_system::OperationDelegate* delegate,
|
| - JobScheduler* scheduler,
|
| - ResourceMetadata* metadata)
|
| - : blocking_task_runner_(blocking_task_runner),
|
| - delegate_(delegate),
|
| - scheduler_(scheduler),
|
| - metadata_(metadata),
|
| - entry_revert_performer_(new EntryRevertPerformer(blocking_task_runner,
|
| - delegate,
|
| - scheduler,
|
| - metadata)),
|
| - weak_ptr_factory_(this) {
|
| -}
|
| -
|
| -RemovePerformer::~RemovePerformer() {
|
| - DCHECK(thread_checker_.CalledOnValidThread());
|
| -}
|
| -
|
| -// Returns |entry| corresponding to |local_id|.
|
| -// Adding to that, removes the entry when it does not exist on the server.
|
| -FileError TryToRemoveLocally(ResourceMetadata* metadata,
|
| - const std::string& local_id,
|
| - ResourceEntry* entry) {
|
| - FileError error = metadata->GetResourceEntryById(local_id, entry);
|
| - if (error != FILE_ERROR_OK || !entry->resource_id().empty())
|
| - return error;
|
| - return metadata->RemoveEntry(local_id);
|
| -}
|
| -
|
| -void RemovePerformer::Remove(const std::string& local_id,
|
| - const ClientContext& context,
|
| - const FileOperationCallback& callback) {
|
| - DCHECK(thread_checker_.CalledOnValidThread());
|
| - DCHECK(!callback.is_null());
|
| -
|
| - ResourceEntry* entry = new ResourceEntry;
|
| - base::PostTaskAndReplyWithResult(
|
| - blocking_task_runner_.get(),
|
| - FROM_HERE,
|
| - base::Bind(&TryToRemoveLocally, metadata_, local_id, entry),
|
| - base::Bind(&RemovePerformer::RemoveAfterGetResourceEntry,
|
| - weak_ptr_factory_.GetWeakPtr(),
|
| - context,
|
| - callback,
|
| - base::Owned(entry)));
|
| -}
|
| -
|
| -void RemovePerformer::RemoveAfterGetResourceEntry(
|
| - const ClientContext& context,
|
| - const FileOperationCallback& callback,
|
| - const ResourceEntry* entry,
|
| - FileError error) {
|
| - DCHECK(thread_checker_.CalledOnValidThread());
|
| - DCHECK(!callback.is_null());
|
| -
|
| - if (error != FILE_ERROR_OK || entry->resource_id().empty()) {
|
| - callback.Run(error);
|
| - return;
|
| - }
|
| -
|
| - // To match with the behavior of drive.google.com:
|
| - // Removal of shared entries under MyDrive is just removing from the parent.
|
| - // The entry will stay in shared-with-me (in other words, in "drive/other".)
|
| - //
|
| - // TODO(kinaba): to be more precise, we might be better to branch by whether
|
| - // or not the current account is an owner of the file. The code below is
|
| - // written under the assumption that |shared_with_me| coincides with that.
|
| - if (entry->shared_with_me()) {
|
| - UnparentResource(context, callback, entry->resource_id(),
|
| - entry->local_id());
|
| - } else {
|
| - // Otherwise try sending the entry to trash.
|
| - TrashResource(context, callback, entry->resource_id(), entry->local_id());
|
| - }
|
| -}
|
| -
|
| -void RemovePerformer::TrashResource(const ClientContext& context,
|
| - const FileOperationCallback& callback,
|
| - const std::string& resource_id,
|
| - const std::string& local_id) {
|
| - DCHECK(thread_checker_.CalledOnValidThread());
|
| - DCHECK(!callback.is_null());
|
| -
|
| - scheduler_->TrashResource(
|
| - resource_id,
|
| - context,
|
| - base::Bind(&RemovePerformer::TrashResourceAfterUpdateRemoteState,
|
| - weak_ptr_factory_.GetWeakPtr(), context, callback, local_id));
|
| -}
|
| -
|
| -void RemovePerformer::TrashResourceAfterUpdateRemoteState(
|
| - const ClientContext& context,
|
| - const FileOperationCallback& callback,
|
| - const std::string& local_id,
|
| - google_apis::DriveApiErrorCode status) {
|
| - DCHECK(thread_checker_.CalledOnValidThread());
|
| - DCHECK(!callback.is_null());
|
| -
|
| - if (status == google_apis::HTTP_FORBIDDEN) {
|
| - // Editing this entry is not allowed, revert local changes.
|
| - entry_revert_performer_->RevertEntry(local_id, context, callback);
|
| - delegate_->OnDriveSyncError(
|
| - file_system::DRIVE_SYNC_ERROR_DELETE_WITHOUT_PERMISSION, local_id);
|
| - return;
|
| - }
|
| -
|
| - FileError error = GDataToFileError(status);
|
| - if (error == FILE_ERROR_NOT_FOUND) { // Remove local entry when not found.
|
| - RemoveEntryOnUIThread(blocking_task_runner_.get(), metadata_, local_id,
|
| - callback);
|
| - return;
|
| - }
|
| -
|
| - // Now we're done. If the entry is trashed on the server, it'll be also
|
| - // deleted locally on the next update.
|
| - callback.Run(error);
|
| -}
|
| -
|
| -void RemovePerformer::UnparentResource(const ClientContext& context,
|
| - const FileOperationCallback& callback,
|
| - const std::string& resource_id,
|
| - const std::string& local_id) {
|
| - DCHECK(thread_checker_.CalledOnValidThread());
|
| - DCHECK(!callback.is_null());
|
| -
|
| - scheduler_->GetFileResource(
|
| - resource_id,
|
| - context,
|
| - base::Bind(&RemovePerformer::UnparentResourceAfterGetFileResource,
|
| - weak_ptr_factory_.GetWeakPtr(), context, callback, local_id));
|
| -}
|
| -
|
| -void RemovePerformer::UnparentResourceAfterGetFileResource(
|
| - const ClientContext& context,
|
| - const FileOperationCallback& callback,
|
| - const std::string& local_id,
|
| - google_apis::DriveApiErrorCode status,
|
| - scoped_ptr<google_apis::FileResource> file_resource) {
|
| - DCHECK(thread_checker_.CalledOnValidThread());
|
| - DCHECK(!callback.is_null());
|
| -
|
| - FileError error = GDataToFileError(status);
|
| - if (error == FILE_ERROR_NOT_FOUND) { // Remove local entry when not found.
|
| - RemoveEntryOnUIThread(blocking_task_runner_.get(), metadata_, local_id,
|
| - callback);
|
| - return;
|
| - }
|
| -
|
| - if (error != FILE_ERROR_OK) {
|
| - callback.Run(error);
|
| - return;
|
| - }
|
| -
|
| - ResourceEntry entry;
|
| - std::string parent_resource_id;
|
| - if (!ConvertFileResourceToResourceEntry(*file_resource, &entry,
|
| - &parent_resource_id)) {
|
| - callback.Run(FILE_ERROR_NOT_A_FILE);
|
| - return;
|
| - }
|
| -
|
| - if (!entry.shared_with_me()) {
|
| - // shared_with_me() has changed on the server.
|
| - UnparentResourceAfterUpdateRemoteState(callback, local_id,
|
| - google_apis::HTTP_CONFLICT);
|
| - return;
|
| - }
|
| -
|
| - if (parent_resource_id.empty()) {
|
| - // This entry is unparented already.
|
| - UnparentResourceAfterUpdateRemoteState(callback, local_id,
|
| - google_apis::HTTP_NO_CONTENT);
|
| - return;
|
| - }
|
| -
|
| - scheduler_->RemoveResourceFromDirectory(
|
| - parent_resource_id,
|
| - entry.resource_id(),
|
| - context,
|
| - base::Bind(&RemovePerformer::UnparentResourceAfterUpdateRemoteState,
|
| - weak_ptr_factory_.GetWeakPtr(), callback, local_id));
|
| -}
|
| -
|
| -void RemovePerformer::UnparentResourceAfterUpdateRemoteState(
|
| - const FileOperationCallback& callback,
|
| - const std::string& local_id,
|
| - google_apis::DriveApiErrorCode status) {
|
| - DCHECK(thread_checker_.CalledOnValidThread());
|
| - DCHECK(!callback.is_null());
|
| -
|
| - FileError error = GDataToFileError(status);
|
| - if (error != FILE_ERROR_OK) {
|
| - callback.Run(error);
|
| - return;
|
| - }
|
| -
|
| - base::PostTaskAndReplyWithResult(
|
| - blocking_task_runner_.get(),
|
| - FROM_HERE,
|
| - base::Bind(&UpdateLocalStateAfterUnparent, metadata_, local_id),
|
| - callback);
|
| -}
|
| -
|
| -} // namespace internal
|
| -} // namespace drive
|
|
|