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

Side by Side Diff: chrome/browser/media_galleries/fileapi/device_media_async_file_util.cc

Issue 12703012: Have media gallery (through native media file util) use MIME sniffer (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed comments about MIME sniffer. Created 7 years, 7 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2013 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/media_galleries/fileapi/device_media_async_file_util.h" 5 #include "chrome/browser/media_galleries/fileapi/device_media_async_file_util.h"
6 6
7 #include "base/callback.h" 7 #include "base/callback.h"
8 #include "base/file_util.h" 8 #include "base/file_util.h"
9 #include "base/single_thread_task_runner.h" 9 #include "base/single_thread_task_runner.h"
10 #include "chrome/browser/media_galleries/fileapi/filtering_file_enumerator.h" 10 #include "chrome/browser/media_galleries/fileapi/filtering_file_enumerator.h"
11 #include "chrome/browser/media_galleries/fileapi/media_file_system_mount_point_p rovider.h" 11 #include "chrome/browser/media_galleries/fileapi/media_file_system_mount_point_p rovider.h"
12 #include "chrome/browser/media_galleries/fileapi/media_path_filter.h" 12 #include "chrome/browser/media_galleries/fileapi/media_path_filter.h"
13 #include "chrome/browser/media_galleries/fileapi/mtp_device_async_delegate.h" 13 #include "chrome/browser/media_galleries/fileapi/mtp_device_async_delegate.h"
14 #include "chrome/browser/media_galleries/fileapi/mtp_device_map_service.h" 14 #include "chrome/browser/media_galleries/fileapi/mtp_device_map_service.h"
15 #include "chrome/browser/media_galleries/fileapi/native_media_file_util.h"
15 #include "webkit/blob/shareable_file_reference.h" 16 #include "webkit/blob/shareable_file_reference.h"
16 #include "webkit/fileapi/file_system_context.h" 17 #include "webkit/fileapi/file_system_context.h"
17 #include "webkit/fileapi/file_system_operation_context.h" 18 #include "webkit/fileapi/file_system_operation_context.h"
18 #include "webkit/fileapi/file_system_task_runners.h" 19 #include "webkit/fileapi/file_system_task_runners.h"
19 #include "webkit/fileapi/file_system_url.h" 20 #include "webkit/fileapi/file_system_url.h"
20 #include "webkit/fileapi/isolated_context.h" 21 #include "webkit/fileapi/isolated_context.h"
22 #include "webkit/fileapi/native_file_util.h"
21 23
22 using fileapi::FileSystemOperationContext; 24 using fileapi::FileSystemOperationContext;
23 using fileapi::FileSystemURL; 25 using fileapi::FileSystemURL;
24 using webkit_blob::ShareableFileReference; 26 using webkit_blob::ShareableFileReference;
25 27
26 namespace chrome { 28 namespace chrome {
27 29
28 namespace { 30 namespace {
29 31
30 const base::FilePath::CharType kDeviceMediaAsyncFileUtilTempDir[] = 32 const base::FilePath::CharType kDeviceMediaAsyncFileUtilTempDir[] =
(...skipping 29 matching lines...) Expand all
60 profile_path.Append(kDeviceMediaAsyncFileUtilTempDir); 62 profile_path.Append(kDeviceMediaAsyncFileUtilTempDir);
61 if (!file_util::CreateDirectory(isolated_media_file_system_dir_path) || 63 if (!file_util::CreateDirectory(isolated_media_file_system_dir_path) ||
62 !file_util::CreateTemporaryFileInDir(isolated_media_file_system_dir_path, 64 !file_util::CreateTemporaryFileInDir(isolated_media_file_system_dir_path,
63 snapshot_file_path)) { 65 snapshot_file_path)) {
64 LOG(WARNING) << "Could not create media snapshot file " 66 LOG(WARNING) << "Could not create media snapshot file "
65 << isolated_media_file_system_dir_path.value(); 67 << isolated_media_file_system_dir_path.value();
66 *snapshot_file_path = base::FilePath(); 68 *snapshot_file_path = base::FilePath();
67 } 69 }
68 } 70 }
69 71
72 void CheckMediaFile(
73 const base::FilePath& file_path,
74 base::PlatformFileError* error) {
75 *error = NativeMediaFileUtil::IsMediaFile(file_path);
76 if (*error == base::PLATFORM_FILE_ERROR_SECURITY)
vandebo (ex-Chrome) 2013/04/30 21:20:36 nit: {}'s because the body is multi line.
Kevin Bailey 2013/05/02 00:54:02 Removed function.
77 // It exists but we reject it. Try to clean up.
78 fileapi::NativeFileUtil::DeleteFile(file_path);
79 }
80
70 } // namespace 81 } // namespace
71 82
72 DeviceMediaAsyncFileUtil::~DeviceMediaAsyncFileUtil() { 83 DeviceMediaAsyncFileUtil::~DeviceMediaAsyncFileUtil() {
73 } 84 }
74 85
75 // static 86 // static
76 DeviceMediaAsyncFileUtil* DeviceMediaAsyncFileUtil::Create( 87 DeviceMediaAsyncFileUtil* DeviceMediaAsyncFileUtil::Create(
77 const base::FilePath& profile_path) { 88 const base::FilePath& profile_path) {
78 DCHECK(!profile_path.empty()); 89 DCHECK(!profile_path.empty());
79 return new DeviceMediaAsyncFileUtil(profile_path); 90 return new DeviceMediaAsyncFileUtil(profile_path);
(...skipping 229 matching lines...) Expand 10 before | Expand all | Expand 10 after
309 callback.Run(error, AsyncFileUtil::EntryList(), false /*no more*/); 320 callback.Run(error, AsyncFileUtil::EntryList(), false /*no more*/);
310 } 321 }
311 322
312 void DeviceMediaAsyncFileUtil::OnDidCreateSnapshotFile( 323 void DeviceMediaAsyncFileUtil::OnDidCreateSnapshotFile(
313 const AsyncFileUtil::CreateSnapshotFileCallback& callback, 324 const AsyncFileUtil::CreateSnapshotFileCallback& callback,
314 base::SequencedTaskRunner* media_task_runner, 325 base::SequencedTaskRunner* media_task_runner,
315 const base::PlatformFileInfo& file_info, 326 const base::PlatformFileInfo& file_info,
316 const base::FilePath& platform_path) { 327 const base::FilePath& platform_path) {
317 if (callback.is_null()) 328 if (callback.is_null())
318 return; 329 return;
319 callback.Run(base::PLATFORM_FILE_OK, file_info, platform_path, 330 base::PlatformFileError* error = new base::PlatformFileError;
320 ShareableFileReference::GetOrCreate( 331 media_task_runner->PostTaskAndReply(
321 platform_path, 332 FROM_HERE,
322 ShareableFileReference::DELETE_ON_FINAL_RELEASE, 333 base::Bind(&CheckMediaFile, platform_path,
323 media_task_runner)); 334 base::Unretained(error)),
335 base::Bind(&DeviceMediaAsyncFileUtil::OnDidCheckMediaRunTask,
336 weak_ptr_factory_.GetWeakPtr(),
337 callback, base::Unretained(media_task_runner),
kinuko 2013/05/01 02:03:46 Please pass media_task_runner as a refptr, i.e. m
Kevin Bailey 2013/05/02 00:54:02 Done. It's unfortunate that it doesn't do that aut
338 file_info, platform_path, base::Owned(error)));
kinuko 2013/05/01 02:03:46 nit: You can create a ShareableFileReference earli
Kevin Bailey 2013/05/02 00:54:02 I moved the GetOrCreate upstream but it seems like
339 }
340
341 void DeviceMediaAsyncFileUtil::OnDidCheckMediaRunTask(
342 const AsyncFileUtil::CreateSnapshotFileCallback& callback,
343 base::SequencedTaskRunner* media_task_runner,
344 const base::PlatformFileInfo& file_info,
345 const base::FilePath& platform_path,
346 base::PlatformFileError* error) {
347 // really should be an assertion
348 if (callback.is_null())
349 return;
350 if (*error == base::PLATFORM_FILE_OK) {
351 callback.Run(base::PLATFORM_FILE_OK, file_info, platform_path,
352 ShareableFileReference::GetOrCreate(
353 platform_path,
354 ShareableFileReference::DELETE_ON_FINAL_RELEASE,
355 media_task_runner));
356 } else {
357 callback.Run(*error, file_info, platform_path,
358 scoped_refptr<ShareableFileReference>());
359 }
324 } 360 }
325 361
326 void DeviceMediaAsyncFileUtil::OnCreateSnapshotFileError( 362 void DeviceMediaAsyncFileUtil::OnCreateSnapshotFileError(
327 const AsyncFileUtil::CreateSnapshotFileCallback& callback, 363 const AsyncFileUtil::CreateSnapshotFileCallback& callback,
328 base::PlatformFileError error) { 364 base::PlatformFileError error) {
329 if (!callback.is_null()) 365 if (!callback.is_null())
330 callback.Run(error, base::PlatformFileInfo(), base::FilePath(), 366 callback.Run(error, base::PlatformFileInfo(), base::FilePath(),
331 scoped_refptr<ShareableFileReference>()); 367 scoped_refptr<ShareableFileReference>());
332 } 368 }
333 369
(...skipping 18 matching lines...) Expand all
352 base::Bind(&DeviceMediaAsyncFileUtil::OnDidCreateSnapshotFile, 388 base::Bind(&DeviceMediaAsyncFileUtil::OnDidCreateSnapshotFile,
353 weak_ptr_factory_.GetWeakPtr(), 389 weak_ptr_factory_.GetWeakPtr(),
354 callback, 390 callback,
355 make_scoped_refptr(context->task_runner())), 391 make_scoped_refptr(context->task_runner())),
356 base::Bind(&DeviceMediaAsyncFileUtil::OnCreateSnapshotFileError, 392 base::Bind(&DeviceMediaAsyncFileUtil::OnCreateSnapshotFileError,
357 weak_ptr_factory_.GetWeakPtr(), 393 weak_ptr_factory_.GetWeakPtr(),
358 callback)); 394 callback));
359 } 395 }
360 396
361 } // namespace chrome 397 } // namespace chrome
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698