1*d9f75844SAndroid Build Coastguard Worker /* 2*d9f75844SAndroid Build Coastguard Worker * Copyright 2017 The WebRTC project authors. All Rights Reserved. 3*d9f75844SAndroid Build Coastguard Worker * 4*d9f75844SAndroid Build Coastguard Worker * Use of this source code is governed by a BSD-style license 5*d9f75844SAndroid Build Coastguard Worker * that can be found in the LICENSE file in the root of the source 6*d9f75844SAndroid Build Coastguard Worker * tree. An additional intellectual property rights grant can be found 7*d9f75844SAndroid Build Coastguard Worker * in the file PATENTS. All contributing project authors may 8*d9f75844SAndroid Build Coastguard Worker * be found in the AUTHORS file in the root of the source tree. 9*d9f75844SAndroid Build Coastguard Worker */ 10*d9f75844SAndroid Build Coastguard Worker 11*d9f75844SAndroid Build Coastguard Worker #ifndef PC_RTP_TRANSPORT_INTERNAL_H_ 12*d9f75844SAndroid Build Coastguard Worker #define PC_RTP_TRANSPORT_INTERNAL_H_ 13*d9f75844SAndroid Build Coastguard Worker 14*d9f75844SAndroid Build Coastguard Worker #include <string> 15*d9f75844SAndroid Build Coastguard Worker 16*d9f75844SAndroid Build Coastguard Worker #include "call/rtp_demuxer.h" 17*d9f75844SAndroid Build Coastguard Worker #include "p2p/base/ice_transport_internal.h" 18*d9f75844SAndroid Build Coastguard Worker #include "pc/session_description.h" 19*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/network_route.h" 20*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/ssl_stream_adapter.h" 21*d9f75844SAndroid Build Coastguard Worker #include "rtc_base/third_party/sigslot/sigslot.h" 22*d9f75844SAndroid Build Coastguard Worker 23*d9f75844SAndroid Build Coastguard Worker namespace rtc { 24*d9f75844SAndroid Build Coastguard Worker class CopyOnWriteBuffer; 25*d9f75844SAndroid Build Coastguard Worker struct PacketOptions; 26*d9f75844SAndroid Build Coastguard Worker } // namespace rtc 27*d9f75844SAndroid Build Coastguard Worker 28*d9f75844SAndroid Build Coastguard Worker namespace webrtc { 29*d9f75844SAndroid Build Coastguard Worker 30*d9f75844SAndroid Build Coastguard Worker // This class is an internal interface; it is not accessible to API consumers 31*d9f75844SAndroid Build Coastguard Worker // but is accessible to internal classes in order to send and receive RTP and 32*d9f75844SAndroid Build Coastguard Worker // RTCP packets belonging to a single RTP session. Additional convenience and 33*d9f75844SAndroid Build Coastguard Worker // configuration methods are also provided. 34*d9f75844SAndroid Build Coastguard Worker class RtpTransportInternal : public sigslot::has_slots<> { 35*d9f75844SAndroid Build Coastguard Worker public: 36*d9f75844SAndroid Build Coastguard Worker virtual ~RtpTransportInternal() = default; 37*d9f75844SAndroid Build Coastguard Worker 38*d9f75844SAndroid Build Coastguard Worker virtual void SetRtcpMuxEnabled(bool enable) = 0; 39*d9f75844SAndroid Build Coastguard Worker 40*d9f75844SAndroid Build Coastguard Worker virtual const std::string& transport_name() const = 0; 41*d9f75844SAndroid Build Coastguard Worker 42*d9f75844SAndroid Build Coastguard Worker // Sets socket options on the underlying RTP or RTCP transports. 43*d9f75844SAndroid Build Coastguard Worker virtual int SetRtpOption(rtc::Socket::Option opt, int value) = 0; 44*d9f75844SAndroid Build Coastguard Worker virtual int SetRtcpOption(rtc::Socket::Option opt, int value) = 0; 45*d9f75844SAndroid Build Coastguard Worker 46*d9f75844SAndroid Build Coastguard Worker virtual bool rtcp_mux_enabled() const = 0; 47*d9f75844SAndroid Build Coastguard Worker 48*d9f75844SAndroid Build Coastguard Worker virtual bool IsReadyToSend() const = 0; 49*d9f75844SAndroid Build Coastguard Worker 50*d9f75844SAndroid Build Coastguard Worker // Called whenever a transport's ready-to-send state changes. The argument 51*d9f75844SAndroid Build Coastguard Worker // is true if all used transports are ready to send. This is more specific 52*d9f75844SAndroid Build Coastguard Worker // than just "writable"; it means the last send didn't return ENOTCONN. 53*d9f75844SAndroid Build Coastguard Worker sigslot::signal1<bool> SignalReadyToSend; 54*d9f75844SAndroid Build Coastguard Worker 55*d9f75844SAndroid Build Coastguard Worker // Called whenever an RTCP packet is received. There is no equivalent signal 56*d9f75844SAndroid Build Coastguard Worker // for RTP packets because they would be forwarded to the BaseChannel through 57*d9f75844SAndroid Build Coastguard Worker // the RtpDemuxer callback. 58*d9f75844SAndroid Build Coastguard Worker sigslot::signal2<rtc::CopyOnWriteBuffer*, int64_t> SignalRtcpPacketReceived; 59*d9f75844SAndroid Build Coastguard Worker 60*d9f75844SAndroid Build Coastguard Worker // Called whenever the network route of the P2P layer transport changes. 61*d9f75844SAndroid Build Coastguard Worker // The argument is an optional network route. 62*d9f75844SAndroid Build Coastguard Worker sigslot::signal1<absl::optional<rtc::NetworkRoute>> SignalNetworkRouteChanged; 63*d9f75844SAndroid Build Coastguard Worker 64*d9f75844SAndroid Build Coastguard Worker // Called whenever a transport's writable state might change. The argument is 65*d9f75844SAndroid Build Coastguard Worker // true if the transport is writable, otherwise it is false. 66*d9f75844SAndroid Build Coastguard Worker sigslot::signal1<bool> SignalWritableState; 67*d9f75844SAndroid Build Coastguard Worker 68*d9f75844SAndroid Build Coastguard Worker sigslot::signal1<const rtc::SentPacket&> SignalSentPacket; 69*d9f75844SAndroid Build Coastguard Worker 70*d9f75844SAndroid Build Coastguard Worker virtual bool IsWritable(bool rtcp) const = 0; 71*d9f75844SAndroid Build Coastguard Worker 72*d9f75844SAndroid Build Coastguard Worker // TODO(zhihuang): Pass the `packet` by copy so that the original data 73*d9f75844SAndroid Build Coastguard Worker // wouldn't be modified. 74*d9f75844SAndroid Build Coastguard Worker virtual bool SendRtpPacket(rtc::CopyOnWriteBuffer* packet, 75*d9f75844SAndroid Build Coastguard Worker const rtc::PacketOptions& options, 76*d9f75844SAndroid Build Coastguard Worker int flags) = 0; 77*d9f75844SAndroid Build Coastguard Worker 78*d9f75844SAndroid Build Coastguard Worker virtual bool SendRtcpPacket(rtc::CopyOnWriteBuffer* packet, 79*d9f75844SAndroid Build Coastguard Worker const rtc::PacketOptions& options, 80*d9f75844SAndroid Build Coastguard Worker int flags) = 0; 81*d9f75844SAndroid Build Coastguard Worker 82*d9f75844SAndroid Build Coastguard Worker // This method updates the RTP header extension map so that the RTP transport 83*d9f75844SAndroid Build Coastguard Worker // can parse the received packets and identify the MID. This is called by the 84*d9f75844SAndroid Build Coastguard Worker // BaseChannel when setting the content description. 85*d9f75844SAndroid Build Coastguard Worker // 86*d9f75844SAndroid Build Coastguard Worker // TODO(zhihuang): Merging and replacing following methods handling header 87*d9f75844SAndroid Build Coastguard Worker // extensions with SetParameters: 88*d9f75844SAndroid Build Coastguard Worker // UpdateRtpHeaderExtensionMap, 89*d9f75844SAndroid Build Coastguard Worker // UpdateSendEncryptedHeaderExtensionIds, 90*d9f75844SAndroid Build Coastguard Worker // UpdateRecvEncryptedHeaderExtensionIds, 91*d9f75844SAndroid Build Coastguard Worker // CacheRtpAbsSendTimeHeaderExtension, 92*d9f75844SAndroid Build Coastguard Worker virtual void UpdateRtpHeaderExtensionMap( 93*d9f75844SAndroid Build Coastguard Worker const cricket::RtpHeaderExtensions& header_extensions) = 0; 94*d9f75844SAndroid Build Coastguard Worker 95*d9f75844SAndroid Build Coastguard Worker virtual bool IsSrtpActive() const = 0; 96*d9f75844SAndroid Build Coastguard Worker 97*d9f75844SAndroid Build Coastguard Worker virtual bool RegisterRtpDemuxerSink(const RtpDemuxerCriteria& criteria, 98*d9f75844SAndroid Build Coastguard Worker RtpPacketSinkInterface* sink) = 0; 99*d9f75844SAndroid Build Coastguard Worker 100*d9f75844SAndroid Build Coastguard Worker virtual bool UnregisterRtpDemuxerSink(RtpPacketSinkInterface* sink) = 0; 101*d9f75844SAndroid Build Coastguard Worker }; 102*d9f75844SAndroid Build Coastguard Worker 103*d9f75844SAndroid Build Coastguard Worker } // namespace webrtc 104*d9f75844SAndroid Build Coastguard Worker 105*d9f75844SAndroid Build Coastguard Worker #endif // PC_RTP_TRANSPORT_INTERNAL_H_ 106