summaryrefslogtreecommitdiffstats
path: root/src/rtcppacketbuilder.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/rtcppacketbuilder.h')
-rw-r--r--src/rtcppacketbuilder.h224
1 files changed, 224 insertions, 0 deletions
diff --git a/src/rtcppacketbuilder.h b/src/rtcppacketbuilder.h
new file mode 100644
index 0000000..cf043f0
--- /dev/null
+++ b/src/rtcppacketbuilder.h
@@ -0,0 +1,224 @@
+/*
+
+ This file is a part of JRTPLIB
+ Copyright (c) 1999-2007 Jori Liesenborgs
+
+ Contact: jori.liesenborgs@gmail.com
+
+ This library was developed at the "Expertisecentrum Digitale 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 "rtpmemoryobject.h"
+
+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 RTCPPacketBuilder : public RTPMemoryObject
+{
+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, RTPMemoryManager *mgr = 0);
+ ~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(size_t maxpacksize,double timestampunit,const void *cname,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(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,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,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,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,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,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,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,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(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;
+ size_t maxpacketsize;
+ double timestampunit;
+ bool firstpacket;
+ RTPTime prevbuildtime,transmissiondelay;
+
+ class RTCPSDESInfoInternal : public RTCPSDESInfo
+ {
+ public:
+ RTCPSDESInfoInternal(RTPMemoryManager *mgr) : RTCPSDESInfo(mgr) { 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;
+};
+
+#endif // RTCPPACKETBUILDER_H
+