中航光电的中间件仓库

OpHangup.cpp 2.5KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. #include "StdAfx.h"
  2. #include "OpHangup.h"
  3. #include "ChanTrunk.h"
  4. #include "FsProxy.h"
  5. #include "OperationReactor.h"
  6. COpHangup::COpHangup(COperationReactor* pParent, LONG Instance) : COperation(pParent, Instance)
  7. {
  8. }
  9. COpHangup::~COpHangup(void)
  10. {
  11. }
  12. void COpHangup::clean()
  13. {
  14. LOGGER(LOG_LEVEL_NORMAL, _T("{OpHangup}: 通道[%lu],操作清除"), m_pHostChan->no());
  15. _end(false);
  16. }
  17. /*****************************************************************
  18. **【函数名称】 _end
  19. **【函数功能】 操作完成
  20. **【参数】 IsSucceed 操作是否成功
  21. lpData 随路数据
  22. **【返回值】
  23. ****************************************************************/
  24. void COpHangup::_end( bool IsSucceed )
  25. {
  26. if(IsSucceed)
  27. {
  28. LOGGER(LOG_LEVEL_NORMAL, _T("{OpHangup}: 通道[%lu]挂机成功"), m_pHostChan->no());
  29. }
  30. else
  31. {
  32. LOGGER(LOG_LEVEL_WARNING, _T("{OpHangup}: 通道[%lu]挂机失败"), m_pHostChan->no());
  33. }
  34. m_pParent->onOpResult(m_Instance, this, IsSucceed);
  35. }
  36. /*****************************************************************
  37. **【函数名称】 start
  38. **【函数功能】 执行操作
  39. **【参数】
  40. **【返回值】
  41. *****************************************************************/
  42. bool COpHangup::start( LineOpParam* pParam )
  43. {
  44. // 通知启动日志
  45. LOGGER(LOG_LEVEL_NORMAL, _T("{OpHangup}: 通道[%lu]执行挂机"), m_pHostChan->no());
  46. // 开始应答
  47. if(m_pHostChan->type() == DEV_RES_TYPE_EXT)
  48. return CFsProxy::GetInstance().kill(uniqueId(), m_pHostChan);
  49. else
  50. return CFsProxy::GetInstance().hangup(dynamic_cast<CChanTrunk*>(m_pHostChan));
  51. }
  52. /*****************************************************************
  53. **【函数名称】 onBackgroudJobDone
  54. **【函数功能】 后台命令执行结束事件处理
  55. **【参数】
  56. **【返回值】
  57. *****************************************************************/
  58. void COpHangup::onBackgroudJobDone( PBG_JOB_NOTIFY pNotify )
  59. {
  60. if(strstr(pNotify->JobBody, ESL_JOB_DONE_RES_OK) != NULL)
  61. _end(true);
  62. else
  63. _end(false);
  64. }
  65. /*****************************************************************
  66. **【函数名称】 onChanAppExecuted
  67. **【函数功能】 通道任务执行结束事件处理
  68. **【参数】
  69. **【返回值】
  70. *****************************************************************/
  71. void COpHangup::onChanAppExecuted( CVirtualChan* pHostChan, PAPP_EXEC_NOTIFY pNotify )
  72. {
  73. if (pNotify == NULL)
  74. return;
  75. if(lstrcmp(pNotify->App, ESL_APP_HANGUP) == 0)
  76. _end(true);
  77. }
  78. void COpHangup::onHostChanStateUpdated(CVirtualChan* pHostChan)
  79. {
  80. LOGGER(LOG_LEVEL_NORMAL, _T("{onHostChanStateUpdated}: 线路状态更新, 通道[%lu]挂机"), pHostChan->no());
  81. ASSERT(pHostChan == m_pHostChan);
  82. if (pHostChan->state() == CHAN_LOGIC_STATE_FREE)
  83. _end(true);
  84. }