mirror of
https://github.com/mollyim/webrtc.git
synced 2025-05-16 15:20:42 +01:00

This reverts commit 586725dc9a
.
Reason for revert: misses a check to see if the optional callback is implemented.
Original change's description:
> Add ios bindings for PeerConnectionState.
>
> This change makes it possible for ios apps to use the new standards-compliant PeerConnectionState.
>
> Bug: webrtc:9977
> Change-Id: Icf69bb1faa0383ae239cb7508f2a740a2d489697
> Reviewed-on: https://webrtc-review.googlesource.com/c/110502
> Commit-Queue: Jonas Olsson <jonasolsson@webrtc.org>
> Reviewed-by: Kári Helgason <kthelgason@webrtc.org>
> Cr-Commit-Position: refs/heads/master@{#25651}
TBR=kthelgason@webrtc.org,jonasolsson@webrtc.org
Change-Id: Iff919e9876e6b8dddc6d8ab7df302081d0cfa917
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: webrtc:9977
Reviewed-on: https://webrtc-review.googlesource.com/c/111062
Reviewed-by: Jonas Olsson <jonasolsson@webrtc.org>
Commit-Queue: Jonas Olsson <jonasolsson@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#25659}
106 lines
3.8 KiB
Objective-C
106 lines
3.8 KiB
Objective-C
/*
|
|
* Copyright 2015 The WebRTC project authors. All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#import "RTCPeerConnection.h"
|
|
|
|
#include "api/peerconnectioninterface.h"
|
|
|
|
NS_ASSUME_NONNULL_BEGIN
|
|
|
|
namespace webrtc {
|
|
|
|
/**
|
|
* These objects are created by RTCPeerConnectionFactory to wrap an
|
|
* id<RTCPeerConnectionDelegate> and call methods on that interface.
|
|
*/
|
|
class PeerConnectionDelegateAdapter : public PeerConnectionObserver {
|
|
public:
|
|
PeerConnectionDelegateAdapter(RTCPeerConnection *peerConnection);
|
|
~PeerConnectionDelegateAdapter() override;
|
|
|
|
void OnSignalingChange(PeerConnectionInterface::SignalingState new_state) override;
|
|
|
|
void OnAddStream(rtc::scoped_refptr<MediaStreamInterface> stream) override;
|
|
|
|
void OnRemoveStream(rtc::scoped_refptr<MediaStreamInterface> stream) override;
|
|
|
|
void OnTrack(rtc::scoped_refptr<RtpTransceiverInterface> transceiver) override;
|
|
|
|
void OnDataChannel(rtc::scoped_refptr<DataChannelInterface> data_channel) override;
|
|
|
|
void OnRenegotiationNeeded() override;
|
|
|
|
void OnIceConnectionChange(PeerConnectionInterface::IceConnectionState new_state) override;
|
|
|
|
void OnIceGatheringChange(PeerConnectionInterface::IceGatheringState new_state) override;
|
|
|
|
void OnIceCandidate(const IceCandidateInterface *candidate) override;
|
|
|
|
void OnIceCandidatesRemoved(const std::vector<cricket::Candidate> &candidates) override;
|
|
|
|
void OnAddTrack(rtc::scoped_refptr<RtpReceiverInterface> receiver,
|
|
const std::vector<rtc::scoped_refptr<MediaStreamInterface>> &streams) override;
|
|
|
|
void OnRemoveTrack(rtc::scoped_refptr<RtpReceiverInterface> receiver) override;
|
|
|
|
private:
|
|
__weak RTCPeerConnection *peer_connection_;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
@interface RTCPeerConnection ()
|
|
|
|
/** The factory used to create this RTCPeerConnection */
|
|
@property(nonatomic, readonly) RTCPeerConnectionFactory *factory;
|
|
|
|
/** The native PeerConnectionInterface created during construction. */
|
|
@property(nonatomic, readonly) rtc::scoped_refptr<webrtc::PeerConnectionInterface>
|
|
nativePeerConnection;
|
|
|
|
/** Initialize an RTCPeerConnection with a configuration, constraints, and
|
|
* delegate.
|
|
*/
|
|
- (instancetype)initWithFactory:(RTCPeerConnectionFactory *)factory
|
|
configuration:(RTCConfiguration *)configuration
|
|
constraints:(RTCMediaConstraints *)constraints
|
|
delegate:(nullable id<RTCPeerConnectionDelegate>)delegate
|
|
NS_DESIGNATED_INITIALIZER;
|
|
|
|
+ (webrtc::PeerConnectionInterface::SignalingState)nativeSignalingStateForState:
|
|
(RTCSignalingState)state;
|
|
|
|
+ (RTCSignalingState)signalingStateForNativeState:
|
|
(webrtc::PeerConnectionInterface::SignalingState)nativeState;
|
|
|
|
+ (NSString *)stringForSignalingState:(RTCSignalingState)state;
|
|
|
|
+ (webrtc::PeerConnectionInterface::IceConnectionState)nativeIceConnectionStateForState:
|
|
(RTCIceConnectionState)state;
|
|
|
|
+ (RTCIceConnectionState)iceConnectionStateForNativeState:
|
|
(webrtc::PeerConnectionInterface::IceConnectionState)nativeState;
|
|
|
|
+ (NSString *)stringForIceConnectionState:(RTCIceConnectionState)state;
|
|
|
|
+ (webrtc::PeerConnectionInterface::IceGatheringState)nativeIceGatheringStateForState:
|
|
(RTCIceGatheringState)state;
|
|
|
|
+ (RTCIceGatheringState)iceGatheringStateForNativeState:
|
|
(webrtc::PeerConnectionInterface::IceGatheringState)nativeState;
|
|
|
|
+ (NSString *)stringForIceGatheringState:(RTCIceGatheringState)state;
|
|
|
|
+ (webrtc::PeerConnectionInterface::StatsOutputLevel)nativeStatsOutputLevelForLevel:
|
|
(RTCStatsOutputLevel)level;
|
|
|
|
@end
|
|
|
|
NS_ASSUME_NONNULL_END
|