blob: b4a873847de5bda226a1c72d23a48b7eff97f1bb [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
13#import "NSString+StdString.h"
14#import "RTCConfiguration+Private.h"
15#import "RTCDataChannel+Private.h"
16#import "RTCIceCandidate+Private.h"
hbosbd3dda62016-09-09 01:36:28 -070017#import "RTCLegacyStatsReport+Private.h"
tkchin9eeb6242016-04-27 01:54:20 -070018#import "RTCMediaConstraints+Private.h"
19#import "RTCMediaStream+Private.h"
20#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"
23#import "RTCSessionDescription+Private.h"
tkchin9eeb6242016-04-27 01:54:20 -070024#import "WebRTC/RTCLogging.h"
hjonf396f602016-02-11 16:19:06 -080025
kwibergbfefb032016-05-01 14:53:46 -070026#include <memory>
27
Honghai Zhangda2ba4d2016-05-23 11:53:14 -070028#include "webrtc/api/jsepicecandidate.h"
hjonf396f602016-02-11 16:19:06 -080029#include "webrtc/base/checks.h"
30
hjonf396f602016-02-11 16:19:06 -080031NSString * const kRTCPeerConnectionErrorDomain =
32 @"org.webrtc.RTCPeerConnection";
33int const kRTCPeerConnnectionSessionDescriptionError = -1;
34
35namespace webrtc {
36
37class CreateSessionDescriptionObserverAdapter
38 : public CreateSessionDescriptionObserver {
39 public:
40 CreateSessionDescriptionObserverAdapter(
41 void (^completionHandler)(RTCSessionDescription *sessionDescription,
42 NSError *error)) {
43 completion_handler_ = completionHandler;
44 }
45
46 ~CreateSessionDescriptionObserverAdapter() {
47 completion_handler_ = nil;
48 }
49
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);
hjonf396f602016-02-11 16:19:06 -080054 RTCSessionDescription* session =
55 [[RTCSessionDescription alloc] initWithNativeDescription:
56 description.get()];
57 completion_handler_(session, nil);
58 completion_handler_ = nil;
59 }
60
61 void OnFailure(const std::string& error) override {
62 RTC_DCHECK(completion_handler_);
63 NSString* str = [NSString stringForStdString:error];
64 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:
73 void (^completion_handler_)
74 (RTCSessionDescription *sessionDescription, NSError *error);
75};
76
77class SetSessionDescriptionObserverAdapter :
78 public SetSessionDescriptionObserver {
79 public:
80 SetSessionDescriptionObserverAdapter(void (^completionHandler)
81 (NSError *error)) {
82 completion_handler_ = completionHandler;
83 }
84
85 ~SetSessionDescriptionObserverAdapter() {
86 completion_handler_ = nil;
87 }
88
89 void OnSuccess() override {
90 RTC_DCHECK(completion_handler_);
91 completion_handler_(nil);
92 completion_handler_ = nil;
93 }
94
95 void OnFailure(const std::string& error) override {
96 RTC_DCHECK(completion_handler_);
97 NSString* str = [NSString stringForStdString:error];
98 NSError* err =
99 [NSError errorWithDomain:kRTCPeerConnectionErrorDomain
100 code:kRTCPeerConnnectionSessionDescriptionError
101 userInfo:@{ NSLocalizedDescriptionKey : str }];
102 completion_handler_(err);
103 completion_handler_ = nil;
104 }
105
106 private:
107 void (^completion_handler_)(NSError *error);
108};
109
110PeerConnectionDelegateAdapter::PeerConnectionDelegateAdapter(
111 RTCPeerConnection *peerConnection) {
112 peer_connection_ = peerConnection;
113}
114
115PeerConnectionDelegateAdapter::~PeerConnectionDelegateAdapter() {
116 peer_connection_ = nil;
117}
118
119void PeerConnectionDelegateAdapter::OnSignalingChange(
120 PeerConnectionInterface::SignalingState new_state) {
121 RTCSignalingState state =
122 [[RTCPeerConnection class] signalingStateForNativeState:new_state];
123 RTCPeerConnection *peer_connection = peer_connection_;
124 [peer_connection.delegate peerConnection:peer_connection
125 didChangeSignalingState:state];
126}
127
128void PeerConnectionDelegateAdapter::OnAddStream(
deadbeefd5f41ce2016-06-08 13:31:45 -0700129 rtc::scoped_refptr<MediaStreamInterface> stream) {
hjonf396f602016-02-11 16:19:06 -0800130 RTCMediaStream *mediaStream =
131 [[RTCMediaStream alloc] initWithNativeMediaStream:stream];
132 RTCPeerConnection *peer_connection = peer_connection_;
133 [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) {
hjonf396f602016-02-11 16:19:06 -0800139 RTCMediaStream *mediaStream =
140 [[RTCMediaStream alloc] initWithNativeMediaStream:stream];
141 RTCPeerConnection *peer_connection = peer_connection_;
142 [peer_connection.delegate peerConnection:peer_connection
143 didRemoveStream:mediaStream];
144}
145
146void PeerConnectionDelegateAdapter::OnDataChannel(
deadbeefd5f41ce2016-06-08 13:31:45 -0700147 rtc::scoped_refptr<DataChannelInterface> data_channel) {
hjonf396f602016-02-11 16:19:06 -0800148 RTCDataChannel *dataChannel =
149 [[RTCDataChannel alloc] initWithNativeDataChannel:data_channel];
150 RTCPeerConnection *peer_connection = peer_connection_;
151 [peer_connection.delegate peerConnection:peer_connection
152 didOpenDataChannel:dataChannel];
153}
154
155void PeerConnectionDelegateAdapter::OnRenegotiationNeeded() {
156 RTCPeerConnection *peer_connection = peer_connection_;
157 [peer_connection.delegate peerConnectionShouldNegotiate:peer_connection];
158}
159
160void PeerConnectionDelegateAdapter::OnIceConnectionChange(
161 PeerConnectionInterface::IceConnectionState new_state) {
162 RTCIceConnectionState state =
163 [[RTCPeerConnection class] iceConnectionStateForNativeState:new_state];
164 RTCPeerConnection *peer_connection = peer_connection_;
165 [peer_connection.delegate peerConnection:peer_connection
166 didChangeIceConnectionState:state];
167}
168
169void PeerConnectionDelegateAdapter::OnIceGatheringChange(
170 PeerConnectionInterface::IceGatheringState new_state) {
171 RTCIceGatheringState state =
172 [[RTCPeerConnection class] iceGatheringStateForNativeState:new_state];
173 RTCPeerConnection *peer_connection = peer_connection_;
174 [peer_connection.delegate peerConnection:peer_connection
175 didChangeIceGatheringState:state];
176}
177
178void PeerConnectionDelegateAdapter::OnIceCandidate(
179 const IceCandidateInterface *candidate) {
180 RTCIceCandidate *iceCandidate =
181 [[RTCIceCandidate alloc] initWithNativeCandidate:candidate];
182 RTCPeerConnection *peer_connection = peer_connection_;
183 [peer_connection.delegate peerConnection:peer_connection
184 didGenerateIceCandidate:iceCandidate];
185}
Honghai Zhangda2ba4d2016-05-23 11:53:14 -0700186
187void PeerConnectionDelegateAdapter::OnIceCandidatesRemoved(
188 const std::vector<cricket::Candidate>& candidates) {
189 NSMutableArray* ice_candidates =
190 [NSMutableArray arrayWithCapacity:candidates.size()];
191 for (const auto& candidate : candidates) {
192 std::unique_ptr<JsepIceCandidate> candidate_wrapper(
193 new JsepIceCandidate(candidate.transport_name(), -1, candidate));
194 RTCIceCandidate* ice_candidate = [[RTCIceCandidate alloc]
195 initWithNativeCandidate:candidate_wrapper.get()];
196 [ice_candidates addObject:ice_candidate];
197 }
198 RTCPeerConnection* peer_connection = peer_connection_;
199 [peer_connection.delegate peerConnection:peer_connection
200 didRemoveIceCandidates:ice_candidates];
201}
202
hjonf396f602016-02-11 16:19:06 -0800203} // namespace webrtc
204
205
206@implementation RTCPeerConnection {
vopatop.skam96b6b832016-08-18 14:21:20 -0700207 NSMutableArray<RTCMediaStream *> *_localStreams;
kwibergbfefb032016-05-01 14:53:46 -0700208 std::unique_ptr<webrtc::PeerConnectionDelegateAdapter> _observer;
hjonf396f602016-02-11 16:19:06 -0800209 rtc::scoped_refptr<webrtc::PeerConnectionInterface> _peerConnection;
ivoc14d5dbe2016-07-04 07:06:55 -0700210 BOOL _hasStartedRtcEventLog;
hjonf396f602016-02-11 16:19:06 -0800211}
212
213@synthesize delegate = _delegate;
214
215- (instancetype)initWithFactory:(RTCPeerConnectionFactory *)factory
216 configuration:(RTCConfiguration *)configuration
217 constraints:(RTCMediaConstraints *)constraints
218 delegate:(id<RTCPeerConnectionDelegate>)delegate {
219 NSParameterAssert(factory);
Henrik Boströme06c2dd2016-05-13 13:50:38 +0200220 std::unique_ptr<webrtc::PeerConnectionInterface::RTCConfiguration> config(
hbosa73ca562016-05-17 03:28:58 -0700221 [configuration createNativeConfiguration]);
222 if (!config) {
223 return nil;
224 }
hjonf396f602016-02-11 16:19:06 -0800225 if (self = [super init]) {
226 _observer.reset(new webrtc::PeerConnectionDelegateAdapter(self));
kwibergbfefb032016-05-01 14:53:46 -0700227 std::unique_ptr<webrtc::MediaConstraints> nativeConstraints =
hjona2f77982016-03-04 07:09:09 -0800228 constraints.nativeConstraints;
hjonf396f602016-02-11 16:19:06 -0800229 _peerConnection =
hbosd7973cc2016-05-27 06:08:53 -0700230 factory.nativeFactory->CreatePeerConnection(*config,
231 nativeConstraints.get(),
232 nullptr,
233 nullptr,
234 _observer.get());
skvlad588783a2016-08-11 14:29:25 -0700235 if (!_peerConnection) {
236 return nil;
237 }
hjonf396f602016-02-11 16:19:06 -0800238 _localStreams = [[NSMutableArray alloc] init];
239 _delegate = delegate;
240 }
241 return self;
242}
243
vopatop.skam96b6b832016-08-18 14:21:20 -0700244- (NSArray<RTCMediaStream *> *)localStreams {
hjonf396f602016-02-11 16:19:06 -0800245 return [_localStreams copy];
246}
247
248- (RTCSessionDescription *)localDescription {
249 const webrtc::SessionDescriptionInterface *description =
250 _peerConnection->local_description();
251 return description ?
252 [[RTCSessionDescription alloc] initWithNativeDescription:description]
253 : nil;
254}
255
256- (RTCSessionDescription *)remoteDescription {
257 const webrtc::SessionDescriptionInterface *description =
258 _peerConnection->remote_description();
259 return description ?
260 [[RTCSessionDescription alloc] initWithNativeDescription:description]
261 : nil;
262}
263
264- (RTCSignalingState)signalingState {
265 return [[self class]
266 signalingStateForNativeState:_peerConnection->signaling_state()];
267}
268
269- (RTCIceConnectionState)iceConnectionState {
270 return [[self class] iceConnectionStateForNativeState:
271 _peerConnection->ice_connection_state()];
272}
273
274- (RTCIceGatheringState)iceGatheringState {
275 return [[self class] iceGatheringStateForNativeState:
276 _peerConnection->ice_gathering_state()];
277}
278
tkchinaac3eb22016-03-09 21:49:40 -0800279- (BOOL)setConfiguration:(RTCConfiguration *)configuration {
Henrik Boströme06c2dd2016-05-13 13:50:38 +0200280 std::unique_ptr<webrtc::PeerConnectionInterface::RTCConfiguration> config(
hbosa73ca562016-05-17 03:28:58 -0700281 [configuration createNativeConfiguration]);
282 if (!config) {
283 return NO;
284 }
Henrik Boströme06c2dd2016-05-13 13:50:38 +0200285 return _peerConnection->SetConfiguration(*config);
tkchinaac3eb22016-03-09 21:49:40 -0800286}
287
hjonf396f602016-02-11 16:19:06 -0800288- (void)close {
289 _peerConnection->Close();
290}
291
292- (void)addIceCandidate:(RTCIceCandidate *)candidate {
kwibergbfefb032016-05-01 14:53:46 -0700293 std::unique_ptr<const webrtc::IceCandidateInterface> iceCandidate(
hjonf396f602016-02-11 16:19:06 -0800294 candidate.nativeCandidate);
295 _peerConnection->AddIceCandidate(iceCandidate.get());
296}
297
Honghai Zhangda2ba4d2016-05-23 11:53:14 -0700298- (void)removeIceCandidates:(NSArray<RTCIceCandidate *> *)iceCandidates {
299 std::vector<cricket::Candidate> candidates;
300 for (RTCIceCandidate *iceCandidate in iceCandidates) {
301 std::unique_ptr<const webrtc::IceCandidateInterface> candidate(
302 iceCandidate.nativeCandidate);
303 if (candidate) {
304 candidates.push_back(candidate->candidate());
305 // Need to fill the transport name from the sdp_mid.
306 candidates.back().set_transport_name(candidate->sdp_mid());
307 }
308 }
309 if (!candidates.empty()) {
310 _peerConnection->RemoveIceCandidates(candidates);
311 }
312}
313
hjonf396f602016-02-11 16:19:06 -0800314- (void)addStream:(RTCMediaStream *)stream {
hjona2f77982016-03-04 07:09:09 -0800315 if (!_peerConnection->AddStream(stream.nativeMediaStream)) {
hjonf396f602016-02-11 16:19:06 -0800316 RTCLogError(@"Failed to add stream: %@", stream);
317 return;
318 }
319 [_localStreams addObject:stream];
320}
321
322- (void)removeStream:(RTCMediaStream *)stream {
323 _peerConnection->RemoveStream(stream.nativeMediaStream);
324 [_localStreams removeObject:stream];
325}
326
327- (void)offerForConstraints:(RTCMediaConstraints *)constraints
328 completionHandler:
329 (void (^)(RTCSessionDescription *sessionDescription,
330 NSError *error))completionHandler {
331 rtc::scoped_refptr<webrtc::CreateSessionDescriptionObserverAdapter>
332 observer(new rtc::RefCountedObject
333 <webrtc::CreateSessionDescriptionObserverAdapter>(completionHandler));
334 _peerConnection->CreateOffer(observer, constraints.nativeConstraints.get());
335}
336
337- (void)answerForConstraints:(RTCMediaConstraints *)constraints
338 completionHandler:
339 (void (^)(RTCSessionDescription *sessionDescription,
340 NSError *error))completionHandler {
341 rtc::scoped_refptr<webrtc::CreateSessionDescriptionObserverAdapter>
342 observer(new rtc::RefCountedObject
343 <webrtc::CreateSessionDescriptionObserverAdapter>(completionHandler));
344 _peerConnection->CreateAnswer(observer, constraints.nativeConstraints.get());
345}
346
347- (void)setLocalDescription:(RTCSessionDescription *)sdp
348 completionHandler:(void (^)(NSError *error))completionHandler {
349 rtc::scoped_refptr<webrtc::SetSessionDescriptionObserverAdapter> observer(
350 new rtc::RefCountedObject<webrtc::SetSessionDescriptionObserverAdapter>(
351 completionHandler));
352 _peerConnection->SetLocalDescription(observer, sdp.nativeDescription);
353}
354
355- (void)setRemoteDescription:(RTCSessionDescription *)sdp
356 completionHandler:(void (^)(NSError *error))completionHandler {
357 rtc::scoped_refptr<webrtc::SetSessionDescriptionObserverAdapter> observer(
358 new rtc::RefCountedObject<webrtc::SetSessionDescriptionObserverAdapter>(
359 completionHandler));
360 _peerConnection->SetRemoteDescription(observer, sdp.nativeDescription);
361}
362
ivoc14d5dbe2016-07-04 07:06:55 -0700363- (BOOL)startRtcEventLogWithFilePath:(NSString *)filePath
364 maxSizeInBytes:(int64_t)maxSizeInBytes {
365 RTC_DCHECK(filePath.length);
366 RTC_DCHECK_GT(maxSizeInBytes, 0);
367 RTC_DCHECK(!_hasStartedRtcEventLog);
368 if (_hasStartedRtcEventLog) {
369 RTCLogError(@"Event logging already started.");
370 return NO;
371 }
372 int fd = open(filePath.UTF8String, O_WRONLY | O_CREAT | O_TRUNC,
373 S_IRUSR | S_IWUSR);
374 if (fd < 0) {
375 RTCLogError(@"Error opening file: %@. Error: %d", filePath, errno);
376 return NO;
377 }
378 _hasStartedRtcEventLog =
379 _peerConnection->StartRtcEventLog(fd, maxSizeInBytes);
380 return _hasStartedRtcEventLog;
381}
382
383- (void)stopRtcEventLog {
384 _peerConnection->StopRtcEventLog();
385 _hasStartedRtcEventLog = NO;
386}
387
skvladf3569c82016-04-29 15:30:16 -0700388- (RTCRtpSender *)senderWithKind:(NSString *)kind
389 streamId:(NSString *)streamId {
390 std::string nativeKind = [NSString stdStringForString:kind];
391 std::string nativeStreamId = [NSString stdStringForString:streamId];
392 rtc::scoped_refptr<webrtc::RtpSenderInterface> nativeSender(
393 _peerConnection->CreateSender(nativeKind, nativeStreamId));
394 return nativeSender ?
395 [[RTCRtpSender alloc] initWithNativeRtpSender:nativeSender]
396 : nil;
397}
398
skvlad79b4b872016-04-08 17:28:55 -0700399- (NSArray<RTCRtpSender *> *)senders {
400 std::vector<rtc::scoped_refptr<webrtc::RtpSenderInterface>> nativeSenders(
401 _peerConnection->GetSenders());
402 NSMutableArray *senders = [[NSMutableArray alloc] init];
403 for (const auto &nativeSender : nativeSenders) {
404 RTCRtpSender *sender =
405 [[RTCRtpSender alloc] initWithNativeRtpSender:nativeSender];
406 [senders addObject:sender];
407 }
408 return senders;
409}
410
Taylor Brandstetterdb0cd9e2016-05-16 11:40:30 -0700411- (NSArray<RTCRtpReceiver *> *)receivers {
412 std::vector<rtc::scoped_refptr<webrtc::RtpReceiverInterface>> nativeReceivers(
413 _peerConnection->GetReceivers());
414 NSMutableArray *receivers = [[NSMutableArray alloc] init];
415 for (const auto &nativeReceiver : nativeReceivers) {
416 RTCRtpReceiver *receiver =
417 [[RTCRtpReceiver alloc] initWithNativeRtpReceiver:nativeReceiver];
418 [receivers addObject:receiver];
419 }
420 return receivers;
421}
422
hjonf396f602016-02-11 16:19:06 -0800423#pragma mark - Private
424
425+ (webrtc::PeerConnectionInterface::SignalingState)nativeSignalingStateForState:
426 (RTCSignalingState)state {
427 switch (state) {
428 case RTCSignalingStateStable:
429 return webrtc::PeerConnectionInterface::kStable;
430 case RTCSignalingStateHaveLocalOffer:
431 return webrtc::PeerConnectionInterface::kHaveLocalOffer;
432 case RTCSignalingStateHaveLocalPrAnswer:
433 return webrtc::PeerConnectionInterface::kHaveLocalPrAnswer;
434 case RTCSignalingStateHaveRemoteOffer:
435 return webrtc::PeerConnectionInterface::kHaveRemoteOffer;
436 case RTCSignalingStateHaveRemotePrAnswer:
437 return webrtc::PeerConnectionInterface::kHaveRemotePrAnswer;
438 case RTCSignalingStateClosed:
439 return webrtc::PeerConnectionInterface::kClosed;
440 }
441}
442
443+ (RTCSignalingState)signalingStateForNativeState:
444 (webrtc::PeerConnectionInterface::SignalingState)nativeState {
445 switch (nativeState) {
446 case webrtc::PeerConnectionInterface::kStable:
447 return RTCSignalingStateStable;
448 case webrtc::PeerConnectionInterface::kHaveLocalOffer:
449 return RTCSignalingStateHaveLocalOffer;
450 case webrtc::PeerConnectionInterface::kHaveLocalPrAnswer:
451 return RTCSignalingStateHaveLocalPrAnswer;
452 case webrtc::PeerConnectionInterface::kHaveRemoteOffer:
453 return RTCSignalingStateHaveRemoteOffer;
454 case webrtc::PeerConnectionInterface::kHaveRemotePrAnswer:
455 return RTCSignalingStateHaveRemotePrAnswer;
456 case webrtc::PeerConnectionInterface::kClosed:
457 return RTCSignalingStateClosed;
458 }
459}
460
461+ (NSString *)stringForSignalingState:(RTCSignalingState)state {
462 switch (state) {
463 case RTCSignalingStateStable:
464 return @"STABLE";
465 case RTCSignalingStateHaveLocalOffer:
466 return @"HAVE_LOCAL_OFFER";
467 case RTCSignalingStateHaveLocalPrAnswer:
468 return @"HAVE_LOCAL_PRANSWER";
469 case RTCSignalingStateHaveRemoteOffer:
470 return @"HAVE_REMOTE_OFFER";
471 case RTCSignalingStateHaveRemotePrAnswer:
472 return @"HAVE_REMOTE_PRANSWER";
473 case RTCSignalingStateClosed:
474 return @"CLOSED";
475 }
476}
477
478+ (webrtc::PeerConnectionInterface::IceConnectionState)
479 nativeIceConnectionStateForState:(RTCIceConnectionState)state {
480 switch (state) {
481 case RTCIceConnectionStateNew:
482 return webrtc::PeerConnectionInterface::kIceConnectionNew;
483 case RTCIceConnectionStateChecking:
484 return webrtc::PeerConnectionInterface::kIceConnectionChecking;
485 case RTCIceConnectionStateConnected:
486 return webrtc::PeerConnectionInterface::kIceConnectionConnected;
487 case RTCIceConnectionStateCompleted:
488 return webrtc::PeerConnectionInterface::kIceConnectionCompleted;
489 case RTCIceConnectionStateFailed:
490 return webrtc::PeerConnectionInterface::kIceConnectionFailed;
491 case RTCIceConnectionStateDisconnected:
492 return webrtc::PeerConnectionInterface::kIceConnectionDisconnected;
493 case RTCIceConnectionStateClosed:
494 return webrtc::PeerConnectionInterface::kIceConnectionClosed;
hjon8bbbf2c2016-03-14 13:15:44 -0700495 case RTCIceConnectionStateCount:
hjonf396f602016-02-11 16:19:06 -0800496 return webrtc::PeerConnectionInterface::kIceConnectionMax;
497 }
498}
499
500+ (RTCIceConnectionState)iceConnectionStateForNativeState:
501 (webrtc::PeerConnectionInterface::IceConnectionState)nativeState {
502 switch (nativeState) {
503 case webrtc::PeerConnectionInterface::kIceConnectionNew:
504 return RTCIceConnectionStateNew;
505 case webrtc::PeerConnectionInterface::kIceConnectionChecking:
506 return RTCIceConnectionStateChecking;
507 case webrtc::PeerConnectionInterface::kIceConnectionConnected:
508 return RTCIceConnectionStateConnected;
509 case webrtc::PeerConnectionInterface::kIceConnectionCompleted:
510 return RTCIceConnectionStateCompleted;
511 case webrtc::PeerConnectionInterface::kIceConnectionFailed:
512 return RTCIceConnectionStateFailed;
513 case webrtc::PeerConnectionInterface::kIceConnectionDisconnected:
514 return RTCIceConnectionStateDisconnected;
515 case webrtc::PeerConnectionInterface::kIceConnectionClosed:
516 return RTCIceConnectionStateClosed;
517 case webrtc::PeerConnectionInterface::kIceConnectionMax:
hjon8bbbf2c2016-03-14 13:15:44 -0700518 return RTCIceConnectionStateCount;
hjonf396f602016-02-11 16:19:06 -0800519 }
520}
521
522+ (NSString *)stringForIceConnectionState:(RTCIceConnectionState)state {
523 switch (state) {
524 case RTCIceConnectionStateNew:
525 return @"NEW";
526 case RTCIceConnectionStateChecking:
527 return @"CHECKING";
528 case RTCIceConnectionStateConnected:
529 return @"CONNECTED";
530 case RTCIceConnectionStateCompleted:
531 return @"COMPLETED";
532 case RTCIceConnectionStateFailed:
533 return @"FAILED";
534 case RTCIceConnectionStateDisconnected:
535 return @"DISCONNECTED";
536 case RTCIceConnectionStateClosed:
537 return @"CLOSED";
hjon8bbbf2c2016-03-14 13:15:44 -0700538 case RTCIceConnectionStateCount:
539 return @"COUNT";
hjonf396f602016-02-11 16:19:06 -0800540 }
541}
542
543+ (webrtc::PeerConnectionInterface::IceGatheringState)
544 nativeIceGatheringStateForState:(RTCIceGatheringState)state {
545 switch (state) {
546 case RTCIceGatheringStateNew:
547 return webrtc::PeerConnectionInterface::kIceGatheringNew;
548 case RTCIceGatheringStateGathering:
549 return webrtc::PeerConnectionInterface::kIceGatheringGathering;
550 case RTCIceGatheringStateComplete:
551 return webrtc::PeerConnectionInterface::kIceGatheringComplete;
552 }
553}
554
555+ (RTCIceGatheringState)iceGatheringStateForNativeState:
556 (webrtc::PeerConnectionInterface::IceGatheringState)nativeState {
557 switch (nativeState) {
558 case webrtc::PeerConnectionInterface::kIceGatheringNew:
559 return RTCIceGatheringStateNew;
560 case webrtc::PeerConnectionInterface::kIceGatheringGathering:
561 return RTCIceGatheringStateGathering;
562 case webrtc::PeerConnectionInterface::kIceGatheringComplete:
563 return RTCIceGatheringStateComplete;
564 }
565}
566
567+ (NSString *)stringForIceGatheringState:(RTCIceGatheringState)state {
568 switch (state) {
569 case RTCIceGatheringStateNew:
570 return @"NEW";
571 case RTCIceGatheringStateGathering:
572 return @"GATHERING";
573 case RTCIceGatheringStateComplete:
574 return @"COMPLETE";
575 }
576}
577
578+ (webrtc::PeerConnectionInterface::StatsOutputLevel)
579 nativeStatsOutputLevelForLevel:(RTCStatsOutputLevel)level {
580 switch (level) {
581 case RTCStatsOutputLevelStandard:
582 return webrtc::PeerConnectionInterface::kStatsOutputLevelStandard;
583 case RTCStatsOutputLevelDebug:
584 return webrtc::PeerConnectionInterface::kStatsOutputLevelDebug;
585 }
586}
587
588- (rtc::scoped_refptr<webrtc::PeerConnectionInterface>)nativePeerConnection {
589 return _peerConnection;
590}
591
592@end