Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/chromeos/file_system_provider/provided_file_system.h" | 5 #include "chrome/browser/chromeos/file_system_provider/provided_file_system.h" |
| 6 | 6 |
| 7 #include "base/files/file.h" | |
| 8 #include "base/values.h" | |
| 9 #include "chrome/browser/chromeos/file_system_provider/request_manager.h" | |
| 10 #include "chrome/browser/profiles/profile.h" | |
| 11 #include "chrome/common/extensions/api/file_system_provider.h" | |
| 12 #include "extensions/browser/event_router.h" | |
| 13 #include "extensions/browser/extension_system.h" | |
| 14 | |
| 7 namespace chromeos { | 15 namespace chromeos { |
| 8 namespace file_system_provider { | 16 namespace file_system_provider { |
| 17 namespace { | |
| 18 | |
| 19 // Creates values to be passed to request events. These values can be extended | |
| 20 // by additional fields. | |
| 21 scoped_ptr<base::ListValue> CreateRequestValues(int file_system_id, | |
| 22 int request_id) { | |
| 23 scoped_ptr<base::ListValue> values(new base::ListValue()); | |
| 24 values->AppendInteger(file_system_id); | |
| 25 values->AppendInteger(request_id); | |
| 26 return values.Pass(); | |
| 27 } | |
| 28 | |
| 29 // Forwards the success callback to the status callback. Ignores arguments, | |
| 30 // since unmount request does not provide arguments. | |
| 31 void OnRequestUnmountSuccess( | |
| 32 const fileapi::AsyncFileUtil::StatusCallback& callback, | |
| 33 scoped_ptr<base::DictionaryValue> /* result */, | |
| 34 bool /* has_next */) { | |
| 35 callback.Run(base::File::FILE_OK); | |
| 36 } | |
| 37 | |
| 38 } // namespace | |
| 9 | 39 |
| 10 ProvidedFileSystem::ProvidedFileSystem() {} | 40 ProvidedFileSystem::ProvidedFileSystem() {} |
| 11 | 41 |
| 12 ProvidedFileSystem::ProvidedFileSystem(const std::string& extension_id, | 42 ProvidedFileSystem::ProvidedFileSystem( |
| 13 int file_system_id, | 43 extensions::EventRouter* event_router, |
| 14 const std::string& file_system_name, | 44 RequestManager* request_manager, |
| 15 const base::FilePath& mount_path) | 45 const ProvidedFileSystemInfo& file_system_info) |
| 16 : extension_id_(extension_id), | 46 : event_router_(event_router), |
| 17 file_system_id_(file_system_id), | 47 request_manager_(request_manager), |
| 18 file_system_name_(file_system_name), | 48 file_system_info_(file_system_info) {} |
| 19 mount_path_(mount_path) {} | |
| 20 | 49 |
| 21 ProvidedFileSystem::~ProvidedFileSystem() {} | 50 ProvidedFileSystem::~ProvidedFileSystem() {} |
| 22 | 51 |
| 52 bool ProvidedFileSystem::RequestUnmount( | |
| 53 const fileapi::AsyncFileUtil::StatusCallback& callback) { | |
| 54 int request_id = request_manager_->CreateRequest( | |
| 55 file_system_info_.extension_id(), | |
| 56 file_system_info_.file_system_id(), | |
| 57 base::Bind(&OnRequestUnmountSuccess, callback), | |
| 58 callback); | |
| 59 | |
| 60 if (!request_id) | |
| 61 return false; | |
| 62 | |
| 63 scoped_ptr<base::ListValue> values( | |
| 64 CreateRequestValues(file_system_info_.file_system_id(), request_id)); | |
| 65 | |
| 66 event_router_->DispatchEventToExtension( | |
| 67 file_system_info_.extension_id(), | |
| 68 make_scoped_ptr(new extensions::Event( | |
| 69 extensions::api::file_system_provider::OnUnmountRequested::kEventName, | |
| 70 values.Pass()))); | |
| 71 | |
| 72 return true; | |
| 73 } | |
| 74 | |
| 75 const ProvidedFileSystemInfo& ProvidedFileSystem::GetFileSystemInfo() const { | |
| 76 return file_system_info_; | |
| 77 } | |
| 78 | |
| 79 ProvidedFileSystemFactory::ProvidedFileSystemFactory() {} | |
| 80 | |
| 81 ProvidedFileSystemFactory::~ProvidedFileSystemFactory() {} | |
| 82 | |
| 83 ProvidedFileSystemInterface* ProvidedFileSystemFactory::Create( | |
| 84 Profile* profile, | |
|
hashimoto
2014/04/11 06:01:50
Why doesn't this method take event_router instead
mtomasz
2014/04/11 07:11:56
I tried it, but it would be difficult to test. Pro
hashimoto
2014/04/14 10:43:42
Sorry, I still don't understand why changing this
mtomasz
2014/04/15 02:46:40
Yep, I must have been tired writing that comment :
hashimoto
2014/04/15 07:22:45
Sorry, I still don't understand why changing this
mtomasz
2014/04/15 09:42:12
Per offline talk. I misread your first comment. So
| |
| 85 RequestManager* request_manager, | |
| 86 const ProvidedFileSystemInfo& file_system_info) { | |
| 87 DCHECK(profile); | |
| 88 DCHECK(request_manager); | |
| 89 extensions::EventRouter* event_router = | |
| 90 extensions::ExtensionSystem::Get(profile)->event_router(); | |
| 91 DCHECK(event_router); | |
| 92 return new ProvidedFileSystem( | |
| 93 event_router, request_manager, file_system_info); | |
| 94 } | |
| 95 | |
| 23 } // namespace file_system_provider | 96 } // namespace file_system_provider |
| 24 } // namespace chromeos | 97 } // namespace chromeos |
| OLD | NEW |