41 #include "rtpconfig.h"
54 #ifdef RTP_SUPPORT_THREAD
55 #include <jthread/jmutex.h>
62 class RTPSessionParams;
63 class RTPTransmissionParams;
68 class RTPTransmissionInfo;
69 class RTCPCompoundPacket;
80 class JRTPLIB_IMPORTEXPORT
RTPSession :
public RTPMemoryObject
162 uint8_t pt,
bool mark,uint32_t timestampinc);
171 uint16_t hdrextID,
const void *hdrextdata,
size_t numhdrextwords);
180 uint8_t pt,
bool mark,uint32_t timestampinc,
181 uint16_t hdrextID,
const void *hdrextdata,
size_t numhdrextwords);
182 #ifdef RTP_SUPPORT_SENDAPP
190 int SendRTCPAPPPacket(uint8_t subtype,
const uint8_t name[4],
const void *appdata,
size_t appdatalen);
193 #ifdef RTP_SUPPORT_RTCPUNKNOWN
199 int SendUnknownPacket(
bool sr, uint8_t payload_type, uint8_t subtype,
const void *data,
size_t len);
205 int SendRawData(
const void *data,
size_t len,
bool usertpchannel);
456 void DumpTransmitter();
489 const uint8_t *cname,
size_t cnamelength);
510 virtual void OnUnknownPacketType(
RTCPPacket *rtcppack,
const RTPTime &receivetime,
514 virtual void OnUnknownPacketFormat(
RTCPPacket *rtcppack,
const RTPTime &receivetime,
528 const void *itemdata,
size_t itemlength);
529 #ifdef RTP_SUPPORT_SDESPRIV
531 virtual void OnRTCPSDESPrivateItem(
RTPSourceData *srcdat,
const void *prefixdata,
size_t prefixlen,
532 const void *valuedata,
size_t valuelen);
540 #ifdef RTP_SUPPORT_THREAD
542 virtual void OnPollThreadError(
int errcode);
548 virtual void OnPollThreadStep();
555 virtual void OnPollThreadStart(
bool &stop);
560 virtual void OnPollThreadStop();
580 virtual int OnChangeRTPOrRTCPData(
const void *origdata,
size_t origlen,
bool isrtp,
void **senddata,
size_t *sendlen);
585 virtual void OnSentRTPOrRTCPData(
void *senddata,
size_t sendlen,
bool isrtp);
593 virtual bool OnChangeIncomingData(
RTPRawPacket *rawpack);
605 virtual void OnValidatedRTPPacket(
RTPSourceData *srcdat,
RTPPacket *rtppack,
bool isonprobation,
bool *ispackethandled);
608 int CreateCNAME(uint8_t *buffer,
size_t *bufferlength,
bool resolve);
609 int ProcessPolledData();
612 int SendRTPData(
const void *data,
size_t len);
613 int SendRTCPData(
const void *data,
size_t len);
620 bool deletetransmitter;
621 bool usingpollthread, needthreadsafety;
622 bool acceptownpackets;
623 bool useSR_BYEifpossible;
625 double sessionbandwidth;
626 double controlfragment;
627 double sendermultiplier;
628 double byemultiplier;
629 double membermultiplier;
630 double collisionmultiplier;
631 double notemultiplier;
634 bool m_changeIncomingData, m_changeOutgoingData;
636 RTPSessionSources sources;
642 std::list<RTCPCompoundPacket *> byepackets;
644 #ifdef RTP_SUPPORT_THREAD
645 RTPPollThread *pollthread;
646 jthread::JMutex sourcesmutex,buildermutex,schedmutex,packsentmutex;
648 friend class RTPPollThread;
650 friend class RTPSessionSources;
651 friend class RTCPSessionPacketBuilder;
671 #ifdef RTP_SUPPORT_SDESPRIV
678 #ifdef RTP_SUPPORT_THREAD
686 return ERR_RTP_RTPSESSION_CHANGEREQUESTEDBUTNOTIMPLEMENTED;
Describes an RTCP APP packet.
Definition: rtcpapppacket.h:55
Represents an RTCP compound packet.
Definition: rtcpcompoundpacket.h:54
This class can be used to build RTCP compound packets, on a higher level than the RTCPCompoundPacketB...
Definition: rtcppacketbuilder.h:64
Base class for specific types of RTCP packets.
Definition: rtcppacket.h:51
ItemType
Identifies the type of an SDES item.
Definition: rtcpsdespacket.h:60
This class determines when RTCP compound packets should be sent.
Definition: rtcpscheduler.h:102
This class is an abstract class which is used to specify destinations, multicast groups etc.
Definition: rtpaddress.h:51
This class represents a list of addresses from which SSRC collisions were detected.
Definition: rtpcollisionlist.h:54
A memory manager.
Definition: rtpmemorymanager.h:151
This class can be used to build RTP packets and is a bit more high-level than the RTPPacket class: it...
Definition: rtppacketbuilder.h:58
Represents an RTP Packet.
Definition: rtppacket.h:57
Interface for generating random numbers.
Definition: rtprandom.h:52
This class is used by the transmission component to store the incoming RTP and RTCP data in.
Definition: rtprawpacket.h:53
Describes the parameters for to be used by an RTPSession instance.
Definition: rtpsessionparams.h:55
High level class for using RTP.
Definition: rtpsession.h:81
int DeleteDestination(const RTPAddress &addr)
Deletes addr from the list of destinations.
void DeleteTransmissionInfo(RTPTransmissionInfo *inf)
Frees the memory used by the transmission information inf.
virtual void OnSendRTCPCompoundPacket(RTCPCompoundPacket *pack)
Is called when an RTCP compound packet has just been sent (useful to inspect outgoing RTCP data).
Definition: rtpsession.h:676
virtual void OnPollThreadError(int errcode)
Is called when error errcode was detected in the poll thread.
Definition: rtpsession.h:679
int SetPreTransmissionDelay(const RTPTime &delay)
This function allows you to inform the library about the delay between sampling the first sample of a...
virtual void OnRTPPacket(RTPPacket *pack, const RTPTime &receivetime, const RTPAddress *senderaddress)
Is called when an incoming RTP packet is about to be processed.
Definition: rtpsession.h:655
bool GotoNextSourceWithData()
Sets the current source to be the next source in the table which has RTPPacket instances that we have...
void SetEMailInterval(int count)
Sets the RTCP interval for the SDES e-mail item.
bool IsActive()
Returns whether the session has been created or not.
virtual int OnChangeRTPOrRTCPData(const void *origdata, size_t origlen, bool isrtp, void **senddata, size_t *sendlen)
If RTPSession::SetChangeOutgoingData was sent to true, overriding this you can change the data packet...
Definition: rtpsession.h:685
bool GotoPreviousSource()
Sets the current source to be the previous source in the table.
int SetLocalTool(const void *s, size_t len)
Sets the SDES tool item for the local participant to the value s with length len.
virtual void OnRTCPSDESItem(RTPSourceData *srcdat, RTCPSDESPacket::ItemType t, const void *itemdata, size_t itemlength)
Is called when a specific SDES item was received for this source.
Definition: rtpsession.h:669
int AddToIgnoreList(const RTPAddress &addr)
Adds addr to the list of addresses to ignore.
virtual RTPTransmitter * NewUserDefinedTransmitter()
Allocate a user defined transmitter.
Definition: rtpsession.h:654
int LeaveMulticastGroup(const RTPAddress &addr)
Leaves the multicast group specified by addr.
int SetLocalName(const void *s, size_t len)
Sets the SDES name item for the local participant to the value s with length len.
int AbortWait()
If the previous function has been called, this one aborts the waiting (only works when you're not usi...
void ClearDestinations()
Clears the list of destinations.
int AddDestination(const RTPAddress &addr)
Adds addr to the list of destinations.
virtual void OnPollThreadStart(bool &stop)
Is called when the poll thread is started.
Definition: rtpsession.h:681
int IncrementTimestampDefault()
This function increments the timestamp with the amount given set by the SetDefaultTimestampIncrement ...
int SetLocalLocation(const void *s, size_t len)
Sets the SDES location item for the local participant to the value s with length len.
virtual void OnAPPPacket(RTCPAPPPacket *apppacket, const RTPTime &receivetime, const RTPAddress *senderaddress)
Is called when an RTCP APP packet apppacket has been received at time receivetime from address sender...
Definition: rtpsession.h:663
int SetDefaultPayloadType(uint8_t pt)
Sets the default payload type for RTP packets to pt.
int SetMaximumPacketSize(size_t s)
Sets the maximum allowed packet size to s.
int JoinMulticastGroup(const RTPAddress &addr)
Joins the multicast group specified by addr.
void SetChangeIncomingData(bool change)
If this is set to true, incoming data will be passed through RTPSession::OnChangeIncomingData,...
Definition: rtpsession.h:569
void SetChangeOutgoingData(bool change)
If this is set to true, outgoing data will be passed through RTPSession::OnChangeRTPOrRTCPData and RT...
Definition: rtpsession.h:565
int WaitForIncomingData(const RTPTime &delay, bool *dataavailable=0)
Waits at most a time delay until incoming data has been detected.
virtual void OnCNAMECollision(RTPSourceData *srcdat, const RTPAddress *senderaddress, const uint8_t *cname, size_t cnamelength)
Is called when another CNAME was received than the one already present for source srcdat.
Definition: rtpsession.h:658
RTPSession(RTPRandom *rnd=0, RTPMemoryManager *mgr=0)
Constructs an RTPSession instance, optionally using a specific instance of a random number generator,...
int SendRTCPAPPPacket(uint8_t subtype, const uint8_t name[4], const void *appdata, size_t appdatalen)
If sending of RTCP APP packets was enabled at compile time, this function creates a compound packet c...
virtual void OnPollThreadStep()
Is called each time the poll thread loops.
Definition: rtpsession.h:680
int Create(const RTPSessionParams &sessparams, RTPTransmitter *transmitter)
Creates an RTP session using transmitter as transmission component.
int Create(const RTPSessionParams &sessparams, const RTPTransmissionParams *transparams=0, RTPTransmitter::TransmissionProtocol proto=RTPTransmitter::IPv4UDPProto)
Creates an RTP session.
void SetPhoneInterval(int count)
Sets the RTCP interval for the SDES phone item.
virtual void OnRemoveSource(RTPSourceData *srcdat)
Is called when the entry srcdat is about to be deleted from the source table.
Definition: rtpsession.h:660
int BeginDataAccess()
The following member functions (till EndDataAccess}) need to be accessed between a call to BeginDataA...
virtual void OnUnknownPacketFormat(RTCPPacket *rtcppack, const RTPTime &receivetime, const RTPAddress *senderaddress)
Is called when an unknown packet format for a known packet type was detected.
Definition: rtpsession.h:665
void SetNoteInterval(int count)
Sets the RTCP interval for the SDES note item.
int SetDefaultMark(bool m)
Sets the default marker for RTP packets to m.
void LeaveAllMulticastGroups()
Leaves all multicast groups.
virtual bool OnChangeIncomingData(RTPRawPacket *rawpack)
By overriding this function, the raw incoming data can be inspected and modified (e....
Definition: rtpsession.h:689
RTPSourceData * GetSourceInfo(uint32_t ssrc)
Returns the RTPSourceData instance for the participant identified by ssrc, or NULL if no such entry e...
bool GotoPreviousSourceWithData()
Sets the current source to be the previous source in the table which has RTPPacket instances that we ...
virtual void OnSSRCCollision(RTPSourceData *srcdat, const RTPAddress *senderaddress, bool isrtp)
Is called when an SSRC collision was detected.
Definition: rtpsession.h:657
void ClearAcceptList()
Clears the list of addresses to accept.
int SetLocalPhone(const void *s, size_t len)
Sets the SDES phone item for the local participant to the value s with length len.
virtual void OnRTCPSDESPrivateItem(RTPSourceData *srcdat, const void *prefixdata, size_t prefixlen, const void *valuedata, size_t valuelen)
Is called when a specific SDES item of 'private' type was received for this source.
Definition: rtpsession.h:672
int SendUnknownPacket(bool sr, uint8_t payload_type, uint8_t subtype, const void *data, size_t len)
Tries to send an Unknown packet immediately.
virtual void OnBYETimeout(RTPSourceData *srcdat)
Is called when participant srcdat is timed after having sent a BYE packet.
Definition: rtpsession.h:662
int SendPacketEx(const void *data, size_t len, uint8_t pt, bool mark, uint32_t timestampinc, uint16_t hdrextID, const void *hdrextdata, size_t numhdrextwords)
Sends the RTP packet with payload data which has length len.
virtual void OnRTCPReceiverReport(RTPSourceData *srcdat)
Is called when an RTCP receiver report has been processed for this source.
Definition: rtpsession.h:668
void DeletePacket(RTPPacket *p)
Frees the memory used by p.
virtual void OnNewSource(RTPSourceData *srcdat)
Is called when a new entry srcdat is added to the source table.
Definition: rtpsession.h:659
bool GotoFirstSourceWithData()
Sets the current source to be the first source in the table which has RTPPacket instances that we hav...
int SetReceiveMode(RTPTransmitter::ReceiveMode m)
Sets the receive mode to m.
virtual void OnRTCPCompoundPacket(RTCPCompoundPacket *pack, const RTPTime &receivetime, const RTPAddress *senderaddress)
Is called when an incoming RTCP packet is about to be processed.
Definition: rtpsession.h:656
RTPPacket * GetNextPacket()
Extracts the next packet from the received packets queue of the current participant,...
void ClearIgnoreList()
Clears the list of addresses to ignore.
uint16_t GetNextSequenceNumber() const
Returns the Sequence Number that will be used in the next SendPacket function call.
int SetDefaultTimestampIncrement(uint32_t timestampinc)
Sets the default value to increment the timestamp with to timestampinc.
RTPTransmissionInfo * GetTransmissionInfo()
This function returns an instance of a subclass of RTPTransmissionInfo which will give some additiona...
virtual void OnPollThreadStop()
Is called when the poll thread is going to stop.
Definition: rtpsession.h:682
int AddToAcceptList(const RTPAddress &addr)
Adds addr to the list of addresses to accept.
void SetNameInterval(int count)
Sets the RTCP interval for the SDES name item.
int SendPacket(const void *data, size_t len, uint8_t pt, bool mark, uint32_t timestampinc)
Sends the RTP packet with payload data which has length len.
void SetLocationInterval(int count)
Sets the RTCP interval for the SDES location item.
uint32_t GetLocalSSRC()
Returns our own SSRC.
virtual void OnNoteTimeout(RTPSourceData *srcdat)
Is called when the SDES NOTE item for source srcdat has been timed out.
Definition: rtpsession.h:666
int Poll()
If you're not using the poll thread, this function must be called regularly to process incoming data ...
int SetSessionBandwidth(double bw)
Sets the session bandwidth to bw, which is specified in bytes per second.
bool SupportsMulticasting()
Returns true if multicasting is supported.
virtual void OnBYEPacket(RTPSourceData *srcdat)
Is called when a BYE packet has been processed for source srcdat.
Definition: rtpsession.h:675
int EndDataAccess()
See BeginDataAccess.
virtual void OnRTCPSenderReport(RTPSourceData *srcdat)
Is called when an RTCP sender report has been processed for this source.
Definition: rtpsession.h:667
virtual void OnSentRTPOrRTCPData(void *senddata, size_t sendlen, bool isrtp)
This function is called when an RTP or RTCP packet was sent, it can be helpful when data was allocate...
Definition: rtpsession.h:688
int SendRawData(const void *data, size_t len, bool usertpchannel)
With this function raw data can be sent directly over the RTP or RTCP channel (if they are different)...
int SetTimestampUnit(double u)
Sets the timestamp unit for our own data.
bool GotoFirstSource()
Starts the iteration over the participants by going to the first member in the table.
virtual void OnTimeout(RTPSourceData *srcdat)
Is called when participant srcdat is timed out.
Definition: rtpsession.h:661
void Destroy()
Leaves the session without sending a BYE packet.
RTPSourceData * GetCurrentSourceInfo()
Returns the RTPSourceData instance for the currently selected participant.
int DeleteFromIgnoreList(const RTPAddress &addr)
Deletes addr from the list of addresses to ignore.
int DeleteFromAcceptList(const RTPAddress &addr)
Deletes addr from the list of addresses to accept.
virtual void OnValidatedRTPPacket(RTPSourceData *srcdat, RTPPacket *rtppack, bool isonprobation, bool *ispackethandled)
Allows you to use an RTP packet from the specified source directly.
Definition: rtpsession.h:690
bool GotoNextSource()
Sets the current source to be the next source in the table.
int SendPacketEx(const void *data, size_t len, uint16_t hdrextID, const void *hdrextdata, size_t numhdrextwords)
Sends the RTP packet with payload data which has length len.
void BYEDestroy(const RTPTime &maxwaittime, const void *reason, size_t reasonlength)
Sends a BYE packet and leaves the session.
int IncrementTimestamp(uint32_t inc)
This function increments the timestamp with the amount given by inc.
int SetLocalEMail(const void *s, size_t len)
Sets the SDES e-mail item for the local participant to the value s with length len.
void SetToolInterval(int count)
Sets the RTCP interval for the SDES tool item.
virtual void OnUnknownPacketType(RTCPPacket *rtcppack, const RTPTime &receivetime, const RTPAddress *senderaddress)
Is called when an unknown RTCP packet type was detected.
Definition: rtpsession.h:664
int SendPacket(const void *data, size_t len)
Sends the RTP packet with payload data which has length len.
int SetLocalNote(const void *s, size_t len)
Sets the SDES note item for the local participant to the value s with length len.
RTPTime GetRTCPDelay()
Returns the time interval after which an RTCP compound packet may have to be sent (only works when yo...
Describes an entry in the RTPSources source table.
Definition: rtpsourcedata.h:167
This class is used to specify wallclock time, delay intervals etc.
Definition: rtptimeutilities.h:86
Base class for additional information about the transmitter.
Definition: rtptransmitter.h:249
Base class for transmission parameters.
Definition: rtptransmitter.h:230
Abstract class from which actual transmission components should be derived.
Definition: rtptransmitter.h:63
ReceiveMode
Three kind of receive modes can be specified.
Definition: rtptransmitter.h:81
TransmissionProtocol
Used to identify a specific transmitter.
Definition: rtptransmitter.h:71
@ IPv4UDPProto
Specifies the internal UDP over IPv4 transmitter.
Definition: rtptransmitter.h:72