| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <unordered_map>
 | 
					
						
							|  |  |  | #include <memory>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-14 01:36:27 +00:00
										 |  |  | #include "holepuncher.hh"
 | 
					
						
							| 
									
										
										
										
											2020-08-04 05:53:27 +00:00
										 |  |  | #include "pkt_dispatch.hh"
 | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | #include "rtcp.hh"
 | 
					
						
							|  |  |  | #include "socket.hh"
 | 
					
						
							| 
									
										
										
										
											2020-09-02 05:29:04 +00:00
										 |  |  | #include "srtp/srtcp.hh"
 | 
					
						
							|  |  |  | #include "srtp/srtp.hh"
 | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | #include "util.hh"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-04 08:32:50 +00:00
										 |  |  | #include "formats/media.hh"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  | namespace uvgrtp { | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     class media_stream { | 
					
						
							|  |  |  |         public: | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /// \cond DO_NOT_DOCUMENT
 | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |             media_stream(std::string addr, int src_port, int dst_port, rtp_format_t fmt, int flags); | 
					
						
							| 
									
										
										
										
											2020-04-03 08:45:19 +00:00
										 |  |  |             media_stream(std::string remote_addr, std::string local_addr, int src_port, int dst_port, rtp_format_t fmt, int flags); | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |             ~media_stream(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /* Initialize traditional RTP session
 | 
					
						
							|  |  |  |              * Allocate Connection/Reader/Writer objects and initialize them | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * Return RTP_OK on success | 
					
						
							|  |  |  |              * Return RTP_MEMORY_ERROR if allocation failed | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * Other error return codes are defined in {conn,writer,reader}.hh */ | 
					
						
							|  |  |  |             rtp_error_t init(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /* Initialize Secure RTP session
 | 
					
						
							|  |  |  |              * Allocate Connection/Reader/Writer objects and initialize them | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * Return RTP_OK on success | 
					
						
							|  |  |  |              * Return RTP_MEMORY_ERROR if allocation failed | 
					
						
							|  |  |  |              * | 
					
						
							| 
									
										
										
										
											2020-02-25 07:48:02 +00:00
										 |  |  |              * TODO document all error codes! | 
					
						
							|  |  |  |              * | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |              * Other error return codes are defined in {conn,writer,reader,srtp}.hh */ | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             rtp_error_t init(uvgrtp::zrtp *zrtp); | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /// \endcond
 | 
					
						
							| 
									
										
										
										
											2020-04-29 22:45:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 12:29:06 +00:00
										 |  |  |             /**
 | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \brief Add keying information for user-managed SRTP session | 
					
						
							| 
									
										
										
										
											2020-04-29 22:45:28 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:29:06 +00:00
										 |  |  |              * \details For user-managed SRTP session, the media stream is not started | 
					
						
							| 
									
										
										
										
											2020-04-29 22:45:28 +00:00
										 |  |  |              * until SRTP key has been added and all calls to push_frame() will fail | 
					
						
							|  |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:29:06 +00:00
										 |  |  |              * Notice that if user-managed SRTP has been enabled during media stream creation, | 
					
						
							|  |  |  |              * this function must be called before anything else. All calls to other functions | 
					
						
							|  |  |  |              * will fail with ::RTP_NOT_INITIALIZED until the SRTP context has been specified | 
					
						
							|  |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-04-22 09:39:07 +00:00
										 |  |  |              * \param key SRTP master key, default is 128-bit long | 
					
						
							| 
									
										
										
										
											2021-02-23 12:29:06 +00:00
										 |  |  |              * \param salt 112-bit long salt | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \return RTP error code | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \retval  RTP_OK On success | 
					
						
							|  |  |  |              * \retval  RTP_INVALID_VALUE If key or salt is invalid | 
					
						
							|  |  |  |              * \retval  RTP_NOT_SUPPORTED If user-managed SRTP was not specified in create_stream() */ | 
					
						
							| 
									
										
										
										
											2020-04-29 22:45:28 +00:00
										 |  |  |             rtp_error_t add_srtp_ctx(uint8_t *key, uint8_t *salt); | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 12:19:32 +00:00
										 |  |  |             /**
 | 
					
						
							|  |  |  |              * \brief Send data to remote participant with a custom timestamp | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:19:32 +00:00
										 |  |  |              * \details If so specified either by the selected media format and/or given | 
					
						
							|  |  |  |              * ::RTP_CTX_ENABLE_FLAGS, uvgRTP fragments the input data into RTP packets of 1500 bytes, | 
					
						
							|  |  |  |              * or to any other size defined by the application using ::RCC_MTU_SIZE | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:19:32 +00:00
										 |  |  |              * The frame is automatically reconstructed by the receiver if all fragments have been | 
					
						
							|  |  |  |              * received successfully. | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:19:32 +00:00
										 |  |  |              * \param data Pointer to data the that should be sent | 
					
						
							|  |  |  |              * \param data_len Length of data | 
					
						
							|  |  |  |              * \param flags Optional flags, see ::RTP_FLAGS for more details | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:19:32 +00:00
										 |  |  |              * \return RTP error code | 
					
						
							| 
									
										
										
										
											2020-06-01 10:18:11 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:19:32 +00:00
										 |  |  |              * \retval  RTP_OK            On success | 
					
						
							|  |  |  |              * \retval  RTP_INVALID_VALUE If one of the parameters are invalid | 
					
						
							|  |  |  |              * \retval  RTP_MEMORY_ERROR  If the data chunk is too large to be processed | 
					
						
							|  |  |  |              * \retval  RTP_SEND_ERROR    If uvgRTP failed to send the data to remote | 
					
						
							|  |  |  |              * \retval  RTP_GENERIC_ERROR If an unspecified error occurred | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |             rtp_error_t push_frame(uint8_t *data, size_t data_len, int flags); | 
					
						
							| 
									
										
										
										
											2021-02-23 12:19:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /**
 | 
					
						
							|  |  |  |              * \brief Send data to remote participant with a custom timestamp | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \details If so specified either by the selected media format and/or given | 
					
						
							|  |  |  |              * ::RTP_CTX_ENABLE_FLAGS, uvgRTP fragments the input data into RTP packets of 1500 bytes, | 
					
						
							|  |  |  |              * or to any other size defined by the application using ::RCC_MTU_SIZE | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * The frame is automatically reconstructed by the receiver if all fragments have been | 
					
						
							|  |  |  |              * received successfully. | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \param data Smart pointer to data the that should be sent | 
					
						
							|  |  |  |              * \param data_len Length of data | 
					
						
							|  |  |  |              * \param flags Optional flags, see ::RTP_FLAGS for more details | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \return RTP error code | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \retval  RTP_OK            On success | 
					
						
							|  |  |  |              * \retval  RTP_INVALID_VALUE If one of the parameters are invalid | 
					
						
							|  |  |  |              * \retval  RTP_MEMORY_ERROR  If the data chunk is too large to be processed | 
					
						
							|  |  |  |              * \retval  RTP_SEND_ERROR    If uvgRTP failed to send the data to remote | 
					
						
							|  |  |  |              * \retval  RTP_GENERIC_ERROR If an unspecified error occurred | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |             rtp_error_t push_frame(std::unique_ptr<uint8_t[]> data, size_t data_len, int flags); | 
					
						
							| 
									
										
										
										
											2021-02-23 12:19:32 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /**
 | 
					
						
							|  |  |  |              * \brief Send data to remote participant with a custom timestamp | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \details If so specified either by the selected media format and/or given | 
					
						
							|  |  |  |              * ::RTP_CTX_ENABLE_FLAGS, uvgRTP fragments the input data into RTP packets of 1500 bytes, | 
					
						
							|  |  |  |              * or to any other size defined by the application using ::RCC_MTU_SIZE | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * The frame is automatically reconstructed by the receiver if all fragments have been | 
					
						
							|  |  |  |              * received successfully. | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * If application so wishes, it may override uvgRTP's own timestamp | 
					
						
							|  |  |  |              * calculations and provide timestamping information for the stream itself. | 
					
						
							|  |  |  |              * This requires that the application provides a sensible value for the ts | 
					
						
							|  |  |  |              * parameter. If RTCP has been enabled, uvgrtp::rtcp::set_ts_info() should have | 
					
						
							|  |  |  |              * been called. | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \param data Pointer to data the that should be sent | 
					
						
							|  |  |  |              * \param data_len Length of data | 
					
						
							|  |  |  |              * \param ts 32-bit timestamp value for the data | 
					
						
							|  |  |  |              * \param flags Optional flags, see ::RTP_FLAGS for more details | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \return RTP error code | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \retval  RTP_OK            On success | 
					
						
							|  |  |  |              * \retval  RTP_INVALID_VALUE If one of the parameters are invalid | 
					
						
							|  |  |  |              * \retval  RTP_MEMORY_ERROR  If the data chunk is too large to be processed | 
					
						
							|  |  |  |              * \retval  RTP_SEND_ERROR    If uvgRTP failed to send the data to remote | 
					
						
							|  |  |  |              * \retval  RTP_GENERIC_ERROR If an unspecified error occurred | 
					
						
							|  |  |  |              */ | 
					
						
							|  |  |  |             rtp_error_t push_frame(uint8_t *data, size_t data_len, uint32_t ts, int flags); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /**
 | 
					
						
							|  |  |  |              * \brief Send data to remote participant with a custom timestamp | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \details If so specified either by the selected media format and/or given | 
					
						
							|  |  |  |              * ::RTP_CTX_ENABLE_FLAGS, uvgRTP fragments the input data into RTP packets of 1500 bytes, | 
					
						
							|  |  |  |              * or to any other size defined by the application using ::RCC_MTU_SIZE | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * The frame is automatically reconstructed by the receiver if all fragments have been | 
					
						
							|  |  |  |              * received successfully. | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * If application so wishes, it may override uvgRTP's own timestamp | 
					
						
							|  |  |  |              * calculations and provide timestamping information for the stream itself. | 
					
						
							|  |  |  |              * This requires that the application provides a sensible value for the ts | 
					
						
							|  |  |  |              * parameter. If RTCP has been enabled, uvgrtp::rtcp::set_ts_info() should have | 
					
						
							|  |  |  |              * been called. | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \param data Smart pointer to data the that should be sent | 
					
						
							|  |  |  |              * \param data_len Length of data | 
					
						
							|  |  |  |              * \param ts 32-bit timestamp value for the data | 
					
						
							|  |  |  |              * \param flags Optional flags, see ::RTP_FLAGS for more details | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \return RTP error code | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \retval  RTP_OK            On success | 
					
						
							|  |  |  |              * \retval  RTP_INVALID_VALUE If one of the parameters are invalid | 
					
						
							|  |  |  |              * \retval  RTP_MEMORY_ERROR  If the data chunk is too large to be processed | 
					
						
							|  |  |  |              * \retval  RTP_SEND_ERROR    If uvgRTP failed to send the data to remote | 
					
						
							| 
									
										
										
										
											2021-02-23 12:23:50 +00:00
										 |  |  |              * \retval  RTP_GENERIC_ERROR If an unspecified error occurred | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2020-06-01 10:18:11 +00:00
										 |  |  |             rtp_error_t push_frame(std::unique_ptr<uint8_t[]> data, size_t data_len, uint32_t ts, int flags); | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /**
 | 
					
						
							| 
									
										
										
										
											2021-02-23 12:23:50 +00:00
										 |  |  |              * \brief Poll a frame indefinitely from the media stream object | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:23:50 +00:00
										 |  |  |              * \return RTP frame | 
					
						
							| 
									
										
										
										
											2020-05-11 14:36:13 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:23:50 +00:00
										 |  |  |              * \retval uvgrtp::frame::rtp_frame* On success | 
					
						
							|  |  |  |              * \retval nullptr If an unrecoverable error happened | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             uvgrtp::frame::rtp_frame *pull_frame(); | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /**
 | 
					
						
							|  |  |  |              * \brief Poll a frame for a specified time from the media stream object | 
					
						
							|  |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-24 01:31:43 +00:00
										 |  |  |              * \param timeout How long is a frame waited, in milliseconds | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \return RTP frame | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 12:23:50 +00:00
										 |  |  |              * \retval uvgrtp::frame::rtp_frame* On success | 
					
						
							|  |  |  |              * \retval nullptr If a frame was not received within the specified time limit | 
					
						
							|  |  |  |              * \retval nullptr If an unrecoverable error happened | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             uvgrtp::frame::rtp_frame *pull_frame(size_t timeout); | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-23 11:57:55 +00:00
										 |  |  |             /**
 | 
					
						
							|  |  |  |              * \brief Asynchronous way of getting frames | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 11:57:55 +00:00
										 |  |  |              * \details Receive hook is an alternative to polling frames using uvgrtp::media_stream::pull_frame(). | 
					
						
							|  |  |  |              * Instead of application asking from uvgRTP if there are any new frames available, uvgRTP will notify | 
					
						
							|  |  |  |              * the application when a frame has been received | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 11:57:55 +00:00
										 |  |  |              * The hook should not be used for media processing as it will block the receiver from | 
					
						
							|  |  |  |              * reading more frames. Instead, it should only be used as an interface between uvgRTP and | 
					
						
							|  |  |  |              * the calling application where the frame hand-off happens. | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-23 11:57:55 +00:00
										 |  |  |              * \param arg Optional argument that is passed to the hook when it is called, can be set to nullptr | 
					
						
							|  |  |  |              * \param hook Function pointer to the receive hook that uvgRTP should call | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \return RTP error code | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \retval RTP_OK On success | 
					
						
							|  |  |  |              * \retval RTP_INVALID_VALUE If hook is nullptr */ | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             rtp_error_t install_receive_hook(void *arg, void (*hook)(void *, uvgrtp::frame::rtp_frame *)); | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /// \cond DO_NOT_DOCUMENT
 | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |             /* If system call dispatcher is enabled and calling application has special requirements
 | 
					
						
							|  |  |  |              * for the deallocation of a frame, it may install a deallocation hook which is called | 
					
						
							|  |  |  |              * when SCD has processed the frame | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * Return RTP_OK on success | 
					
						
							|  |  |  |              * Return RTP_INVALID_VALUE if "hook" is nullptr */ | 
					
						
							| 
									
										
										
										
											2020-02-10 06:50:36 +00:00
										 |  |  |             rtp_error_t install_deallocation_hook(void (*hook)(void *)); | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-27 11:07:24 +00:00
										 |  |  |             /* If needed, a notification hook can be installed to uvgRTP that can be used as
 | 
					
						
							| 
									
										
										
										
											2020-04-16 08:00:07 +00:00
										 |  |  |              * an information side channel to the internal state of the library. | 
					
						
							|  |  |  |              * | 
					
						
							| 
									
										
										
										
											2020-04-27 11:07:24 +00:00
										 |  |  |              * When uvgRTP encouters a situation it doesn't know how to react to, | 
					
						
							| 
									
										
										
										
											2020-04-16 08:00:07 +00:00
										 |  |  |              * it calls the notify hook with certain notify reason number (src/util.hh). | 
					
						
							|  |  |  |              * Upon receiving a notification, application may ignore it or act on it somehow | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * Currently only one notification type is supported and only receiver uses notifications | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * "arg" is optional argument that is passed to hook when it is called. It may be nullptr | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * Return RTP_OK on success | 
					
						
							|  |  |  |              * Return RTP_INVALID_VALUE if "hook" is nullptr */ | 
					
						
							|  |  |  |             rtp_error_t install_notify_hook(void *arg, void (*hook)(void *, int)); | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /// \endcond
 | 
					
						
							| 
									
										
										
										
											2020-04-16 08:00:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /**
 | 
					
						
							|  |  |  |              * \brief Configure the media stream, see ::RTP_CTX_CONFIGURATION_FLAGS for more details | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |              * \return RTP error code | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |              * \retval RTP_OK On success | 
					
						
							|  |  |  |              * \retval RTP_INVALID_VALUE If the provided value is not valid for a given configuration flag | 
					
						
							|  |  |  |              * \retval RTP_INVALID_VALUE If the provided configuration flag is not supported | 
					
						
							|  |  |  |              * \retval RTP_GENERIC_ERROR If setsockopt(2) failed | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2020-02-10 07:04:52 +00:00
										 |  |  |             rtp_error_t configure_ctx(int flag, ssize_t value); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /// \cond DO_NOT_DOCUMENT
 | 
					
						
							| 
									
										
										
										
											2020-02-13 05:47:51 +00:00
										 |  |  |             /* Setter and getter for media-specific config that can be used f.ex with Opus */ | 
					
						
							| 
									
										
										
										
											2020-02-10 07:04:52 +00:00
										 |  |  |             void  set_media_config(void *config); | 
					
						
							|  |  |  |             void *get_media_config(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-25 07:48:02 +00:00
										 |  |  |             /* Get unique key of the media stream
 | 
					
						
							|  |  |  |              * Used by session to index media streams */ | 
					
						
							| 
									
										
										
										
											2020-02-21 07:20:57 +00:00
										 |  |  |             uint32_t get_key(); | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /// \endcond
 | 
					
						
							| 
									
										
										
										
											2020-02-21 07:20:57 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |             /**
 | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \brief Get pointer to the RTCP object of the media stream | 
					
						
							|  |  |  |              * | 
					
						
							|  |  |  |              * \details This object is used to control all RTCP-related functionality | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |              * and RTCP documentation can be found from \ref uvgrtp::rtcp | 
					
						
							| 
									
										
										
										
											2020-06-17 04:55:47 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |              * \return Pointer to RTCP object | 
					
						
							| 
									
										
										
										
											2020-06-17 04:55:47 +00:00
										 |  |  |              * | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |              * \retval uvgrtp::rtcp* If RTCP has been enabled (RCE_RTCP has been given to uvgrtp::session::create_stream()) | 
					
						
							| 
									
										
										
										
											2021-02-14 07:35:31 +00:00
										 |  |  |              * \retval nullptr        If RTCP has not been enabled | 
					
						
							|  |  |  |              */ | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             uvgrtp::rtcp *get_rtcp(); | 
					
						
							| 
									
										
										
										
											2020-06-17 04:55:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |         private: | 
					
						
							| 
									
										
										
										
											2020-02-10 07:13:31 +00:00
										 |  |  |             /* Initialize the connection by initializing the socket
 | 
					
						
							|  |  |  |              * and binding ourselves to specified interface and creating | 
					
						
							|  |  |  |              * an outgoing address */ | 
					
						
							|  |  |  |             rtp_error_t init_connection(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-25 00:47:18 +00:00
										 |  |  |             /* Create the media object for the stream */ | 
					
						
							|  |  |  |             rtp_error_t create_media(rtp_format_t fmt); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-25 22:30:22 +00:00
										 |  |  |             /* free all allocated resources */ | 
					
						
							|  |  |  |             rtp_error_t free_resources(rtp_error_t ret); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |             uint32_t key_; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             uvgrtp::srtp   *srtp_; | 
					
						
							|  |  |  |             uvgrtp::srtcp  *srtcp_; | 
					
						
							|  |  |  |             uvgrtp::socket *socket_; | 
					
						
							|  |  |  |             uvgrtp::rtp    *rtp_; | 
					
						
							|  |  |  |             uvgrtp::rtcp   *rtcp_; | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-10 07:13:31 +00:00
										 |  |  |             sockaddr_in addr_out_; | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |             std::string addr_; | 
					
						
							| 
									
										
										
										
											2020-04-03 08:45:19 +00:00
										 |  |  |             std::string laddr_; | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |             int src_port_; | 
					
						
							|  |  |  |             int dst_port_; | 
					
						
							|  |  |  |             rtp_format_t fmt_; | 
					
						
							|  |  |  |             int flags_; | 
					
						
							| 
									
										
										
										
											2020-02-10 07:04:52 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /* Media context config (SCD etc.) */ | 
					
						
							|  |  |  |             rtp_ctx_conf_t ctx_config_; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /* Media config f.ex. for Opus */ | 
					
						
							|  |  |  |             void *media_config_; | 
					
						
							| 
									
										
										
										
											2020-04-29 22:45:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /* Has the media stream been initialized */ | 
					
						
							|  |  |  |             bool initialized_; | 
					
						
							| 
									
										
										
										
											2020-06-17 05:23:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-12 13:19:31 +00:00
										 |  |  |             /* Primary handler keys for the RTP packet dispatcher */ | 
					
						
							| 
									
										
										
										
											2020-08-06 04:32:28 +00:00
										 |  |  |             uint32_t rtp_handler_key_; | 
					
						
							| 
									
										
										
										
											2020-08-12 13:19:31 +00:00
										 |  |  |             uint32_t zrtp_handler_key_; | 
					
						
							| 
									
										
										
										
											2020-08-06 04:32:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-04 05:53:27 +00:00
										 |  |  |             /* RTP packet dispatcher for the receiver */ | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             uvgrtp::pkt_dispatcher *pkt_dispatcher_; | 
					
						
							| 
									
										
										
										
											2020-08-04 05:53:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /* Media object associated with this media stream. */ | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             uvgrtp::formats::media *media_; | 
					
						
							| 
									
										
										
										
											2021-02-14 01:36:27 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /* Thread that keeps the holepunched connection open for unidirectional streams */ | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  |             uvgrtp::holepuncher *holepuncher_; | 
					
						
							| 
									
										
										
										
											2020-02-07 10:22:58 +00:00
										 |  |  |     }; | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2021-02-19 01:13:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace uvg_rtp = uvgrtp; |