中间件标准版5.1git,去除基础模块

TaskAgentCall.cpp 4.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. #include "stdafx.h"
  2. #include "TaskAgentCall.h"
  3. #include "LineHolder.h"
  4. #include "LogicLine.h"
  5. #include "LogicLineExt.h"
  6. #include "StatisticsMgr.h"
  7. #include "CtiCore.h"
  8. CTaskAgentCall::CTaskAgentCall(CPduEntity &PduEntity) : CTask(PduEntity)
  9. {
  10. m_HeadNumber="";
  11. m_VisitStr="";
  12. }
  13. CTaskAgentCall::~CTaskAgentCall(void)
  14. {
  15. }
  16. /*****************************************************************
  17. **【函数名称】 DoTask
  18. **【函数功能】 Task处理
  19. **【参数】
  20. **【返回值】 void
  21. ****************************************************************/
  22. BOOL CTaskAgentCall::DoTask()
  23. {
  24. // 显示日志
  25. ShowLog();
  26. // 校验
  27. if(!Verify()) return FALSE;
  28. // 设置当前操作类型
  29. m_pCurrLine->opType() = PDU_CMD_AGENT_MAKECALL;
  30. // 向底层设备发送外呼命令
  31. LineOpParam pLineOpParam;
  32. memset(&pLineOpParam, 0, sizeof(pLineOpParam));
  33. lstrcpy(pLineOpParam.szParam1, m_CurrCmd.GetDataString(5));
  34. lstrcpy(pLineOpParam.szParam2, m_CurrCmd.GetDataString(4));
  35. m_HeadNumber= m_CurrCmd.GetDataString(7);
  36. m_VisitStr = m_CurrCmd.GetDataString(8);
  37. return CCtiCore::GetInstance().getDevLink().exec((long)this, LINE_OP_MAKE_CALL, m_pCurrLine->lineId(), &pLineOpParam);
  38. }
  39. /*****************************************************************
  40. **【函数名称】 Verify
  41. **【函数功能】 校验
  42. **【参数】
  43. **【返回值】 BOOL
  44. ****************************************************************/
  45. BOOL CTaskAgentCall::Verify()
  46. {
  47. // 获取对端线路
  48. int nAssoLineId;
  49. sscanf_s(m_CurrCmd.GetDataString(4).GetBuffer(), "%d", &nAssoLineId);
  50. CLogicLine *pAssoLine = CLineHolder::GetInstance().getLogicLine(nAssoLineId);
  51. // 设置返回命令外呼类型(0呼外线,1呼坐席)
  52. if(pAssoLine == NULL)
  53. m_CurrCmd.SetDataUInt(6, 0);
  54. else
  55. m_CurrCmd.SetDataUInt(6, pAssoLine->type() == DEV_RES_TYPE_EXT ? 1:0);
  56. // 线路绑定校验
  57. if(!_bindLogicLine(m_CurrCmd.GetDataUInt(1)))
  58. return FALSE;
  59. // 本端状态校验
  60. if((m_pCurrLine->status() & 0xFF) != INNER_STATE_INIT && (m_pCurrLine->status() & 0xFF) != INNER_STATE_FREE)
  61. {
  62. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_WARNING, _T("{Task}: 线路[%d]执行座席呼叫任务校验时失败:当前线路忙"), m_pCurrLine->lineId());
  63. return FALSE;
  64. }
  65. // 对端线路状态验证
  66. if(pAssoLine != NULL && pAssoLine->type() == DEV_RES_TYPE_EXT &&
  67. pAssoLine->status() != INNER_STATE_INIT &&
  68. pAssoLine->status() != INNER_STATE_FREE)
  69. {
  70. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_WARNING, _T("{Task}: 线路[%d]执行座席呼叫任务校验时失败:关联线路状态校验不通过"), m_pCurrLine->lineId());
  71. return FALSE;
  72. }
  73. return TRUE;
  74. }
  75. /*****************************************************************
  76. **【函数名称】 ShowLog
  77. **【函数功能】 显示日志
  78. **【参数】
  79. **【返回值】 void
  80. ****************************************************************/
  81. void CTaskAgentCall::ShowLog()
  82. {
  83. // 显示日志
  84. ILogger::getInstance().log(LOG_CLASS_SOCKET, LOG_LEVEL_NORMAL, _T("AGENT->CTI, CMD = [座席呼叫], \
  85. Exten = %d, DestNum = %s"), m_CurrCmd.GetDataUInt(1), m_CurrCmd.GetDataString(4));
  86. }
  87. /*****************************************************************
  88. **【函数名称】 ProcLineOpProcess
  89. **【函数功能】 处理设备操作进展
  90. **【参数】 EvtType 消息事件类型;lpContent 消息内容
  91. **【返回值】 void
  92. ****************************************************************/
  93. void CTaskAgentCall::OnDevOpProcess(EventOpProcess &EvtInfo)
  94. {
  95. // 处理会话
  96. _PrcoCallNode(m_pCurrLine->lineId(), EvtInfo.nAssoLine);
  97. // 获取对端线路
  98. CLogicLine *pAssoLine = CLineHolder::GetInstance().getLogicLine(EvtInfo.nAssoLine);
  99. if(pAssoLine == NULL) return;
  100. // 统计 REP_EVENT_EXT_CALL_OUT
  101. T_EvtExtCallOut repInfoCallOut;
  102. memset(&repInfoCallOut, 0, sizeof(repInfoCallOut));
  103. repInfoCallOut.nCallType = 0; // 呼出方式(0:ocx外呼,1:话机外呼)
  104. repInfoCallOut.nPeerLineType = EvtInfo.nAssoLineType; // 对端线路类型
  105. repInfoCallOut.nCallerAgentId = m_pCurrLine->getAgentNum(); // 主叫坐席工号
  106. repInfoCallOut.nCalleeAgentId = pAssoLine->getAgentNum(); // 被叫坐席工号
  107. lstrcpy(repInfoCallOut.szCalleeNum, m_CurrCmd.GetDataString(4)); // 被叫号码
  108. lstrcpy(repInfoCallOut.szCalleeHeader,m_HeadNumber); // 号码前缀
  109. lstrcpy(repInfoCallOut.szVisitstr,m_VisitStr); //回访字符串
  110. CStatisticsMgr::GetInstance().onCallDetail(m_pCurrLine->callId(), REP_EVENT_EXT_CALL_OUT, m_pCurrLine->lineId(), &repInfoCallOut);
  111. // 统计REP_EVENT_EXT_CALL_IN
  112. T_EvtExtCallIn repInfoCallIn;
  113. if(pAssoLine->type() != DEV_RES_TYPE_EXT) return;
  114. memset(&repInfoCallIn, 0, sizeof(repInfoCallIn));
  115. repInfoCallIn.nCallType = 0; // 呼入方式(0:坐席呼入 1:转坐席呼入,2:转移呼入,3:会议呼入)
  116. repInfoCallIn.nPeerLineType = m_pCurrLine->type(); // 对端线路类型
  117. repInfoCallIn.nCallerAgentId = m_pCurrLine->getAgentNum(); // 主叫坐席工号
  118. lstrcpy(repInfoCallIn.szCallerNum, EvtInfo.szCallerNum); // 主叫号码
  119. repInfoCallIn.nCalleeAgentId = pAssoLine->getAgentNum(); // 被叫坐席工号
  120. CStatisticsMgr::GetInstance().onCallDetail(pAssoLine->callId(), REP_EVENT_EXT_CALL_IN, pAssoLine->lineId(), &repInfoCallIn);
  121. }