#include "StdAfx.h" #include "CellHangUp.h" #include "NetworkIvr.h" #include "IvrFlow.h" #include "FlowDataProvider.h" IMPLEMENT_CELL_AUTOCREATE(CCellHangUp, CELL_NAME_HANGUP) CCellHangUp::CCellHangUp(void) : m_NextPos(0) { } CCellHangUp::CCellHangUp( CCellHangUp & cellHangUp ) : CCellBase(cellHangUp), m_NextPos(cellHangUp.m_NextPos) { } CCellHangUp::~CCellHangUp(void) { } /***************************************************************** **【函数名称】 operate **【函数功能】 节点执行函数 **【参数】 **【返回值】 下一个节点编号 ****************************************************************/ int CCellHangUp::operate( void ) { if(m_pIvrFlow == NULL) return CELL_OP_ERROR; CString Info; _getCellInfo(Info); ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_NORMAL, _T("{Cell}: 开始执行[%s]"), Info); CPduEntity CmdHangUp(PDU_CMD_IVR_HANGUP); CmdHangUp.SetDataInt(1, m_pIvrFlow->id()); if(!CNetworkIvr::GetInstance().send(CmdHangUp)) { ILogger::getInstance().log(LOG_CLASS_SOCKET, LOG_LEVEL_WARNING, _T("{Cell}: 执行[%s]出错, 向CTI发送消息失败"), Info); return CELL_OP_SEND_ERROR; } return m_NextPos; } /***************************************************************** **【函数名称】 copy **【函数功能】 拷贝自身 **【参数】 **【返回值】 拷贝副本 ****************************************************************/ CCellBase * CCellHangUp::copy( void ) { CCellBase * pCellBase = new CCellHangUp(*this); return pCellBase; } /***************************************************************** **【函数名称】 fillData **【函数功能】 节点解析,填充数据 **【参数】 Provider:数据提供器 **【返回值】 成功true,失败false ****************************************************************/ bool CCellHangUp::fillData( IFlowDataProvider& Provider ) { CString Data; do { if(!Provider.getData(CELL_ATTRIBUTE_POS, Data)) { Data = _T("节点号"); break; } else { sscanf_s(Data, _T("%d"), &m_Pos); if(m_Pos < 1) { Data = _T("节点号"); break; } } if(!Provider.getData(CELL_ATTRIBUTE_NEXT, Data)) { Data = _T("跳转节点"); break; } else { sscanf_s(Data, _T("%d"), &m_NextPos); if(m_NextPos < 1) { Data = _T("跳转节点"); break; } } Provider.getData(CELL_ATTRIBUTE_NOTE, m_Note); return true; } while (false); ILogger::getInstance().log(LOG_CLASS_BUSI, LOG_LEVEL_ERROR, _T("{Cell}: 节点[%s]解析失败, '%s'错误"), CELL_NAME_HANGUP, Data); return false; }