blob: 117bca069c1a244f5de6862b0fd2fa226c327f42 [file] [log] [blame]
nisseb8f9a322017-03-27 05:36:15 -07001/*
2 * Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
3 *
4 * Use of this source code is governed by a BSD-style license
5 * that can be found in the LICENSE file in the root of the source
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
11#ifndef WEBRTC_CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_
12#define WEBRTC_CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_
13
14namespace webrtc {
15
16class Module;
17class PacketRouter;
18class RtpPacketSender;
19class SendSideCongestionController;
20class TransportFeedbackObserver;
nisseb8f9a322017-03-27 05:36:15 -070021
22// An RtpTransportController should own everything related to the RTP
23// transport to/from a remote endpoint. We should have separate
24// interfaces for send and receive side, even if they are implemented
25// by the same class. This is an ongoing refactoring project. At some
26// point, this class should be promoted to a public api under
27// webrtc/api/rtp/.
28//
29// For a start, this object is just a collection of the objects needed
30// by the VideoSendStream constructor. The plan is to move ownership
31// of all RTP-related objects here, and add methods to create per-ssrc
32// objects which would then be passed to VideoSendStream. Eventually,
33// direct accessors like packet_router() should be removed.
34//
35// This should also have a reference to the underlying
36// webrtc::Transport(s). Currently, webrtc::Transport is implemented by
37// WebRtcVideoChannel2 and WebRtcVoiceMediaChannel, and owned by
38// WebrtcSession. Video and audio always uses different transport
39// objects, even in the common case where they are bundled over the
40// same underlying transport.
41//
42// Extracting the logic of the webrtc::Transport from BaseChannel and
43// subclasses into a separate class seems to be a prerequesite for
44// moving the transport here.
45class RtpTransportControllerSendInterface {
46 public:
47 virtual ~RtpTransportControllerSendInterface() {}
48 virtual PacketRouter* packet_router() = 0;
49 // Currently returning the same pointer, but with different types.
50 virtual SendSideCongestionController* send_side_cc() = 0;
51 virtual TransportFeedbackObserver* transport_feedback_observer() = 0;
52
53 virtual RtpPacketSender* packet_sender() = 0;
54};
55
56} // namespace webrtc
57
58#endif // WEBRTC_CALL_RTP_TRANSPORT_CONTROLLER_SEND_H_