mirror of
				https://github.com/f4exb/sdrangel.git
				synced 2025-10-24 17:40:24 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			365 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			365 lines
		
	
	
		
			13 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 rtcppacketbuilder.h
 | |
|  */
 | |
| 
 | |
| #ifndef RTCPPACKETBUILDER_H
 | |
| 
 | |
| #define RTCPPACKETBUILDER_H
 | |
| 
 | |
| #include "rtpconfig.h"
 | |
| #include "rtptypes.h"
 | |
| #include "rtperrors.h"
 | |
| #include "rtcpsdesinfo.h"
 | |
| #include "rtptimeutilities.h"
 | |
| 
 | |
| #include "export.h"
 | |
| 
 | |
| namespace qrtplib
 | |
| {
 | |
| 
 | |
| class RTPSources;
 | |
| class RTPPacketBuilder;
 | |
| class RTCPScheduler;
 | |
| class RTCPCompoundPacket;
 | |
| class RTCPCompoundPacketBuilder;
 | |
| 
 | |
| /** This class can be used to build RTCP compound packets, on a higher level than the RTCPCompoundPacketBuilder.
 | |
|  *  The class RTCPPacketBuilder can be used to build RTCP compound packets. This class is more high-level
 | |
|  *  than the RTCPCompoundPacketBuilder class: it uses the information of an RTPPacketBuilder instance and of
 | |
|  *  an RTPSources instance to automatically generate the next compound packet which should be sent. It also
 | |
|  *  provides functions to determine when SDES items other than the CNAME item should be sent.
 | |
|  */
 | |
| class QRTPLIB_API RTCPPacketBuilder
 | |
| {
 | |
| public:
 | |
|     /** Creates an RTCPPacketBuilder instance.
 | |
|      *  Creates an instance which will use the source table \c sources and the RTP packet builder
 | |
|      *  \c rtppackbuilder to determine the information for the next RTCP compound packet. Optionally,
 | |
|      *  the memory manager \c mgr can be installed.
 | |
|      */
 | |
|     RTCPPacketBuilder(RTPSources &sources, RTPPacketBuilder &rtppackbuilder);
 | |
|     ~RTCPPacketBuilder();
 | |
| 
 | |
|     /** Initializes the builder.
 | |
|      *  Initializes the builder to use the maximum allowed packet size \c maxpacksize, timestamp unit
 | |
|      *  \c timestampunit and the SDES CNAME item specified by \c cname with length \c cnamelen.
 | |
|      *  The timestamp unit is defined as a time interval divided by the timestamp interval corresponding to
 | |
|      *  that interval: for 8000 Hz audio this would be 1/8000.
 | |
|      */
 | |
|     int Init(std::size_t maxpacksize, double timestampunit, const void *cname, std::size_t cnamelen);
 | |
| 
 | |
|     /** Cleans up the builder. */
 | |
|     void Destroy();
 | |
| 
 | |
|     /** Sets the timestamp unit to be used to \c tsunit.
 | |
|      *  Sets the timestamp unit to be used to \c tsunit. The timestamp unit is defined as a time interval
 | |
|      *  divided by the timestamp interval corresponding to that interval: for 8000 Hz audio this would
 | |
|      *  be 1/8000.
 | |
|      */
 | |
|     int SetTimestampUnit(double tsunit)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         if (tsunit < 0)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_ILLEGALTIMESTAMPUNIT;
 | |
|         timestampunit = tsunit;
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     /** Sets the maximum size allowed size of an RTCP compound packet to \c maxpacksize. */
 | |
|     int SetMaximumPacketSize(std::size_t maxpacksize)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         if (maxpacksize < RTP_MINPACKETSIZE)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_ILLEGALMAXPACKSIZE;
 | |
|         maxpacketsize = maxpacksize;
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     /** This function allows you to inform RTCP packet builder about the delay between sampling the first
 | |
|      *  sample of a packet and sending the packet.
 | |
|      *  This function allows you to inform RTCP packet builder 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         transmissiondelay = delay;
 | |
|         return 0;
 | |
|     }
 | |
| 
 | |
|     /** Builds the next RTCP compound packet which should be sent and stores it in \c pack. */
 | |
|     int BuildNextPacket(RTCPCompoundPacket **pack);
 | |
| 
 | |
|     /** Builds a BYE packet with reason for leaving specified by \c reason and length \c reasonlength.
 | |
|      *  Builds a BYE packet with reason for leaving specified by \c reason and length \c reasonlength. If
 | |
|      *  \c useSRifpossible is set to \c true, the RTCP compound packet will start with a sender report if
 | |
|      *  allowed. Otherwise, a receiver report is used.
 | |
|      */
 | |
|     int BuildBYEPacket(RTCPCompoundPacket **pack, const void *reason, std::size_t reasonlength, bool useSRifpossible = true);
 | |
| 
 | |
|     /** 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return;
 | |
|         interval_name = 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return;
 | |
|         interval_email = 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return;
 | |
|         interval_location = 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return;
 | |
|         interval_phone = 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return;
 | |
|         interval_tool = 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return;
 | |
|         interval_note = 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         return ownsdesinfo.SetName((const uint8_t *) s, 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         return ownsdesinfo.SetEMail((const uint8_t *) s, 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         return ownsdesinfo.SetLocation((const uint8_t *) s, 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         return ownsdesinfo.SetPhone((const uint8_t *) s, 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         return ownsdesinfo.SetTool((const uint8_t *) s, 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)
 | |
|     {
 | |
|         if (!init)
 | |
|             return ERR_RTP_RTCPPACKETBUILDER_NOTINIT;
 | |
|         return ownsdesinfo.SetNote((const uint8_t *) s, len);
 | |
|     }
 | |
| 
 | |
|     /** Returns the own CNAME item with length \c len */
 | |
|     uint8_t *GetLocalCNAME(std::size_t *len) const
 | |
|     {
 | |
|         if (!init)
 | |
|             return 0;
 | |
|         return ownsdesinfo.GetCNAME(len);
 | |
|     }
 | |
| private:
 | |
|     void ClearAllSourceFlags();
 | |
|     int FillInReportBlocks(RTCPCompoundPacketBuilder *pack, const RTPTime &curtime, int maxcount, bool *full, int *added, int *skipped, bool *atendoflist);
 | |
|     int FillInSDES(RTCPCompoundPacketBuilder *pack, bool *full, bool *processedall, int *added);
 | |
|     void ClearAllSDESFlags();
 | |
| 
 | |
|     RTPSources &sources;
 | |
|     RTPPacketBuilder &rtppacketbuilder;
 | |
| 
 | |
|     bool init;
 | |
|     std::size_t maxpacketsize;
 | |
|     double timestampunit;
 | |
|     bool firstpacket;
 | |
|     RTPTime prevbuildtime, transmissiondelay;
 | |
| 
 | |
|     class RTCPSDESInfoInternal: public RTCPSDESInfo
 | |
|     {
 | |
|     public:
 | |
|         RTCPSDESInfoInternal()
 | |
|         {
 | |
|             ClearFlags();
 | |
|         }
 | |
|         void ClearFlags()
 | |
|         {
 | |
|             pname = false;
 | |
|             pemail = false;
 | |
|             plocation = false;
 | |
|             pphone = false;
 | |
|             ptool = false;
 | |
|             pnote = false;
 | |
|         }
 | |
|         bool ProcessedName() const
 | |
|         {
 | |
|             return pname;
 | |
|         }
 | |
|         bool ProcessedEMail() const
 | |
|         {
 | |
|             return pemail;
 | |
|         }
 | |
|         bool ProcessedLocation() const
 | |
|         {
 | |
|             return plocation;
 | |
|         }
 | |
|         bool ProcessedPhone() const
 | |
|         {
 | |
|             return pphone;
 | |
|         }
 | |
|         bool ProcessedTool() const
 | |
|         {
 | |
|             return ptool;
 | |
|         }
 | |
|         bool ProcessedNote() const
 | |
|         {
 | |
|             return pnote;
 | |
|         }
 | |
|         void SetProcessedName(bool v)
 | |
|         {
 | |
|             pname = v;
 | |
|         }
 | |
|         void SetProcessedEMail(bool v)
 | |
|         {
 | |
|             pemail = v;
 | |
|         }
 | |
|         void SetProcessedLocation(bool v)
 | |
|         {
 | |
|             plocation = v;
 | |
|         }
 | |
|         void SetProcessedPhone(bool v)
 | |
|         {
 | |
|             pphone = v;
 | |
|         }
 | |
|         void SetProcessedTool(bool v)
 | |
|         {
 | |
|             ptool = v;
 | |
|         }
 | |
|         void SetProcessedNote(bool v)
 | |
|         {
 | |
|             pnote = v;
 | |
|         }
 | |
|     private:
 | |
|         bool pname, pemail, plocation, pphone, ptool, pnote;
 | |
|     };
 | |
| 
 | |
|     RTCPSDESInfoInternal ownsdesinfo;
 | |
|     int interval_name, interval_email, interval_location;
 | |
|     int interval_phone, interval_tool, interval_note;
 | |
|     bool doname, doemail, doloc, dophone, dotool, donote;
 | |
|     bool processingsdes;
 | |
| 
 | |
|     int sdesbuildcount;
 | |
| };
 | |
| 
 | |
| } // end namespace
 | |
| 
 | |
| #endif // RTCPPACKETBUILDER_H
 | |
| 
 |