Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(467)

Side by Side Diff: remoting/jingle_glue/jingle_info_request.cc

Issue 98173006: Fix LibjingleTransportFactory to refresh STUN/Relay. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « remoting/jingle_glue/jingle_info_request.h ('k') | remoting/protocol/connection_to_host.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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/jingle_glue/jingle_info_request.h" 5 #include "remoting/jingle_glue/jingle_info_request.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/message_loop/message_loop.h" 8 #include "base/message_loop/message_loop.h"
9 #include "base/stl_util.h" 9 #include "base/stl_util.h"
10 #include "base/strings/string_number_conversions.h" 10 #include "base/strings/string_number_conversions.h"
11 #include "base/time/time.h"
11 #include "net/base/net_util.h" 12 #include "net/base/net_util.h"
12 #include "remoting/jingle_glue/iq_sender.h" 13 #include "remoting/jingle_glue/iq_sender.h"
13 #include "third_party/libjingle/source/talk/base/socketaddress.h" 14 #include "third_party/libjingle/source/talk/base/socketaddress.h"
14 #include "third_party/libjingle/source/talk/xmllite/xmlelement.h" 15 #include "third_party/libjingle/source/talk/xmllite/xmlelement.h"
15 #include "third_party/libjingle/source/talk/xmpp/constants.h" 16 #include "third_party/libjingle/source/talk/xmpp/constants.h"
16 17
17 namespace remoting { 18 namespace remoting {
18 19
20 const int kRequestTimeoutSeconds = 5;
21
19 JingleInfoRequest::JingleInfoRequest(SignalStrategy* signal_strategy) 22 JingleInfoRequest::JingleInfoRequest(SignalStrategy* signal_strategy)
20 : iq_sender_(signal_strategy) { 23 : iq_sender_(signal_strategy) {
21 } 24 }
22 25
23 JingleInfoRequest::~JingleInfoRequest() { 26 JingleInfoRequest::~JingleInfoRequest() {}
24 }
25 27
26 void JingleInfoRequest::Send(const OnJingleInfoCallback& callback) { 28 void JingleInfoRequest::Send(const OnJingleInfoCallback& callback) {
27 on_jingle_info_cb_ = callback; 29 on_jingle_info_cb_ = callback;
28 scoped_ptr<buzz::XmlElement> iq_body( 30 scoped_ptr<buzz::XmlElement> iq_body(
29 new buzz::XmlElement(buzz::QN_JINGLE_INFO_QUERY, true)); 31 new buzz::XmlElement(buzz::QN_JINGLE_INFO_QUERY, true));
30 request_ = iq_sender_.SendIq( 32 request_ = iq_sender_.SendIq(
31 buzz::STR_GET, buzz::STR_EMPTY, iq_body.Pass(), 33 buzz::STR_GET, buzz::STR_EMPTY, iq_body.Pass(),
32 base::Bind(&JingleInfoRequest::OnResponse, base::Unretained(this))); 34 base::Bind(&JingleInfoRequest::OnResponse, base::Unretained(this)));
35 if (!request_) {
36 // If we failed to send IqRequest it means that SignalStrategy is
37 // disconnected. Notify the caller.
38 std::vector<talk_base::SocketAddress> stun_hosts;
39 std::vector<std::string> relay_hosts;
40 std::string relay_token;
41 on_jingle_info_cb_.Run(relay_token, relay_hosts, stun_hosts);
42 return;
43 }
44 request_->SetTimeout(base::TimeDelta::FromSeconds(kRequestTimeoutSeconds));
33 } 45 }
34 46
35 void JingleInfoRequest::OnResponse(IqRequest* request, 47 void JingleInfoRequest::OnResponse(IqRequest* request,
36 const buzz::XmlElement* stanza) { 48 const buzz::XmlElement* stanza) {
49 std::vector<talk_base::SocketAddress> stun_hosts;
50 std::vector<std::string> relay_hosts;
51 std::string relay_token;
52
53 if (!stanza) {
54 LOG(WARNING) << "Jingle info request has timed out.";
55 on_jingle_info_cb_.Run(relay_token, relay_hosts, stun_hosts);
56 return;
57 }
58
37 const buzz::XmlElement* query = 59 const buzz::XmlElement* query =
38 stanza->FirstNamed(buzz::QN_JINGLE_INFO_QUERY); 60 stanza->FirstNamed(buzz::QN_JINGLE_INFO_QUERY);
39 if (query == NULL) { 61 if (query == NULL) {
40 LOG(WARNING) << "No Jingle info found in Jingle Info query response." 62 LOG(WARNING) << "No Jingle info found in Jingle Info query response."
41 << stanza->Str(); 63 << stanza->Str();
64 on_jingle_info_cb_.Run(relay_token, relay_hosts, stun_hosts);
42 return; 65 return;
43 } 66 }
44 67
45 std::vector<talk_base::SocketAddress> stun_hosts;
46 const buzz::XmlElement* stun = query->FirstNamed(buzz::QN_JINGLE_INFO_STUN); 68 const buzz::XmlElement* stun = query->FirstNamed(buzz::QN_JINGLE_INFO_STUN);
47 if (stun) { 69 if (stun) {
48 for (const buzz::XmlElement* server = 70 for (const buzz::XmlElement* server =
49 stun->FirstNamed(buzz::QN_JINGLE_INFO_SERVER); 71 stun->FirstNamed(buzz::QN_JINGLE_INFO_SERVER);
50 server != NULL; 72 server != NULL;
51 server = server->NextNamed(buzz::QN_JINGLE_INFO_SERVER)) { 73 server = server->NextNamed(buzz::QN_JINGLE_INFO_SERVER)) {
52 std::string host = server->Attr(buzz::QN_JINGLE_INFO_HOST); 74 std::string host = server->Attr(buzz::QN_JINGLE_INFO_HOST);
53 std::string port_str = server->Attr(buzz::QN_JINGLE_INFO_UDP); 75 std::string port_str = server->Attr(buzz::QN_JINGLE_INFO_UDP);
54 if (host != buzz::STR_EMPTY && port_str != buzz::STR_EMPTY) { 76 if (host != buzz::STR_EMPTY && port_str != buzz::STR_EMPTY) {
55 int port; 77 int port;
56 if (!base::StringToInt(port_str, &port)) { 78 if (!base::StringToInt(port_str, &port)) {
57 LOG(WARNING) << "Unable to parse port in stanza" << stanza->Str(); 79 LOG(WARNING) << "Unable to parse port in stanza" << stanza->Str();
58 continue; 80 continue;
59 } 81 }
60 82
61 stun_hosts.push_back(talk_base::SocketAddress(host, port)); 83 stun_hosts.push_back(talk_base::SocketAddress(host, port));
62 } 84 }
63 } 85 }
64 } 86 }
65 87
66 std::vector<std::string> relay_hosts;
67 std::string relay_token;
68 const buzz::XmlElement* relay = query->FirstNamed(buzz::QN_JINGLE_INFO_RELAY); 88 const buzz::XmlElement* relay = query->FirstNamed(buzz::QN_JINGLE_INFO_RELAY);
69 if (relay) { 89 if (relay) {
70 relay_token = relay->TextNamed(buzz::QN_JINGLE_INFO_TOKEN); 90 relay_token = relay->TextNamed(buzz::QN_JINGLE_INFO_TOKEN);
71 for (const buzz::XmlElement* server = 91 for (const buzz::XmlElement* server =
72 relay->FirstNamed(buzz::QN_JINGLE_INFO_SERVER); 92 relay->FirstNamed(buzz::QN_JINGLE_INFO_SERVER);
73 server != NULL; 93 server != NULL;
74 server = server->NextNamed(buzz::QN_JINGLE_INFO_SERVER)) { 94 server = server->NextNamed(buzz::QN_JINGLE_INFO_SERVER)) {
75 std::string host = server->Attr(buzz::QN_JINGLE_INFO_HOST); 95 std::string host = server->Attr(buzz::QN_JINGLE_INFO_HOST);
76 if (host != buzz::STR_EMPTY) 96 if (host != buzz::STR_EMPTY)
77 relay_hosts.push_back(host); 97 relay_hosts.push_back(host);
78 } 98 }
79 } 99 }
80 100
81 on_jingle_info_cb_.Run(relay_token, relay_hosts, stun_hosts); 101 on_jingle_info_cb_.Run(relay_token, relay_hosts, stun_hosts);
82 } 102 }
83 103
84 } // namespace remoting 104 } // namespace remoting
OLDNEW
« no previous file with comments | « remoting/jingle_glue/jingle_info_request.h ('k') | remoting/protocol/connection_to_host.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698