Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(270)

Side by Side Diff: webrtc/ortc/rtptransportadapter.cc

Issue 2675173003: Adding "adapter" ORTC objects on top of ChannelManager/BaseChannel/etc. (Closed)
Patch Set: Adding OrtcFactory unit tests. Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
(Empty)
1 /*
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 "webrtc/ortc/rtptransportadapter.h"
12
13 #include <algorithm> // For find.
14 #include <set>
15 #include <sstream>
16
17 #include "webrtc/api/proxy.h"
18 #include "webrtc/base/helpers.h"
19 #include "webrtc/base/logging.h"
20
21 namespace {
22
23 static const int kDefaultRtcpCnameLength = 16;
24
25 } // namespace
26
27 namespace webrtc {
28
29 BEGIN_OWNED_PROXY_MAP(RtpTransport)
30 PROXY_SIGNALING_THREAD_DESTRUCTOR()
31 PROXY_CONSTMETHOD0(PacketTransportInterface*, GetRtpPacketTransport)
32 PROXY_CONSTMETHOD0(PacketTransportInterface*, GetRtcpPacketTransport)
33 PROXY_METHOD1(RTCError, SetRtcpParameters, const RtcpParameters&)
34 PROXY_CONSTMETHOD0(RtcpParameters, GetRtcpParameters)
35 protected:
36 RtpTransportAdapter* GetInternal() override {
37 return internal();
38 }
39 END_PROXY_MAP()
40
41 // static
42 RTCErrorOr<std::unique_ptr<RtpTransportInterface>>
43 RtpTransportAdapter::CreateProxied(
44 const RtcpParameters& rtcp_parameters,
45 PacketTransportInterface* rtp,
46 PacketTransportInterface* rtcp,
47 RtpTransportControllerInterface* rtp_transport_controller) {
48 if (!rtp) {
49 LOG_AND_RETURN_ERROR(RTCErrorType::INVALID_PARAMETER,
50 "Must provide an RTP packet transport.");
51 }
52 if (!rtcp_parameters.mux && !rtcp) {
53 LOG_AND_RETURN_ERROR(
54 RTCErrorType::INVALID_PARAMETER,
55 "Must provide an RTCP packet transport when RTCP muxing is not used.");
56 }
57 if (rtcp_parameters.mux) {
58 rtcp = nullptr;
59 }
60 if (!rtp_transport_controller) {
61 LOG_AND_RETURN_ERROR(RTCErrorType::INVALID_PARAMETER,
62 "Must provide an RTP transport controller.");
63 }
64 RtpTransportControllerAdapter* internal_controller =
65 rtp_transport_controller->GetInternal();
66 return RtpTransportProxyWithInternal<RtpTransportAdapter>::Create(
67 internal_controller->signaling_thread(),
68 internal_controller->worker_thread(),
69 new RtpTransportAdapter(rtcp_parameters, rtp, rtcp, internal_controller));
70 }
71
72 RTCErrorOr<std::unique_ptr<RtpTransportInterface>>
73 RtpTransportAdapter::CreateProxied(
74 const RtcpParameters& rtcp_parameters,
75 PacketTransportInterface* rtp,
76 PacketTransportInterface* rtcp,
77 std::unique_ptr<RtpTransportControllerInterface> rtp_transport_controller) {
78 auto result =
79 CreateProxied(rtcp_parameters, rtp, rtcp, rtp_transport_controller.get());
80 // If RtpTransport was successfully created, transfer ownership of
81 // |rtp_transport_controller|. Otherwise it will go out of scope and be
82 // deleted automatically.
83 if (result.ok()) {
84 result.value()->GetInternal()->owned_rtp_transport_controller_.reset(
85 rtp_transport_controller.release());
86 }
87 return result;
88 }
89
90 RtpTransportAdapter::~RtpTransportAdapter() {
91 rtp_transport_controller_->RemoveTransport(this);
92 }
93
94 PacketTransportInterface* RtpTransportAdapter::GetRtpPacketTransport() const {
95 return rtp_packet_transport_;
96 }
97
98 PacketTransportInterface* RtpTransportAdapter::GetRtcpPacketTransport() const {
99 return rtcp_packet_transport_;
100 }
101
102 RTCError RtpTransportAdapter::SetRtcpParameters(
103 const RtcpParameters& parameters) {
104 if (!parameters.mux && rtcp_parameters_.mux) {
105 LOG_AND_RETURN_ERROR(webrtc::RTCErrorType::INVALID_STATE,
106 "Can't disable RTCP muxing after enabling.");
107 }
108 RTCError err = rtp_transport_controller_->SetRtcpParameters(parameters, this);
109 if (!err.ok()) {
110 return err;
111 }
112 rtcp_parameters_ = parameters;
113 if (parameters.mux) {
114 rtcp_packet_transport_ = nullptr;
115 }
116 return RTCError::OK();
117 }
118
119 RtpTransportAdapter::RtpTransportAdapter(
120 const RtcpParameters& rtcp_parameters,
121 PacketTransportInterface* rtp,
122 PacketTransportInterface* rtcp,
123 RtpTransportControllerAdapter* rtp_transport_controller)
124 : rtp_packet_transport_(rtp),
125 rtcp_packet_transport_(rtcp),
126 rtp_transport_controller_(rtp_transport_controller),
127 rtcp_parameters_(rtcp_parameters) {
128 RTC_DCHECK(rtp_transport_controller);
129 if (rtcp_parameters_.cname.empty()) {
130 if (!rtc::CreateRandomString(kDefaultRtcpCnameLength,
131 &rtcp_parameters_.cname)) {
132 LOG(LS_ERROR) << "Failed to generate CNAME.";
133 RTC_NOTREACHED();
134 }
135 }
136 rtp_transport_controller_->AddTransport(this);
137 }
138
139 } // namespace webrtc
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698