stream-deploy/ZLM/3rdpart/media-server/librtsp/include/rtsp-client.h

135 lines
5.2 KiB
C++

#ifndef _rtsp_client_h_
#define _rtsp_client_h_
#include "rtsp-header-transport.h"
#include <stdint.h>
#include <stddef.h>
#if defined(__cplusplus)
extern "C" {
#endif
typedef struct rtsp_client_t rtsp_client_t;
// seq=232433;rtptime=972948234
struct rtsp_rtp_info_t
{
const char* uri;
uint32_t seq; // uint16_t
uint32_t time; // uint32_t
};
struct rtsp_client_handler_t
{
///network implementation
///@return >0-sent bytes, <0-error
int (*send)(void* param, const char* uri, const void* req, size_t bytes);
///create rtp/rtcp port
/// @param[in] source media source address
/// @param[in,out] port [INPUT] media port, [OUTPUT] udp: bind local port for rtp/rtcp(port[0] % 2 == 0), tcp: channel interleaved id
/// @param[in,out] ip [INPUT] media address, [OUTPUT] udp bind local ip address, 224~239.x.x.x for multicast udp transport
/// @param[in] len ip buffer length in byte
/// @return <0-error, 0-ignore this media track, other-RTSP_TRANSPORT_XXX
int (*rtpport)(void* param, int media, const char* source, unsigned short port[2], char* ip, int len);
/// rtsp_client_announce callback only
int (*onannounce)(void* param);
/// call rtsp_client_setup
int (*ondescribe)(void* param, const char* sdp, int len);
/// @param[in] timeout session timeout in seconds
/// @param[in] duration -1-unknown or live stream, other-rtsp stream duration in MS
int (*onsetup)(void* param, int timeout, int64_t duration);
int (*onplay)(void* param, int media, const uint64_t *nptbegin, const uint64_t *nptend, const double *scale, const struct rtsp_rtp_info_t* rtpinfo, int count); // play
int (*onrecord)(void* param, int media, const uint64_t *nptbegin, const uint64_t *nptend, const double *scale, const struct rtsp_rtp_info_t* rtpinfo, int count); // record
int (*onpause)(void* param);
int (*onteardown)(void* param);
void (*onrtp)(void* param, uint8_t channel, const void* data, uint16_t bytes);
/// @param[in] location redirection url
/// @param[in] len location length in byte
/// @return 0-ok, other-error
int (*onredirect)(void* param, const char* location, int len);
};
/// @param[in] param user-defined parameter
/// @param[in] usr RTSP auth username(optional)
/// @param[in] pwd RTSP auth password(optional)
rtsp_client_t* rtsp_client_create(const char* uri, const char* usr, const char* pwd, const struct rtsp_client_handler_t *handler, void* param);
void rtsp_client_destroy(rtsp_client_t* rtsp);
/// input server reply
/// @param[in] data server response message
/// @param[in] bytes data length in byte
/// @return 0-ok, other-error
int rtsp_client_input(rtsp_client_t* rtsp, const void* data, size_t bytes);
/// find RTSP response header
/// @param[in] name header name
/// @return header value, NULL if not found.
/// NOTICE: call in rtsp_client_handler_t callback only
const char* rtsp_client_get_header(rtsp_client_t* rtsp, const char* name);
/// rtsp options (optional)
/// @param[in] commands optional required command, NULL if none
int rtsp_client_options(struct rtsp_client_t* rtsp, const char* commands);
/// rtsp describe (optional)
int rtsp_client_describe(struct rtsp_client_t* rtsp);
/// rtsp setup
/// @param[in] sdp resource info. it can be null, sdp will get by describe command
/// @return 0-ok, -EACCESS-auth required, try again, other-error.
int rtsp_client_setup(rtsp_client_t* rtsp, const char* sdp, int len);
/// stop and close session(TearDown)
/// call onclose on done
/// @return 0-ok, other-error.
int rtsp_client_teardown(rtsp_client_t* rtsp);
/// play session(PLAY)
/// call onplay on done
/// @param[in] npt PLAY range parameter [optional, NULL is acceptable]
/// @param[in] speed PLAY scale+speed parameter [optional, NULL is acceptable]
/// @return 0-ok, other-error.
/// Notice: if npt and speed is null, resume play only
int rtsp_client_play(rtsp_client_t* rtsp, const uint64_t *npt, const float *speed);
/// pause session(PAUSE)
/// call onpause on done
/// @return 0-ok, other-error.
/// use rtsp_client_play(rtsp, NULL, NULL) to resume play
int rtsp_client_pause(rtsp_client_t* rtsp);
/// announce server sdp
/// @return 0-ok, other-error.
int rtsp_client_announce(rtsp_client_t* rtsp, const char* sdp);
/// record session(publish)
/// call onrecord on done
/// @param[in] npt RECORD range parameter [optional, NULL is acceptable]
/// @param[in] scale RECORD scale parameter [optional, NULL is acceptable]
/// @return 0-ok, other-error.
/// Notice: if npt and scale is null, resume record only
int rtsp_client_record(struct rtsp_client_t *rtsp, const uint64_t *npt, const float *scale);
/// SDP API
int rtsp_client_media_count(rtsp_client_t* rtsp);
const struct rtsp_header_transport_t* rtsp_client_get_media_transport(rtsp_client_t* rtsp, int media);
const char* rtsp_client_get_media_encoding(rtsp_client_t* rtsp, int media);
const char* rtsp_client_get_media_fmtp(rtsp_client_t* rtsp, int media);
int rtsp_client_get_media_payload(rtsp_client_t* rtsp, int media);
/// @return media sampling rate/frequency, 0 if unknown
int rtsp_client_get_media_rate(rtsp_client_t* rtsp, int media);
/// @return SDP_M_MEDIA_AUDIO/SDP_M_MEDIA_VIDEO/SDP_M_MEDIA_xxx, see more @sdp.h
int rtsp_client_get_media_type(rtsp_client_t* rtsp, int media);
#if defined(__cplusplus)
}
#endif
#endif /* !_rtsp_client_h_ */