📄 tuple.hxx
字号:
#if !defined(RESIP_TUPLE_HXX)#define RESIP_TUPLE_HXX#include "rutil/Socket.hxx"#include "rutil/compat.hxx"#include "rutil/HashMap.hxx"#include "rutil/TransportType.hxx"#include "rutil/HeapInstanceCounter.hxx"#include "rutil/Data.hxx"#if defined(WIN32)#include <Ws2tcpip.h>#else#include <netinet/in.h>#endifnamespace resip{struct GenericIPAddress;class Transport;// WARNING!!// When you change this structure, make sure to update the hash function,// operator== and operator< to be consistent with the new structure. For// instance, the Connection* and Transport* change value in the Tuple over// its lifetime so they must not be included in the hash or comparisons. typedef unsigned long FlowKey;/** @ingroup resip_crit @brief Represents a network address. This includes: - IP address - port - protocol - TLS hostname (since this is integral to connection establishment)*/class Tuple{ public: RESIP_HeapCount(Tuple); Tuple(); explicit Tuple(const GenericIPAddress& genericAddress, TransportType type=UNKNOWN_TRANSPORT, const Data& targetDomain = Data::Empty); Tuple(const Data& printableAddress, int port, IpVersion ipVer, TransportType type=UNKNOWN_TRANSPORT, const Data& targetDomain = Data::Empty); Tuple(const Data& printableAddress, int port, TransportType type, const Data& targetDomain = Data::Empty); Tuple(const in_addr& pipv4, int pport, TransportType ptype, const Data& targetDomain = Data::Empty); Tuple(const sockaddr& addr, TransportType ptype, const Data& targetDomain = Data::Empty);#ifdef USE_IPV6 Tuple(const in6_addr& pipv6, int pport, TransportType ptype, const Data& targetDomain = Data::Empty);#endif // convert from a tuple to a sockaddr structure const sockaddr& getSockaddr() const { return mSockaddr; } sockaddr& getMutableSockaddr() { return mSockaddr; } void setSockaddr(const GenericIPAddress &); TransportType getType() const { return mTransportType; } void setType(TransportType type) { mTransportType = type ;} void setPort(int port); int getPort() const; bool isV4() const; //!dcm! -- should deprecate asap IpVersion ipVersion() const; bool isAnyInterface() const; socklen_t length() const; // of sockaddr bool isLoopback() const; bool operator<(const Tuple& rhs) const; bool operator==(const Tuple& rhs) const; Data presentationFormat() const; static TransportType toTransport( const Data& ); static const Data& toData( TransportType ); static Data inet_ntop(const Tuple& tuple); static void writeBinaryToken(const Tuple& tuple,Data& container); static Tuple makeTuple(const Data& binaryToken); GenericIPAddress toGenericIPAddress() const; /// This is a (largely) opaque key that subclasses of Transport will use /// to help record/find flows. For UDP and DTLS, this is just the FD, and /// the rest of the information about the flow is carried in the Tuple. /// For TCP and TLS, the FD of the connection is used. /// For protocols where using the FD would not be appropriate (SCTP), /// the transport may use whatever method to generate these it likes. /// (It is highly recommended that these ids are unique across all /// instances of a transport type) FlowKey mFlowKey; Transport* transport; bool onlyUseExistingConnection; /// compares this tuple with the one passed in for family, port and address equality /// using the passed in address mask (mask is specified by number of bits) bool isEqualWithMask(const Tuple& tuple, short mask, bool ignorePort=false, bool ignoreTransport=false) const; // special comparitors class AnyInterfaceCompare { public: bool operator()(const Tuple& x, const Tuple& y) const; }; friend class AnyInterfaceCompare; class AnyPortCompare { public: bool operator()(const Tuple& x, const Tuple& y) const; }; friend class AnyPortCompare; class AnyPortAnyInterfaceCompare { public: bool operator()(const Tuple& x, const Tuple& y) const; }; friend class AnyPortAnyInterfaceCompare; void setTargetDomain(const Data& target) { mTargetDomain = target; } const Data& getTargetDomain() const { return mTargetDomain; } /** Creates a 32-bit hash based on the contents of this Tuple. */ size_t hash() const; private: union { sockaddr mSockaddr; sockaddr_in m_anonv4;#ifdef USE_IPV6 sockaddr_in6 m_anonv6;#endif char pad[28]; // this make union same size if v6 is in or out }; TransportType mTransportType; Data mTargetDomain; friend std::ostream& operator<<(std::ostream& strm, const Tuple& tuple); friend class DnsResult;};}HashValue(resip::Tuple);#endif/* ==================================================================== * The Vovida Software License, Version 1.0 * * Copyright (c) 2000 Vovida Networks, Inc. All rights reserved. * * 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 names "VOCAL", "Vovida Open Communication Application Library", * and "Vovida Open Communication Application Library (VOCAL)" must * not be used to endorse or promote products derived from this * software without prior written permission. For written * permission, please contact vocal@vovida.org. * * 4. Products derived from this software may not be called "VOCAL", nor * may "VOCAL" appear in their name, without prior written * permission of Vovida Networks, Inc. * * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE AND * NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL VOVIDA * NETWORKS, INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT DAMAGES * IN EXCESS OF $1,000, NOR FOR ANY 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. * * ==================================================================== * * This software consists of voluntary contributions made by Vovida * Networks, Inc. and many individuals on behalf of Vovida Networks, * Inc. For more information on Vovida Networks, Inc., please see * <http://www.vovida.org/>. * */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -