deadbeef | 6979b02 | 2015-09-24 16:47:53 -0700 | [diff] [blame] | 1 | /* |
kjellander | b24317b | 2016-02-10 07:54:43 -0800 | [diff] [blame] | 2 | * Copyright 2015 The WebRTC project authors. All Rights Reserved. |
deadbeef | 6979b02 | 2015-09-24 16:47:53 -0700 | [diff] [blame] | 3 | * |
kjellander | b24317b | 2016-02-10 07:54:43 -0800 | [diff] [blame] | 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. |
deadbeef | 6979b02 | 2015-09-24 16:47:53 -0700 | [diff] [blame] | 9 | */ |
| 10 | |
deadbeef | 70ab1a1 | 2015-09-28 16:53:55 -0700 | [diff] [blame] | 11 | // This file contains classes that implement RtpReceiverInterface. |
| 12 | // An RtpReceiver associates a MediaStreamTrackInterface with an underlying |
Taylor Brandstetter | ba29c6a | 2016-06-27 16:30:35 -0700 | [diff] [blame] | 13 | // transport (provided by cricket::VoiceChannel/cricket::VideoChannel) |
deadbeef | 70ab1a1 | 2015-09-28 16:53:55 -0700 | [diff] [blame] | 14 | |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame] | 15 | #ifndef PC_RTP_RECEIVER_H_ |
| 16 | #define PC_RTP_RECEIVER_H_ |
deadbeef | 70ab1a1 | 2015-09-28 16:53:55 -0700 | [diff] [blame] | 17 | |
pbos | c7c26a0 | 2017-01-02 08:42:32 -0800 | [diff] [blame] | 18 | #include <stdint.h> |
Jonas Olsson | a4d8737 | 2019-07-05 19:08:33 +0200 | [diff] [blame] | 19 | |
deadbeef | 70ab1a1 | 2015-09-28 16:53:55 -0700 | [diff] [blame] | 20 | #include <string> |
Steve Anton | 36b29d1 | 2017-10-30 09:57:42 -0700 | [diff] [blame] | 21 | #include <vector> |
deadbeef | 70ab1a1 | 2015-09-28 16:53:55 -0700 | [diff] [blame] | 22 | |
Yves Gerey | 3e70781 | 2018-11-28 16:47:49 +0100 | [diff] [blame] | 23 | #include "absl/types/optional.h" |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame] | 24 | #include "api/crypto/frame_decryptor_interface.h" |
Harald Alvestrand | 5761e7b | 2021-01-29 14:45:08 +0000 | [diff] [blame] | 25 | #include "api/dtls_transport_interface.h" |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame] | 26 | #include "api/media_stream_interface.h" |
| 27 | #include "api/media_types.h" |
| 28 | #include "api/rtp_parameters.h" |
| 29 | #include "api/rtp_receiver_interface.h" |
Mirko Bonadei | d970807 | 2019-01-25 20:26:48 +0100 | [diff] [blame] | 30 | #include "api/scoped_refptr.h" |
Yves Gerey | 3e70781 | 2018-11-28 16:47:49 +0100 | [diff] [blame] | 31 | #include "api/video/video_frame.h" |
| 32 | #include "api/video/video_sink_interface.h" |
| 33 | #include "api/video/video_source_interface.h" |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame] | 34 | #include "media/base/media_channel.h" |
| 35 | #include "media/base/video_broadcaster.h" |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame] | 36 | #include "pc/video_track_source.h" |
Yves Gerey | 3e70781 | 2018-11-28 16:47:49 +0100 | [diff] [blame] | 37 | #include "rtc_base/thread.h" |
deadbeef | 70ab1a1 | 2015-09-28 16:53:55 -0700 | [diff] [blame] | 38 | |
| 39 | namespace webrtc { |
| 40 | |
deadbeef | a601f5c | 2016-06-06 14:27:39 -0700 | [diff] [blame] | 41 | // Internal class used by PeerConnection. |
| 42 | class RtpReceiverInternal : public RtpReceiverInterface { |
| 43 | public: |
Tommi | 6589def | 2022-02-17 23:36:47 +0100 | [diff] [blame] | 44 | // Call on the signaling thread, to let the receiver know that the the |
| 45 | // embedded source object should enter a stopped/ended state and the track's |
| 46 | // state set to `kEnded`, a final state that cannot be reversed. |
deadbeef | a601f5c | 2016-06-06 14:27:39 -0700 | [diff] [blame] | 47 | virtual void Stop() = 0; |
Tommi | 6589def | 2022-02-17 23:36:47 +0100 | [diff] [blame] | 48 | |
Steve Anton | 57858b3 | 2018-02-15 15:19:50 -0800 | [diff] [blame] | 49 | // Sets the underlying MediaEngine channel associated with this RtpSender. |
Amit Hilbuch | dd9390c | 2018-11-13 16:26:05 -0800 | [diff] [blame] | 50 | // A VoiceMediaChannel should be used for audio RtpSenders and |
| 51 | // a VideoMediaChannel should be used for video RtpSenders. |
Tommi | 6589def | 2022-02-17 23:36:47 +0100 | [diff] [blame] | 52 | // NOTE: |
| 53 | // * SetMediaChannel(nullptr) must be called before the media channel is |
| 54 | // destroyed. |
| 55 | // * This method must be invoked on the worker thread. |
Harald Alvestrand | 36fafc8 | 2022-12-08 08:47:42 +0000 | [diff] [blame] | 56 | virtual void SetMediaChannel( |
| 57 | cricket::MediaReceiveChannelInterface* media_channel) = 0; |
Steve Anton | 57858b3 | 2018-02-15 15:19:50 -0800 | [diff] [blame] | 58 | |
Steve Anton | d367921 | 2018-01-17 17:41:02 -0800 | [diff] [blame] | 59 | // Configures the RtpReceiver with the underlying media channel, with the |
Saurav Das | 7262fc2 | 2019-09-11 16:23:05 -0700 | [diff] [blame] | 60 | // given SSRC as the stream identifier. |
Steve Anton | d367921 | 2018-01-17 17:41:02 -0800 | [diff] [blame] | 61 | virtual void SetupMediaChannel(uint32_t ssrc) = 0; |
| 62 | |
Saurav Das | 7262fc2 | 2019-09-11 16:23:05 -0700 | [diff] [blame] | 63 | // Configures the RtpReceiver with the underlying media channel to receive an |
| 64 | // unsignaled receive stream. |
| 65 | virtual void SetupUnsignaledMediaChannel() = 0; |
| 66 | |
Harald Alvestrand | 4a7b3ac | 2019-01-17 10:39:40 +0100 | [diff] [blame] | 67 | virtual void set_transport( |
| 68 | rtc::scoped_refptr<DtlsTransportInterface> dtls_transport) = 0; |
deadbeef | e814a0d | 2017-02-25 18:15:09 -0800 | [diff] [blame] | 69 | // This SSRC is used as an identifier for the receiver between the API layer |
eladalon | f184138 | 2017-06-12 01:16:46 -0700 | [diff] [blame] | 70 | // and the WebRtcVideoEngine, WebRtcVoiceEngine layer. |
Henrik Boström | 175f06f | 2023-01-05 08:53:16 +0100 | [diff] [blame] | 71 | virtual absl::optional<uint32_t> ssrc() const = 0; |
Steve Anton | 6077675 | 2018-01-10 11:51:34 -0800 | [diff] [blame] | 72 | |
| 73 | // Call this to notify the RtpReceiver when the first packet has been received |
| 74 | // on the corresponding channel. |
| 75 | virtual void NotifyFirstPacketReceived() = 0; |
Steve Anton | ef65ef1 | 2018-01-10 17:15:20 -0800 | [diff] [blame] | 76 | |
| 77 | // Set the associated remote media streams for this receiver. The remote track |
| 78 | // will be removed from any streams that are no longer present and added to |
| 79 | // any new streams. |
Henrik Boström | 199e27b | 2018-07-04 20:51:53 +0200 | [diff] [blame] | 80 | virtual void set_stream_ids(std::vector<std::string> stream_ids) = 0; |
| 81 | // TODO(https://crbug.com/webrtc/9480): Remove SetStreams() in favor of |
| 82 | // set_stream_ids() as soon as downstream projects are no longer dependent on |
| 83 | // stream objects. |
Steve Anton | ef65ef1 | 2018-01-10 17:15:20 -0800 | [diff] [blame] | 84 | virtual void SetStreams( |
| 85 | const std::vector<rtc::scoped_refptr<MediaStreamInterface>>& streams) = 0; |
Steve Anton | 57858b3 | 2018-02-15 15:19:50 -0800 | [diff] [blame] | 86 | |
| 87 | // Returns an ID that changes if the attached track changes, but |
| 88 | // otherwise remains constant. Used to generate IDs for stats. |
| 89 | // The special value zero means that no track is attached. |
| 90 | virtual int AttachmentId() const = 0; |
deadbeef | a601f5c | 2016-06-06 14:27:39 -0700 | [diff] [blame] | 91 | |
Ruslan Burakov | 501bfba | 2019-02-11 10:29:19 +0100 | [diff] [blame] | 92 | protected: |
| 93 | static int GenerateUniqueId(); |
| 94 | |
| 95 | static std::vector<rtc::scoped_refptr<MediaStreamInterface>> |
| 96 | CreateStreamsFromIds(std::vector<std::string> stream_ids); |
deadbeef | 70ab1a1 | 2015-09-28 16:53:55 -0700 | [diff] [blame] | 97 | }; |
| 98 | |
| 99 | } // namespace webrtc |
| 100 | |
Steve Anton | 10542f2 | 2019-01-11 09:11:00 -0800 | [diff] [blame] | 101 | #endif // PC_RTP_RECEIVER_H_ |