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

TaskAgentTurnIvr.cpp 4.7KB

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