| /* | 
 |  *  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_ |