| 
									
										
										
										
											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 rtppacket.h | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef RTPPACKET_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define RTPPACKET_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "rtpconfig.h"
 | 
					
						
							|  |  |  | #include "rtptypes.h"
 | 
					
						
							|  |  |  | #include "rtptimeutilities.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-27 02:14:45 +01:00
										 |  |  | #include "rtpendian.h"
 | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace qrtplib | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class RTPRawPacket; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /** Represents an RTP Packet.
 | 
					
						
							|  |  |  |  *  The RTPPacket class can be used to parse a RTPRawPacket instance if it represents RTP data. | 
					
						
							|  |  |  |  *  The class can also be used to create a new RTP packet according to the parameters specified by | 
					
						
							|  |  |  |  *  the user. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2018-02-27 23:26:03 +01:00
										 |  |  | class RTPPacket | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     /** Creates an RTPPacket instance based upon the data in \c rawpack, optionally installing a memory manager.
 | 
					
						
							|  |  |  |      *  Creates an RTPPacket instance based upon the data in \c rawpack, optionally installing a memory manager. | 
					
						
							|  |  |  |      *  If successful, the data is moved from the raw packet to the RTPPacket instance. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     RTPPacket(RTPRawPacket &rawpack); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Creates a new buffer for an RTP packet and fills in the fields according to the specified parameters.
 | 
					
						
							|  |  |  |      *  Creates a new buffer for an RTP packet and fills in the fields according to the specified parameters. | 
					
						
							|  |  |  |      *  If \c maxpacksize is not equal to zero, an error is generated if the total packet size would exceed | 
					
						
							|  |  |  |      *  \c maxpacksize. The arguments of the constructor are self-explanatory. Note that the size of a header | 
					
						
							|  |  |  |      *  extension is specified in a number of 32-bit words. A memory manager can be installed. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2018-03-29 19:55:03 +02:00
										 |  |  |     RTPPacket(uint8_t payloadtype, | 
					
						
							|  |  |  |             const void *payloaddata, | 
					
						
							|  |  |  |             unsigned int payloadlen, | 
					
						
							|  |  |  |             uint16_t seqnr, | 
					
						
							|  |  |  |             uint32_t timestamp, | 
					
						
							|  |  |  |             uint32_t ssrc, | 
					
						
							|  |  |  |             bool gotmarker, | 
					
						
							|  |  |  |             uint8_t numcsrcs, | 
					
						
							|  |  |  |             const uint32_t *csrcs, | 
					
						
							|  |  |  |             bool gotextension, | 
					
						
							|  |  |  |             uint16_t extensionid, | 
					
						
							|  |  |  |             uint16_t extensionlen_numwords, | 
					
						
							|  |  |  |             const void *extensiondata, | 
					
						
							|  |  |  |             unsigned int maxpacksize); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /** This constructor is similar to the other constructor, but here data is stored in an external buffer
 | 
					
						
							|  |  |  |      *  \c buffer with size \c buffersize. */ | 
					
						
							| 
									
										
										
										
											2018-03-29 19:55:03 +02:00
										 |  |  |     RTPPacket(uint8_t payloadtype, | 
					
						
							|  |  |  |             const void *payloaddata, | 
					
						
							|  |  |  |             unsigned int payloadlen, | 
					
						
							|  |  |  |             uint16_t seqnr, | 
					
						
							|  |  |  |             uint32_t timestamp, | 
					
						
							|  |  |  |             uint32_t ssrc, | 
					
						
							|  |  |  |             bool gotmarker, | 
					
						
							|  |  |  |             uint8_t numcsrcs, | 
					
						
							|  |  |  |             const uint32_t *csrcs, | 
					
						
							|  |  |  |             bool gotextension, | 
					
						
							|  |  |  |             uint16_t extensionid, | 
					
						
							|  |  |  |             uint16_t extensionlen_numwords, | 
					
						
							|  |  |  |             const void *extensiondata, | 
					
						
							|  |  |  |             void *buffer, | 
					
						
							|  |  |  |             unsigned int buffersize); | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     virtual ~RTPPacket() | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         if (packet && !externalbuffer) | 
					
						
							|  |  |  |             delete[] packet; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** If an error occurred in one of the constructors, this function returns the error code. */ | 
					
						
							|  |  |  |     int GetCreationError() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return error; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns \c true if the RTP packet has a header extension and \c false otherwise. */ | 
					
						
							|  |  |  |     bool HasExtension() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return hasextension; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns \c true if the marker bit was set and \c false otherwise. */ | 
					
						
							|  |  |  |     bool HasMarker() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return hasmarker; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the number of CSRCs contained in this packet. */ | 
					
						
							|  |  |  |     int GetCSRCCount() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return numcsrcs; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns a specific CSRC identifier.
 | 
					
						
							|  |  |  |      *  Returns a specific CSRC identifier. The parameter \c num can go from 0 to GetCSRCCount()-1. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint32_t GetCSRC(int num) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the payload type of the packet. */ | 
					
						
							|  |  |  |     uint8_t GetPayloadType() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return payloadtype; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the extended sequence number of the packet.
 | 
					
						
							|  |  |  |      *  Returns the extended sequence number of the packet. When the packet is just received, | 
					
						
							|  |  |  |      *  only the low $16$ bits will be set. The high 16 bits can be filled in later. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     uint32_t GetExtendedSequenceNumber() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return extseqnr; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the sequence number of this packet. */ | 
					
						
							|  |  |  |     uint16_t GetSequenceNumber() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return (uint16_t) (extseqnr & 0x0000FFFF); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Sets the extended sequence number of this packet to \c seq. */ | 
					
						
							|  |  |  |     void SetExtendedSequenceNumber(uint32_t seq) | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         extseqnr = seq; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the timestamp of this packet. */ | 
					
						
							|  |  |  |     uint32_t GetTimestamp() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return timestamp; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the SSRC identifier stored in this packet. */ | 
					
						
							|  |  |  |     uint32_t GetSSRC() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return ssrc; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns a pointer to the data of the entire packet. */ | 
					
						
							|  |  |  |     uint8_t *GetPacketData() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return packet; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns a pointer to the actual payload data. */ | 
					
						
							|  |  |  |     uint8_t *GetPayloadData() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return payload; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the length of the entire packet. */ | 
					
						
							| 
									
										
										
										
											2018-03-29 19:55:03 +02:00
										 |  |  |     unsigned int GetPacketLength() const | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         return packetlength; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the payload length. */ | 
					
						
							| 
									
										
										
										
											2018-03-29 19:55:03 +02:00
										 |  |  |     unsigned int GetPayloadLength() const | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         return payloadlength; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** If a header extension is present, this function returns the extension identifier. */ | 
					
						
							|  |  |  |     uint16_t GetExtensionID() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return extid; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the length of the header extension data. */ | 
					
						
							|  |  |  |     uint8_t *GetExtensionData() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return extension; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the length of the header extension data. */ | 
					
						
							| 
									
										
										
										
											2018-03-29 19:55:03 +02:00
										 |  |  |     unsigned int GetExtensionLength() const | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     { | 
					
						
							|  |  |  |         return extensionlength; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /** Returns the time at which this packet was received.
 | 
					
						
							|  |  |  |      *  When an RTPPacket instance is created from an RTPRawPacket instance, the raw packet's | 
					
						
							|  |  |  |      *  reception time is stored in the RTPPacket instance. This function then retrieves that | 
					
						
							|  |  |  |      *  time. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     RTPTime GetReceiveTime() const | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |         return receivetime; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     void Clear(); | 
					
						
							|  |  |  |     int ParseRawPacket(RTPRawPacket &rawpack); | 
					
						
							| 
									
										
										
										
											2018-03-29 19:55:03 +02:00
										 |  |  |     int BuildPacket(uint8_t payloadtype, const void *payloaddata, unsigned int payloadlen, uint16_t seqnr, uint32_t timestamp, uint32_t ssrc, bool gotmarker, uint8_t numcsrcs, | 
					
						
							|  |  |  |             const uint32_t *csrcs, bool gotextension, uint16_t extensionid, uint16_t extensionlen_numwords, const void *extensiondata, void *buffer, unsigned int maxsize); | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     RTPEndian m_endian; | 
					
						
							|  |  |  |     int error; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     bool hasextension, hasmarker; | 
					
						
							|  |  |  |     int numcsrcs; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     uint8_t payloadtype; | 
					
						
							|  |  |  |     uint32_t extseqnr, timestamp, ssrc; | 
					
						
							|  |  |  |     uint8_t *packet, *payload; | 
					
						
							| 
									
										
										
										
											2018-03-29 19:55:03 +02:00
										 |  |  |     unsigned int packetlength, payloadlength; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     uint16_t extid; | 
					
						
							|  |  |  |     uint8_t *extension; | 
					
						
							| 
									
										
										
										
											2018-03-29 19:55:03 +02:00
										 |  |  |     unsigned int extensionlength; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     bool externalbuffer; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-02-27 23:05:46 +01:00
										 |  |  |     RTPTime receivetime; | 
					
						
							| 
									
										
										
										
											2018-02-27 01:35:16 +01:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // end namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif // RTPPACKET_H
 | 
					
						
							|  |  |  | 
 |