blob: ee0cca240282b19632197e9bd3dc04b52b521386 [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
11// P2PTransportChannel wraps up the state management of the connection between
12// two P2P clients. Clients have candidate ports for connecting, and
13// connections which are combinations of candidates from each end (Alice and
14// Bob each have candidates, one candidate from Alice and one candidate from
15// Bob are used to make a connection, repeat to make many connections).
16//
17// When all of the available connections become invalid (non-writable), we
18// kick off a process of determining more candidates and more connections.
19//
Steve Anton10542f22019-01-11 09:11:00 -080020#ifndef P2P_BASE_P2P_TRANSPORT_CHANNEL_H_
21#define P2P_BASE_P2P_TRANSPORT_CHANNEL_H_
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000022
Qingsi Wange6826d22018-03-08 14:55:14 -080023#include <algorithm>
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000024#include <map>
kwiberg3ec46792016-04-27 07:22:53 -070025#include <memory>
guoweis36f01372016-03-02 18:02:40 -080026#include <set>
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000027#include <string>
28#include <vector>
kwiberg4485ffb2016-04-26 08:14:39 -070029
Steve Anton10542f22019-01-11 09:11:00 -080030#include "api/async_resolver_factory.h"
Patrik Höglunde2d6a062017-10-05 14:53:33 +020031#include "api/candidate.h"
Steve Anton10542f22019-01-11 09:11:00 -080032#include "api/rtc_error.h"
Qingsi Wang93a84392018-01-30 17:13:09 -080033#include "logging/rtc_event_log/events/rtc_event_ice_candidate_pair_config.h"
Steve Anton10542f22019-01-11 09:11:00 -080034#include "logging/rtc_event_log/ice_logger.h"
35#include "p2p/base/candidate_pair_interface.h"
Jonas Oreland09c452e2019-11-20 09:01:02 +010036#include "p2p/base/ice_controller_interface.h"
Steve Anton10542f22019-01-11 09:11:00 -080037#include "p2p/base/ice_transport_internal.h"
38#include "p2p/base/p2p_constants.h"
39#include "p2p/base/port_allocator.h"
40#include "p2p/base/port_interface.h"
41#include "p2p/base/regathering_controller.h"
42#include "rtc_base/async_invoker.h"
43#include "rtc_base/async_packet_socket.h"
44#include "rtc_base/constructor_magic.h"
Jonas Olsson941a07c2018-09-13 10:07:07 +020045#include "rtc_base/strings/string_builder.h"
Mirko Bonadeiac194142018-10-22 17:08:37 +020046#include "rtc_base/system/rtc_export.h"
Artem Titove41c4332018-07-25 15:04:28 +020047#include "rtc_base/third_party/sigslot/sigslot.h"
Harald Alvestrand36bc4f82019-05-27 15:49:31 +020048#include "rtc_base/thread_annotations.h"
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000049
Qingsi Wang93a84392018-01-30 17:13:09 -080050namespace webrtc {
51class RtcEventLog;
52} // namespace webrtc
53
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000054namespace cricket {
55
Honghai Zhangd93f50c2016-10-05 11:47:22 -070056// Enum for UMA metrics, used to record whether the channel is
57// connected/connecting/disconnected when ICE restart happens.
58enum class IceRestartState { CONNECTING, CONNECTED, DISCONNECTED, MAX_VALUE };
59
honghaiz524ecc22016-05-25 12:48:31 -070060static const int MIN_PINGS_AT_WEAK_PING_INTERVAL = 3;
guoweisb0bb77f2015-10-26 15:10:01 -070061
Taylor Brandstetter6e2e7ce2017-12-19 10:26:23 -080062bool IceCredentialsChanged(const std::string& old_ufrag,
63 const std::string& old_pwd,
64 const std::string& new_ufrag,
65 const std::string& new_pwd);
66
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000067// Adds the port on which the candidate originated.
68class RemoteCandidate : public Candidate {
69 public:
70 RemoteCandidate(const Candidate& c, PortInterface* origin_port)
71 : Candidate(c), origin_port_(origin_port) {}
72
73 PortInterface* origin_port() { return origin_port_; }
74
75 private:
76 PortInterface* origin_port_;
77};
78
Jonas Oreland4af78822019-10-11 08:17:06 +020079struct IceFieldTrials {
80 bool skip_relay_to_non_relay_connections = false;
Jonas Orelandc6404a12019-10-14 15:52:15 +020081 absl::optional<int> max_outstanding_pings;
Jonas Oreland1230fb72019-10-25 15:58:14 +020082
83 // Wait X ms before selecting a connection when having none.
84 // This will make media slower, but will give us chance to find
85 // a better connection before starting.
86 absl::optional<int> initial_select_dampening;
87
88 // If the connection has recevied a ping-request, delay by
89 // maximum this delay. This will make media slower, but will
90 // give us chance to find a better connection before starting.
91 absl::optional<int> initial_select_dampening_ping_received;
Jonas Oreland4af78822019-10-11 08:17:06 +020092};
93
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000094// P2PTransportChannel manages the candidates and connection process to keep
95// two P2P clients connected to each other.
Mirko Bonadeiac194142018-10-22 17:08:37 +020096class RTC_EXPORT P2PTransportChannel : public IceTransportInternal {
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +000097 public:
Zach Steine20867f2018-08-02 13:20:15 -070098 // For testing only.
99 // TODO(zstein): Remove once AsyncResolverFactory is required.
100 P2PTransportChannel(const std::string& transport_name,
101 int component,
102 PortAllocator* allocator);
deadbeefcbecd352015-09-23 11:50:27 -0700103 P2PTransportChannel(const std::string& transport_name,
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000104 int component,
Qingsi Wang93a84392018-01-30 17:13:09 -0800105 PortAllocator* allocator,
Zach Steine20867f2018-08-02 13:20:15 -0700106 webrtc::AsyncResolverFactory* async_resolver_factory,
Qingsi Wang93a84392018-01-30 17:13:09 -0800107 webrtc::RtcEventLog* event_log = nullptr);
Steve Anton33f69db2017-10-30 10:01:15 -0700108 ~P2PTransportChannel() override;
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000109
110 // From TransportChannelImpl:
zhihuangd06adf62017-01-12 15:58:31 -0800111 IceTransportState GetState() const override;
Jonas Olsson81125f02018-10-09 10:52:04 +0200112 webrtc::IceTransportState GetIceTransportState() const override;
113
Steve Anton33f69db2017-10-30 10:01:15 -0700114 const std::string& transport_name() const override;
115 int component() const override;
116 bool writable() const override;
117 bool receiving() const override;
Henrik Boströmf3ecdb92015-09-08 12:11:54 +0200118 void SetIceRole(IceRole role) override;
Steve Anton33f69db2017-10-30 10:01:15 -0700119 IceRole GetIceRole() const override;
Peter Boström0c4e06b2015-10-07 12:23:21 +0200120 void SetIceTiebreaker(uint64_t tiebreaker) override;
Honghai Zhang4cedf2b2016-08-31 08:18:11 -0700121 void SetIceParameters(const IceParameters& ice_params) override;
122 void SetRemoteIceParameters(const IceParameters& ice_params) override;
Henrik Boströmf3ecdb92015-09-08 12:11:54 +0200123 void SetRemoteIceMode(IceMode mode) override;
deadbeef886815b2016-06-29 15:21:04 -0700124 // TODO(deadbeef): Deprecated. Remove when Chromium's
125 // IceTransportChannel does not depend on this.
126 void Connect() {}
deadbeefcbecd352015-09-23 11:50:27 -0700127 void MaybeStartGathering() override;
Steve Anton33f69db2017-10-30 10:01:15 -0700128 IceGatheringState gathering_state() const override;
Zach Stein6fcdc2f2018-08-23 16:25:55 -0700129 void ResolveHostnameCandidate(const Candidate& candidate);
deadbeefcbecd352015-09-23 11:50:27 -0700130 void AddRemoteCandidate(const Candidate& candidate) override;
Honghai Zhang7fb69db2016-03-14 11:59:18 -0700131 void RemoveRemoteCandidate(const Candidate& candidate) override;
Harald Alvestrand4241cf52019-01-21 09:29:42 +0100132 void RemoveAllRemoteCandidates() override;
Honghai Zhang049fbb12016-03-07 11:13:07 -0800133 // Sets the parameters in IceConfig. We do not set them blindly. Instead, we
134 // only update the parameter if it is considered set in |config|. For example,
135 // a negative value of receiving_timeout will be considered "not set" and we
136 // will not use it to update the respective parameter in |config_|.
Danil Chapovalov00c71832018-06-15 15:58:38 +0200137 // TODO(deadbeef): Use absl::optional instead of negative values.
honghaiz1f429e32015-09-28 07:57:34 -0700138 void SetIceConfig(const IceConfig& config) override;
guoweis36f01372016-03-02 18:02:40 -0800139 const IceConfig& config() const;
Qingsi Wangdea68892018-03-27 10:55:21 -0700140 static webrtc::RTCError ValidateIceConfig(const IceConfig& config);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000141
142 // From TransportChannel:
deadbeefcbecd352015-09-23 11:50:27 -0700143 int SendPacket(const char* data,
144 size_t len,
145 const rtc::PacketOptions& options,
146 int flags) override;
Henrik Boströmf3ecdb92015-09-08 12:11:54 +0200147 int SetOption(rtc::Socket::Option opt, int value) override;
148 bool GetOption(rtc::Socket::Option opt, int* value) override;
Steve Anton33f69db2017-10-30 10:01:15 -0700149 int GetError() override;
Jonas Oreland149dc722019-08-28 08:10:27 +0200150 bool GetStats(IceTransportStats* ice_transport_stats) override;
Danil Chapovalov00c71832018-06-15 15:58:38 +0200151 absl::optional<int> GetRttEstimate() override;
Harald Alvestrand4241cf52019-01-21 09:29:42 +0100152 const Connection* selected_connection() const override;
Qingsi Wange5defb12019-08-15 11:01:53 -0700153 absl::optional<const CandidatePair> GetSelectedCandidatePair() const override;
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000154
Honghai Zhang8cd7f222016-06-23 13:44:34 -0700155 // TODO(honghaiz): Remove this method once the reference of it in
156 // Chromoting is removed.
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200157 const Connection* best_connection() const {
158 RTC_DCHECK_RUN_ON(network_thread_);
159 return selected_connection_;
160 }
Honghai Zhang8cd7f222016-06-23 13:44:34 -0700161
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200162 void set_incoming_only(bool value) {
163 RTC_DCHECK_RUN_ON(network_thread_);
164 incoming_only_ = value;
165 }
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000166
Honghai Zhanga74363c2016-07-28 18:06:15 -0700167 // Note: These are only for testing purpose.
168 // |ports_| and |pruned_ports| should not be changed from outside.
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200169 const std::vector<PortInterface*>& ports() {
170 RTC_DCHECK_RUN_ON(network_thread_);
171 return ports_;
172 }
173 const std::vector<PortInterface*>& pruned_ports() {
174 RTC_DCHECK_RUN_ON(network_thread_);
175 return pruned_ports_;
176 }
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000177
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200178 IceMode remote_ice_mode() const {
179 RTC_DCHECK_RUN_ON(network_thread_);
180 return remote_ice_mode_;
181 }
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000182
Honghai Zhanga74363c2016-07-28 18:06:15 -0700183 void PruneAllPorts();
Qingsi Wang866e08d2018-03-22 17:54:23 -0700184 int check_receiving_interval() const;
Danil Chapovalov00c71832018-06-15 15:58:38 +0200185 absl::optional<rtc::NetworkRoute> network_route() const override;
Zhi Huang942bc2e2017-11-13 13:26:07 -0800186
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000187 // Helper method used only in unittest.
188 rtc::DiffServCodePoint DefaultDscpValue() const;
189
Peter Thatcher7351f462015-04-02 16:39:16 -0700190 // Public for unit tests.
191 Connection* FindNextPingableConnection();
guoweis36f01372016-03-02 18:02:40 -0800192 void MarkConnectionPinged(Connection* conn);
Peter Thatcher7351f462015-04-02 16:39:16 -0700193
honghaiz77d0d6e2015-10-27 11:34:45 -0700194 // Public for unit tests.
Jonas Oreland09c452e2019-11-20 09:01:02 +0100195 rtc::ArrayView<Connection*> connections() const;
honghaiz77d0d6e2015-10-27 11:34:45 -0700196
honghaiz9b669572015-11-04 12:07:44 -0800197 // Public for unit tests.
Qingsi Wang1b368942018-06-13 13:54:08 -0700198 PortAllocatorSession* allocator_session() const {
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200199 RTC_DCHECK_RUN_ON(network_thread_);
Qingsi Wang1b368942018-06-13 13:54:08 -0700200 if (allocator_sessions_.empty()) {
201 return nullptr;
202 }
Taylor Brandstettera1c30352016-05-13 08:15:11 -0700203 return allocator_sessions_.back().get();
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000204 }
205
honghaiz112fe432015-12-30 13:32:47 -0800206 // Public for unit tests.
207 const std::vector<RemoteCandidate>& remote_candidates() const {
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200208 RTC_DCHECK_RUN_ON(network_thread_);
honghaiz112fe432015-12-30 13:32:47 -0800209 return remote_candidates_;
210 }
211
zhihuangd06adf62017-01-12 15:58:31 -0800212 std::string ToString() const {
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200213 RTC_DCHECK_RUN_ON(network_thread_);
Jonas Olsson941a07c2018-09-13 10:07:07 +0200214 const std::string RECEIVING_ABBREV[2] = {"_", "R"};
215 const std::string WRITABLE_ABBREV[2] = {"_", "W"};
216 rtc::StringBuilder ss;
zhihuangd06adf62017-01-12 15:58:31 -0800217 ss << "Channel[" << transport_name_ << "|" << component_ << "|"
218 << RECEIVING_ABBREV[receiving_] << WRITABLE_ABBREV[writable_] << "]";
Jonas Olsson84df1c72018-09-14 16:59:32 +0200219 return ss.Release();
zhihuangd06adf62017-01-12 15:58:31 -0800220 }
221
honghaiz9b669572015-11-04 12:07:44 -0800222 private:
johan0fd22ef2016-09-29 01:19:20 -0700223 rtc::Thread* thread() const { return network_thread_; }
Qingsi Wang1b368942018-06-13 13:54:08 -0700224
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200225 bool IsGettingPorts() {
226 RTC_DCHECK_RUN_ON(network_thread_);
227 return allocator_session()->IsGettingPorts();
228 }
honghaiz9b669572015-11-04 12:07:44 -0800229
Honghai Zhange05bcc22016-08-16 18:19:14 -0700230 // Returns true if it's possible to send packets on |connection|.
231 bool ReadyToSend(Connection* connection) const;
Jonas Oreland09c452e2019-11-20 09:01:02 +0100232 bool PresumedWritable(const Connection* conn) const;
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000233 void UpdateConnectionStates();
Jonas Oreland09c452e2019-11-20 09:01:02 +0100234 void RequestSortAndStateUpdate(IceControllerEvent reason_to_sort);
Taylor Brandstetterb825aee2016-06-29 13:07:16 -0700235 // Start pinging if we haven't already started, and we now have a connection
236 // that's pingable.
237 void MaybeStartPinging();
deadbeef14f97f52016-06-22 17:14:15 -0700238
Jonas Oreland09c452e2019-11-20 09:01:02 +0100239 void SortConnectionsAndUpdateState(IceControllerEvent reason_to_sort);
240 void SortConnections();
241 void SortConnectionsIfNeeded();
242 void SwitchSelectedConnection(Connection* conn, IceControllerEvent reason);
Honghai Zhang381b4212015-12-04 12:24:03 -0800243 void UpdateState();
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000244 void HandleAllTimedOut();
honghaiz9b669572015-11-04 12:07:44 -0800245 void MaybeStopPortAllocatorSessions();
Jonas Olsson81125f02018-10-09 10:52:04 +0200246
247 // ComputeIceTransportState computes the RTCIceTransportState as described in
248 // https://w3c.github.io/webrtc-pc/#dom-rtcicetransportstate. ComputeState
249 // computes the value we currently export as RTCIceTransportState.
250 // TODO(bugs.webrtc.org/9308): Remove ComputeState once it's no longer used.
zhihuangd06adf62017-01-12 15:58:31 -0800251 IceTransportState ComputeState() const;
Jonas Olsson81125f02018-10-09 10:52:04 +0200252 webrtc::IceTransportState ComputeIceTransportState() const;
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000253
Peter Thatcher04ac81f2015-09-21 11:48:28 -0700254 bool CreateConnections(const Candidate& remote_candidate,
255 PortInterface* origin_port);
256 bool CreateConnection(PortInterface* port,
257 const Candidate& remote_candidate,
258 PortInterface* origin_port);
Jonas Oreland09c452e2019-11-20 09:01:02 +0100259 bool FindConnection(Connection* connection) const;
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000260
Peter Boström0c4e06b2015-10-07 12:23:21 +0200261 uint32_t GetRemoteCandidateGeneration(const Candidate& candidate);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000262 bool IsDuplicateRemoteCandidate(const Candidate& candidate);
263 void RememberRemoteCandidate(const Candidate& remote_candidate,
264 PortInterface* origin_port);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000265 void PingConnection(Connection* conn);
Taylor Brandstettera1c30352016-05-13 08:15:11 -0700266 void AddAllocatorSession(std::unique_ptr<PortAllocatorSession> session);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000267 void AddConnection(Connection* connection);
268
Yves Gerey665174f2018-06-19 15:03:05 +0200269 void OnPortReady(PortAllocatorSession* session, PortInterface* port);
Honghai Zhang8eeecab2016-07-28 13:20:15 -0700270 void OnPortsPruned(PortAllocatorSession* session,
271 const std::vector<PortInterface*>& ports);
Yves Gerey665174f2018-06-19 15:03:05 +0200272 void OnCandidatesReady(PortAllocatorSession* session,
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000273 const std::vector<Candidate>& candidates);
Eldar Relloda13ea22019-06-01 12:23:43 +0300274 void OnCandidateError(PortAllocatorSession* session,
275 const IceCandidateErrorEvent& event);
Honghai Zhang5622c5e2016-07-01 13:59:29 -0700276 void OnCandidatesRemoved(PortAllocatorSession* session,
277 const std::vector<Candidate>& candidates);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000278 void OnCandidatesAllocationDone(PortAllocatorSession* session);
279 void OnUnknownAddress(PortInterface* port,
280 const rtc::SocketAddress& addr,
281 ProtocolType proto,
282 IceMessage* stun_msg,
283 const std::string& remote_username,
284 bool port_muxed);
Qingsi Wangc129c352019-04-18 10:41:58 -0700285 void OnCandidateFilterChanged(uint32_t prev_filter, uint32_t cur_filter);
Honghai Zhang5622c5e2016-07-01 13:59:29 -0700286
287 // When a port is destroyed, remove it from both lists |ports_|
Honghai Zhang8eeecab2016-07-28 13:20:15 -0700288 // and |pruned_ports_|.
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000289 void OnPortDestroyed(PortInterface* port);
Honghai Zhang8eeecab2016-07-28 13:20:15 -0700290 // When pruning a port, move it from |ports_| to |pruned_ports_|.
Honghai Zhang5622c5e2016-07-01 13:59:29 -0700291 // Returns true if the port is found and removed from |ports_|.
Honghai Zhanga74363c2016-07-28 18:06:15 -0700292 bool PrunePort(PortInterface* port);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000293 void OnRoleConflict(PortInterface* port);
294
295 void OnConnectionStateChange(Connection* connection);
Yves Gerey665174f2018-06-19 15:03:05 +0200296 void OnReadPacket(Connection* connection,
297 const char* data,
298 size_t len,
Niels Möllere6933812018-11-05 13:01:41 +0100299 int64_t packet_time_us);
Stefan Holmer55674ff2016-01-14 15:49:16 +0100300 void OnSentPacket(const rtc::SentPacket& sent_packet);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000301 void OnReadyToSend(Connection* connection);
Yves Gerey665174f2018-06-19 15:03:05 +0200302 void OnConnectionDestroyed(Connection* connection);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000303
honghaiz5a3acd82015-08-20 15:53:17 -0700304 void OnNominated(Connection* conn);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000305
Qingsi Wang502db3d2018-05-16 17:01:37 -0700306 void CheckAndPing();
Peter Thatcher54360512015-07-08 11:08:35 -0700307
Bjorn Terelius59b4e3e2018-05-30 17:14:08 +0200308 void LogCandidatePairConfig(Connection* conn,
309 webrtc::IceCandidatePairConfigType type);
Qingsi Wang93a84392018-01-30 17:13:09 -0800310
Honghai Zhang8cd8f812016-08-03 19:50:41 -0700311 uint32_t GetNominationAttr(Connection* conn) const;
Jonas Oreland09c452e2019-11-20 09:01:02 +0100312 bool GetUseCandidateAttr(Connection* conn) const;
Honghai Zhang8cd8f812016-08-03 19:50:41 -0700313
honghaiz9ad0db52016-07-14 19:30:28 -0700314 // Returns true if the new_connection is selected for transmission.
315 bool MaybeSwitchSelectedConnection(Connection* new_connection,
Jonas Oreland09c452e2019-11-20 09:01:02 +0100316 IceControllerEvent reason);
317 bool MaybeSwitchSelectedConnection(
318 IceControllerEvent reason,
319 IceControllerInterface::SwitchResult result);
honghaiz5a3acd82015-08-20 15:53:17 -0700320 void PruneConnections();
guoweis36f01372016-03-02 18:02:40 -0800321
honghaiza54a0802015-12-16 18:37:23 -0800322 // Returns the latest remote ICE parameters or nullptr if there are no remote
323 // ICE parameters yet.
324 IceParameters* remote_ice() {
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200325 RTC_DCHECK_RUN_ON(network_thread_);
honghaiza54a0802015-12-16 18:37:23 -0800326 return remote_ice_parameters_.empty() ? nullptr
327 : &remote_ice_parameters_.back();
328 }
honghaiz112fe432015-12-30 13:32:47 -0800329 // Returns the remote IceParameters and generation that match |ufrag|
330 // if found, and returns nullptr otherwise.
331 const IceParameters* FindRemoteIceFromUfrag(const std::string& ufrag,
332 uint32_t* generation);
honghaiza54a0802015-12-16 18:37:23 -0800333 // Returns the index of the latest remote ICE parameters, or 0 if no remote
334 // ICE parameters have been received.
335 uint32_t remote_ice_generation() {
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200336 RTC_DCHECK_RUN_ON(network_thread_);
honghaiza54a0802015-12-16 18:37:23 -0800337 return remote_ice_parameters_.empty()
338 ? 0
339 : static_cast<uint32_t>(remote_ice_parameters_.size() - 1);
340 }
341
Steve Anton300bf8e2017-07-14 10:13:10 -0700342 // Indicates if the given local port has been pruned.
343 bool IsPortPruned(const Port* port) const;
344
345 // Indicates if the given remote candidate has been pruned.
346 bool IsRemoteCandidatePruned(const Candidate& cand) const;
347
zhihuangd06adf62017-01-12 15:58:31 -0800348 // Sets the writable state, signaling if necessary.
Jonas Olsson7a6739e2019-01-15 16:31:55 +0100349 void SetWritable(bool writable);
zhihuangd06adf62017-01-12 15:58:31 -0800350 // Sets the receiving state, signaling if necessary.
Jonas Olsson7a6739e2019-01-15 16:31:55 +0100351 void SetReceiving(bool receiving);
Qingsi Wang7627fdd2019-08-19 16:07:40 -0700352 // Clears the address and the related address fields of a local candidate to
353 // avoid IP leakage. This is applicable in several scenarios as commented in
354 // |PortAllocator::SanitizeCandidate|.
355 Candidate SanitizeLocalCandidate(const Candidate& c) const;
356 // Clears the address field of a remote candidate to avoid IP leakage. This is
357 // applicable in the following scenarios:
358 // 1. mDNS candidates are received.
359 // 2. Peer-reflexive remote candidates.
360 Candidate SanitizeRemoteCandidate(const Candidate& c) const;
zhihuangd06adf62017-01-12 15:58:31 -0800361
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200362 std::string transport_name_ RTC_GUARDED_BY(network_thread_);
363 int component_ RTC_GUARDED_BY(network_thread_);
364 PortAllocator* allocator_ RTC_GUARDED_BY(network_thread_);
365 webrtc::AsyncResolverFactory* async_resolver_factory_
366 RTC_GUARDED_BY(network_thread_);
johan0fd22ef2016-09-29 01:19:20 -0700367 rtc::Thread* network_thread_;
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200368 bool incoming_only_ RTC_GUARDED_BY(network_thread_);
369 int error_ RTC_GUARDED_BY(network_thread_);
370 std::vector<std::unique_ptr<PortAllocatorSession>> allocator_sessions_
371 RTC_GUARDED_BY(network_thread_);
deadbeefdfc42442016-06-21 14:19:48 -0700372 // |ports_| contains ports that are used to form new connections when
373 // new remote candidates are added.
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200374 std::vector<PortInterface*> ports_ RTC_GUARDED_BY(network_thread_);
Honghai Zhang8eeecab2016-07-28 13:20:15 -0700375 // |pruned_ports_| contains ports that have been removed from |ports_| and
deadbeefdfc42442016-06-21 14:19:48 -0700376 // are not being used to form new connections, but that aren't yet destroyed.
377 // They may have existing connections, and they still fire signals such as
378 // SignalUnknownAddress.
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200379 std::vector<PortInterface*> pruned_ports_ RTC_GUARDED_BY(network_thread_);
guoweis36f01372016-03-02 18:02:40 -0800380
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200381 Connection* selected_connection_ RTC_GUARDED_BY(network_thread_) = nullptr;
guoweis36f01372016-03-02 18:02:40 -0800382
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200383 std::vector<RemoteCandidate> remote_candidates_
384 RTC_GUARDED_BY(network_thread_);
385 bool sort_dirty_ RTC_GUARDED_BY(
386 network_thread_); // indicates whether another sort is needed right now
387 bool had_connection_ RTC_GUARDED_BY(network_thread_) =
388 false; // if connections_ has ever been nonempty
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000389 typedef std::map<rtc::Socket::Option, int> OptionMap;
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200390 OptionMap options_ RTC_GUARDED_BY(network_thread_);
391 IceParameters ice_parameters_ RTC_GUARDED_BY(network_thread_);
392 std::vector<IceParameters> remote_ice_parameters_
393 RTC_GUARDED_BY(network_thread_);
394 IceMode remote_ice_mode_ RTC_GUARDED_BY(network_thread_);
395 IceRole ice_role_ RTC_GUARDED_BY(network_thread_);
396 uint64_t tiebreaker_ RTC_GUARDED_BY(network_thread_);
397 IceGatheringState gathering_state_ RTC_GUARDED_BY(network_thread_);
398 std::unique_ptr<webrtc::BasicRegatheringController> regathering_controller_
399 RTC_GUARDED_BY(network_thread_);
400 int64_t last_ping_sent_ms_ RTC_GUARDED_BY(network_thread_) = 0;
401 int weak_ping_interval_ RTC_GUARDED_BY(network_thread_) = WEAK_PING_INTERVAL;
Jonas Olsson81125f02018-10-09 10:52:04 +0200402 // TODO(jonasolsson): Remove state_ and rename standardized_state_ once state_
403 // is no longer used to compute the ICE connection state.
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200404 IceTransportState state_ RTC_GUARDED_BY(network_thread_) =
405 IceTransportState::STATE_INIT;
406 webrtc::IceTransportState standardized_state_
407 RTC_GUARDED_BY(network_thread_) = webrtc::IceTransportState::kNew;
408 IceConfig config_ RTC_GUARDED_BY(network_thread_);
409 int last_sent_packet_id_ RTC_GUARDED_BY(network_thread_) =
410 -1; // -1 indicates no packet was sent before.
411 bool started_pinging_ RTC_GUARDED_BY(network_thread_) = false;
Honghai Zhang8cd8f812016-08-03 19:50:41 -0700412 // The value put in the "nomination" attribute for the next nominated
413 // connection. A zero-value indicates the connection will not be nominated.
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200414 uint32_t nomination_ RTC_GUARDED_BY(network_thread_) = 0;
415 bool receiving_ RTC_GUARDED_BY(network_thread_) = false;
416 bool writable_ RTC_GUARDED_BY(network_thread_) = false;
417 bool has_been_writable_ RTC_GUARDED_BY(network_thread_) =
418 false; // if writable_ has ever been true
Peter Thatcher54360512015-07-08 11:08:35 -0700419
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200420 rtc::AsyncInvoker invoker_ RTC_GUARDED_BY(network_thread_);
421 absl::optional<rtc::NetworkRoute> network_route_
422 RTC_GUARDED_BY(network_thread_);
423 webrtc::IceEventLog ice_event_log_ RTC_GUARDED_BY(network_thread_);
Qingsi Wang93a84392018-01-30 17:13:09 -0800424
Jonas Oreland09c452e2019-11-20 09:01:02 +0100425 std::unique_ptr<IceControllerInterface> ice_controller_
426 RTC_GUARDED_BY(network_thread_);
427
Zach Stein6fcdc2f2018-08-23 16:25:55 -0700428 struct CandidateAndResolver final {
429 CandidateAndResolver(const Candidate& candidate,
430 rtc::AsyncResolverInterface* resolver);
431 ~CandidateAndResolver();
432 Candidate candidate_;
433 rtc::AsyncResolverInterface* resolver_;
434 };
Harald Alvestrand36bc4f82019-05-27 15:49:31 +0200435 std::vector<CandidateAndResolver> resolvers_ RTC_GUARDED_BY(network_thread_);
Zach Stein6fcdc2f2018-08-23 16:25:55 -0700436 void FinishAddingRemoteCandidate(const Candidate& new_remote_candidate);
437 void OnCandidateResolved(rtc::AsyncResolverInterface* resolver);
438 void AddRemoteCandidateWithResolver(Candidate candidate,
439 rtc::AsyncResolverInterface* resolver);
440
Jonas Oreland149dc722019-08-28 08:10:27 +0200441 // Number of times the selected_connection_ has been modified.
442 uint32_t selected_candidate_pair_changes_ = 0;
443
Jonas Oreland4af78822019-10-11 08:17:06 +0200444 IceFieldTrials field_trials_;
445
henrikg3c089d72015-09-16 05:37:44 -0700446 RTC_DISALLOW_COPY_AND_ASSIGN(P2PTransportChannel);
henrike@webrtc.org269fb4b2014-10-28 22:20:11 +0000447};
448
449} // namespace cricket
450
Steve Anton10542f22019-01-11 09:11:00 -0800451#endif // P2P_BASE_P2P_TRANSPORT_CHANNEL_H_