Index: webrtc/p2p/base/transportcontroller.cc |
diff --git a/webrtc/p2p/base/transportcontroller.cc b/webrtc/p2p/base/transportcontroller.cc |
deleted file mode 100644 |
index 4d9e403d3b8abe53393d8f9445035e0a68ee35e3..0000000000000000000000000000000000000000 |
--- a/webrtc/p2p/base/transportcontroller.cc |
+++ /dev/null |
@@ -1,575 +0,0 @@ |
-/* |
- * Copyright 2015 The WebRTC Project Authors. All rights reserved. |
- * |
- * Use of this source code is governed by a BSD-style license |
- * that can be found in the LICENSE file in the root of the source |
- * tree. An additional intellectual property rights grant can be found |
- * in the file PATENTS. All contributing project authors may |
- * be found in the AUTHORS file in the root of the source tree. |
- */ |
- |
-#include "webrtc/p2p/base/transportcontroller.h" |
- |
-#include "webrtc/base/bind.h" |
-#include "webrtc/base/checks.h" |
-#include "webrtc/base/thread.h" |
-#include "webrtc/p2p/base/dtlstransport.h" |
-#include "webrtc/p2p/base/p2ptransport.h" |
- |
-namespace cricket { |
- |
-enum { |
- MSG_ICECONNECTIONSTATE, |
- MSG_RECEIVING, |
- MSG_ICEGATHERINGSTATE, |
- MSG_CANDIDATESGATHERED, |
-}; |
- |
-struct CandidatesData : public rtc::MessageData { |
- CandidatesData(const std::string& transport_name, |
- const Candidates& candidates) |
- : transport_name(transport_name), candidates(candidates) {} |
- |
- std::string transport_name; |
- Candidates candidates; |
-}; |
- |
-TransportController::TransportController(rtc::Thread* signaling_thread, |
- rtc::Thread* worker_thread, |
- PortAllocator* port_allocator) |
- : signaling_thread_(signaling_thread), |
- worker_thread_(worker_thread), |
- port_allocator_(port_allocator) {} |
- |
-TransportController::~TransportController() { |
- worker_thread_->Invoke<void>( |
- rtc::Bind(&TransportController::DestroyAllTransports_w, this)); |
- signaling_thread_->Clear(this); |
-} |
- |
-bool TransportController::SetSslMaxProtocolVersion( |
- rtc::SSLProtocolVersion version) { |
- return worker_thread_->Invoke<bool>(rtc::Bind( |
- &TransportController::SetSslMaxProtocolVersion_w, this, version)); |
-} |
- |
-void TransportController::SetIceConnectionReceivingTimeout(int timeout_ms) { |
- worker_thread_->Invoke<void>( |
- rtc::Bind(&TransportController::SetIceConnectionReceivingTimeout_w, this, |
- timeout_ms)); |
-} |
- |
-void TransportController::SetIceRole(IceRole ice_role) { |
- worker_thread_->Invoke<void>( |
- rtc::Bind(&TransportController::SetIceRole_w, this, ice_role)); |
-} |
- |
-bool TransportController::GetSslRole(rtc::SSLRole* role) { |
- return worker_thread_->Invoke<bool>( |
- rtc::Bind(&TransportController::GetSslRole_w, this, role)); |
-} |
- |
-bool TransportController::SetLocalCertificate( |
- const rtc::scoped_refptr<rtc::RTCCertificate>& certificate) { |
- return worker_thread_->Invoke<bool>(rtc::Bind( |
- &TransportController::SetLocalCertificate_w, this, certificate)); |
-} |
- |
-bool TransportController::GetLocalCertificate( |
- const std::string& transport_name, |
- rtc::scoped_refptr<rtc::RTCCertificate>* certificate) { |
- return worker_thread_->Invoke<bool>( |
- rtc::Bind(&TransportController::GetLocalCertificate_w, this, |
- transport_name, certificate)); |
-} |
- |
-bool TransportController::GetRemoteSSLCertificate( |
- const std::string& transport_name, |
- rtc::SSLCertificate** cert) { |
- return worker_thread_->Invoke<bool>( |
- rtc::Bind(&TransportController::GetRemoteSSLCertificate_w, this, |
- transport_name, cert)); |
-} |
- |
-bool TransportController::SetLocalTransportDescription( |
- const std::string& transport_name, |
- const TransportDescription& tdesc, |
- ContentAction action, |
- std::string* err) { |
- return worker_thread_->Invoke<bool>( |
- rtc::Bind(&TransportController::SetLocalTransportDescription_w, this, |
- transport_name, tdesc, action, err)); |
-} |
- |
-bool TransportController::SetRemoteTransportDescription( |
- const std::string& transport_name, |
- const TransportDescription& tdesc, |
- ContentAction action, |
- std::string* err) { |
- return worker_thread_->Invoke<bool>( |
- rtc::Bind(&TransportController::SetRemoteTransportDescription_w, this, |
- transport_name, tdesc, action, err)); |
-} |
- |
-void TransportController::MaybeStartGathering() { |
- worker_thread_->Invoke<void>( |
- rtc::Bind(&TransportController::MaybeStartGathering_w, this)); |
-} |
- |
-bool TransportController::AddRemoteCandidates(const std::string& transport_name, |
- const Candidates& candidates, |
- std::string* err) { |
- return worker_thread_->Invoke<bool>( |
- rtc::Bind(&TransportController::AddRemoteCandidates_w, this, |
- transport_name, candidates, err)); |
-} |
- |
-bool TransportController::ReadyForRemoteCandidates( |
- const std::string& transport_name) { |
- return worker_thread_->Invoke<bool>(rtc::Bind( |
- &TransportController::ReadyForRemoteCandidates_w, this, transport_name)); |
-} |
- |
-bool TransportController::GetStats(const std::string& transport_name, |
- TransportStats* stats) { |
- return worker_thread_->Invoke<bool>( |
- rtc::Bind(&TransportController::GetStats_w, this, transport_name, stats)); |
-} |
- |
-TransportChannel* TransportController::CreateTransportChannel_w( |
- const std::string& transport_name, |
- int component) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- Transport* transport = GetOrCreateTransport_w(transport_name); |
- return transport->CreateChannel(component); |
-} |
- |
-void TransportController::DestroyTransportChannel_w( |
- const std::string& transport_name, |
- int component) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- Transport* transport = GetTransport_w(transport_name); |
- if (!transport) { |
- ASSERT(false); |
- return; |
- } |
- transport->DestroyChannel(component); |
- |
- // Just as we create a Transport when its first channel is created, |
- // we delete it when its last channel is deleted. |
- if (!transport->HasChannels()) { |
- DestroyTransport_w(transport_name); |
- } |
-} |
- |
-const rtc::scoped_refptr<rtc::RTCCertificate>& |
-TransportController::certificate_for_testing() { |
- return certificate_; |
-} |
- |
-Transport* TransportController::CreateTransport_w( |
- const std::string& transport_name) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- Transport* transport = new DtlsTransport<P2PTransport>( |
- transport_name, port_allocator(), certificate_); |
- return transport; |
-} |
- |
-Transport* TransportController::GetTransport_w( |
- const std::string& transport_name) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- auto iter = transports_.find(transport_name); |
- return (iter != transports_.end()) ? iter->second : nullptr; |
-} |
- |
-void TransportController::OnMessage(rtc::Message* pmsg) { |
- RTC_DCHECK(signaling_thread_->IsCurrent()); |
- |
- switch (pmsg->message_id) { |
- case MSG_ICECONNECTIONSTATE: { |
- rtc::TypedMessageData<IceConnectionState>* data = |
- static_cast<rtc::TypedMessageData<IceConnectionState>*>(pmsg->pdata); |
- SignalConnectionState(data->data()); |
- delete data; |
- break; |
- } |
- case MSG_RECEIVING: { |
- rtc::TypedMessageData<bool>* data = |
- static_cast<rtc::TypedMessageData<bool>*>(pmsg->pdata); |
- SignalReceiving(data->data()); |
- delete data; |
- break; |
- } |
- case MSG_ICEGATHERINGSTATE: { |
- rtc::TypedMessageData<IceGatheringState>* data = |
- static_cast<rtc::TypedMessageData<IceGatheringState>*>(pmsg->pdata); |
- SignalGatheringState(data->data()); |
- delete data; |
- break; |
- } |
- case MSG_CANDIDATESGATHERED: { |
- CandidatesData* data = static_cast<CandidatesData*>(pmsg->pdata); |
- SignalCandidatesGathered(data->transport_name, data->candidates); |
- delete data; |
- break; |
- } |
- default: |
- ASSERT(false); |
- } |
-} |
- |
-Transport* TransportController::GetOrCreateTransport_w( |
- const std::string& transport_name) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- Transport* transport = GetTransport_w(transport_name); |
- if (transport) { |
- return transport; |
- } |
- |
- transport = CreateTransport_w(transport_name); |
- // The stuff below happens outside of CreateTransport_w so that unit tests |
- // can override CreateTransport_w to return a different type of transport. |
- transport->SetSslMaxProtocolVersion(ssl_max_version_); |
- transport->SetChannelReceivingTimeout(ice_receiving_timeout_ms_); |
- transport->SetIceRole(ice_role_); |
- transport->SetIceTiebreaker(ice_tiebreaker_); |
- if (certificate_) { |
- transport->SetLocalCertificate(certificate_); |
- } |
- transport->SignalConnecting.connect( |
- this, &TransportController::OnTransportConnecting_w); |
- transport->SignalWritableState.connect( |
- this, &TransportController::OnTransportWritableState_w); |
- transport->SignalReceivingState.connect( |
- this, &TransportController::OnTransportReceivingState_w); |
- transport->SignalCompleted.connect( |
- this, &TransportController::OnTransportCompleted_w); |
- transport->SignalFailed.connect(this, |
- &TransportController::OnTransportFailed_w); |
- transport->SignalGatheringState.connect( |
- this, &TransportController::OnTransportGatheringState_w); |
- transport->SignalCandidatesGathered.connect( |
- this, &TransportController::OnTransportCandidatesGathered_w); |
- transport->SignalRoleConflict.connect( |
- this, &TransportController::OnTransportRoleConflict_w); |
- transports_[transport_name] = transport; |
- |
- return transport; |
-} |
- |
-void TransportController::DestroyTransport_w( |
- const std::string& transport_name) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- auto iter = transports_.find(transport_name); |
- if (iter != transports_.end()) { |
- delete iter->second; |
- transports_.erase(transport_name); |
- } |
- // Destroying a transport may cause aggregate state to change. |
- UpdateAggregateStates_w(); |
-} |
- |
-void TransportController::DestroyAllTransports_w() { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- for (const auto& kv : transports_) { |
- delete kv.second; |
- } |
- transports_.clear(); |
-} |
- |
-bool TransportController::SetSslMaxProtocolVersion_w( |
- rtc::SSLProtocolVersion version) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- // Max SSL version can only be set before transports are created. |
- if (!transports_.empty()) { |
- return false; |
- } |
- |
- ssl_max_version_ = version; |
- return true; |
-} |
- |
-void TransportController::SetIceConnectionReceivingTimeout_w(int timeout_ms) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- ice_receiving_timeout_ms_ = timeout_ms; |
- for (const auto& kv : transports_) { |
- kv.second->SetChannelReceivingTimeout(timeout_ms); |
- } |
-} |
- |
-void TransportController::SetIceRole_w(IceRole ice_role) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- ice_role_ = ice_role; |
- for (const auto& kv : transports_) { |
- kv.second->SetIceRole(ice_role_); |
- } |
-} |
- |
-bool TransportController::GetSslRole_w(rtc::SSLRole* role) { |
- RTC_DCHECK(worker_thread()->IsCurrent()); |
- |
- if (transports_.empty()) { |
- return false; |
- } |
- return transports_.begin()->second->GetSslRole(role); |
-} |
- |
-bool TransportController::SetLocalCertificate_w( |
- const rtc::scoped_refptr<rtc::RTCCertificate>& certificate) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- if (certificate_) { |
- return false; |
- } |
- if (!certificate) { |
- return false; |
- } |
- certificate_ = certificate; |
- |
- for (const auto& kv : transports_) { |
- kv.second->SetLocalCertificate(certificate_); |
- } |
- return true; |
-} |
- |
-bool TransportController::GetLocalCertificate_w( |
- const std::string& transport_name, |
- rtc::scoped_refptr<rtc::RTCCertificate>* certificate) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- Transport* t = GetTransport_w(transport_name); |
- if (!t) { |
- return false; |
- } |
- |
- return t->GetLocalCertificate(certificate); |
-} |
- |
-bool TransportController::GetRemoteSSLCertificate_w( |
- const std::string& transport_name, |
- rtc::SSLCertificate** cert) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- Transport* t = GetTransport_w(transport_name); |
- if (!t) { |
- return false; |
- } |
- |
- return t->GetRemoteSSLCertificate(cert); |
-} |
- |
-bool TransportController::SetLocalTransportDescription_w( |
- const std::string& transport_name, |
- const TransportDescription& tdesc, |
- ContentAction action, |
- std::string* err) { |
- RTC_DCHECK(worker_thread()->IsCurrent()); |
- |
- Transport* transport = GetTransport_w(transport_name); |
- if (!transport) { |
- // If we didn't find a transport, that's not an error; |
- // it could have been deleted as a result of bundling. |
- // TODO(deadbeef): Make callers smarter so they won't attempt to set a |
- // description on a deleted transport. |
- return true; |
- } |
- |
- return transport->SetLocalTransportDescription(tdesc, action, err); |
-} |
- |
-bool TransportController::SetRemoteTransportDescription_w( |
- const std::string& transport_name, |
- const TransportDescription& tdesc, |
- ContentAction action, |
- std::string* err) { |
- RTC_DCHECK(worker_thread()->IsCurrent()); |
- |
- Transport* transport = GetTransport_w(transport_name); |
- if (!transport) { |
- // If we didn't find a transport, that's not an error; |
- // it could have been deleted as a result of bundling. |
- // TODO(deadbeef): Make callers smarter so they won't attempt to set a |
- // description on a deleted transport. |
- return true; |
- } |
- |
- return transport->SetRemoteTransportDescription(tdesc, action, err); |
-} |
- |
-void TransportController::MaybeStartGathering_w() { |
- for (const auto& kv : transports_) { |
- kv.second->MaybeStartGathering(); |
- } |
-} |
- |
-bool TransportController::AddRemoteCandidates_w( |
- const std::string& transport_name, |
- const Candidates& candidates, |
- std::string* err) { |
- RTC_DCHECK(worker_thread()->IsCurrent()); |
- |
- Transport* transport = GetTransport_w(transport_name); |
- if (!transport) { |
- // If we didn't find a transport, that's not an error; |
- // it could have been deleted as a result of bundling. |
- return true; |
- } |
- |
- return transport->AddRemoteCandidates(candidates, err); |
-} |
- |
-bool TransportController::ReadyForRemoteCandidates_w( |
- const std::string& transport_name) { |
- RTC_DCHECK(worker_thread()->IsCurrent()); |
- |
- Transport* transport = GetTransport_w(transport_name); |
- if (!transport) { |
- return false; |
- } |
- return transport->ready_for_remote_candidates(); |
-} |
- |
-bool TransportController::GetStats_w(const std::string& transport_name, |
- TransportStats* stats) { |
- RTC_DCHECK(worker_thread()->IsCurrent()); |
- |
- Transport* transport = GetTransport_w(transport_name); |
- if (!transport) { |
- return false; |
- } |
- return transport->GetStats(stats); |
-} |
- |
-void TransportController::OnTransportConnecting_w(Transport* transport) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- UpdateAggregateStates_w(); |
-} |
- |
-void TransportController::OnTransportWritableState_w(Transport* transport) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- UpdateAggregateStates_w(); |
-} |
- |
-void TransportController::OnTransportReceivingState_w(Transport* transport) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- UpdateAggregateStates_w(); |
-} |
- |
-void TransportController::OnTransportCompleted_w(Transport* transport) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- UpdateAggregateStates_w(); |
-} |
- |
-void TransportController::OnTransportFailed_w(Transport* transport) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- UpdateAggregateStates_w(); |
-} |
- |
-void TransportController::OnTransportGatheringState_w(Transport* transport) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- UpdateAggregateStates_w(); |
-} |
- |
-void TransportController::OnTransportCandidatesGathered_w( |
- Transport* transport, |
- const std::vector<Candidate>& candidates) { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- CandidatesData* data = new CandidatesData(transport->name(), candidates); |
- signaling_thread_->Post(this, MSG_CANDIDATESGATHERED, data); |
-} |
- |
-void TransportController::OnTransportRoleConflict_w() { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- if (ice_role_switch_) { |
- LOG(LS_WARNING) << "Repeat of role conflict signal from Transport."; |
- return; |
- } |
- |
- ice_role_switch_ = true; |
- IceRole reversed_role = (ice_role_ == ICEROLE_CONTROLLING) |
- ? ICEROLE_CONTROLLED |
- : ICEROLE_CONTROLLING; |
- for (const auto& kv : transports_) { |
- kv.second->SetIceRole(reversed_role); |
- } |
-} |
- |
-void TransportController::UpdateAggregateStates_w() { |
- RTC_DCHECK(worker_thread_->IsCurrent()); |
- |
- IceConnectionState new_connection_state = kIceConnectionConnecting; |
- IceGatheringState new_gathering_state = kIceGatheringNew; |
- bool any_receiving = false; |
- bool any_failed = false; |
- bool all_connected = HasChannels_w(); |
- bool all_completed = HasChannels_w(); |
- bool any_gathering = false; |
- bool all_done_gathering = HasChannels_w(); |
- for (const auto& kv : transports_) { |
- // Ignore transports without channels since they're about to be deleted, |
- // and their state is meaningless. |
- if (!kv.second->HasChannels()) { |
- continue; |
- } |
- any_receiving = any_receiving || kv.second->any_channel_receiving(); |
- any_failed = any_failed || kv.second->AnyChannelFailed(); |
- all_connected = all_connected && kv.second->all_channels_writable(); |
- all_completed = all_completed && kv.second->AllChannelsCompleted(); |
- any_gathering = |
- any_gathering || kv.second->gathering_state() != kIceGatheringNew; |
- all_done_gathering = all_done_gathering && |
- kv.second->gathering_state() == kIceGatheringComplete; |
- } |
- |
- if (any_failed) { |
- new_connection_state = kIceConnectionFailed; |
- } else if (all_completed) { |
- new_connection_state = kIceConnectionCompleted; |
- } else if (all_connected) { |
- new_connection_state = kIceConnectionConnected; |
- } |
- if (connection_state_ != new_connection_state) { |
- connection_state_ = new_connection_state; |
- signaling_thread_->Post( |
- this, MSG_ICECONNECTIONSTATE, |
- new rtc::TypedMessageData<IceConnectionState>(new_connection_state)); |
- } |
- |
- if (receiving_ != any_receiving) { |
- receiving_ = any_receiving; |
- signaling_thread_->Post(this, MSG_RECEIVING, |
- new rtc::TypedMessageData<bool>(any_receiving)); |
- } |
- |
- if (all_done_gathering) { |
- new_gathering_state = kIceGatheringComplete; |
- } else if (any_gathering) { |
- new_gathering_state = kIceGatheringGathering; |
- } |
- if (gathering_state_ != new_gathering_state) { |
- gathering_state_ = new_gathering_state; |
- signaling_thread_->Post( |
- this, MSG_ICEGATHERINGSTATE, |
- new rtc::TypedMessageData<IceGatheringState>(new_gathering_state)); |
- } |
-} |
- |
-bool TransportController::HasChannels_w() { |
- for (const auto& kv : transports_) { |
- if (kv.second->HasChannels()) { |
- return true; |
- } |
- } |
- return false; |
-} |
- |
-} // namespace cricket |