OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "remoting/protocol/libjingle_transport_factory.h" | 5 #include "remoting/protocol/libjingle_transport_factory.h" |
6 | 6 |
7 #include "base/callback.h" | 7 #include "base/callback.h" |
8 #include "base/single_thread_task_runner.h" | 8 #include "base/single_thread_task_runner.h" |
9 #include "base/thread_task_runner_handle.h" | 9 #include "base/thread_task_runner_handle.h" |
10 #include "base/timer/timer.h" | 10 #include "base/timer/timer.h" |
(...skipping 187 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
198 channel_->SetIceProtocolType(cricket::ICEPROTO_GOOGLE); | 198 channel_->SetIceProtocolType(cricket::ICEPROTO_GOOGLE); |
199 channel_->SetIceCredentials(ice_username_fragment_, ice_password_); | 199 channel_->SetIceCredentials(ice_username_fragment_, ice_password_); |
200 channel_->SignalRequestSignaling.connect( | 200 channel_->SignalRequestSignaling.connect( |
201 this, &LibjingleStreamTransport::OnRequestSignaling); | 201 this, &LibjingleStreamTransport::OnRequestSignaling); |
202 channel_->SignalCandidateReady.connect( | 202 channel_->SignalCandidateReady.connect( |
203 this, &LibjingleStreamTransport::OnCandidateReady); | 203 this, &LibjingleStreamTransport::OnCandidateReady); |
204 channel_->SignalRouteChange.connect( | 204 channel_->SignalRouteChange.connect( |
205 this, &LibjingleStreamTransport::OnRouteChange); | 205 this, &LibjingleStreamTransport::OnRouteChange); |
206 channel_->SignalWritableState.connect( | 206 channel_->SignalWritableState.connect( |
207 this, &LibjingleStreamTransport::OnWritableState); | 207 this, &LibjingleStreamTransport::OnWritableState); |
208 channel_->set_incoming_only( | 208 if (network_settings_.nat_traversal_mode == |
209 !(network_settings_.flags & NetworkSettings::NAT_TRAVERSAL_OUTGOING)); | 209 NetworkSettings::NAT_TRAVERSAL_DISABLED) { |
| 210 channel_->set_incoming_only(true); |
| 211 } |
210 | 212 |
211 channel_->Connect(); | 213 channel_->Connect(); |
212 | 214 |
213 --connect_attempts_left_; | 215 --connect_attempts_left_; |
214 | 216 |
215 // Start reconnection timer. | 217 // Start reconnection timer. |
216 reconnect_timer_.Start( | 218 reconnect_timer_.Start( |
217 FROM_HERE, base::TimeDelta::FromSeconds(kReconnectDelaySeconds), | 219 FROM_HERE, base::TimeDelta::FromSeconds(kReconnectDelaySeconds), |
218 this, &LibjingleStreamTransport::TryReconnect); | 220 this, &LibjingleStreamTransport::TryReconnect); |
219 | 221 |
(...skipping 223 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
443 return result.PassAs<StreamTransport>(); | 445 return result.PassAs<StreamTransport>(); |
444 } | 446 } |
445 | 447 |
446 scoped_ptr<DatagramTransport> | 448 scoped_ptr<DatagramTransport> |
447 LibjingleTransportFactory::CreateDatagramTransport() { | 449 LibjingleTransportFactory::CreateDatagramTransport() { |
448 NOTIMPLEMENTED(); | 450 NOTIMPLEMENTED(); |
449 return scoped_ptr<DatagramTransport>(); | 451 return scoped_ptr<DatagramTransport>(); |
450 } | 452 } |
451 | 453 |
452 void LibjingleTransportFactory::EnsureFreshJingleInfo() { | 454 void LibjingleTransportFactory::EnsureFreshJingleInfo() { |
453 uint32 stun_or_relay_flags = NetworkSettings::NAT_TRAVERSAL_STUN | | 455 if (network_settings_.nat_traversal_mode != |
454 NetworkSettings::NAT_TRAVERSAL_RELAY; | 456 NetworkSettings::NAT_TRAVERSAL_ENABLED || |
455 if (!(network_settings_.flags & stun_or_relay_flags) || | |
456 jingle_info_request_) { | 457 jingle_info_request_) { |
457 return; | 458 return; |
458 } | 459 } |
459 | 460 |
460 if (base::TimeTicks::Now() - last_jingle_info_update_time_ > | 461 if (base::TimeTicks::Now() - last_jingle_info_update_time_ > |
461 base::TimeDelta::FromSeconds(kJingleInfoUpdatePeriodSeconds)) { | 462 base::TimeDelta::FromSeconds(kJingleInfoUpdatePeriodSeconds)) { |
462 jingle_info_request_.reset(new JingleInfoRequest(signal_strategy_)); | 463 jingle_info_request_.reset(new JingleInfoRequest(signal_strategy_)); |
463 jingle_info_request_->Send(base::Bind( | 464 jingle_info_request_->Send(base::Bind( |
464 &LibjingleTransportFactory::OnJingleInfo, base::Unretained(this))); | 465 &LibjingleTransportFactory::OnJingleInfo, base::Unretained(this))); |
465 } | 466 } |
(...skipping 16 matching lines...) Expand all Loading... |
482 last_jingle_info_update_time_ = base::TimeTicks::Now(); | 483 last_jingle_info_update_time_ = base::TimeTicks::Now(); |
483 | 484 |
484 while (!on_jingle_info_callbacks_.empty()) { | 485 while (!on_jingle_info_callbacks_.empty()) { |
485 on_jingle_info_callbacks_.begin()->Run(); | 486 on_jingle_info_callbacks_.begin()->Run(); |
486 on_jingle_info_callbacks_.pop_front(); | 487 on_jingle_info_callbacks_.pop_front(); |
487 } | 488 } |
488 } | 489 } |
489 | 490 |
490 } // namespace protocol | 491 } // namespace protocol |
491 } // namespace remoting | 492 } // namespace remoting |
OLD | NEW |