📄 dnsinterface.hxx
字号:
#if !defined(RESIP_DNSINTERFACE_HXX)#define RESIP_DNSINTERFACE_HXX #include <set>#include <vector>#include "rutil/TransportType.hxx"#include "rutil/Data.hxx"#include "rutil/Socket.hxx"#include "rutil/BaseException.hxx"#include "rutil/dns/DnsStub.hxx"#include "rutil/dns/RRVip.hxx"#include "resip/stack/TupleMarkManager.hxx"namespace resip{class DnsHandler;class DnsResultSink;class DnsResult;class Uri;class Via;//class ExternalDns;class DnsRawSink;class DnsInterface{ public: class Exception : public BaseException { public: Exception(const Data& msg, const Data& file, const int line) : BaseException(msg,file,line){} const char* name() const { return "DnsInterface::Exception"; } }; // Used to create an asynchronous Dns Interface. Any lookup requests will // be queued for later processing. It is critical that the consumer of the // DnsResult be in the same thread that is processing the async results // since there is no locking on the DnsResult // Will throw DnsInterface::Exception if the Dns provider fails to initialize DnsInterface(DnsStub& dnsStub); virtual ~DnsInterface(); //Data errorMessage(int status); // set the supported set of types that a UAC wishes to use void addTransportType(TransportType type, IpVersion version); // return if the client supports the specified service (e.g. SIP+D2T) bool isSupported(const Data& service); bool isSupported(TransportType t, IpVersion version); // this is used if NAPTR doesn't return anything to decide which SRV // records to query bool isSupportedProtocol(TransportType t); int supportedProtocols(); //only call buildFdSet and process if requiresProcess is true. bool requiresProcess(); // adds the appropriate file descriptors to the fdset to allow a // select/poll call to be made void buildFdSet(FdSet& fdset); // process any dns results back from the async dns library (e.g. ares). If // there are results to report, post an event to the fifo void process(FdSet& fdset); // For each of the following calls, immediately return a DnsResult to the // caller. If synchronous, the DnsResult is complete and may block for an // arbitrary amount of time. In the synchronous case, the transactionId is // not useful. If asynchronous, the DnsResult will be returned immediately // and is owned by the caller. If queries are outstanding, it is not valid // for the caller to delete the DnsResult. // // First determine a transport. Second, determine a set of ports and ip // addresses. These can be returned to the client by asking the DnsResult // for the next result in the form of a Transport:Tuple. The client can // continue to ask the DnsResult to return more tuples. If the tuples for // the current transport are exhausted, move on to the next preferred // transport (if there is one) DnsResult* createDnsResult(DnsHandler* handler=0); void lookup(DnsResult* res, const Uri& uri); //DnsResult* lookup(const Uri& url, DnsHandler* handler=0); //DnsResult* lookup(const Via& via, DnsHandler* handler=0); //void lookupRecords(const Data& target, unsigned short type, DnsRawSink* sink); //virtual void handleDnsRaw(ExternalDnsRawResult); TupleMarkManager& getMarkManager(){return mMarkManager;} protected: // When complete or partial results are ready, call DnsHandler::process() // For synchronous DnsInterface, set to 0 friend class DnsResult; DnsHandler* mHandler; std::set<Data> mSupportedNaptrs; typedef std::vector<std::pair<TransportType, IpVersion> > TransportMap; TransportMap mSupportedTransports; //std::set<TransportType> mSupportedTransportTypes; //ExternalDns* mDnsProvider; int mActiveQueryCount; DnsStub& mDnsStub; RRVip mVip; TupleMarkManager mMarkManager;};}#endif// Copyright (c) 2003, Jason Fischl/* ==================================================================== * 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 + -