| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/ice_transport.h" | 5 #include "remoting/protocol/ice_transport.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "remoting/protocol/channel_authenticator.h" | 8 #include "remoting/protocol/channel_authenticator.h" |
| 9 #include "remoting/protocol/channel_multiplexer.h" | 9 #include "remoting/protocol/channel_multiplexer.h" |
| 10 #include "remoting/protocol/pseudotcp_channel_factory.h" | 10 #include "remoting/protocol/pseudotcp_channel_factory.h" |
| 11 #include "remoting/protocol/secure_channel_factory.h" | 11 #include "remoting/protocol/secure_channel_factory.h" |
| 12 #include "remoting/protocol/stream_channel_factory.h" | 12 #include "remoting/protocol/stream_channel_factory.h" |
| 13 #include "remoting/protocol/stream_message_pipe_adapter.h" |
| 13 #include "remoting/protocol/transport_context.h" | 14 #include "remoting/protocol/transport_context.h" |
| 14 | 15 |
| 15 namespace remoting { | 16 namespace remoting { |
| 16 namespace protocol { | 17 namespace protocol { |
| 17 | 18 |
| 18 // Delay after candidate creation before sending transport-info message to | 19 // Delay after candidate creation before sending transport-info message to |
| 19 // accumulate multiple candidates. This is an optimization to reduce number of | 20 // accumulate multiple candidates. This is an optimization to reduce number of |
| 20 // transport-info messages. | 21 // transport-info messages. |
| 21 const int kTransportInfoSendDelayMs = 20; | 22 const int kTransportInfoSendDelayMs = 20; |
| 22 | 23 |
| (...skipping 15 matching lines...) Expand all Loading... |
| 38 | 39 |
| 39 void IceTransport::Start( | 40 void IceTransport::Start( |
| 40 Authenticator* authenticator, | 41 Authenticator* authenticator, |
| 41 SendTransportInfoCallback send_transport_info_callback) { | 42 SendTransportInfoCallback send_transport_info_callback) { |
| 42 DCHECK(!pseudotcp_channel_factory_); | 43 DCHECK(!pseudotcp_channel_factory_); |
| 43 | 44 |
| 44 send_transport_info_callback_ = std::move(send_transport_info_callback); | 45 send_transport_info_callback_ = std::move(send_transport_info_callback); |
| 45 pseudotcp_channel_factory_.reset(new PseudoTcpChannelFactory(this)); | 46 pseudotcp_channel_factory_.reset(new PseudoTcpChannelFactory(this)); |
| 46 secure_channel_factory_.reset(new SecureChannelFactory( | 47 secure_channel_factory_.reset(new SecureChannelFactory( |
| 47 pseudotcp_channel_factory_.get(), authenticator)); | 48 pseudotcp_channel_factory_.get(), authenticator)); |
| 49 message_channel_factory_.reset(new StreamMessageChannelFactoryAdapter( |
| 50 secure_channel_factory_.get(), |
| 51 base::Bind(&IceTransport::OnChannelError, weak_factory_.GetWeakPtr()))); |
| 48 } | 52 } |
| 49 | 53 |
| 50 bool IceTransport::ProcessTransportInfo(buzz::XmlElement* transport_info_xml) { | 54 bool IceTransport::ProcessTransportInfo(buzz::XmlElement* transport_info_xml) { |
| 51 IceTransportInfo transport_info; | 55 IceTransportInfo transport_info; |
| 52 if (!transport_info.ParseXml(transport_info_xml)) | 56 if (!transport_info.ParseXml(transport_info_xml)) |
| 53 return false; | 57 return false; |
| 54 | 58 |
| 55 for (auto it = transport_info.ice_credentials.begin(); | 59 for (auto it = transport_info.ice_credentials.begin(); |
| 56 it != transport_info.ice_credentials.end(); ++it) { | 60 it != transport_info.ice_credentials.end(); ++it) { |
| 57 ChannelsMap::iterator channel = channels_.find(it->channel); | 61 ChannelsMap::iterator channel = channels_.find(it->channel); |
| (...skipping 14 matching lines...) Expand all Loading... |
| 72 } else { | 76 } else { |
| 73 // Transport info was received before the channel was created. | 77 // Transport info was received before the channel was created. |
| 74 // This could happen due to messages being reordered on the wire. | 78 // This could happen due to messages being reordered on the wire. |
| 75 pending_remote_candidates_.push_back(*it); | 79 pending_remote_candidates_.push_back(*it); |
| 76 } | 80 } |
| 77 } | 81 } |
| 78 | 82 |
| 79 return true; | 83 return true; |
| 80 } | 84 } |
| 81 | 85 |
| 82 StreamChannelFactory* IceTransport::GetStreamChannelFactory() { | 86 MessageChannelFactory* IceTransport::GetChannelFactory() { |
| 83 return secure_channel_factory_.get(); | 87 return message_channel_factory_.get(); |
| 84 } | 88 } |
| 85 | 89 |
| 86 StreamChannelFactory* IceTransport::GetMultiplexedChannelFactory() { | 90 MessageChannelFactory* IceTransport::GetMultiplexedChannelFactory() { |
| 87 if (!channel_multiplexer_.get()) { | 91 if (!channel_multiplexer_) { |
| 88 channel_multiplexer_.reset( | 92 channel_multiplexer_.reset( |
| 89 new ChannelMultiplexer(GetStreamChannelFactory(), kMuxChannelName)); | 93 new ChannelMultiplexer(secure_channel_factory_.get(), kMuxChannelName)); |
| 94 mux_channel_factory_.reset(new StreamMessageChannelFactoryAdapter( |
| 95 channel_multiplexer_.get(), |
| 96 base::Bind(&IceTransport::OnChannelError, weak_factory_.GetWeakPtr()))); |
| 90 } | 97 } |
| 91 return channel_multiplexer_.get(); | 98 return mux_channel_factory_.get(); |
| 92 } | 99 } |
| 93 | 100 |
| 94 void IceTransport::CreateChannel(const std::string& name, | 101 void IceTransport::CreateChannel(const std::string& name, |
| 95 const ChannelCreatedCallback& callback) { | 102 const ChannelCreatedCallback& callback) { |
| 96 DCHECK(!channels_[name]); | 103 DCHECK(!channels_[name]); |
| 97 | 104 |
| 98 scoped_ptr<IceTransportChannel> channel( | 105 scoped_ptr<IceTransportChannel> channel( |
| 99 new IceTransportChannel(transport_context_)); | 106 new IceTransportChannel(transport_context_)); |
| 100 channel->Connect(name, this, callback); | 107 channel->Connect(name, this, callback); |
| 101 AddPendingRemoteTransportInfo(channel.get()); | 108 AddPendingRemoteTransportInfo(channel.get()); |
| (...skipping 82 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 184 | 191 |
| 185 void IceTransport::SendTransportInfo() { | 192 void IceTransport::SendTransportInfo() { |
| 186 DCHECK(pending_transport_info_message_); | 193 DCHECK(pending_transport_info_message_); |
| 187 | 194 |
| 188 scoped_ptr<buzz::XmlElement> transport_info_xml = | 195 scoped_ptr<buzz::XmlElement> transport_info_xml = |
| 189 pending_transport_info_message_->ToXml(); | 196 pending_transport_info_message_->ToXml(); |
| 190 pending_transport_info_message_.reset(); | 197 pending_transport_info_message_.reset(); |
| 191 send_transport_info_callback_.Run(std::move(transport_info_xml)); | 198 send_transport_info_callback_.Run(std::move(transport_info_xml)); |
| 192 } | 199 } |
| 193 | 200 |
| 201 void IceTransport::OnChannelError(int error) { |
| 202 LOG(ERROR) << "Data channel failed, error=" << error; |
| 203 event_handler_->OnIceTransportError(CHANNEL_CONNECTION_ERROR); |
| 204 } |
| 205 |
| 194 } // namespace protocol | 206 } // namespace protocol |
| 195 } // namespace remoting | 207 } // namespace remoting |
| OLD | NEW |