diff --git a/atom/browser/api/atom_api_session.cc b/atom/browser/api/atom_api_session.cc index b0c99141f75b..b9032409e463 100644 --- a/atom/browser/api/atom_api_session.cc +++ b/atom/browser/api/atom_api_session.cc @@ -400,7 +400,7 @@ void Session::SetCertVerifyProc(v8::Local val, } void Session::SetPermissionRequestHandler(v8::Local 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"); diff --git a/atom/browser/web_contents_permission_helper.cc b/atom/browser/web_contents_permission_helper.cc index 6cade6aa3526..f5ce414dd2ca 100644 --- a/atom/browser/web_contents_permission_helper.cc +++ b/atom/browser/web_contents_permission_helper.cc @@ -7,8 +7,8 @@ #include #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()); - 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()); + 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) {