mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-24 17:40:24 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			665 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			665 lines
		
	
	
		
			30 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /*
 | |
| 
 | |
|  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.
 | |
| 
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * \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>
 | |
| 
 | |
| #include "export.h"
 | |
| 
 | |
| 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.
 | |
|  */
 | |
| class QRTPLIB_API RTPSession
 | |
| {
 | |
| public:
 | |
|     /** 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.
 | |
|      */
 | |
|     void BYEDestroy(const RTPTime &maxwaittime, const void *reason, std::size_t reasonlength);
 | |
| 
 | |
|     /** 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.
 | |
|      */
 | |
|     int SendPacket(const void *data, std::size_t len);
 | |
| 
 | |
|     /** 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.
 | |
|      */
 | |
|     int SendPacket(const void *data, std::size_t len, uint8_t pt, bool mark, uint32_t timestampinc);
 | |
| 
 | |
|     /** 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.
 | |
|      */
 | |
|     int SendPacketEx(const void *data, std::size_t len, uint16_t hdrextID, const void *hdrextdata, std::size_t numhdrextwords);
 | |
| 
 | |
|     /** 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.
 | |
|      */
 | |
|     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);
 | |
| #ifdef RTP_SUPPORT_SENDAPP
 | |
|     /** 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.
 | |
|      */
 | |
|     int SendRTCPAPPPacket(uint8_t subtype, const uint8_t name[4], const void *appdata, std::size_t appdatalen);
 | |
| #endif // RTP_SUPPORT_SENDAPP
 | |
| 
 | |
|     /** 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. */
 | |
|     int SendRawData(const void *data, std::size_t len, bool usertpchannel);
 | |
| 
 | |
|     /** 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();
 | |
| 
 | |
|     /** Returns the Sequence Number that will be used in the next SendPacket function call. */
 | |
|     uint16_t GetNextSequenceNumber() const;
 | |
| 
 | |
|     /** 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. */
 | |
|     int SetMaximumPacketSize(std::size_t s);
 | |
| 
 | |
|     /** 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. */
 | |
|     int SetLocalName(const void *s, std::size_t len);
 | |
| 
 | |
|     /** Sets the SDES e-mail item for the local participant to the value \c s with length \c len. */
 | |
|     int SetLocalEMail(const void *s, std::size_t len);
 | |
| 
 | |
|     /** Sets the SDES location item for the local participant to the value \c s with length \c len. */
 | |
|     int SetLocalLocation(const void *s, std::size_t len);
 | |
| 
 | |
|     /** Sets the SDES phone item for the local participant to the value \c s with length \c len. */
 | |
|     int SetLocalPhone(const void *s, std::size_t len);
 | |
| 
 | |
|     /** Sets the SDES tool item for the local participant to the value \c s with length \c len. */
 | |
|     int SetLocalTool(const void *s, std::size_t len);
 | |
| 
 | |
|     /** Sets the SDES note item for the local participant to the value \c s with length \c len. */
 | |
|     int SetLocalNote(const void *s, std::size_t len);
 | |
| 
 | |
| protected:
 | |
|     /** 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. */
 | |
|     virtual void OnCNAMECollision(RTPSourceData *srcdat, const RTPAddress *senderaddress, const uint8_t *cname, std::size_t cnamelength);
 | |
| 
 | |
|     /** 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. */
 | |
|     virtual void OnRTCPSDESItem(RTPSourceData *srcdat, RTCPSDESPacket::ItemType t, const void *itemdata, std::size_t itemlength);
 | |
| #ifdef RTP_SUPPORT_SDESPRIV
 | |
|     /** Is called when a specific SDES item of 'private' type was received for this source. */
 | |
|     virtual void OnRTCPSDESPrivateItem(RTPSourceData *srcdat, const void *prefixdata, std::size_t prefixlen, const void *valuedata, std::size_t valuelen);
 | |
| #endif // RTP_SUPPORT_SDESPRIV
 | |
| 
 | |
|     /** 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. */
 | |
|     virtual int OnChangeRTPOrRTCPData(const void *origdata, std::size_t origlen, bool isrtp, void **senddata, std::size_t *sendlen);
 | |
| 
 | |
|     /** 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. */
 | |
|     virtual void OnSentRTPOrRTCPData(void *senddata, std::size_t sendlen, bool isrtp);
 | |
| 
 | |
|     /** 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);
 | |
| private:
 | |
|     int InternalCreate(const RTPSessionParams &sessparams);
 | |
|     int CreateCNAME(uint8_t *buffer, std::size_t *bufferlength, bool resolve);
 | |
|     int ProcessPolledData();
 | |
|     int ProcessRTCPCompoundPacket(RTCPCompoundPacket &rtcpcomppack, RTPRawPacket *pack);
 | |
|     RTPRandom *GetRandomNumberGenerator(RTPRandom *r);
 | |
|     int SendRTPData(const void *data, std::size_t len);
 | |
|     int SendRTCPData(const void *data, std::size_t len);
 | |
| 
 | |
|     RTPRandom *rtprnd;
 | |
|     bool deletertprnd;
 | |
| 
 | |
|     RTPTransmitter *rtptrans;
 | |
|     bool created;
 | |
|     bool deletetransmitter;
 | |
|     bool usingpollthread;
 | |
|     bool acceptownpackets;
 | |
|     bool useSR_BYEifpossible;
 | |
|     std::size_t maxpacksize;
 | |
|     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;
 | |
| };
 | |
| 
 | |
| 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)
 | |
| {
 | |
| }
 | |
| inline void RTPSession::OnCNAMECollision(RTPSourceData *, const RTPAddress *, const uint8_t *, std::size_t)
 | |
| {
 | |
| }
 | |
| 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 *)
 | |
| {
 | |
| }
 | |
| inline void RTPSession::OnRTCPSDESItem(RTPSourceData *, RTCPSDESPacket::ItemType, const void *, std::size_t)
 | |
| {
 | |
| }
 | |
| 
 | |
| #ifdef RTP_SUPPORT_SDESPRIV
 | |
| inline void RTPSession::OnRTCPSDESPrivateItem(RTPSourceData *, const void *, std::size_t, const void *, std::size_t)
 | |
| {
 | |
| }
 | |
| #endif // RTP_SUPPORT_SDESPRIV
 | |
| 
 | |
| inline void RTPSession::OnBYEPacket(RTPSourceData *)
 | |
| {
 | |
| }
 | |
| inline void RTPSession::OnSendRTCPCompoundPacket(RTCPCompoundPacket *)
 | |
| {
 | |
| }
 | |
| 
 | |
| inline int RTPSession::OnChangeRTPOrRTCPData(const void *, std::size_t, bool, void **, std::size_t *)
 | |
| {
 | |
|     return ERR_RTP_RTPSESSION_CHANGEREQUESTEDBUTNOTIMPLEMENTED;
 | |
| }
 | |
| inline void RTPSession::OnSentRTPOrRTCPData(void *, std::size_t, bool)
 | |
| {
 | |
| }
 | |
| inline bool RTPSession::OnChangeIncomingData(RTPRawPacket *)
 | |
| {
 | |
|     return true;
 | |
| }
 | |
| inline void RTPSession::OnValidatedRTPPacket(RTPSourceData *, RTPPacket *, bool, bool *)
 | |
| {
 | |
| }
 | |
| 
 | |
| } // end namespace
 | |
| 
 | |
| #endif // RTPSESSION_H
 | |
| 
 |