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

CdrConference.cpp 3.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. #include "StdAfx.h"
  2. #include "CdrConference.h"
  3. #include "SqlWriter.h"
  4. CCdrConference::CCdrConference(ULONG uCallId, UINT nActionId, UINT nHostLine) : m_uCallId(uCallId), m_nActionId(nActionId), m_nHostLine(nHostLine)
  5. {
  6. m_bIsActive = TRUE;
  7. m_nPeerLineType = 0;
  8. m_nCallerAgentId = 0;
  9. m_strCallerNum = _T("");
  10. m_nCalleeAgentId = 0;
  11. m_strCalleeNum = _T("");
  12. m_nTimeConference = 0;
  13. m_nIsConferenceSucceed = 0;
  14. m_nTimeConnected = 0;
  15. m_nTimeConferenceEnd = 0;
  16. }
  17. CCdrConference::~CCdrConference(void)
  18. {
  19. }
  20. /*****************************************************************
  21. **【函数名称】 __verifyData
  22. **【函数功能】 数据校验
  23. **【参数】
  24. **【返回值】
  25. *****************************************************************/
  26. BOOL CCdrConference::__verifyData()
  27. {
  28. // 会话销毁时,填充三方结束时间
  29. if(m_nTimeConferenceEnd == 0) m_nTimeConferenceEnd = time(NULL);
  30. return TRUE;
  31. }
  32. /*****************************************************************
  33. **【函数名称】 onCallDetail
  34. **【函数功能】 统计事件响应
  35. **【参数】 nEvent 统计事件
  36. nHostLine 主控线路
  37. lpParam 统计信息
  38. **【返回值】
  39. *****************************************************************/
  40. void CCdrConference::onCallDetail( REP_EVENT nEvent, UINT nHostLine, void* lpParam )
  41. {
  42. // 接收并处理 Conference表 需要的事件
  43. switch (nEvent)
  44. {
  45. case REP_EVENT_CONFERENCE: // 会议事件
  46. {
  47. if(nHostLine != m_nHostLine) return;
  48. T_EvtConference* tEvent = (T_EvtConference*)lpParam;
  49. m_nCallerAgentId = tEvent->nCallerAgentId; // 主叫坐席工号
  50. m_strCallerNum.Format(_T("%d"), nHostLine); // 主叫号码
  51. m_nCalleeAgentId = tEvent->nCalleeAgentId; // 被叫坐席工号
  52. m_strCalleeNum = tEvent->szCalleeNum; // 被叫号码
  53. m_nTimeConference = time(NULL); // 发起会议时间
  54. m_nTimeConnected = time(NULL); // 接通时间
  55. m_nPeerLineType = tEvent->nPeerLineType; // 对端线路类型
  56. }
  57. break;
  58. case REP_EVENT_CONF_RESULT: // 三方结束事件
  59. {
  60. if(nHostLine != m_nHostLine) return;
  61. T_EvtConference* tEvent = (T_EvtConference*)lpParam;
  62. m_nTimeConferenceEnd = time(NULL); // 记录结束时间
  63. if(tEvent->bEvtResult)
  64. {
  65. m_nIsConferenceSucceed = 1; // 会议成功
  66. }
  67. // 提交数据
  68. toSql();
  69. }
  70. break;
  71. default:
  72. break;
  73. } // end switch
  74. }
  75. /*****************************************************************
  76. **【函数名称】 toSql
  77. **【函数功能】 更新数据库表数据
  78. **【参数】
  79. **【返回值】
  80. *****************************************************************/
  81. void CCdrConference::toSql()
  82. {
  83. // 表被关闭,不再更新数据
  84. if (!m_bIsActive) return;
  85. // 数据校验(有关键数据未填写且不适合自动填充时,返回失败)
  86. if (__verifyData())
  87. m_bIsActive = FALSE;
  88. else
  89. return;
  90. // 写入 rep_host 主表
  91. CSqlWriter& Writer = CSqlWriter::GetInstance();
  92. CString strSql = _T("");
  93. strSql.Format(_T("INSERT INTO rep_host (CallID, ActionID, CallTypeOpType, HostLine, CallerNum, CalleeNum, TimeConnected, TimeHangUp)\
  94. VALUES (%lu, %d, %d, %d, '%s', '%s', %s, %s)"),
  95. m_uCallId,
  96. m_nActionId,
  97. REP_EVENT_CONFERENCE,
  98. m_nHostLine,
  99. m_strCallerNum,
  100. m_strCalleeNum,
  101. FormatTime(m_nTimeConnected),
  102. FormatTime(0)
  103. );
  104. Writer.addSql(strSql);
  105. // 写入 rep_conference 会议子表
  106. strSql.Format(_T("INSERT INTO rep_conference (CallID,ActionID,PeerLineType,CallerAgentID,CallerNum,CalleeAgentID,CalleeNum,\
  107. TimeConference,IsConferenceSucceed,TimeConnected,TimeConferenceEnd)\
  108. VALUES (%lu, %d, %d, %d, '%s', %d, '%s', %s, %d, %s, %s)"),
  109. m_uCallId,
  110. m_nActionId,
  111. m_nPeerLineType,
  112. m_nCallerAgentId,
  113. m_strCallerNum,
  114. m_nCalleeAgentId,
  115. m_strCalleeNum,
  116. FormatTime(m_nTimeConference),
  117. m_nIsConferenceSucceed,
  118. FormatTime(m_nTimeConnected),
  119. FormatTime(m_nTimeConferenceEnd)
  120. );
  121. Writer.addSql(strSql);
  122. }