blob: dc84d76d01e9d889552e63152b7079bacdf358d6 [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
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020011#include "pc/peerconnectionfactory.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000012
kwiberg0eb15ed2015-12-17 03:04:15 -080013#include <utility>
14
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020015#include "api/mediaconstraintsinterface.h"
16#include "api/mediastreamproxy.h"
17#include "api/mediastreamtrackproxy.h"
18#include "api/peerconnectionfactoryproxy.h"
19#include "api/peerconnectionproxy.h"
Jonas Orelandbdcee282017-10-10 14:01:40 +020020#include "api/turncustomizer.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020021#include "api/videosourceproxy.h"
22#include "logging/rtc_event_log/rtc_event_log.h"
Steve Antonda6c0952017-10-23 11:41:54 -070023#include "media/sctp/sctptransport.h"
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020024#include "rtc_base/bind.h"
25#include "rtc_base/checks.h"
26#include "rtc_base/ptr_util.h"
zhihuang38ede132017-06-15 12:52:32 -070027// Adding 'nogncheck' to disable the gn include headers check to support modular
28// WebRTC build targets.
29// TODO(zhihuang): This wouldn't be necessary if the interface and
30// implementation of the media engine were in separate build targets.
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020031#include "media/engine/webrtcmediaengine.h" // nogncheck
32#include "media/engine/webrtcvideodecoderfactory.h" // nogncheck
33#include "media/engine/webrtcvideoencoderfactory.h" // nogncheck
34#include "modules/audio_device/include/audio_device.h" // nogncheck
35#include "p2p/base/basicpacketsocketfactory.h"
36#include "p2p/client/basicportallocator.h"
37#include "pc/audiotrack.h"
38#include "pc/localaudiosource.h"
39#include "pc/mediastream.h"
40#include "pc/peerconnection.h"
41#include "pc/videocapturertracksource.h"
42#include "pc/videotrack.h"
henrike@webrtc.org28e20752013-07-10 00:45:36 +000043
henrike@webrtc.org28e20752013-07-10 00:45:36 +000044namespace webrtc {
45
kwiberg1e4e8cb2017-01-31 01:48:08 -080046rtc::scoped_refptr<PeerConnectionFactoryInterface>
zhihuang38ede132017-06-15 12:52:32 -070047CreateModularPeerConnectionFactory(
gyzhou95aa9642016-12-13 14:06:26 -080048 rtc::Thread* network_thread,
49 rtc::Thread* worker_thread,
50 rtc::Thread* signaling_thread,
zhihuang38ede132017-06-15 12:52:32 -070051 std::unique_ptr<cricket::MediaEngineInterface> media_engine,
52 std::unique_ptr<CallFactoryInterface> call_factory,
53 std::unique_ptr<RtcEventLogFactoryInterface> event_log_factory) {
gyzhou95aa9642016-12-13 14:06:26 -080054 rtc::scoped_refptr<PeerConnectionFactory> pc_factory(
55 new rtc::RefCountedObject<PeerConnectionFactory>(
Magnus Jedvert835cc0c2017-09-23 16:14:25 +020056 network_thread, worker_thread, signaling_thread,
Magnus Jedvert02e7a192017-09-23 17:21:32 +020057 std::move(media_engine), std::move(call_factory),
58 std::move(event_log_factory)));
gyzhou95aa9642016-12-13 14:06:26 -080059
60 // Call Initialize synchronously but make sure it is executed on
61 // |signaling_thread|.
62 MethodCall0<PeerConnectionFactory, bool> call(
63 pc_factory.get(), &PeerConnectionFactory::Initialize);
zhihuang38ede132017-06-15 12:52:32 -070064 bool result = call.Marshal(RTC_FROM_HERE, pc_factory->signaling_thread());
gyzhou95aa9642016-12-13 14:06:26 -080065
66 if (!result) {
67 return nullptr;
68 }
zhihuang38ede132017-06-15 12:52:32 -070069 return PeerConnectionFactoryProxy::Create(pc_factory->signaling_thread(),
70 pc_factory);
kwiberg1e4e8cb2017-01-31 01:48:08 -080071}
72
henrike@webrtc.org28e20752013-07-10 00:45:36 +000073PeerConnectionFactory::PeerConnectionFactory(
danilchape9021a32016-05-17 01:52:02 -070074 rtc::Thread* network_thread,
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +000075 rtc::Thread* worker_thread,
76 rtc::Thread* signaling_thread,
zhihuang38ede132017-06-15 12:52:32 -070077 std::unique_ptr<cricket::MediaEngineInterface> media_engine,
78 std::unique_ptr<webrtc::CallFactoryInterface> call_factory,
79 std::unique_ptr<RtcEventLogFactoryInterface> event_log_factory)
80 : wraps_current_thread_(false),
danilchape9021a32016-05-17 01:52:02 -070081 network_thread_(network_thread),
henrike@webrtc.org28e20752013-07-10 00:45:36 +000082 worker_thread_(worker_thread),
danilchape9021a32016-05-17 01:52:02 -070083 signaling_thread_(signaling_thread),
zhihuang38ede132017-06-15 12:52:32 -070084 media_engine_(std::move(media_engine)),
85 call_factory_(std::move(call_factory)),
86 event_log_factory_(std::move(event_log_factory)) {
87 if (!network_thread_) {
88 owned_network_thread_ = rtc::Thread::CreateWithSocketServer();
89 owned_network_thread_->Start();
90 network_thread_ = owned_network_thread_.get();
91 }
92
93 if (!worker_thread_) {
94 owned_worker_thread_ = rtc::Thread::Create();
95 owned_worker_thread_->Start();
96 worker_thread_ = owned_worker_thread_.get();
97 }
98
99 if (!signaling_thread_) {
100 signaling_thread_ = rtc::Thread::Current();
101 if (!signaling_thread_) {
102 // If this thread isn't already wrapped by an rtc::Thread, create a
103 // wrapper and own it in this class.
104 signaling_thread_ = rtc::ThreadManager::Instance()->WrapCurrentThread();
105 wraps_current_thread_ = true;
106 }
107 }
108
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000109 // TODO: Currently there is no way creating an external adm in
110 // libjingle source tree. So we can 't currently assert if this is NULL.
nisseede5da42017-01-12 05:15:36 -0800111 // RTC_DCHECK(default_adm != NULL);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000112}
113
114PeerConnectionFactory::~PeerConnectionFactory() {
henrikg91d6ede2015-09-17 00:24:34 -0700115 RTC_DCHECK(signaling_thread_->IsCurrent());
Henrik Boström5e56c592015-08-11 10:33:13 +0200116 channel_manager_.reset(nullptr);
jiayl@webrtc.orgd83f4ef2015-03-13 21:26:12 +0000117
118 // Make sure |worker_thread_| and |signaling_thread_| outlive
Henrik Boströmcebf0a22016-06-01 15:45:30 +0200119 // |default_socket_factory_| and |default_network_manager_|.
deadbeef41b07982015-12-01 15:01:24 -0800120 default_socket_factory_ = nullptr;
121 default_network_manager_ = nullptr;
jiayl@webrtc.orgd83f4ef2015-03-13 21:26:12 +0000122
zhihuang38ede132017-06-15 12:52:32 -0700123 if (wraps_current_thread_)
124 rtc::ThreadManager::Instance()->UnwrapCurrentThread();
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000125}
126
127bool PeerConnectionFactory::Initialize() {
henrikg91d6ede2015-09-17 00:24:34 -0700128 RTC_DCHECK(signaling_thread_->IsCurrent());
Honghai Zhang82d78622016-05-06 11:29:15 -0700129 rtc::InitRandom(rtc::Time32());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000130
deadbeef41b07982015-12-01 15:01:24 -0800131 default_network_manager_.reset(new rtc::BasicNetworkManager());
132 if (!default_network_manager_) {
133 return false;
134 }
135
136 default_socket_factory_.reset(
danilchape9021a32016-05-17 01:52:02 -0700137 new rtc::BasicPacketSocketFactory(network_thread_));
deadbeef41b07982015-12-01 15:01:24 -0800138 if (!default_socket_factory_) {
139 return false;
140 }
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000141
Danil Chapovalov33b01f22016-05-11 19:55:27 +0200142 channel_manager_.reset(new cricket::ChannelManager(
zhihuang38ede132017-06-15 12:52:32 -0700143 std::move(media_engine_), worker_thread_, network_thread_));
henrika@webrtc.org62f6e752015-02-11 08:38:35 +0000144
stefan@webrtc.org85d27942014-06-09 12:51:39 +0000145 channel_manager_->SetVideoRtxEnabled(true);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000146 if (!channel_manager_->Init()) {
147 return false;
148 }
jiayl@webrtc.org61e00b02015-03-04 22:17:38 +0000149
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000150 return true;
151}
152
jbauchcb560652016-08-04 05:20:32 -0700153void PeerConnectionFactory::SetOptions(const Options& options) {
154 options_ = options;
jbauchcb560652016-08-04 05:20:32 -0700155}
156
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000157rtc::scoped_refptr<AudioSourceInterface>
perkj@webrtc.org81134d02015-01-12 08:30:16 +0000158PeerConnectionFactory::CreateAudioSource(
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000159 const MediaConstraintsInterface* constraints) {
henrikg91d6ede2015-09-17 00:24:34 -0700160 RTC_DCHECK(signaling_thread_->IsCurrent());
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000161 rtc::scoped_refptr<LocalAudioSource> source(
deadbeef757146b2017-02-10 21:26:48 -0800162 LocalAudioSource::Create(constraints));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000163 return source;
164}
165
htaa2a49d92016-03-04 02:51:39 -0800166rtc::scoped_refptr<AudioSourceInterface>
167PeerConnectionFactory::CreateAudioSource(const cricket::AudioOptions& options) {
168 RTC_DCHECK(signaling_thread_->IsCurrent());
169 rtc::scoped_refptr<LocalAudioSource> source(
deadbeef757146b2017-02-10 21:26:48 -0800170 LocalAudioSource::Create(&options));
htaa2a49d92016-03-04 02:51:39 -0800171 return source;
172}
173
perkja3ede6c2016-03-08 01:27:48 +0100174rtc::scoped_refptr<VideoTrackSourceInterface>
perkj@webrtc.org81134d02015-01-12 08:30:16 +0000175PeerConnectionFactory::CreateVideoSource(
deadbeef112b2e92017-02-10 20:13:37 -0800176 std::unique_ptr<cricket::VideoCapturer> capturer,
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000177 const MediaConstraintsInterface* constraints) {
henrikg91d6ede2015-09-17 00:24:34 -0700178 RTC_DCHECK(signaling_thread_->IsCurrent());
perkja3ede6c2016-03-08 01:27:48 +0100179 rtc::scoped_refptr<VideoTrackSourceInterface> source(
deadbeef112b2e92017-02-10 20:13:37 -0800180 VideoCapturerTrackSource::Create(worker_thread_, std::move(capturer),
181 constraints, false));
nisse5b68ab52016-04-07 07:45:54 -0700182 return VideoTrackSourceProxy::Create(signaling_thread_, worker_thread_,
183 source);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000184}
185
perkja3ede6c2016-03-08 01:27:48 +0100186rtc::scoped_refptr<VideoTrackSourceInterface>
deadbeef112b2e92017-02-10 20:13:37 -0800187PeerConnectionFactory::CreateVideoSource(
188 std::unique_ptr<cricket::VideoCapturer> capturer) {
htaa2a49d92016-03-04 02:51:39 -0800189 RTC_DCHECK(signaling_thread_->IsCurrent());
perkja3ede6c2016-03-08 01:27:48 +0100190 rtc::scoped_refptr<VideoTrackSourceInterface> source(
deadbeef112b2e92017-02-10 20:13:37 -0800191 VideoCapturerTrackSource::Create(worker_thread_, std::move(capturer),
192 false));
nisse5b68ab52016-04-07 07:45:54 -0700193 return VideoTrackSourceProxy::Create(signaling_thread_, worker_thread_,
194 source);
htaa2a49d92016-03-04 02:51:39 -0800195}
196
ivocd66b44d2016-01-15 03:06:36 -0800197bool PeerConnectionFactory::StartAecDump(rtc::PlatformFile file,
198 int64_t max_size_bytes) {
henrikg91d6ede2015-09-17 00:24:34 -0700199 RTC_DCHECK(signaling_thread_->IsCurrent());
ivocd66b44d2016-01-15 03:06:36 -0800200 return channel_manager_->StartAecDump(file, max_size_bytes);
wu@webrtc.orga9890802013-12-13 00:21:03 +0000201}
202
ivoc797ef122015-10-22 03:25:41 -0700203void PeerConnectionFactory::StopAecDump() {
204 RTC_DCHECK(signaling_thread_->IsCurrent());
205 channel_manager_->StopAecDump();
206}
207
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000208rtc::scoped_refptr<PeerConnectionInterface>
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000209PeerConnectionFactory::CreatePeerConnection(
htaa2a49d92016-03-04 02:51:39 -0800210 const PeerConnectionInterface::RTCConfiguration& configuration_in,
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000211 const MediaConstraintsInterface* constraints,
kwibergd1fe2812016-04-27 06:47:29 -0700212 std::unique_ptr<cricket::PortAllocator> allocator,
Henrik Boströmd03c23b2016-06-01 11:44:18 +0200213 std::unique_ptr<rtc::RTCCertificateGeneratorInterface> cert_generator,
deadbeef41b07982015-12-01 15:01:24 -0800214 PeerConnectionObserver* observer) {
215 RTC_DCHECK(signaling_thread_->IsCurrent());
216
htaa2a49d92016-03-04 02:51:39 -0800217 // We merge constraints and configuration into a single configuration.
218 PeerConnectionInterface::RTCConfiguration configuration = configuration_in;
219 CopyConstraintsIntoRtcConfiguration(constraints, &configuration);
220
221 return CreatePeerConnection(configuration, std::move(allocator),
Henrik Boströmd03c23b2016-06-01 11:44:18 +0200222 std::move(cert_generator), observer);
htaa2a49d92016-03-04 02:51:39 -0800223}
224
225rtc::scoped_refptr<PeerConnectionInterface>
226PeerConnectionFactory::CreatePeerConnection(
227 const PeerConnectionInterface::RTCConfiguration& configuration,
kwibergd1fe2812016-04-27 06:47:29 -0700228 std::unique_ptr<cricket::PortAllocator> allocator,
Henrik Boströmd03c23b2016-06-01 11:44:18 +0200229 std::unique_ptr<rtc::RTCCertificateGeneratorInterface> cert_generator,
htaa2a49d92016-03-04 02:51:39 -0800230 PeerConnectionObserver* observer) {
231 RTC_DCHECK(signaling_thread_->IsCurrent());
232
Henrik Boströmd03c23b2016-06-01 11:44:18 +0200233 if (!cert_generator.get()) {
Henrik Boströmcebf0a22016-06-01 15:45:30 +0200234 // No certificate generator specified, use the default one.
Henrik Boströmd03c23b2016-06-01 11:44:18 +0200235 cert_generator.reset(
Henrik Boströmcebf0a22016-06-01 15:45:30 +0200236 new rtc::RTCCertificateGenerator(signaling_thread_, network_thread_));
deadbeef41b07982015-12-01 15:01:24 -0800237 }
238
jonasoc251cb12017-08-29 03:20:58 -0700239 if (!allocator) {
240 allocator.reset(new cricket::BasicPortAllocator(
Jonas Orelandbdcee282017-10-10 14:01:40 +0200241 default_network_manager_.get(), default_socket_factory_.get(),
242 configuration.turn_customizer));
jonasoc251cb12017-08-29 03:20:58 -0700243 }
244 network_thread_->Invoke<void>(
245 RTC_FROM_HERE, rtc::Bind(&cricket::PortAllocator::SetNetworkIgnoreMask,
246 allocator.get(), options_.network_ignore_mask));
247
eladalon393a9f62017-09-05 04:30:30 -0700248 std::unique_ptr<RtcEventLog> event_log =
eladalon248fd4f2017-09-06 05:18:15 -0700249 worker_thread_->Invoke<std::unique_ptr<RtcEventLog>>(
250 RTC_FROM_HERE,
251 rtc::Bind(&PeerConnectionFactory::CreateRtcEventLog_w, this));
maxmorine9ef9072017-08-29 04:49:00 -0700252
zhihuang38ede132017-06-15 12:52:32 -0700253 std::unique_ptr<Call> call = worker_thread_->Invoke<std::unique_ptr<Call>>(
254 RTC_FROM_HERE,
255 rtc::Bind(&PeerConnectionFactory::CreateCall_w, this, event_log.get()));
256
deadbeef41b07982015-12-01 15:01:24 -0800257 rtc::scoped_refptr<PeerConnection> pc(
zhihuang38ede132017-06-15 12:52:32 -0700258 new rtc::RefCountedObject<PeerConnection>(this, std::move(event_log),
259 std::move(call)));
htaa2a49d92016-03-04 02:51:39 -0800260
nissec36b31b2016-04-11 23:25:29 -0700261 if (!pc->Initialize(configuration, std::move(allocator),
Henrik Boströmd03c23b2016-06-01 11:44:18 +0200262 std::move(cert_generator), observer)) {
deadbeef41b07982015-12-01 15:01:24 -0800263 return nullptr;
264 }
265 return PeerConnectionProxy::Create(signaling_thread(), pc);
266}
267
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000268rtc::scoped_refptr<MediaStreamInterface>
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000269PeerConnectionFactory::CreateLocalMediaStream(const std::string& label) {
henrikg91d6ede2015-09-17 00:24:34 -0700270 RTC_DCHECK(signaling_thread_->IsCurrent());
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000271 return MediaStreamProxy::Create(signaling_thread_,
272 MediaStream::Create(label));
273}
274
perkja3ede6c2016-03-08 01:27:48 +0100275rtc::scoped_refptr<VideoTrackInterface> PeerConnectionFactory::CreateVideoTrack(
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000276 const std::string& id,
perkja3ede6c2016-03-08 01:27:48 +0100277 VideoTrackSourceInterface* source) {
henrikg91d6ede2015-09-17 00:24:34 -0700278 RTC_DCHECK(signaling_thread_->IsCurrent());
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000279 rtc::scoped_refptr<VideoTrackInterface> track(
perkj773be362017-07-31 23:22:01 -0700280 VideoTrack::Create(id, source, worker_thread_));
nisse5b68ab52016-04-07 07:45:54 -0700281 return VideoTrackProxy::Create(signaling_thread_, worker_thread_, track);
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000282}
283
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000284rtc::scoped_refptr<AudioTrackInterface>
pbos@webrtc.orgb5a22b12014-05-13 11:07:01 +0000285PeerConnectionFactory::CreateAudioTrack(const std::string& id,
286 AudioSourceInterface* source) {
henrikg91d6ede2015-09-17 00:24:34 -0700287 RTC_DCHECK(signaling_thread_->IsCurrent());
tommi6eca7e32015-12-15 04:27:11 -0800288 rtc::scoped_refptr<AudioTrackInterface> track(AudioTrack::Create(id, source));
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000289 return AudioTrackProxy::Create(signaling_thread_, track);
290}
291
zhihuang29ff8442016-07-27 11:07:25 -0700292cricket::TransportController* PeerConnectionFactory::CreateTransportController(
Honghai Zhangbfd398c2016-08-30 22:07:42 -0700293 cricket::PortAllocator* port_allocator,
294 bool redetermine_role_on_ice_restart) {
zhihuang29ff8442016-07-27 11:07:25 -0700295 RTC_DCHECK(signaling_thread_->IsCurrent());
deadbeef7914b8c2017-04-21 03:23:33 -0700296 return new cricket::TransportController(
297 signaling_thread_, network_thread_, port_allocator,
298 redetermine_role_on_ice_restart, options_.crypto_options);
zhihuang29ff8442016-07-27 11:07:25 -0700299}
300
Steve Antonda6c0952017-10-23 11:41:54 -0700301std::unique_ptr<cricket::SctpTransportInternalFactory>
302PeerConnectionFactory::CreateSctpTransportInternalFactory() {
303#ifdef HAVE_SCTP
304 return rtc::MakeUnique<cricket::SctpTransportFactory>(network_thread());
305#else
306 return nullptr;
307#endif
308}
309
nisseeaabdf62017-05-05 02:23:02 -0700310cricket::ChannelManager* PeerConnectionFactory::channel_manager() {
311 return channel_manager_.get();
312}
313
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000314rtc::Thread* PeerConnectionFactory::signaling_thread() {
perkj@webrtc.org81134d02015-01-12 08:30:16 +0000315 // This method can be called on a different thread when the factory is
316 // created in CreatePeerConnectionFactory().
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000317 return signaling_thread_;
318}
319
buildbot@webrtc.orgd4e598d2014-07-29 17:36:52 +0000320rtc::Thread* PeerConnectionFactory::worker_thread() {
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000321 return worker_thread_;
322}
323
danilchape9021a32016-05-17 01:52:02 -0700324rtc::Thread* PeerConnectionFactory::network_thread() {
325 return network_thread_;
326}
327
eladalon248fd4f2017-09-06 05:18:15 -0700328std::unique_ptr<RtcEventLog> PeerConnectionFactory::CreateRtcEventLog_w() {
eladalon591753b2017-09-06 12:33:43 -0700329 RTC_DCHECK_RUN_ON(worker_thread_);
Elad Alon4a87e1c2017-10-03 16:11:34 +0200330 const auto encoding_type = RtcEventLog::EncodingType::Legacy;
331 return event_log_factory_
332 ? event_log_factory_->CreateRtcEventLog(encoding_type)
333 : rtc::MakeUnique<RtcEventLogNullImpl>();
eladalon248fd4f2017-09-06 05:18:15 -0700334}
335
zhihuang38ede132017-06-15 12:52:32 -0700336std::unique_ptr<Call> PeerConnectionFactory::CreateCall_w(
337 RtcEventLog* event_log) {
eladalon591753b2017-09-06 12:33:43 -0700338 RTC_DCHECK_RUN_ON(worker_thread_);
339
zhihuang38ede132017-06-15 12:52:32 -0700340 const int kMinBandwidthBps = 30000;
341 const int kStartBandwidthBps = 300000;
342 const int kMaxBandwidthBps = 2000000;
343
344 webrtc::Call::Config call_config(event_log);
345 if (!channel_manager_->media_engine() || !call_factory_) {
346 return nullptr;
347 }
348 call_config.audio_state = channel_manager_->media_engine()->GetAudioState();
349 call_config.bitrate_config.min_bitrate_bps = kMinBandwidthBps;
350 call_config.bitrate_config.start_bitrate_bps = kStartBandwidthBps;
351 call_config.bitrate_config.max_bitrate_bps = kMaxBandwidthBps;
352
353 return std::unique_ptr<Call>(call_factory_->CreateCall(call_config));
354}
355
henrike@webrtc.org28e20752013-07-10 00:45:36 +0000356} // namespace webrtc