⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sipmessage.cxx

📁 这是国外的resip协议栈
💻 CXX
📖 第 1 页 / 共 4 页
字号:
   // empty?   if (hfvs == 0)   {      // create the list with a new component      hfvs = new HeaderFieldValueList;      mHeaders[type] = hfvs;      if (single)      {         HeaderFieldValue* hfv = new HeaderFieldValue;         hfvs->push_back(hfv);      }   }   // !dlb! not thrilled about checking this every access   else if (single)   {      if (hfvs->parsedEmpty())      {         // create an unparsed shared header field value // !dlb! when will this happen?         hfvs->push_back(new HeaderFieldValue(Data::Empty.data(), 0));      }   }   return hfvs;}HeaderFieldValueList* SipMessage::ensureHeaders(Headers::Type type, bool single) const{   HeaderFieldValueList* hfvs = mHeaders[type];      // empty?   if (hfvs == 0)   {      // header missing      // assert(false);      InfoLog( << "Missing Header [" << Headers::getHeaderName(type) << "]");            DebugLog (<< *this);      throw Exception("Missing header " + Headers::getHeaderName(type), __FILE__, __LINE__);   }   // !dlb! not thrilled about checking this every access   else if (single)   {      if (hfvs->parsedEmpty())      {         // !dlb! when will this happen?         // assert(false);         InfoLog( << "Missing Header " << Headers::getHeaderName(type) );         DebugLog (<< *this);         throw Exception("Empty header", __FILE__, __LINE__);      }   }   return hfvs;}// type safe header accessorsbool    SipMessage::exists(const HeaderBase& headerType) const {   return mHeaders[headerType.getTypeNum()] != 0;};boolSipMessage::empty(const HeaderBase& headerType) const{   return !mHeaders[headerType.getTypeNum()] || mHeaders[headerType.getTypeNum()]->parsedEmpty();}voidSipMessage::remove(const HeaderBase& headerType){   delete mHeaders[headerType.getTypeNum()];    mHeaders[headerType.getTypeNum()] = 0; };#ifndef PARTIAL_TEMPLATE_SPECIALIZATION#undef defineHeader#define defineHeader(_header, _name, _type, _rfc)                                                       \const H_##_header::Type&                                                                                \SipMessage::header(const H_##_header& headerType) const                                                 \{                                                                                                       \   HeaderFieldValueList* hfvs = ensureHeaders(headerType.getTypeNum(), true);                           \   if (hfvs->getParserContainer() == 0)                                                                 \   {                                                                                                    \      hfvs->setParserContainer(new ParserContainer<H_##_header::Type>(hfvs, headerType.getTypeNum()));  \   }                                                                                                    \   return dynamic_cast<ParserContainer<H_##_header::Type>*>(hfvs->getParserContainer())->front();       \}                                                                                                       \                                                                                                        \H_##_header::Type&                                                                                      \SipMessage::header(const H_##_header& headerType)                                                       \{                                                                                                       \   HeaderFieldValueList* hfvs = ensureHeaders(headerType.getTypeNum(), true);                           \   if (hfvs->getParserContainer() == 0)                                                                 \   {                                                                                                    \      hfvs->setParserContainer(new ParserContainer<H_##_header::Type>(hfvs, headerType.getTypeNum()));  \   }                                                                                                    \   return dynamic_cast<ParserContainer<H_##_header::Type>*>(hfvs->getParserContainer())->front();       \}#undef defineMultiHeader#define defineMultiHeader(_header, _name, _type, _rfc)                                          \const H_##_header##s::Type&                                                                     \SipMessage::header(const H_##_header##s& headerType) const                                      \{                                                                                               \   HeaderFieldValueList* hfvs = ensureHeaders(headerType.getTypeNum(), false);                  \   if (hfvs->getParserContainer() == 0)                                                         \   {                                                                                            \      hfvs->setParserContainer(new H_##_header##s::Type(hfvs, headerType.getTypeNum()));        \   }                                                                                            \   return *dynamic_cast<H_##_header##s::Type*>(hfvs->getParserContainer());                     \}                                                                                               \                                                                                                \H_##_header##s::Type&                                                                           \SipMessage::header(const H_##_header##s& headerType)                                            \{                                                                                               \   HeaderFieldValueList* hfvs = ensureHeaders(headerType.getTypeNum(), false);                  \   if (hfvs->getParserContainer() == 0)                                                         \   {                                                                                            \      hfvs->setParserContainer(new H_##_header##s::Type(hfvs, headerType.getTypeNum()));        \   }                                                                                            \   return *dynamic_cast<H_##_header##s::Type*>(hfvs->getParserContainer());                     \}defineHeader(ContentDisposition, "Content-Disposition", Token, "RFC 3261");defineHeader(ContentEncoding, "Content-Encoding", Token, "RFC 3261");defineHeader(MIMEVersion, "Mime-Version", Token, "RFC 3261");defineHeader(Priority, "Priority", Token, "RFC 3261");defineHeader(Event, "Event", Token, "RFC 3265");defineHeader(SubscriptionState, "Subscription-State", Token, "RFC 3265");defineHeader(SIPETag, "SIP-ETag", Token, "RFC 3903");defineHeader(SIPIfMatch, "SIP-If-Match", Token, "RFC 3903");defineHeader(ContentId, "Content-ID", Token, "RFC 2045");defineMultiHeader(AllowEvents, "Allow-Events", Token, "RFC 3265");defineHeader(Identity, "Identity", StringCategory, "draft-sip-identity-03");defineMultiHeader(AcceptEncoding, "Accept-Encoding", Token, "RFC 3261");defineMultiHeader(AcceptLanguage, "Accept-Language", Token, "RFC 3261");defineMultiHeader(Allow, "Allow", Token, "RFC 3261");defineMultiHeader(ContentLanguage, "Content-Language", Token, "RFC 3261");defineMultiHeader(ProxyRequire, "Proxy-Require", Token, "RFC 3261");defineMultiHeader(Require, "Require", Token, "RFC 3261");defineMultiHeader(Supported, "Supported", Token, "RFC 3261");defineMultiHeader(Unsupported, "Unsupported", Token, "RFC 3261");defineMultiHeader(SecurityClient, "Security-Client", Token, "RFC 3329");defineMultiHeader(SecurityServer, "Security-Server", Token, "RFC 3329");defineMultiHeader(SecurityVerify, "Security-Verify", Token, "RFC 3329");defineMultiHeader(RequestDisposition, "Request-Disposition", Token, "RFC 3841");defineMultiHeader(Reason, "Reason", Token, "RFC 3326");defineMultiHeader(Privacy, "Privacy", Token, "RFC 3323");defineMultiHeader(PMediaAuthorization, "P-Media-Authorization", Token, "RFC 3313");defineHeader(ReferSub, "Refer-Sub", Token, "draft-ietf-sip-refer-with-norefersub-03");defineHeader(AnswerMode, "Answer-Mode", Token, "draft-ietf-answermode-01");defineHeader(PrivAnswerMode, "Priv-Answer-Mode", Token, "draft-ietf-answermode-01");defineMultiHeader(Accept, "Accept", Mime, "RFC 3261");defineHeader(ContentType, "Content-Type", Mime, "RFC 3261");defineMultiHeader(CallInfo, "Call-Info", GenericUri, "RFC 3261");defineMultiHeader(AlertInfo, "Alert-Info", GenericUri, "RFC 3261");defineMultiHeader(ErrorInfo, "Error-Info", GenericUri, "RFC 3261");defineHeader(IdentityInfo, "Identity-Info", GenericUri, "draft-sip-identity-03");defineMultiHeader(RecordRoute, "Record-Route", NameAddr, "RFC 3261");defineMultiHeader(Route, "Route", NameAddr, "RFC 3261");defineMultiHeader(Contact, "Contact", NameAddr, "RFC 3261");defineHeader(From, "From", NameAddr, "RFC 3261");defineHeader(To, "To", NameAddr, "RFC 3261");defineHeader(ReplyTo, "Reply-To", NameAddr, "RFC 3261");defineHeader(ReferTo, "Refer-To", NameAddr, "RFC 3515");defineHeader(ReferredBy, "Referred-By", NameAddr, "RFC 3892");defineMultiHeader(Path, "Path", NameAddr, "RFC 3327");defineMultiHeader(AcceptContact, "Accept-Contact", NameAddr, "RFC 3841");defineMultiHeader(RejectContact, "Reject-Contact", NameAddr, "RFC 3841");defineMultiHeader(PAssertedIdentity, "P-Asserted-Identity", NameAddr, "RFC 3325");defineMultiHeader(PPreferredIdentity, "P-Preferred-Identity", NameAddr, "RFC 3325");defineHeader(PCalledPartyId, "P-Called-Party-ID", NameAddr, "RFC 3455");defineMultiHeader(PAssociatedUri, "P-Associated-URI", NameAddr, "RFC 3455");defineMultiHeader(ServiceRoute, "Service-Route", NameAddr, "RFC 3608");defineHeader(ContentTransferEncoding, "Content-Transfer-Encoding", StringCategory, "RFC ?");defineHeader(Organization, "Organization", StringCategory, "RFC 3261");defineHeader(Server, "Server", StringCategory, "RFC 3261");defineHeader(Subject, "Subject", StringCategory, "RFC 3261");defineHeader(UserAgent, "User-Agent", StringCategory, "RFC 3261");defineHeader(Timestamp, "Timestamp", StringCategory, "RFC 3261");defineHeader(ContentLength, "Content-Length", UInt32Category, "RFC 3261");defineHeader(MaxForwards, "Max-Forwards", UInt32Category, "RFC 3261");defineHeader(MinExpires, "Min-Expires", Uint32Category, "RFC 3261");defineHeader(RSeq, "RSeq", UInt32Category, "RFC 3261");// !dlb! this one is not quite right -- can have (comment) after field valuedefineHeader(RetryAfter, "Retry-After", UInt32Category, "RFC 3261");defineHeader(Expires, "Expires", ExpiresCategory, "RFC 3261");defineHeader(SessionExpires, "Session-Expires", ExpiresCategory, "RFC 4028");defineHeader(MinSE, "Min-SE", ExpiresCategory, "RFC 4028");defineHeader(CallID, "Call-ID", CallID, "RFC 3261");defineHeader(Replaces, "Replaces", CallID, "RFC 3261");defineHeader(InReplyTo, "In-Reply-To", CallID, "RFC 3261");defineHeader(Join, "Join", CallId, "RFC 3911");defineHeader(TargetDialog, "Target-Dialog", CallId, "Target Dialog draft");defineHeader(AuthenticationInfo, "Authentication-Info", Auth, "RFC 3261");defineMultiHeader(Authorization, "Authorization", Auth, "RFC 3261");defineMultiHeader(ProxyAuthenticate, "Proxy-Authenticate", Auth, "RFC 3261");defineMultiHeader(ProxyAuthorization, "Proxy-Authorization", Auth, "RFC 3261");defineMultiHeader(WWWAuthenticate, "Www-Authenticate", Auth, "RFC 3261");defineHeader(CSeq, "CSeq", CSeqCategory, "RFC 3261");defineHeader(Date, "Date", DateCategory, "RFC 3261");defineMultiHeader(Warning, "Warning", WarningCategory, "RFC 3261");defineMultiHeader(Via, "Via", Via, "RFC 3261");defineHeader(RAck, "RAck", RAckCategory, "RFC 3262");defineHeader(RemotePartyId, "Remote-Party-ID", NameAddr, "draft-ietf-sip-privacy-04");#endifconst HeaderFieldValueList*SipMessage::getRawHeader(Headers::Type headerType) const{   return mHeaders[headerType];}voidSipMessage::setRawHeader(const HeaderFieldValueList* hfvs, Headers::Type headerType){   if (mHeaders[headerType] != hfvs)   {      delete mHeaders[headerType];      mHeaders[headerType] = new HeaderFieldValueList(*hfvs);   }}voidSipMessage::setForceTarget(const Uri& uri){   if (mForceTarget)   {      *mForceTarget = uri;   }   else   {      mForceTarget = new Uri(uri);   }}voidSipMessage::clearForceTarget(){   delete mForceTarget;   mForceTarget = 0;}const Uri&SipMessage::getForceTarget() const{   assert(mForceTarget);   return *mForceTarget;}boolSipMessage::hasForceTarget() const{   return (mForceTarget != 0);}SipMessage& SipMessage::mergeUri(const Uri& source){   header(h_RequestLine).uri() = source;   header(h_RequestLine).uri().removeEmbedded();   if (source.exists(p_method))   {      header(h_RequestLine).method() = getMethodType(source.param(p_method));      header(h_RequestLine).uri().remove(p_method);         }                 //19.1.5   //dangerous headers not included in merge:   // From, Call-ID, Cseq, Via, Record Route, Route, Accept, Accept-Encoding,   // Accept-Langauge, Allow, Contact, Organization, Supported, User-Agent   //from the should-verify section, remove for now, some never seem to make   //sense:     // Content-Encoding, Content-Language, Content-Length, Content-Type, Date,   // Mime-Version, and TimeStamp   if (source.hasEmbedded())   {      h_AuthenticationInfo.merge(*this, source.embedded());      h_ContentTransferEncoding.merge(*this, source.embedded());      h_Event.merge(*this, source.embedded());      h_Expires.merge(*this, source.embedded());      h_SessionExpires.merge(*this, source.embedded());      h_MinSE.merge(*this, source.embedded());      h_InReplyTo.merge(*this, source.embedded());      h_MaxForwards.merge(*this, source.embedded());      h_MinExpires.merge(*this, source.embedded());      h_Priority.merge(*this, source.embedded());      h_ReferTo.merge(*this, source.embedded());      h_ReferredBy.merge(*this, source.embedded());      h_Replaces.merge(*this, source.embedded());      h_ReplyTo.merge(*this, source.embedded());      h_RetryAfter.merge(*this, source.embedded());      h_Server.merge(*this, source.embedded());      h_SIPETag.merge(*this, source.embedded());      h_SIPIfMatch.merge(*this, source.embedded());      h_Subject.merge(*this, source.embedded());      h_SubscriptionState.merge(*this, source.embedded());      h_To.merge(*this, source.embedded());      h_Warnings.merge(*this, source.embedded());      h_SecurityClients.merge(*this, source.embedded());      h_SecurityServers.merge(*this, source.embedded());      h_SecurityVerifys.merge(*this, source.embedded());      h_Authorizations.merge(*this, source.embedded());      h_ProxyAuthenticates.merge(*this, source.embedded());      h_WWWAuthenticates.merge(*this, source.embedded());      h_ProxyAuthorizations.merge(*this, source.embedded());      h_AlertInfos.merge(*this, source.embedded());      h_AllowEvents.merge(*this, source.embedded());      h_CallInfos.merge(*this, source.embedded());      h_ErrorInfos.merge(*this, source.embedded());      h_ProxyRequires.merge(*this, source.embedded());      h_Requires.merge(*this, source.embedded());      h_Unsupporteds.merge(*this, source.embedded());      h_AnswerMode.merge(*this, source.embedded());      h_PrivAnswerMode.merge(*this, source.embedded());      h_RSeq.merge(*this, source.embedded());      h_RAck.merge(*this, source.embedded());   }      //unknown header merge   return *this;   }void SipMessage::setSecurityAttributes(auto_ptr<SecurityAttributes> sec) const{   mSecurityAttributes = sec;}voidSipMessage::callOutboundDecorators(const Tuple &src, const Tuple &dest){  std::vector<MessageDecorator*>::iterator i;  for (i = mOutboundDecorators.begin();       i != mOutboundDecorators.end(); i++)  {    (*i)->decorateMessage(*this, src, dest);  }  mIsDecorated = true;}/* ==================================================================== * 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 + -