Built motion from commit (unavailable).|2.0.83
[motion2.git] / server / services / ami / acw / index.js
1 // *************************************************************************
2 // *                                                                       *
3 // * xCALLY Motion -  The Omnichannel Contact Center                       *
4 // * Copyright (c) Xenialab s.r.l. All Rights Reserved                     *
5 // *                                                                       *
6 // *************************************************************************
7 // *                                                                       *
8 // * Email: info@xcally.com                                                *
9 // * Website: https://www.xcally.com                                       *
10 // *                                                                       *
11 // *************************************************************************
12 // *                                                                       *
13 // * The SOFTWARE PRODUCT is protected by copyright laws and international *
14 // * copyright treaties, as well as other intellectual property laws and   *
15 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                         *
16 // *                                                                       *
17 // *************************************************************************
18 var _0x425d=['[ACW][syncHangupRequest]\x20%s','[%s][HANGUPATTENDEDTRANSFER:UNIQUEID]','[%s][HANGUPATTENDEDTRANSFER:LINKEDID]','isNil','transfereeuniqueid','secondtransfereruniqueid','transfertargetuniqueid','origtransfereruniqueid','stringify','transfereruniqueid','transfererlinkedid','[%s][BLINDTRANSFER:LINKEDID]','autopause','all','[%s][AUTOPAUSE][AGENT:%s][QUEUE:%]','savePause','[ACW][syncAgentRingNoAnswer]\x20%s','exports','util','moment','../ami','../../../config/logger','acw','../rpc/user','../rpc/voiceAgentReport','voiceQueues','agents','timers','channels','syncAgentConnect','bind','hanguprequest','syncHangupRequest','hangup','syncHangup','agentringnoanswer','syncAgentRingNoAnswer','attendedtransfer','syncAttendedTransfer','blindtransfer','syncBlindTransfer','custom:agentConnectPreview','syncAgentConnectPreview','milliseconds','diff','seconds','prototype','startAcw','interface','queue','Action','QueuePause','ACW','then','info','[%s][START][AGENT:%s][QUEUE:%s]','[%s][TIMER:%s][AGENT:%s][QUEUE:%s]','acwTimeout','timer','stopAcw','lastPauseAt','uniqueid','updateAcw','update','catch','error','[%s][UPDATE][ERRORS:%s]','[%s][INPAUSE][AGENT:%s][QUEUE:%s]','finally','message','[TIMER][STOP][AGENT:%s]','[ACW][STOP]\x20Interface\x20%s\x20doesn\x27t\x20have\x20timer','isUndefined','attended','[%s][HANGUP:UNIQUEID]','linkedid','[%s][HANGUP:LINKEDID]'];(function(_0x53f80c,_0x5913f7){var _0x1408fd=function(_0x5dc479){while(--_0x5dc479){_0x53f80c['push'](_0x53f80c['shift']());}};_0x1408fd(++_0x5913f7);}(_0x425d,0x1e0));var _0xd425=function(_0x1faa6e,_0x423197){_0x1faa6e=_0x1faa6e-0x0;var _0x15fc1d=_0x425d[_0x1faa6e];return _0x15fc1d;};'use strict';var util=require(_0xd425('0x0'));var _=require('lodash');var moment=require(_0xd425('0x1'));var ami=require(_0xd425('0x2'));var logger=require(_0xd425('0x3'))(_0xd425('0x4'));var RpcUser=require(_0xd425('0x5'));var RpcVoiceAgentReport=require(_0xd425('0x6'));function Acw(_0x47043f){this['voiceQueues']=_0x47043f[_0xd425('0x7')];this[_0xd425('0x8')]=_0x47043f[_0xd425('0x8')];this[_0xd425('0x9')]=_0x47043f[_0xd425('0x9')];this[_0xd425('0xa')]={};ami['on']('agentconnect',this[_0xd425('0xb')][_0xd425('0xc')](this));ami['on'](_0xd425('0xd'),this[_0xd425('0xe')][_0xd425('0xc')](this));ami['on'](_0xd425('0xf'),this[_0xd425('0x10')][_0xd425('0xc')](this));ami['on'](_0xd425('0x11'),this[_0xd425('0x12')][_0xd425('0xc')](this));ami['on'](_0xd425('0x13'),this[_0xd425('0x14')][_0xd425('0xc')](this));ami['on'](_0xd425('0x15'),this[_0xd425('0x16')][_0xd425('0xc')](this));ami['on'](_0xd425('0x17'),this[_0xd425('0x18')][_0xd425('0xc')](this));}function getDiff(_0x51263f){var _0x27318c=moment()[_0xd425('0x19')](0x0);var _0x336dc3=moment(_0x51263f)['milliseconds'](0x0);return _0x27318c[_0xd425('0x1a')](_0x336dc3,_0xd425('0x1b'));}Acw[_0xd425('0x1c')][_0xd425('0x1d')]=function(_0x1fc822){try{var _0x538a0a=this;var _0x278626=this[_0xd425('0xa')][_0x1fc822][_0xd425('0x1e')];var _0x5dda0c=this['channels'][_0x1fc822][_0xd425('0x1f')];ami[_0xd425('0x20')]({'action':_0xd425('0x21'),'interface':_0x278626,'paused':!![],'reason':_0xd425('0x22')})['then'](function(_0x58a0c1){if(_0x538a0a['agents'][_0x278626]){return RpcUser['getAgent'](_0x538a0a[_0xd425('0x8')][_0x278626]['id'])[_0xd425('0x23')](function(_0x3c98db){if(_0x3c98db&&!_0x3c98db['voicePause']){logger[_0xd425('0x24')](_0xd425('0x25'),_0x1fc822,_0x278626,_0x5dda0c);return RpcUser['savePause'](_0x538a0a[_0xd425('0x8')][_0x278626],_0xd425('0x22'),_0x1fc822)[_0xd425('0x23')](function(_0x1d3fc0){_0x538a0a[_0xd425('0x9')][_0x278626]={};logger[_0xd425('0x24')](_0xd425('0x26'),_0x1fc822,_0x538a0a[_0xd425('0x7')][_0x5dda0c][_0xd425('0x27')],_0x278626,_0x5dda0c);_0x538a0a[_0xd425('0x9')][_0x278626][_0xd425('0x28')]=setTimeout(_0x538a0a[_0xd425('0x29')]['bind'](_0x538a0a,_0x278626),_0x538a0a[_0xd425('0x7')][_0x5dda0c][_0xd425('0x27')]*0x3e8);_0x538a0a[_0xd425('0x9')][_0x278626][_0xd425('0x2a')]=_0x1d3fc0[_0xd425('0x2a')];_0x538a0a[_0xd425('0x9')][_0x278626][_0xd425('0x2b')]=_0x1fc822;_0x538a0a['timers'][_0x278626][_0xd425('0x1f')]=_0x5dda0c;_0x538a0a[_0xd425('0x9')][_0x278626][_0xd425('0x2c')]=function(){var _0x57c950=getDiff(_0x538a0a[_0xd425('0x9')][_0x278626][_0xd425('0x2a')]);clearTimeout(_0x538a0a[_0xd425('0x9')][_0x278626][_0xd425('0x28')]);RpcVoiceAgentReport[_0xd425('0x2d')]({'acwtime':_0x57c950},_0x538a0a[_0xd425('0x9')][_0x278626][_0xd425('0x2b')],_0x278626)[_0xd425('0x23')](function(_0x24da23){logger[_0xd425('0x24')]('[%s][UPDATE][ACWTIME:%s]',_0x1fc822,_0x57c950,_0x24da23);})[_0xd425('0x2e')](function(_0x219ada){logger[_0xd425('0x2f')](_0xd425('0x30'),_0x1fc822,_0x219ada);});delete _0x538a0a[_0xd425('0x9')][_0x278626];};});}else{logger[_0xd425('0x24')](_0xd425('0x31'),_0x1fc822,_0x278626,_0x5dda0c);}});}})[_0xd425('0x2e')](function(_0x3ec51b){logger[_0xd425('0x2f')](_0xd425('0x26'),_0x1fc822,_0x538a0a['voiceQueues'][_0x5dda0c][_0xd425('0x27')],_0x278626,_0x5dda0c);})[_0xd425('0x32')](function(){delete _0x538a0a[_0xd425('0xa')][_0x1fc822];});}catch(_0x21e0bd){logger[_0xd425('0x2f')]('[ACW][START]\x20%s',_0x21e0bd[_0xd425('0x33')]);}};Acw[_0xd425('0x1c')]['stopAcw']=function(_0x574962){try{var _0x51669d=this;if(_0x51669d[_0xd425('0x9')][_0x574962]){var _0xfb0c8=_0x51669d[_0xd425('0x9')][_0x574962][_0xd425('0x2b')];var _0x4aa5b2=_0x51669d[_0xd425('0x9')][_0x574962][_0xd425('0x1f')];var _0x30a9dc=_0x51669d[_0xd425('0x7')][_0x4aa5b2][_0xd425('0x27')];logger[_0xd425('0x24')](_0xd425('0x34'),_0x574962);RpcUser['saveUnpause'](this[_0xd425('0x8')][_0x574962]);RpcVoiceAgentReport['update']({'acwtime':_0x30a9dc,'agentacw':!![]},_0xfb0c8,_0x574962)[_0xd425('0x23')](function(_0x29cca9){logger[_0xd425('0x24')]('[%s][UPDATE][ACWTIME:%s]',_0xfb0c8,_0x30a9dc,_0x29cca9);})[_0xd425('0x2e')](function(_0x26806c){logger[_0xd425('0x2f')](_0xd425('0x30'),_0xfb0c8,_0x26806c);});}else{logger['error'](_0xd425('0x35'),_0x574962);if(_0x51669d[_0xd425('0x9')]){logger['info']('[ACW][TIMERS]',JSON['stringify'](_0x51669d[_0xd425('0x9')]));}}}catch(_0x400d57){logger[_0xd425('0x2f')]('[ACW][STOP]\x20%s',_0x400d57['message']);}};Acw['prototype'][_0xd425('0xb')]=function(_0x3f9090){try{if(this[_0xd425('0x7')][_0x3f9090[_0xd425('0x1f')]]&&this[_0xd425('0x7')][_0x3f9090[_0xd425('0x1f')]][_0xd425('0x4')]){if(this['agents'][_0x3f9090[_0xd425('0x1e')]]){this[_0xd425('0xa')][_0x3f9090[_0xd425('0x2b')]]={'queue':_0x3f9090['queue'],'interface':_0x3f9090[_0xd425('0x1e')]};}}}catch(_0x2dffc7){logger[_0xd425('0x2f')]('[ACW][syncAgentConnect]\x20%s',_0x2dffc7[_0xd425('0x33')]);}};Acw[_0xd425('0x1c')][_0xd425('0x18')]=function(_0x2d7a2f){try{if(this['voiceQueues'][_0x2d7a2f[_0xd425('0x1f')]]&&this[_0xd425('0x7')][_0x2d7a2f[_0xd425('0x1f')]][_0xd425('0x4')]){if(this[_0xd425('0x8')][_0x2d7a2f[_0xd425('0x1e')]]){this[_0xd425('0xa')][_0x2d7a2f['uniqueid']]={'queue':_0x2d7a2f[_0xd425('0x1f')],'interface':_0x2d7a2f[_0xd425('0x1e')]};}}}catch(_0x5b65fe){logger[_0xd425('0x2f')]('[ACW][syncAgentConnectPreview]\x20%s',_0x5b65fe['message']);}};Acw[_0xd425('0x1c')]['syncHangupRequest']=function(_0x1be60a){try{if(this['channels'][_0x1be60a[_0xd425('0x2b')]]&&_[_0xd425('0x36')](this[_0xd425('0xa')][_0x1be60a[_0xd425('0x2b')]][_0xd425('0x37')])){logger['info'](_0xd425('0x38'),_0x1be60a['uniqueid']);this[_0xd425('0x1d')](_0x1be60a['uniqueid']);}else if(this[_0xd425('0xa')][_0x1be60a[_0xd425('0x39')]]&&_[_0xd425('0x36')](this[_0xd425('0xa')][_0x1be60a[_0xd425('0x39')]]['attended'])){logger[_0xd425('0x24')](_0xd425('0x3a'),_0x1be60a[_0xd425('0x39')]);this[_0xd425('0x1d')](_0x1be60a[_0xd425('0x39')]);}}catch(_0x499796){logger[_0xd425('0x2f')](_0xd425('0x3b'),_0x499796[_0xd425('0x33')]);}};Acw[_0xd425('0x1c')][_0xd425('0x10')]=function(_0xf7a74c){try{if(this['channels'][_0xf7a74c[_0xd425('0x2b')]]&&this[_0xd425('0xa')][_0xf7a74c['uniqueid']][_0xd425('0x37')]){logger[_0xd425('0x24')](_0xd425('0x3c'),_0xf7a74c[_0xd425('0x2b')]);this['startAcw'](_0xf7a74c[_0xd425('0x2b')]);}else if(this[_0xd425('0xa')][_0xf7a74c[_0xd425('0x39')]]&&this[_0xd425('0xa')][_0xf7a74c[_0xd425('0x39')]]['attended']){logger['info'](_0xd425('0x3d'),_0xf7a74c['linkedid']);this[_0xd425('0x1d')](_0xf7a74c[_0xd425('0x39')]);}}catch(_0x5594f9){logger[_0xd425('0x2f')]('[ACW][syncHangup]\x20%s',_0x5594f9['message']);}};Acw[_0xd425('0x1c')][_0xd425('0x14')]=function(_0xe6451f){try{if(!_[_0xd425('0x3e')](this[_0xd425('0xa')][_0xe6451f[_0xd425('0x3f')]])){this[_0xd425('0x1d')](_0xe6451f[_0xd425('0x3f')]);if(this['channels'][_0xe6451f[_0xd425('0x40')]]){this[_0xd425('0xa')][_0xe6451f[_0xd425('0x40')]][_0xd425('0x37')]=!![];this[_0xd425('0xa')][_0xe6451f[_0xd425('0x41')]]=this[_0xd425('0xa')][_0xe6451f[_0xd425('0x40')]];delete this['channels'][_0xe6451f['secondtransfereruniqueid']];}}else if(!_['isNil'](this[_0xd425('0xa')][_0xe6451f[_0xd425('0x41')]])){this[_0xd425('0x1d')](_0xe6451f[_0xd425('0x41')]);if(this['channels'][_0xe6451f['origtransfereruniqueid']]){this['channels'][_0xe6451f['origtransfereruniqueid']][_0xd425('0x37')]=!![];this[_0xd425('0xa')][_0xe6451f['transfereeuniqueid']]=this[_0xd425('0xa')][_0xe6451f[_0xd425('0x42')]];delete this[_0xd425('0xa')][_0xe6451f['origtransfereruniqueid']];}}}catch(_0x517e2e){logger[_0xd425('0x2f')]('[ACW][syncAttendedTransfer]\x20%s',_0x517e2e['message']);}};Acw['prototype'][_0xd425('0x16')]=function(_0x259482){try{if(this[_0xd425('0xa')][_0x259482['transfereruniqueid']]){logger[_0xd425('0x24')]('[%s][BLINDTRANSFER:UNIQUEID]',JSON[_0xd425('0x43')](_0x259482[_0xd425('0x44')]));this[_0xd425('0x1d')](_0x259482[_0xd425('0x44')]);}else if(this[_0xd425('0xa')][_0x259482[_0xd425('0x45')]]){logger[_0xd425('0x24')](_0xd425('0x46'),JSON[_0xd425('0x43')](_0x259482['transfererlinkedid']));this[_0xd425('0x1d')](_0x259482[_0xd425('0x45')]);}}catch(_0x18dc33){logger[_0xd425('0x2f')]('[ACW][syncBlindTransfer]\x20%s',_0x18dc33['message']);}};Acw[_0xd425('0x1c')][_0xd425('0x12')]=function(_0x142660){try{if(this[_0xd425('0x7')][_0x142660[_0xd425('0x1f')]]&&this[_0xd425('0x7')][_0x142660[_0xd425('0x1f')]][_0xd425('0x47')]===_0xd425('0x48')){if(this[_0xd425('0x8')][_0x142660[_0xd425('0x1e')]]){logger[_0xd425('0x24')](_0xd425('0x49'),_0x142660[_0xd425('0x2b')],_0x142660['interface'],_0x142660[_0xd425('0x1f')]);return RpcUser[_0xd425('0x4a')](this[_0xd425('0x8')][_0x142660['interface']],'Auto-Pause',_0x142660['uniqueid']);}}}catch(_0x403cb3){logger[_0xd425('0x2f')](_0xd425('0x4b'),_0x403cb3['message']);}};module[_0xd425('0x4c')]=Acw;