blob: 8ca29fce53fa57f7b2d41c99c8762e8b3b8fbacc [file] [log] [blame]
Steve Anton6e634bf2017-11-13 10:44:53 -08001/*
2 * Copyright 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#include "pc/rtptransceiver.h"
12
13#include <string>
14
15namespace webrtc {
16
17RtpTransceiver::RtpTransceiver(cricket::MediaType media_type)
18 : unified_plan_(false), media_type_(media_type) {
19 RTC_DCHECK(media_type == cricket::MEDIA_TYPE_AUDIO ||
20 media_type == cricket::MEDIA_TYPE_VIDEO);
21}
22
Steve Anton79e79602017-11-20 10:25:56 -080023RtpTransceiver::RtpTransceiver(
24 rtc::scoped_refptr<RtpSenderProxyWithInternal<RtpSenderInternal>> sender,
25 rtc::scoped_refptr<RtpReceiverProxyWithInternal<RtpReceiverInternal>>
26 receiver)
27 : unified_plan_(true), media_type_(sender->media_type()) {
28 RTC_DCHECK(media_type_ == cricket::MEDIA_TYPE_AUDIO ||
29 media_type_ == cricket::MEDIA_TYPE_VIDEO);
30 RTC_DCHECK_EQ(sender->media_type(), receiver->media_type());
31 senders_.push_back(sender);
32 receivers_.push_back(receiver);
33}
34
Steve Anton6e634bf2017-11-13 10:44:53 -080035RtpTransceiver::~RtpTransceiver() {
36 Stop();
37}
38
39void RtpTransceiver::SetChannel(cricket::BaseChannel* channel) {
40 if (channel) {
41 RTC_DCHECK_EQ(media_type(), channel->media_type());
42 }
43 channel_ = channel;
44 for (auto sender : senders_) {
45 if (media_type() == cricket::MEDIA_TYPE_AUDIO) {
46 static_cast<AudioRtpSender*>(sender->internal())
47 ->SetChannel(static_cast<cricket::VoiceChannel*>(channel));
48 } else {
49 static_cast<VideoRtpSender*>(sender->internal())
50 ->SetChannel(static_cast<cricket::VideoChannel*>(channel));
51 }
52 }
53 for (auto receiver : receivers_) {
54 if (!channel) {
55 receiver->internal()->Stop();
56 }
57 if (media_type() == cricket::MEDIA_TYPE_AUDIO) {
58 static_cast<AudioRtpReceiver*>(receiver->internal())
59 ->SetChannel(static_cast<cricket::VoiceChannel*>(channel));
60 } else {
61 static_cast<VideoRtpReceiver*>(receiver->internal())
62 ->SetChannel(static_cast<cricket::VideoChannel*>(channel));
63 }
64 }
65}
66
67void RtpTransceiver::AddSender(
68 rtc::scoped_refptr<RtpSenderProxyWithInternal<RtpSenderInternal>> sender) {
69 RTC_DCHECK(!unified_plan_);
70 RTC_DCHECK(sender);
71 RTC_DCHECK_EQ(media_type(), sender->internal()->media_type());
72 RTC_DCHECK(std::find(senders_.begin(), senders_.end(), sender) ==
73 senders_.end());
74 senders_.push_back(sender);
75}
76
77bool RtpTransceiver::RemoveSender(RtpSenderInterface* sender) {
78 RTC_DCHECK(!unified_plan_);
79 if (sender) {
80 RTC_DCHECK_EQ(media_type(), sender->media_type());
81 }
82 auto it = std::find(senders_.begin(), senders_.end(), sender);
83 if (it == senders_.end()) {
84 return false;
85 }
86 (*it)->internal()->Stop();
87 senders_.erase(it);
88 return true;
89}
90
91void RtpTransceiver::AddReceiver(
92 rtc::scoped_refptr<RtpReceiverProxyWithInternal<RtpReceiverInternal>>
93 receiver) {
94 RTC_DCHECK(!unified_plan_);
95 RTC_DCHECK(receiver);
96 RTC_DCHECK_EQ(media_type(), receiver->internal()->media_type());
97 RTC_DCHECK(std::find(receivers_.begin(), receivers_.end(), receiver) ==
98 receivers_.end());
99 receivers_.push_back(receiver);
100}
101
102bool RtpTransceiver::RemoveReceiver(RtpReceiverInterface* receiver) {
103 RTC_DCHECK(!unified_plan_);
104 if (receiver) {
105 RTC_DCHECK_EQ(media_type(), receiver->media_type());
106 }
107 auto it = std::find(receivers_.begin(), receivers_.end(), receiver);
108 if (it == receivers_.end()) {
109 return false;
110 }
111 (*it)->internal()->Stop();
112 receivers_.erase(it);
113 return true;
114}
115
116rtc::Optional<std::string> RtpTransceiver::mid() const {
117 return mid_;
118}
119
120rtc::scoped_refptr<RtpSenderInterface> RtpTransceiver::sender() const {
121 RTC_DCHECK(unified_plan_);
122 RTC_CHECK_EQ(1u, senders_.size());
123 return senders_[0];
124}
125
126rtc::scoped_refptr<RtpReceiverInterface> RtpTransceiver::receiver() const {
127 RTC_DCHECK(unified_plan_);
128 RTC_CHECK_EQ(1u, receivers_.size());
129 return receivers_[0];
130}
131
132bool RtpTransceiver::stopped() const {
133 return stopped_;
134}
135
136RtpTransceiverDirection RtpTransceiver::direction() const {
137 return direction_;
138}
139
140void RtpTransceiver::SetDirection(RtpTransceiverDirection new_direction) {
141 // TODO(steveanton): This should fire OnNegotiationNeeded.
142 direction_ = new_direction;
143}
144
145rtc::Optional<RtpTransceiverDirection> RtpTransceiver::current_direction()
146 const {
147 return current_direction_;
148}
149
150void RtpTransceiver::Stop() {
151 for (auto sender : senders_) {
152 sender->internal()->Stop();
153 }
154 for (auto receiver : receivers_) {
155 receiver->internal()->Stop();
156 }
157 stopped_ = true;
158}
159
160void RtpTransceiver::SetCodecPreferences(
161 rtc::ArrayView<RtpCodecCapability> codecs) {
162 // TODO(steveanton): Implement this.
163 RTC_NOTREACHED() << "Not implemented";
164}
165
166} // namespace webrtc