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

📄 clientpagermessage.cxx

📁 这是国外的resip协议栈
💻 CXX
字号:
#include "resip/stack/SipMessage.hxx"#include "resip/stack/MethodTypes.hxx"#include "resip/stack/TransactionUser.hxx"#include "resip/stack/Security.hxx"#include "resip/dum/PagerMessageCreator.hxx"#include "resip/dum/DialogUsageManager.hxx"#include "resip/dum/ClientPagerMessage.hxx"#include "resip/dum/PagerMessageHandler.hxx"#include "resip/dum/Dialog.hxx"#include "resip/dum/UsageUseException.hxx"#include "resip/dum/DumHelper.hxx"#include "rutil/Logger.hxx"#include "resip/stack/Helper.hxx"using namespace resip;#if(0)//  for appcliation behaves like ICQapp::onSendButtonClicked(im){    disableSendButton();    mPageManager.page(im);}app::onSuccess(...){    enableSendButton();}app::onFailure(...){    reportFailueToUI();    enableSendButton();}//  for application behaves like MSNapp::onSendButtonClicked(im){    mPageManager.page(im);}app::onSuccess(...){    // most likely no-op}app::onFailure(...){    reportFailueToUI();}//  for application behaves like MSN but wants to limit number of pages queued.app::onSendButtonClicked(im){    if(mPageManager.msgQueued() > 5 - 1)    {        disableSendButton();    }    mPageManager.page(im);}app::onSuccess(...){    if(mPageManager.msgQueued() < 5)    {        enableSendButton();    }}app::onFailure(...){    reportFailueToUI();    if(mPageManager.msgQueued() < 5)    {        enableSendButton();    }}#endif#define RESIPROCATE_SUBSYSTEM Subsystem::DUMClientPagerMessageHandleClientPagerMessage::getHandle(){   return ClientPagerMessageHandle(mDum, getBaseHandle().getId());}ClientPagerMessage::ClientPagerMessage(DialogUsageManager& dum, DialogSet& dialogSet)   : NonDialogUsage(dum, dialogSet),     mRequest(dialogSet.getCreator()->getLastRequest()),     mEnded(false){}ClientPagerMessage::~ClientPagerMessage(){   this->clearMsgQueued();   mDialogSet.mClientPagerMessage = 0;}SipMessage&ClientPagerMessage::getMessageRequest(){   return *mRequest;}voidClientPagerMessage::page(std::auto_ptr<Contents> contents,                         DialogUsageManager::EncryptionLevel level){    assert(contents.get() != 0);    bool do_page = mMsgQueue.empty();    Item item;    item.contents = contents.release();    item.encryptionLevel = level;    mMsgQueue.push_back(item);    if(do_page)    {       this->pageFirstMsgQueued();    }}class ClientPagerMessagePageCommand : public DumCommandAdapter{public:   ClientPagerMessagePageCommand(ClientPagerMessage& clientPagerMessage,       std::auto_ptr<Contents> contents,      DialogUsageManager::EncryptionLevel level)      : mClientPagerMessage(clientPagerMessage),        mContents(contents),        mLevel(level)   {   }   virtual void executeCommand()   {      mClientPagerMessage.page(mContents, mLevel);   }   virtual std::ostream& encodeBrief(std::ostream& strm) const   {      return strm << "ClientPagerMessagePageCommand";   }private:   ClientPagerMessage& mClientPagerMessage;   std::auto_ptr<Contents> mContents;   DialogUsageManager::EncryptionLevel mLevel;};voidClientPagerMessage::pageCommand(std::auto_ptr<Contents> contents,                                DialogUsageManager::EncryptionLevel level){   mDum.post(new ClientPagerMessagePageCommand(*this, contents, level));}voidClientPagerMessage::dispatch(const SipMessage& msg){	assert(msg.isResponse());    ClientPagerMessageHandler* handler = mDum.mClientPagerMessageHandler;    assert(handler);    int code = msg.header(h_StatusLine).statusCode();    DebugLog ( << "ClientPagerMessageReq::dispatch(msg)" << msg.brief() );    {        assert(mMsgQueue.empty() == false);        if (code < 200)        {           DebugLog ( << "ClientPagerMessageReq::dispatch - encountered provisional response" << msg.brief() );        }        else if (code < 300)        {           if(mMsgQueue.empty() == false)           {              delete mMsgQueue.front().contents;              mMsgQueue.pop_front();              if(mMsgQueue.empty() == false)              {                 this->pageFirstMsgQueued();              }                            handler->onSuccess(getHandle(), msg);           }        }        else        {           SipMessage errResponse;           MsgQueue::iterator contents;           for(contents = mMsgQueue.begin(); contents != mMsgQueue.end(); ++contents)           {               Contents* p = contents->contents;               WarningLog ( << "Paging failed" << *p );               Helper::makeResponse(errResponse, *mRequest, code);               handler->onFailure(getHandle(), errResponse, std::auto_ptr<Contents>(p));               contents->contents = 0;           }           mMsgQueue.clear();        }    }}voidClientPagerMessage::dispatch(const DumTimeout& timer){}voidClientPagerMessage::end(){   if(!mEnded)   {      mEnded = true;      mDum.destroy(this);   }}class ClientPagerMessageEndCommand : public DumCommandAdapter{public:   ClientPagerMessageEndCommand(ClientPagerMessage& clientPagerMessage)      : mClientPagerMessage(clientPagerMessage)   {   }   virtual void executeCommand()   {      mClientPagerMessage.end();   }   virtual std::ostream& encodeBrief(std::ostream& strm) const   {      return strm << "ClientPagerMessageEndCommand";   }private:   ClientPagerMessage& mClientPagerMessage;};voidClientPagerMessage::endCommand(){   mDum.post(new ClientPagerMessageEndCommand(*this));}size_tClientPagerMessage::msgQueued () const{    return  mMsgQueue.size();}voidClientPagerMessage::pageFirstMsgQueued (){   assert(mMsgQueue.empty() == false);   mRequest->header(h_CSeq).sequence()++;   mRequest->setContents(mMsgQueue.front().contents);   DumHelper::setOutgoingEncryptionLevel(*mRequest, mMsgQueue.front().encryptionLevel);   DebugLog(<< "ClientPagerMessage::pageFirstMsgQueued: " << *mRequest);   mDum.send(mRequest);}voidClientPagerMessage::clearMsgQueued (){   MsgQueue::iterator   contents;   for(contents = mMsgQueue.begin(); contents != mMsgQueue.end(); ++contents)   {      Contents* p = contents->contents;      delete p;   }   mMsgQueue.clear();}std::ostream& ClientPagerMessage::dump(std::ostream& strm) const{   strm << "ClientPagerMessage queued: " << mMsgQueue.size();   return strm;}/* ==================================================================== * 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 + -