| 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 // Implements the Chrome Extensions Media Galleries API. | 5 // Implements the Chrome Extensions Media Galleries API. |
| 6 | 6 |
| 7 #include "chrome/browser/extensions/api/media_galleries/media_galleries_api.h" | 7 #include "chrome/browser/extensions/api/media_galleries/media_galleries_api.h" |
| 8 | 8 |
| 9 #include <set> | 9 #include <set> |
| 10 #include <string> | 10 #include <string> |
| (...skipping 21 matching lines...) Expand all Loading... |
| 32 #include "content/public/browser/child_process_security_policy.h" | 32 #include "content/public/browser/child_process_security_policy.h" |
| 33 #include "content/public/browser/render_process_host.h" | 33 #include "content/public/browser/render_process_host.h" |
| 34 #include "content/public/browser/render_view_host.h" | 34 #include "content/public/browser/render_view_host.h" |
| 35 #include "content/public/browser/web_contents.h" | 35 #include "content/public/browser/web_contents.h" |
| 36 | 36 |
| 37 #if defined(OS_WIN) | 37 #if defined(OS_WIN) |
| 38 #include "base/strings/sys_string_conversions.h" | 38 #include "base/strings/sys_string_conversions.h" |
| 39 #endif | 39 #endif |
| 40 | 40 |
| 41 using apps::ShellWindow; | 41 using apps::ShellWindow; |
| 42 using chrome::MediaFileSystemInfo; | |
| 43 using chrome::MediaFileSystemRegistry; | |
| 44 using chrome::MediaFileSystemsCallback; | |
| 45 using content::ChildProcessSecurityPolicy; | 42 using content::ChildProcessSecurityPolicy; |
| 46 using content::WebContents; | 43 using content::WebContents; |
| 47 using web_modal::WebContentsModalDialogManager; | 44 using web_modal::WebContentsModalDialogManager; |
| 48 | 45 |
| 49 namespace MediaGalleries = extensions::api::media_galleries; | 46 namespace MediaGalleries = extensions::api::media_galleries; |
| 50 namespace GetMediaFileSystems = MediaGalleries::GetMediaFileSystems; | 47 namespace GetMediaFileSystems = MediaGalleries::GetMediaFileSystems; |
| 51 | 48 |
| 52 namespace extensions { | 49 namespace extensions { |
| 53 | 50 |
| 54 namespace { | 51 namespace { |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 86 scoped_ptr<GetMediaFileSystems::Params> params( | 83 scoped_ptr<GetMediaFileSystems::Params> params( |
| 87 GetMediaFileSystems::Params::Create(*args_)); | 84 GetMediaFileSystems::Params::Create(*args_)); |
| 88 EXTENSION_FUNCTION_VALIDATE(params.get()); | 85 EXTENSION_FUNCTION_VALIDATE(params.get()); |
| 89 MediaGalleries::GetMediaFileSystemsInteractivity interactive = | 86 MediaGalleries::GetMediaFileSystemsInteractivity interactive = |
| 90 MediaGalleries::GET_MEDIA_FILE_SYSTEMS_INTERACTIVITY_NO; | 87 MediaGalleries::GET_MEDIA_FILE_SYSTEMS_INTERACTIVITY_NO; |
| 91 if (params->details.get() && params->details->interactive != MediaGalleries:: | 88 if (params->details.get() && params->details->interactive != MediaGalleries:: |
| 92 GET_MEDIA_FILE_SYSTEMS_INTERACTIVITY_NONE) { | 89 GET_MEDIA_FILE_SYSTEMS_INTERACTIVITY_NONE) { |
| 93 interactive = params->details->interactive; | 90 interactive = params->details->interactive; |
| 94 } | 91 } |
| 95 | 92 |
| 96 chrome::StorageMonitor::GetInstance()->EnsureInitialized(base::Bind( | 93 StorageMonitor::GetInstance()->EnsureInitialized(base::Bind( |
| 97 &MediaGalleriesGetMediaFileSystemsFunction::OnStorageMonitorInit, | 94 &MediaGalleriesGetMediaFileSystemsFunction::OnStorageMonitorInit, |
| 98 this, | 95 this, |
| 99 interactive)); | 96 interactive)); |
| 100 return true; | 97 return true; |
| 101 } | 98 } |
| 102 | 99 |
| 103 void MediaGalleriesGetMediaFileSystemsFunction::OnStorageMonitorInit( | 100 void MediaGalleriesGetMediaFileSystemsFunction::OnStorageMonitorInit( |
| 104 MediaGalleries::GetMediaFileSystemsInteractivity interactive) { | 101 MediaGalleries::GetMediaFileSystemsInteractivity interactive) { |
| 105 switch (interactive) { | 102 switch (interactive) { |
| 106 case MediaGalleries::GET_MEDIA_FILE_SYSTEMS_INTERACTIVITY_YES: { | 103 case MediaGalleries::GET_MEDIA_FILE_SYSTEMS_INTERACTIVITY_YES: { |
| (...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 221 } else { | 218 } else { |
| 222 // Abort showing the dialog. TODO(estade) Perhaps return an error instead. | 219 // Abort showing the dialog. TODO(estade) Perhaps return an error instead. |
| 223 GetAndReturnGalleries(); | 220 GetAndReturnGalleries(); |
| 224 return; | 221 return; |
| 225 } | 222 } |
| 226 } | 223 } |
| 227 | 224 |
| 228 // Controller will delete itself. | 225 // Controller will delete itself. |
| 229 base::Closure cb = base::Bind( | 226 base::Closure cb = base::Bind( |
| 230 &MediaGalleriesGetMediaFileSystemsFunction::GetAndReturnGalleries, this); | 227 &MediaGalleriesGetMediaFileSystemsFunction::GetAndReturnGalleries, this); |
| 231 new chrome::MediaGalleriesDialogController(contents, *GetExtension(), cb); | 228 new MediaGalleriesDialogController(contents, *GetExtension(), cb); |
| 232 } | 229 } |
| 233 | 230 |
| 234 void MediaGalleriesGetMediaFileSystemsFunction::GetMediaFileSystemsForExtension( | 231 void MediaGalleriesGetMediaFileSystemsFunction::GetMediaFileSystemsForExtension( |
| 235 const chrome::MediaFileSystemsCallback& cb) { | 232 const MediaFileSystemsCallback& cb) { |
| 236 if (!render_view_host()) { | 233 if (!render_view_host()) { |
| 237 cb.Run(std::vector<MediaFileSystemInfo>()); | 234 cb.Run(std::vector<MediaFileSystemInfo>()); |
| 238 return; | 235 return; |
| 239 } | 236 } |
| 240 | 237 |
| 241 DCHECK(chrome::StorageMonitor::GetInstance()->IsInitialized()); | 238 DCHECK(StorageMonitor::GetInstance()->IsInitialized()); |
| 242 MediaFileSystemRegistry* registry = | 239 MediaFileSystemRegistry* registry = |
| 243 g_browser_process->media_file_system_registry(); | 240 g_browser_process->media_file_system_registry(); |
| 244 registry->GetMediaFileSystemsForExtension( | 241 registry->GetMediaFileSystemsForExtension( |
| 245 render_view_host(), GetExtension(), cb); | 242 render_view_host(), GetExtension(), cb); |
| 246 } | 243 } |
| 247 | 244 |
| 248 } // namespace extensions | 245 } // namespace extensions |
| OLD | NEW |