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

CdrFax.cpp 3.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. #include "StdAfx.h"
  2. #include "CdrFax.h"
  3. #include "SqlWriter.h"
  4. CCdrFax::CCdrFax(ULONG uCallId, UINT nActionId, UINT nHostLine) : m_uCallId(uCallId), m_nActionId(nActionId), m_nHostLine(nHostLine)
  5. {
  6. m_bIsActive = TRUE;
  7. m_nIsAuto = 0;
  8. m_nRcvOrSend = 0;
  9. m_nTimeFaxBegin = 0;
  10. m_nCallerAgentId = 0;
  11. m_strCallerNum = _T("");
  12. m_nCalleeAgentId = 0;
  13. m_strCalleeNum = _T("");
  14. m_nIsSucceed = 0;
  15. m_nPeriodFax = 0;
  16. m_strFaxFileName = _T("");
  17. }
  18. CCdrFax::~CCdrFax(void)
  19. {
  20. }
  21. /*****************************************************************
  22. **【函数名称】 __VerifyData
  23. **【函数功能】 数据校验
  24. **【参数】
  25. **【返回值】
  26. *****************************************************************/
  27. BOOL CCdrFax::__verifyData()
  28. {
  29. return TRUE;
  30. }
  31. /*****************************************************************
  32. **【函数名称】 onCallDetail
  33. **【函数功能】 统计事件响应
  34. **【参数】 nEvent 统计事件
  35. nHostLine 主控线路
  36. lpParam 统计信息
  37. **【返回值】
  38. *****************************************************************/
  39. void CCdrFax::onCallDetail( REP_EVENT nEvent, UINT nHostLine, void* lpParam )
  40. {
  41. // 接收并处理 fax表 需要的事件
  42. switch (nEvent)
  43. {
  44. case REP_EVENT_FAX_BEGIN: // 接收传真开始事件
  45. {
  46. if (m_nHostLine == nHostLine)
  47. {
  48. T_EvtFaxBegin* tEvent = (T_EvtFaxBegin*)lpParam;
  49. m_nIsAuto = tEvent->nIsAuto; // 是否自动收发
  50. m_nRcvOrSend = tEvent->nRcvOrSend; // 收/发传真
  51. m_nTimeFaxBegin = time(NULL); // 开始时间
  52. m_nCallerAgentId = tEvent->nCallerAgentId; // 主叫坐席工号
  53. m_strCallerNum = tEvent->szCallerNum; // 主叫号码
  54. m_nCalleeAgentId = tEvent->nCalleeAgentId; // 被叫坐席工号
  55. m_strCalleeNum = tEvent->szCalleeNum; // 被叫号码
  56. m_strFaxFileName = tEvent->szFileName; // 传真文件路径
  57. }
  58. }
  59. break;
  60. case REP_EVENT_FAX_END: // 收发传真结束
  61. {
  62. if (m_nHostLine == nHostLine)
  63. {
  64. T_EvtFaxEnd* tEvent = (T_EvtFaxEnd*)lpParam;
  65. m_nIsSucceed = tEvent->nIsSucceed; // 收发是否成功
  66. m_nPeriodFax = (UINT)(time(NULL) - m_nTimeFaxBegin); // 收发传真时长
  67. // 更新数据
  68. toSql();
  69. }
  70. }
  71. break;
  72. default:
  73. break;
  74. } // end switch
  75. }
  76. /*****************************************************************
  77. **【函数名称】 toSql
  78. **【函数功能】 更新数据库表数据
  79. **【参数】
  80. **【返回值】
  81. *****************************************************************/
  82. void CCdrFax::toSql()
  83. {
  84. // 表被关闭,不再更新数据
  85. if (!m_bIsActive)
  86. return;
  87. // 数据校验(有关键数据未填写且不适合自动填充时,返回失败)
  88. if (__verifyData())
  89. m_bIsActive = FALSE;
  90. else
  91. return;
  92. // 写入 rep_fax 收发传真子表
  93. CSqlWriter& Writer = CSqlWriter::GetInstance();
  94. CString strSql = _T("");
  95. strSql.Format(_T("INSERT INTO rep_fax (CallID,ActionID,IsAuto,RcvOrSend,TimeFaxBegin,CallerAgentID,\
  96. CallerNum,CalleeAgentID,CalleeNum,IsSucceed,PeriodFax,FaxFileName)\
  97. VALUES (%lu, %d, %d, %d, %s, %d, '%s', %d, '%s', %d, %d, '%s')"),
  98. m_uCallId,
  99. m_nActionId,
  100. m_nIsAuto,
  101. m_nRcvOrSend,
  102. FormatTime(m_nTimeFaxBegin),
  103. m_nCallerAgentId,
  104. m_strCallerNum,
  105. m_nCalleeAgentId,
  106. m_strCalleeNum,
  107. m_nIsSucceed,
  108. m_nPeriodFax,
  109. m_strFaxFileName
  110. );
  111. Writer.addSql(strSql);
  112. }