| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |  This file is a part of JRTPLIB | 
					
						
							|  |  |  |  Copyright (c) 1999-2017 Jori Liesenborgs | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Contact: jori.liesenborgs@gmail.com | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  This library was developed at the Expertise Centre for Digital Media | 
					
						
							|  |  |  |  (http://www.edm.uhasselt.be), a research center of the Hasselt University
 | 
					
						
							|  |  |  |  (http://www.uhasselt.be). The library is based upon work done for
 | 
					
						
							|  |  |  |  my thesis at the School for Knowledge Technology (Belgium/The Netherlands). | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  Permission is hereby granted, free of charge, to any person obtaining a | 
					
						
							|  |  |  |  copy of this software and associated documentation files (the "Software"), | 
					
						
							|  |  |  |  to deal in the Software without restriction, including without limitation | 
					
						
							|  |  |  |  the rights to use, copy, modify, merge, publish, distribute, sublicense, | 
					
						
							|  |  |  |  and/or sell copies of the Software, and to permit persons to whom the | 
					
						
							|  |  |  |  Software is furnished to do so, subject to the following conditions: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  The above copyright notice and this permission notice shall be included | 
					
						
							|  |  |  |  in all copies or substantial portions of the Software. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | 
					
						
							|  |  |  |  OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | 
					
						
							|  |  |  |  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL | 
					
						
							|  |  |  |  THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | 
					
						
							|  |  |  |  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | 
					
						
							|  |  |  |  FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | 
					
						
							|  |  |  |  IN THE SOFTWARE. | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * \file rtpsession.h | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef RTPSESSION_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define RTPSESSION_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "rtpconfig.h"
 | 
					
						
							|  |  |  | #include "rtppacketbuilder.h"
 | 
					
						
							|  |  |  | #include "rtpsessionsources.h"
 | 
					
						
							|  |  |  | #include "rtptransmitter.h"
 | 
					
						
							|  |  |  | #include "rtpcollisionlist.h"
 | 
					
						
							|  |  |  | #include "rtcpscheduler.h"
 | 
					
						
							|  |  |  | #include "rtcppacketbuilder.h"
 | 
					
						
							|  |  |  | #include "rtptimeutilities.h"
 | 
					
						
							|  |  |  | #include "rtcpcompoundpacketbuilder.h"
 | 
					
						
							|  |  |  | #include <list>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-03-20 13:49:21 +01:00
										 |  |  | #include "export.h"
 | 
					
						
							| 
									
										
										
										
											2018-03-03 20:23:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | namespace qrtplib | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class RTPTransmitter; | 
					
						
							|  |  |  | class RTPSessionParams; | 
					
						
							|  |  |  | class RTPTransmissionParams; | 
					
						
							|  |  |  | class RTPAddress; | 
					
						
							|  |  |  | class RTPSourceData; | 
					
						
							|  |  |  | class RTPPacket; | 
					
						
							|  |  |  | class RTPPollThread; | 
					
						
							|  |  |  | class RTPTransmissionInfo; | 
					
						
							|  |  |  | class RTCPCompoundPacket; | 
					
						
							|  |  |  | class RTCPPacket; | 
					
						
							|  |  |  | class RTCPAPPPacket; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** High level class for using RTP.
 | 
					
						
							|  |  |  |  *  For most RTP based applications, the RTPSession class will probably be the one to use. It handles | 
					
						
							|  |  |  |  *  the RTCP part completely internally, so the user can focus on sending and receiving the actual data. | 
					
						
							|  |  |  |  *  In case you want to use SRTP, you should create an RTPSecureSession derived class. | 
					
						
							|  |  |  |  *  \note The RTPSession class is not meant to be thread safe. The user should use some kind of locking | 
					
						
							|  |  |  |  *        mechanism to prevent different threads from using the same RTPSession instance. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-03-03 20:23:38 +01:00
										 |  |  | class QRTPLIB_API RTPSession | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** Constructs an RTPSession instance, optionally using a specific instance of a random
 | 
					
						
							|  |  |  |      *  number generator, and optionally installing a memory manager. | 
					
						
							|  |  |  |      *  Constructs an RTPSession instance, optionally using a specific instance of a random | 
					
						
							|  |  |  |      *  number generator, and optionally installing a memory manager. If no random number generator | 
					
						
							|  |  |  |      *  is specified, the RTPSession object will try to use either a RTPRandomURandom or | 
					
						
							|  |  |  |      *  RTPRandomRandS instance. If neither is available on the current platform, a RTPRandomRand48 | 
					
						
							|  |  |  |      *  instance will be used instead. By specifying a random number generator yourself, it is | 
					
						
							|  |  |  |      *  possible to use the same generator in several RTPSession instances. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     RTPSession(RTPRandom *rnd = 0); | 
					
						
							|  |  |  |     virtual ~RTPSession(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Creates an RTP session.
 | 
					
						
							|  |  |  |      *  This function creates an RTP session with parameters \c sessparams, which will use a transmitter | 
					
						
							|  |  |  |      *  corresponding to \c proto. Parameters for this transmitter can be specified as well. If \c | 
					
						
							|  |  |  |      *  proto is of type RTPTransmitter::UserDefinedProto, the NewUserDefinedTransmitter function must | 
					
						
							|  |  |  |      *  be implemented. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int Create(const RTPSessionParams &sessparams, const RTPTransmissionParams *transparams = 0, RTPTransmitter::TransmissionProtocol proto = RTPTransmitter::IPv4UDPProto); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Creates an RTP session using \c transmitter as transmission component.
 | 
					
						
							|  |  |  |      *  This function creates an RTP session with parameters \c sessparams, which will use the | 
					
						
							|  |  |  |      *  transmission component \c transmitter. Initialization and destruction of the transmitter | 
					
						
							|  |  |  |      *  will not be done by the RTPSession class if this Create function is used. This function | 
					
						
							|  |  |  |      *  can be useful if you which to reuse the transmission component in another RTPSession | 
					
						
							|  |  |  |      *  instance, once the original RTPSession isn't using the transmitter anymore. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int Create(const RTPSessionParams &sessparams, RTPTransmitter *transmitter); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Leaves the session without sending a BYE packet. */ | 
					
						
							|  |  |  |     void Destroy(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sends a BYE packet and leaves the session.
 | 
					
						
							|  |  |  |      *  Sends a BYE packet and leaves the session. At most a time \c maxwaittime will be waited to | 
					
						
							|  |  |  |      *  send the BYE packet. If this time expires, the session will be left without sending a BYE packet. | 
					
						
							|  |  |  |      *  The BYE packet will contain as reason for leaving \c reason with length \c reasonlength. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     void BYEDestroy(const RTPTime &maxwaittime, const void *reason, std::size_t reasonlength); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Returns whether the session has been created or not. */ | 
					
						
							|  |  |  |     bool IsActive(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns our own SSRC. */ | 
					
						
							|  |  |  |     uint32_t GetLocalSSRC(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Adds \c addr to the list of destinations. */ | 
					
						
							|  |  |  |     int AddDestination(const RTPAddress &addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Deletes \c addr from the list of destinations. */ | 
					
						
							|  |  |  |     int DeleteDestination(const RTPAddress &addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Clears the list of destinations. */ | 
					
						
							|  |  |  |     void ClearDestinations(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns \c true if multicasting is supported. */ | 
					
						
							|  |  |  |     bool SupportsMulticasting(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Joins the multicast group specified by \c addr. */ | 
					
						
							|  |  |  |     int JoinMulticastGroup(const RTPAddress &addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Leaves the multicast group specified by \c addr. */ | 
					
						
							|  |  |  |     int LeaveMulticastGroup(const RTPAddress &addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sends the RTP packet with payload \c data which has length \c len.
 | 
					
						
							|  |  |  |      *  Sends the RTP packet with payload \c data which has length \c len. | 
					
						
							|  |  |  |      *  The used payload type, marker and timestamp increment will be those that have been set | 
					
						
							|  |  |  |      *  using the \c SetDefault member functions. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SendPacket(const void *data, std::size_t len); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sends the RTP packet with payload \c data which has length \c len.
 | 
					
						
							|  |  |  |      *  It will use payload type \c pt, marker \c mark and after the packet has been built, the | 
					
						
							|  |  |  |      *  timestamp will be incremented by \c timestampinc. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SendPacket(const void *data, std::size_t len, uint8_t pt, bool mark, uint32_t timestampinc); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sends the RTP packet with payload \c data which has length \c len.
 | 
					
						
							|  |  |  |      *  The packet will contain a header extension with identifier \c hdrextID and containing data | 
					
						
							|  |  |  |      *  \c hdrextdata. The length of this data is given by \c numhdrextwords and is specified in a | 
					
						
							|  |  |  |      *  number of 32-bit words. The used payload type, marker and timestamp increment will be those that | 
					
						
							|  |  |  |      *  have been set using the \c SetDefault member functions. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SendPacketEx(const void *data, std::size_t len, uint16_t hdrextID, const void *hdrextdata, std::size_t numhdrextwords); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sends the RTP packet with payload \c data which has length \c len.
 | 
					
						
							|  |  |  |      *  It will use payload type \c pt, marker \c mark and after the packet has been built, the | 
					
						
							|  |  |  |      *  timestamp will be incremented by \c timestampinc. The packet will contain a header | 
					
						
							|  |  |  |      *  extension with identifier \c hdrextID and containing data \c hdrextdata. The length | 
					
						
							|  |  |  |      *  of this data is given by \c numhdrextwords and is specified in a number of 32-bit words. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SendPacketEx(const void *data, std::size_t len, uint8_t pt, bool mark, uint32_t timestampinc, uint16_t hdrextID, const void *hdrextdata, std::size_t numhdrextwords); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | #ifdef RTP_SUPPORT_SENDAPP
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** If sending of RTCP APP packets was enabled at compile time, this function creates a compound packet
 | 
					
						
							|  |  |  |      *  containing an RTCP APP packet and sends it immediately. | 
					
						
							|  |  |  |      *  If sending of RTCP APP packets was enabled at compile time, this function creates a compound packet | 
					
						
							|  |  |  |      *  containing an RTCP APP packet and sends it immediately. If successful, the function returns the number | 
					
						
							|  |  |  |      *  of bytes in the RTCP compound packet. Note that this immediate sending is not compliant with the RTP | 
					
						
							|  |  |  |      *  specification, so use with care. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SendRTCPAPPPacket(uint8_t subtype, const uint8_t name[4], const void *appdata, std::size_t appdatalen); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | #endif // RTP_SUPPORT_SENDAPP
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** With this function raw data can be sent directly over the RTP or
 | 
					
						
							|  |  |  |      *  RTCP channel (if they are different); the data is **not** passed through the | 
					
						
							|  |  |  |      *  RTPSession::OnChangeRTPOrRTCPData function. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SendRawData(const void *data, std::size_t len, bool usertpchannel); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the default payload type for RTP packets to \c pt. */ | 
					
						
							|  |  |  |     int SetDefaultPayloadType(uint8_t pt); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the default marker for RTP packets to \c m. */ | 
					
						
							|  |  |  |     int SetDefaultMark(bool m); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the default value to increment the timestamp with to \c timestampinc. */ | 
					
						
							|  |  |  |     int SetDefaultTimestampIncrement(uint32_t timestampinc); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** This function increments the timestamp with the amount given by \c inc.
 | 
					
						
							|  |  |  |      *  This function increments the timestamp with the amount given by \c inc. This can be useful | 
					
						
							|  |  |  |      *  if, for example, a packet was not sent because it contained only silence. Then, this function | 
					
						
							|  |  |  |      *  should be called to increment the timestamp with the appropriate amount so that the next packets | 
					
						
							|  |  |  |      *  will still be played at the correct time at other hosts. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int IncrementTimestamp(uint32_t inc); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** This function increments the timestamp with the amount given set by the SetDefaultTimestampIncrement
 | 
					
						
							|  |  |  |      *  member function. | 
					
						
							|  |  |  |      *  This function increments the timestamp with the amount given set by the SetDefaultTimestampIncrement | 
					
						
							|  |  |  |      *  member function. This can be useful if, for example, a packet was not sent because it contained only silence. | 
					
						
							|  |  |  |      *  Then, this function should be called to increment the timestamp with the appropriate amount so that the next | 
					
						
							|  |  |  |      *  packets will still be played at the correct time at other hosts. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int IncrementTimestampDefault(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** This function allows you to inform the library about the delay between sampling the first
 | 
					
						
							|  |  |  |      *  sample of a packet and sending the packet. | 
					
						
							|  |  |  |      *  This function allows you to inform the library about the delay between sampling the first | 
					
						
							|  |  |  |      *  sample of a packet and sending the packet. This delay is taken into account when calculating the | 
					
						
							|  |  |  |      *  relation between RTP timestamp and wallclock time, used for inter-media synchronization. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int SetPreTransmissionDelay(const RTPTime &delay); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** This function returns an instance of a subclass of RTPTransmissionInfo which will give some
 | 
					
						
							|  |  |  |      *  additional information about the transmitter (a list of local IP addresses for example). | 
					
						
							|  |  |  |      *  This function returns an instance of a subclass of RTPTransmissionInfo which will give some | 
					
						
							|  |  |  |      *  additional information about the transmitter (a list of local IP addresses for example). The user | 
					
						
							|  |  |  |      *  has to free the returned instance when it is no longer needed, preferably using the DeleteTransmissionInfo | 
					
						
							|  |  |  |      *  function. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     RTPTransmissionInfo *GetTransmissionInfo(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Frees the memory used by the transmission information \c inf. */ | 
					
						
							|  |  |  |     void DeleteTransmissionInfo(RTPTransmissionInfo *inf); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the time interval after which an RTCP compound packet may have to be sent (only works when
 | 
					
						
							|  |  |  |      *  you're not using the poll thread. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     RTPTime GetRTCPDelay(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** The following member functions (till EndDataAccess}) need to be accessed between a call
 | 
					
						
							|  |  |  |      *  to BeginDataAccess and EndDataAccess. | 
					
						
							|  |  |  |      *  The BeginDataAccess function makes sure that the poll thread won't access the source table | 
					
						
							|  |  |  |      *  at the same time that you're using it. When the EndDataAccess is called, the lock on the | 
					
						
							|  |  |  |      *  source table is freed again. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int BeginDataAccess(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Starts the iteration over the participants by going to the first member in the table.
 | 
					
						
							|  |  |  |      *  Starts the iteration over the participants by going to the first member in the table. | 
					
						
							|  |  |  |      *  If a member was found, the function returns \c true, otherwise it returns \c false. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool GotoFirstSource(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the current source to be the next source in the table.
 | 
					
						
							|  |  |  |      *  Sets the current source to be the next source in the table. If we're already at the last | 
					
						
							|  |  |  |      *  source, the function returns \c false, otherwise it returns \c true. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool GotoNextSource(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the current source to be the previous source in the table.
 | 
					
						
							|  |  |  |      *  Sets the current source to be the previous source in the table. If we're at the first source, | 
					
						
							|  |  |  |      *  the function returns \c false, otherwise it returns \c true. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool GotoPreviousSource(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the current source to be the first source in the table which has RTPPacket instances
 | 
					
						
							|  |  |  |      *  that we haven't extracted yet. | 
					
						
							|  |  |  |      *  Sets the current source to be the first source in the table which has RTPPacket instances | 
					
						
							|  |  |  |      *  that we haven't extracted yet. If no such member was found, the function returns \c false, | 
					
						
							|  |  |  |      *  otherwise it returns \c true. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool GotoFirstSourceWithData(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the current source to be the next source in the table which has RTPPacket instances
 | 
					
						
							|  |  |  |      *  that we haven't extracted yet. | 
					
						
							|  |  |  |      *  Sets the current source to be the next source in the table which has RTPPacket instances | 
					
						
							|  |  |  |      *  that we haven't extracted yet. If no such member was found, the function returns \c false, | 
					
						
							|  |  |  |      *  otherwise it returns \c true. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool GotoNextSourceWithData(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the current source to be the previous source in the table which has RTPPacket
 | 
					
						
							|  |  |  |      *  instances that we haven't extracted yet. | 
					
						
							|  |  |  |      *  Sets the current source to be the previous source in the table which has RTPPacket | 
					
						
							|  |  |  |      *  instances that we haven't extracted yet. If no such member was found, the function returns \c false, | 
					
						
							|  |  |  |      *  otherwise it returns \c true. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool GotoPreviousSourceWithData(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the \c RTPSourceData instance for the currently selected participant. */ | 
					
						
							|  |  |  |     RTPSourceData *GetCurrentSourceInfo(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the \c RTPSourceData instance for the participant identified by \c ssrc,
 | 
					
						
							|  |  |  |      *  or NULL if no such entry exists. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     RTPSourceData *GetSourceInfo(uint32_t ssrc); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Extracts the next packet from the received packets queue of the current participant,
 | 
					
						
							|  |  |  |      *  or NULL if no more packets are available. | 
					
						
							|  |  |  |      *  Extracts the next packet from the received packets queue of the current participant, | 
					
						
							|  |  |  |      *  or NULL if no more packets are available. When the packet is no longer needed, its | 
					
						
							|  |  |  |      *  memory should be freed using the DeletePacket member function. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     RTPPacket *GetNextPacket(); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the Sequence Number that will be used in the next SendPacket function call. */ | 
					
						
							|  |  |  |     uint16_t GetNextSequenceNumber() const; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** Frees the memory used by \c p. */ | 
					
						
							|  |  |  |     void DeletePacket(RTPPacket *p); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** See BeginDataAccess. */ | 
					
						
							|  |  |  |     int EndDataAccess(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the receive mode to \c m.
 | 
					
						
							|  |  |  |      *  Sets the receive mode to \c m. Note that when the receive mode is changed, the list of | 
					
						
							|  |  |  |      *  addresses to be ignored ot accepted will be cleared. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int SetReceiveMode(RTPTransmitter::ReceiveMode m); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Adds \c addr to the list of addresses to ignore. */ | 
					
						
							|  |  |  |     int AddToIgnoreList(const RTPAddress &addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Deletes \c addr from the list of addresses to ignore. */ | 
					
						
							|  |  |  |     int DeleteFromIgnoreList(const RTPAddress &addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Clears the list of addresses to ignore. */ | 
					
						
							|  |  |  |     void ClearIgnoreList(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Adds \c addr to the list of addresses to accept. */ | 
					
						
							|  |  |  |     int AddToAcceptList(const RTPAddress &addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Deletes \c addr from the list of addresses to accept. */ | 
					
						
							|  |  |  |     int DeleteFromAcceptList(const RTPAddress &addr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Clears the list of addresses to accept. */ | 
					
						
							|  |  |  |     void ClearAcceptList(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the maximum allowed packet size to \c s. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SetMaximumPacketSize(std::size_t s); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the session bandwidth to \c bw, which is specified in bytes per second. */ | 
					
						
							|  |  |  |     int SetSessionBandwidth(double bw); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the timestamp unit for our own data.
 | 
					
						
							|  |  |  |      *  Sets the timestamp unit for our own data. The timestamp unit is defined as a time interval in | 
					
						
							|  |  |  |      *  seconds divided by the corresponding timestamp interval. For example, for 8000 Hz audio, the | 
					
						
							|  |  |  |      *  timestamp unit would typically be 1/8000. Since this value is initially set to an illegal value, | 
					
						
							|  |  |  |      *  the user must set this to an allowed value to be able to create a session. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     int SetTimestampUnit(double u); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the RTCP interval for the SDES name item.
 | 
					
						
							|  |  |  |      *  After all possible sources in the source table have been processed, the class will check if other | 
					
						
							|  |  |  |      *  SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count | 
					
						
							|  |  |  |      *  is positive, an SDES name item will be added after the sources in the source table have been | 
					
						
							|  |  |  |      *  processed \c count times. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void SetNameInterval(int count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the RTCP interval for the SDES e-mail item.
 | 
					
						
							|  |  |  |      *  After all possible sources in the source table have been processed, the class will check if other | 
					
						
							|  |  |  |      *  SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count | 
					
						
							|  |  |  |      *  is positive, an SDES e-mail item will be added after the sources in the source table have been | 
					
						
							|  |  |  |      *  processed \c count times. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void SetEMailInterval(int count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the RTCP interval for the SDES location item.
 | 
					
						
							|  |  |  |      *  After all possible sources in the source table have been processed, the class will check if other | 
					
						
							|  |  |  |      *  SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count | 
					
						
							|  |  |  |      *  is positive, an SDES location item will be added after the sources in the source table have been | 
					
						
							|  |  |  |      *  processed \c count times. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void SetLocationInterval(int count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the RTCP interval for the SDES phone item.
 | 
					
						
							|  |  |  |      *  After all possible sources in the source table have been processed, the class will check if other | 
					
						
							|  |  |  |      *  SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count | 
					
						
							|  |  |  |      *  is positive, an SDES phone item will be added after the sources in the source table have been | 
					
						
							|  |  |  |      *  processed \c count times. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void SetPhoneInterval(int count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the RTCP interval for the SDES tool item.
 | 
					
						
							|  |  |  |      *  After all possible sources in the source table have been processed, the class will check if other | 
					
						
							|  |  |  |      *  SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count | 
					
						
							|  |  |  |      *  is positive, an SDES tool item will be added after the sources in the source table have been | 
					
						
							|  |  |  |      *  processed \c count times. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void SetToolInterval(int count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the RTCP interval for the SDES note item.
 | 
					
						
							|  |  |  |      *  After all possible sources in the source table have been processed, the class will check if other | 
					
						
							|  |  |  |      *  SDES items need to be sent. If \c count is zero or negative, nothing will happen. If \c count | 
					
						
							|  |  |  |      *  is positive, an SDES note item will be added after the sources in the source table have been | 
					
						
							|  |  |  |      *  processed \c count times. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void SetNoteInterval(int count); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the SDES name item for the local participant to the value \c s with length \c len. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SetLocalName(const void *s, std::size_t len); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the SDES e-mail item for the local participant to the value \c s with length \c len. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SetLocalEMail(const void *s, std::size_t len); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the SDES location item for the local participant to the value \c s with length \c len. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SetLocalLocation(const void *s, std::size_t len); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the SDES phone item for the local participant to the value \c s with length \c len. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SetLocalPhone(const void *s, std::size_t len); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the SDES tool item for the local participant to the value \c s with length \c len. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SetLocalTool(const void *s, std::size_t len); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the SDES note item for the local participant to the value \c s with length \c len. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SetLocalNote(const void *s, std::size_t len); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | protected: | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** Allocate a user defined transmitter.
 | 
					
						
							|  |  |  |      *  In case you specified in the Create function that you want to use a | 
					
						
							|  |  |  |      *  user defined transmitter, you should override this function. The RTPTransmitter | 
					
						
							|  |  |  |      *  instance returned by this function will then be used to send and receive RTP and | 
					
						
							|  |  |  |      *  RTCP packets. Note that when the session is destroyed, this RTPTransmitter | 
					
						
							|  |  |  |      *  instance will be destroyed as well. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual RTPTransmitter *NewUserDefinedTransmitter(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an incoming RTP packet is about to be processed.
 | 
					
						
							|  |  |  |      *  Is called when an incoming RTP packet is about to be processed. This is _not_ | 
					
						
							|  |  |  |      *  a good function to process an RTP packet in, in case you want to avoid iterating | 
					
						
							|  |  |  |      *  over the sources using the GotoFirst/GotoNext functions. In that case, the | 
					
						
							|  |  |  |      *  RTPSession::OnValidatedRTPPacket function should be used. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void OnRTPPacket(RTPPacket *pack, const RTPTime &receivetime, const RTPAddress *senderaddress); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an incoming RTCP packet is about to be processed. */ | 
					
						
							|  |  |  |     virtual void OnRTCPCompoundPacket(RTCPCompoundPacket *pack, const RTPTime &receivetime, const RTPAddress *senderaddress); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an SSRC collision was detected.
 | 
					
						
							|  |  |  |      *  Is called when an SSRC collision was detected. The instance \c srcdat is the one present in | 
					
						
							|  |  |  |      *  the table, the address \c senderaddress is the one that collided with one of the addresses | 
					
						
							|  |  |  |      *  and \c isrtp indicates against which address of \c srcdat the check failed. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void OnSSRCCollision(RTPSourceData *srcdat, const RTPAddress *senderaddress, bool isrtp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when another CNAME was received than the one already present for source \c srcdat. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     virtual void OnCNAMECollision(RTPSourceData *srcdat, const RTPAddress *senderaddress, const uint8_t *cname, std::size_t cnamelength); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when a new entry \c srcdat is added to the source table. */ | 
					
						
							|  |  |  |     virtual void OnNewSource(RTPSourceData *srcdat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when the entry \c srcdat is about to be deleted from the source table. */ | 
					
						
							|  |  |  |     virtual void OnRemoveSource(RTPSourceData *srcdat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when participant \c srcdat is timed out. */ | 
					
						
							|  |  |  |     virtual void OnTimeout(RTPSourceData *srcdat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when participant \c srcdat is timed after having sent a BYE packet. */ | 
					
						
							|  |  |  |     virtual void OnBYETimeout(RTPSourceData *srcdat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an RTCP APP packet \c apppacket has been received at time \c receivetime
 | 
					
						
							|  |  |  |      *  from address \c senderaddress. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void OnAPPPacket(RTCPAPPPacket *apppacket, const RTPTime &receivetime, const RTPAddress *senderaddress); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an unknown RTCP packet type was detected. */ | 
					
						
							|  |  |  |     virtual void OnUnknownPacketType(RTCPPacket *rtcppack, const RTPTime &receivetime, const RTPAddress *senderaddress); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an unknown packet format for a known packet type was detected. */ | 
					
						
							|  |  |  |     virtual void OnUnknownPacketFormat(RTCPPacket *rtcppack, const RTPTime &receivetime, const RTPAddress *senderaddress); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when the SDES NOTE item for source \c srcdat has been timed out. */ | 
					
						
							|  |  |  |     virtual void OnNoteTimeout(RTPSourceData *srcdat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an RTCP sender report has been processed for this source. */ | 
					
						
							|  |  |  |     virtual void OnRTCPSenderReport(RTPSourceData *srcdat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an RTCP receiver report has been processed for this source. */ | 
					
						
							|  |  |  |     virtual void OnRTCPReceiverReport(RTPSourceData *srcdat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when a specific SDES item was received for this source. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     virtual void OnRTCPSDESItem(RTPSourceData *srcdat, RTCPSDESPacket::ItemType t, const void *itemdata, std::size_t itemlength); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | #ifdef RTP_SUPPORT_SDESPRIV
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** Is called when a specific SDES item of 'private' type was received for this source. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     virtual void OnRTCPSDESPrivateItem(RTPSourceData *srcdat, const void *prefixdata, std::size_t prefixlen, const void *valuedata, std::size_t valuelen); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | #endif // RTP_SUPPORT_SDESPRIV
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** Is called when a BYE packet has been processed for source \c srcdat. */ | 
					
						
							|  |  |  |     virtual void OnBYEPacket(RTPSourceData *srcdat); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Is called when an RTCP compound packet has just been sent (useful to inspect outgoing RTCP data). */ | 
					
						
							|  |  |  |     virtual void OnSendRTCPCompoundPacket(RTCPCompoundPacket *pack); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** If this is set to true, outgoing data will be passed through RTPSession::OnChangeRTPOrRTCPData
 | 
					
						
							|  |  |  |      *  and RTPSession::OnSentRTPOrRTCPData, allowing you to modify the data (e.g. to encrypt it). */ | 
					
						
							|  |  |  |     void SetChangeOutgoingData(bool change) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         m_changeOutgoingData = change; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** If this is set to true, incoming data will be passed through RTPSession::OnChangeIncomingData,
 | 
					
						
							|  |  |  |      *  allowing you to modify the data (e.g. to decrypt it). */ | 
					
						
							|  |  |  |     void SetChangeIncomingData(bool change) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         m_changeIncomingData = change; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** If RTPSession::SetChangeOutgoingData was sent to true, overriding this you can change the
 | 
					
						
							|  |  |  |      *  data packet that will actually be sent, for example adding encryption. | 
					
						
							|  |  |  |      *  If RTPSession::SetChangeOutgoingData was sent to true, overriding this you can change the | 
					
						
							|  |  |  |      *  data packet that will actually be sent, for example adding encryption. | 
					
						
							|  |  |  |      *  Note that no memory management will be performed on the `senddata` pointer you fill in, | 
					
						
							|  |  |  |      *  so if it needs to be deleted at some point you need to take care of this in some way | 
					
						
							|  |  |  |      *  yourself, a good way may be to do this in RTPSession::OnSentRTPOrRTCPData. If `senddata` is | 
					
						
							|  |  |  |      *  set to 0, no packet will be sent out. This also provides a way to turn off sending RTCP | 
					
						
							|  |  |  |      *  packets if desired. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     virtual int OnChangeRTPOrRTCPData(const void *origdata, std::size_t origlen, bool isrtp, void **senddata, std::size_t *sendlen); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** This function is called when an RTP or RTCP packet was sent, it can be helpful
 | 
					
						
							|  |  |  |      *  when data was allocated in RTPSession::OnChangeRTPOrRTCPData to deallocate it | 
					
						
							|  |  |  |      *  here. */ | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     virtual void OnSentRTPOrRTCPData(void *senddata, std::size_t sendlen, bool isrtp); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** By overriding this function, the raw incoming data can be inspected
 | 
					
						
							|  |  |  |      *  and modified (e.g. for encryption). | 
					
						
							|  |  |  |      *  By overriding this function, the raw incoming data can be inspected | 
					
						
							|  |  |  |      *  and modified (e.g. for encryption). If the function returns `false`, | 
					
						
							|  |  |  |      *  the packet is discarded. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual bool OnChangeIncomingData(RTPRawPacket *rawpack); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Allows you to use an RTP packet from the specified source directly.
 | 
					
						
							|  |  |  |      *  Allows you to use an RTP packet from the specified source directly. If | 
					
						
							|  |  |  |      *  `ispackethandled` is set to `true`, the packet will no longer be stored in this | 
					
						
							|  |  |  |      *  source's packet list. Note that if you do set this flag, you'll need to | 
					
						
							|  |  |  |      *  deallocate the packet yourself at an appropriate time. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      *  The difference with RTPSession::OnRTPPacket is that that | 
					
						
							|  |  |  |      *  function will always process the RTP packet further and is therefore not | 
					
						
							|  |  |  |      *  really suited to actually do something with the data. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual void OnValidatedRTPPacket(RTPSourceData *srcdat, RTPPacket *rtppack, bool isonprobation, bool *ispackethandled); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     int InternalCreate(const RTPSessionParams &sessparams); | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int CreateCNAME(uint8_t *buffer, std::size_t *bufferlength, bool resolve); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     int ProcessPolledData(); | 
					
						
							|  |  |  |     int ProcessRTCPCompoundPacket(RTCPCompoundPacket &rtcpcomppack, RTPRawPacket *pack); | 
					
						
							|  |  |  |     RTPRandom *GetRandomNumberGenerator(RTPRandom *r); | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     int SendRTPData(const void *data, std::size_t len); | 
					
						
							|  |  |  |     int SendRTCPData(const void *data, std::size_t len); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     RTPRandom *rtprnd; | 
					
						
							|  |  |  |     bool deletertprnd; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     RTPTransmitter *rtptrans; | 
					
						
							|  |  |  |     bool created; | 
					
						
							|  |  |  |     bool deletetransmitter; | 
					
						
							| 
									
										
										
										
											2018-03-05 01:17:19 +01:00
										 |  |  |     bool usingpollthread; | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     bool acceptownpackets; | 
					
						
							|  |  |  |     bool useSR_BYEifpossible; | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  |     std::size_t maxpacksize; | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     double sessionbandwidth; | 
					
						
							|  |  |  |     double controlfragment; | 
					
						
							|  |  |  |     double sendermultiplier; | 
					
						
							|  |  |  |     double byemultiplier; | 
					
						
							|  |  |  |     double membermultiplier; | 
					
						
							|  |  |  |     double collisionmultiplier; | 
					
						
							|  |  |  |     double notemultiplier; | 
					
						
							|  |  |  |     bool sentpackets; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     bool m_changeIncomingData, m_changeOutgoingData; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     RTPSessionSources sources; | 
					
						
							|  |  |  |     RTPPacketBuilder packetbuilder; | 
					
						
							|  |  |  |     RTCPScheduler rtcpsched; | 
					
						
							|  |  |  |     RTCPPacketBuilder rtcpbuilder; | 
					
						
							|  |  |  |     RTPCollisionList collisionlist; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::list<RTCPCompoundPacket *> byepackets; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     friend class RTPSessionSources; | 
					
						
							|  |  |  |     friend class RTCPSessionPacketBuilder; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | inline RTPTransmitter *RTPSession::NewUserDefinedTransmitter() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnRTPPacket(RTPPacket *, const RTPTime &, const RTPAddress *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnRTCPCompoundPacket(RTCPCompoundPacket *, const RTPTime &, const RTPAddress *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnSSRCCollision(RTPSourceData *, const RTPAddress *, bool) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  | inline void RTPSession::OnCNAMECollision(RTPSourceData *, const RTPAddress *, const uint8_t *, std::size_t) | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnNewSource(RTPSourceData *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnRemoveSource(RTPSourceData *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnTimeout(RTPSourceData *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnBYETimeout(RTPSourceData *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnAPPPacket(RTCPAPPPacket *, const RTPTime &, const RTPAddress *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnUnknownPacketType(RTCPPacket *, const RTPTime &, const RTPAddress *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnUnknownPacketFormat(RTCPPacket *, const RTPTime &, const RTPAddress *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnNoteTimeout(RTPSourceData *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnRTCPSenderReport(RTPSourceData *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnRTCPReceiverReport(RTPSourceData *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  | inline void RTPSession::OnRTCPSDESItem(RTPSourceData *, RTCPSDESPacket::ItemType, const void *, std::size_t) | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef RTP_SUPPORT_SDESPRIV
 | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  | inline void RTPSession::OnRTCPSDESPrivateItem(RTPSourceData *, const void *, std::size_t, const void *, std::size_t) | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | #endif // RTP_SUPPORT_SDESPRIV
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | inline void RTPSession::OnBYEPacket(RTPSourceData *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnSendRTCPCompoundPacket(RTCPCompoundPacket *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  | inline int RTPSession::OnChangeRTPOrRTCPData(const void *, std::size_t, bool, void **, std::size_t *) | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | { | 
					
						
							|  |  |  |     return ERR_RTP_RTPSESSION_CHANGEREQUESTEDBUTNOTIMPLEMENTED; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2018-02-28 13:31:44 +01:00
										 |  |  | inline void RTPSession::OnSentRTPOrRTCPData(void *, std::size_t, bool) | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | { | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline bool RTPSession::OnChangeIncomingData(RTPRawPacket *) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     return true; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | inline void RTPSession::OnValidatedRTPPacket(RTPSourceData *, RTPPacket *, bool, bool *) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // end namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // RTPSESSION_H
 | 
					
						
							|  |  |  | 
 |