// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "jingle/glue/utils.h" #include "base/json/json_reader.h" #include "base/json/json_writer.h" #include "base/logging.h" #include "base/memory/scoped_ptr.h" #include "base/values.h" #include "net/base/ip_endpoint.h" #include "net/base/net_util.h" #include "third_party/libjingle/overrides/talk/base/byteorder.h" #include "third_party/libjingle/source/talk/base/socketaddress.h" #include "third_party/libjingle/source/talk/p2p/base/candidate.h" namespace jingle_glue { bool IPEndPointToSocketAddress(const net::IPEndPoint& address_chrome, talk_base::SocketAddress* address_lj) { if (address_chrome.GetFamily() != AF_INET) { LOG(ERROR) << "Only IPv4 addresses are supported."; return false; } uint32 ip_as_int = talk_base::NetworkToHost32( *reinterpret_cast(&address_chrome.address()[0])); *address_lj = talk_base::SocketAddress(ip_as_int, address_chrome.port()); return true; } bool SocketAddressToIPEndPoint(const talk_base::SocketAddress& address_lj, net::IPEndPoint* address_chrome) { uint32 ip = talk_base::HostToNetwork32(address_lj.ip()); net::IPAddressNumber address; address.resize(net::kIPv4AddressSize); memcpy(&address[0], &ip, net::kIPv4AddressSize); *address_chrome = net::IPEndPoint(address, address_lj.port()); return true; } std::string SerializeP2PCandidate(const cricket::Candidate& candidate) { // TODO(sergeyu): Use SDP to format candidates? DictionaryValue value; value.SetString("name", candidate.name()); value.SetString("ip", candidate.address().IPAsString()); value.SetInteger("port", candidate.address().port()); value.SetString("type", candidate.type()); value.SetString("protocol", candidate.protocol()); value.SetString("username", candidate.username()); value.SetString("password", candidate.password()); value.SetDouble("preference", candidate.preference()); value.SetInteger("generation", candidate.generation()); std::string result; base::JSONWriter::Write(&value, &result); return result; } bool DeserializeP2PCandidate(const std::string& candidate_str, cricket::Candidate* candidate) { scoped_ptr value( base::JSONReader::Read(candidate_str, base::JSON_ALLOW_TRAILING_COMMAS)); if (!value.get() || !value->IsType(Value::TYPE_DICTIONARY)) { return false; } DictionaryValue* dic_value = static_cast(value.get()); std::string name; std::string ip; int port; std::string type; std::string protocol; std::string username; std::string password; double preference; int generation; if (!dic_value->GetString("name", &name) || !dic_value->GetString("ip", &ip) || !dic_value->GetInteger("port", &port) || !dic_value->GetString("type", &type) || !dic_value->GetString("protocol", &protocol) || !dic_value->GetString("username", &username) || !dic_value->GetString("password", &password) || !dic_value->GetDouble("preference", &preference) || !dic_value->GetInteger("generation", &generation)) { return false; } candidate->set_name(name); candidate->set_address(talk_base::SocketAddress(ip, port)); candidate->set_type(type); candidate->set_protocol(protocol); candidate->set_username(username); candidate->set_password(password); candidate->set_preference(static_cast(preference)); candidate->set_generation(generation); return true; } } // namespace jingle_glue