Index: talk/app/webrtc/peerconnection.h |
diff --git a/talk/app/webrtc/peerconnection.h b/talk/app/webrtc/peerconnection.h |
index 3d6ce1ba6d94911c5ba95be793d25a39561150fc..0c048988e13d5de30feb4dcaf593d9386f1937e7 100644 |
--- a/talk/app/webrtc/peerconnection.h |
+++ b/talk/app/webrtc/peerconnection.h |
@@ -31,7 +31,6 @@ |
#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" |
@@ -43,11 +42,26 @@ |
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|. |
bool ParseIceServers(const PeerConnectionInterface::IceServers& servers, |
@@ -55,10 +69,8 @@ bool ParseIceServers(const PeerConnectionInterface::IceServers& servers, |
TurnConfigurations* turn_config); |
// PeerConnection implements the PeerConnectionInterface interface. |
-// It uses MediaStreamSignaling and WebRtcSession to implement |
-// the PeerConnection functionality. |
+// It uses WebRtcSession to implement the PeerConnection functionality. |
class PeerConnection : public PeerConnectionInterface, |
- public MediaStreamSignalingObserver, |
public IceObserver, |
public rtc::MessageHandler, |
public sigslot::has_slots<> { |
@@ -76,6 +88,8 @@ class PeerConnection : public PeerConnectionInterface, |
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; |
@@ -120,39 +134,72 @@ class PeerConnection : public PeerConnectionInterface, |
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; |
- // 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; |
+ 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 IceObserver |
void OnIceConnectionChange(IceConnectionState new_state) override; |
@@ -172,21 +219,138 @@ class PeerConnection : public PeerConnectionInterface, |
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 |
- // PeerConnectionFactoryInteface all instances created using the raw pointer |
+ // PeerConnectionFactoryInterface all instances created using the raw pointer |
// will refer to the same reference count. |
rtc::scoped_refptr<PeerConnectionFactory> factory_; |
PeerConnectionObserver* observer_; |
@@ -198,12 +362,35 @@ class PeerConnection : public PeerConnectionInterface, |
IceGatheringState ice_gathering_state_; |
rtc::scoped_ptr<cricket::PortAllocator> port_allocator_; |
- rtc::scoped_ptr<WebRtcSession> session_; |
- rtc::scoped_ptr<MediaStreamSignaling> mediastream_signaling_; |
- rtc::scoped_ptr<StatsCollector> stats_; |
+ |
+ // 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_; |
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 |