中间件底层,websocket

TaskAgentTurnIvr.cpp 5.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. #include "stdafx.h"
  2. #include "TaskAgentTurnIvr.h"
  3. #include "LineHolder.h"
  4. #include "LogicLine.h"
  5. #include "CtiCore.h"
  6. #include "NetworkCti.h"
  7. CTaskAgentTurnIvr::CTaskAgentTurnIvr(CPduEntity &PduEntity) : CTask(PduEntity)
  8. {
  9. }
  10. CTaskAgentTurnIvr::~CTaskAgentTurnIvr(void)
  11. {
  12. }
  13. /*****************************************************************
  14. **【函数名称】 DoTask
  15. **【函数功能】 Task处理
  16. **【参数】
  17. **【返回值】 void
  18. ****************************************************************/
  19. BOOL CTaskAgentTurnIvr::DoTask()
  20. {
  21. // 显示日志
  22. ShowLog();
  23. // 校验
  24. if (!Verify()) return FALSE;
  25. if (m_pCurrLine == NULL)return FALSE;
  26. // 向底层设备发送转IVR命令
  27. LineOpParam LineOpParam;
  28. memset(&LineOpParam, 0, sizeof(LineOpParam));
  29. LineOpParam.nParam1 = LINE_TURN_TO_IVR;
  30. LineOpParam.nParam2 = m_pCurrLine->lineId();
  31. LineOpParam.nParam3 = m_CurrCmd.GetDataBool(8) ? 1 : 0;
  32. LineOpParam.nParam4 = m_pCurrLine->callId(); // callid
  33. if (m_CurrCmd.GetDataString(6) != "MYD") // 2022-07-05 不等于满意度,不需要callid,并用于底层判断是否调用lua执行满意度还是调用ivr程序
  34. LineOpParam.nParam4 = 0;
  35. return CCtiCore::GetInstance().getDevLink().exec((long)this, LINE_OP_TURNIVR, m_pCurrLine->assoLine()->lineId(), &LineOpParam);
  36. }
  37. /*****************************************************************
  38. **【函数名称】 Verify
  39. **【函数功能】 校验
  40. **【参数】
  41. **【返回值】 BOOL
  42. ****************************************************************/
  43. BOOL CTaskAgentTurnIvr::Verify()
  44. {
  45. // 线路绑定校验
  46. if(!_bindLogicLine(m_CurrCmd.GetDataUInt(1)))
  47. return FALSE;
  48. // 如果线路在监听状态,则不允许转IVR
  49. if (PDU_CMD_AGENT_MONI_LISTEN == m_pCurrLine->opType())
  50. {
  51. ILogger::getInstance().log(LOG_CLASS_SOCKET, LOG_LEVEL_WARNING, _T("{Task}: 线路[%d]执行座席转IVR任务校验时失败:监听状态下不允许转IVR!"), m_pCurrLine->lineId());
  52. return FALSE;
  53. }
  54. // 获取关联中继线路
  55. CLogicLine* pAssoLine = m_pCurrLine->assoLine();
  56. ASSERT(pAssoLine != NULL);
  57. if(pAssoLine == NULL)
  58. {
  59. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_WARNING, _T("{Task}: 线路[%d]执行座席转IVR任务校验时失败:无法获取对应线路"), m_CurrCmd.GetDataUInt(1));
  60. return FALSE;
  61. }
  62. // 状态校验
  63. if(m_pCurrLine->status() != INNER_STATE_TALKING || pAssoLine->status() != TRUNK_STATE_TALKING)
  64. {
  65. ILogger::getInstance().log(LOG_CLASS_SOCKET, LOG_LEVEL_WARNING, _T("{Task}: 线路[%d]执行座席转IVR任务校验时失败:当前线路状态校验不通过!"), m_pCurrLine->lineId());
  66. return FALSE;
  67. }
  68. // 解绑座席分机线路
  69. _freeLogicLine();
  70. // 重新绑定座席线路关联的中继线路
  71. if(!_bindLogicLine(pAssoLine->lineId()))
  72. return FALSE;
  73. // 命令保存信息
  74. m_CurrCmd.SetDataULong(3, m_pCurrLine->callId()); // 获取CallId
  75. m_CurrCmd.SetDataUInt(4, m_pCurrLine->lineId()); // 获取外线Id
  76. return TRUE;
  77. }
  78. /*****************************************************************
  79. **【函数名称】 ShowLog
  80. **【函数功能】 显示日志
  81. **【参数】
  82. **【返回值】 void
  83. ****************************************************************/
  84. void CTaskAgentTurnIvr::ShowLog()
  85. {
  86. // 显示日志
  87. ILogger::getInstance().log(LOG_CLASS_SOCKET, LOG_LEVEL_NORMAL, _T("AGENT->CTI, CMD = [座席转IVR], \
  88. Exten = %d, IvrFileName = %s"),
  89. m_CurrCmd.GetDataUInt(1),
  90. m_CurrCmd.GetDataString(6));
  91. }
  92. /*****************************************************************
  93. **【函数名称】 OnDevOpResult
  94. **【函数功能】 底层线路操作结果
  95. **【参数】
  96. **【返回值】 void
  97. ****************************************************************/
  98. BOOL CTaskAgentTurnIvr::OnDevOpResult(EventOpResult &EvtInfo)
  99. {
  100. if(!EvtInfo.bIsSucceed)
  101. {
  102. // 返回转Ivr失败
  103. _ProcCmdReturn(EvtInfo.bIsSucceed);
  104. return TRUE;
  105. }
  106. else
  107. {
  108. // 向Ivr发送转Ivr命令
  109. CPduEntity CmdTurnIvr(PDU_CMD_CTI_IVR_TURNIVR);
  110. CmdTurnIvr.SetDataULong(2, m_pCurrLine->callId()); // CallId
  111. CmdTurnIvr.SetDataString(3, m_pCurrLine->callerNum()); // 主叫
  112. CmdTurnIvr.SetDataString(4, m_pCurrLine->calleeNum()); // 被叫
  113. CmdTurnIvr.SetDataUInt(5, m_pCurrLine->lineId()); // 外线Id
  114. CmdTurnIvr.SetDataUInt(6, m_CurrCmd.GetDataUInt(1)); // 分机Id
  115. CmdTurnIvr.SetDataUInt(7, m_CurrCmd.GetDataUInt(5)); // IVr节点号
  116. CmdTurnIvr.SetDataString(8, m_CurrCmd.GetDataString(6)); // Ivr文件名
  117. CmdTurnIvr.SetDataString(9, m_CurrCmd.GetDataString(7)); // 随路数据
  118. CmdTurnIvr.SetDataBool(10, m_CurrCmd.GetDataBool(8)); // 是否返回
  119. BOOL bRet = true;
  120. if (m_CurrCmd.GetDataString(6) != "MYD") // 满意度走lua脚本,不再走ivr程序
  121. {
  122. bRet = CNetworkCti::GetInstance().send2IVR(CmdTurnIvr);
  123. }
  124. // 发送IVR失败,转IVR失败,外线挂机
  125. if(!bRet)
  126. {
  127. LineOpParam pLineOpParam;
  128. memset(&pLineOpParam,0,sizeof(pLineOpParam));
  129. CCtiCore::GetInstance().getDevLink().exec((long)this, LINE_OP_HANG_UP, m_pCurrLine->lineId(), &pLineOpParam);
  130. _ProcCmdReturn(FALSE);
  131. }
  132. return !bRet;
  133. }
  134. }
  135. /*****************************************************************
  136. **【函数名称】 OnCmdOperation
  137. **【函数功能】 Task命令处理
  138. **【参数】 成功还是失败
  139. **【返回值】 void
  140. ****************************************************************/
  141. BOOL CTaskAgentTurnIvr::OnCmdOperation(CPduEntity &PduEntity)
  142. {
  143. if(PduEntity.GetCmdType() != PDU_CMD_CTI_IVR_TURNIVR) return FALSE;
  144. _ProcCmdReturn(PduEntity.GetDataBool(0));
  145. return TRUE;
  146. }