升龙物业 老版本 ocx IPO, 加密狗 转值班电话

TrunkTurnReq.cpp 5.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. #include "StdAfx.h"
  2. #include "TrunkTurnReq.h"
  3. #include "ProxyExten.h"
  4. #include "SessionShell.h"
  5. #include "ControlShell.h"
  6. #include "ProxyShell.h"
  7. #include "MC.h"
  8. CTrunkTurnReq::CTrunkTurnReq(CProxyShell* pParent, CPduEntity& ReqPdu) : CReqBase(pParent, ReqPdu),
  9. m_pAssoLine(NULL), m_PendingCallId(SESSION_INVALID_SUB_CALL), m_PeerLineType(DEV_RES_TYPE_EXT), m_SipAccountId(INVALID_ID_SIP_ACCOUNT)
  10. {
  11. }
  12. CTrunkTurnReq::~CTrunkTurnReq(void)
  13. {
  14. }
  15. /*****************************************************************
  16. **【函数名称】 request
  17. **【函数功能】 发出请求(命令方式)
  18. **【参数】
  19. **【返回值】
  20. ****************************************************************/
  21. bool CTrunkTurnReq::request( void )
  22. {
  23. // 校验状态
  24. if(m_pHostLine->state() != VIRTUAL_LINE_STATE_TALKING)
  25. return false;
  26. // 保存被叫信息
  27. CString CallerNum = m_ReqPdu.GetDataString(4);
  28. m_DestNum = m_ReqPdu.GetDataString(3);
  29. // 根据被叫号码查找对端线路且修正被叫号码
  30. m_pAssoLine = m_pParent->setEnv4Calling(CallerNum, m_DestNum, m_PeerLineType, m_SipAccountId);
  31. if(m_pAssoLine == NULL)
  32. {
  33. LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_WARNING, _T("{LineReq}: 中继[%lu]跳转失败, 查找关联线路失败, DestNum = %s"),
  34. m_pHostLine->lineId(), m_DestNum);
  35. return false;
  36. } // end if
  37. if(m_pAssoLine->type() == DEV_RES_TYPE_EXT)
  38. {
  39. if(m_pAssoLine->state() != VIRTUAL_LINE_STATE_FREE)
  40. {
  41. LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_WARNING, _T("{LineReq}: 中继[%lu]跳转失败, 对端分机[%s]非空闲"), m_pHostLine->lineId(), m_DestNum);
  42. return false;
  43. }
  44. CallerNum = m_pHostLine->callerNum();
  45. }
  46. // 通知启动日志
  47. LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{LineReq}: 中继[%lu]跳转, DestNum = %s, HostCall = %ld"),
  48. m_pHostLine->lineId(), m_DestNum, m_pHostLine->activeCallId());
  49. // 开始建立转移
  50. PendingCallInfo info;
  51. memset(&info, 0, sizeof(PendingCallInfo));
  52. info.nCall = m_pHostLine->activeCallId();
  53. info.nHostLine = m_pHostLine->devId();
  54. info.nAssoLine = m_pAssoLine->devId();
  55. lstrcpy(info.szCallerNum, CallerNum);
  56. lstrcpy(info.szCalleeNum, m_DestNum);
  57. lstrcpy(info.szPreCallerNum, m_pHostLine->callerNum());
  58. lstrcpy(info.szPreCalleeNum, m_pHostLine->calleeNum());
  59. info.nCallType = (m_PeerLineType == DEV_RES_TYPE_EXT) ? PENDING_CALL_DIRECT : PENDING_CALL_TRUNK;
  60. info.nHostLineStatus = VIRTUAL_LINE_STATE_TALKING;
  61. info.nSipAccountId = m_SipAccountId;
  62. return CSessionShell::GetInstance().procReqDialSetup(m_PendingCallId, &info);
  63. }
  64. /*****************************************************************
  65. **【函数名称】 hangUp
  66. **【函数功能】 操作中挂机(命令方式)
  67. **【参数】
  68. **【返回值】
  69. ****************************************************************/
  70. bool CTrunkTurnReq::hangUp( long InstanceHangUp )
  71. {
  72. // 转座席取消日志
  73. LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, __T("{LineReq}: 中继[%lu]因挂机取消跳转, DestNum = %s"),
  74. m_pHostLine->lineId(), m_DestNum);
  75. m_InstanceCancel = InstanceHangUp;
  76. return CMC::GetInstance().dropCall(m_pAssoLine->devId(), false);
  77. }
  78. /*****************************************************************
  79. **【函数名称】 end
  80. **【函数功能】 操作完成
  81. **【参数】 IsSucceed 操作是否成功
  82. lpData 随路数据
  83. **【返回值】
  84. ****************************************************************/
  85. void CTrunkTurnReq::end( bool IsSucceed, LPCTSTR lpData )
  86. {
  87. if(IsSucceed)
  88. {
  89. LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{LineReq}: 中继[%lu]跳转成功, DestNum = %s"), m_pHostLine->lineId(), m_DestNum);
  90. }
  91. else
  92. {
  93. LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_WARNING, _T("{LineReq}: 中继[%lu]跳转失败, DestNum = %s"), m_pHostLine->lineId(), m_DestNum);
  94. } // end if
  95. // 返回执行结果
  96. if(m_InstanceCancel != 0)
  97. {
  98. m_pParent->notifyReqResult(m_ReqPdu, m_InstanceCancel, !IsSucceed, lpData);
  99. } // end if
  100. m_pParent->onLineReqEnd(this, IsSucceed, lpData);
  101. }
  102. /*****************************************************************
  103. **【函数名称】 onDevChEvent
  104. **【函数功能】 线路向上层发送的设备主动事件
  105. **【参数】 pEventLine 触发事件的线路
  106. EvtType 事件类型
  107. lpContent 事件内容
  108. **【返回值】
  109. *****************************************************************/
  110. void CTrunkTurnReq::onDevChEvent( CVirtualProxy* pEventLine, DEV_CH_EVT_TYPE EvtType, LPCTSTR lpContent )
  111. {
  112. // TODO: do nothing
  113. }
  114. /*****************************************************************
  115. **【函数名称】 onLineStateChanged
  116. **【函数功能】 线路状态变化事件响应接口
  117. **【参数】 pEventLine 状态变化的线路实体指针
  118. LineState 线路当前状态
  119. Call 主呼叫ID
  120. SubCall 子呼叫ID
  121. lpCallerNum 主叫号码
  122. lpCalleeNum 被叫号码
  123. **【返回值】
  124. ****************************************************************/
  125. void CTrunkTurnReq::onLineStateChanged( CVirtualProxy* pEventLine, VIRTUAL_LINE_STATE LineState, long Call, long SubCall, LPCTSTR lpCallerNum, LPCTSTR lpCalleeNum )
  126. {
  127. // 外线挂机
  128. if(LineState == VIRTUAL_LINE_STATE_FREE && SubCall == SESSION_INVALID_SUB_CALL)
  129. {
  130. CMC::GetInstance().dropCall(m_pAssoLine->devId(), false);
  131. end(false, NULL);
  132. return;
  133. } // end if
  134. if(SubCall != m_PendingCallId) // 其它呼叫信息
  135. return;
  136. // 根据线路状态进行处理
  137. switch(LineState)
  138. {
  139. case VIRTUAL_LINE_STATE_FREE: // 呼叫失败
  140. {
  141. end(false, NULL);
  142. }
  143. break;
  144. case VIRTUAL_LINE_STATE_RING_BACK: // 呼出振铃
  145. {
  146. _notifyOpProcess(m_pHostLine->lineId(), m_pAssoLine->lineId(), m_PeerLineType, lpCallerNum, lpCalleeNum);
  147. }
  148. break;
  149. case VIRTUAL_LINE_STATE_TALKING: // 呼叫成功
  150. {
  151. end(true, NULL);
  152. }
  153. break;
  154. } // end switch
  155. }