/* * libjingle * Copyright 2012, The Libjingle Authors. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * 3. The name of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ #ifndef TALK_P2P_BASE_TRANSPORTDESCRIPTION_H_ #define TALK_P2P_BASE_TRANSPORTDESCRIPTION_H_ #include #include #include #include "talk/base/scoped_ptr.h" #include "talk/base/sslfingerprint.h" #include "talk/p2p/base/candidate.h" #include "talk/p2p/base/constants.h" namespace cricket { // SEC_ENABLED and SEC_REQUIRED should only be used if the session // was negotiated over TLS, to protect the inline crypto material // exchange. // SEC_DISABLED: No crypto in outgoing offer, ignore any supplied crypto. // SEC_ENABLED: Crypto in outgoing offer and answer (if supplied in offer). // SEC_REQUIRED: Crypto in outgoing offer and answer. Fail any offer with absent // or unsupported crypto. enum SecurePolicy { SEC_DISABLED, SEC_ENABLED, SEC_REQUIRED }; // The transport protocol we've elected to use. enum TransportProtocol { ICEPROTO_GOOGLE, // Google version of ICE protocol. ICEPROTO_HYBRID, // ICE, but can fall back to the Google version. ICEPROTO_RFC5245 // Standard RFC 5245 version of ICE. }; // The old name for TransportProtocol. // TODO(juberti): remove this. typedef TransportProtocol IceProtocolType; // Whether our side of the call is driving the negotiation, or the other side. enum IceRole { ICEROLE_CONTROLLING = 0, ICEROLE_CONTROLLED, ICEROLE_UNKNOWN }; // ICE RFC 5245 implementation type. enum IceMode { ICEMODE_FULL, // As defined in http://tools.ietf.org/html/rfc5245#section-4.1 ICEMODE_LITE // As defined in http://tools.ietf.org/html/rfc5245#section-4.2 }; // RFC 4145 - http://tools.ietf.org/html/rfc4145#section-4 // 'active': The endpoint will initiate an outgoing connection. // 'passive': The endpoint will accept an incoming connection. // 'actpass': The endpoint is willing to accept an incoming // connection or to initiate an outgoing connection. enum ConnectionRole { CONNECTIONROLE_NONE = 0, CONNECTIONROLE_ACTIVE, CONNECTIONROLE_PASSIVE, CONNECTIONROLE_ACTPASS, CONNECTIONROLE_HOLDCONN, }; extern const char CONNECTIONROLE_ACTIVE_STR[]; extern const char CONNECTIONROLE_PASSIVE_STR[]; extern const char CONNECTIONROLE_ACTPASS_STR[]; extern const char CONNECTIONROLE_HOLDCONN_STR[]; bool StringToConnectionRole(const std::string& role_str, ConnectionRole* role); typedef std::vector Candidates; struct TransportDescription { TransportDescription() : ice_mode(ICEMODE_FULL) {} TransportDescription(const std::string& transport_type, const std::vector& transport_options, const std::string& ice_ufrag, const std::string& ice_pwd, IceMode ice_mode, ConnectionRole role, const talk_base::SSLFingerprint* identity_fingerprint, const Candidates& candidates) : transport_type(transport_type), transport_options(transport_options), ice_ufrag(ice_ufrag), ice_pwd(ice_pwd), ice_mode(ice_mode), connection_role(role), identity_fingerprint(CopyFingerprint(identity_fingerprint)), candidates(candidates) {} TransportDescription(const std::string& transport_type, const std::string& ice_ufrag, const std::string& ice_pwd) : transport_type(transport_type), ice_ufrag(ice_ufrag), ice_pwd(ice_pwd), ice_mode(ICEMODE_FULL), connection_role(CONNECTIONROLE_NONE) {} TransportDescription(const TransportDescription& from) : transport_type(from.transport_type), transport_options(from.transport_options), ice_ufrag(from.ice_ufrag), ice_pwd(from.ice_pwd), ice_mode(from.ice_mode), connection_role(from.connection_role), identity_fingerprint(CopyFingerprint(from.identity_fingerprint.get())), candidates(from.candidates) {} TransportDescription& operator=(const TransportDescription& from) { // Self-assignment if (this == &from) return *this; transport_type = from.transport_type; transport_options = from.transport_options; ice_ufrag = from.ice_ufrag; ice_pwd = from.ice_pwd; ice_mode = from.ice_mode; connection_role = from.connection_role; identity_fingerprint.reset(CopyFingerprint( from.identity_fingerprint.get())); candidates = from.candidates; return *this; } bool HasOption(const std::string& option) const { return (std::find(transport_options.begin(), transport_options.end(), option) != transport_options.end()); } void AddOption(const std::string& option) { transport_options.push_back(option); } bool secure() { return identity_fingerprint != NULL; } static talk_base::SSLFingerprint* CopyFingerprint( const talk_base::SSLFingerprint* from) { if (!from) return NULL; return new talk_base::SSLFingerprint(*from); } std::string transport_type; // xmlns of std::vector transport_options; std::string ice_ufrag; std::string ice_pwd; IceMode ice_mode; ConnectionRole connection_role; talk_base::scoped_ptr identity_fingerprint; Candidates candidates; }; } // namespace cricket #endif // TALK_P2P_BASE_TRANSPORTDESCRIPTION_H_