Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 // chromeos::StorageMonitorCros implementation. | 5 // chromeos::StorageMonitorCros implementation. |
| 6 | 6 |
| 7 #include "chrome/browser/storage_monitor/storage_monitor_chromeos.h" | 7 #include "chrome/browser/storage_monitor/storage_monitor_chromeos.h" |
| 8 | 8 |
| 9 #include "base/files/file_path.h" | 9 #include "base/files/file_path.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 10 matching lines...) Expand all Loading... | |
| 21 | 21 |
| 22 namespace chromeos { | 22 namespace chromeos { |
| 23 | 23 |
| 24 namespace { | 24 namespace { |
| 25 | 25 |
| 26 // Constructs a device id using uuid or manufacturer (vendor and product) id | 26 // Constructs a device id using uuid or manufacturer (vendor and product) id |
| 27 // details. | 27 // details. |
| 28 std::string MakeDeviceUniqueId(const disks::DiskMountManager::Disk& disk) { | 28 std::string MakeDeviceUniqueId(const disks::DiskMountManager::Disk& disk) { |
| 29 std::string uuid = disk.fs_uuid(); | 29 std::string uuid = disk.fs_uuid(); |
| 30 if (!uuid.empty()) | 30 if (!uuid.empty()) |
| 31 return chrome::kFSUniqueIdPrefix + uuid; | 31 return kFSUniqueIdPrefix + uuid; |
| 32 | 32 |
| 33 // If one of the vendor or product information is missing, its value in the | 33 // If one of the vendor or product information is missing, its value in the |
| 34 // string is empty. | 34 // string is empty. |
| 35 // Format: VendorModelSerial:VendorInfo:ModelInfo:SerialInfo | 35 // Format: VendorModelSerial:VendorInfo:ModelInfo:SerialInfo |
| 36 // TODO(kmadhusu) Extract serial information for the disks and append it to | 36 // TODO(kmadhusu) Extract serial information for the disks and append it to |
| 37 // the device unique id. | 37 // the device unique id. |
| 38 const std::string& vendor = disk.vendor_id(); | 38 const std::string& vendor = disk.vendor_id(); |
| 39 const std::string& product = disk.product_id(); | 39 const std::string& product = disk.product_id(); |
| 40 if (vendor.empty() && product.empty()) | 40 if (vendor.empty() && product.empty()) |
| 41 return std::string(); | 41 return std::string(); |
| 42 return chrome::kVendorModelSerialPrefix + vendor + ":" + product + ":"; | 42 return kVendorModelSerialPrefix + vendor + ":" + product + ":"; |
| 43 } | 43 } |
| 44 | 44 |
| 45 // Returns true if the requested device is valid, else false. On success, fills | 45 // Returns true if the requested device is valid, else false. On success, fills |
| 46 // in |info|. | 46 // in |info|. |
| 47 bool GetDeviceInfo(const disks::DiskMountManager::MountPointInfo& mount_info, | 47 bool GetDeviceInfo(const disks::DiskMountManager::MountPointInfo& mount_info, |
| 48 bool has_dcim, | 48 bool has_dcim, |
| 49 chrome::StorageInfo* info) { | 49 StorageInfo* info) { |
| 50 DCHECK(info); | 50 DCHECK(info); |
| 51 std::string source_path = mount_info.source_path; | 51 std::string source_path = mount_info.source_path; |
| 52 | 52 |
| 53 const disks::DiskMountManager::Disk* disk = | 53 const disks::DiskMountManager::Disk* disk = |
| 54 disks::DiskMountManager::GetInstance()->FindDiskBySourcePath(source_path); | 54 disks::DiskMountManager::GetInstance()->FindDiskBySourcePath(source_path); |
| 55 if (!disk || disk->device_type() == DEVICE_TYPE_UNKNOWN) | 55 if (!disk || disk->device_type() == DEVICE_TYPE_UNKNOWN) |
| 56 return false; | 56 return false; |
| 57 | 57 |
| 58 std::string unique_id = MakeDeviceUniqueId(*disk); | 58 std::string unique_id = MakeDeviceUniqueId(*disk); |
| 59 // Keep track of device uuid and label, to see how often we receive empty | 59 // Keep track of device uuid and label, to see how often we receive empty |
| 60 // values. | 60 // values. |
| 61 string16 device_label = UTF8ToUTF16(disk->device_label()); | 61 string16 device_label = UTF8ToUTF16(disk->device_label()); |
| 62 chrome::MediaStorageUtil::RecordDeviceInfoHistogram(true, unique_id, | 62 MediaStorageUtil::RecordDeviceInfoHistogram(true, unique_id, device_label); |
| 63 device_label); | |
| 64 if (unique_id.empty()) | 63 if (unique_id.empty()) |
| 65 return false; | 64 return false; |
| 66 | 65 |
| 67 chrome::StorageInfo::Type type = has_dcim ? | 66 StorageInfo::Type type = has_dcim ? |
| 68 chrome::StorageInfo::REMOVABLE_MASS_STORAGE_WITH_DCIM : | 67 StorageInfo::REMOVABLE_MASS_STORAGE_WITH_DCIM : |
| 69 chrome::StorageInfo::REMOVABLE_MASS_STORAGE_NO_DCIM; | 68 StorageInfo::REMOVABLE_MASS_STORAGE_NO_DCIM; |
| 70 | 69 |
| 71 *info = chrome::StorageInfo( | 70 *info = StorageInfo( |
| 72 chrome::StorageInfo::MakeDeviceId(type, unique_id), | 71 StorageInfo::MakeDeviceId(type, unique_id), |
|
vandebo (ex-Chrome)
2013/09/12 20:37:23
nit: this could go up to the previous line, with i
Lei Zhang
2013/09/12 20:40:06
Done.
| |
| 73 string16(), | 72 string16(), |
| 74 mount_info.mount_path, | 73 mount_info.mount_path, |
| 75 device_label, | 74 device_label, |
| 76 UTF8ToUTF16(disk->vendor_name()), | 75 UTF8ToUTF16(disk->vendor_name()), |
| 77 UTF8ToUTF16(disk->product_name()), | 76 UTF8ToUTF16(disk->product_name()), |
| 78 disk->total_size_in_bytes()); | 77 disk->total_size_in_bytes()); |
| 79 return true; | 78 return true; |
| 80 } | 79 } |
| 81 | 80 |
| 82 // Returns whether the mount point in |mount_info| is a media device or not. | 81 // Returns whether the mount point in |mount_info| is a media device or not. |
| 83 bool CheckMountedPathOnFileThread( | 82 bool CheckMountedPathOnFileThread( |
| 84 const disks::DiskMountManager::MountPointInfo& mount_info) { | 83 const disks::DiskMountManager::MountPointInfo& mount_info) { |
| 85 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::FILE)); | 84 DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::FILE)); |
| 86 return chrome::MediaStorageUtil::HasDcim( | 85 return MediaStorageUtil::HasDcim(base::FilePath(mount_info.mount_path)); |
| 87 base::FilePath(mount_info.mount_path)); | |
| 88 } | 86 } |
| 89 | 87 |
| 90 } // namespace | 88 } // namespace |
| 91 | 89 |
| 92 using content::BrowserThread; | 90 using content::BrowserThread; |
| 93 using chrome::StorageInfo; | |
| 94 | 91 |
| 95 StorageMonitorCros::StorageMonitorCros() | 92 StorageMonitorCros::StorageMonitorCros() |
| 96 : weak_ptr_factory_(this) { | 93 : weak_ptr_factory_(this) { |
| 97 } | 94 } |
| 98 | 95 |
| 99 StorageMonitorCros::~StorageMonitorCros() { | 96 StorageMonitorCros::~StorageMonitorCros() { |
| 100 disks::DiskMountManager* manager = disks::DiskMountManager::GetInstance(); | 97 disks::DiskMountManager* manager = disks::DiskMountManager::GetInstance(); |
| 101 if (manager) { | 98 if (manager) { |
| 102 manager->RemoveObserver(this); | 99 manager->RemoveObserver(this); |
| 103 } | 100 } |
| 104 } | 101 } |
| 105 | 102 |
| 106 void StorageMonitorCros::Init() { | 103 void StorageMonitorCros::Init() { |
| 107 DCHECK(disks::DiskMountManager::GetInstance()); | 104 DCHECK(disks::DiskMountManager::GetInstance()); |
| 108 disks::DiskMountManager::GetInstance()->AddObserver(this); | 105 disks::DiskMountManager::GetInstance()->AddObserver(this); |
| 109 CheckExistingMountPoints(); | 106 CheckExistingMountPoints(); |
| 110 | 107 |
| 111 if (!media_transfer_protocol_manager_) { | 108 if (!media_transfer_protocol_manager_) { |
| 112 scoped_refptr<base::MessageLoopProxy> loop_proxy; | 109 scoped_refptr<base::MessageLoopProxy> loop_proxy; |
| 113 media_transfer_protocol_manager_.reset( | 110 media_transfer_protocol_manager_.reset( |
| 114 device::MediaTransferProtocolManager::Initialize(loop_proxy)); | 111 device::MediaTransferProtocolManager::Initialize(loop_proxy)); |
| 115 } | 112 } |
| 116 | 113 |
| 117 media_transfer_protocol_device_observer_.reset( | 114 media_transfer_protocol_device_observer_.reset( |
| 118 new chrome::MediaTransferProtocolDeviceObserverLinux( | 115 new MediaTransferProtocolDeviceObserverLinux( |
| 119 receiver(), media_transfer_protocol_manager_.get())); | 116 receiver(), media_transfer_protocol_manager_.get())); |
| 120 } | 117 } |
| 121 | 118 |
| 122 void StorageMonitorCros::CheckExistingMountPoints() { | 119 void StorageMonitorCros::CheckExistingMountPoints() { |
| 123 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 120 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 124 const disks::DiskMountManager::MountPointMap& mount_point_map = | 121 const disks::DiskMountManager::MountPointMap& mount_point_map = |
| 125 disks::DiskMountManager::GetInstance()->mount_points(); | 122 disks::DiskMountManager::GetInstance()->mount_points(); |
| 126 for (disks::DiskMountManager::MountPointMap::const_iterator it = | 123 for (disks::DiskMountManager::MountPointMap::const_iterator it = |
| 127 mount_point_map.begin(); it != mount_point_map.end(); ++it) { | 124 mount_point_map.begin(); it != mount_point_map.end(); ++it) { |
| 128 BrowserThread::PostTaskAndReplyWithResult( | 125 BrowserThread::PostTaskAndReplyWithResult( |
| (...skipping 100 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 229 if (info_it == mount_map_.end()) | 226 if (info_it == mount_map_.end()) |
| 230 return false; | 227 return false; |
| 231 | 228 |
| 232 *device_info = info_it->second; | 229 *device_info = info_it->second; |
| 233 return true; | 230 return true; |
| 234 } | 231 } |
| 235 | 232 |
| 236 // Callback executed when the unmount call is run by DiskMountManager. | 233 // Callback executed when the unmount call is run by DiskMountManager. |
| 237 // Forwards result to |EjectDevice| caller. | 234 // Forwards result to |EjectDevice| caller. |
| 238 void NotifyUnmountResult( | 235 void NotifyUnmountResult( |
| 239 base::Callback<void(chrome::StorageMonitor::EjectStatus)> callback, | 236 base::Callback<void(StorageMonitor::EjectStatus)> callback, |
| 240 chromeos::MountError error_code) { | 237 chromeos::MountError error_code) { |
| 241 if (error_code == MOUNT_ERROR_NONE) | 238 if (error_code == MOUNT_ERROR_NONE) |
| 242 callback.Run(chrome::StorageMonitor::EJECT_OK); | 239 callback.Run(StorageMonitor::EJECT_OK); |
| 243 else | 240 else |
| 244 callback.Run(chrome::StorageMonitor::EJECT_FAILURE); | 241 callback.Run(StorageMonitor::EJECT_FAILURE); |
| 245 } | 242 } |
| 246 | 243 |
| 247 void StorageMonitorCros::EjectDevice( | 244 void StorageMonitorCros::EjectDevice( |
| 248 const std::string& device_id, | 245 const std::string& device_id, |
| 249 base::Callback<void(EjectStatus)> callback) { | 246 base::Callback<void(EjectStatus)> callback) { |
| 250 StorageInfo::Type type; | 247 StorageInfo::Type type; |
| 251 if (!StorageInfo::CrackDeviceId(device_id, &type, NULL)) { | 248 if (!StorageInfo::CrackDeviceId(device_id, &type, NULL)) { |
| 252 callback.Run(EJECT_FAILURE); | 249 callback.Run(EJECT_FAILURE); |
| 253 return; | 250 return; |
| 254 } | 251 } |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 290 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 287 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 291 | 288 |
| 292 if (ContainsKey(mount_map_, mount_info.mount_path)) { | 289 if (ContainsKey(mount_map_, mount_info.mount_path)) { |
| 293 // CheckExistingMountPointsOnUIThread() added the mount point information | 290 // CheckExistingMountPointsOnUIThread() added the mount point information |
| 294 // in the map before the device attached handler is called. Therefore, an | 291 // in the map before the device attached handler is called. Therefore, an |
| 295 // entry for the device already exists in the map. | 292 // entry for the device already exists in the map. |
| 296 return; | 293 return; |
| 297 } | 294 } |
| 298 | 295 |
| 299 // Get the media device uuid and label if exists. | 296 // Get the media device uuid and label if exists. |
| 300 chrome::StorageInfo info; | 297 StorageInfo info; |
| 301 if (!GetDeviceInfo(mount_info, has_dcim, &info)) | 298 if (!GetDeviceInfo(mount_info, has_dcim, &info)) |
| 302 return; | 299 return; |
| 303 | 300 |
| 304 if (info.device_id().empty()) | 301 if (info.device_id().empty()) |
| 305 return; | 302 return; |
| 306 | 303 |
| 307 mount_map_.insert(std::make_pair(mount_info.mount_path, info)); | 304 mount_map_.insert(std::make_pair(mount_info.mount_path, info)); |
| 308 | 305 |
| 309 receiver()->ProcessAttach(info); | 306 receiver()->ProcessAttach(info); |
| 310 } | 307 } |
| 311 | 308 |
| 312 } // namespace chromeos | 309 } // namespace chromeos |
| 313 | 310 |
| 314 namespace chrome { | |
| 315 | |
| 316 StorageMonitor* StorageMonitor::Create() { | 311 StorageMonitor* StorageMonitor::Create() { |
| 317 return new chromeos::StorageMonitorCros(); | 312 return new chromeos::StorageMonitorCros(); |
| 318 } | 313 } |
| 319 | |
| 320 } // namespace chrome | |
| OLD | NEW |