blob: 52d1f82babe64cd271e2d8e82487b0ea29fbd1b1 [file] [log] [blame]
henrike@webrtc.org28e20752013-07-10 00:45:36 +00001/*
kjellanderb24317b2016-02-10 07:54:43 -08002 * Copyright 2004 The WebRTC project authors. All Rights Reserved.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00003 *
kjellanderb24317b2016-02-10 07:54:43 -08004 * 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.
henrike@webrtc.org28e20752013-07-10 00:45:36 +00009 */
10
Steve Anton10542f22019-01-11 09:11:00 -080011#include "pc/peer_connection_factory.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000012
Ying Wang0810a7c2019-04-10 13:48:24 +020013#include <memory>
kwiberg0eb15ed2015-12-17 03:04:15 -080014#include <utility>
Florent Castelli72b751a2018-06-28 14:09:33 +020015#include <vector>
kwiberg0eb15ed2015-12-17 03:04:15 -080016
Karl Wiberg918f50c2018-07-05 11:40:33 +020017#include "absl/memory/memory.h"
Ying Wang0dd1b0a2018-02-20 12:50:27 +010018#include "api/fec_controller.h"
Steve Anton10542f22019-01-11 09:11:00 -080019#include "api/media_stream_proxy.h"
20#include "api/media_stream_track_proxy.h"
Piotr (Peter) Slatalae0c2e972018-10-08 09:43:21 -070021#include "api/media_transport_interface.h"
Ying Wang0810a7c2019-04-10 13:48:24 +020022#include "api/network_state_predictor.h"
Steve Anton10542f22019-01-11 09:11:00 -080023#include "api/peer_connection_factory_proxy.h"
24#include "api/peer_connection_proxy.h"
Danil Chapovalov83bbe912019-08-07 12:24:53 +020025#include "api/rtc_event_log/rtc_event_log.h"
Steve Anton10542f22019-01-11 09:11:00 -080026#include "api/turn_customizer.h"
27#include "api/video_track_source_proxy.h"
Steve Anton10542f22019-01-11 09:11:00 -080028#include "media/base/rtp_data_engine.h"
29#include "media/sctp/sctp_transport.h"
Steve Anton10542f22019-01-11 09:11:00 -080030#include "p2p/base/basic_packet_socket_factory.h"
31#include "p2p/client/basic_port_allocator.h"
32#include "pc/audio_track.h"
33#include "pc/local_audio_source.h"
34#include "pc/media_stream.h"
35#include "pc/peer_connection.h"
Ying Wang0810a7c2019-04-10 13:48:24 +020036#include "pc/rtp_parameters_conversion.h"
Steve Anton10542f22019-01-11 09:11:00 -080037#include "pc/video_track.h"
Ying Wang0810a7c2019-04-10 13:48:24 +020038#include "rtc_base/bind.h"
39#include "rtc_base/checks.h"
Niels Möllere8e4dc42019-06-11 14:04:16 +020040#include "rtc_base/system/file_wrapper.h"
Bjorn Tereliusb26cf2f2018-10-26 20:39:33 +020041#include "system_wrappers/include/field_trial.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000042
henrike@webrtc.org28e20752013-07-10 00:45:36 +000043namespace webrtc {
44
kwiberg1e4e8cb2017-01-31 01:48:08 -080045rtc::scoped_refptr<PeerConnectionFactoryInterface>
zhihuang38ede132017-06-15 12:52:32 -070046CreateModularPeerConnectionFactory(
Benjamin Wright5234a492018-05-29 15:04:32 -070047 PeerConnectionFactoryDependencies dependencies) {
gyzhou95aa9642016-12-13 14:06:26 -080048 rtc::scoped_refptr<PeerConnectionFactory> pc_factory(
49 new rtc::RefCountedObject<PeerConnectionFactory>(
Benjamin Wright5234a492018-05-29 15:04:32 -070050 std::move(dependencies)));
gyzhou95aa9642016-12-13 14:06:26 -080051 // Call Initialize synchronously but make sure it is executed on
52 // |signaling_thread|.
53 MethodCall0<PeerConnectionFactory, bool> call(
54 pc_factory.get(), &PeerConnectionFactory::Initialize);
zhihuang38ede132017-06-15 12:52:32 -070055 bool result = call.Marshal(RTC_FROM_HERE, pc_factory->signaling_thread());
gyzhou95aa9642016-12-13 14:06:26 -080056
57 if (!result) {
58 return nullptr;
59 }
zhihuang38ede132017-06-15 12:52:32 -070060 return PeerConnectionFactoryProxy::Create(pc_factory->signaling_thread(),
61 pc_factory);
kwiberg1e4e8cb2017-01-31 01:48:08 -080062}
63
henrike@webrtc.org28e20752013-07-10 00:45:36 +000064PeerConnectionFactory::PeerConnectionFactory(
Danil Chapovalovf5258be2019-03-19 17:45:24 +010065 PeerConnectionFactoryDependencies dependencies)
zhihuang38ede132017-06-15 12:52:32 -070066 : wraps_current_thread_(false),
Danil Chapovalovf5258be2019-03-19 17:45:24 +010067 network_thread_(dependencies.network_thread),
68 worker_thread_(dependencies.worker_thread),
69 signaling_thread_(dependencies.signaling_thread),
Danil Chapovalov9435c612019-04-01 10:33:16 +020070 task_queue_factory_(std::move(dependencies.task_queue_factory)),
Danil Chapovalovf5258be2019-03-19 17:45:24 +010071 media_engine_(std::move(dependencies.media_engine)),
72 call_factory_(std::move(dependencies.call_factory)),
73 event_log_factory_(std::move(dependencies.event_log_factory)),
74 fec_controller_factory_(std::move(dependencies.fec_controller_factory)),
Ying Wang0810a7c2019-04-10 13:48:24 +020075 network_state_predictor_factory_(
76 std::move(dependencies.network_state_predictor_factory)),
Sebastian Janssondfce03a2018-05-18 18:05:10 +020077 injected_network_controller_factory_(
Danil Chapovalovf5258be2019-03-19 17:45:24 +010078 std::move(dependencies.network_controller_factory)),
79 media_transport_factory_(
80 std::move(dependencies.media_transport_factory)) {
zhihuang38ede132017-06-15 12:52:32 -070081 if (!network_thread_) {
82 owned_network_thread_ = rtc::Thread::CreateWithSocketServer();
Sebastian Jansson13f35ec2017-11-13 10:54:45 +010083 owned_network_thread_->SetName("pc_network_thread", nullptr);
zhihuang38ede132017-06-15 12:52:32 -070084 owned_network_thread_->Start();
85 network_thread_ = owned_network_thread_.get();
86 }
87
88 if (!worker_thread_) {
89 owned_worker_thread_ = rtc::Thread::Create();
Sebastian Jansson13f35ec2017-11-13 10:54:45 +010090 owned_worker_thread_->SetName("pc_worker_thread", nullptr);
zhihuang38ede132017-06-15 12:52:32 -070091 owned_worker_thread_->Start();
92 worker_thread_ = owned_worker_thread_.get();
93 }
94
95 if (!signaling_thread_) {
96 signaling_thread_ = rtc::Thread::Current();
97 if (!signaling_thread_) {
98 // If this thread isn't already wrapped by an rtc::Thread, create a
99 // wrapper and own it in this class.
100 signaling_thread_ = rtc::ThreadManager::Instance()->WrapCurrentThread();
101 wraps_current_thread_ = true;
102 }
103 }
Piotr (Peter) Slatalae0c2e972018-10-08 09:43:21 -0700104}
Benjamin Wright5234a492018-05-29 15:04:32 -0700105
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000106PeerConnectionFactory::~PeerConnectionFactory() {
henrikg91d6ede2015-09-17 00:24:34 -0700107 RTC_DCHECK(signaling_thread_->IsCurrent());
Henrik Boström5e56c592015-08-11 10:33:13 +0200108 channel_manager_.reset(nullptr);
jiayl@webrtc.orgd83f4ef2015-03-13 21:26:12 +0000109
110 // Make sure |worker_thread_| and |signaling_thread_| outlive
Henrik Boströmcebf0a22016-06-01 15:45:30 +0200111 // |default_socket_factory_| and |default_network_manager_|.
deadbeef41b07982015-12-01 15:01:24 -0800112 default_socket_factory_ = nullptr;
113 default_network_manager_ = nullptr;
jiayl@webrtc.orgd83f4ef2015-03-13 21:26:12 +0000114
zhihuang38ede132017-06-15 12:52:32 -0700115 if (wraps_current_thread_)
116 rtc::ThreadManager::Instance()->UnwrapCurrentThread();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000117}
118
119bool PeerConnectionFactory::Initialize() {
henrikg91d6ede2015-09-17 00:24:34 -0700120 RTC_DCHECK(signaling_thread_->IsCurrent());
Honghai Zhang82d78622016-05-06 11:29:15 -0700121 rtc::InitRandom(rtc::Time32());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000122
deadbeef41b07982015-12-01 15:01:24 -0800123 default_network_manager_.reset(new rtc::BasicNetworkManager());
124 if (!default_network_manager_) {
125 return false;
126 }
127
128 default_socket_factory_.reset(
danilchape9021a32016-05-17 01:52:02 -0700129 new rtc::BasicPacketSocketFactory(network_thread_));
deadbeef41b07982015-12-01 15:01:24 -0800130 if (!default_socket_factory_) {
131 return false;
132 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000133
Karl Wiberg918f50c2018-07-05 11:40:33 +0200134 channel_manager_ = absl::make_unique<cricket::ChannelManager>(
135 std::move(media_engine_), absl::make_unique<cricket::RtpDataEngine>(),
Steve Antonc9e15602017-11-06 15:40:09 -0800136 worker_thread_, network_thread_);
henrika@webrtc.org62f6e752015-02-11 08:38:35 +0000137
stefan@webrtc.org85d27942014-06-09 12:51:39 +0000138 channel_manager_->SetVideoRtxEnabled(true);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000139 if (!channel_manager_->Init()) {
140 return false;
141 }
jiayl@webrtc.org61e00b02015-03-04 22:17:38 +0000142
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000143 return true;
144}
145
jbauchcb560652016-08-04 05:20:32 -0700146void PeerConnectionFactory::SetOptions(const Options& options) {
147 options_ = options;
jbauchcb560652016-08-04 05:20:32 -0700148}
149
Florent Castelli72b751a2018-06-28 14:09:33 +0200150RtpCapabilities PeerConnectionFactory::GetRtpSenderCapabilities(
151 cricket::MediaType kind) const {
152 RTC_DCHECK_RUN_ON(signaling_thread_);
153 switch (kind) {
154 case cricket::MEDIA_TYPE_AUDIO: {
155 cricket::AudioCodecs cricket_codecs;
156 cricket::RtpHeaderExtensions cricket_extensions;
157 channel_manager_->GetSupportedAudioSendCodecs(&cricket_codecs);
158 channel_manager_->GetSupportedAudioRtpHeaderExtensions(
159 &cricket_extensions);
160 return ToRtpCapabilities(cricket_codecs, cricket_extensions);
161 }
162 case cricket::MEDIA_TYPE_VIDEO: {
163 cricket::VideoCodecs cricket_codecs;
164 cricket::RtpHeaderExtensions cricket_extensions;
165 channel_manager_->GetSupportedVideoCodecs(&cricket_codecs);
166 channel_manager_->GetSupportedVideoRtpHeaderExtensions(
167 &cricket_extensions);
168 return ToRtpCapabilities(cricket_codecs, cricket_extensions);
169 }
170 case cricket::MEDIA_TYPE_DATA:
171 return RtpCapabilities();
172 }
173 // Not reached; avoids compile warning.
174 FATAL();
175}
176
177RtpCapabilities PeerConnectionFactory::GetRtpReceiverCapabilities(
178 cricket::MediaType kind) const {
179 RTC_DCHECK_RUN_ON(signaling_thread_);
180 switch (kind) {
181 case cricket::MEDIA_TYPE_AUDIO: {
182 cricket::AudioCodecs cricket_codecs;
183 cricket::RtpHeaderExtensions cricket_extensions;
184 channel_manager_->GetSupportedAudioReceiveCodecs(&cricket_codecs);
185 channel_manager_->GetSupportedAudioRtpHeaderExtensions(
186 &cricket_extensions);
187 return ToRtpCapabilities(cricket_codecs, cricket_extensions);
188 }
189 case cricket::MEDIA_TYPE_VIDEO: {
190 cricket::VideoCodecs cricket_codecs;
191 cricket::RtpHeaderExtensions cricket_extensions;
192 channel_manager_->GetSupportedVideoCodecs(&cricket_codecs);
193 channel_manager_->GetSupportedVideoRtpHeaderExtensions(
194 &cricket_extensions);
195 return ToRtpCapabilities(cricket_codecs, cricket_extensions);
196 }
197 case cricket::MEDIA_TYPE_DATA:
198 return RtpCapabilities();
199 }
200 // Not reached; avoids compile warning.
201 FATAL();
202}
203
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000204rtc::scoped_refptr<AudioSourceInterface>
htaa2a49d92016-03-04 02:51:39 -0800205PeerConnectionFactory::CreateAudioSource(const cricket::AudioOptions& options) {
206 RTC_DCHECK(signaling_thread_->IsCurrent());
207 rtc::scoped_refptr<LocalAudioSource> source(
deadbeef757146b2017-02-10 21:26:48 -0800208 LocalAudioSource::Create(&options));
htaa2a49d92016-03-04 02:51:39 -0800209 return source;
210}
211
Niels Möllere8e4dc42019-06-11 14:04:16 +0200212bool PeerConnectionFactory::StartAecDump(FILE* file, int64_t max_size_bytes) {
213 RTC_DCHECK(signaling_thread_->IsCurrent());
214 return channel_manager_->StartAecDump(FileWrapper(file), max_size_bytes);
215}
216
ivoc797ef122015-10-22 03:25:41 -0700217void PeerConnectionFactory::StopAecDump() {
218 RTC_DCHECK(signaling_thread_->IsCurrent());
219 channel_manager_->StopAecDump();
220}
221
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000222rtc::scoped_refptr<PeerConnectionInterface>
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000223PeerConnectionFactory::CreatePeerConnection(
htaa2a49d92016-03-04 02:51:39 -0800224 const PeerConnectionInterface::RTCConfiguration& configuration,
kwibergd1fe2812016-04-27 06:47:29 -0700225 std::unique_ptr<cricket::PortAllocator> allocator,
Henrik Boströmd03c23b2016-06-01 11:44:18 +0200226 std::unique_ptr<rtc::RTCCertificateGeneratorInterface> cert_generator,
htaa2a49d92016-03-04 02:51:39 -0800227 PeerConnectionObserver* observer) {
Benjamin Wright6f7e6d62018-05-02 13:46:31 -0700228 // Convert the legacy API into the new depnedency structure.
229 PeerConnectionDependencies dependencies(observer);
230 dependencies.allocator = std::move(allocator);
231 dependencies.cert_generator = std::move(cert_generator);
232 // Pass that into the new API.
233 return CreatePeerConnection(configuration, std::move(dependencies));
234}
235
236rtc::scoped_refptr<PeerConnectionInterface>
237PeerConnectionFactory::CreatePeerConnection(
238 const PeerConnectionInterface::RTCConfiguration& configuration,
239 PeerConnectionDependencies dependencies) {
htaa2a49d92016-03-04 02:51:39 -0800240 RTC_DCHECK(signaling_thread_->IsCurrent());
241
Benjamin Wright6f7e6d62018-05-02 13:46:31 -0700242 // Set internal defaults if optional dependencies are not set.
243 if (!dependencies.cert_generator) {
Karl Wiberg918f50c2018-07-05 11:40:33 +0200244 dependencies.cert_generator =
245 absl::make_unique<rtc::RTCCertificateGenerator>(signaling_thread_,
246 network_thread_);
deadbeef41b07982015-12-01 15:01:24 -0800247 }
Benjamin Wright6f7e6d62018-05-02 13:46:31 -0700248 if (!dependencies.allocator) {
Qingsi Wang7852d292018-10-31 11:17:07 -0700249 network_thread_->Invoke<void>(RTC_FROM_HERE, [this, &configuration,
250 &dependencies]() {
251 dependencies.allocator = absl::make_unique<cricket::BasicPortAllocator>(
252 default_network_manager_.get(), default_socket_factory_.get(),
253 configuration.turn_customizer);
254 });
jonasoc251cb12017-08-29 03:20:58 -0700255 }
Benjamin Wright6f7e6d62018-05-02 13:46:31 -0700256
Zach Steine20867f2018-08-02 13:20:15 -0700257 // TODO(zstein): Once chromium injects its own AsyncResolverFactory, set
258 // |dependencies.async_resolver_factory| to a new
259 // |rtc::BasicAsyncResolverFactory| if no factory is provided.
260
jonasoc251cb12017-08-29 03:20:58 -0700261 network_thread_->Invoke<void>(
Benjamin Wright6f7e6d62018-05-02 13:46:31 -0700262 RTC_FROM_HERE,
263 rtc::Bind(&cricket::PortAllocator::SetNetworkIgnoreMask,
264 dependencies.allocator.get(), options_.network_ignore_mask));
jonasoc251cb12017-08-29 03:20:58 -0700265
eladalon393a9f62017-09-05 04:30:30 -0700266 std::unique_ptr<RtcEventLog> event_log =
eladalon248fd4f2017-09-06 05:18:15 -0700267 worker_thread_->Invoke<std::unique_ptr<RtcEventLog>>(
268 RTC_FROM_HERE,
269 rtc::Bind(&PeerConnectionFactory::CreateRtcEventLog_w, this));
maxmorine9ef9072017-08-29 04:49:00 -0700270
zhihuang38ede132017-06-15 12:52:32 -0700271 std::unique_ptr<Call> call = worker_thread_->Invoke<std::unique_ptr<Call>>(
272 RTC_FROM_HERE,
273 rtc::Bind(&PeerConnectionFactory::CreateCall_w, this, event_log.get()));
274
deadbeef41b07982015-12-01 15:01:24 -0800275 rtc::scoped_refptr<PeerConnection> pc(
zhihuang38ede132017-06-15 12:52:32 -0700276 new rtc::RefCountedObject<PeerConnection>(this, std::move(event_log),
277 std::move(call)));
Harald Alvestrand19793842018-06-25 12:03:50 +0200278 ActionsBeforeInitializeForTesting(pc);
Benjamin Wrightcab58882018-05-02 15:12:47 -0700279 if (!pc->Initialize(configuration, std::move(dependencies))) {
deadbeef41b07982015-12-01 15:01:24 -0800280 return nullptr;
281 }
282 return PeerConnectionProxy::Create(signaling_thread(), pc);
283}
284
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000285rtc::scoped_refptr<MediaStreamInterface>
Seth Hampson845e8782018-03-02 11:34:10 -0800286PeerConnectionFactory::CreateLocalMediaStream(const std::string& stream_id) {
henrikg91d6ede2015-09-17 00:24:34 -0700287 RTC_DCHECK(signaling_thread_->IsCurrent());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000288 return MediaStreamProxy::Create(signaling_thread_,
Seth Hampson845e8782018-03-02 11:34:10 -0800289 MediaStream::Create(stream_id));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000290}
291
perkja3ede6c2016-03-08 01:27:48 +0100292rtc::scoped_refptr<VideoTrackInterface> PeerConnectionFactory::CreateVideoTrack(
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000293 const std::string& id,
perkja3ede6c2016-03-08 01:27:48 +0100294 VideoTrackSourceInterface* source) {
henrikg91d6ede2015-09-17 00:24:34 -0700295 RTC_DCHECK(signaling_thread_->IsCurrent());
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000296 rtc::scoped_refptr<VideoTrackInterface> track(
perkj773be362017-07-31 23:22:01 -0700297 VideoTrack::Create(id, source, worker_thread_));
nisse5b68ab52016-04-07 07:45:54 -0700298 return VideoTrackProxy::Create(signaling_thread_, worker_thread_, track);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000299}
300
Yves Gerey665174f2018-06-19 15:03:05 +0200301rtc::scoped_refptr<AudioTrackInterface> PeerConnectionFactory::CreateAudioTrack(
302 const std::string& id,
303 AudioSourceInterface* source) {
henrikg91d6ede2015-09-17 00:24:34 -0700304 RTC_DCHECK(signaling_thread_->IsCurrent());
tommi6eca7e32015-12-15 04:27:11 -0800305 rtc::scoped_refptr<AudioTrackInterface> track(AudioTrack::Create(id, source));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000306 return AudioTrackProxy::Create(signaling_thread_, track);
307}
308
Steve Antonda6c0952017-10-23 11:41:54 -0700309std::unique_ptr<cricket::SctpTransportInternalFactory>
310PeerConnectionFactory::CreateSctpTransportInternalFactory() {
311#ifdef HAVE_SCTP
Karl Wiberg918f50c2018-07-05 11:40:33 +0200312 return absl::make_unique<cricket::SctpTransportFactory>(network_thread());
Steve Antonda6c0952017-10-23 11:41:54 -0700313#else
314 return nullptr;
315#endif
316}
317
nisseeaabdf62017-05-05 02:23:02 -0700318cricket::ChannelManager* PeerConnectionFactory::channel_manager() {
319 return channel_manager_.get();
320}
321
eladalon248fd4f2017-09-06 05:18:15 -0700322std::unique_ptr<RtcEventLog> PeerConnectionFactory::CreateRtcEventLog_w() {
eladalon591753b2017-09-06 12:33:43 -0700323 RTC_DCHECK_RUN_ON(worker_thread_);
Bjorn Tereliusb26cf2f2018-10-26 20:39:33 +0200324
325 auto encoding_type = RtcEventLog::EncodingType::Legacy;
326 if (field_trial::IsEnabled("WebRTC-RtcEventLogNewFormat"))
327 encoding_type = RtcEventLog::EncodingType::NewFormat;
Elad Alon4a87e1c2017-10-03 16:11:34 +0200328 return event_log_factory_
329 ? event_log_factory_->CreateRtcEventLog(encoding_type)
Danil Chapovalov83bbe912019-08-07 12:24:53 +0200330 : absl::make_unique<RtcEventLogNull>();
eladalon248fd4f2017-09-06 05:18:15 -0700331}
332
zhihuang38ede132017-06-15 12:52:32 -0700333std::unique_ptr<Call> PeerConnectionFactory::CreateCall_w(
334 RtcEventLog* event_log) {
eladalon591753b2017-09-06 12:33:43 -0700335 RTC_DCHECK_RUN_ON(worker_thread_);
336
zhihuang38ede132017-06-15 12:52:32 -0700337 const int kMinBandwidthBps = 30000;
338 const int kStartBandwidthBps = 300000;
339 const int kMaxBandwidthBps = 2000000;
340
341 webrtc::Call::Config call_config(event_log);
342 if (!channel_manager_->media_engine() || !call_factory_) {
343 return nullptr;
344 }
Sebastian Jansson6eb8a162018-11-16 11:29:55 +0100345 call_config.audio_state =
346 channel_manager_->media_engine()->voice().GetAudioState();
zhihuang38ede132017-06-15 12:52:32 -0700347 call_config.bitrate_config.min_bitrate_bps = kMinBandwidthBps;
348 call_config.bitrate_config.start_bitrate_bps = kStartBandwidthBps;
349 call_config.bitrate_config.max_bitrate_bps = kMaxBandwidthBps;
350
Ying Wang0dd1b0a2018-02-20 12:50:27 +0100351 call_config.fec_controller_factory = fec_controller_factory_.get();
Danil Chapovalov9435c612019-04-01 10:33:16 +0200352 call_config.task_queue_factory = task_queue_factory_.get();
Ying Wang0810a7c2019-04-10 13:48:24 +0200353 call_config.network_state_predictor_factory =
354 network_state_predictor_factory_.get();
Ying Wang0dd1b0a2018-02-20 12:50:27 +0100355
Sebastian Jansson7f577882018-12-20 09:46:29 +0100356 if (field_trial::IsEnabled("WebRTC-Bwe-InjectedCongestionController")) {
Sebastian Janssondfce03a2018-05-18 18:05:10 +0200357 RTC_LOG(LS_INFO) << "Using injected network controller factory";
358 call_config.network_controller_factory =
359 injected_network_controller_factory_.get();
360 } else {
361 RTC_LOG(LS_INFO) << "Using default network controller factory";
362 }
363
zhihuang38ede132017-06-15 12:52:32 -0700364 return std::unique_ptr<Call>(call_factory_->CreateCall(call_config));
365}
366
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000367} // namespace webrtc