blob: a2be32de6f81a9cf4f22daef5ccb8a2a23332220 [file] [log] [blame]
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +00001/*
2 * Copyright 2004 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
Steve Anton10542f22019-01-11 09:11:00 -080011#ifndef P2P_BASE_P2P_CONSTANTS_H_
12#define P2P_BASE_P2P_CONSTANTS_H_
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000013
Yves Gerey3e707812018-11-28 16:47:49 +010014#include <stddef.h>
15#include <stdint.h>
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000016
Mirko Bonadeiac194142018-10-22 17:08:37 +020017#include "rtc_base/system/rtc_export.h"
18
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000019namespace cricket {
20
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000021// CN_ == "content name". When we initiate a session, we choose the
22// name, and when we receive a Gingle session, we provide default
23// names (since Gingle has no content names). But when we receive a
24// Jingle call, the content name can be anything, so don't rely on
25// these values being the same as the ones received.
26extern const char CN_AUDIO[];
27extern const char CN_VIDEO[];
28extern const char CN_DATA[];
29extern const char CN_OTHER[];
pthatcher@webrtc.org5ad41782014-12-23 22:14:15 +000030
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000031// GN stands for group name
32extern const char GROUP_TYPE_BUNDLE[];
33
Mirko Bonadei66e76792019-04-02 11:33:59 +020034RTC_EXPORT extern const int ICE_UFRAG_LENGTH;
Mirko Bonadeiac194142018-10-22 17:08:37 +020035RTC_EXPORT extern const int ICE_PWD_LENGTH;
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000036extern const size_t ICE_UFRAG_MIN_LENGTH;
37extern const size_t ICE_PWD_MIN_LENGTH;
38extern const size_t ICE_UFRAG_MAX_LENGTH;
39extern const size_t ICE_PWD_MAX_LENGTH;
pthatcher@webrtc.org5ad41782014-12-23 22:14:15 +000040
Mirko Bonadei66e76792019-04-02 11:33:59 +020041RTC_EXPORT extern const int ICE_CANDIDATE_COMPONENT_RTP;
42RTC_EXPORT extern const int ICE_CANDIDATE_COMPONENT_RTCP;
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000043extern const int ICE_CANDIDATE_COMPONENT_DEFAULT;
44
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000045// RFC 4145, SDP setup attribute values.
46extern const char CONNECTIONROLE_ACTIVE_STR[];
47extern const char CONNECTIONROLE_PASSIVE_STR[];
48extern const char CONNECTIONROLE_ACTPASS_STR[];
49extern const char CONNECTIONROLE_HOLDCONN_STR[];
50
Qingsi Wang866e08d2018-03-22 17:54:23 -070051// Constants for time intervals are in milliseconds unless otherwise stated.
52//
53// Most of the following constants are the default values of IceConfig
54// paramters. See IceConfig for detailed definition.
55//
56// Default value of IceConfig.receiving_timeout.
57extern const int RECEIVING_TIMEOUT;
58// Default value IceConfig.ice_check_min_interval.
59extern const int MIN_CHECK_RECEIVING_INTERVAL;
60// The next two ping intervals are at the ICE transport level.
61//
62// STRONG_PING_INTERVAL is applied when the selected connection is both
63// writable and receiving.
64//
65// Default value of IceConfig.ice_check_interval_strong_connectivity.
66extern const int STRONG_PING_INTERVAL;
67// WEAK_PING_INTERVAL is applied when the selected connection is either
68// not writable or not receiving.
69//
70// Defaul value of IceConfig.ice_check_interval_weak_connectivity.
71extern const int WEAK_PING_INTERVAL;
72// The next two ping intervals are at the candidate pair level.
73//
74// Writable candidate pairs are pinged at a slower rate once they are stabilized
75// and the channel is strongly connected.
76extern const int STRONG_AND_STABLE_WRITABLE_CONNECTION_PING_INTERVAL;
77// Writable candidate pairs are pinged at a faster rate while the connections
78// are stabilizing or the channel is weak.
79extern const int WEAK_OR_STABILIZING_WRITABLE_CONNECTION_PING_INTERVAL;
80// Default value of IceConfig.backup_connection_ping_interval
81extern const int BACKUP_CONNECTION_PING_INTERVAL;
82// Defualt value of IceConfig.receiving_switching_delay.
83extern const int RECEIVING_SWITCHING_DELAY;
84// Default value of IceConfig.regather_on_failed_networks_interval.
85extern const int REGATHER_ON_FAILED_NETWORKS_INTERVAL;
86// Default vaule of IceConfig.ice_unwritable_timeout.
87extern const int CONNECTION_WRITE_CONNECT_TIMEOUT;
88// Default vaule of IceConfig.ice_unwritable_min_checks.
89extern const uint32_t CONNECTION_WRITE_CONNECT_FAILURES;
Jiawei Ou9d4fd5552018-12-06 23:30:17 -080090// Default value of IceConfig.ice_inactive_timeout;
91extern const int CONNECTION_WRITE_TIMEOUT;
Qingsi Wang866e08d2018-03-22 17:54:23 -070092// Default value of IceConfig.stun_keepalive_interval;
93extern const int STUN_KEEPALIVE_INTERVAL;
94
95// The following constants are used at the candidate pair level to determine the
96// state of a candidate pair.
97//
98// The timeout duration when a connection does not receive anything.
99extern const int WEAK_CONNECTION_RECEIVE_TIMEOUT;
100// A connection will be declared dead if it has not received anything for this
101// long.
102extern const int DEAD_CONNECTION_RECEIVE_TIMEOUT;
Qingsi Wang866e08d2018-03-22 17:54:23 -0700103// This is the length of time that we wait for a ping response to come back.
104extern const int CONNECTION_RESPONSE_TIMEOUT;
105// The minimum time we will wait before destroying a connection after creating
106// it.
107extern const int MIN_CONNECTION_LIFETIME;
Mirko Bonadei5f4d47b2018-08-22 17:41:22 +0000108
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000109} // namespace cricket
110
Steve Anton10542f22019-01-11 09:11:00 -0800111#endif // P2P_BASE_P2P_CONSTANTS_H_