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

Side by Side Diff: chrome/browser/system_monitor/removable_device_notifications_chromeos.cc

Issue 11366144: [Media Gallery][ChromeOS] Improve device media gallery names. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: '' Created 8 years, 1 month 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
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::RemovableDeviceNotificationsCros implementation. 5 // chromeos::RemovableDeviceNotificationsCros implementation.
6 6
7 #include "chrome/browser/system_monitor/removable_device_notifications_chromeos. h" 7 #include "chrome/browser/system_monitor/removable_device_notifications_chromeos. h"
8 8
9 #include "base/file_path.h" 9 #include "base/file_path.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "base/stl_util.h" 11 #include "base/stl_util.h"
12 #include "base/string_number_conversions.h" 12 #include "base/string_number_conversions.h"
13 #include "base/string_util.h"
13 #include "base/utf_string_conversions.h" 14 #include "base/utf_string_conversions.h"
14 #include "chrome/browser/system_monitor/media_device_notifications_utils.h" 15 #include "chrome/browser/system_monitor/media_device_notifications_utils.h"
15 #include "chrome/browser/system_monitor/media_storage_util.h" 16 #include "chrome/browser/system_monitor/media_storage_util.h"
16 #include "chrome/browser/system_monitor/removable_device_constants.h" 17 #include "chrome/browser/system_monitor/removable_device_constants.h"
17 #include "content/public/browser/browser_thread.h" 18 #include "content/public/browser/browser_thread.h"
18 19
19 namespace chromeos { 20 namespace chromeos {
20 21
21 using base::SystemMonitor; 22 using base::SystemMonitor;
22 23
23 namespace { 24 namespace {
24 25
25 // Construct a device name using label or manufacturer (vendor and product) name 26 // Constructs a device name using label or manufacturer (vendor and product)
26 // details. 27 // name details.
27 string16 GetDeviceName(const disks::DiskMountManager::Disk& disk) { 28 string16 GetDeviceName(const disks::DiskMountManager::Disk& disk) {
28 std::string device_name = disk.device_label(); 29 if (disk.device_type() == DEVICE_TYPE_SD) {
29 if (device_name.empty()) { 30 // Mount path of an SD card will be one of the following:
30 device_name = disk.vendor_name(); 31 // (1) /media/removable/<volume_label>
31 const std::string& product_name = disk.product_name(); 32 // (2) /media/removable/SD Card
32 if (!product_name.empty()) { 33 // If the volume label is available, mount path will be (1) else (2).
33 if (!device_name.empty()) 34 FilePath mount_point(disk.mount_path());
34 device_name += " "; 35 const string16 display_name(mount_point.BaseName().LossyDisplayName());
35 device_name += product_name; 36 if (!display_name.empty())
36 } 37 return display_name;
37 } 38 }
38 return UTF8ToUTF16(device_name); 39
40 const std::string& device_label = disk.device_label();
41 if (!device_label.empty() && IsStringUTF8(device_label))
42 return UTF8ToUTF16(device_label);
43 return chrome::GetFullProductName(disk.vendor_name(), disk.product_name());
39 } 44 }
40 45
41 // Construct a device id using uuid or manufacturer (vendor and product) id 46 // Constructs a device id using uuid or manufacturer (vendor and product) id
42 // details. 47 // details.
43 std::string MakeDeviceUniqueId(const disks::DiskMountManager::Disk& disk) { 48 std::string MakeDeviceUniqueId(const disks::DiskMountManager::Disk& disk) {
44 std::string uuid = disk.fs_uuid(); 49 std::string uuid = disk.fs_uuid();
45 if (!uuid.empty()) 50 if (!uuid.empty())
46 return chrome::kFSUniqueIdPrefix + uuid; 51 return chrome::kFSUniqueIdPrefix + uuid;
47 52
48 // If one of the vendor or product information is missing, its value in the 53 // If one of the vendor or product information is missing, its value in the
49 // string is empty. 54 // string is empty.
50 // Format: VendorModelSerial:VendorInfo:ModelInfo:SerialInfo 55 // Format: VendorModelSerial:VendorInfo:ModelInfo:SerialInfo
51 // TODO(kmadhusu) Extract serial information for the disks and append it to 56 // TODO(kmadhusu) Extract serial information for the disks and append it to
52 // the device unique id. 57 // the device unique id.
53 const std::string& vendor = disk.vendor_id(); 58 const std::string& vendor = disk.vendor_id();
54 const std::string& product = disk.product_id(); 59 const std::string& product = disk.product_id();
55 if (vendor.empty() && product.empty()) 60 if (vendor.empty() && product.empty())
56 return std::string(); 61 return std::string();
57 return chrome::kVendorModelSerialPrefix + vendor + ":" + product + ":"; 62 return chrome::kVendorModelSerialPrefix + vendor + ":" + product + ":";
58 } 63 }
59 64
60 static RemovableDeviceNotificationsCros* 65 static RemovableDeviceNotificationsCros*
61 g_removable_device_notifications_chromeos = NULL; 66 g_removable_device_notifications_chromeos = NULL;
62 67
63 // Returns true if the requested device is valid, else false. On success, fills 68 // Returns true if the requested device is valid, else false. On success, fills
64 // in |unique_id| and |device_label| 69 // in |unique_id|, |device_label| and |storage_size_in_bytes|.
65 bool GetDeviceInfo(const std::string& source_path, std::string* unique_id, 70 bool GetDeviceInfo(const std::string& source_path,
66 string16* device_label) { 71 std::string* unique_id,
67 // Get the media device uuid and label if exists. 72 string16* device_label,
73 uint64* storage_size_in_bytes) {
68 const disks::DiskMountManager::Disk* disk = 74 const disks::DiskMountManager::Disk* disk =
69 disks::DiskMountManager::GetInstance()->FindDiskBySourcePath(source_path); 75 disks::DiskMountManager::GetInstance()->FindDiskBySourcePath(source_path);
70 if (!disk || disk->device_type() == DEVICE_TYPE_UNKNOWN) 76 if (!disk || disk->device_type() == DEVICE_TYPE_UNKNOWN)
71 return false; 77 return false;
72 78
73 if (unique_id) 79 if (unique_id)
74 *unique_id = MakeDeviceUniqueId(*disk); 80 *unique_id = MakeDeviceUniqueId(*disk);
75 81
76 if (device_label) 82 if (device_label)
77 *device_label = GetDeviceName(*disk); 83 *device_label = GetDeviceName(*disk);
84
85 if (storage_size_in_bytes)
86 *storage_size_in_bytes = disk->total_size_in_bytes();
78 return true; 87 return true;
79 } 88 }
80 89
81 } // namespace 90 } // namespace
82 91
83 using chrome::MediaStorageUtil;
84 using content::BrowserThread; 92 using content::BrowserThread;
85 93
86 RemovableDeviceNotificationsCros::RemovableDeviceNotificationsCros() { 94 RemovableDeviceNotificationsCros::RemovableDeviceNotificationsCros() {
87 DCHECK(disks::DiskMountManager::GetInstance()); 95 DCHECK(disks::DiskMountManager::GetInstance());
88 DCHECK(!g_removable_device_notifications_chromeos); 96 DCHECK(!g_removable_device_notifications_chromeos);
89 g_removable_device_notifications_chromeos = this; 97 g_removable_device_notifications_chromeos = this;
90 disks::DiskMountManager::GetInstance()->AddObserver(this); 98 disks::DiskMountManager::GetInstance()->AddObserver(this);
91 CheckExistingMountPointsOnUIThread(); 99 CheckExistingMountPointsOnUIThread();
92 } 100 }
93 101
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after
157 base::Bind( 165 base::Bind(
158 &RemovableDeviceNotificationsCros::CheckMountedPathOnFileThread, 166 &RemovableDeviceNotificationsCros::CheckMountedPathOnFileThread,
159 this, mount_info)); 167 this, mount_info));
160 break; 168 break;
161 } 169 }
162 case disks::DiskMountManager::UNMOUNTING: { 170 case disks::DiskMountManager::UNMOUNTING: {
163 MountMap::iterator it = mount_map_.find(mount_info.mount_path); 171 MountMap::iterator it = mount_map_.find(mount_info.mount_path);
164 if (it == mount_map_.end()) 172 if (it == mount_map_.end())
165 return; 173 return;
166 SystemMonitor::Get()->ProcessRemovableStorageDetached( 174 SystemMonitor::Get()->ProcessRemovableStorageDetached(
167 it->second.device_id); 175 it->second.storage_info.device_id);
168 mount_map_.erase(it); 176 mount_map_.erase(it);
169 break; 177 break;
170 } 178 }
171 } 179 }
172 } 180 }
173 181
174 bool RemovableDeviceNotificationsCros::GetDeviceInfoForPath( 182 bool RemovableDeviceNotificationsCros::GetDeviceInfoForPath(
175 const FilePath& path, 183 const FilePath& path,
176 SystemMonitor::RemovableStorageInfo* device_info) const { 184 SystemMonitor::RemovableStorageInfo* device_info) const {
177 if (!path.IsAbsolute()) 185 if (!path.IsAbsolute())
178 return false; 186 return false;
179 187
180 FilePath current = path; 188 FilePath current = path;
181 while (!ContainsKey(mount_map_, current.value()) && 189 while (!ContainsKey(mount_map_, current.value()) &&
182 current != current.DirName()) { 190 current != current.DirName()) {
183 current = current.DirName(); 191 current = current.DirName();
184 } 192 }
185 193
186 MountMap::const_iterator info_it = mount_map_.find(current.value()); 194 MountMap::const_iterator info_it = mount_map_.find(current.value());
187 if (info_it == mount_map_.end()) 195 if (info_it == mount_map_.end())
188 return false; 196 return false;
189 197
190 if (device_info) 198 if (device_info)
191 *device_info = info_it->second; 199 *device_info = info_it->second.storage_info;
192 return true; 200 return true;
193 } 201 }
194 202
203 uint64 RemovableDeviceNotificationsCros::GetStorageSize(
204 const std::string& device_location) const {
205 MountMap::const_iterator info_it = mount_map_.find(device_location);
206 return (info_it != mount_map_.end()) ?
207 info_it->second.storage_size_in_bytes : 0;
208 }
209
195 void RemovableDeviceNotificationsCros::CheckMountedPathOnFileThread( 210 void RemovableDeviceNotificationsCros::CheckMountedPathOnFileThread(
196 const disks::DiskMountManager::MountPointInfo& mount_info) { 211 const disks::DiskMountManager::MountPointInfo& mount_info) {
197 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE)); 212 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE));
198 213
199 bool has_dcim = chrome::IsMediaDevice(mount_info.mount_path); 214 bool has_dcim = chrome::IsMediaDevice(mount_info.mount_path);
200 215
201 BrowserThread::PostTask( 216 BrowserThread::PostTask(
202 BrowserThread::UI, FROM_HERE, 217 BrowserThread::UI, FROM_HERE,
203 base::Bind(&RemovableDeviceNotificationsCros::AddMountedPathOnUIThread, 218 base::Bind(&RemovableDeviceNotificationsCros::AddMountedPathOnUIThread,
204 this, mount_info, has_dcim)); 219 this, mount_info, has_dcim));
205 } 220 }
206 221
207 void RemovableDeviceNotificationsCros::AddMountedPathOnUIThread( 222 void RemovableDeviceNotificationsCros::AddMountedPathOnUIThread(
208 const disks::DiskMountManager::MountPointInfo& mount_info, bool has_dcim) { 223 const disks::DiskMountManager::MountPointInfo& mount_info, bool has_dcim) {
209 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); 224 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI));
210 225
211 if (ContainsKey(mount_map_, mount_info.mount_path)) { 226 if (ContainsKey(mount_map_, mount_info.mount_path)) {
212 // CheckExistingMountPointsOnUIThread() added the mount point information 227 // CheckExistingMountPointsOnUIThread() added the mount point information
213 // in the map before the device attached handler is called. Therefore, an 228 // in the map before the device attached handler is called. Therefore, an
214 // entry for the device already exists in the map. 229 // entry for the device already exists in the map.
215 return; 230 return;
216 } 231 }
217 232
218 // Get the media device uuid and label if exists. 233 // Get the media device uuid and label if exists.
219 std::string unique_id; 234 std::string unique_id;
220 string16 device_label; 235 string16 device_label;
221 if (!GetDeviceInfo(mount_info.source_path, &unique_id, &device_label)) 236 uint64 storage_size_in_bytes;
237 if (!GetDeviceInfo(mount_info.source_path, &unique_id, &device_label,
238 &storage_size_in_bytes))
222 return; 239 return;
223 240
224 // Keep track of device uuid and label, to see how often we receive empty 241 // Keep track of device uuid and label, to see how often we receive empty
225 // values. 242 // values.
226 MediaStorageUtil::RecordDeviceInfoHistogram(true, unique_id, device_label); 243 chrome::MediaStorageUtil::RecordDeviceInfoHistogram(true, unique_id,
244 device_label);
227 if (unique_id.empty() || device_label.empty()) 245 if (unique_id.empty() || device_label.empty())
228 return; 246 return;
229 247
230 MediaStorageUtil::Type type = has_dcim ? 248 chrome::MediaStorageUtil::Type type = has_dcim ?
231 MediaStorageUtil::REMOVABLE_MASS_STORAGE_WITH_DCIM : 249 chrome::MediaStorageUtil::REMOVABLE_MASS_STORAGE_WITH_DCIM :
232 MediaStorageUtil::REMOVABLE_MASS_STORAGE_NO_DCIM; 250 chrome::MediaStorageUtil::REMOVABLE_MASS_STORAGE_NO_DCIM;
233 251
234 std::string device_id = chrome::MediaStorageUtil::MakeDeviceId(type, 252 std::string device_id = chrome::MediaStorageUtil::MakeDeviceId(type,
235 unique_id); 253 unique_id);
236 SystemMonitor::RemovableStorageInfo info(device_id, device_label, 254 StorageObjectInfo object_info = {
237 mount_info.mount_path); 255 base::SystemMonitor::RemovableStorageInfo(device_id, device_label,
238 mount_map_.insert(std::make_pair(mount_info.mount_path, info)); 256 mount_info.mount_path),
257 storage_size_in_bytes
258 };
259 mount_map_.insert(std::make_pair(mount_info.mount_path, object_info));
239 SystemMonitor::Get()->ProcessRemovableStorageAttached( 260 SystemMonitor::Get()->ProcessRemovableStorageAttached(
240 device_id, 261 device_id,
241 device_label, 262 chrome::GetDisplayNameForDevice(storage_size_in_bytes, device_label),
242 mount_info.mount_path); 263 mount_info.mount_path);
243 } 264 }
244 265
245 } // namespace chrome 266 } // namespace chromeos
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698