blob: e56c859d0e1bf89474decea717eb9601af555597 [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>
deadbeef70ab1a12015-09-28 16:53:55 -070019#include <string>
Steve Anton36b29d12017-10-30 09:57:42 -070020#include <vector>
deadbeef70ab1a12015-09-28 16:53:55 -070021
Yves Gerey3e707812018-11-28 16:47:49 +010022#include "absl/types/optional.h"
Steve Anton10542f22019-01-11 09:11:00 -080023#include "api/crypto/frame_decryptor_interface.h"
24#include "api/media_stream_interface.h"
25#include "api/media_types.h"
26#include "api/rtp_parameters.h"
27#include "api/rtp_receiver_interface.h"
Mirko Bonadeid9708072019-01-25 20:26:48 +010028#include "api/scoped_refptr.h"
Yves Gerey3e707812018-11-28 16:47:49 +010029#include "api/video/video_frame.h"
30#include "api/video/video_sink_interface.h"
31#include "api/video/video_source_interface.h"
Steve Anton10542f22019-01-11 09:11:00 -080032#include "media/base/media_channel.h"
33#include "media/base/video_broadcaster.h"
Steve Anton10542f22019-01-11 09:11:00 -080034#include "pc/video_track_source.h"
35#include "rtc_base/ref_counted_object.h"
Yves Gerey3e707812018-11-28 16:47:49 +010036#include "rtc_base/thread.h"
deadbeef70ab1a12015-09-28 16:53:55 -070037
38namespace webrtc {
39
deadbeefa601f5c2016-06-06 14:27:39 -070040// Internal class used by PeerConnection.
41class RtpReceiverInternal : public RtpReceiverInterface {
42 public:
43 virtual void Stop() = 0;
Steve Antonef65ef12018-01-10 17:15:20 -080044
Steve Anton57858b32018-02-15 15:19:50 -080045 // Sets the underlying MediaEngine channel associated with this RtpSender.
Amit Hilbuchdd9390c2018-11-13 16:26:05 -080046 // A VoiceMediaChannel should be used for audio RtpSenders and
47 // a VideoMediaChannel should be used for video RtpSenders.
48 // Must call SetMediaChannel(nullptr) before the media channel is destroyed.
49 virtual void SetMediaChannel(cricket::MediaChannel* media_channel) = 0;
Steve Anton57858b32018-02-15 15:19:50 -080050
Steve Antond3679212018-01-17 17:41:02 -080051 // Configures the RtpReceiver with the underlying media channel, with the
52 // given SSRC as the stream identifier. If |ssrc| is 0, the receiver will
53 // receive packets on unsignaled SSRCs.
54 virtual void SetupMediaChannel(uint32_t ssrc) = 0;
55
Harald Alvestrand4a7b3ac2019-01-17 10:39:40 +010056 virtual void set_transport(
57 rtc::scoped_refptr<DtlsTransportInterface> dtls_transport) = 0;
deadbeefe814a0d2017-02-25 18:15:09 -080058 // This SSRC is used as an identifier for the receiver between the API layer
eladalonf1841382017-06-12 01:16:46 -070059 // and the WebRtcVideoEngine, WebRtcVoiceEngine layer.
deadbeefe814a0d2017-02-25 18:15:09 -080060 virtual uint32_t ssrc() const = 0;
Steve Anton60776752018-01-10 11:51:34 -080061
62 // Call this to notify the RtpReceiver when the first packet has been received
63 // on the corresponding channel.
64 virtual void NotifyFirstPacketReceived() = 0;
Steve Antonef65ef12018-01-10 17:15:20 -080065
66 // Set the associated remote media streams for this receiver. The remote track
67 // will be removed from any streams that are no longer present and added to
68 // any new streams.
Henrik Boström199e27b2018-07-04 20:51:53 +020069 virtual void set_stream_ids(std::vector<std::string> stream_ids) = 0;
70 // TODO(https://crbug.com/webrtc/9480): Remove SetStreams() in favor of
71 // set_stream_ids() as soon as downstream projects are no longer dependent on
72 // stream objects.
Steve Antonef65ef12018-01-10 17:15:20 -080073 virtual void SetStreams(
74 const std::vector<rtc::scoped_refptr<MediaStreamInterface>>& streams) = 0;
Steve Anton57858b32018-02-15 15:19:50 -080075
76 // Returns an ID that changes if the attached track changes, but
77 // otherwise remains constant. Used to generate IDs for stats.
78 // The special value zero means that no track is attached.
79 virtual int AttachmentId() const = 0;
deadbeefa601f5c2016-06-06 14:27:39 -070080
Ruslan Burakov501bfba2019-02-11 10:29:19 +010081 protected:
82 static int GenerateUniqueId();
83
84 static std::vector<rtc::scoped_refptr<MediaStreamInterface>>
85 CreateStreamsFromIds(std::vector<std::string> stream_ids);
86
87 static void MaybeAttachFrameDecryptorToMediaChannel(
88 const absl::optional<uint32_t>& ssrc,
Steve Anton60776752018-01-10 11:51:34 -080089 rtc::Thread* worker_thread,
Ruslan Burakov501bfba2019-02-11 10:29:19 +010090 rtc::scoped_refptr<webrtc::FrameDecryptorInterface> frame_decryptor,
91 cricket::MediaChannel* media_channel,
92 bool stopped);
deadbeef70ab1a12015-09-28 16:53:55 -070093};
94
95} // namespace webrtc
96
Steve Anton10542f22019-01-11 09:11:00 -080097#endif // PC_RTP_RECEIVER_H_