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

OpHangup.cpp 2.1KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  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. /*****************************************************************
  13. **【函数名称】 _end
  14. **【函数功能】 操作完成
  15. **【参数】 IsSucceed 操作是否成功
  16. lpData 随路数据
  17. **【返回值】
  18. ****************************************************************/
  19. void COpHangup::_end( bool IsSucceed )
  20. {
  21. if(IsSucceed)
  22. {
  23. LOGGER(LOG_LEVEL_NORMAL, _T("{OpHangup}: 通道[%lu]挂机成功"), m_pHostChan->no());
  24. }
  25. else
  26. {
  27. LOGGER(LOG_LEVEL_WARNING, _T("{OpHangup}: 通道[%lu]挂机失败"), m_pHostChan->no());
  28. }
  29. m_pParent->onOpResult(m_Instance, this, IsSucceed);
  30. }
  31. /*****************************************************************
  32. **【函数名称】 start
  33. **【函数功能】 执行操作
  34. **【参数】
  35. **【返回值】
  36. *****************************************************************/
  37. bool COpHangup::start( LineOpParam* pParam )
  38. {
  39. // 通知启动日志
  40. LOGGER(LOG_LEVEL_NORMAL, _T("{OpHangup}: 通道[%lu]执行挂机"), m_pHostChan->no());
  41. // 开始应答
  42. if(m_pHostChan->type() == DEV_RES_TYPE_EXT)
  43. return CFsProxy::GetInstance().kill(uniqueId(), m_pHostChan);
  44. else
  45. return CFsProxy::GetInstance().hangup(dynamic_cast<CChanTrunk*>(m_pHostChan));
  46. }
  47. /*****************************************************************
  48. **【函数名称】 onBackgroudJobDone
  49. **【函数功能】 后台命令执行结束事件处理
  50. **【参数】
  51. **【返回值】
  52. *****************************************************************/
  53. void COpHangup::onBackgroudJobDone( PBG_JOB_NOTIFY pNotify )
  54. {
  55. if(strstr(pNotify->JobBody, ESL_JOB_DONE_RES_OK) != NULL)
  56. _end(true);
  57. else
  58. _end(false);
  59. }
  60. /*****************************************************************
  61. **【函数名称】 onChanAppExecuted
  62. **【函数功能】 通道任务执行结束事件处理
  63. **【参数】
  64. **【返回值】
  65. *****************************************************************/
  66. void COpHangup::onChanAppExecuted( CVirtualChan* pHostChan, PAPP_EXEC_NOTIFY pNotify )
  67. {
  68. if (pNotify == NULL)
  69. return;
  70. if(lstrcmp(pNotify->App, ESL_APP_HANGUP) == 0)
  71. _end(true);
  72. }