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

Unified Diff: chrome/browser/extensions/api/media_galleries_private/media_galleries_private_api.cc

Issue 13063004: Method to get Media Galleries handlers in MediaGalleriesPrivateApi. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed comments. Created 7 years, 9 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/extensions/api/media_galleries_private/media_galleries_private_api.cc
diff --git a/chrome/browser/extensions/api/media_galleries_private/media_galleries_private_api.cc b/chrome/browser/extensions/api/media_galleries_private/media_galleries_private_api.cc
index cb953f8745c6867abb8ea6ccbf0f0648e0a8bd65..d84c36dafeab76da0b0f4c4177db40603381d0f5 100644
--- a/chrome/browser/extensions/api/media_galleries_private/media_galleries_private_api.cc
+++ b/chrome/browser/extensions/api/media_galleries_private/media_galleries_private_api.cc
@@ -16,10 +16,12 @@
#include "chrome/browser/extensions/event_names.h"
#include "chrome/browser/extensions/event_router.h"
#include "chrome/browser/extensions/extension_function.h"
+#include "chrome/browser/extensions/extension_service.h"
#include "chrome/browser/extensions/extension_system.h"
#include "chrome/browser/extensions/media_galleries_handler.h"
#include "chrome/browser/media_galleries/media_file_system_registry.h"
#include "chrome/browser/media_galleries/media_galleries_preferences.h"
+#include "chrome/browser/profiles/profile.h"
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/render_view_host.h"
@@ -350,4 +352,54 @@ void MediaGalleriesPrivateEjectDeviceFunction::HandleResponse(
SendResponse(true);
}
+///////////////////////////////////////////////////////////////////////////////
+// MediaGalleriesPrivateGetHandlersFunction //
+///////////////////////////////////////////////////////////////////////////////
+
+MediaGalleriesPrivateGetHandlersFunction::
+~MediaGalleriesPrivateGetHandlersFunction() {
+}
+
+bool MediaGalleriesPrivateGetHandlersFunction::RunImpl() {
+ DCHECK(content::BrowserThread::CurrentlyOn(content::BrowserThread::UI));
+
+ ExtensionService* service =
+ extensions::ExtensionSystem::Get(profile_)->extension_service();
+ DCHECK(service);
+
+ ListValue* result_list = new ListValue();
+
+ for (ExtensionSet::const_iterator iter = service->extensions()->begin();
+ iter != service->extensions()->end();
+ ++iter) {
+ const Extension* extension = *iter;
+ if (profile_->IsOffTheRecord() &&
+ !service->IsIncognitoEnabled(extension->id()))
+ continue;
+
+ MediaGalleriesHandler::List* handler_list =
+ MediaGalleriesHandler::GetHandlers(extension);
+ if (!handler_list)
+ continue;
+
+ for (MediaGalleriesHandler::List::const_iterator action_iter =
+ handler_list->begin();
+ action_iter != handler_list->end();
+ ++action_iter) {
+ const MediaGalleriesHandler* action = action_iter->get();
+ DictionaryValue* handler = new DictionaryValue();
+ handler->SetString("extensionId", action->extension_id());
+ handler->SetString("id", action->id());
+ handler->SetString("title", action->title());
+ handler->SetString("iconUrl", action->icon_path());
+ result_list->Append(handler);
+ }
+ }
+
+ SetResult(result_list);
+ SendResponse(true);
+
+ return true;
+}
+
} // namespace extensions

Powered by Google App Engine
This is Rietveld 408576698