| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129 |
- #include "StdAfx.h"
- #include "LeaveWordReq.h"
- #include "ProxyExten.h"
- #include "MC.h"
- #include "SessionShell.h"
- #include "ProxyShell.h"
- CLeaveWordReq::CLeaveWordReq(CProxyShell* pParent, CPduEntity& ReqPdu) : CReqBase(pParent, ReqPdu)
- {
- }
- CLeaveWordReq::~CLeaveWordReq(void)
- {
- }
- /*****************************************************************
- **【函数名称】 request
- **【函数功能】 发出请求(命令方式)
- **【参数】
- **【返回值】
- ****************************************************************/
- bool CLeaveWordReq::request( void )
- {
- // 线路是否在通话中
- if(m_pHostLine->state() != VIRTUAL_LINE_STATE_TALKING)
- return false;
- UINT LimitTime = m_ReqPdu.GetDataUInt(3);
- CString FinishKey = m_ReqPdu.GetDataString(4);
- m_FileName = m_ReqPdu.GetDataString(5);
- // 录音启动日志
- LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{LineReq}: 中继线路[%lu]留言, FileName = %s, LimitTime = %lu(s), FinishKey = '%s'"),
- m_pHostLine->lineId(), m_FileName, LimitTime, FinishKey);
- // 初始化留言内容
- RecordContent content;
- memset(&content, 0, sizeof(RecordContent));
- lstrcpy(content.szFileName, m_FileName);
- content.nPeriod = LimitTime;
- content.cEnd = FinishKey[0];
- // 启动留言
- return CSessionShell::GetInstance().procReqLeaveWord(m_pHostLine->activeCallId(), m_pHostLine->devId(), &content);
- }
- /*****************************************************************
- **【函数名称】 cancel
- **【函数功能】 请求取消
- **【参数】
- **【返回值】
- ****************************************************************/
- bool CLeaveWordReq::cancel( long InstanceCancel )
- {
- // 留言停止日志
- LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{LineReq}: 中继线路[%lu]留言取消, FileName = %s"),
- m_pHostLine->lineId(), m_FileName);
- m_InstanceCancel = InstanceCancel;
- CMC::GetInstance().stopRecord(m_pHostLine->devId());
- end(false, NULL);
- return true;
- }
- /*****************************************************************
- **【函数名称】 end
- **【函数功能】 操作完成
- **【参数】 IsSucceed 操作是否成功
- lpData 随路数据
- **【返回值】
- ****************************************************************/
- void CLeaveWordReq::end( bool IsSucceed, LPCTSTR lpData )
- {
- if(IsSucceed)
- {
- LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{LineReq}: 中继线路[%lu]留言成功, FileName = %s"),
- m_pHostLine->lineId(), m_FileName);
- }
- else
- {
- LOGGER(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{LineReq}: 中继线路[%lu]留言结束, FileName = %s"),
- m_pHostLine->lineId(), m_FileName);
- } // end if
- // 返回执行结果
- if(m_InstanceCancel != 0)
- {
- m_pParent->notifyReqResult(m_ReqPdu, m_InstanceCancel, !IsSucceed, lpData);
- } // end if
- m_pParent->onLineReqEnd(this, IsSucceed, lpData);
- }
- /*****************************************************************
- **【函数名称】 onDevChEvent
- **【函数功能】 线路向上层发送的设备主动事件
- **【参数】 pEventLine 触发事件的线路
- EvtType 事件类型
- lpContent 事件内容
- **【返回值】
- *****************************************************************/
- void CLeaveWordReq::onDevChEvent( CVirtualProxy* pEventLine, DEV_CH_EVT_TYPE EvtType, LPCTSTR lpContent )
- {
- if(EvtType == DEV_CH_EVT_REC_END)
- end(true, lpContent);
- }
- /*****************************************************************
- **【函数名称】 onLineStateChanged
- **【函数功能】 线路状态变化事件响应接口
- **【参数】 pEventLine 状态变化的线路实体指针
- LineState 线路当前状态
- Call 主呼叫ID
- SubCall 子呼叫ID
- lpCallerNum 主叫号码
- lpCalleeNum 被叫号码
- **【返回值】
- ****************************************************************/
- void CLeaveWordReq::onLineStateChanged( CVirtualProxy* pEventLine, VIRTUAL_LINE_STATE LineState, long Call, long SubCall, LPCTSTR lpCallerNum, LPCTSTR lpCalleeNum )
- {
- // 正在留言时外线挂机
- if(LineState == VIRTUAL_LINE_STATE_FREE)
- end(true, NULL);
- }
|