Index: webrtc/sdk/objc/Framework/Classes/RTCPeerConnectionFactory.mm |
diff --git a/webrtc/sdk/objc/Framework/Classes/RTCPeerConnectionFactory.mm b/webrtc/sdk/objc/Framework/Classes/RTCPeerConnectionFactory.mm |
new file mode 100644 |
index 0000000000000000000000000000000000000000..18a707cf4c9987062272925f7e5e0eff4d85cd9b |
--- /dev/null |
+++ b/webrtc/sdk/objc/Framework/Classes/RTCPeerConnectionFactory.mm |
@@ -0,0 +1,144 @@ |
+/* |
+ * 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 "RTCPeerConnectionFactory+Private.h" |
+ |
+#import "NSString+StdString.h" |
+#import "RTCAVFoundationVideoSource+Private.h" |
+#import "RTCAudioSource+Private.h" |
+#import "RTCAudioTrack+Private.h" |
+#import "RTCMediaConstraints+Private.h" |
+#import "RTCMediaStream+Private.h" |
+#import "RTCPeerConnection+Private.h" |
+#import "RTCVideoSource+Private.h" |
+#import "RTCVideoTrack+Private.h" |
+#import "WebRTC/RTCLogging.h" |
+ |
+#include "objcvideotracksource.h" |
+#include "videotoolboxvideocodecfactory.h" |
+ |
+@implementation RTCPeerConnectionFactory { |
+ std::unique_ptr<rtc::Thread> _networkThread; |
+ std::unique_ptr<rtc::Thread> _workerThread; |
+ std::unique_ptr<rtc::Thread> _signalingThread; |
+ BOOL _hasStartedAecDump; |
+} |
+ |
+@synthesize nativeFactory = _nativeFactory; |
+ |
+- (instancetype)init { |
+ if ((self = [super init])) { |
+ _networkThread = rtc::Thread::CreateWithSocketServer(); |
+ BOOL result = _networkThread->Start(); |
+ NSAssert(result, @"Failed to start network thread."); |
+ |
+ _workerThread = rtc::Thread::Create(); |
+ result = _workerThread->Start(); |
+ NSAssert(result, @"Failed to start worker thread."); |
+ |
+ _signalingThread = rtc::Thread::Create(); |
+ result = _signalingThread->Start(); |
+ NSAssert(result, @"Failed to start signaling thread."); |
+ |
+ const auto encoder_factory = new webrtc::VideoToolboxVideoEncoderFactory(); |
+ const auto decoder_factory = new webrtc::VideoToolboxVideoDecoderFactory(); |
+ |
+ // Ownership of encoder/decoder factories is passed on to the |
+ // peerconnectionfactory, that handles deleting them. |
+ _nativeFactory = webrtc::CreatePeerConnectionFactory( |
+ _networkThread.get(), _workerThread.get(), _signalingThread.get(), |
+ nullptr, encoder_factory, decoder_factory); |
+ NSAssert(_nativeFactory, @"Failed to initialize PeerConnectionFactory!"); |
+ } |
+ return self; |
+} |
+ |
+- (RTCAudioSource *)audioSourceWithConstraints:(nullable RTCMediaConstraints *)constraints { |
+ std::unique_ptr<webrtc::MediaConstraints> nativeConstraints; |
+ if (constraints) { |
+ nativeConstraints = constraints.nativeConstraints; |
+ } |
+ rtc::scoped_refptr<webrtc::AudioSourceInterface> source = |
+ _nativeFactory->CreateAudioSource(nativeConstraints.get()); |
+ return [[RTCAudioSource alloc] initWithNativeAudioSource:source]; |
+} |
+ |
+- (RTCAudioTrack *)audioTrackWithTrackId:(NSString *)trackId { |
+ RTCAudioSource *audioSource = [self audioSourceWithConstraints:nil]; |
+ return [self audioTrackWithSource:audioSource trackId:trackId]; |
+} |
+ |
+- (RTCAudioTrack *)audioTrackWithSource:(RTCAudioSource *)source |
+ trackId:(NSString *)trackId { |
+ return [[RTCAudioTrack alloc] initWithFactory:self |
+ source:source |
+ trackId:trackId]; |
+} |
+ |
+- (RTCAVFoundationVideoSource *)avFoundationVideoSourceWithConstraints: |
+ (nullable RTCMediaConstraints *)constraints { |
+ return [[RTCAVFoundationVideoSource alloc] initWithFactory:self |
+ constraints:constraints]; |
+} |
+ |
+- (RTCVideoSource *)videoSource { |
+ rtc::scoped_refptr<webrtc::ObjcVideoTrackSource> objcVideoTrackSource( |
+ new rtc::RefCountedObject<webrtc::ObjcVideoTrackSource>()); |
+ return [[RTCVideoSource alloc] initWithNativeVideoSource:objcVideoTrackSource]; |
+} |
+ |
+- (RTCVideoTrack *)videoTrackWithSource:(RTCVideoSource *)source |
+ trackId:(NSString *)trackId { |
+ return [[RTCVideoTrack alloc] initWithFactory:self |
+ source:source |
+ trackId:trackId]; |
+} |
+ |
+- (RTCMediaStream *)mediaStreamWithStreamId:(NSString *)streamId { |
+ return [[RTCMediaStream alloc] initWithFactory:self |
+ streamId:streamId]; |
+} |
+ |
+- (RTCPeerConnection *)peerConnectionWithConfiguration: |
+ (RTCConfiguration *)configuration |
+ constraints: |
+ (RTCMediaConstraints *)constraints |
+ delegate: |
+ (nullable id<RTCPeerConnectionDelegate>)delegate { |
+ return [[RTCPeerConnection alloc] initWithFactory:self |
+ configuration:configuration |
+ constraints:constraints |
+ delegate:delegate]; |
+} |
+ |
+- (BOOL)startAecDumpWithFilePath:(NSString *)filePath |
+ maxSizeInBytes:(int64_t)maxSizeInBytes { |
+ RTC_DCHECK(filePath.length); |
+ RTC_DCHECK_GT(maxSizeInBytes, 0); |
+ |
+ if (_hasStartedAecDump) { |
+ RTCLogError(@"Aec dump already started."); |
+ return NO; |
+ } |
+ int fd = open(filePath.UTF8String, O_WRONLY | O_CREAT | O_TRUNC, S_IRUSR | S_IWUSR); |
+ if (fd < 0) { |
+ RTCLogError(@"Error opening file: %@. Error: %d", filePath, errno); |
+ return NO; |
+ } |
+ _hasStartedAecDump = _nativeFactory->StartAecDump(fd, maxSizeInBytes); |
+ return _hasStartedAecDump; |
+} |
+ |
+- (void)stopAecDump { |
+ _nativeFactory->StopAecDump(); |
+ _hasStartedAecDump = NO; |
+} |
+ |
+@end |