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

Unified Diff: webkit/browser/fileapi/file_system_operation_impl.cc

Issue 539143002: Migrate webkit/browser/ to storage/browser/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 6 years, 3 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: webkit/browser/fileapi/file_system_operation_impl.cc
diff --git a/webkit/browser/fileapi/file_system_operation_impl.cc b/webkit/browser/fileapi/file_system_operation_impl.cc
deleted file mode 100644
index 286f19f177e2beb50b737fa6c0814cc054e61652..0000000000000000000000000000000000000000
--- a/webkit/browser/fileapi/file_system_operation_impl.cc
+++ /dev/null
@@ -1,559 +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 "webkit/browser/fileapi/file_system_operation_impl.h"
-
-#include "base/bind.h"
-#include "base/single_thread_task_runner.h"
-#include "base/strings/utf_string_conversions.h"
-#include "base/time/time.h"
-#include "net/base/escape.h"
-#include "net/url_request/url_request.h"
-#include "webkit/browser/fileapi/async_file_util.h"
-#include "webkit/browser/fileapi/copy_or_move_operation_delegate.h"
-#include "webkit/browser/fileapi/file_observers.h"
-#include "webkit/browser/fileapi/file_system_backend.h"
-#include "webkit/browser/fileapi/file_system_context.h"
-#include "webkit/browser/fileapi/file_system_file_util.h"
-#include "webkit/browser/fileapi/file_system_operation_context.h"
-#include "webkit/browser/fileapi/file_system_url.h"
-#include "webkit/browser/fileapi/file_writer_delegate.h"
-#include "webkit/browser/fileapi/remove_operation_delegate.h"
-#include "webkit/browser/fileapi/sandbox_file_system_backend.h"
-#include "webkit/browser/quota/quota_manager_proxy.h"
-#include "webkit/common/blob/shareable_file_reference.h"
-#include "webkit/common/fileapi/file_system_types.h"
-#include "webkit/common/fileapi/file_system_util.h"
-#include "webkit/common/quota/quota_types.h"
-
-using storage::ScopedFile;
-
-namespace storage {
-
-FileSystemOperation* FileSystemOperation::Create(
- const FileSystemURL& url,
- FileSystemContext* file_system_context,
- scoped_ptr<FileSystemOperationContext> operation_context) {
- return new FileSystemOperationImpl(url, file_system_context,
- operation_context.Pass());
-}
-
-FileSystemOperationImpl::~FileSystemOperationImpl() {
-}
-
-void FileSystemOperationImpl::CreateFile(const FileSystemURL& url,
- bool exclusive,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCreateFile));
- GetUsageAndQuotaThenRunTask(
- url,
- base::Bind(&FileSystemOperationImpl::DoCreateFile,
- weak_factory_.GetWeakPtr(), url, callback, exclusive),
- base::Bind(callback, base::File::FILE_ERROR_FAILED));
-}
-
-void FileSystemOperationImpl::CreateDirectory(const FileSystemURL& url,
- bool exclusive,
- bool recursive,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCreateDirectory));
- GetUsageAndQuotaThenRunTask(
- url,
- base::Bind(&FileSystemOperationImpl::DoCreateDirectory,
- weak_factory_.GetWeakPtr(), url, callback,
- exclusive, recursive),
- base::Bind(callback, base::File::FILE_ERROR_FAILED));
-}
-
-void FileSystemOperationImpl::Copy(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- CopyOrMoveOption option,
- const CopyProgressCallback& progress_callback,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCopy));
- DCHECK(!recursive_operation_delegate_);
-
- // TODO(hidehiko): Support |progress_callback|. (crbug.com/278038).
- recursive_operation_delegate_.reset(
- new CopyOrMoveOperationDelegate(
- file_system_context(),
- src_url, dest_url,
- CopyOrMoveOperationDelegate::OPERATION_COPY,
- option,
- progress_callback,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback)));
- recursive_operation_delegate_->RunRecursively();
-}
-
-void FileSystemOperationImpl::Move(const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- CopyOrMoveOption option,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationMove));
- DCHECK(!recursive_operation_delegate_);
- recursive_operation_delegate_.reset(
- new CopyOrMoveOperationDelegate(
- file_system_context(),
- src_url, dest_url,
- CopyOrMoveOperationDelegate::OPERATION_MOVE,
- option,
- FileSystemOperation::CopyProgressCallback(),
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback)));
- recursive_operation_delegate_->RunRecursively();
-}
-
-void FileSystemOperationImpl::DirectoryExists(const FileSystemURL& url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationDirectoryExists));
- async_file_util_->GetFileInfo(
- operation_context_.Pass(), url,
- base::Bind(&FileSystemOperationImpl::DidDirectoryExists,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::FileExists(const FileSystemURL& url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationFileExists));
- async_file_util_->GetFileInfo(
- operation_context_.Pass(), url,
- base::Bind(&FileSystemOperationImpl::DidFileExists,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::GetMetadata(
- const FileSystemURL& url, const GetMetadataCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationGetMetadata));
- async_file_util_->GetFileInfo(operation_context_.Pass(), url, callback);
-}
-
-void FileSystemOperationImpl::ReadDirectory(
- const FileSystemURL& url, const ReadDirectoryCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationReadDirectory));
- async_file_util_->ReadDirectory(
- operation_context_.Pass(), url, callback);
-}
-
-void FileSystemOperationImpl::Remove(const FileSystemURL& url,
- bool recursive,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationRemove));
- DCHECK(!recursive_operation_delegate_);
-
- if (recursive) {
- // For recursive removal, try to delegate the operation to AsyncFileUtil
- // first. If not supported, it is delegated to RemoveOperationDelegate
- // in DidDeleteRecursively.
- async_file_util_->DeleteRecursively(
- operation_context_.Pass(), url,
- base::Bind(&FileSystemOperationImpl::DidDeleteRecursively,
- weak_factory_.GetWeakPtr(), url, callback));
- return;
- }
-
- recursive_operation_delegate_.reset(
- new RemoveOperationDelegate(
- file_system_context(), url,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback)));
- recursive_operation_delegate_->Run();
-}
-
-void FileSystemOperationImpl::Write(
- const FileSystemURL& url,
- scoped_ptr<FileWriterDelegate> writer_delegate,
- scoped_ptr<net::URLRequest> blob_request,
- const WriteCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationWrite));
- file_writer_delegate_ = writer_delegate.Pass();
- file_writer_delegate_->Start(
- blob_request.Pass(),
- base::Bind(&FileSystemOperationImpl::DidWrite,
- weak_factory_.GetWeakPtr(), url, callback));
-}
-
-void FileSystemOperationImpl::Truncate(const FileSystemURL& url, int64 length,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationTruncate));
- GetUsageAndQuotaThenRunTask(
- url,
- base::Bind(&FileSystemOperationImpl::DoTruncate,
- weak_factory_.GetWeakPtr(), url, callback, length),
- base::Bind(callback, base::File::FILE_ERROR_FAILED));
-}
-
-void FileSystemOperationImpl::TouchFile(const FileSystemURL& url,
- const base::Time& last_access_time,
- const base::Time& last_modified_time,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationTouchFile));
- async_file_util_->Touch(
- operation_context_.Pass(), url,
- last_access_time, last_modified_time,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::OpenFile(const FileSystemURL& url,
- int file_flags,
- const OpenFileCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationOpenFile));
-
- if (file_flags &
- (base::File::FLAG_TEMPORARY | base::File::FLAG_HIDDEN)) {
- callback.Run(base::File(base::File::FILE_ERROR_FAILED),
- base::Closure());
- return;
- }
- GetUsageAndQuotaThenRunTask(
- url,
- base::Bind(&FileSystemOperationImpl::DoOpenFile,
- weak_factory_.GetWeakPtr(),
- url, callback, file_flags),
- base::Bind(callback, Passed(base::File(base::File::FILE_ERROR_FAILED)),
- base::Closure()));
-}
-
-// We can only get here on a write or truncate that's not yet completed.
-// We don't support cancelling any other operation at this time.
-void FileSystemOperationImpl::Cancel(const StatusCallback& cancel_callback) {
- DCHECK(cancel_callback_.is_null());
- cancel_callback_ = cancel_callback;
-
- if (file_writer_delegate_.get()) {
- DCHECK_EQ(kOperationWrite, pending_operation_);
- // This will call DidWrite() with ABORT status code.
- file_writer_delegate_->Cancel();
- } else if (recursive_operation_delegate_) {
- // This will call DidFinishOperation() with ABORT status code.
- recursive_operation_delegate_->Cancel();
- } else {
- // For truncate we have no way to cancel the inflight operation (for now).
- // Let it just run and dispatch cancel callback later.
- DCHECK_EQ(kOperationTruncate, pending_operation_);
- }
-}
-
-void FileSystemOperationImpl::CreateSnapshotFile(
- const FileSystemURL& url,
- const SnapshotFileCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCreateSnapshotFile));
- async_file_util_->CreateSnapshotFile(
- operation_context_.Pass(), url, callback);
-}
-
-void FileSystemOperationImpl::CopyInForeignFile(
- const base::FilePath& src_local_disk_file_path,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCopyInForeignFile));
- GetUsageAndQuotaThenRunTask(
- dest_url,
- base::Bind(&FileSystemOperationImpl::DoCopyInForeignFile,
- weak_factory_.GetWeakPtr(), src_local_disk_file_path, dest_url,
- callback),
- base::Bind(callback, base::File::FILE_ERROR_FAILED));
-}
-
-void FileSystemOperationImpl::RemoveFile(
- const FileSystemURL& url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationRemove));
- async_file_util_->DeleteFile(
- operation_context_.Pass(), url,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::RemoveDirectory(
- const FileSystemURL& url,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationRemove));
- async_file_util_->DeleteDirectory(
- operation_context_.Pass(), url,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::CopyFileLocal(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- CopyOrMoveOption option,
- const CopyFileProgressCallback& progress_callback,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationCopy));
- DCHECK(src_url.IsInSameFileSystem(dest_url));
-
- GetUsageAndQuotaThenRunTask(
- dest_url,
- base::Bind(&FileSystemOperationImpl::DoCopyFileLocal,
- weak_factory_.GetWeakPtr(), src_url, dest_url, option,
- progress_callback, callback),
- base::Bind(callback, base::File::FILE_ERROR_FAILED));
-}
-
-void FileSystemOperationImpl::MoveFileLocal(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- CopyOrMoveOption option,
- const StatusCallback& callback) {
- DCHECK(SetPendingOperationType(kOperationMove));
- DCHECK(src_url.IsInSameFileSystem(dest_url));
- GetUsageAndQuotaThenRunTask(
- dest_url,
- base::Bind(&FileSystemOperationImpl::DoMoveFileLocal,
- weak_factory_.GetWeakPtr(),
- src_url, dest_url, option, callback),
- base::Bind(callback, base::File::FILE_ERROR_FAILED));
-}
-
-base::File::Error FileSystemOperationImpl::SyncGetPlatformPath(
- const FileSystemURL& url,
- base::FilePath* platform_path) {
- DCHECK(SetPendingOperationType(kOperationGetLocalPath));
- if (!file_system_context()->IsSandboxFileSystem(url.type()))
- return base::File::FILE_ERROR_INVALID_OPERATION;
- FileSystemFileUtil* file_util =
- file_system_context()->sandbox_delegate()->sync_file_util();
- file_util->GetLocalFilePath(operation_context_.get(), url, platform_path);
- return base::File::FILE_OK;
-}
-
-FileSystemOperationImpl::FileSystemOperationImpl(
- const FileSystemURL& url,
- FileSystemContext* file_system_context,
- scoped_ptr<FileSystemOperationContext> operation_context)
- : file_system_context_(file_system_context),
- operation_context_(operation_context.Pass()),
- async_file_util_(NULL),
- pending_operation_(kOperationNone),
- weak_factory_(this) {
- DCHECK(operation_context_.get());
- operation_context_->DetachUserDataThread();
- async_file_util_ = file_system_context_->GetAsyncFileUtil(url.type());
- DCHECK(async_file_util_);
-}
-
-void FileSystemOperationImpl::GetUsageAndQuotaThenRunTask(
- const FileSystemURL& url,
- const base::Closure& task,
- const base::Closure& error_callback) {
- storage::QuotaManagerProxy* quota_manager_proxy =
- file_system_context()->quota_manager_proxy();
- if (!quota_manager_proxy ||
- !file_system_context()->GetQuotaUtil(url.type())) {
- // If we don't have the quota manager or the requested filesystem type
- // does not support quota, we should be able to let it go.
- operation_context_->set_allowed_bytes_growth(kint64max);
- task.Run();
- return;
- }
-
- DCHECK(quota_manager_proxy);
- DCHECK(quota_manager_proxy->quota_manager());
- quota_manager_proxy->quota_manager()->GetUsageAndQuota(
- url.origin(),
- FileSystemTypeToQuotaStorageType(url.type()),
- base::Bind(&FileSystemOperationImpl::DidGetUsageAndQuotaAndRunTask,
- weak_factory_.GetWeakPtr(), task, error_callback));
-}
-
-void FileSystemOperationImpl::DidGetUsageAndQuotaAndRunTask(
- const base::Closure& task,
- const base::Closure& error_callback,
- storage::QuotaStatusCode status,
- int64 usage,
- int64 quota) {
- if (status != storage::kQuotaStatusOk) {
- LOG(WARNING) << "Got unexpected quota error : " << status;
- error_callback.Run();
- return;
- }
-
- operation_context_->set_allowed_bytes_growth(quota - usage);
- task.Run();
-}
-
-void FileSystemOperationImpl::DoCreateFile(
- const FileSystemURL& url,
- const StatusCallback& callback,
- bool exclusive) {
- async_file_util_->EnsureFileExists(
- operation_context_.Pass(), url,
- base::Bind(
- exclusive ?
- &FileSystemOperationImpl::DidEnsureFileExistsExclusive :
- &FileSystemOperationImpl::DidEnsureFileExistsNonExclusive,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::DoCreateDirectory(
- const FileSystemURL& url,
- const StatusCallback& callback,
- bool exclusive, bool recursive) {
- async_file_util_->CreateDirectory(
- operation_context_.Pass(),
- url, exclusive, recursive,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::DoCopyFileLocal(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- CopyOrMoveOption option,
- const CopyFileProgressCallback& progress_callback,
- const StatusCallback& callback) {
- async_file_util_->CopyFileLocal(
- operation_context_.Pass(), src_url, dest_url, option, progress_callback,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::DoMoveFileLocal(
- const FileSystemURL& src_url,
- const FileSystemURL& dest_url,
- CopyOrMoveOption option,
- const StatusCallback& callback) {
- async_file_util_->MoveFileLocal(
- operation_context_.Pass(), src_url, dest_url, option,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::DoCopyInForeignFile(
- const base::FilePath& src_local_disk_file_path,
- const FileSystemURL& dest_url,
- const StatusCallback& callback) {
- async_file_util_->CopyInForeignFile(
- operation_context_.Pass(),
- src_local_disk_file_path, dest_url,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::DoTruncate(const FileSystemURL& url,
- const StatusCallback& callback,
- int64 length) {
- async_file_util_->Truncate(
- operation_context_.Pass(), url, length,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::DoOpenFile(const FileSystemURL& url,
- const OpenFileCallback& callback,
- int file_flags) {
- async_file_util_->CreateOrOpen(
- operation_context_.Pass(), url, file_flags,
- base::Bind(&FileSystemOperationImpl::DidOpenFile,
- weak_factory_.GetWeakPtr(), callback));
-}
-
-void FileSystemOperationImpl::DidEnsureFileExistsExclusive(
- const StatusCallback& callback,
- base::File::Error rv, bool created) {
- if (rv == base::File::FILE_OK && !created) {
- callback.Run(base::File::FILE_ERROR_EXISTS);
- } else {
- DidFinishOperation(callback, rv);
- }
-}
-
-void FileSystemOperationImpl::DidEnsureFileExistsNonExclusive(
- const StatusCallback& callback,
- base::File::Error rv, bool /* created */) {
- DidFinishOperation(callback, rv);
-}
-
-void FileSystemOperationImpl::DidFinishOperation(
- const StatusCallback& callback,
- base::File::Error rv) {
- if (!cancel_callback_.is_null()) {
- StatusCallback cancel_callback = cancel_callback_;
- callback.Run(rv);
-
- // Return OK only if we succeeded to stop the operation.
- cancel_callback.Run(rv == base::File::FILE_ERROR_ABORT ?
- base::File::FILE_OK :
- base::File::FILE_ERROR_INVALID_OPERATION);
- } else {
- callback.Run(rv);
- }
-}
-
-void FileSystemOperationImpl::DidDirectoryExists(
- const StatusCallback& callback,
- base::File::Error rv,
- const base::File::Info& file_info) {
- if (rv == base::File::FILE_OK && !file_info.is_directory)
- rv = base::File::FILE_ERROR_NOT_A_DIRECTORY;
- callback.Run(rv);
-}
-
-void FileSystemOperationImpl::DidFileExists(
- const StatusCallback& callback,
- base::File::Error rv,
- const base::File::Info& file_info) {
- if (rv == base::File::FILE_OK && file_info.is_directory)
- rv = base::File::FILE_ERROR_NOT_A_FILE;
- callback.Run(rv);
-}
-
-void FileSystemOperationImpl::DidDeleteRecursively(
- const FileSystemURL& url,
- const StatusCallback& callback,
- base::File::Error rv) {
- if (rv == base::File::FILE_ERROR_INVALID_OPERATION) {
- // Recursive removal is not supported on this platform.
- DCHECK(!recursive_operation_delegate_);
- recursive_operation_delegate_.reset(
- new RemoveOperationDelegate(
- file_system_context(), url,
- base::Bind(&FileSystemOperationImpl::DidFinishOperation,
- weak_factory_.GetWeakPtr(), callback)));
- recursive_operation_delegate_->RunRecursively();
- return;
- }
-
- callback.Run(rv);
-}
-
-void FileSystemOperationImpl::DidWrite(
- const FileSystemURL& url,
- const WriteCallback& write_callback,
- base::File::Error rv,
- int64 bytes,
- FileWriterDelegate::WriteProgressStatus write_status) {
- const bool complete = (
- write_status != FileWriterDelegate::SUCCESS_IO_PENDING);
- if (complete && write_status != FileWriterDelegate::ERROR_WRITE_NOT_STARTED) {
- DCHECK(operation_context_);
- operation_context_->change_observers()->Notify(
- &FileChangeObserver::OnModifyFile, MakeTuple(url));
- }
-
- StatusCallback cancel_callback = cancel_callback_;
- write_callback.Run(rv, bytes, complete);
- if (!cancel_callback.is_null())
- cancel_callback.Run(base::File::FILE_OK);
-}
-
-void FileSystemOperationImpl::DidOpenFile(
- const OpenFileCallback& callback,
- base::File file,
- const base::Closure& on_close_callback) {
- callback.Run(file.Pass(), on_close_callback);
-}
-
-bool FileSystemOperationImpl::SetPendingOperationType(OperationType type) {
- if (pending_operation_ != kOperationNone)
- return false;
- pending_operation_ = type;
- return true;
-}
-
-} // namespace storage

Powered by Google App Engine
This is Rietveld 408576698