This reverts commit 18c869bc36b342cd4a79947067e52a93a04a7808. Reason for revert: Added a field trial that allows landing the code without affecting performance in prod. This CL also incorporates subsequent CLs that also had to be reverted. Original change's description: > Revert "Use two MediaChannels for 2 directions." > > This reverts commit 8981a6fac3d665beac4a58b9453e6c39988a024f. > > Reason for revert: Quality regression detected. > > Original change's description: > > Use two MediaChannels for 2 directions. > > > > This CL separates the two directions of MediaChannel into two separate objects that do not couple with each other. > > > > The notable API change is that receiver local SSRC now has to be set explicitly - before, it was done implicitly when the send-side MediaChannel had a stream added to it. > > > > Bug: webrtc:13931 > > Change-Id: I83c2e3c8e79f89872d5adda1bc2899f7049748b3 > > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/288400 > > Commit-Queue: Harald Alvestrand <hta@webrtc.org> > > Reviewed-by: Henrik Boström <hbos@webrtc.org> > > Cr-Commit-Position: refs/heads/main@{#39340} > > No-Try: true > Bug: webrtc:13931 > Change-Id: I791997ad9eff75c3ac9cd2e4bbacf5bc6c3a3a79 > Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/295663 > Commit-Queue: Harald Alvestrand <hta@webrtc.org> > Reviewed-by: Mirko Bonadei <mbonadei@webrtc.org> > Cr-Commit-Position: refs/heads/main@{#39445} Bug: webrtc:13931 Change-Id: I1318910a685188e2b846c9040e1efc04c2c894ac Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/296080 Reviewed-by: Tomas Gunnarsson <tommi@webrtc.org> Reviewed-by: Per Kjellander <perkj@webrtc.org> Commit-Queue: Harald Alvestrand <hta@webrtc.org> Reviewed-by: Henrik Boström <hbos@webrtc.org> Cr-Commit-Position: refs/heads/main@{#39494}
107 lines
3.9 KiB
C++
107 lines
3.9 KiB
C++
/*
|
|
* Copyright 2018 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 PC_CHANNEL_INTERFACE_H_
|
|
#define PC_CHANNEL_INTERFACE_H_
|
|
|
|
#include <memory>
|
|
#include <string>
|
|
#include <vector>
|
|
|
|
#include "absl/strings/string_view.h"
|
|
#include "api/jsep.h"
|
|
#include "api/media_types.h"
|
|
#include "media/base/media_channel.h"
|
|
#include "pc/rtp_transport_internal.h"
|
|
|
|
namespace webrtc {
|
|
class Call;
|
|
class VideoBitrateAllocatorFactory;
|
|
} // namespace webrtc
|
|
|
|
namespace cricket {
|
|
|
|
class MediaChannel;
|
|
class VoiceChannel;
|
|
class VideoChannel;
|
|
class MediaContentDescription;
|
|
struct MediaConfig;
|
|
|
|
// A Channel is a construct that groups media streams of the same type
|
|
// (audio or video), both outgoing and incoming.
|
|
// When the PeerConnection API is used, a Channel corresponds one to one
|
|
// to an RtpTransceiver.
|
|
// When Unified Plan is used, there can only be at most one outgoing and
|
|
// one incoming stream. With Plan B, there can be more than one.
|
|
|
|
// ChannelInterface contains methods common to voice and video channels.
|
|
// As more methods are added to BaseChannel, they should be included in the
|
|
// interface as well.
|
|
// TODO(bugs.webrtc.org/13931): Merge this class into RtpTransceiver.
|
|
class ChannelInterface {
|
|
public:
|
|
virtual ~ChannelInterface() = default;
|
|
virtual cricket::MediaType media_type() const = 0;
|
|
|
|
virtual VideoChannel* AsVideoChannel() = 0;
|
|
virtual VoiceChannel* AsVoiceChannel() = 0;
|
|
|
|
virtual MediaSendChannelInterface* media_send_channel() = 0;
|
|
// Typecasts of media_channel(). Will cause an exception if the
|
|
// channel is of the wrong type.
|
|
virtual VideoMediaSendChannelInterface* video_media_send_channel() = 0;
|
|
virtual VoiceMediaSendChannelInterface* voice_media_send_channel() = 0;
|
|
virtual MediaReceiveChannelInterface* media_receive_channel() = 0;
|
|
// Typecasts of media_channel(). Will cause an exception if the
|
|
// channel is of the wrong type.
|
|
virtual VideoMediaReceiveChannelInterface* video_media_receive_channel() = 0;
|
|
virtual VoiceMediaReceiveChannelInterface* voice_media_receive_channel() = 0;
|
|
|
|
// Returns a string view for the transport name. Fetching the transport name
|
|
// must be done on the network thread only and note that the lifetime of
|
|
// the returned object should be assumed to only be the calling scope.
|
|
// TODO(deadbeef): This is redundant; remove this.
|
|
virtual absl::string_view transport_name() const = 0;
|
|
|
|
// TODO(tommi): Change return type to string_view.
|
|
virtual const std::string& mid() const = 0;
|
|
|
|
// Enables or disables this channel
|
|
virtual void Enable(bool enable) = 0;
|
|
|
|
// Used for latency measurements.
|
|
virtual void SetFirstPacketReceivedCallback(
|
|
std::function<void()> callback) = 0;
|
|
|
|
// Channel control
|
|
virtual bool SetLocalContent(const MediaContentDescription* content,
|
|
webrtc::SdpType type,
|
|
std::string& error_desc) = 0;
|
|
virtual bool SetRemoteContent(const MediaContentDescription* content,
|
|
webrtc::SdpType type,
|
|
std::string& error_desc) = 0;
|
|
virtual bool SetPayloadTypeDemuxingEnabled(bool enabled) = 0;
|
|
|
|
// Access to the local and remote streams that were set on the channel.
|
|
virtual const std::vector<StreamParams>& local_streams() const = 0;
|
|
virtual const std::vector<StreamParams>& remote_streams() const = 0;
|
|
|
|
// Set an RTP level transport.
|
|
// Some examples:
|
|
// * An RtpTransport without encryption.
|
|
// * An SrtpTransport for SDES.
|
|
// * A DtlsSrtpTransport for DTLS-SRTP.
|
|
virtual bool SetRtpTransport(webrtc::RtpTransportInternal* rtp_transport) = 0;
|
|
};
|
|
|
|
} // namespace cricket
|
|
|
|
#endif // PC_CHANNEL_INTERFACE_H_
|