/* * Copyright (c) 2011 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #ifndef WEBRTC_VIDEO_ENGINE_INCLUDE_VIE_NETWORK_H_ #define WEBRTC_VIDEO_ENGINE_INCLUDE_VIE_NETWORK_H_ // This sub-API supports the following functionalities: // - Configuring send and receive addresses. // - External transport support. // - Port and address filters. // - Windows GQoS functions and ToS functions. // - Packet timeout notification. // - Dead‐or‐Alive connection observations. #include "common_types.h" namespace webrtc { class Transport; class VideoEngine; // This enumerator describes VideoEngine packet timeout states. enum ViEPacketTimeout { NoPacket = 0, PacketReceived = 1 }; // This class declares an abstract interface for a user defined observer. It is // up to the VideoEngine user to implement a derived class which implements the // observer class. The observer is registered using RegisterObserver() and // deregistered using DeregisterObserver(). class WEBRTC_DLLEXPORT ViENetworkObserver { public: // This method will be called periodically delivering a dead‐or‐alive // decision for a specified channel. virtual void OnPeriodicDeadOrAlive(const int video_channel, const bool alive) = 0; // This method is called once if a packet timeout occurred. virtual void PacketTimeout(const int video_channel, const ViEPacketTimeout timeout) = 0; protected: virtual ~ViENetworkObserver() {} }; class WEBRTC_DLLEXPORT ViENetwork { public: // Default values. enum { KDefaultSampleTimeSeconds = 2 }; // Factory for the ViENetwork sub‐API and increases an internal reference // counter if successful. Returns NULL if the API is not supported or if // construction fails. static ViENetwork* GetInterface(VideoEngine* video_engine); // Releases the ViENetwork sub-API and decreases an internal reference // counter.Returns the new reference count. This value should be zero // for all sub-API:s before the VideoEngine object can be safely deleted. virtual int Release() = 0; // Specifies the ports to receive RTP packets on. It is also possible to set // port for RTCP and local IP address. virtual int SetLocalReceiver(const int video_channel, const unsigned short rtp_port, const unsigned short rtcp_port = 0, const char* ip_address = NULL) = 0; // Gets the local receiver ports and address for a specified channel. virtual int GetLocalReceiver(const int video_channel, unsigned short& rtp_port, unsigned short& rtcp_port, char* ip_address) = 0; // Specifies the destination port and IP address for a specified channel. virtual int SetSendDestination(const int video_channel, const char* ip_address, const unsigned short rtp_port, const unsigned short rtcp_port = 0, const unsigned short source_rtp_port = 0, const unsigned short source_rtcp_port = 0) = 0; // Get the destination port and address for a specified channel. virtual int GetSendDestination(const int video_channel, char* ip_address, unsigned short& rtp_port, unsigned short& rtcp_port, unsigned short& source_rtp_port, unsigned short& source_rtcp_port) = 0; // This function registers a user implementation of Transport to use for // sending RTP and RTCP packets on this channel. virtual int RegisterSendTransport(const int video_channel, Transport& transport) = 0; // This function deregisters a used Transport for a specified channel. virtual int DeregisterSendTransport(const int video_channel) = 0; // When using external transport for a channel, received RTP packets should // be passed to VideoEngine using this function. The input should contain // the RTP header and payload. virtual int ReceivedRTPPacket(const int video_channel, const void* data, const int length) = 0; // When using external transport for a channel, received RTCP packets should // be passed to VideoEngine using this function. virtual int ReceivedRTCPPacket(const int video_channel, const void* data, const int length) = 0; // Gets the source ports and IP address of the incoming stream for a // specified channel. virtual int GetSourceInfo(const int video_channel, unsigned short& rtp_port, unsigned short& rtcp_port, char* ip_address, unsigned int ip_address_length) = 0; // Gets the local IP address, in string format. virtual int GetLocalIP(char ip_address[64], bool ipv6 = false) = 0; // Enables IPv6, instead of IPv4, for a specified channel. virtual int EnableIPv6(int video_channel) = 0; // The function returns true if IPv6 is enabled, false otherwise. virtual bool IsIPv6Enabled(int video_channel) = 0; // Enables a port and IP address filtering for incoming packets on a // specific channel. virtual int SetSourceFilter(const int video_channel, const unsigned short rtp_port, const unsigned short rtcp_port = 0, const char* ip_address = NULL) = 0; // Gets current port and IP address filter for a specified channel. virtual int GetSourceFilter(const int video_channel, unsigned short& rtp_port, unsigned short& rtcp_port, char* ip_address) = 0; // This function sets the six‐bit Differentiated Services Code Point (DSCP) // in the IP header of the outgoing stream for a specific channel. // Windows and Linux only. virtual int SetSendToS(const int video_channel, const int DSCP, const bool use_set_sockOpt = false) = 0; // Retrieves the six‐bit Differentiated Services Code Point (DSCP) in the IP // header of the outgoing stream for a specific channel. virtual int GetSendToS(const int video_channel, int& DSCP, bool& use_set_sockOpt) = 0; // This function sets the Generic Quality of Service (GQoS) service level. // The Windows operating system then maps to a Differentiated Services Code // Point (DSCP) and to an 802.1p setting. Windows only. virtual int SetSendGQoS(const int video_channel, const bool enable, const int service_type, const int overrideDSCP = 0) = 0; // This function retrieves the currently set GQoS service level for a // specific channel. virtual int GetSendGQoS(const int video_channel, bool& enabled, int& service_type, int& overrideDSCP) = 0; // This function sets the Maximum Transition Unit (MTU) for a channel. The // RTP packet will be packetized based on this MTU to optimize performance // over the network. virtual int SetMTU(int video_channel, unsigned int mtu) = 0; // This function enables or disables warning reports if packets have not // been received for a specified time interval. virtual int SetPacketTimeoutNotification(const int video_channel, bool enable, int timeout_seconds) = 0; // Registers an instance of a user implementation of the ViENetwork // observer. virtual int RegisterObserver(const int video_channel, ViENetworkObserver& observer) = 0; // Removes a registered instance of ViENetworkObserver. virtual int DeregisterObserver(const int video_channel) = 0; // This function enables or disables the periodic dead‐or‐alive callback // functionality for a specified channel. virtual int SetPeriodicDeadOrAliveStatus( const int video_channel, const bool enable, const unsigned int sample_time_seconds = KDefaultSampleTimeSeconds) = 0; // This function handles sending a raw UDP data packet over an existing RTP // or RTCP socket. virtual int SendUDPPacket(const int video_channel, const void* data, const unsigned int length, int& transmitted_bytes, bool use_rtcp_socket = false) = 0; protected: ViENetwork() {} virtual ~ViENetwork() {} }; } // namespace webrtc #endif // WEBRTC_VIDEO_ENGINE_INCLUDE_VIE_NETWORK_H_