Chromium Code Reviews| Index: chrome/browser/media/desktop_capture_access_handler.cc |
| diff --git a/chrome/browser/media/desktop_capture_access_handler.cc b/chrome/browser/media/desktop_capture_access_handler.cc |
| index 66f37c09d6c5595f9fe0f41566df0fb867f57727..285a4435e26bf591e3411bbcee65e422dc9a57cf 100644 |
| --- a/chrome/browser/media/desktop_capture_access_handler.cc |
| +++ b/chrome/browser/media/desktop_capture_access_handler.cc |
| @@ -11,6 +11,7 @@ |
| #include "base/strings/string_util.h" |
| #include "base/strings/utf_string_conversions.h" |
| #include "build/build_config.h" |
| +#include "chrome/browser/content_settings/host_content_settings_map_factory.h" |
| #include "chrome/browser/media/desktop_streams_registry.h" |
| #include "chrome/browser/media/media_capture_devices_dispatcher.h" |
| #include "chrome/browser/ui/browser.h" |
| @@ -20,6 +21,8 @@ |
| #include "chrome/browser/ui/simple_message_box.h" |
| #include "chrome/common/chrome_switches.h" |
| #include "chrome/grit/generated_resources.h" |
| +#include "components/content_settings/core/browser/host_content_settings_map.h" |
| +#include "components/content_settings/core/common/content_settings.h" |
| #include "content/public/browser/browser_thread.h" |
| #include "content/public/browser/desktop_media_id.h" |
| #include "content/public/browser/render_frame_host.h" |
| @@ -343,11 +346,34 @@ void DesktopCaptureAccessHandler::HandleRequest( |
| loopback_audio_supported = true; |
| #endif |
| + bool loopback_audio_permitted = true; |
|
GeorgeZ
2016/01/15 16:37:55
Maybe use this flag for all audio share (such as t
qiangchen
2016/01/15 18:19:40
Done.
|
| + |
| + const bool audio_support_flag_for_desktop_share = |
| + base::CommandLine::ForCurrentProcess()->HasSwitch( |
| + switches::kEnableAudioSupportForDesktopShare); |
| + |
| + if (audio_support_flag_for_desktop_share) { |
| + Profile* profile = |
| + Profile::FromBrowserContext(web_contents->GetBrowserContext()); |
| + |
| + GURL origin(web_contents->GetLastCommittedURL().GetOrigin()); |
| + |
| + ContentSetting result = |
| + HostContentSettingsMapFactory::GetForProfile(profile) |
| + ->GetContentSetting( |
| + origin, origin, |
| + ContentSettingsType::CONTENT_SETTINGS_TYPE_DESKTOP_AUDIO_SHARE, |
| + std::string()); |
| + |
| + loopback_audio_permitted = |
| + (result == ContentSetting::CONTENT_SETTING_ALLOW); |
| + } |
| + |
| // Audio is only supported for screen capture streams. |
| bool capture_audio = |
| (media_id.type == content::DesktopMediaID::TYPE_SCREEN && |
| request.audio_type == content::MEDIA_DESKTOP_AUDIO_CAPTURE && |
| - loopback_audio_supported); |
| + loopback_audio_supported && loopback_audio_permitted); |
| ui = GetDevicesForDesktopCapture(&devices, media_id, capture_audio, true, |
| GetApplicationTitle(web_contents, extension), |