use mediastreamdevicescontroller from brightray to enumerate available devices
authorRobo <hop2deep@gmail.com>
Mon, 1 Feb 2016 12:15:53 +0000 (17:45 +0530)
committerRobo <hop2deep@gmail.com>
Mon, 1 Feb 2016 12:15:53 +0000 (17:45 +0530)
atom/browser/api/atom_api_session.cc
atom/browser/web_contents_permission_helper.cc

index b0c9914..b903240 100644 (file)
@@ -400,7 +400,7 @@ void Session::SetCertVerifyProc(v8::Local<v8::Value> val,
 }
 
 void Session::SetPermissionRequestHandler(v8::Local<v8::Value> val,
-                                              mate::Arguments* args) {
+                                          mate::Arguments* args) {
   AtomPermissionManager::RequestHandler handler;
   if (!(val->IsNull() || mate::ConvertFromV8(args->isolate(), val, &handler))) {
     args->ThrowError("Must pass null or function");
index 6cade6a..f5ce414 100644 (file)
@@ -7,8 +7,8 @@
 #include <string>
 
 #include "atom/browser/atom_permission_manager.h"
+#include "brightray/browser/media/media_stream_devices_controller.h"
 #include "content/public/browser/browser_context.h"
-#include "content/public/browser/media_capture_devices.h"
 #include "content/public/browser/render_process_host.h"
 
 DEFINE_WEB_CONTENTS_USER_DATA_KEY(atom::WebContentsPermissionHelper);
@@ -17,53 +17,15 @@ namespace atom {
 
 namespace {
 
-const content::MediaStreamDevice* FindDeviceWithId(
-    const content::MediaStreamDevices& devices,
-    const std::string& device_id) {
-  if (device_id.empty())
-    return &(*devices.begin());
-  for (const auto& iter : devices)
-    if (iter.id == device_id)
-      return &(iter);
-  return nullptr;
-}
-
 void MediaAccessAllowed(
     const content::MediaStreamRequest& request,
     const content::MediaResponseCallback& callback,
     bool allowed) {
-  if (!allowed) {
-    callback.Run(content::MediaStreamDevices(),
-                 content::MEDIA_DEVICE_PERMISSION_DENIED,
-                 scoped_ptr<content::MediaStreamUI>());
-    return;
-  }
-
-  content::MediaStreamDevices devices;
-  content::MediaStreamRequestResult result = content::MEDIA_DEVICE_NO_HARDWARE;
-
-  if (request.audio_type == content::MEDIA_DEVICE_AUDIO_CAPTURE) {
-    const content::MediaStreamDevices& audio_devices =
-        content::MediaCaptureDevices::GetInstance()->GetAudioCaptureDevices();
-    const content::MediaStreamDevice* audio_device =
-        FindDeviceWithId(audio_devices, request.requested_audio_device_id);
-    if (audio_device)
-      devices.push_back(*audio_device);
-  }
-
-  if (request.video_type == content::MEDIA_DEVICE_VIDEO_CAPTURE) {
-    const content::MediaStreamDevices& video_devices =
-        content::MediaCaptureDevices::GetInstance()->GetVideoCaptureDevices();
-    const content::MediaStreamDevice* video_device =
-        FindDeviceWithId(video_devices, request.requested_video_device_id);
-    if (video_device)
-      devices.push_back(*video_device);
-  }
-
-  if (!devices.empty())
-    result = content::MEDIA_DEVICE_OK;
-
-  callback.Run(devices, result, scoped_ptr<content::MediaStreamUI>());
+  brightray::MediaStreamDevicesController controller(request, callback);
+  if (allowed)
+    controller.Accept();
+  else
+    controller.Deny(content::MEDIA_DEVICE_PERMISSION_DENIED);
 }
 
 void OnPointerLockResponse(content::WebContents* web_contents, bool allowed) {