Review URL: https://webrtc-codereview.appspot.com/1232004 git-svn-id: http://webrtc.googlecode.com/svn/trunk@3754 4adac7df-926f-26a2-2b94-8c16560cd09d
128 lines
4.9 KiB
C++
128 lines
4.9 KiB
C++
/*
|
||
* 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 "webrtc/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;
|
||
|
||
// Inform the engine about if the network adapter is currently transmitting
|
||
// packets or not.
|
||
virtual void SetNetworkTransmissionState(const int video_channel,
|
||
const bool is_transmitting) = 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;
|
||
|
||
// 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;
|
||
|
||
protected:
|
||
ViENetwork() {}
|
||
virtual ~ViENetwork() {}
|
||
};
|
||
|
||
} // namespace webrtc
|
||
|
||
#endif // WEBRTC_VIDEO_ENGINE_INCLUDE_VIE_NETWORK_H_
|