blob: 205f7a48bb9ea3bc46fcd9bcf9a37251877d50be [file] [log] [blame]
Paulina Hensman11b34f42018-04-09 14:24:52 +02001/*
2 * Copyright (c) 2018 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#ifndef CALL_CALL_CONFIG_H_
11#define CALL_CALL_CONFIG_H_
12
13#include "api/fec_controller.h"
Ivo Creusenc3d1f9b2019-11-01 11:47:51 +010014#include "api/neteq/neteq_factory.h"
Ying Wang0810a7c2019-04-10 13:48:24 +020015#include "api/network_state_predictor.h"
Steve Anton10542f22019-01-11 09:11:00 -080016#include "api/rtc_error.h"
Danil Chapovalov359fe332019-04-01 10:46:36 +020017#include "api/task_queue/task_queue_factory.h"
Mirko Bonadei738bfa72019-09-17 14:47:38 +020018#include "api/transport/bitrate_settings.h"
Sebastian Janssondfce03a2018-05-18 18:05:10 +020019#include "api/transport/network_control.h"
Erik Språng662678d2019-11-15 17:18:52 +010020#include "api/transport/webrtc_key_value_config.h"
Paulina Hensman11b34f42018-04-09 14:24:52 +020021#include "call/audio_state.h"
Paulina Hensman11b34f42018-04-09 14:24:52 +020022
23namespace webrtc {
24
25class AudioProcessing;
26class RtcEventLog;
27
28struct CallConfig {
29 explicit CallConfig(RtcEventLog* event_log);
Mirko Bonadei8fdcac32018-08-28 16:30:18 +020030 CallConfig(const CallConfig&);
Paulina Hensman11b34f42018-04-09 14:24:52 +020031 ~CallConfig();
32
Paulina Hensman11b34f42018-04-09 14:24:52 +020033 // Bitrate config used until valid bitrate estimates are calculated. Also
34 // used to cap total bitrate used. This comes from the remote connection.
35 BitrateConstraints bitrate_config;
36
37 // AudioState which is possibly shared between multiple calls.
Paulina Hensman11b34f42018-04-09 14:24:52 +020038 rtc::scoped_refptr<AudioState> audio_state;
39
40 // Audio Processing Module to be used in this call.
Paulina Hensman11b34f42018-04-09 14:24:52 +020041 AudioProcessing* audio_processing = nullptr;
42
43 // RtcEventLog to use for this call. Required.
44 // Use webrtc::RtcEventLog::CreateNull() for a null implementation.
45 RtcEventLog* event_log = nullptr;
46
47 // FecController to use for this call.
48 FecControllerFactoryInterface* fec_controller_factory = nullptr;
Sebastian Janssondfce03a2018-05-18 18:05:10 +020049
Danil Chapovalov53d45ba2019-07-03 14:56:33 +020050 // Task Queue Factory to be used in this call. Required.
Danil Chapovalov359fe332019-04-01 10:46:36 +020051 TaskQueueFactory* task_queue_factory = nullptr;
52
Ying Wang0810a7c2019-04-10 13:48:24 +020053 // NetworkStatePredictor to use for this call.
54 NetworkStatePredictorFactoryInterface* network_state_predictor_factory =
55 nullptr;
56
Sebastian Janssondfce03a2018-05-18 18:05:10 +020057 // Network controller factory to use for this call.
58 NetworkControllerFactoryInterface* network_controller_factory = nullptr;
Ivo Creusenc3d1f9b2019-11-01 11:47:51 +010059
60 // NetEq factory to use for this call.
61 NetEqFactory* neteq_factory = nullptr;
Erik Språng662678d2019-11-15 17:18:52 +010062
63 // Key-value mapping of internal configurations to apply,
64 // e.g. field trials.
65 const WebRtcKeyValueConfig* trials = nullptr;
Paulina Hensman11b34f42018-04-09 14:24:52 +020066};
67
68} // namespace webrtc
69
70#endif // CALL_CALL_CONFIG_H_