Chromium Code Reviews| 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 CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_ | 5 #ifndef CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_ |
| 6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_ | 6 #define CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_ |
| 7 | 7 |
| 8 #include <list> | 8 #include <list> |
| 9 #include <map> | 9 #include <map> |
| 10 #include <string> | 10 #include <string> |
| 11 #include <utility> | 11 #include <utility> |
| 12 | 12 |
| 13 #include "base/basictypes.h" | 13 #include "base/basictypes.h" |
| 14 #include "base/compiler_specific.h" | 14 #include "base/compiler_specific.h" |
| 15 #include "base/gtest_prod_util.h" | 15 #include "base/gtest_prod_util.h" |
| 16 #include "base/memory/ref_counted.h" | 16 #include "base/memory/ref_counted.h" |
| 17 #include "base/memory/scoped_ptr.h" | 17 #include "base/memory/scoped_ptr.h" |
| 18 #include "base/memory/weak_ptr.h" | 18 #include "base/memory/weak_ptr.h" |
| 19 #include "base/message_loop_proxy.h" | 19 #include "base/message_loop_proxy.h" |
| 20 #include "base/threading/non_thread_safe.h" | 20 #include "base/threading/non_thread_safe.h" |
| 21 #include "base/threading/thread.h" | 21 #include "base/threading/thread.h" |
| 22 #include "content/common/content_export.h" | 22 #include "content/common/content_export.h" |
| 23 #include "content/public/renderer/render_view_observer.h" | 23 #include "content/public/renderer/render_view_observer.h" |
| 24 #include "content/renderer/media/media_stream_extra_data.h" | |
| 24 #include "content/renderer/media/media_stream_dispatcher_eventhandler.h" | 25 #include "content/renderer/media/media_stream_dispatcher_eventhandler.h" |
| 25 #include "content/renderer/media/rtc_video_decoder.h" | 26 #include "content/renderer/media/rtc_video_decoder.h" |
| 26 #include "third_party/libjingle/source/talk/app/webrtc/mediastream.h" | 27 #include "third_party/libjingle/source/talk/app/webrtc/mediastream.h" |
| 27 #include "third_party/libjingle/source/talk/base/scoped_ref_ptr.h" | 28 #include "third_party/libjingle/source/talk/base/scoped_ref_ptr.h" |
| 28 #include "third_party/WebKit/Source/WebKit/chromium/public/WebUserMediaClient.h" | 29 #include "third_party/WebKit/Source/WebKit/chromium/public/WebUserMediaClient.h" |
| 29 #include "third_party/WebKit/Source/WebKit/chromium/public/WebUserMediaRequest.h " | 30 #include "third_party/WebKit/Source/WebKit/chromium/public/WebUserMediaRequest.h " |
| 30 #include "webkit/media/media_stream_client.h" | 31 #include "webkit/media/media_stream_client.h" |
| 31 | 32 |
| 32 namespace base { | 33 namespace base { |
| 33 class WaitableEvent; | 34 class WaitableEvent; |
| (...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 80 MediaStreamDispatcher* media_stream_dispatcher, | 81 MediaStreamDispatcher* media_stream_dispatcher, |
| 81 content::P2PSocketDispatcher* p2p_socket_dispatcher, | 82 content::P2PSocketDispatcher* p2p_socket_dispatcher, |
| 82 VideoCaptureImplManager* vc_manager, | 83 VideoCaptureImplManager* vc_manager, |
| 83 MediaStreamDependencyFactory* dependency_factory); | 84 MediaStreamDependencyFactory* dependency_factory); |
| 84 virtual ~MediaStreamImpl(); | 85 virtual ~MediaStreamImpl(); |
| 85 | 86 |
| 86 virtual WebKit::WebPeerConnectionHandler* CreatePeerConnectionHandler( | 87 virtual WebKit::WebPeerConnectionHandler* CreatePeerConnectionHandler( |
| 87 WebKit::WebPeerConnectionHandlerClient* client); | 88 WebKit::WebPeerConnectionHandlerClient* client); |
| 88 virtual WebKit::WebPeerConnection00Handler* CreatePeerConnectionHandlerJsep( | 89 virtual WebKit::WebPeerConnection00Handler* CreatePeerConnectionHandlerJsep( |
| 89 WebKit::WebPeerConnection00HandlerClient* client); | 90 WebKit::WebPeerConnection00HandlerClient* client); |
| 90 virtual void ClosePeerConnection(PeerConnectionHandlerBase* pc_handler); | |
| 91 | 91 |
| 92 virtual webrtc::LocalMediaStreamInterface* GetLocalMediaStream( | 92 virtual void StopLocalMediaStream( |
| 93 const WebKit::WebMediaStreamDescriptor& stream); | 93 const WebKit::WebMediaStreamDescriptor& stream); |
| 94 bool StopLocalMediaStream(const WebKit::WebMediaStreamDescriptor& stream); | 94 // A new MediaStream have been created based on existing tracks. |
| 95 virtual void CreateMediaStream( | |
| 96 WebKit::WebFrame* frame, | |
| 97 WebKit::WebMediaStreamDescriptor* stream); | |
| 95 | 98 |
| 96 // WebKit::WebUserMediaClient implementation | 99 // WebKit::WebUserMediaClient implementation |
| 97 virtual void requestUserMedia( | 100 virtual void requestUserMedia( |
| 98 const WebKit::WebUserMediaRequest& user_media_request, | 101 const WebKit::WebUserMediaRequest& user_media_request, |
| 99 const WebKit::WebVector<WebKit::WebMediaStreamSource>& audio_sources, | 102 const WebKit::WebVector<WebKit::WebMediaStreamSource>& audio_sources, |
| 100 const WebKit::WebVector<WebKit::WebMediaStreamSource>& video_sources) | 103 const WebKit::WebVector<WebKit::WebMediaStreamSource>& video_sources) |
| 101 OVERRIDE; | 104 OVERRIDE; |
| 102 virtual void cancelUserMediaRequest( | 105 virtual void cancelUserMediaRequest( |
| 103 const WebKit::WebUserMediaRequest& user_media_request) OVERRIDE; | 106 const WebKit::WebUserMediaRequest& user_media_request) OVERRIDE; |
| 104 | 107 |
| (...skipping 21 matching lines...) Expand all Loading... | |
| 126 virtual void OnDevicesEnumerationFailed(int request_id) OVERRIDE; | 129 virtual void OnDevicesEnumerationFailed(int request_id) OVERRIDE; |
| 127 virtual void OnDeviceOpened( | 130 virtual void OnDeviceOpened( |
| 128 int request_id, | 131 int request_id, |
| 129 const std::string& label, | 132 const std::string& label, |
| 130 const media_stream::StreamDeviceInfo& device_info) OVERRIDE; | 133 const media_stream::StreamDeviceInfo& device_info) OVERRIDE; |
| 131 virtual void OnDeviceOpenFailed(int request_id) OVERRIDE; | 134 virtual void OnDeviceOpenFailed(int request_id) OVERRIDE; |
| 132 | 135 |
| 133 // content::RenderViewObserver OVERRIDE | 136 // content::RenderViewObserver OVERRIDE |
| 134 virtual void FrameWillClose(WebKit::WebFrame* frame) OVERRIDE; | 137 virtual void FrameWillClose(WebKit::WebFrame* frame) OVERRIDE; |
| 135 | 138 |
| 139 protected: | |
| 140 // This function is virtual for test purposes. A test can override this to | |
| 141 // test requesting local media streams. | |
| 142 virtual void CompleteGetUserMediaRequest( | |
| 143 const WebKit::WebMediaStreamDescriptor& stream, | |
| 144 WebKit::WebUserMediaRequest* request); | |
|
tommi (sloooow) - chröme
2012/05/13 20:08:46
strange indent
perkj_chrome
2012/05/14 11:50:25
Done.
| |
| 145 // This function is virtual for test purposes. | |
| 146 virtual WebKit::WebMediaStreamDescriptor GetMediaStream(const GURL& url); | |
| 147 | |
| 136 private: | 148 private: |
| 137 FRIEND_TEST_ALL_PREFIXES(MediaStreamImplTest, Basic); | |
| 138 FRIEND_TEST_ALL_PREFIXES(MediaStreamImplTest, MultiplePeerConnections); | |
| 139 FRIEND_TEST_ALL_PREFIXES(MediaStreamImplTest, LocalMediaStream); | |
| 140 | |
| 141 class VideoRendererWrapper : public webrtc::VideoRendererWrapperInterface { | 149 class VideoRendererWrapper : public webrtc::VideoRendererWrapperInterface { |
| 142 public: | 150 public: |
| 143 explicit VideoRendererWrapper(RTCVideoDecoder* decoder); | 151 explicit VideoRendererWrapper(RTCVideoDecoder* decoder); |
| 144 virtual cricket::VideoRenderer* renderer() OVERRIDE { | 152 virtual cricket::VideoRenderer* renderer() OVERRIDE { |
| 145 return rtc_video_decoder_.get(); | 153 return rtc_video_decoder_.get(); |
| 146 } | 154 } |
| 147 | 155 |
| 148 protected: | 156 protected: |
| 149 virtual ~VideoRendererWrapper(); | 157 virtual ~VideoRendererWrapper(); |
| 150 | 158 |
| 151 private: | 159 private: |
| 152 scoped_refptr<RTCVideoDecoder> rtc_video_decoder_; | 160 scoped_refptr<RTCVideoDecoder> rtc_video_decoder_; |
| 153 }; | 161 }; |
| 154 | 162 |
| 155 // Structure for storing information about a WebKit request to create a | 163 // Structure for storing information about a WebKit request to create a |
| 156 // MediaStream. | 164 // MediaStream. |
| 157 struct UserMediaRequestInfo { | 165 struct UserMediaRequestInfo { |
| 158 UserMediaRequestInfo() : frame_(NULL), request_() {} | 166 UserMediaRequestInfo() : frame_(NULL), request_() {} |
| 159 UserMediaRequestInfo(WebKit::WebFrame* frame, | 167 UserMediaRequestInfo(WebKit::WebFrame* frame, |
| 160 const WebKit::WebUserMediaRequest& request) | 168 const WebKit::WebUserMediaRequest& request) |
| 161 : frame_(frame), request_(request) {} | 169 : frame_(frame), request_(request) {} |
| 162 WebKit::WebFrame* frame_; // WebFrame that requested the MediaStream. | 170 WebKit::WebFrame* frame_; // WebFrame that requested the MediaStream. |
| 163 WebKit::WebUserMediaRequest request_; | 171 WebKit::WebUserMediaRequest request_; |
| 164 }; | 172 }; |
| 165 typedef std::map<int, UserMediaRequestInfo> MediaRequestMap; | 173 typedef std::map<int, UserMediaRequestInfo> MediaRequestMap; |
| 166 | 174 |
| 167 // We keep a list of the generated local media streams, | 175 // We keep a list of the label and WebFrame of generated local media streams, |
| 168 // so that we can enable and disable individual tracks and add renderers | 176 // so that we can stop them when needed. |
| 169 // when needed. | 177 typedef std::map<std::string, WebKit::WebFrame*> LocalNativeStreamMap; |
| 170 typedef talk_base::scoped_refptr<webrtc::LocalMediaStreamInterface> | 178 typedef talk_base::scoped_refptr<webrtc::LocalMediaStreamInterface> |
| 171 LocalMediaStreamPtr; | 179 LocalNativeStreamPtr; |
| 172 struct LocalMediaStreamInfo { | |
| 173 LocalMediaStreamInfo() : frame_(NULL), stream_() {} | |
| 174 LocalMediaStreamInfo(WebKit::WebFrame* frame, | |
| 175 webrtc::LocalMediaStreamInterface* stream) | |
| 176 : frame_(frame), stream_(stream) {} | |
| 177 ~LocalMediaStreamInfo(); | |
| 178 // WebFrame that requested the Stream. | |
| 179 WebKit::WebFrame* frame_; | |
| 180 // Native representation of a local MediaStream. | |
| 181 LocalMediaStreamPtr stream_; | |
| 182 }; | |
| 183 typedef std::map<std::string, LocalMediaStreamInfo> LocalNativeStreamMap; | |
| 184 | 180 |
| 185 void InitializeWorkerThread(talk_base::Thread** thread, | 181 void InitializeWorkerThread(talk_base::Thread** thread, |
| 186 base::WaitableEvent* event); | 182 base::WaitableEvent* event); |
| 187 | 183 |
| 188 void CreateIpcNetworkManagerOnWorkerThread(base::WaitableEvent* event); | 184 void CreateIpcNetworkManagerOnWorkerThread(base::WaitableEvent* event); |
| 189 void DeleteIpcNetworkManager(); | 185 void DeleteIpcNetworkManager(); |
| 190 | 186 |
| 191 bool EnsurePeerConnectionFactory(); | 187 bool EnsurePeerConnectionFactory(); |
| 192 | 188 |
| 193 PeerConnectionHandlerBase* FindPeerConnectionByStream( | 189 PeerConnectionHandlerBase* FindPeerConnectionByStream( |
| 194 const WebKit::WebMediaStreamDescriptor& stream); | 190 const WebKit::WebMediaStreamDescriptor& stream); |
| 195 scoped_refptr<media::VideoDecoder> CreateLocalVideoDecoder( | 191 scoped_refptr<media::VideoDecoder> CreateLocalVideoDecoder( |
| 196 webrtc::LocalMediaStreamInterface* stream, | 192 webrtc::MediaStreamInterface* stream, |
| 197 media::MessageLoopFactory* message_loop_factory); | 193 media::MessageLoopFactory* message_loop_factory); |
| 198 scoped_refptr<media::VideoDecoder> CreateRemoteVideoDecoder( | 194 scoped_refptr<media::VideoDecoder> CreateRemoteVideoDecoder( |
| 199 const WebKit::WebMediaStreamDescriptor& stream, | 195 webrtc::MediaStreamInterface* stream, |
| 200 PeerConnectionHandlerBase* pc_handler, | |
| 201 const GURL& url, | 196 const GURL& url, |
| 202 media::MessageLoopFactory* message_loop_factory); | 197 media::MessageLoopFactory* message_loop_factory); |
| 203 void CreateNativeLocalMediaStream( | 198 LocalNativeStreamPtr CreateNativeLocalMediaStream( |
| 204 const std::string& label, | 199 const std::string& label, |
| 205 WebKit::WebFrame* frame, | 200 WebKit::WebFrame* frame, |
| 206 const WebKit::WebVector<WebKit::WebMediaStreamSource>& audio_sources, | 201 const WebKit::WebVector<WebKit::WebMediaStreamSource>& audio_sources, |
| 207 const WebKit::WebVector<WebKit::WebMediaStreamSource>& video_sources); | 202 const WebKit::WebVector<WebKit::WebMediaStreamSource>& video_sources); |
| 208 | 203 |
| 209 scoped_ptr<MediaStreamDependencyFactory> dependency_factory_; | 204 scoped_ptr<MediaStreamDependencyFactory> dependency_factory_; |
| 210 | 205 |
| 211 // media_stream_dispatcher_ is a weak reference, owned by RenderView. It's | 206 // media_stream_dispatcher_ is a weak reference, owned by RenderView. It's |
| 212 // valid for the lifetime of RenderView. | 207 // valid for the lifetime of RenderView. |
| 213 MediaStreamDispatcher* media_stream_dispatcher_; | 208 MediaStreamDispatcher* media_stream_dispatcher_; |
| 214 | 209 |
| 215 // p2p_socket_dispatcher_ is a weak reference, owned by RenderView. It's valid | 210 // p2p_socket_dispatcher_ is a weak reference, owned by RenderView. It's valid |
| 216 // for the lifetime of RenderView. | 211 // for the lifetime of RenderView. |
| 217 content::P2PSocketDispatcher* p2p_socket_dispatcher_; | 212 content::P2PSocketDispatcher* p2p_socket_dispatcher_; |
| 218 | 213 |
| 219 // We own network_manager_, must be deleted on the worker thread. | 214 // We own network_manager_, must be deleted on the worker thread. |
| 220 // The network manager uses |p2p_socket_dispatcher_|. | 215 // The network manager uses |p2p_socket_dispatcher_|. |
| 221 content::IpcNetworkManager* network_manager_; | 216 content::IpcNetworkManager* network_manager_; |
| 222 scoped_ptr<content::IpcPacketSocketFactory> socket_factory_; | 217 scoped_ptr<content::IpcPacketSocketFactory> socket_factory_; |
| 223 scoped_refptr<VideoCaptureImplManager> vc_manager_; | 218 scoped_refptr<VideoCaptureImplManager> vc_manager_; |
| 224 | 219 |
| 225 // peer_connection_handlers_ contains raw references, owned by WebKit. A | |
| 226 // pointer is valid until stop is called on the object (which will call | |
| 227 // ClosePeerConnection on us and we remove the pointer). | |
| 228 std::list<PeerConnectionHandlerBase*> peer_connection_handlers_; | |
| 229 | |
| 230 MediaRequestMap user_media_requests_; | 220 MediaRequestMap user_media_requests_; |
| 231 LocalNativeStreamMap local_media_streams_; | 221 LocalNativeStreamMap local_media_streams_; |
| 232 | 222 |
| 233 // PeerConnection threads. signaling_thread_ is created from the | 223 // PeerConnection threads. signaling_thread_ is created from the |
| 234 // "current" chrome thread. | 224 // "current" chrome thread. |
| 235 talk_base::Thread* signaling_thread_; | 225 talk_base::Thread* signaling_thread_; |
| 236 talk_base::Thread* worker_thread_; | 226 talk_base::Thread* worker_thread_; |
| 237 base::Thread chrome_worker_thread_; | 227 base::Thread chrome_worker_thread_; |
| 238 | 228 |
| 239 DISALLOW_COPY_AND_ASSIGN(MediaStreamImpl); | 229 DISALLOW_COPY_AND_ASSIGN(MediaStreamImpl); |
| 240 }; | 230 }; |
| 241 | 231 |
| 242 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_ | 232 #endif // CONTENT_RENDERER_MEDIA_MEDIA_STREAM_IMPL_H_ |
| OLD | NEW |