blob: 84c2ff723bb4c8aa6e382c194878b49b4244a1be [file] [log] [blame]
deadbeef6979b022015-09-24 16:47:53 -07001/*
kjellanderb24317b2016-02-10 07:54:43 -08002 * Copyright 2015 The WebRTC project authors. All Rights Reserved.
deadbeef6979b022015-09-24 16:47:53 -07003 *
kjellanderb24317b2016-02-10 07:54:43 -08004 * 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.
deadbeef6979b022015-09-24 16:47:53 -07009 */
10
deadbeef70ab1a12015-09-28 16:53:55 -070011// This file contains classes that implement RtpReceiverInterface.
12// An RtpReceiver associates a MediaStreamTrackInterface with an underlying
Taylor Brandstetterba29c6a2016-06-27 16:30:35 -070013// transport (provided by cricket::VoiceChannel/cricket::VideoChannel)
deadbeef70ab1a12015-09-28 16:53:55 -070014
Steve Anton10542f22019-01-11 09:11:00 -080015#ifndef PC_RTP_RECEIVER_H_
16#define PC_RTP_RECEIVER_H_
deadbeef70ab1a12015-09-28 16:53:55 -070017
pbosc7c26a02017-01-02 08:42:32 -080018#include <stdint.h>
Jonas Olssona4d87372019-07-05 19:08:33 +020019
deadbeef70ab1a12015-09-28 16:53:55 -070020#include <string>
Steve Anton36b29d12017-10-30 09:57:42 -070021#include <vector>
deadbeef70ab1a12015-09-28 16:53:55 -070022
Yves Gerey3e707812018-11-28 16:47:49 +010023#include "absl/types/optional.h"
Steve Anton10542f22019-01-11 09:11:00 -080024#include "api/crypto/frame_decryptor_interface.h"
25#include "api/media_stream_interface.h"
26#include "api/media_types.h"
27#include "api/rtp_parameters.h"
28#include "api/rtp_receiver_interface.h"
Mirko Bonadeid9708072019-01-25 20:26:48 +010029#include "api/scoped_refptr.h"
Yves Gerey3e707812018-11-28 16:47:49 +010030#include "api/video/video_frame.h"
31#include "api/video/video_sink_interface.h"
32#include "api/video/video_source_interface.h"
Steve Anton10542f22019-01-11 09:11:00 -080033#include "media/base/media_channel.h"
34#include "media/base/video_broadcaster.h"
Steve Anton10542f22019-01-11 09:11:00 -080035#include "pc/video_track_source.h"
36#include "rtc_base/ref_counted_object.h"
Yves Gerey3e707812018-11-28 16:47:49 +010037#include "rtc_base/thread.h"
deadbeef70ab1a12015-09-28 16:53:55 -070038
39namespace webrtc {
40
deadbeefa601f5c2016-06-06 14:27:39 -070041// Internal class used by PeerConnection.
42class RtpReceiverInternal : public RtpReceiverInterface {
43 public:
44 virtual void Stop() = 0;
Steve Antonef65ef12018-01-10 17:15:20 -080045
Steve Anton57858b32018-02-15 15:19:50 -080046 // Sets the underlying MediaEngine channel associated with this RtpSender.
Amit Hilbuchdd9390c2018-11-13 16:26:05 -080047 // A VoiceMediaChannel should be used for audio RtpSenders and
48 // a VideoMediaChannel should be used for video RtpSenders.
49 // Must call SetMediaChannel(nullptr) before the media channel is destroyed.
50 virtual void SetMediaChannel(cricket::MediaChannel* media_channel) = 0;
Steve Anton57858b32018-02-15 15:19:50 -080051
Steve Antond3679212018-01-17 17:41:02 -080052 // Configures the RtpReceiver with the underlying media channel, with the
Saurav Das7262fc22019-09-11 16:23:05 -070053 // given SSRC as the stream identifier.
Steve Antond3679212018-01-17 17:41:02 -080054 virtual void SetupMediaChannel(uint32_t ssrc) = 0;
55
Saurav Das7262fc22019-09-11 16:23:05 -070056 // Configures the RtpReceiver with the underlying media channel to receive an
57 // unsignaled receive stream.
58 virtual void SetupUnsignaledMediaChannel() = 0;
59
Harald Alvestrand4a7b3ac2019-01-17 10:39:40 +010060 virtual void set_transport(
61 rtc::scoped_refptr<DtlsTransportInterface> dtls_transport) = 0;
deadbeefe814a0d2017-02-25 18:15:09 -080062 // This SSRC is used as an identifier for the receiver between the API layer
eladalonf1841382017-06-12 01:16:46 -070063 // and the WebRtcVideoEngine, WebRtcVoiceEngine layer.
deadbeefe814a0d2017-02-25 18:15:09 -080064 virtual uint32_t ssrc() const = 0;
Steve Anton60776752018-01-10 11:51:34 -080065
66 // Call this to notify the RtpReceiver when the first packet has been received
67 // on the corresponding channel.
68 virtual void NotifyFirstPacketReceived() = 0;
Steve Antonef65ef12018-01-10 17:15:20 -080069
70 // Set the associated remote media streams for this receiver. The remote track
71 // will be removed from any streams that are no longer present and added to
72 // any new streams.
Henrik Boström199e27b2018-07-04 20:51:53 +020073 virtual void set_stream_ids(std::vector<std::string> stream_ids) = 0;
74 // TODO(https://crbug.com/webrtc/9480): Remove SetStreams() in favor of
75 // set_stream_ids() as soon as downstream projects are no longer dependent on
76 // stream objects.
Steve Antonef65ef12018-01-10 17:15:20 -080077 virtual void SetStreams(
78 const std::vector<rtc::scoped_refptr<MediaStreamInterface>>& streams) = 0;
Steve Anton57858b32018-02-15 15:19:50 -080079
80 // Returns an ID that changes if the attached track changes, but
81 // otherwise remains constant. Used to generate IDs for stats.
82 // The special value zero means that no track is attached.
83 virtual int AttachmentId() const = 0;
deadbeefa601f5c2016-06-06 14:27:39 -070084
Ruslan Burakov501bfba2019-02-11 10:29:19 +010085 protected:
86 static int GenerateUniqueId();
87
88 static std::vector<rtc::scoped_refptr<MediaStreamInterface>>
89 CreateStreamsFromIds(std::vector<std::string> stream_ids);
90
91 static void MaybeAttachFrameDecryptorToMediaChannel(
92 const absl::optional<uint32_t>& ssrc,
Steve Anton60776752018-01-10 11:51:34 -080093 rtc::Thread* worker_thread,
Ruslan Burakov501bfba2019-02-11 10:29:19 +010094 rtc::scoped_refptr<webrtc::FrameDecryptorInterface> frame_decryptor,
95 cricket::MediaChannel* media_channel,
96 bool stopped);
deadbeef70ab1a12015-09-28 16:53:55 -070097};
98
99} // namespace webrtc
100
Steve Anton10542f22019-01-11 09:11:00 -0800101#endif // PC_RTP_RECEIVER_H_