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