| 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 #ifndef CHROME_BROWSER_UI_MEDIA_STREAM_INFOBAR_DELEGATE_H_ | 5 #ifndef CHROME_BROWSER_UI_MEDIA_STREAM_INFOBAR_DELEGATE_H_ |
| 6 #define CHROME_BROWSER_UI_MEDIA_STREAM_INFOBAR_DELEGATE_H_ | 6 #define CHROME_BROWSER_UI_MEDIA_STREAM_INFOBAR_DELEGATE_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "base/callback.h" | 10 #include "base/callback.h" |
| 11 #include "base/compiler_specific.h" | 11 #include "base/compiler_specific.h" |
| 12 #include "chrome/browser/infobars/infobar_delegate.h" | 12 #include "chrome/browser/infobars/infobar_delegate.h" |
| 13 #include "chrome/browser/media/media_stream_devices_prefs.h" |
| 13 #include "content/public/browser/content_browser_client.h" | 14 #include "content/public/browser/content_browser_client.h" |
| 14 #include "content/public/common/media_stream_request.h" | 15 #include "content/public/common/media_stream_request.h" |
| 15 | 16 |
| 16 class MessageLoop; | 17 class MessageLoop; |
| 18 class PrefService; |
| 17 class TabContents; | 19 class TabContents; |
| 18 typedef TabContents TabContentsWrapper; | 20 typedef TabContents TabContentsWrapper; |
| 19 | 21 |
| 20 // This class configures an infobar shown when a page requests access to a | 22 // This class configures an infobar shown when a page requests access to a |
| 21 // user's microphone and/or video camera. The user is shown a message asking | 23 // user's microphone and/or video camera. The user is shown a message asking |
| 22 // which audio and/or video devices he wishes to use with the current page, and | 24 // which audio and/or video devices he wishes to use with the current page, and |
| 23 // buttons to give access to the selected devices to the page, or to deny access | 25 // buttons to give access to the selected devices to the page, or to deny access |
| 24 // to them. | 26 // to them. |
| 25 class MediaStreamInfoBarDelegate : public InfoBarDelegate { | 27 class MediaStreamInfoBarDelegate : public InfoBarDelegate { |
| 26 public: | 28 public: |
| 27 MediaStreamInfoBarDelegate( | 29 MediaStreamInfoBarDelegate( |
| 28 InfoBarTabHelper* tab_helper, | 30 InfoBarTabHelper* tab_helper, |
| 31 Profile* profile, |
| 29 const content::MediaStreamRequest* request, | 32 const content::MediaStreamRequest* request, |
| 30 const content::MediaResponseCallback& callback); | 33 const content::MediaResponseCallback& callback); |
| 31 | 34 |
| 32 virtual ~MediaStreamInfoBarDelegate(); | 35 virtual ~MediaStreamInfoBarDelegate(); |
| 33 | 36 |
| 34 // These tell whether the user has to select audio and/or video devices. | 37 // These tell whether the user has to select audio and/or video devices. |
| 35 bool has_audio() const { return has_audio_; } | 38 bool has_audio() const { return has_audio_; } |
| 36 bool has_video() const { return has_video_; } | 39 bool has_video() const { return has_video_; } |
| 37 | 40 |
| 38 // Returns lists of audio and/or video devices from which the user will have | 41 // Returns lists of audio and/or video devices from which the user will have |
| 39 // to choose. | 42 // to choose. |
| 40 content::MediaStreamDevices GetAudioDevices() const; | 43 content::MediaStreamDevices GetAudioDevices() const; |
| 41 content::MediaStreamDevices GetVideoDevices() const; | 44 content::MediaStreamDevices GetVideoDevices() const; |
| 42 | 45 |
| 43 // Returns the security origin (e.g. "www.html5rocks.com") at the origin | 46 // Returns the security origin (e.g. "www.html5rocks.com") at the origin |
| 44 // of this request. | 47 // of this request. |
| 45 const GURL& GetSecurityOrigin() const; | 48 const GURL& GetSecurityOrigin() const; |
| 46 | 49 |
| 50 // Returns true if we should show the infobar for this request, otherwise |
| 51 // returns false. |
| 52 bool ShouldShowInfoBar(); |
| 53 |
| 47 // Callbacks to handle accepting devices or denying the request. |audio_id| | 54 // Callbacks to handle accepting devices or denying the request. |audio_id| |
| 48 // and |video_id| are the device IDs of the accepted audio and video devices. | 55 // and |video_id| are the device IDs of the accepted audio and video devices. |
| 56 // |always_allow| is true if the option t |
| 49 // The |audio_id| or |video_id| values are ignored if the request did not ask | 57 // The |audio_id| or |video_id| values are ignored if the request did not ask |
| 50 // for audio or video devices respectively. | 58 // for audio or video devices respectively. |
| 51 void Accept(const std::string& audio_id, const std::string& video_id); | 59 void Accept(const std::string& audio_id, const std::string& video_id, |
| 60 bool always_allow); |
| 52 void Deny(); | 61 void Deny(); |
| 53 | 62 |
| 54 private: | 63 private: |
| 64 // Gets an array of selected devices and add them to |devices| array. |
| 65 void GetDevicesWithId(const std::string& audio_id, |
| 66 const std::string& video_id, |
| 67 content::MediaStreamDevices* devices); |
| 68 |
| 55 // Finds a device in the current request with the specified |id| and |type|, | 69 // Finds a device in the current request with the specified |id| and |type|, |
| 56 // and adds it to the |devices| array. | 70 // and adds it to the |devices| array. |
| 57 void AddDeviceWithId(content::MediaStreamDeviceType type, | 71 void AddDeviceWithId(content::MediaStreamDeviceType type, |
| 58 const std::string& id, | 72 const std::string& id, |
| 59 content::MediaStreamDevices* devices); | 73 content::MediaStreamDevices* devices); |
| 60 | 74 |
| 75 // Gets the always allowed audio and/or video devices. This function is called |
| 76 // by ShouldShowInfoBar(). |
| 77 // Returns true if the always allowed devices are available for this |
| 78 // request, otherwise returns false. |
| 79 bool GetAlwaysAllowedDevices(std::string* audio_id, std::string* video_id); |
| 80 |
| 61 // InfoBarDelegate: | 81 // InfoBarDelegate: |
| 62 virtual InfoBar* CreateInfoBar(InfoBarTabHelper* owner) OVERRIDE; | 82 virtual InfoBar* CreateInfoBar(InfoBarTabHelper* owner) OVERRIDE; |
| 63 virtual void InfoBarDismissed() OVERRIDE; | 83 virtual void InfoBarDismissed() OVERRIDE; |
| 64 virtual gfx::Image* GetIcon() const OVERRIDE; | 84 virtual gfx::Image* GetIcon() const OVERRIDE; |
| 65 virtual Type GetInfoBarType() const OVERRIDE; | 85 virtual Type GetInfoBarType() const OVERRIDE; |
| 66 virtual MediaStreamInfoBarDelegate* AsMediaStreamInfoBarDelegate() OVERRIDE; | 86 virtual MediaStreamInfoBarDelegate* AsMediaStreamInfoBarDelegate() OVERRIDE; |
| 67 | 87 |
| 68 // The original request for access to devices. | 88 // The original request for access to devices. |
| 69 const content::MediaStreamRequest* request_; | 89 const content::MediaStreamRequest* request_; |
| 70 | 90 |
| 71 // The callback that needs to be Run to notify WebRTC of whether access to | 91 // The callback that needs to be Run to notify WebRTC of whether access to |
| 72 // audio/video devices was granted or not. | 92 // audio/video devices was granted or not. |
| 73 content::MediaResponseCallback callback_; | 93 content::MediaResponseCallback callback_; |
| 74 | 94 |
| 75 // Whether the request is for audio and/or video devices. | 95 // Whether the request is for audio and/or video devices. |
| 76 bool has_audio_; | 96 bool has_audio_; |
| 77 bool has_video_; | 97 bool has_video_; |
| 78 | 98 |
| 99 private: |
| 100 // The media stram capture devices related preferences. |
| 101 MediaStreamDevicesPrefs prefs_; |
| 102 |
| 79 DISALLOW_COPY_AND_ASSIGN(MediaStreamInfoBarDelegate); | 103 DISALLOW_COPY_AND_ASSIGN(MediaStreamInfoBarDelegate); |
| 80 }; | 104 }; |
| 81 | 105 |
| 82 #endif // CHROME_BROWSER_UI_MEDIA_STREAM_INFOBAR_DELEGATE_H_ | 106 #endif // CHROME_BROWSER_UI_MEDIA_STREAM_INFOBAR_DELEGATE_H_ |
| OLD | NEW |