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 if (network_settings_.nat_traversal_mode == | 208 channel_->set_incoming_only( |
209 NetworkSettings::NAT_TRAVERSAL_DISABLED) { | 209 !(network_settings_.flags & NetworkSettings::NAT_TRAVERSAL_OUTGOING)); |
210 channel_->set_incoming_only(true); | |
211 } | |
212 | 210 |
213 channel_->Connect(); | 211 channel_->Connect(); |
214 | 212 |
215 --connect_attempts_left_; | 213 --connect_attempts_left_; |
216 | 214 |
217 // Start reconnection timer. | 215 // Start reconnection timer. |
218 reconnect_timer_.Start( | 216 reconnect_timer_.Start( |
219 FROM_HERE, base::TimeDelta::FromSeconds(kReconnectDelaySeconds), | 217 FROM_HERE, base::TimeDelta::FromSeconds(kReconnectDelaySeconds), |
220 this, &LibjingleStreamTransport::TryReconnect); | 218 this, &LibjingleStreamTransport::TryReconnect); |
221 | 219 |
(...skipping 223 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
445 return result.PassAs<StreamTransport>(); | 443 return result.PassAs<StreamTransport>(); |
446 } | 444 } |
447 | 445 |
448 scoped_ptr<DatagramTransport> | 446 scoped_ptr<DatagramTransport> |
449 LibjingleTransportFactory::CreateDatagramTransport() { | 447 LibjingleTransportFactory::CreateDatagramTransport() { |
450 NOTIMPLEMENTED(); | 448 NOTIMPLEMENTED(); |
451 return scoped_ptr<DatagramTransport>(); | 449 return scoped_ptr<DatagramTransport>(); |
452 } | 450 } |
453 | 451 |
454 void LibjingleTransportFactory::EnsureFreshJingleInfo() { | 452 void LibjingleTransportFactory::EnsureFreshJingleInfo() { |
455 if (network_settings_.nat_traversal_mode != | 453 uint32 stun_or_relay_flags = NetworkSettings::NAT_TRAVERSAL_STUN | |
456 NetworkSettings::NAT_TRAVERSAL_ENABLED || | 454 NetworkSettings::NAT_TRAVERSAL_RELAY; |
| 455 if (!(network_settings_.flags & stun_or_relay_flags) || |
457 jingle_info_request_) { | 456 jingle_info_request_) { |
458 return; | 457 return; |
459 } | 458 } |
460 | 459 |
461 if (base::TimeTicks::Now() - last_jingle_info_update_time_ > | 460 if (base::TimeTicks::Now() - last_jingle_info_update_time_ > |
462 base::TimeDelta::FromSeconds(kJingleInfoUpdatePeriodSeconds)) { | 461 base::TimeDelta::FromSeconds(kJingleInfoUpdatePeriodSeconds)) { |
463 jingle_info_request_.reset(new JingleInfoRequest(signal_strategy_)); | 462 jingle_info_request_.reset(new JingleInfoRequest(signal_strategy_)); |
464 jingle_info_request_->Send(base::Bind( | 463 jingle_info_request_->Send(base::Bind( |
465 &LibjingleTransportFactory::OnJingleInfo, base::Unretained(this))); | 464 &LibjingleTransportFactory::OnJingleInfo, base::Unretained(this))); |
466 } | 465 } |
(...skipping 16 matching lines...) Expand all Loading... |
483 last_jingle_info_update_time_ = base::TimeTicks::Now(); | 482 last_jingle_info_update_time_ = base::TimeTicks::Now(); |
484 | 483 |
485 while (!on_jingle_info_callbacks_.empty()) { | 484 while (!on_jingle_info_callbacks_.empty()) { |
486 on_jingle_info_callbacks_.begin()->Run(); | 485 on_jingle_info_callbacks_.begin()->Run(); |
487 on_jingle_info_callbacks_.pop_front(); | 486 on_jingle_info_callbacks_.pop_front(); |
488 } | 487 } |
489 } | 488 } |
490 | 489 |
491 } // namespace protocol | 490 } // namespace protocol |
492 } // namespace remoting | 491 } // namespace remoting |
OLD | NEW |