Nessuna descrizione

OpSetChannelVar.cpp 1.7KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. #include "stdafx.h"
  2. #include "OpSetChannelVar.h"
  3. #include "VirtualChan.h"
  4. #include "FsProxy.h"
  5. #include "OperationReactor.h"
  6. COpSetChannelVar::COpSetChannelVar(COperationReactor * pParent, LONG Instance) : COperation(pParent, Instance)
  7. {
  8. }
  9. COpSetChannelVar::~COpSetChannelVar(void)
  10. {
  11. }
  12. bool COpSetChannelVar::attachHostChan(CVirtualChan * pChan)
  13. {
  14. m_pHostChan = pChan;
  15. return true;
  16. }
  17. void COpSetChannelVar::detachHostChan(void)
  18. {
  19. m_pHostChan = NULL;
  20. }
  21. bool COpSetChannelVar::start(LineOpParam * pParam)
  22. {
  23. LOGGER(LOG_LEVEL_NORMAL, _T("{OpRecord}: 通道[%lu]执行设置通道变量,State:%d;[%s]"), m_pHostChan->no(), m_pHostChan->state(), pParam->szParam4);
  24. /*if (m_pHostChan->type() == DEV_RES_TYPE_EXT)
  25. return false;*/
  26. m_MeetingId.Format("%s", pParam->szParam3);
  27. LOGGER(LOG_LEVEL_NORMAL, _T("{OpRecord}: 通道[%lu]执行设置通道变量,ChanID[%s]SessionID[%s]"), m_pHostChan->no(), m_pHostChan->chanId(), m_pHostChan->sessionId());
  28. return CFsProxy::GetInstance().setChannelVariable(uniqueId(), m_pHostChan->chanId(),"asr_info",pParam->szParam4);
  29. }
  30. void COpSetChannelVar::onBackgroudJobDone(PBG_JOB_NOTIFY pNotify)
  31. {
  32. if (strstr(pNotify->JobBody, ESL_JOB_DONE_RES_OK) == NULL)
  33. _end(false);
  34. else
  35. _end(true);
  36. }
  37. void COpSetChannelVar::_end(bool IsSucceed)
  38. {
  39. if (IsSucceed)
  40. {
  41. LOGGER(LOG_LEVEL_NORMAL, _T("{OpRecord}: 通道[%lu]设置通道变量成功"), m_pHostChan->no());
  42. }
  43. else
  44. {
  45. LOGGER(LOG_LEVEL_WARNING, _T("{OpRecord}: 通道[%lu]设置通道变量失败"), m_pHostChan->no());
  46. }
  47. /*if (m_pHostChan)
  48. CFsProxy::GetInstance().ExecteApp("lua", "asr.lua "+ m_MeetingId, m_pHostChan->chanId());*/
  49. // 返回执行结果
  50. if (m_InstanceCancel != FS_LINK_INSTANCE_INVALID)
  51. m_pParent->onOpResult(m_InstanceCancel, !IsSucceed);
  52. m_pParent->onOpResult(m_Instance, this, IsSucceed);
  53. }