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

CellHangUp.cpp 2.4KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. #include "StdAfx.h"
  2. #include "CellHangUp.h"
  3. #include "NetworkIvr.h"
  4. #include "IvrFlow.h"
  5. #include "FlowDataProvider.h"
  6. IMPLEMENT_CELL_AUTOCREATE(CCellHangUp, CELL_NAME_HANGUP)
  7. CCellHangUp::CCellHangUp(void) : m_NextPos(0)
  8. {
  9. }
  10. CCellHangUp::CCellHangUp( CCellHangUp & cellHangUp ) : CCellBase(cellHangUp), m_NextPos(cellHangUp.m_NextPos)
  11. {
  12. }
  13. CCellHangUp::~CCellHangUp(void)
  14. {
  15. }
  16. /*****************************************************************
  17. **【函数名称】 operate
  18. **【函数功能】 节点执行函数
  19. **【参数】
  20. **【返回值】 下一个节点编号
  21. ****************************************************************/
  22. int CCellHangUp::operate( void )
  23. {
  24. if(m_pIvrFlow == NULL)
  25. return CELL_OP_ERROR;
  26. CString Info;
  27. _getCellInfo(Info);
  28. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{Cell}: 开始执行[%s]"), Info);
  29. CPduEntity CmdHangUp(PDU_CMD_IVR_HANGUP);
  30. CmdHangUp.SetDataInt(1, m_pIvrFlow->id());
  31. if(!CNetworkIvr::GetInstance().send(CmdHangUp))
  32. {
  33. ILogger::getInstance().log(LOG_CLASS_SOCKET, LOG_LEVEL_WARNING, _T("{Cell}: 执行[%s]出错, 向CTI发送消息失败"), Info);
  34. return CELL_OP_SEND_ERROR;
  35. }
  36. return m_NextPos;
  37. }
  38. /*****************************************************************
  39. **【函数名称】 copy
  40. **【函数功能】 拷贝自身
  41. **【参数】
  42. **【返回值】 拷贝副本
  43. ****************************************************************/
  44. CCellBase * CCellHangUp::copy( void )
  45. {
  46. CCellBase * pCellBase = new CCellHangUp(*this);
  47. return pCellBase;
  48. }
  49. /*****************************************************************
  50. **【函数名称】 fillData
  51. **【函数功能】 节点解析,填充数据
  52. **【参数】 Provider:数据提供器
  53. **【返回值】 成功true,失败false
  54. ****************************************************************/
  55. bool CCellHangUp::fillData( IFlowDataProvider& Provider )
  56. {
  57. CString Data;
  58. do
  59. {
  60. if(!Provider.getData(CELL_ATTRIBUTE_POS, Data))
  61. {
  62. Data = _T("节点号");
  63. break;
  64. }
  65. else
  66. {
  67. sscanf_s(Data, _T("%d"), &m_Pos);
  68. if(m_Pos < 1)
  69. {
  70. Data = _T("节点号");
  71. break;
  72. }
  73. }
  74. if(!Provider.getData(CELL_ATTRIBUTE_NEXT, Data))
  75. {
  76. Data = _T("跳转节点");
  77. break;
  78. }
  79. else
  80. {
  81. sscanf_s(Data, _T("%d"), &m_NextPos);
  82. if(m_NextPos < 1)
  83. {
  84. Data = _T("跳转节点");
  85. break;
  86. }
  87. }
  88. Provider.getData(CELL_ATTRIBUTE_NOTE, m_Note);
  89. return true;
  90. } while (false);
  91. ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_ERROR, _T("{Cell}: 节点[%s]解析失败, '%s'错误"), CELL_NAME_HANGUP, Data);
  92. return false;
  93. }