hd

CdrInstead.cpp 4.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. #include "StdAfx.h"
  2. #include "CdrInstead.h"
  3. #include "SqlWriter.h"
  4. CCdrInstead::CCdrInstead(ULONG uCallId, UINT nActionId, UINT nHostLine) : m_uCallId(uCallId), m_nActionId(nActionId), m_nHostLine(nHostLine)
  5. {
  6. m_bIsActive = TRUE;
  7. m_nCallerAgentId = 0;
  8. m_strCallerNum = _T("");
  9. m_nCalleeAgentId = 0;
  10. m_strCalleeNum = _T("");
  11. m_nTimeInstead = 0;
  12. m_nIsInsteadSucceed = 0;
  13. m_nTimeConnected = 0;
  14. m_strRecFileName = _T("");
  15. m_nTimeHangUp = 0;
  16. m_nPeriodTalking = 0;
  17. }
  18. CCdrInstead::~CCdrInstead(void)
  19. {
  20. }
  21. /*****************************************************************
  22. **【函数名称】 __verifyData
  23. **【函数功能】 数据校验
  24. **【参数】
  25. **【返回值】
  26. *****************************************************************/
  27. BOOL CCdrInstead::__verifyData()
  28. {
  29. return TRUE;
  30. }
  31. /*****************************************************************
  32. **【函数名称】 __onLineStateChanged
  33. **【函数功能】 线路状态变化响应
  34. **【参数】 nHostLine 主控线路
  35. tEvtState 线路状态变化事件
  36. **【返回值】
  37. *****************************************************************/
  38. void CCdrInstead::__onLineStateChanged( UINT nHostLine, T_EvtStateChanged* tEvtState )
  39. {
  40. // 接收并处理 Instead表 需要的线路状态
  41. switch (tEvtState->nLineState)
  42. {
  43. case INNER_STATE_TALKING: // 内线通话中
  44. {
  45. if (m_nHostLine == nHostLine)
  46. {
  47. m_nIsInsteadSucceed = 1; // 代接成功
  48. m_nTimeConnected = time(NULL); // 接通时间
  49. }
  50. }
  51. break;
  52. case INNER_STATE_FREE: // 内线挂机
  53. {
  54. if (m_nHostLine == nHostLine)
  55. {
  56. m_nTimeHangUp = time(NULL); // 挂机时间
  57. m_nPeriodTalking = (m_nIsInsteadSucceed == 1) ? (UINT)(m_nTimeHangUp - m_nTimeConnected) : 0; // 通话时长
  58. // 更新数据
  59. toSql();
  60. }
  61. }
  62. break;
  63. default:
  64. break;
  65. } // end switch
  66. }
  67. /*****************************************************************
  68. **【函数名称】 onCallDetail
  69. **【函数功能】 统计事件响应
  70. **【参数】 nEvent 统计事件
  71. nHostLine 主控线路
  72. lpParam 统计信息
  73. **【返回值】
  74. *****************************************************************/
  75. void CCdrInstead::onCallDetail( REP_EVENT nEvent, UINT nHostLine, void* lpParam )
  76. {
  77. // 接收并处理 instead表 需要的事件
  78. switch (nEvent)
  79. {
  80. case REP_EVENT_INSTEAD: // 坐席代接事件
  81. {
  82. T_EvtInstead* tEvent = (T_EvtInstead*)lpParam;
  83. m_nCallerAgentId = tEvent->nCallerAgentId; // 主叫坐席工号
  84. m_strCallerNum = tEvent->szCallerNum; // 主叫号码
  85. m_nCalleeAgentId = tEvent->nCalleeAgentId; // 被叫坐席工号
  86. m_strCalleeNum.Format(_T("%d"), nHostLine); // 被叫号码
  87. m_nTimeInstead = time(NULL); // 代接开始时间
  88. }
  89. break;
  90. case REP_EVENT_REC_BEGIN: // 录音开始事件
  91. {
  92. T_EvtRecBegin* tEvent = (T_EvtRecBegin*)lpParam;
  93. if (m_nHostLine == nHostLine)
  94. m_strRecFileName = tEvent->szFileName; // 录音文件路径
  95. }
  96. break;
  97. case REP_EVENT_HANG_UP: // 挂机事件
  98. {
  99. if (m_nHostLine == nHostLine)
  100. {
  101. m_nTimeHangUp = time(NULL); // 坐席挂机时间
  102. m_nPeriodTalking = (m_nIsInsteadSucceed == 1) ? (UINT)(m_nTimeHangUp - m_nTimeConnected) : 0; // 通话时长
  103. // 更新数据
  104. toSql();
  105. }
  106. }
  107. break;
  108. case REP_EVENT_STATE_CHANGED: // 线路变化事件
  109. {
  110. T_EvtStateChanged* tEvtState = (T_EvtStateChanged*)lpParam;
  111. __onLineStateChanged(nHostLine, tEvtState);
  112. }
  113. break;
  114. default:
  115. break;
  116. } // end switch
  117. }
  118. /*****************************************************************
  119. **【函数名称】 toSql
  120. **【函数功能】 更新数据库表数据
  121. **【参数】
  122. **【返回值】
  123. *****************************************************************/
  124. void CCdrInstead::toSql()
  125. {
  126. // 表被关闭,不再更新数据
  127. if (!m_bIsActive)
  128. return;
  129. // 数据校验(有关键数据未填写且不适合自动填充时,返回失败)
  130. if (__verifyData())
  131. m_bIsActive = FALSE;
  132. else
  133. return;
  134. // 写入 rep_host 主表
  135. CSqlWriter& Writer = CSqlWriter::GetInstance();
  136. CString strSql = _T("");
  137. strSql.Format(_T("INSERT INTO rep_host VALUES (%lu, %d, %d, %d, '%s', '%s', %s, %s)"),
  138. m_uCallId,
  139. m_nActionId,
  140. REP_EVENT_INSTEAD,
  141. m_nHostLine,
  142. m_strCallerNum,
  143. m_strCalleeNum,
  144. FormatTime(m_nTimeConnected),
  145. FormatTime(m_nTimeHangUp)
  146. );
  147. Writer.addSql(strSql);
  148. // 写入 rep_instead 坐席代接子表
  149. strSql.Format(_T("INSERT INTO rep_instead VALUES (%lu, %d, %d, '%s', %d, '%s', %d, %d, %s, '%s', %s, %d)"),
  150. m_uCallId,
  151. m_nActionId,
  152. m_nCallerAgentId,
  153. m_strCallerNum,
  154. m_nCalleeAgentId,
  155. m_strCallerNum,
  156. m_nTimeInstead,
  157. m_nIsInsteadSucceed,
  158. FormatTime(m_nTimeConnected),
  159. m_strRecFileName,
  160. FormatTime(m_nTimeHangUp),
  161. m_nPeriodTalking
  162. );
  163. Writer.addSql(strSql);
  164. }