No Description

OperationReactor.cpp 37KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266
  1. #include "StdAfx.h"
  2. #include "OperationReactor.h"
  3. #include "DevControl.h"
  4. #include "ChanExten.h"
  5. #include "ChanTrunk.h"
  6. #include "FsProxy.h"
  7. #include "OpAnswer.h"
  8. #include "OpHangup.h"
  9. #include "OpConsult.h"
  10. #include "OpInsert.h"
  11. #include "OpInstead.h"
  12. #include "OpIntercept.h"
  13. #include "OpLeaveWord.h"
  14. #include "OpListen.h"
  15. #include "OpMakeCall.h"
  16. #include "OpTransfer.h"
  17. #include "OpTurnExten.h"
  18. #include "OpTrunk2Trunk.h"
  19. #include "OpTurnIvr.h"
  20. #include "OpMeeting.h"
  21. #include "OpHoldon.h"
  22. #include "OpMute.h"
  23. #include "OpPlayAndDtmf.h"
  24. #include "OpRecord.h"
  25. #include "OpPredictionCall.h"
  26. #include "OpSetChannelVar.h"
  27. #include "OpSendDtmf.h"
  28. SINGLETON_IMPLEMENT(COperationReactor)
  29. COperationReactor::COperationReactor(void)
  30. {
  31. }
  32. COperationReactor::~COperationReactor(void)
  33. {
  34. }
  35. /*****************************************************************
  36. **【函数名称】 __addOperation
  37. **【函数功能】 存储一个操作
  38. **【参数】
  39. **【返回值】
  40. *****************************************************************/
  41. void COperationReactor::__addOperation( COperation* pOperation )
  42. {
  43. m_TaskLock.Lock();
  44. m_TableOperation.SetAt(pOperation->uniqueId(), pOperation);
  45. m_TaskLock.Unlock();
  46. }
  47. /*****************************************************************
  48. **【函数名称】 __delOperation
  49. **【函数功能】 删除指定操作
  50. **【参数】
  51. **【返回值】
  52. *****************************************************************/
  53. bool COperationReactor::__delOperation( COperation* pOperation )
  54. {
  55. m_TaskLock.Lock();
  56. bool b= m_TableOperation.RemoveKey(pOperation->uniqueId()) == TRUE;
  57. m_TaskLock.Unlock();
  58. return b;
  59. }
  60. /*****************************************************************
  61. **【函数名称】 __getOperation
  62. **【函数功能】 获取指定操作
  63. **【参数】
  64. **【返回值】
  65. *****************************************************************/
  66. COperation* COperationReactor::__getOperation( LONG OpId )
  67. {
  68. m_TaskLock.Lock();
  69. COperation* pOp = NULL;
  70. m_TableOperation.Lookup(OpId, pOp);
  71. m_TaskLock.Unlock();
  72. return pOp;
  73. }
  74. /*****************************************************************
  75. **【函数名称】 __execOp
  76. **【函数功能】 执行OP
  77. **【参数】 pOp 操作实体
  78. pParam 操作参数
  79. **【返回值】
  80. ****************************************************************/
  81. bool COperationReactor::__execOp( COperation* pOp, LineOpParam* pParam )
  82. {
  83. __addOperation(pOp);
  84. if(pOp->start(pParam))
  85. return true;
  86. if(__delOperation(pOp))
  87. {
  88. pOp->detachHostChan();
  89. FS_LINK_DELETE(pOp);
  90. }
  91. return false;
  92. }
  93. /*****************************************************************
  94. **【函数名称】 __procOpMakeCall
  95. **【函数功能】 坐席外呼处理
  96. **【参数】
  97. **【返回值】
  98. ****************************************************************/
  99. bool COperationReactor::__procOpMakeCall( LONG Instance, ULONG ResID, LineOpParam* pParam )
  100. {
  101. // 通过设备资源查找主控线路
  102. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  103. if(pExten == NULL)
  104. {
  105. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行分机呼叫失败, 未找到分机通道[%lu], DestNum = %s"), ResID, pParam->szParam2);
  106. return false;
  107. }
  108. // 生成外呼操作类
  109. COperation* pOp = new COpMakeCall(this, Instance);
  110. if(!pOp->attachHostChan(pExten))
  111. {
  112. // 如果线路正在执行其它操作
  113. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行分机呼叫失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"), ResID,
  114. (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()), pParam->szParam2);
  115. FS_LINK_DELETE(pOp);
  116. return false;
  117. }
  118. // 启动操作
  119. return __execOp(pOp, pParam);
  120. }
  121. /*****************************************************************
  122. **【函数名称】 __procPredictionCall
  123. **【函数功能】 预测外呼
  124. **【参数】
  125. **【返回值】
  126. ****************************************************************/
  127. bool COperationReactor::__procOpPCall( LONG Instance, ULONG ResID, LineOpParam* pParam )
  128. {
  129. // 生成自动呼叫操作类
  130. COperation* pOp = new COpPredictionCall(this, Instance);
  131. // 启动操作
  132. return __execOp(pOp, pParam);
  133. }
  134. /*****************************************************************
  135. **【函数名称】 __procOpAnswerCall
  136. **【函数功能】 应答呼叫
  137. **【参数】
  138. **【返回值】
  139. ****************************************************************/
  140. bool COperationReactor::__procOpAnswerCall( LONG Instance, ULONG ResID, LineOpParam* pParam )
  141. {
  142. // 查找要应答呼叫的线路
  143. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  144. if(pExten == NULL)
  145. {
  146. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行分机应答失败, 未找到分机通道[%lu]"), ResID);
  147. return false;
  148. }
  149. // 生成应答呼叫操作类
  150. COperation* pOp = new COpAnswer(this, Instance);
  151. if(!pOp->attachHostChan(pExten))
  152. {
  153. // 如果线路正在执行其它操作
  154. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行分机应答失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  155. (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()));
  156. FS_LINK_DELETE(pOp);
  157. return false;
  158. }
  159. // 启动操作
  160. return __execOp(pOp, pParam);
  161. }
  162. /*****************************************************************
  163. **【函数名称】 __procOpHangUp
  164. **【函数功能】 挂机操作处理
  165. **【参数】
  166. **【返回值】
  167. ****************************************************************/
  168. bool COperationReactor::__procOpHangUp( LONG Instance, ULONG ResID, LineOpParam* pParam )
  169. {
  170. // 查找要挂机的线路
  171. CVirtualChan* pChan = CFsProxy::GetInstance().getExten(ResID);
  172. if(pChan == NULL)
  173. pChan = CFsProxy::GetInstance().getTrunk(ResID);
  174. if(pChan == NULL)
  175. {
  176. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行挂机操作失败, 未找到通道[%lu]"), ResID);
  177. return false;
  178. } // end if
  179. // 如果线路正在执行其它操作
  180. if (pChan->currOp() != NULL)
  181. {
  182. if (pChan->currOp()->type() == LINE_OP_HANG_UP)
  183. {
  184. LOGGER(LOG_LEVEL_NORMAL, _T("{OperationReactor}: 当前线路正在执行挂机"));
  185. return false; // 使任务删除
  186. }
  187. LOGGER(LOG_LEVEL_NORMAL, _T("{OperationReactor}: 执行挂机, 当前线路绑定操作, Operation = %d"), pChan->currOp()->type());
  188. return pChan->currOp()->hangup(Instance);
  189. }
  190. if (pChan->state() == CHAN_LOGIC_STATE_FREE || pChan->state() == CHAN_LOGIC_STATE_DISABLED)
  191. {
  192. LOGGER(LOG_LEVEL_NORMAL, _T("{OperationReactor}: 当前线路已挂机"));
  193. return false; // 使任务删除
  194. }
  195. // 执行挂机操作
  196. COperation* pOp = new COpHangup(this, Instance);
  197. if(!pOp->attachHostChan(pChan))
  198. {
  199. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行挂机操作失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  200. (pChan->currOp() == NULL ? LINE_OP_UNKNOWN : pChan->currOp()->type()));
  201. FS_LINK_DELETE(pOp);
  202. return false;
  203. }
  204. // 启动操作
  205. return __execOp(pOp, pParam);
  206. }
  207. /*****************************************************************
  208. **【函数名称】 __procOpTransfer
  209. **【函数功能】 座席呼叫转移
  210. **【参数】
  211. **【返回值】
  212. ****************************************************************/
  213. bool COperationReactor::__procOpTransfer( LONG Instance, ULONG ResID, LineOpParam* pParam )
  214. {
  215. // 通过设备资源查找主控线路
  216. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  217. if(pExten == NULL)
  218. {
  219. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行呼叫转移失败, 未找到分机通道[%lu], DestNum = %s"), ResID, pParam->szParam2);
  220. return false;
  221. }
  222. COperation* pOp = new COpTransfer(this, Instance);
  223. if(!pOp->attachHostChan(pExten))
  224. {
  225. // 如果通道正在执行其它操作
  226. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行呼叫转移失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"), ResID,
  227. (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()), pParam->szParam2);
  228. FS_LINK_DELETE(pOp);
  229. return false;
  230. }
  231. // 启动操作
  232. return __execOp(pOp, pParam);
  233. }
  234. /*****************************************************************
  235. **【函数名称】 __procOpTurnAgent
  236. **【函数功能】 外线转座席
  237. **【参数】
  238. **【返回值】
  239. ****************************************************************/
  240. bool COperationReactor::__procOpTurnAgent( LONG Instance, ULONG ResID, LineOpParam* pParam )
  241. {
  242. // 通过设备资源查找主控线路
  243. CVirtualChan* pChan = CFsProxy::GetInstance().getTrunk(ResID);
  244. if(pChan == NULL)
  245. {
  246. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行中继转座席失败, 未找到中继通道[%lu], ExtenNum = %s"), ResID, pParam->szParam2);
  247. return false;
  248. }
  249. // 生成外线呼叫转移操作类
  250. COperation* pOp = new COpTurnExten(this, Instance);
  251. if(!pOp->attachHostChan(pChan))
  252. {
  253. // 当前线路是否正在进行其它操作
  254. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行中继转座席失败, 无法绑定通道[%lu], ChanCurTask = %d, ExtenNum = %s"), ResID,
  255. (pChan->currOp() == NULL ? LINE_OP_UNKNOWN : pChan->currOp()->type()), pParam->szParam2);
  256. FS_LINK_DELETE(pOp);
  257. return false;
  258. }
  259. // 启动操作
  260. return __execOp(pOp, pParam);
  261. }
  262. /*****************************************************************
  263. **【函数名称】 __procOpTurnOut
  264. **【函数功能】 外线呼叫跳转
  265. **【参数】
  266. **【返回值】
  267. ****************************************************************/
  268. bool COperationReactor::__procOpTurnOut( LONG Instance, ULONG ResID, LineOpParam* pParam )
  269. {
  270. // 通过设备资源查找主控线路
  271. CVirtualChan* pChan = CFsProxy::GetInstance().getTrunk(ResID);
  272. if(pChan == NULL)
  273. {
  274. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行中继呼叫跳转失败, 未找到中继通道[%lu], DestNum = %s"), ResID, pParam->szParam2);
  275. return false;
  276. }
  277. // 生成外线呼叫转移操作类
  278. COperation* pOp = new COpTrunk2Trunk(this, Instance);
  279. if(!pOp->attachHostChan(pChan))
  280. {
  281. // 当前线路是否正在进行其它操作
  282. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行中继呼叫跳转失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"), ResID,
  283. (pChan->currOp() == NULL ? LINE_OP_UNKNOWN : pChan->currOp()->type()), pParam->szParam2);
  284. FS_LINK_DELETE(pOp);
  285. return false;
  286. }
  287. // 启动操作
  288. return __execOp(pOp, pParam);
  289. }
  290. /*****************************************************************
  291. **【函数名称】 __procOpTurnIvr
  292. **【函数功能】 转IVR
  293. **【参数】
  294. **【返回值】
  295. ****************************************************************/
  296. bool COperationReactor::__procOpTurnIvr( LONG Instance, ULONG ResID, LineOpParam* pParam )
  297. {
  298. // 查找要转IVR的线路
  299. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  300. if(pExten == NULL)
  301. {
  302. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行跳转IVR操作失败, 未找到分机通道[%lu]"), ResID);
  303. return false;
  304. } // end if
  305. // 执行转IVR操作
  306. COperation* pOp = new COpTurnIvr(this, Instance);
  307. if(!pOp->attachHostChan(pExten))
  308. {
  309. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行跳转IVR操作失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  310. (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()));
  311. FS_LINK_DELETE(pOp);
  312. return false;
  313. } // end if
  314. return __execOp(pOp, pParam);
  315. }
  316. /*****************************************************************
  317. **【函数名称】 __procReqMeeting
  318. **【函数功能】 单步会议
  319. **【参数】
  320. **【返回值】
  321. ****************************************************************/
  322. bool COperationReactor::__procOpMeeting( LONG Instance, ULONG ResID, LineOpParam* pParam )
  323. {
  324. // 通过设备资源查找主控线路
  325. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  326. if(pExten == NULL)
  327. {
  328. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行会议操作失败, 未找到分机通道[%lu], DestNum = %s"), ResID, pParam->szParam2);
  329. return false;
  330. }
  331. COperation* pOp = new COpMeeting(this, Instance);
  332. if(!pOp->attachHostChan(pExten))
  333. {
  334. // 如果线路正在执行其它操作
  335. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行会议操作失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"), ResID,
  336. (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()), pParam->szParam2);
  337. FS_LINK_DELETE(pOp);
  338. return false;
  339. }
  340. // 启动操作
  341. return __execOp(pOp, pParam);
  342. }
  343. bool COperationReactor::__procOpMeetingTackBack(LONG Instance, ULONG ResID, LineOpParam * pParam)
  344. {
  345. // 通过设备资源查找主控线路
  346. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  347. if (pExten == NULL)
  348. {
  349. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行会议接回操作失败, 未找到分机通道[%lu]"), ResID);
  350. return false;
  351. }
  352. // 如果线路正在执行其它操作
  353. COperation* pCurrOp = pExten->currOp();
  354. if (pCurrOp == NULL || pCurrOp->type() != LINE_OP_CONFERENCE)
  355. {
  356. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行会议接回操作失败, 分机通道[%lu]当前未在会议"), ResID);
  357. return false;
  358. }
  359. // 执行会议接回主叫操作
  360. return pCurrOp->cancel(Instance);
  361. }
  362. /*****************************************************************
  363. **【函数名称】 __procOpHold
  364. **【函数功能】 座席通话保持操作处理
  365. **【参数】 Instance 调用标识
  366. ResID 操作的主控资源ID
  367. LineOpParam* 操作信息
  368. **【返回值】 启动操作是否成功
  369. ****************************************************************/
  370. bool COperationReactor::__procOpHold( LONG Instance, ULONG ResID, LineOpParam* pParam )
  371. {
  372. // 通过设备资源查找主控线路
  373. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  374. if(pExten == NULL)
  375. {
  376. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行保持操作失败, 未找到分机通道[%lu]"), ResID);
  377. return false;
  378. }
  379. // 生成保持操作类
  380. COperation* pOp = new COpHoldon(this, Instance);
  381. if(!pOp->attachHostChan(pExten))
  382. {
  383. // 如果线路正在执行其它操作
  384. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行保持操作失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  385. (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()));
  386. FS_LINK_DELETE(pOp);
  387. return false;
  388. }
  389. // 启动操作
  390. return __execOp(pOp, pParam);
  391. }
  392. /*****************************************************************
  393. **【函数名称】 __procOpTakeBack
  394. **【函数功能】 座席通话接回操作处理
  395. **【参数】 Instance 调用标识
  396. ResID 操作的主控资源ID
  397. LineOpParam* 操作信息
  398. **【返回值】 启动操作是否成功
  399. ****************************************************************/
  400. bool COperationReactor::__procOpTakeBack( LONG Instance, ULONG ResID, LineOpParam* pParam )
  401. {
  402. // 通过设备资源查找主控线路
  403. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  404. if(pExten == NULL)
  405. {
  406. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行保持接回操作失败, 未找到分机通道[%lu]"), ResID);
  407. return false;
  408. }
  409. // 如果线路正在执行其它操作
  410. COperation* pCurrOp = pExten->currOp();
  411. if(pCurrOp == NULL || pCurrOp->type() != LINE_OP_HOLD)
  412. {
  413. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行保持接回操作失败, 分机通道[%lu]当前未保持"), ResID);
  414. return false;
  415. }
  416. // 执行取消静音操作
  417. return pCurrOp->cancel(Instance);
  418. }
  419. /*****************************************************************
  420. **【函数名称】 __procOpMuteOn
  421. **【函数功能】 静音启动
  422. **【参数】
  423. **【返回值】
  424. ****************************************************************/
  425. bool COperationReactor::__procOpMuteOn( LONG Instance, ULONG ResID, LineOpParam* pParam )
  426. {
  427. // 通过设备资源查找主控线路
  428. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  429. if(pExten == NULL)
  430. {
  431. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行静音操作失败, 未找到分机通道[%lu]"), ResID);
  432. return false;
  433. }
  434. // 生成静音操作类
  435. COperation* pOp = new COpMute(this, Instance);
  436. if(!pOp->attachHostChan(pExten))
  437. {
  438. // 如果线路正在执行其它操作
  439. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行静音操作失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  440. (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()));
  441. FS_LINK_DELETE(pOp);
  442. return false;
  443. }
  444. // 启动操作
  445. return __execOp(pOp, pParam);
  446. }
  447. /*****************************************************************
  448. **【函数名称】 __procOpMuteOff
  449. **【函数功能】 静音取消
  450. **【参数】
  451. **【返回值】
  452. ****************************************************************/
  453. bool COperationReactor::__procOpMuteOff( LONG Instance, ULONG ResID, LineOpParam* pParam )
  454. {
  455. // 通过设备资源查找主控线路
  456. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  457. if(pExten == NULL)
  458. {
  459. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行取消静音操作失败, 未找到分机通道[%lu]"), ResID);
  460. return false;
  461. }
  462. // 如果线路正在执行其它操作
  463. COperation* pCurrOp = pExten->currOp();
  464. if(pCurrOp == NULL || pCurrOp->type() != LINE_OP_MUTE_BEGIN)
  465. {
  466. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行取消静音操作失败, 分机通道[%lu]当前未静音"), ResID);
  467. return false;
  468. }
  469. // 执行取消静音操作
  470. return pCurrOp->cancel(Instance);
  471. }
  472. /*****************************************************************
  473. **【函数名称】 __procOpReset
  474. **【函数功能】 重置
  475. **【参数】
  476. **【返回值】
  477. ****************************************************************/
  478. bool COperationReactor::__procOpReset( LONG Instance, ULONG ResID, LineOpParam* pParam )
  479. {
  480. // 通过设备资源查找主控线路
  481. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  482. if(pExten == NULL)
  483. {
  484. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行通道重置操作失败, 未找到分机通道[%lu]"), ResID);
  485. return false;
  486. }
  487. LOGGER(LOG_LEVEL_NORMAL, _T("{OperationReactor}: 执行通道重置操作, ChanNo = %lu"), ResID);
  488. // 清除关联操作
  489. COperation* pOp = pExten->currOp();
  490. if(pOp != NULL)
  491. {
  492. pOp->hangup(FS_LINK_INSTANCE_INVALID);
  493. if(__delOperation(pOp))
  494. {
  495. pOp->detachHostChan();
  496. FS_LINK_DELETE(pOp);
  497. }
  498. }
  499. else
  500. {
  501. if(!pExten->isFree())
  502. CFsProxy::GetInstance().kill(FS_LINK_JOBID_INVALID, pExten);
  503. } // end if
  504. return true;
  505. }
  506. /*****************************************************************
  507. **【函数名称】 __procOpListen
  508. **【函数功能】 监听
  509. **【参数】
  510. **【返回值】
  511. ****************************************************************/
  512. bool COperationReactor::__procOpListen( LONG Instance, ULONG ResID, LineOpParam* pParam )
  513. {
  514. // 通过设备资源查找主控线路
  515. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  516. if(pExten == NULL)
  517. {
  518. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行监听操作失败, 未找到分机通道[%lu], DestNum = %s"),
  519. ResID, pParam->szParam2);
  520. return false;
  521. }
  522. // 生成强插操作类
  523. COperation* pOp = new COpListen(this, Instance);
  524. if(!pOp->attachHostChan(pExten))
  525. {
  526. // 如果线路正在执行其它操作
  527. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行监听操作失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"),
  528. ResID, (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()), pParam->szParam2);
  529. FS_LINK_DELETE(pOp);
  530. return false;
  531. }
  532. // 启动操作
  533. return __execOp(pOp, pParam);
  534. }
  535. /*****************************************************************
  536. **【函数名称】 __procOpInsert
  537. **【函数功能】 强插
  538. **【参数】
  539. **【返回值】
  540. ****************************************************************/
  541. bool COperationReactor::__procOpInsert( LONG Instance, ULONG ResID, LineOpParam* pParam )
  542. {
  543. // 通过设备资源查找主控线路
  544. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  545. if(pExten == NULL)
  546. {
  547. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行强插操作失败, 未找到分机通道[%lu], DestNum = %s"), ResID, pParam->szParam2);
  548. return false;
  549. }
  550. // 生成强插操作类
  551. COperation* pOp = new COpInsert(this, Instance);
  552. if(!pOp->attachHostChan(pExten))
  553. {
  554. // 如果线路正在执行其它操作
  555. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行强插操作失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"),
  556. ResID, (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()), pParam->szParam2);
  557. FS_LINK_DELETE(pOp);
  558. return false;
  559. }
  560. // 启动操作
  561. return __execOp(pOp, pParam);
  562. }
  563. /*****************************************************************
  564. **【函数名称】 __procReqInstead
  565. **【函数功能】 代接
  566. **【参数】
  567. **【返回值】
  568. ****************************************************************/
  569. bool COperationReactor::__procOpInstead( LONG Instance, ULONG ResID, LineOpParam* pParam )
  570. {
  571. // 通过设备资源查找主控线路
  572. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  573. if(pExten == NULL)
  574. {
  575. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行代接操作失败, 未找到分机通道[%lu], DestNum = %s"), ResID, pParam->szParam2);
  576. return false;
  577. }
  578. // 生成代接操作类
  579. COperation* pOp = new COpInstead(this, Instance);
  580. if(!pOp->attachHostChan(pExten))
  581. {
  582. // 如果线路正在执行其它操作
  583. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行代接操作失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"),
  584. ResID, (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()), pParam->szParam2);
  585. FS_LINK_DELETE(pOp);
  586. return false;
  587. }
  588. // 启动操作
  589. return __execOp(pOp, pParam);
  590. }
  591. /*****************************************************************
  592. **【函数名称】 __procReqIntercept
  593. **【函数功能】 强截
  594. **【参数】
  595. **【返回值】
  596. ****************************************************************/
  597. bool COperationReactor::__procOpIntercept( LONG Instance, ULONG ResID, LineOpParam* pParam )
  598. {
  599. // 通过设备资源查找主控线路
  600. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  601. if(pExten == NULL)
  602. {
  603. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行强截操作失败, 未找到分机通道[%lu], DestNum = %s"), ResID, pParam->szParam2);
  604. return false;
  605. }
  606. // 生成强截操作类
  607. COperation* pOp = new COpIntercept(this, Instance);
  608. if(!pOp->attachHostChan(pExten))
  609. {
  610. // 如果线路正在执行其它操作
  611. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行强截操作失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"),
  612. ResID, (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()), pParam->szParam2);
  613. FS_LINK_DELETE(pOp);
  614. return false;
  615. }
  616. // 启动操作
  617. return __execOp(pOp, pParam);
  618. }
  619. /*****************************************************************
  620. **【函数名称】 __procOpInfoTransaction
  621. **【函数功能】 数据交互
  622. **【参数】
  623. **【返回值】 启动操作是否成功
  624. ****************************************************************/
  625. bool COperationReactor::__procOpInfoTransaction( LONG Instance, ULONG ResID, LineOpParam* pParam )
  626. {
  627. // 通过设备资源查找主控线路
  628. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  629. if(pExten == NULL)
  630. {
  631. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行数据交换操作失败, 未找到分机通道[%lu]"), ResID);
  632. return false;
  633. }
  634. // 查找线路关联的操作
  635. COperation* pCurrOp = pExten->currOp();
  636. if(pCurrOp == NULL)
  637. {
  638. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行数据交换操作失败, 分机通道[%lu]未绑定任务"), ResID);
  639. return false;
  640. }
  641. // 执行信息交互
  642. pCurrOp->setOpInstance(Instance);
  643. return true;
  644. }
  645. /*****************************************************************
  646. **【函数名称】 __procOpConsultBegin
  647. **【函数功能】 协商呼叫启动
  648. **【参数】
  649. **【返回值】
  650. ****************************************************************/
  651. bool COperationReactor::__procOpConsultBegin( LONG Instance, ULONG ResID, LineOpParam* pParam )
  652. {
  653. // 通过设备资源查找主控线路
  654. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  655. if(pExten == NULL)
  656. {
  657. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行协商呼叫操作失败, 未找到分机通道[%lu], DestNum = %s"), ResID, pParam->szParam2);
  658. return false;
  659. }
  660. // 生成协商呼叫操作类
  661. COperation* pOp = new COpConsult(this, Instance);
  662. if(!pOp->attachHostChan(pExten))
  663. {
  664. // 如果线路正在执行其它操作
  665. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行协商呼叫操作失败, 无法绑定通道[%lu], ChanCurTask = %d, DestNum = %s"),
  666. ResID, (pExten->currOp() == NULL ? LINE_OP_UNKNOWN : pExten->currOp()->type()), pParam->szParam2);
  667. FS_LINK_DELETE(pOp);
  668. return false;
  669. }
  670. // 启动操作
  671. return __execOp(pOp, pParam);
  672. }
  673. /*****************************************************************
  674. **【函数名称】 __procOpConsultConfirm
  675. **【函数功能】 协商呼叫确认
  676. **【参数】
  677. **【返回值】
  678. ****************************************************************/
  679. bool COperationReactor::__procOpConsultConfirm( LONG Instance, ULONG ResID, LineOpParam* pParam )
  680. {
  681. // 通过设备资源查找主控线路
  682. CChanExten* pExten = CFsProxy::GetInstance().getExten(ResID);
  683. if(pExten == NULL)
  684. {
  685. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行协商确认操作失败, 未找到分机通道[%lu]"), ResID);
  686. return false;
  687. }
  688. // 如果线路未执行协商呼叫操作
  689. COperation* pCurrOp = pExten->currOp();
  690. if(pCurrOp == NULL || pCurrOp->type() != LINE_OP_CONSULT_CALL_BEGIN)
  691. {
  692. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行协商确认操作失败, 分机通道[%lu]未在协商呼叫环境中"), ResID);
  693. return false;
  694. }
  695. if (pParam->nParam1==3)
  696. {
  697. // 执行操作确认
  698. if(!pCurrOp->cancel(Instance))
  699. {
  700. if(__delOperation(pCurrOp))
  701. {
  702. pCurrOp->detachHostChan();
  703. FS_LINK_DELETE(pCurrOp);
  704. }
  705. return false;
  706. } // end if
  707. }
  708. else
  709. {
  710. // 执行操作确认
  711. if(!pCurrOp->next(Instance))
  712. {
  713. if(__delOperation(pCurrOp))
  714. {
  715. pCurrOp->detachHostChan();
  716. FS_LINK_DELETE(pCurrOp);
  717. }
  718. return false;
  719. } // end if
  720. }
  721. return true;
  722. }
  723. /*****************************************************************
  724. **【函数名称】 __procOpPlayAndDtmf
  725. **【函数功能】 线路放音收号
  726. **【参数】
  727. **【返回值】
  728. ****************************************************************/
  729. bool COperationReactor::__procOpPlayAndDtmf( LONG Instance, ULONG ResID, LineOpParam* pParam )
  730. {
  731. // 通过设备资源查找主控线路
  732. CVirtualChan* pChan = CFsProxy::GetInstance().getTrunk(ResID);
  733. if(pChan == NULL)
  734. {
  735. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行放音收号操作失败, 未找到通道[%lu], mode = %d, AudioFile = %s"),
  736. ResID, pParam->nParam1, pParam->szParam3);
  737. return false;
  738. }
  739. COperation* pCurrOp = pChan->currOp();
  740. if(pParam->nParam1 == PVM_STOP_PLAY) // 停止放音
  741. {
  742. // 如果线路未在执行放音操作
  743. if(pCurrOp == NULL || pCurrOp->type() != LINE_OP_PLAY_VOICE)
  744. {
  745. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行停止放音操作失败, 通道[%lu]未执行放音操作"), ResID);
  746. return false;
  747. }
  748. else
  749. return pCurrOp->cancel(Instance); // 执行取消操作
  750. }
  751. else // 启动放音
  752. {
  753. // 生成放音操作类
  754. COperation* pOp = new COpPlayAndDtmf(this, Instance);
  755. if(!pOp->attachHostChan(pChan))
  756. {
  757. // 如果线路正在执行其它操作
  758. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行放音收号操作失败, 无法绑定通道[%lu], ChanCurTask = %d, AudioFile = %s"),
  759. ResID, (pChan->currOp() == NULL ? LINE_OP_UNKNOWN : pChan->currOp()->type()), pParam->szParam3);
  760. FS_LINK_DELETE(pOp);
  761. return false;
  762. }
  763. // 启动操作
  764. return __execOp(pOp, pParam);
  765. }
  766. }
  767. /*****************************************************************
  768. **【函数名称】 __procOpRecord
  769. **【函数功能】 线路录音
  770. **【参数】
  771. **【返回值】
  772. ****************************************************************/
  773. bool COperationReactor::__procOpRecord( LONG Instance, ULONG ResID, LineOpParam* pParam )
  774. {
  775. // 查找要录音的线路
  776. CVirtualChan* pChan = CFsProxy::GetInstance().getTrunk(ResID);
  777. if(pChan == NULL)
  778. pChan = CFsProxy::GetInstance().getExten(ResID);
  779. if(pChan == NULL)
  780. {
  781. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行录音操作失败, 未找到通道[%lu]"), ResID);
  782. return false;
  783. } // end if
  784. // 生成录音操作类
  785. COperation* pOp = new COpRecord(this, Instance);
  786. if(!pOp->attachHostChan(pChan))
  787. {
  788. // 如果线路正在执行其它操作
  789. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行录音操作失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  790. (pChan->currOp() == NULL ? LINE_OP_UNKNOWN : pChan->currOp()->type()));
  791. FS_LINK_DELETE(pOp);
  792. return false;
  793. }
  794. // 启动操作
  795. return __execOp(pOp, pParam);
  796. }
  797. /*****************************************************************
  798. **【函数名称】 __procOpLeaveWord
  799. **【函数功能】 留言录音
  800. **【参数】
  801. **【返回值】
  802. ****************************************************************/
  803. bool COperationReactor::__procOpLeaveWord( LONG Instance, ULONG ResID, LineOpParam* pParam )
  804. {
  805. // 查找要留言的线路
  806. CVirtualChan* pChan = CFsProxy::GetInstance().getTrunk(ResID); // 外线
  807. if(pChan == NULL)
  808. {
  809. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行留言操作失败, 未找到通道[%lu]"), ResID);
  810. return false;
  811. } // end if
  812. // 生成留言操作类
  813. COperation* pOp = new COpLeaveWord(this, Instance);
  814. if(!pOp->attachHostChan(pChan))
  815. {
  816. // 如果线路正在执行其它操作
  817. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行留言操作失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  818. (pChan->currOp() == NULL ? LINE_OP_UNKNOWN : pChan->currOp()->type()));
  819. FS_LINK_DELETE(pOp);
  820. return false;
  821. }
  822. // 启动操作
  823. return __execOp(pOp, pParam);
  824. }
  825. /*****************************************************************
  826. **【函数名称】 __procOpFax
  827. **【函数功能】 传真
  828. **【参数】
  829. **【返回值】
  830. ****************************************************************/
  831. bool COperationReactor::__procOpFax( LONG Instance, ULONG ResID, LineOpParam* pParam )
  832. {
  833. return false;
  834. }
  835. /*****************************************************************
  836. **【函数名称】 __procOpSetChannelVar
  837. **【函数功能】 设置通道变量
  838. **【参数】
  839. **【返回值】
  840. ****************************************************************/
  841. bool COperationReactor::__procOpSetChannelVar(LONG Instance, ULONG ResID, LineOpParam * pParam)
  842. {
  843. // 查找要设置通道变量的线路
  844. CVirtualChan* pChan = CFsProxy::GetInstance().getTrunk(ResID);
  845. if (pChan == NULL)
  846. pChan = CFsProxy::GetInstance().getExten(ResID);
  847. if (pChan == NULL)
  848. {
  849. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行设置通道变量操作失败, 未找到通道[%lu]"), ResID);
  850. return false;
  851. } // end if
  852. // 生成设置通道变量操作类
  853. COperation* pOp = new COpSetChannelVar(this, Instance);
  854. if (!pOp->attachHostChan(pChan))
  855. {
  856. // 如果线路正在执行其它操作
  857. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行设置通道变量操作失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  858. (pChan->currOp() == NULL ? LINE_OP_UNKNOWN : pChan->currOp()->type()));
  859. FS_LINK_DELETE(pOp);
  860. return false;
  861. }
  862. // 启动操作
  863. return __execOp(pOp, pParam);
  864. }
  865. bool COperationReactor::__procOpSendDtmf(LONG Instance, ULONG ResID, LineOpParam * pParam)
  866. {
  867. // 查找要设置通道变量的线路
  868. CVirtualChan* pChan = CFsProxy::GetInstance().getTrunk(ResID);
  869. if (pChan == NULL)
  870. pChan = CFsProxy::GetInstance().getExten(ResID);
  871. if (pChan == NULL)
  872. {
  873. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行发送按键操作失败, 未找到通道[%lu]"), ResID);
  874. return false;
  875. } // end if
  876. // 生成设置通道变量操作类
  877. COperation* pOp = new COpSendDtmf(this, Instance);
  878. if (!pOp->attachHostChan(pChan))
  879. {
  880. // 如果线路正在执行其它操作
  881. LOGGER(LOG_LEVEL_WARNING, _T("{OperationReactor}: 执行发送按键操作失败, 无法绑定通道[%lu], ChanCurTask = %d"), ResID,
  882. (pChan->currOp() == NULL ? LINE_OP_UNKNOWN : pChan->currOp()->type()));
  883. FS_LINK_DELETE(pOp);
  884. return false;
  885. }
  886. // 启动操作
  887. return __execOp(pOp, pParam);
  888. }
  889. /*****************************************************************
  890. **【函数名称】 procOperation
  891. **【函数功能】 线路操作处理
  892. **【参数】
  893. **【返回值】
  894. ****************************************************************/
  895. bool COperationReactor::procOperation( LONG Instance, UINT OpType, ULONG ResID, LineOpParam* pParam )
  896. {
  897. LOGGER(LOG_LEVEL_NORMAL, _T("{OperationReactor}: 通道操作, OpType = %lu,通道[%lu]"), OpType, ResID);
  898. bool Res = false;
  899. // 根据操作类型进行分类处理
  900. switch(OpType)
  901. {
  902. case LINE_OP_MAKE_CALL: // 座席外呼
  903. Res = __procOpMakeCall(Instance, ResID, pParam);
  904. break;
  905. case LINE_OP_ANSWER_CALL: // 应答呼叫
  906. Res = __procOpAnswerCall(Instance, ResID, pParam);
  907. break;
  908. case LINE_OP_PREDICTION_CALL: // 预测外呼
  909. Res = __procOpPCall(Instance, ResID, pParam);
  910. break;
  911. case LINE_OP_HANG_UP: // 挂机
  912. Res = __procOpHangUp(Instance, ResID, pParam);
  913. break;
  914. case LINE_OP_TRANSFER: // 呼叫转移
  915. Res = __procOpTransfer(Instance, ResID, pParam);
  916. break;
  917. case LINE_OP_TURNAGENT: // 转坐席
  918. Res = __procOpTurnAgent(Instance, ResID, pParam);
  919. break;
  920. case LINE_OP_TURNOUT: // 转外线
  921. Res = __procOpTurnOut(Instance, ResID, pParam);
  922. break;
  923. case LINE_OP_TURNIVR: // 转IVR
  924. Res = __procOpTurnIvr(Instance, ResID, pParam);
  925. break;
  926. case LINE_OP_CONFERENCE: // 单步会议
  927. Res = __procOpMeeting(Instance, ResID, pParam);
  928. break;
  929. case LINE_OP_CONFERENCE_TAKEBACK: // 会议接回主叫
  930. Res = __procOpMeetingTackBack(Instance, ResID, pParam);
  931. break;
  932. case LINE_OP_LISTEN: // 监听
  933. Res = __procOpListen(Instance, ResID, pParam);
  934. break;
  935. case LINE_OP_INSERT: // 强插
  936. Res = __procOpInsert(Instance, ResID, pParam);
  937. break;
  938. case LINE_OP_RESET: // 重置
  939. Res = __procOpReset(Instance, ResID, pParam);
  940. break;
  941. case LINE_OP_INSTEAD: // 代接
  942. Res = __procOpInstead(Instance, ResID, pParam);
  943. break;
  944. case LINE_OP_GRAB: // 强截
  945. Res = __procOpIntercept(Instance, ResID, pParam);
  946. break;
  947. case LINE_OP_TRANSFER_INFO: // 信息交互
  948. Res = __procOpInfoTransaction(Instance, ResID, pParam);
  949. break;
  950. case LINE_OP_PLAY_VOICE: // 放音收号
  951. Res = __procOpPlayAndDtmf(Instance, ResID, pParam);
  952. break;
  953. case LINE_OP_FAX: // 传真
  954. Res = __procOpFax(Instance, ResID, pParam);
  955. break;
  956. case LINE_OP_RECORD: // 录音
  957. Res = __procOpRecord(Instance, ResID, pParam);
  958. break;
  959. case LINE_OP_LEAVEWORD: // 留言
  960. Res = __procOpLeaveWord(Instance, ResID, pParam);
  961. break;
  962. case LINE_OP_MUTE_BEGIN: // 静音开始
  963. Res = __procOpMuteOn(Instance, ResID, pParam);
  964. break;
  965. case LINE_OP_MUTE_END: // 静音结束
  966. Res = __procOpMuteOff(Instance, ResID, pParam);
  967. break;
  968. case LINE_OP_HOLD: // 保持
  969. Res = __procOpHold(Instance, ResID, pParam);
  970. break;
  971. case LINE_OP_TAKEBACK: // 接回
  972. Res = __procOpTakeBack(Instance, ResID, pParam);
  973. break;
  974. case LINE_OP_CONSULT_CALL_BEGIN: // 协商呼叫启动
  975. Res = __procOpConsultBegin(Instance, ResID, pParam);
  976. break;
  977. case LINE_OP_CONSULT_CALL_CONFIRM: // 协商呼叫确认
  978. Res = __procOpConsultConfirm(Instance, ResID, pParam);
  979. break;
  980. case LINE_OP_IVRFAX_TRANSFER:
  981. {
  982. CDevControl::GetInstance().onEventOpResult(Instance, true, NULL);
  983. Res = true;
  984. }
  985. break;
  986. case LINE_OP_SET_CHANNEL_VARIABLE: // 设置通道变量
  987. Res = __procOpSetChannelVar(Instance, ResID, pParam);
  988. break;
  989. case LINE_OP_SEND_DTMF: // 发送按键
  990. Res = __procOpSendDtmf(Instance, ResID, pParam);
  991. break;
  992. default:
  993. ASSERT(FALSE);
  994. } // end switch
  995. return Res;
  996. }
  997. /*****************************************************************
  998. **【函数名称】 onOpProcess
  999. **【函数功能】 操作进展返回
  1000. **【参数】 Instance 调用标识
  1001. HostLine 主控线路ID
  1002. AssoLine 关联线路ID
  1003. AssoLineType 关联线路类型
  1004. CallerNum 主叫号码
  1005. CalleeNum 被叫号码
  1006. **【返回值】
  1007. ****************************************************************/
  1008. void COperationReactor::onOpProcess( LONG Instance, UINT HostChanNo, UINT AssoChanNo, DEV_RES_TYPE AssoChanType, LPCTSTR CallerNum, LPCTSTR CalleeNum )
  1009. {
  1010. CDevControl::GetInstance().onEventOpProcess(Instance, HostChanNo, AssoChanNo, AssoChanType, CallerNum, CalleeNum);
  1011. }
  1012. /*****************************************************************
  1013. **【函数名称】 onOpResult
  1014. **【函数功能】 操作结果返回
  1015. **【参数】 Instance 调用标识
  1016. IsSucceed 操作结果
  1017. pInfo 附加信息
  1018. **【返回值】
  1019. ****************************************************************/
  1020. void COperationReactor::onOpResult( LONG Instance, bool IsSucceed )
  1021. {
  1022. CDevControl::GetInstance().onEventOpResult(Instance, IsSucceed, NULL);
  1023. }
  1024. /*****************************************************************
  1025. **【函数名称】 onOpResult
  1026. **【函数功能】 操作结果返回
  1027. **【参数】 Instance 调用标识
  1028. pOp 返回操作结果的操作实体指针
  1029. IsSucceed 操作结果
  1030. pInfo 附加信息
  1031. **【返回值】
  1032. ****************************************************************/
  1033. void COperationReactor::onOpResult( LONG Instance, COperation* pOp, bool IsSucceed, CString Data /*= _T("")*/ )
  1034. {
  1035. ASSERT(pOp != NULL);
  1036. if (pOp == NULL)return;
  1037. if (__delOperation(pOp)) // 非取消操作的返回结果
  1038. {
  1039. // 关闭线路关联
  1040. pOp->detachHostChan();
  1041. // 释放操作
  1042. FS_LINK_DELETE(pOp);
  1043. } // end if
  1044. // 返回执行结果
  1045. CDevControl::GetInstance().onEventOpResult(Instance, IsSucceed, Data);
  1046. }
  1047. //2019.3.7
  1048. void COperationReactor::releaseOpResult( COperation* pOp)
  1049. {
  1050. if (pOp == NULL)return;
  1051. pOp->clean();
  1052. if (__delOperation(pOp)) // 非取消操作的返回结果
  1053. {
  1054. // 关闭线路关联
  1055. pOp->detachHostChan();
  1056. // 释放操作
  1057. FS_LINK_DELETE(pOp);
  1058. } // end if
  1059. }
  1060. /*****************************************************************
  1061. **【函数名称】 onOpFromDev
  1062. **【函数功能】 设备主动操作事件
  1063. **【参数】 pChan 主动操作的通道
  1064. OpType 操作类型
  1065. CallerNum 主叫号码
  1066. CalleeNum 被叫号码
  1067. **【返回值】
  1068. ****************************************************************/
  1069. void COperationReactor::onOpFromDev( CVirtualChan* pChan, DEV_OP OpType, LPCTSTR CallerNum, LPCTSTR CalleeNum )
  1070. {
  1071. CDevControl::GetInstance().onEventDevOperation(pChan->no(), OpType, CallerNum, CalleeNum);
  1072. }
  1073. /*****************************************************************
  1074. **【函数名称】 onExtenCallFromDev
  1075. **【函数功能】 分机直接外呼
  1076. **【参数】
  1077. **【返回值】
  1078. *****************************************************************/
  1079. bool COperationReactor::onExtenCallFromDev( CVirtualChan* pHostChan, PCHAN_EVENT_NOTIFY pNotify )
  1080. {
  1081. COpMakeCall* pMakeCall = new COpMakeCall(this, FS_LINK_INSTANCE_INVALID);
  1082. pMakeCall->attachHostChan(pHostChan);
  1083. if(pMakeCall->start(pNotify))
  1084. {
  1085. __addOperation(pMakeCall);
  1086. return true;
  1087. }
  1088. else
  1089. {
  1090. pMakeCall->detachHostChan();
  1091. FS_LINK_DELETE(pMakeCall);
  1092. return false;
  1093. }
  1094. }
  1095. /*****************************************************************
  1096. **【函数名称】 onEslEvtBgJobDone
  1097. **【函数功能】 后台任务执行结束事件处理
  1098. **【参数】
  1099. **【返回值】
  1100. *****************************************************************/
  1101. void COperationReactor::onEslEvtBgJobDone( PBG_JOB_NOTIFY pNotify )
  1102. {
  1103. ASSERT(pNotify != NULL);
  1104. COperation* pOperation = __getOperation(pNotify->JobInstance);
  1105. if(pOperation != NULL)
  1106. pOperation->onBackgroudJobDone(pNotify);
  1107. }
  1108. /*****************************************************************
  1109. **【函数名称】 onEslEvtChanState
  1110. **【函数功能】 通道状态事件处理
  1111. **【参数】
  1112. **【返回值】
  1113. *****************************************************************/
  1114. void COperationReactor::onEslEvtChanState( LONG OpInstance, CVirtualChan* pChan )
  1115. {
  1116. COperation* pOperation = __getOperation(OpInstance);
  1117. if(pOperation != NULL)
  1118. pOperation->onAssoChanStateUpdated(pChan);
  1119. }