Index: talk/app/webrtc/peerconnection.h |
diff --git a/talk/app/webrtc/peerconnection.h b/talk/app/webrtc/peerconnection.h |
index 0c048988e13d5de30feb4dcaf593d9386f1937e7..3d6ce1ba6d94911c5ba95be793d25a39561150fc 100644 |
--- a/talk/app/webrtc/peerconnection.h |
+++ b/talk/app/webrtc/peerconnection.h |
@@ -31,6 +31,7 @@ |
#include <string> |
#include "talk/app/webrtc/dtlsidentitystore.h" |
+#include "talk/app/webrtc/mediastreamsignaling.h" |
#include "talk/app/webrtc/peerconnectionfactory.h" |
#include "talk/app/webrtc/peerconnectioninterface.h" |
#include "talk/app/webrtc/rtpreceiverinterface.h" |
@@ -42,25 +43,10 @@ |
namespace webrtc { |
-class RemoteMediaStreamFactory; |
- |
typedef std::vector<PortAllocatorFactoryInterface::StunConfiguration> |
StunConfigurations; |
typedef std::vector<PortAllocatorFactoryInterface::TurnConfiguration> |
TurnConfigurations; |
- |
-// Populates |session_options| from |rtc_options|, and returns true if options |
-// are valid. |
-// Send streams should already be added to |session_options| before this method |
-// is called, as this affects the values of recv_audio and recv_video. |
-bool ConvertRtcOptionsForOffer( |
- const PeerConnectionInterface::RTCOfferAnswerOptions& rtc_options, |
- cricket::MediaSessionOptions* session_options); |
- |
-// Populates |session_options| from |constraints|, and returns true if all |
-// mandatory constraints are satisfied. |
-bool ParseConstraintsForAnswer(const MediaConstraintsInterface* constraints, |
- cricket::MediaSessionOptions* session_options); |
// Parses the URLs for each server in |servers| to build |stun_config| and |
// |turn_config|. |
@@ -69,8 +55,10 @@ |
TurnConfigurations* turn_config); |
// PeerConnection implements the PeerConnectionInterface interface. |
-// It uses WebRtcSession to implement the PeerConnection functionality. |
+// It uses MediaStreamSignaling and WebRtcSession to implement |
+// the PeerConnection functionality. |
class PeerConnection : public PeerConnectionInterface, |
+ public MediaStreamSignalingObserver, |
public IceObserver, |
public rtc::MessageHandler, |
public sigslot::has_slots<> { |
@@ -87,8 +75,6 @@ |
rtc::scoped_refptr<StreamCollectionInterface> remote_streams() override; |
bool AddStream(MediaStreamInterface* local_stream) override; |
void RemoveStream(MediaStreamInterface* local_stream) override; |
- |
- virtual WebRtcSession* session() { return session_.get(); } |
rtc::scoped_refptr<DtmfSenderInterface> CreateDtmfSender( |
AudioTrackInterface* track) override; |
@@ -134,72 +120,39 @@ |
void Close() override; |
- // Virtual for unit tests. |
- virtual const std::vector<rtc::scoped_refptr<DataChannel>>& |
- sctp_data_channels() const { |
- return sctp_data_channels_; |
- }; |
- |
protected: |
~PeerConnection() override; |
private: |
- struct TrackInfo { |
- TrackInfo() : ssrc(0) {} |
- TrackInfo(const std::string& stream_label, |
- const std::string track_id, |
- uint32_t ssrc) |
- : stream_label(stream_label), track_id(track_id), ssrc(ssrc) {} |
- std::string stream_label; |
- std::string track_id; |
- uint32_t ssrc; |
- }; |
- typedef std::vector<TrackInfo> TrackInfos; |
- |
- struct RemotePeerInfo { |
- RemotePeerInfo() |
- : msid_supported(false), |
- default_audio_track_needed(false), |
- default_video_track_needed(false) {} |
- // True if it has been discovered that the remote peer support MSID. |
- bool msid_supported; |
- // The remote peer indicates in the session description that audio will be |
- // sent but no MSID is given. |
- bool default_audio_track_needed; |
- // The remote peer indicates in the session description that video will be |
- // sent but no MSID is given. |
- bool default_video_track_needed; |
- |
- bool IsDefaultMediaStreamNeeded() { |
- return !msid_supported && |
- (default_audio_track_needed || default_video_track_needed); |
- } |
- }; |
- |
// Implements MessageHandler. |
void OnMessage(rtc::Message* msg) override; |
- void CreateAudioReceiver(MediaStreamInterface* stream, |
- AudioTrackInterface* audio_track, |
- uint32_t ssrc); |
- void CreateVideoReceiver(MediaStreamInterface* stream, |
- VideoTrackInterface* video_track, |
- uint32_t ssrc); |
- void DestroyAudioReceiver(MediaStreamInterface* stream, |
- AudioTrackInterface* audio_track); |
- void DestroyVideoReceiver(MediaStreamInterface* stream, |
- VideoTrackInterface* video_track); |
- void CreateAudioSender(MediaStreamInterface* stream, |
- AudioTrackInterface* audio_track, |
- uint32_t ssrc); |
- void CreateVideoSender(MediaStreamInterface* stream, |
- VideoTrackInterface* video_track, |
- uint32_t ssrc); |
- void DestroyAudioSender(MediaStreamInterface* stream, |
- AudioTrackInterface* audio_track, |
- uint32_t ssrc); |
- void DestroyVideoSender(MediaStreamInterface* stream, |
- VideoTrackInterface* video_track); |
+ // Implements MediaStreamSignalingObserver. |
+ void OnAddRemoteStream(MediaStreamInterface* stream) override; |
+ void OnRemoveRemoteStream(MediaStreamInterface* stream) override; |
+ void OnAddDataChannel(DataChannelInterface* data_channel) override; |
+ void OnAddRemoteAudioTrack(MediaStreamInterface* stream, |
+ AudioTrackInterface* audio_track, |
+ uint32_t ssrc) override; |
+ void OnAddRemoteVideoTrack(MediaStreamInterface* stream, |
+ VideoTrackInterface* video_track, |
+ uint32_t ssrc) override; |
+ void OnRemoveRemoteAudioTrack(MediaStreamInterface* stream, |
+ AudioTrackInterface* audio_track) override; |
+ void OnRemoveRemoteVideoTrack(MediaStreamInterface* stream, |
+ VideoTrackInterface* video_track) override; |
+ void OnAddLocalAudioTrack(MediaStreamInterface* stream, |
+ AudioTrackInterface* audio_track, |
+ uint32_t ssrc) override; |
+ void OnAddLocalVideoTrack(MediaStreamInterface* stream, |
+ VideoTrackInterface* video_track, |
+ uint32_t ssrc) override; |
+ void OnRemoveLocalAudioTrack(MediaStreamInterface* stream, |
+ AudioTrackInterface* audio_track, |
+ uint32_t ssrc) override; |
+ void OnRemoveLocalVideoTrack(MediaStreamInterface* stream, |
+ VideoTrackInterface* video_track) override; |
+ void OnRemoveLocalStream(MediaStreamInterface* stream) override; |
// Implements IceObserver |
void OnIceConnectionChange(IceConnectionState new_state) override; |
@@ -219,138 +172,21 @@ |
void PostSetSessionDescriptionFailure(SetSessionDescriptionObserver* observer, |
const std::string& error); |
- void PostCreateSessionDescriptionFailure( |
- CreateSessionDescriptionObserver* observer, |
- const std::string& error); |
bool IsClosed() const { |
return signaling_state_ == PeerConnectionInterface::kClosed; |
} |
- |
- // Returns a MediaSessionOptions struct with options decided by |options|, |
- // the local MediaStreams and DataChannels. |
- virtual bool GetOptionsForOffer( |
- const PeerConnectionInterface::RTCOfferAnswerOptions& rtc_options, |
- cricket::MediaSessionOptions* session_options); |
- |
- // Returns a MediaSessionOptions struct with options decided by |
- // |constraints|, the local MediaStreams and DataChannels. |
- virtual bool GetOptionsForAnswer( |
- const MediaConstraintsInterface* constraints, |
- cricket::MediaSessionOptions* session_options); |
- |
- // Makes sure a MediaStream Track is created for each StreamParam in |
- // |streams|. |media_type| is the type of the |streams| and can be either |
- // audio or video. |
- // If a new MediaStream is created it is added to |new_streams|. |
- void UpdateRemoteStreamsList( |
- const std::vector<cricket::StreamParams>& streams, |
- cricket::MediaType media_type, |
- StreamCollection* new_streams); |
- |
- // Triggered when a remote track has been seen for the first time in a remote |
- // session description. It creates a remote MediaStreamTrackInterface |
- // implementation and triggers CreateAudioReceiver or CreateVideoReceiver. |
- void OnRemoteTrackSeen(const std::string& stream_label, |
- const std::string& track_id, |
- uint32_t ssrc, |
- cricket::MediaType media_type); |
- |
- // Triggered when a remote track has been removed from a remote session |
- // description. It removes the remote track with id |track_id| from a remote |
- // MediaStream and triggers DestroyAudioReceiver or DestroyVideoReceiver. |
- void OnRemoteTrackRemoved(const std::string& stream_label, |
- const std::string& track_id, |
- cricket::MediaType media_type); |
- |
- // Finds remote MediaStreams without any tracks and removes them from |
- // |remote_streams_| and notifies the observer that the MediaStreams no longer |
- // exist. |
- void UpdateEndedRemoteMediaStreams(); |
- |
- void MaybeCreateDefaultStream(); |
- |
- // Set the MediaStreamTrackInterface::TrackState to |kEnded| on all remote |
- // tracks of type |media_type|. |
- void EndRemoteTracks(cricket::MediaType media_type); |
- |
- // Loops through the vector of |streams| and finds added and removed |
- // StreamParams since last time this method was called. |
- // For each new or removed StreamParam, OnLocalTrackSeen or |
- // OnLocalTrackRemoved is invoked. |
- void UpdateLocalTracks(const std::vector<cricket::StreamParams>& streams, |
- cricket::MediaType media_type); |
- |
- // Triggered when a local track has been seen for the first time in a local |
- // session description. |
- // This method triggers CreateAudioSender or CreateVideoSender if the rtp |
- // streams in the local SessionDescription can be mapped to a MediaStreamTrack |
- // in a MediaStream in |local_streams_| |
- void OnLocalTrackSeen(const std::string& stream_label, |
- const std::string& track_id, |
- uint32_t ssrc, |
- cricket::MediaType media_type); |
- |
- // Triggered when a local track has been removed from a local session |
- // description. |
- // This method triggers DestroyAudioSender or DestroyVideoSender if a stream |
- // has been removed from the local SessionDescription and the stream can be |
- // mapped to a MediaStreamTrack in a MediaStream in |local_streams_|. |
- void OnLocalTrackRemoved(const std::string& stream_label, |
- const std::string& track_id, |
- uint32_t ssrc, |
- cricket::MediaType media_type); |
- |
- void UpdateLocalRtpDataChannels(const cricket::StreamParamsVec& streams); |
- void UpdateRemoteRtpDataChannels(const cricket::StreamParamsVec& streams); |
- void UpdateClosingRtpDataChannels( |
- const std::vector<std::string>& active_channels, |
- bool is_local_update); |
- void CreateRemoteRtpDataChannel(const std::string& label, |
- uint32_t remote_ssrc); |
- |
- // Creates channel and adds it to the collection of DataChannels that will |
- // be offered in a SessionDescription. |
- rtc::scoped_refptr<DataChannel> InternalCreateDataChannel( |
- const std::string& label, |
- const InternalDataChannelInit* config); |
- |
- // Checks if any data channel has been added. |
- bool HasDataChannels() const; |
- |
- void AllocateSctpSids(rtc::SSLRole role); |
- void OnSctpDataChannelClosed(DataChannel* channel); |
- |
- // Notifications from WebRtcSession relating to BaseChannels. |
- void OnVoiceChannelDestroyed(); |
- void OnVideoChannelDestroyed(); |
- void OnDataChannelCreated(); |
- void OnDataChannelDestroyed(); |
- // Called when the cricket::DataChannel receives a message indicating that a |
- // webrtc::DataChannel should be opened. |
- void OnDataChannelOpenMessage(const std::string& label, |
- const InternalDataChannelInit& config); |
std::vector<rtc::scoped_refptr<RtpSenderInterface>>::iterator |
FindSenderForTrack(MediaStreamTrackInterface* track); |
std::vector<rtc::scoped_refptr<RtpReceiverInterface>>::iterator |
FindReceiverForTrack(MediaStreamTrackInterface* track); |
- TrackInfos* GetRemoteTracks(cricket::MediaType media_type); |
- TrackInfos* GetLocalTracks(cricket::MediaType media_type); |
- const TrackInfo* FindTrackInfo(const TrackInfos& infos, |
- const std::string& stream_label, |
- const std::string track_id) const; |
- |
- // Returns the specified SCTP DataChannel in sctp_data_channels_, |
- // or nullptr if not found. |
- DataChannel* FindDataChannelBySid(int sid) const; |
- |
// Storing the factory as a scoped reference pointer ensures that the memory |
// in the PeerConnectionFactoryImpl remains available as long as the |
// PeerConnection is running. It is passed to PeerConnection as a raw pointer. |
// However, since the reference counting is done in the |
- // PeerConnectionFactoryInterface all instances created using the raw pointer |
+ // PeerConnectionFactoryInteface all instances created using the raw pointer |
// will refer to the same reference count. |
rtc::scoped_refptr<PeerConnectionFactory> factory_; |
PeerConnectionObserver* observer_; |
@@ -362,35 +198,12 @@ |
IceGatheringState ice_gathering_state_; |
rtc::scoped_ptr<cricket::PortAllocator> port_allocator_; |
- |
- // Streams added via AddStream. |
- rtc::scoped_refptr<StreamCollection> local_streams_; |
- // Streams created as a result of SetRemoteDescription. |
- rtc::scoped_refptr<StreamCollection> remote_streams_; |
- |
- // These lists store track info seen in local/remote descriptions. |
- TrackInfos remote_audio_tracks_; |
- TrackInfos remote_video_tracks_; |
- TrackInfos local_audio_tracks_; |
- TrackInfos local_video_tracks_; |
- |
- SctpSidAllocator sid_allocator_; |
- // label -> DataChannel |
- std::map<std::string, rtc::scoped_refptr<DataChannel>> rtp_data_channels_; |
- std::vector<rtc::scoped_refptr<DataChannel>> sctp_data_channels_; |
- |
- RemotePeerInfo remote_info_; |
- rtc::scoped_ptr<RemoteMediaStreamFactory> remote_stream_factory_; |
+ rtc::scoped_ptr<WebRtcSession> session_; |
+ rtc::scoped_ptr<MediaStreamSignaling> mediastream_signaling_; |
+ rtc::scoped_ptr<StatsCollector> stats_; |
std::vector<rtc::scoped_refptr<RtpSenderInterface>> senders_; |
std::vector<rtc::scoped_refptr<RtpReceiverInterface>> receivers_; |
- |
- // The session_ scoped_ptr is declared at the bottom of PeerConnection |
- // because its destruction fires signals (such as VoiceChannelDestroyed) |
- // which will trigger some final actions in PeerConnection... |
- rtc::scoped_ptr<WebRtcSession> session_; |
- // ... But stats_ depends on session_ so it should be destroyed even earlier. |
- rtc::scoped_ptr<StatsCollector> stats_; |
}; |
} // namespace webrtc |