blob: 42a43a79cdebbb7108a71c1f52f7a39dbc77c071 [file] [log] [blame]
hjonf396f602016-02-11 16:19:06 -08001/*
2 * Copyright 2015 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
tkchin9eeb6242016-04-27 01:54:20 -070011#import "RTCPeerConnection+Private.h"
12
tkchin9eeb6242016-04-27 01:54:20 -070013#import "RTCConfiguration+Private.h"
14#import "RTCDataChannel+Private.h"
15#import "RTCIceCandidate+Private.h"
hbosbd3dda62016-09-09 01:36:28 -070016#import "RTCLegacyStatsReport+Private.h"
tkchin9eeb6242016-04-27 01:54:20 -070017#import "RTCMediaConstraints+Private.h"
18#import "RTCMediaStream+Private.h"
Steve Anton8cb344a2018-02-27 15:34:53 -080019#import "RTCMediaStreamTrack+Private.h"
tkchin9eeb6242016-04-27 01:54:20 -070020#import "RTCPeerConnectionFactory+Private.h"
Taylor Brandstetterdb0cd9e2016-05-16 11:40:30 -070021#import "RTCRtpReceiver+Private.h"
tkchin9eeb6242016-04-27 01:54:20 -070022#import "RTCRtpSender+Private.h"
Steve Anton8cb344a2018-02-27 15:34:53 -080023#import "RTCRtpTransceiver+Private.h"
tkchin9eeb6242016-04-27 01:54:20 -070024#import "RTCSessionDescription+Private.h"
Anders Carlsson7bca8ca2018-08-30 09:30:29 +020025#import "base/RTCLogging.h"
26#import "helpers/NSString+StdString.h"
hjonf396f602016-02-11 16:19:06 -080027
kwibergbfefb032016-05-01 14:53:46 -070028#include <memory>
29
Steve Anton10542f22019-01-11 09:11:00 -080030#include "api/jsep_ice_candidate.h"
Niels Möller695cf6a2019-05-13 12:27:23 +020031#include "api/rtc_event_log_output_file.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020032#include "rtc_base/checks.h"
Niels Möller695cf6a2019-05-13 12:27:23 +020033#include "rtc_base/numerics/safe_conversions.h"
hjonf396f602016-02-11 16:19:06 -080034
Mirko Bonadeia81e9c82020-05-04 16:14:32 +020035NSString *const kRTCPeerConnectionErrorDomain = @"org.webrtc.RTC_OBJC_TYPE(RTCPeerConnection)";
hjonf396f602016-02-11 16:19:06 -080036int const kRTCPeerConnnectionSessionDescriptionError = -1;
37
38namespace webrtc {
39
40class CreateSessionDescriptionObserverAdapter
41 : public CreateSessionDescriptionObserver {
42 public:
Mirko Bonadeia81e9c82020-05-04 16:14:32 +020043 CreateSessionDescriptionObserverAdapter(void (^completionHandler)(
44 RTC_OBJC_TYPE(RTCSessionDescription) * sessionDescription, NSError *error)) {
hjonf396f602016-02-11 16:19:06 -080045 completion_handler_ = completionHandler;
46 }
47
Mirko Bonadei17aff352018-07-26 12:20:40 +020048 ~CreateSessionDescriptionObserverAdapter() override { completion_handler_ = nil; }
hjonf396f602016-02-11 16:19:06 -080049
50 void OnSuccess(SessionDescriptionInterface *desc) override {
51 RTC_DCHECK(completion_handler_);
kwibergbfefb032016-05-01 14:53:46 -070052 std::unique_ptr<webrtc::SessionDescriptionInterface> description =
53 std::unique_ptr<webrtc::SessionDescriptionInterface>(desc);
Mirko Bonadeia81e9c82020-05-04 16:14:32 +020054 RTC_OBJC_TYPE(RTCSessionDescription) *session =
55 [[RTC_OBJC_TYPE(RTCSessionDescription) alloc] initWithNativeDescription:description.get()];
hjonf396f602016-02-11 16:19:06 -080056 completion_handler_(session, nil);
57 completion_handler_ = nil;
58 }
59
Harald Alvestrand73771a82018-05-24 10:53:49 +020060 void OnFailure(RTCError error) override {
hjonf396f602016-02-11 16:19:06 -080061 RTC_DCHECK(completion_handler_);
Harald Alvestrand73771a82018-05-24 10:53:49 +020062 // TODO(hta): Add handling of error.type()
63 NSString *str = [NSString stringForStdString:error.message()];
hjonf396f602016-02-11 16:19:06 -080064 NSError* err =
65 [NSError errorWithDomain:kRTCPeerConnectionErrorDomain
66 code:kRTCPeerConnnectionSessionDescriptionError
67 userInfo:@{ NSLocalizedDescriptionKey : str }];
68 completion_handler_(nil, err);
69 completion_handler_ = nil;
70 }
71
72 private:
Mirko Bonadeia81e9c82020-05-04 16:14:32 +020073 void (^completion_handler_)(RTC_OBJC_TYPE(RTCSessionDescription) * sessionDescription,
74 NSError *error);
hjonf396f602016-02-11 16:19:06 -080075};
76
77class SetSessionDescriptionObserverAdapter :
78 public SetSessionDescriptionObserver {
79 public:
80 SetSessionDescriptionObserverAdapter(void (^completionHandler)
81 (NSError *error)) {
82 completion_handler_ = completionHandler;
83 }
84
Mirko Bonadei17aff352018-07-26 12:20:40 +020085 ~SetSessionDescriptionObserverAdapter() override { completion_handler_ = nil; }
hjonf396f602016-02-11 16:19:06 -080086
87 void OnSuccess() override {
88 RTC_DCHECK(completion_handler_);
89 completion_handler_(nil);
90 completion_handler_ = nil;
91 }
92
Harald Alvestrand73771a82018-05-24 10:53:49 +020093 void OnFailure(RTCError error) override {
hjonf396f602016-02-11 16:19:06 -080094 RTC_DCHECK(completion_handler_);
Harald Alvestrand73771a82018-05-24 10:53:49 +020095 // TODO(hta): Add handling of error.type()
96 NSString *str = [NSString stringForStdString:error.message()];
hjonf396f602016-02-11 16:19:06 -080097 NSError* err =
98 [NSError errorWithDomain:kRTCPeerConnectionErrorDomain
99 code:kRTCPeerConnnectionSessionDescriptionError
100 userInfo:@{ NSLocalizedDescriptionKey : str }];
101 completion_handler_(err);
102 completion_handler_ = nil;
103 }
104
105 private:
106 void (^completion_handler_)(NSError *error);
107};
108
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200109PeerConnectionDelegateAdapter::PeerConnectionDelegateAdapter(RTC_OBJC_TYPE(RTCPeerConnection) *
110 peerConnection) {
hjonf396f602016-02-11 16:19:06 -0800111 peer_connection_ = peerConnection;
112}
113
114PeerConnectionDelegateAdapter::~PeerConnectionDelegateAdapter() {
115 peer_connection_ = nil;
116}
117
118void PeerConnectionDelegateAdapter::OnSignalingChange(
119 PeerConnectionInterface::SignalingState new_state) {
120 RTCSignalingState state =
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200121 [[RTC_OBJC_TYPE(RTCPeerConnection) class] signalingStateForNativeState:new_state];
122 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
hjonf396f602016-02-11 16:19:06 -0800123 [peer_connection.delegate peerConnection:peer_connection
124 didChangeSignalingState:state];
125}
126
127void PeerConnectionDelegateAdapter::OnAddStream(
deadbeefd5f41ce2016-06-08 13:31:45 -0700128 rtc::scoped_refptr<MediaStreamInterface> stream) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200129 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
130 RTC_OBJC_TYPE(RTCMediaStream) *mediaStream =
131 [[RTC_OBJC_TYPE(RTCMediaStream) alloc] initWithFactory:peer_connection.factory
132 nativeMediaStream:stream];
hjonf396f602016-02-11 16:19:06 -0800133 [peer_connection.delegate peerConnection:peer_connection
134 didAddStream:mediaStream];
135}
136
137void PeerConnectionDelegateAdapter::OnRemoveStream(
deadbeefd5f41ce2016-06-08 13:31:45 -0700138 rtc::scoped_refptr<MediaStreamInterface> stream) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200139 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
140 RTC_OBJC_TYPE(RTCMediaStream) *mediaStream =
141 [[RTC_OBJC_TYPE(RTCMediaStream) alloc] initWithFactory:peer_connection.factory
142 nativeMediaStream:stream];
Yura Yaroshevichc806c1d2018-06-21 12:51:11 +0300143
hjonf396f602016-02-11 16:19:06 -0800144 [peer_connection.delegate peerConnection:peer_connection
145 didRemoveStream:mediaStream];
146}
147
Steve Anton8cb344a2018-02-27 15:34:53 -0800148void PeerConnectionDelegateAdapter::OnTrack(
149 rtc::scoped_refptr<RtpTransceiverInterface> nativeTransceiver) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200150 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
151 RTC_OBJC_TYPE(RTCRtpTransceiver) *transceiver =
152 [[RTC_OBJC_TYPE(RTCRtpTransceiver) alloc] initWithFactory:peer_connection.factory
153 nativeRtpTransceiver:nativeTransceiver];
Steve Anton8cb344a2018-02-27 15:34:53 -0800154 if ([peer_connection.delegate
155 respondsToSelector:@selector(peerConnection:didStartReceivingOnTransceiver:)]) {
156 [peer_connection.delegate peerConnection:peer_connection
157 didStartReceivingOnTransceiver:transceiver];
158 }
159}
160
hjonf396f602016-02-11 16:19:06 -0800161void PeerConnectionDelegateAdapter::OnDataChannel(
deadbeefd5f41ce2016-06-08 13:31:45 -0700162 rtc::scoped_refptr<DataChannelInterface> data_channel) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200163 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
164 RTC_OBJC_TYPE(RTCDataChannel) *dataChannel =
165 [[RTC_OBJC_TYPE(RTCDataChannel) alloc] initWithFactory:peer_connection.factory
166 nativeDataChannel:data_channel];
hjonf396f602016-02-11 16:19:06 -0800167 [peer_connection.delegate peerConnection:peer_connection
168 didOpenDataChannel:dataChannel];
169}
170
171void PeerConnectionDelegateAdapter::OnRenegotiationNeeded() {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200172 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
hjonf396f602016-02-11 16:19:06 -0800173 [peer_connection.delegate peerConnectionShouldNegotiate:peer_connection];
174}
175
176void PeerConnectionDelegateAdapter::OnIceConnectionChange(
177 PeerConnectionInterface::IceConnectionState new_state) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200178 RTCIceConnectionState state =
179 [RTC_OBJC_TYPE(RTCPeerConnection) iceConnectionStateForNativeState:new_state];
Jonas Olssoncfddbb72018-11-15 16:52:45 +0100180 [peer_connection_.delegate peerConnection:peer_connection_ didChangeIceConnectionState:state];
181}
182
Qingsi Wang36e31472019-05-29 11:37:26 -0700183void PeerConnectionDelegateAdapter::OnStandardizedIceConnectionChange(
184 PeerConnectionInterface::IceConnectionState new_state) {
185 if ([peer_connection_.delegate
186 respondsToSelector:@selector(peerConnection:didChangeStandardizedIceConnectionState:)]) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200187 RTCIceConnectionState state =
188 [RTC_OBJC_TYPE(RTCPeerConnection) iceConnectionStateForNativeState:new_state];
Qingsi Wang36e31472019-05-29 11:37:26 -0700189 [peer_connection_.delegate peerConnection:peer_connection_
190 didChangeStandardizedIceConnectionState:state];
191 }
192}
193
Jonas Olssoncfddbb72018-11-15 16:52:45 +0100194void PeerConnectionDelegateAdapter::OnConnectionChange(
195 PeerConnectionInterface::PeerConnectionState new_state) {
196 if ([peer_connection_.delegate
197 respondsToSelector:@selector(peerConnection:didChangeConnectionState:)]) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200198 RTCPeerConnectionState state =
199 [RTC_OBJC_TYPE(RTCPeerConnection) connectionStateForNativeState:new_state];
Jonas Olssoncfddbb72018-11-15 16:52:45 +0100200 [peer_connection_.delegate peerConnection:peer_connection_ didChangeConnectionState:state];
201 }
hjonf396f602016-02-11 16:19:06 -0800202}
203
204void PeerConnectionDelegateAdapter::OnIceGatheringChange(
205 PeerConnectionInterface::IceGatheringState new_state) {
206 RTCIceGatheringState state =
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200207 [[RTC_OBJC_TYPE(RTCPeerConnection) class] iceGatheringStateForNativeState:new_state];
208 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
hjonf396f602016-02-11 16:19:06 -0800209 [peer_connection.delegate peerConnection:peer_connection
210 didChangeIceGatheringState:state];
211}
212
213void PeerConnectionDelegateAdapter::OnIceCandidate(
214 const IceCandidateInterface *candidate) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200215 RTC_OBJC_TYPE(RTCIceCandidate) *iceCandidate =
216 [[RTC_OBJC_TYPE(RTCIceCandidate) alloc] initWithNativeCandidate:candidate];
217 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
hjonf396f602016-02-11 16:19:06 -0800218 [peer_connection.delegate peerConnection:peer_connection
219 didGenerateIceCandidate:iceCandidate];
220}
Honghai Zhangda2ba4d2016-05-23 11:53:14 -0700221
222void PeerConnectionDelegateAdapter::OnIceCandidatesRemoved(
223 const std::vector<cricket::Candidate>& candidates) {
224 NSMutableArray* ice_candidates =
225 [NSMutableArray arrayWithCapacity:candidates.size()];
226 for (const auto& candidate : candidates) {
227 std::unique_ptr<JsepIceCandidate> candidate_wrapper(
228 new JsepIceCandidate(candidate.transport_name(), -1, candidate));
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200229 RTC_OBJC_TYPE(RTCIceCandidate) *ice_candidate =
230 [[RTC_OBJC_TYPE(RTCIceCandidate) alloc] initWithNativeCandidate:candidate_wrapper.get()];
Honghai Zhangda2ba4d2016-05-23 11:53:14 -0700231 [ice_candidates addObject:ice_candidate];
232 }
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200233 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
Honghai Zhangda2ba4d2016-05-23 11:53:14 -0700234 [peer_connection.delegate peerConnection:peer_connection
235 didRemoveIceCandidates:ice_candidates];
236}
237
Alex Drake43faee02019-08-12 16:27:34 -0700238void PeerConnectionDelegateAdapter::OnIceSelectedCandidatePairChanged(
239 const cricket::CandidatePairChangeEvent &event) {
Qingsi Wang7cdcda92019-08-28 09:18:37 -0700240 const auto &selected_pair = event.selected_candidate_pair;
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200241 auto local_candidate_wrapper = std::make_unique<JsepIceCandidate>(
Qingsi Wang7cdcda92019-08-28 09:18:37 -0700242 selected_pair.local_candidate().transport_name(), -1, selected_pair.local_candidate());
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200243 RTC_OBJC_TYPE(RTCIceCandidate) *local_candidate = [[RTC_OBJC_TYPE(RTCIceCandidate) alloc]
244 initWithNativeCandidate:local_candidate_wrapper.release()];
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200245 auto remote_candidate_wrapper = std::make_unique<JsepIceCandidate>(
Qingsi Wang7cdcda92019-08-28 09:18:37 -0700246 selected_pair.remote_candidate().transport_name(), -1, selected_pair.remote_candidate());
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200247 RTC_OBJC_TYPE(RTCIceCandidate) *remote_candidate = [[RTC_OBJC_TYPE(RTCIceCandidate) alloc]
248 initWithNativeCandidate:remote_candidate_wrapper.release()];
249 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
Alex Drake43faee02019-08-12 16:27:34 -0700250 NSString *nsstr_reason = [NSString stringForStdString:event.reason];
251 if ([peer_connection.delegate
252 respondsToSelector:@selector
253 (peerConnection:didChangeLocalCandidate:remoteCandidate:lastReceivedMs:changeReason:)]) {
254 [peer_connection.delegate peerConnection:peer_connection
255 didChangeLocalCandidate:local_candidate
256 remoteCandidate:remote_candidate
257 lastReceivedMs:event.last_data_received_ms
258 changeReason:nsstr_reason];
259 }
260}
261
Yura Yaroshevich546d7f92018-02-28 21:06:34 +0300262void PeerConnectionDelegateAdapter::OnAddTrack(
263 rtc::scoped_refptr<RtpReceiverInterface> receiver,
Alex Drake43faee02019-08-12 16:27:34 -0700264 const std::vector<rtc::scoped_refptr<MediaStreamInterface>> &streams) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200265 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
Alex Drake43faee02019-08-12 16:27:34 -0700266 if ([peer_connection.delegate respondsToSelector:@selector(peerConnection:
267 didAddReceiver:streams:)]) {
Yura Yaroshevich546d7f92018-02-28 21:06:34 +0300268 NSMutableArray *mediaStreams = [NSMutableArray arrayWithCapacity:streams.size()];
Alex Drake43faee02019-08-12 16:27:34 -0700269 for (const auto &nativeStream : streams) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200270 RTC_OBJC_TYPE(RTCMediaStream) *mediaStream =
271 [[RTC_OBJC_TYPE(RTCMediaStream) alloc] initWithFactory:peer_connection.factory
272 nativeMediaStream:nativeStream];
Yura Yaroshevich546d7f92018-02-28 21:06:34 +0300273 [mediaStreams addObject:mediaStream];
274 }
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200275 RTC_OBJC_TYPE(RTCRtpReceiver) *rtpReceiver =
276 [[RTC_OBJC_TYPE(RTCRtpReceiver) alloc] initWithFactory:peer_connection.factory
277 nativeRtpReceiver:receiver];
Yura Yaroshevich546d7f92018-02-28 21:06:34 +0300278
279 [peer_connection.delegate peerConnection:peer_connection
280 didAddReceiver:rtpReceiver
281 streams:mediaStreams];
282 }
283}
284
Zeke Chin8de502b2018-08-21 11:41:07 -0700285void PeerConnectionDelegateAdapter::OnRemoveTrack(
286 rtc::scoped_refptr<RtpReceiverInterface> receiver) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200287 RTC_OBJC_TYPE(RTCPeerConnection) *peer_connection = peer_connection_;
Zeke Chin8de502b2018-08-21 11:41:07 -0700288 if ([peer_connection.delegate respondsToSelector:@selector(peerConnection:didRemoveReceiver:)]) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200289 RTC_OBJC_TYPE(RTCRtpReceiver) *rtpReceiver =
290 [[RTC_OBJC_TYPE(RTCRtpReceiver) alloc] initWithFactory:peer_connection.factory
291 nativeRtpReceiver:receiver];
Zeke Chin8de502b2018-08-21 11:41:07 -0700292 [peer_connection.delegate peerConnection:peer_connection didRemoveReceiver:rtpReceiver];
293 }
294}
295
hjonf396f602016-02-11 16:19:06 -0800296} // namespace webrtc
297
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200298@implementation RTC_OBJC_TYPE (RTCPeerConnection) {
299 RTC_OBJC_TYPE(RTCPeerConnectionFactory) * _factory;
300 NSMutableArray<RTC_OBJC_TYPE(RTCMediaStream) *> *_localStreams;
kwibergbfefb032016-05-01 14:53:46 -0700301 std::unique_ptr<webrtc::PeerConnectionDelegateAdapter> _observer;
hjonf396f602016-02-11 16:19:06 -0800302 rtc::scoped_refptr<webrtc::PeerConnectionInterface> _peerConnection;
deadbeef5d0b6d82017-01-09 16:05:28 -0800303 std::unique_ptr<webrtc::MediaConstraints> _nativeConstraints;
ivoc14d5dbe2016-07-04 07:06:55 -0700304 BOOL _hasStartedRtcEventLog;
hjonf396f602016-02-11 16:19:06 -0800305}
306
307@synthesize delegate = _delegate;
Yura Yaroshevichc806c1d2018-06-21 12:51:11 +0300308@synthesize factory = _factory;
hjonf396f602016-02-11 16:19:06 -0800309
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200310- (instancetype)initWithFactory:(RTC_OBJC_TYPE(RTCPeerConnectionFactory) *)factory
311 configuration:(RTC_OBJC_TYPE(RTCConfiguration) *)configuration
312 constraints:(RTC_OBJC_TYPE(RTCMediaConstraints) *)constraints
313 delegate:(id<RTC_OBJC_TYPE(RTCPeerConnectionDelegate)>)delegate {
hjonf396f602016-02-11 16:19:06 -0800314 NSParameterAssert(factory);
Jonas Oreland285f83d2020-02-07 10:30:08 +0100315 std::unique_ptr<webrtc::PeerConnectionDependencies> dependencies =
316 std::make_unique<webrtc::PeerConnectionDependencies>(nullptr);
317 return [self initWithDependencies:factory
318 configuration:configuration
319 constraints:constraints
320 dependencies:std::move(dependencies)
321 delegate:delegate];
322}
323
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200324- (instancetype)initWithDependencies:(RTC_OBJC_TYPE(RTCPeerConnectionFactory) *)factory
325 configuration:(RTC_OBJC_TYPE(RTCConfiguration) *)configuration
326 constraints:(RTC_OBJC_TYPE(RTCMediaConstraints) *)constraints
Jonas Oreland285f83d2020-02-07 10:30:08 +0100327 dependencies:
328 (std::unique_ptr<webrtc::PeerConnectionDependencies>)dependencies
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200329 delegate:(id<RTC_OBJC_TYPE(RTCPeerConnectionDelegate)>)delegate {
Jonas Oreland285f83d2020-02-07 10:30:08 +0100330 NSParameterAssert(factory);
331 NSParameterAssert(dependencies.get());
Henrik Boströme06c2dd2016-05-13 13:50:38 +0200332 std::unique_ptr<webrtc::PeerConnectionInterface::RTCConfiguration> config(
hbosa73ca562016-05-17 03:28:58 -0700333 [configuration createNativeConfiguration]);
334 if (!config) {
335 return nil;
336 }
hjonf396f602016-02-11 16:19:06 -0800337 if (self = [super init]) {
338 _observer.reset(new webrtc::PeerConnectionDelegateAdapter(self));
deadbeef5d0b6d82017-01-09 16:05:28 -0800339 _nativeConstraints = constraints.nativeConstraints;
Jonas Oreland285f83d2020-02-07 10:30:08 +0100340 CopyConstraintsIntoRtcConfiguration(_nativeConstraints.get(), config.get());
341
342 webrtc::PeerConnectionDependencies deps = std::move(*dependencies.release());
343 deps.observer = _observer.get();
344 _peerConnection = factory.nativeFactory->CreatePeerConnection(*config, std::move(deps));
345
skvlad588783a2016-08-11 14:29:25 -0700346 if (!_peerConnection) {
347 return nil;
348 }
Yura Yaroshevich5297bd22018-06-19 12:51:51 +0300349 _factory = factory;
hjonf396f602016-02-11 16:19:06 -0800350 _localStreams = [[NSMutableArray alloc] init];
351 _delegate = delegate;
352 }
353 return self;
354}
355
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200356- (NSArray<RTC_OBJC_TYPE(RTCMediaStream) *> *)localStreams {
hjonf396f602016-02-11 16:19:06 -0800357 return [_localStreams copy];
358}
359
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200360- (RTC_OBJC_TYPE(RTCSessionDescription) *)localDescription {
hjonf396f602016-02-11 16:19:06 -0800361 const webrtc::SessionDescriptionInterface *description =
362 _peerConnection->local_description();
363 return description ?
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200364 [[RTC_OBJC_TYPE(RTCSessionDescription) alloc] initWithNativeDescription:description] :
365 nil;
hjonf396f602016-02-11 16:19:06 -0800366}
367
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200368- (RTC_OBJC_TYPE(RTCSessionDescription) *)remoteDescription {
hjonf396f602016-02-11 16:19:06 -0800369 const webrtc::SessionDescriptionInterface *description =
370 _peerConnection->remote_description();
371 return description ?
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200372 [[RTC_OBJC_TYPE(RTCSessionDescription) alloc] initWithNativeDescription:description] :
373 nil;
hjonf396f602016-02-11 16:19:06 -0800374}
375
376- (RTCSignalingState)signalingState {
377 return [[self class]
378 signalingStateForNativeState:_peerConnection->signaling_state()];
379}
380
381- (RTCIceConnectionState)iceConnectionState {
382 return [[self class] iceConnectionStateForNativeState:
383 _peerConnection->ice_connection_state()];
384}
385
Jonas Olssoncfddbb72018-11-15 16:52:45 +0100386- (RTCPeerConnectionState)connectionState {
387 return [[self class] connectionStateForNativeState:_peerConnection->peer_connection_state()];
388}
389
hjonf396f602016-02-11 16:19:06 -0800390- (RTCIceGatheringState)iceGatheringState {
391 return [[self class] iceGatheringStateForNativeState:
392 _peerConnection->ice_gathering_state()];
393}
394
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200395- (BOOL)setConfiguration:(RTC_OBJC_TYPE(RTCConfiguration) *)configuration {
Henrik Boströme06c2dd2016-05-13 13:50:38 +0200396 std::unique_ptr<webrtc::PeerConnectionInterface::RTCConfiguration> config(
hbosa73ca562016-05-17 03:28:58 -0700397 [configuration createNativeConfiguration]);
398 if (!config) {
399 return NO;
400 }
deadbeef5d0b6d82017-01-09 16:05:28 -0800401 CopyConstraintsIntoRtcConfiguration(_nativeConstraints.get(),
402 config.get());
Niels Möller2579f0c2019-08-19 09:58:17 +0200403 return _peerConnection->SetConfiguration(*config).ok();
tkchinaac3eb22016-03-09 21:49:40 -0800404}
405
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200406- (RTC_OBJC_TYPE(RTCConfiguration) *)configuration {
jtteh4eeb5372017-04-03 15:06:37 -0700407 webrtc::PeerConnectionInterface::RTCConfiguration config =
408 _peerConnection->GetConfiguration();
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200409 return [[RTC_OBJC_TYPE(RTCConfiguration) alloc] initWithNativeConfiguration:config];
jtteh4eeb5372017-04-03 15:06:37 -0700410}
411
hjonf396f602016-02-11 16:19:06 -0800412- (void)close {
413 _peerConnection->Close();
414}
415
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200416- (void)addIceCandidate:(RTC_OBJC_TYPE(RTCIceCandidate) *)candidate {
kwibergbfefb032016-05-01 14:53:46 -0700417 std::unique_ptr<const webrtc::IceCandidateInterface> iceCandidate(
hjonf396f602016-02-11 16:19:06 -0800418 candidate.nativeCandidate);
419 _peerConnection->AddIceCandidate(iceCandidate.get());
420}
421
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200422- (void)removeIceCandidates:(NSArray<RTC_OBJC_TYPE(RTCIceCandidate) *> *)iceCandidates {
Honghai Zhangda2ba4d2016-05-23 11:53:14 -0700423 std::vector<cricket::Candidate> candidates;
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200424 for (RTC_OBJC_TYPE(RTCIceCandidate) * iceCandidate in iceCandidates) {
Honghai Zhangda2ba4d2016-05-23 11:53:14 -0700425 std::unique_ptr<const webrtc::IceCandidateInterface> candidate(
426 iceCandidate.nativeCandidate);
427 if (candidate) {
428 candidates.push_back(candidate->candidate());
429 // Need to fill the transport name from the sdp_mid.
430 candidates.back().set_transport_name(candidate->sdp_mid());
431 }
432 }
433 if (!candidates.empty()) {
434 _peerConnection->RemoveIceCandidates(candidates);
435 }
436}
437
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200438- (void)addStream:(RTC_OBJC_TYPE(RTCMediaStream) *)stream {
hjona2f77982016-03-04 07:09:09 -0800439 if (!_peerConnection->AddStream(stream.nativeMediaStream)) {
hjonf396f602016-02-11 16:19:06 -0800440 RTCLogError(@"Failed to add stream: %@", stream);
441 return;
442 }
443 [_localStreams addObject:stream];
444}
445
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200446- (void)removeStream:(RTC_OBJC_TYPE(RTCMediaStream) *)stream {
hjonf396f602016-02-11 16:19:06 -0800447 _peerConnection->RemoveStream(stream.nativeMediaStream);
448 [_localStreams removeObject:stream];
449}
450
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200451- (RTC_OBJC_TYPE(RTCRtpSender) *)addTrack:(RTC_OBJC_TYPE(RTCMediaStreamTrack) *)track
452 streamIds:(NSArray<NSString *> *)streamIds {
Seth Hampson513449e2018-03-06 09:35:56 -0800453 std::vector<std::string> nativeStreamIds;
454 for (NSString *streamId in streamIds) {
455 nativeStreamIds.push_back([streamId UTF8String]);
Steve Anton8cb344a2018-02-27 15:34:53 -0800456 }
457 webrtc::RTCErrorOr<rtc::scoped_refptr<webrtc::RtpSenderInterface>> nativeSenderOrError =
Seth Hampson513449e2018-03-06 09:35:56 -0800458 _peerConnection->AddTrack(track.nativeTrack, nativeStreamIds);
Steve Anton8cb344a2018-02-27 15:34:53 -0800459 if (!nativeSenderOrError.ok()) {
460 RTCLogError(@"Failed to add track %@: %s", track, nativeSenderOrError.error().message());
461 return nil;
462 }
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200463 return [[RTC_OBJC_TYPE(RTCRtpSender) alloc] initWithFactory:self.factory
464 nativeRtpSender:nativeSenderOrError.MoveValue()];
Steve Anton8cb344a2018-02-27 15:34:53 -0800465}
466
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200467- (BOOL)removeTrack:(RTC_OBJC_TYPE(RTCRtpSender) *)sender {
Steve Anton8cb344a2018-02-27 15:34:53 -0800468 bool result = _peerConnection->RemoveTrack(sender.nativeRtpSender);
469 if (!result) {
470 RTCLogError(@"Failed to remote track %@", sender);
471 }
472 return result;
473}
474
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200475- (RTC_OBJC_TYPE(RTCRtpTransceiver) *)addTransceiverWithTrack:
476 (RTC_OBJC_TYPE(RTCMediaStreamTrack) *)track {
477 return [self addTransceiverWithTrack:track
478 init:[[RTC_OBJC_TYPE(RTCRtpTransceiverInit) alloc] init]];
Steve Anton8cb344a2018-02-27 15:34:53 -0800479}
480
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200481- (RTC_OBJC_TYPE(RTCRtpTransceiver) *)
482 addTransceiverWithTrack:(RTC_OBJC_TYPE(RTCMediaStreamTrack) *)track
483 init:(RTC_OBJC_TYPE(RTCRtpTransceiverInit) *)init {
Steve Anton8cb344a2018-02-27 15:34:53 -0800484 webrtc::RTCErrorOr<rtc::scoped_refptr<webrtc::RtpTransceiverInterface>> nativeTransceiverOrError =
485 _peerConnection->AddTransceiver(track.nativeTrack, init.nativeInit);
486 if (!nativeTransceiverOrError.ok()) {
487 RTCLogError(
488 @"Failed to add transceiver %@: %s", track, nativeTransceiverOrError.error().message());
489 return nil;
490 }
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200491 return [[RTC_OBJC_TYPE(RTCRtpTransceiver) alloc]
492 initWithFactory:self.factory
493 nativeRtpTransceiver:nativeTransceiverOrError.MoveValue()];
Steve Anton8cb344a2018-02-27 15:34:53 -0800494}
495
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200496- (RTC_OBJC_TYPE(RTCRtpTransceiver) *)addTransceiverOfType:(RTCRtpMediaType)mediaType {
497 return [self addTransceiverOfType:mediaType
498 init:[[RTC_OBJC_TYPE(RTCRtpTransceiverInit) alloc] init]];
Steve Anton8cb344a2018-02-27 15:34:53 -0800499}
500
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200501- (RTC_OBJC_TYPE(RTCRtpTransceiver) *)addTransceiverOfType:(RTCRtpMediaType)mediaType
502 init:(RTC_OBJC_TYPE(RTCRtpTransceiverInit) *)
503 init {
Steve Anton8cb344a2018-02-27 15:34:53 -0800504 webrtc::RTCErrorOr<rtc::scoped_refptr<webrtc::RtpTransceiverInterface>> nativeTransceiverOrError =
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200505 _peerConnection->AddTransceiver(
506 [RTC_OBJC_TYPE(RTCRtpReceiver) nativeMediaTypeForMediaType:mediaType], init.nativeInit);
Steve Anton8cb344a2018-02-27 15:34:53 -0800507 if (!nativeTransceiverOrError.ok()) {
508 RTCLogError(@"Failed to add transceiver %@: %s",
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200509 [RTC_OBJC_TYPE(RTCRtpReceiver) stringForMediaType:mediaType],
Steve Anton8cb344a2018-02-27 15:34:53 -0800510 nativeTransceiverOrError.error().message());
511 return nil;
512 }
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200513 return [[RTC_OBJC_TYPE(RTCRtpTransceiver) alloc]
514 initWithFactory:self.factory
515 nativeRtpTransceiver:nativeTransceiverOrError.MoveValue()];
Steve Anton8cb344a2018-02-27 15:34:53 -0800516}
517
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200518- (void)offerForConstraints:(RTC_OBJC_TYPE(RTCMediaConstraints) *)constraints
519 completionHandler:(void (^)(RTC_OBJC_TYPE(RTCSessionDescription) * sessionDescription,
520 NSError *error))completionHandler {
hjonf396f602016-02-11 16:19:06 -0800521 rtc::scoped_refptr<webrtc::CreateSessionDescriptionObserverAdapter>
522 observer(new rtc::RefCountedObject
523 <webrtc::CreateSessionDescriptionObserverAdapter>(completionHandler));
Niels Möllerf06f9232018-08-07 12:32:18 +0200524 webrtc::PeerConnectionInterface::RTCOfferAnswerOptions options;
525 CopyConstraintsIntoOfferAnswerOptions(constraints.nativeConstraints.get(), &options);
526
527 _peerConnection->CreateOffer(observer, options);
hjonf396f602016-02-11 16:19:06 -0800528}
529
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200530- (void)answerForConstraints:(RTC_OBJC_TYPE(RTCMediaConstraints) *)constraints
531 completionHandler:(void (^)(RTC_OBJC_TYPE(RTCSessionDescription) * sessionDescription,
532 NSError *error))completionHandler {
hjonf396f602016-02-11 16:19:06 -0800533 rtc::scoped_refptr<webrtc::CreateSessionDescriptionObserverAdapter>
534 observer(new rtc::RefCountedObject
535 <webrtc::CreateSessionDescriptionObserverAdapter>(completionHandler));
Niels Möllerf06f9232018-08-07 12:32:18 +0200536 webrtc::PeerConnectionInterface::RTCOfferAnswerOptions options;
537 CopyConstraintsIntoOfferAnswerOptions(constraints.nativeConstraints.get(), &options);
538
539 _peerConnection->CreateAnswer(observer, options);
hjonf396f602016-02-11 16:19:06 -0800540}
541
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200542- (void)setLocalDescription:(RTC_OBJC_TYPE(RTCSessionDescription) *)sdp
hjonf396f602016-02-11 16:19:06 -0800543 completionHandler:(void (^)(NSError *error))completionHandler {
544 rtc::scoped_refptr<webrtc::SetSessionDescriptionObserverAdapter> observer(
545 new rtc::RefCountedObject<webrtc::SetSessionDescriptionObserverAdapter>(
546 completionHandler));
547 _peerConnection->SetLocalDescription(observer, sdp.nativeDescription);
548}
549
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200550- (void)setRemoteDescription:(RTC_OBJC_TYPE(RTCSessionDescription) *)sdp
hjonf396f602016-02-11 16:19:06 -0800551 completionHandler:(void (^)(NSError *error))completionHandler {
552 rtc::scoped_refptr<webrtc::SetSessionDescriptionObserverAdapter> observer(
553 new rtc::RefCountedObject<webrtc::SetSessionDescriptionObserverAdapter>(
554 completionHandler));
555 _peerConnection->SetRemoteDescription(observer, sdp.nativeDescription);
556}
557
zstein8b476172017-09-05 14:43:03 -0700558- (BOOL)setBweMinBitrateBps:(nullable NSNumber *)minBitrateBps
559 currentBitrateBps:(nullable NSNumber *)currentBitrateBps
560 maxBitrateBps:(nullable NSNumber *)maxBitrateBps {
Niels Möller9ad1f6f2020-07-13 10:25:41 +0200561 webrtc::BitrateSettings params;
zstein03adb7c2017-08-09 14:29:42 -0700562 if (minBitrateBps != nil) {
Danil Chapovalov196100e2018-06-21 10:17:24 +0200563 params.min_bitrate_bps = absl::optional<int>(minBitrateBps.intValue);
zstein03adb7c2017-08-09 14:29:42 -0700564 }
565 if (currentBitrateBps != nil) {
Niels Möller9ad1f6f2020-07-13 10:25:41 +0200566 params.start_bitrate_bps = absl::optional<int>(currentBitrateBps.intValue);
zstein03adb7c2017-08-09 14:29:42 -0700567 }
568 if (maxBitrateBps != nil) {
Danil Chapovalov196100e2018-06-21 10:17:24 +0200569 params.max_bitrate_bps = absl::optional<int>(maxBitrateBps.intValue);
zstein03adb7c2017-08-09 14:29:42 -0700570 }
571 return _peerConnection->SetBitrate(params).ok();
572}
573
ivoc14d5dbe2016-07-04 07:06:55 -0700574- (BOOL)startRtcEventLogWithFilePath:(NSString *)filePath
575 maxSizeInBytes:(int64_t)maxSizeInBytes {
576 RTC_DCHECK(filePath.length);
577 RTC_DCHECK_GT(maxSizeInBytes, 0);
578 RTC_DCHECK(!_hasStartedRtcEventLog);
579 if (_hasStartedRtcEventLog) {
580 RTCLogError(@"Event logging already started.");
581 return NO;
582 }
Niels Möllerdec9f742019-06-03 15:25:20 +0200583 FILE *f = fopen(filePath.UTF8String, "wb");
584 if (!f) {
ivoc14d5dbe2016-07-04 07:06:55 -0700585 RTCLogError(@"Error opening file: %@. Error: %d", filePath, errno);
586 return NO;
587 }
Niels Möller695cf6a2019-05-13 12:27:23 +0200588 // TODO(eladalon): It would be better to not allow negative values into PC.
589 const size_t max_size = (maxSizeInBytes < 0) ? webrtc::RtcEventLog::kUnlimitedOutput :
590 rtc::saturated_cast<size_t>(maxSizeInBytes);
591
592 _hasStartedRtcEventLog = _peerConnection->StartRtcEventLog(
Mirko Bonadei317a1f02019-09-17 17:06:18 +0200593 std::make_unique<webrtc::RtcEventLogOutputFile>(f, max_size));
ivoc14d5dbe2016-07-04 07:06:55 -0700594 return _hasStartedRtcEventLog;
595}
596
597- (void)stopRtcEventLog {
598 _peerConnection->StopRtcEventLog();
599 _hasStartedRtcEventLog = NO;
600}
601
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200602- (RTC_OBJC_TYPE(RTCRtpSender) *)senderWithKind:(NSString *)kind streamId:(NSString *)streamId {
skvladf3569c82016-04-29 15:30:16 -0700603 std::string nativeKind = [NSString stdStringForString:kind];
604 std::string nativeStreamId = [NSString stdStringForString:streamId];
605 rtc::scoped_refptr<webrtc::RtpSenderInterface> nativeSender(
606 _peerConnection->CreateSender(nativeKind, nativeStreamId));
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200607 return nativeSender ? [[RTC_OBJC_TYPE(RTCRtpSender) alloc] initWithFactory:self.factory
608 nativeRtpSender:nativeSender] :
609 nil;
skvladf3569c82016-04-29 15:30:16 -0700610}
611
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200612- (NSArray<RTC_OBJC_TYPE(RTCRtpSender) *> *)senders {
skvlad79b4b872016-04-08 17:28:55 -0700613 std::vector<rtc::scoped_refptr<webrtc::RtpSenderInterface>> nativeSenders(
614 _peerConnection->GetSenders());
615 NSMutableArray *senders = [[NSMutableArray alloc] init];
616 for (const auto &nativeSender : nativeSenders) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200617 RTC_OBJC_TYPE(RTCRtpSender) *sender =
618 [[RTC_OBJC_TYPE(RTCRtpSender) alloc] initWithFactory:self.factory
619 nativeRtpSender:nativeSender];
skvlad79b4b872016-04-08 17:28:55 -0700620 [senders addObject:sender];
621 }
622 return senders;
623}
624
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200625- (NSArray<RTC_OBJC_TYPE(RTCRtpReceiver) *> *)receivers {
Taylor Brandstetterdb0cd9e2016-05-16 11:40:30 -0700626 std::vector<rtc::scoped_refptr<webrtc::RtpReceiverInterface>> nativeReceivers(
627 _peerConnection->GetReceivers());
628 NSMutableArray *receivers = [[NSMutableArray alloc] init];
629 for (const auto &nativeReceiver : nativeReceivers) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200630 RTC_OBJC_TYPE(RTCRtpReceiver) *receiver =
631 [[RTC_OBJC_TYPE(RTCRtpReceiver) alloc] initWithFactory:self.factory
632 nativeRtpReceiver:nativeReceiver];
Taylor Brandstetterdb0cd9e2016-05-16 11:40:30 -0700633 [receivers addObject:receiver];
634 }
635 return receivers;
636}
637
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200638- (NSArray<RTC_OBJC_TYPE(RTCRtpTransceiver) *> *)transceivers {
Steve Anton8cb344a2018-02-27 15:34:53 -0800639 std::vector<rtc::scoped_refptr<webrtc::RtpTransceiverInterface>> nativeTransceivers(
640 _peerConnection->GetTransceivers());
641 NSMutableArray *transceivers = [[NSMutableArray alloc] init];
Mirko Bonadei739baf02019-01-27 17:29:42 +0100642 for (const auto &nativeTransceiver : nativeTransceivers) {
Mirko Bonadeia81e9c82020-05-04 16:14:32 +0200643 RTC_OBJC_TYPE(RTCRtpTransceiver) *transceiver =
644 [[RTC_OBJC_TYPE(RTCRtpTransceiver) alloc] initWithFactory:self.factory
645 nativeRtpTransceiver:nativeTransceiver];
Steve Anton8cb344a2018-02-27 15:34:53 -0800646 [transceivers addObject:transceiver];
647 }
648 return transceivers;
649}
650
hjonf396f602016-02-11 16:19:06 -0800651#pragma mark - Private
652
653+ (webrtc::PeerConnectionInterface::SignalingState)nativeSignalingStateForState:
654 (RTCSignalingState)state {
655 switch (state) {
656 case RTCSignalingStateStable:
657 return webrtc::PeerConnectionInterface::kStable;
658 case RTCSignalingStateHaveLocalOffer:
659 return webrtc::PeerConnectionInterface::kHaveLocalOffer;
660 case RTCSignalingStateHaveLocalPrAnswer:
661 return webrtc::PeerConnectionInterface::kHaveLocalPrAnswer;
662 case RTCSignalingStateHaveRemoteOffer:
663 return webrtc::PeerConnectionInterface::kHaveRemoteOffer;
664 case RTCSignalingStateHaveRemotePrAnswer:
665 return webrtc::PeerConnectionInterface::kHaveRemotePrAnswer;
666 case RTCSignalingStateClosed:
667 return webrtc::PeerConnectionInterface::kClosed;
668 }
669}
670
671+ (RTCSignalingState)signalingStateForNativeState:
672 (webrtc::PeerConnectionInterface::SignalingState)nativeState {
673 switch (nativeState) {
674 case webrtc::PeerConnectionInterface::kStable:
675 return RTCSignalingStateStable;
676 case webrtc::PeerConnectionInterface::kHaveLocalOffer:
677 return RTCSignalingStateHaveLocalOffer;
678 case webrtc::PeerConnectionInterface::kHaveLocalPrAnswer:
679 return RTCSignalingStateHaveLocalPrAnswer;
680 case webrtc::PeerConnectionInterface::kHaveRemoteOffer:
681 return RTCSignalingStateHaveRemoteOffer;
682 case webrtc::PeerConnectionInterface::kHaveRemotePrAnswer:
683 return RTCSignalingStateHaveRemotePrAnswer;
684 case webrtc::PeerConnectionInterface::kClosed:
685 return RTCSignalingStateClosed;
686 }
687}
688
689+ (NSString *)stringForSignalingState:(RTCSignalingState)state {
690 switch (state) {
691 case RTCSignalingStateStable:
692 return @"STABLE";
693 case RTCSignalingStateHaveLocalOffer:
694 return @"HAVE_LOCAL_OFFER";
695 case RTCSignalingStateHaveLocalPrAnswer:
696 return @"HAVE_LOCAL_PRANSWER";
697 case RTCSignalingStateHaveRemoteOffer:
698 return @"HAVE_REMOTE_OFFER";
699 case RTCSignalingStateHaveRemotePrAnswer:
700 return @"HAVE_REMOTE_PRANSWER";
701 case RTCSignalingStateClosed:
702 return @"CLOSED";
703 }
704}
705
Jonas Olssoncfddbb72018-11-15 16:52:45 +0100706+ (webrtc::PeerConnectionInterface::PeerConnectionState)nativeConnectionStateForState:
707 (RTCPeerConnectionState)state {
708 switch (state) {
709 case RTCPeerConnectionStateNew:
710 return webrtc::PeerConnectionInterface::PeerConnectionState::kNew;
711 case RTCPeerConnectionStateConnecting:
712 return webrtc::PeerConnectionInterface::PeerConnectionState::kConnecting;
713 case RTCPeerConnectionStateConnected:
714 return webrtc::PeerConnectionInterface::PeerConnectionState::kConnected;
715 case RTCPeerConnectionStateFailed:
716 return webrtc::PeerConnectionInterface::PeerConnectionState::kFailed;
717 case RTCPeerConnectionStateDisconnected:
718 return webrtc::PeerConnectionInterface::PeerConnectionState::kDisconnected;
719 case RTCPeerConnectionStateClosed:
720 return webrtc::PeerConnectionInterface::PeerConnectionState::kClosed;
721 }
722}
723
724+ (RTCPeerConnectionState)connectionStateForNativeState:
725 (webrtc::PeerConnectionInterface::PeerConnectionState)nativeState {
726 switch (nativeState) {
727 case webrtc::PeerConnectionInterface::PeerConnectionState::kNew:
728 return RTCPeerConnectionStateNew;
729 case webrtc::PeerConnectionInterface::PeerConnectionState::kConnecting:
730 return RTCPeerConnectionStateConnecting;
731 case webrtc::PeerConnectionInterface::PeerConnectionState::kConnected:
732 return RTCPeerConnectionStateConnected;
733 case webrtc::PeerConnectionInterface::PeerConnectionState::kFailed:
734 return RTCPeerConnectionStateFailed;
735 case webrtc::PeerConnectionInterface::PeerConnectionState::kDisconnected:
736 return RTCPeerConnectionStateDisconnected;
737 case webrtc::PeerConnectionInterface::PeerConnectionState::kClosed:
738 return RTCPeerConnectionStateClosed;
739 }
740}
741
742+ (NSString *)stringForConnectionState:(RTCPeerConnectionState)state {
743 switch (state) {
744 case RTCPeerConnectionStateNew:
745 return @"NEW";
746 case RTCPeerConnectionStateConnecting:
747 return @"CONNECTING";
748 case RTCPeerConnectionStateConnected:
749 return @"CONNECTED";
750 case RTCPeerConnectionStateFailed:
751 return @"FAILED";
752 case RTCPeerConnectionStateDisconnected:
753 return @"DISCONNECTED";
754 case RTCPeerConnectionStateClosed:
755 return @"CLOSED";
756 }
757}
758
hjonf396f602016-02-11 16:19:06 -0800759+ (webrtc::PeerConnectionInterface::IceConnectionState)
760 nativeIceConnectionStateForState:(RTCIceConnectionState)state {
761 switch (state) {
762 case RTCIceConnectionStateNew:
763 return webrtc::PeerConnectionInterface::kIceConnectionNew;
764 case RTCIceConnectionStateChecking:
765 return webrtc::PeerConnectionInterface::kIceConnectionChecking;
766 case RTCIceConnectionStateConnected:
767 return webrtc::PeerConnectionInterface::kIceConnectionConnected;
768 case RTCIceConnectionStateCompleted:
769 return webrtc::PeerConnectionInterface::kIceConnectionCompleted;
770 case RTCIceConnectionStateFailed:
771 return webrtc::PeerConnectionInterface::kIceConnectionFailed;
772 case RTCIceConnectionStateDisconnected:
773 return webrtc::PeerConnectionInterface::kIceConnectionDisconnected;
774 case RTCIceConnectionStateClosed:
775 return webrtc::PeerConnectionInterface::kIceConnectionClosed;
hjon8bbbf2c2016-03-14 13:15:44 -0700776 case RTCIceConnectionStateCount:
hjonf396f602016-02-11 16:19:06 -0800777 return webrtc::PeerConnectionInterface::kIceConnectionMax;
778 }
779}
780
781+ (RTCIceConnectionState)iceConnectionStateForNativeState:
782 (webrtc::PeerConnectionInterface::IceConnectionState)nativeState {
783 switch (nativeState) {
784 case webrtc::PeerConnectionInterface::kIceConnectionNew:
785 return RTCIceConnectionStateNew;
786 case webrtc::PeerConnectionInterface::kIceConnectionChecking:
787 return RTCIceConnectionStateChecking;
788 case webrtc::PeerConnectionInterface::kIceConnectionConnected:
789 return RTCIceConnectionStateConnected;
790 case webrtc::PeerConnectionInterface::kIceConnectionCompleted:
791 return RTCIceConnectionStateCompleted;
792 case webrtc::PeerConnectionInterface::kIceConnectionFailed:
793 return RTCIceConnectionStateFailed;
794 case webrtc::PeerConnectionInterface::kIceConnectionDisconnected:
795 return RTCIceConnectionStateDisconnected;
796 case webrtc::PeerConnectionInterface::kIceConnectionClosed:
797 return RTCIceConnectionStateClosed;
798 case webrtc::PeerConnectionInterface::kIceConnectionMax:
hjon8bbbf2c2016-03-14 13:15:44 -0700799 return RTCIceConnectionStateCount;
hjonf396f602016-02-11 16:19:06 -0800800 }
801}
802
803+ (NSString *)stringForIceConnectionState:(RTCIceConnectionState)state {
804 switch (state) {
805 case RTCIceConnectionStateNew:
806 return @"NEW";
807 case RTCIceConnectionStateChecking:
808 return @"CHECKING";
809 case RTCIceConnectionStateConnected:
810 return @"CONNECTED";
811 case RTCIceConnectionStateCompleted:
812 return @"COMPLETED";
813 case RTCIceConnectionStateFailed:
814 return @"FAILED";
815 case RTCIceConnectionStateDisconnected:
816 return @"DISCONNECTED";
817 case RTCIceConnectionStateClosed:
818 return @"CLOSED";
hjon8bbbf2c2016-03-14 13:15:44 -0700819 case RTCIceConnectionStateCount:
820 return @"COUNT";
hjonf396f602016-02-11 16:19:06 -0800821 }
822}
823
824+ (webrtc::PeerConnectionInterface::IceGatheringState)
825 nativeIceGatheringStateForState:(RTCIceGatheringState)state {
826 switch (state) {
827 case RTCIceGatheringStateNew:
828 return webrtc::PeerConnectionInterface::kIceGatheringNew;
829 case RTCIceGatheringStateGathering:
830 return webrtc::PeerConnectionInterface::kIceGatheringGathering;
831 case RTCIceGatheringStateComplete:
832 return webrtc::PeerConnectionInterface::kIceGatheringComplete;
833 }
834}
835
836+ (RTCIceGatheringState)iceGatheringStateForNativeState:
837 (webrtc::PeerConnectionInterface::IceGatheringState)nativeState {
838 switch (nativeState) {
839 case webrtc::PeerConnectionInterface::kIceGatheringNew:
840 return RTCIceGatheringStateNew;
841 case webrtc::PeerConnectionInterface::kIceGatheringGathering:
842 return RTCIceGatheringStateGathering;
843 case webrtc::PeerConnectionInterface::kIceGatheringComplete:
844 return RTCIceGatheringStateComplete;
845 }
846}
847
848+ (NSString *)stringForIceGatheringState:(RTCIceGatheringState)state {
849 switch (state) {
850 case RTCIceGatheringStateNew:
851 return @"NEW";
852 case RTCIceGatheringStateGathering:
853 return @"GATHERING";
854 case RTCIceGatheringStateComplete:
855 return @"COMPLETE";
856 }
857}
858
859+ (webrtc::PeerConnectionInterface::StatsOutputLevel)
860 nativeStatsOutputLevelForLevel:(RTCStatsOutputLevel)level {
861 switch (level) {
862 case RTCStatsOutputLevelStandard:
863 return webrtc::PeerConnectionInterface::kStatsOutputLevelStandard;
864 case RTCStatsOutputLevelDebug:
865 return webrtc::PeerConnectionInterface::kStatsOutputLevelDebug;
866 }
867}
868
hjonf396f602016-02-11 16:19:06 -0800869- (rtc::scoped_refptr<webrtc::PeerConnectionInterface>)nativePeerConnection {
870 return _peerConnection;
871}
872
873@end