Built motion from commit c116dc8b.|2.6.30
[motion2.git] / server / services / xdr / agents.controller.js
index 304912c..8b0b0d7 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0xb9a7=['connect','answered_elsewhere','answeredelsewheredestinationuniqueid','answeredelsewheremembername','[%s][agents][agentconnect]','[%s][agents][agentcomplete]','[%s][agents][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','diffTime','complete','[%s][agents][blindtransfer]','transfereruniqueid','transfer','transfertype','blind','transferexten','transferuniqueid','origtransfererlinkedid','secondtransfereruniqueid','[%s][agents][attendedtransfer]\x20agent:%s','origtransfereruniqueid','ATTENDED','transfereeuniqueid','calleridname','agententerreason','secondtransfererlinkedid','transfertargetuniqueid','hangup','[%s][agents][hangup]','cause','rejected','splice','agentcompleteAt','agent','[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s','util','info','[%s][agents][writeDB]\x20channel:%s\x20queue:%s\x20agent:%s\x20interface:%s\x20calleridnum:%s\x20connectedlinenum:%s\x20lastevent:%s','uniqueid','channel','queue','membername','interface','calleridnum','connectedlinenum','lastevent','then','agentacw','agentcomplete','acwtime','acwTimeout','CreateVoiceAgentReport','request','destuniqueid','agentcalled','debug','format','agentcalledAt','now','called','[%s][agents][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called','error','[%s][agents][agentcalled]','agentringnoanswer','isNil','[%s][agents][agentringnoanswer]','[%s][agents][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:timeout','timeout','reason','ringtime','talktime','queuecallerabandon','forIn','includes','agentringnoanswerAt','abandoned','holdtime','[%s][agents][queuecallerabandon]','agentconnect','agentconnectAt','connectedlinename'];(function(_0x16d545,_0x52816d){var _0x78c374=function(_0x5845b7){while(--_0x5845b7){_0x16d545['push'](_0x16d545['shift']());}};_0x78c374(++_0x52816d);}(_0xb9a7,0x112));var _0x7b9a=function(_0x17b6e3,_0x4522ed){_0x17b6e3=_0x17b6e3-0x0;var _0x3906f3=_0xb9a7[_0x17b6e3];return _0x3906f3;};'use strict';var _=require('lodash');var util=require(_0x7b9a('0x0'));var utils=require('./utils');var agents={};var transfers={};var unanswered=[];function writeDB(_0x563857,_0x5f1a52){utils[_0x7b9a('0x1')](util['format'](_0x7b9a('0x2'),_0x563857[_0x7b9a('0x3')],_0x563857[_0x7b9a('0x4')],_0x563857[_0x7b9a('0x5')],_0x563857[_0x7b9a('0x6')],_0x563857[_0x7b9a('0x7')],_0x563857[_0x7b9a('0x8')],_0x563857[_0x7b9a('0x9')],_0x563857[_0x7b9a('0xa')]));if(_0x563857[_0x7b9a('0x5')]){utils['getVoiceQueueByName'](_0x563857[_0x7b9a('0x5')])[_0x7b9a('0xb')](function(_0x56a199){if(_0x56a199){_0x563857['type']=_0x56a199['type'];_0x563857[_0x7b9a('0xc')]=_0x563857[_0x7b9a('0xd')]?_0x56a199['acw']:![];_0x563857[_0x7b9a('0xe')]=_0x563857['agentacw']?_0x56a199[_0x7b9a('0xf')]:0x0;}utils['request'](_0x7b9a('0x10'),_0x563857);});}else{utils[_0x7b9a('0x11')](_0x7b9a('0x10'),_0x563857);}if(_0x5f1a52){delete transfers[_0x563857['uniqueid']];}else{delete agents[_0x563857[_0x7b9a('0x12')]];}}exports[_0x7b9a('0x13')]=function(_0x5e3875){try{utils[_0x7b9a('0x14')](util[_0x7b9a('0x15')]('[%s][agents][agentcalled]',_0x5e3875[_0x7b9a('0x3')]),_0x5e3875);agents[_0x5e3875[_0x7b9a('0x12')]]=_0x5e3875;agents[_0x5e3875[_0x7b9a('0x12')]][_0x7b9a('0x16')]=utils[_0x7b9a('0x17')]();agents[_0x5e3875[_0x7b9a('0x12')]][_0x7b9a('0xa')]=_0x7b9a('0x18');agents[_0x5e3875[_0x7b9a('0x12')]]['connectedlinenum']=null;agents[_0x5e3875[_0x7b9a('0x12')]]['connectedlinename']=null;utils[_0x7b9a('0x1')](util[_0x7b9a('0x15')](_0x7b9a('0x19'),_0x5e3875[_0x7b9a('0x3')],agents[_0x5e3875[_0x7b9a('0x12')]][_0x7b9a('0x6')],_0x5e3875[_0x7b9a('0x12')]));}catch(_0x283cc3){utils[_0x7b9a('0x1a')](util[_0x7b9a('0x15')](_0x7b9a('0x1b'),_0x5e3875[_0x7b9a('0x3')]),_0x283cc3);}};exports[_0x7b9a('0x1c')]=function(_0x58aed7){try{if(!_[_0x7b9a('0x1d')](agents[_0x58aed7['destuniqueid']])){utils[_0x7b9a('0x14')](util['format'](_0x7b9a('0x1e'),_0x58aed7[_0x7b9a('0x3')]),_0x58aed7);utils[_0x7b9a('0x1')](util['format'](_0x7b9a('0x1f'),_0x58aed7[_0x7b9a('0x3')],agents[_0x58aed7['destuniqueid']][_0x7b9a('0x6')],_0x58aed7[_0x7b9a('0x12')]));agents[_0x58aed7[_0x7b9a('0x12')]][_0x7b9a('0x1c')]=!![];agents[_0x58aed7[_0x7b9a('0x12')]]['agentringnoanswerAt']=utils[_0x7b9a('0x17')]();agents[_0x58aed7[_0x7b9a('0x12')]]['lastevent']=_0x7b9a('0x20');agents[_0x58aed7['destuniqueid']][_0x7b9a('0x21')]=_0x7b9a('0x20');agents[_0x58aed7['destuniqueid']]['holdtime']=_0x58aed7[_0x7b9a('0x22')]?parseInt(_0x58aed7['ringtime'])/0x3e8:0x0;agents[_0x58aed7['destuniqueid']][_0x7b9a('0x23')]=0x0;unanswered['push'](_0x58aed7['destuniqueid']);}}catch(_0x3847b4){utils['error'](util[_0x7b9a('0x15')](_0x7b9a('0x1e'),_0x58aed7['uniqueid']),_0x3847b4);}};exports[_0x7b9a('0x24')]=function(_0x2e6144){try{_[_0x7b9a('0x25')](agents,function(_0x5b64d7,_0x45ccf5){if(_0x5b64d7[_0x7b9a('0x3')]==_0x2e6144[_0x7b9a('0x3')]&&!_[_0x7b9a('0x26')](unanswered,_0x5b64d7[_0x7b9a('0x12')])){utils[_0x7b9a('0x14')](util['format']('[%s][agents][queuecallerabandon]',_0x2e6144[_0x7b9a('0x3')]),_0x2e6144);utils[_0x7b9a('0x1')](util[_0x7b9a('0x15')]('[%s][agents][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned',_0x2e6144[_0x7b9a('0x3')],_0x5b64d7[_0x7b9a('0x6')],_0x5b64d7['destuniqueid']));_0x5b64d7['agentringnoanswer']=!![];_0x5b64d7[_0x7b9a('0x27')]=utils[_0x7b9a('0x17')]();_0x5b64d7['lastevent']=_0x7b9a('0x28');_0x5b64d7[_0x7b9a('0x21')]=_0x7b9a('0x28');_0x5b64d7[_0x7b9a('0x29')]=_0x2e6144[_0x7b9a('0x29')];_0x5b64d7['talktime']=0x0;writeDB(_0x5b64d7);}});}catch(_0x46bcd0){utils[_0x7b9a('0x1a')](util[_0x7b9a('0x15')](_0x7b9a('0x2a'),_0x2e6144[_0x7b9a('0x3')]),_0x46bcd0);}};exports[_0x7b9a('0x2b')]=function(_0x5f1da4){try{if(agents[_0x5f1da4['destuniqueid']]){utils[_0x7b9a('0x14')](util[_0x7b9a('0x15')]('[%s][agents][agentconnect]',_0x5f1da4[_0x7b9a('0x3')]),_0x5f1da4);utils[_0x7b9a('0x1')](util[_0x7b9a('0x15')]('[%s][agents][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect',_0x5f1da4[_0x7b9a('0x3')],agents[_0x5f1da4[_0x7b9a('0x12')]]['membername'],_0x5f1da4['destuniqueid']));agents[_0x5f1da4[_0x7b9a('0x12')]][_0x7b9a('0x2c')]=utils[_0x7b9a('0x17')]();agents[_0x5f1da4[_0x7b9a('0x12')]][_0x7b9a('0x9')]=_0x5f1da4[_0x7b9a('0x9')];agents[_0x5f1da4[_0x7b9a('0x12')]][_0x7b9a('0x2d')]=_0x5f1da4['connectedlinename'];agents[_0x5f1da4[_0x7b9a('0x12')]]['holdtime']=_0x5f1da4[_0x7b9a('0x22')];agents[_0x5f1da4[_0x7b9a('0x12')]][_0x7b9a('0xa')]=_0x7b9a('0x2e');_[_0x7b9a('0x25')](agents,function(_0x89951b,_0x5e504f){if(_0x89951b[_0x7b9a('0x12')]!=_0x5f1da4[_0x7b9a('0x12')]&&_0x89951b[_0x7b9a('0x3')]==_0x5f1da4[_0x7b9a('0x3')]){_0x89951b['talktime']=0x0;_0x89951b[_0x7b9a('0x29')]=_0x5f1da4[_0x7b9a('0x22')];_0x89951b[_0x7b9a('0x1c')]=!![];_0x89951b[_0x7b9a('0x27')]=utils['now']();_0x89951b[_0x7b9a('0xa')]='answered_elsewhere';_0x89951b[_0x7b9a('0x21')]=_0x7b9a('0x2f');_0x89951b[_0x7b9a('0x30')]=_0x5f1da4[_0x7b9a('0x12')];_0x89951b[_0x7b9a('0x31')]=_0x5f1da4[_0x7b9a('0x6')];writeDB(_0x89951b);}});}}catch(_0x56e274){utils[_0x7b9a('0x1a')](util[_0x7b9a('0x15')](_0x7b9a('0x32'),_0x5f1da4['uniqueid']),_0x56e274);}};exports['agentcomplete']=function(_0x3724fe){try{if(!_[_0x7b9a('0x1d')](agents[_0x3724fe[_0x7b9a('0x12')]])){utils[_0x7b9a('0x14')](util[_0x7b9a('0x15')](_0x7b9a('0x33'),_0x3724fe['uniqueid']),_0x3724fe);utils['info'](util['format'](_0x7b9a('0x34'),_0x3724fe[_0x7b9a('0x3')],agents[_0x3724fe['destuniqueid']][_0x7b9a('0x6')],_0x3724fe[_0x7b9a('0x12')]));agents[_0x3724fe[_0x7b9a('0x12')]]['agentcomplete']=!![];agents[_0x3724fe[_0x7b9a('0x12')]]['agentcompleteAt']=utils[_0x7b9a('0x17')]();agents[_0x3724fe[_0x7b9a('0x12')]][_0x7b9a('0x23')]=utils[_0x7b9a('0x35')](agents[_0x3724fe[_0x7b9a('0x12')]]['agentcompleteAt'],agents[_0x3724fe[_0x7b9a('0x12')]]['agentconnectAt']);agents[_0x3724fe[_0x7b9a('0x12')]]['reason']=_0x3724fe['reason'];agents[_0x3724fe[_0x7b9a('0x12')]][_0x7b9a('0xa')]=_0x7b9a('0x36');writeDB(agents[_0x3724fe[_0x7b9a('0x12')]]);}}catch(_0x1cbd5a){utils[_0x7b9a('0x1a')](util[_0x7b9a('0x15')](_0x7b9a('0x33'),_0x3724fe[_0x7b9a('0x3')]),_0x1cbd5a);}};exports['blindtransfer']=function(_0x1d7957){try{if(!_[_0x7b9a('0x1d')](agents[_0x1d7957['transfereruniqueid']])){utils['debug'](util['format'](_0x7b9a('0x37'),_0x1d7957[_0x7b9a('0x3')]),_0x1d7957);utils[_0x7b9a('0x1')](util[_0x7b9a('0x15')]('[%s][agents][blindtransfer]\x20agent:%s\x20transferuniqueid:%s',_0x1d7957[_0x7b9a('0x3')],agents[_0x1d7957[_0x7b9a('0x38')]][_0x7b9a('0x6')],agents[_0x1d7957[_0x7b9a('0x38')]][_0x7b9a('0x3')]));agents[_0x1d7957['transfereruniqueid']][_0x7b9a('0x39')]=!![];agents[_0x1d7957['transfereruniqueid']][_0x7b9a('0x3a')]=_0x7b9a('0x3b');agents[_0x1d7957[_0x7b9a('0x38')]][_0x7b9a('0x3c')]=_0x1d7957['extension'];agents[_0x1d7957[_0x7b9a('0x38')]][_0x7b9a('0x3d')]=agents[_0x1d7957[_0x7b9a('0x38')]][_0x7b9a('0x3')];}}catch(_0x2b0db5){utils[_0x7b9a('0x1a')](util[_0x7b9a('0x15')]('[%s][agents][blindtransfer]',_0x1d7957['uniqueid']),_0x2b0db5);}};exports['attendedtransfer']=function(_0x12c5bf){try{utils[_0x7b9a('0x14')](util['format']('[%s][agents][attendedtransfer]',_0x12c5bf['origtransfereruniqueid']),_0x12c5bf);if(_0x12c5bf['origtransfereruniqueid']==_0x12c5bf[_0x7b9a('0x3e')]){if(!_[_0x7b9a('0x1d')](agents[_0x12c5bf[_0x7b9a('0x3f')]])){utils[_0x7b9a('0x1')](util[_0x7b9a('0x15')](_0x7b9a('0x40'),_0x12c5bf[_0x7b9a('0x41')],agents[_0x12c5bf[_0x7b9a('0x3f')]]['membername']));agents[_0x12c5bf[_0x7b9a('0x3f')]]['transfer']=!![];agents[_0x12c5bf[_0x7b9a('0x3f')]][_0x7b9a('0x3a')]=_0x7b9a('0x42');agents[_0x12c5bf[_0x7b9a('0x3f')]][_0x7b9a('0x3c')]=_0x12c5bf['origtransfererexten'];agents[_0x12c5bf[_0x7b9a('0x3f')]]['transferuniqueid']=_0x12c5bf[_0x7b9a('0x41')];}if(_0x12c5bf[_0x7b9a('0x43')]&&agents[_0x12c5bf[_0x7b9a('0x43')]]){agents[_0x12c5bf['transfereeuniqueid']]['agententerreason']=0x1;transfers[_0x12c5bf['transfereeuniqueid']]=_['clone'](agents[_0x12c5bf[_0x7b9a('0x43')]]);transfers[_0x12c5bf[_0x7b9a('0x43')]][_0x7b9a('0x8')]=agents[_0x12c5bf['secondtransfereruniqueid']][_0x7b9a('0x8')];transfers[_0x12c5bf[_0x7b9a('0x43')]][_0x7b9a('0x44')]=agents[_0x12c5bf[_0x7b9a('0x3f')]][_0x7b9a('0x44')];transfers[_0x12c5bf['transfereeuniqueid']][_0x7b9a('0x16')]=utils[_0x7b9a('0x17')]();transfers[_0x12c5bf[_0x7b9a('0x43')]]['agentconnectAt']=utils['now']();transfers[_0x12c5bf['transfereeuniqueid']][_0x7b9a('0x29')]=0x0;transfers[_0x12c5bf[_0x7b9a('0x43')]][_0x7b9a('0x45')]=0x2;}}else if(_0x12c5bf['secondtransfereruniqueid']==_0x12c5bf[_0x7b9a('0x46')]){if(!_[_0x7b9a('0x1d')](agents[_0x12c5bf['origtransfereruniqueid']])){utils[_0x7b9a('0x1')](util['format'](_0x7b9a('0x40'),_0x12c5bf['origtransfereruniqueid'],agents[_0x12c5bf[_0x7b9a('0x41')]][_0x7b9a('0x6')]));agents[_0x12c5bf[_0x7b9a('0x41')]][_0x7b9a('0x39')]=!![];agents[_0x12c5bf['origtransfereruniqueid']][_0x7b9a('0x3a')]=_0x7b9a('0x42');agents[_0x12c5bf[_0x7b9a('0x41')]][_0x7b9a('0x3c')]=_0x12c5bf['secondtransfererexten'];agents[_0x12c5bf[_0x7b9a('0x41')]]['transferuniqueid']=_0x12c5bf[_0x7b9a('0x3f')];}if(_0x12c5bf['transfertargetuniqueid']&&agents[_0x12c5bf[_0x7b9a('0x47')]]){agents[_0x12c5bf['transfertargetuniqueid']]['agententerreason']=0x1;transfers[_0x12c5bf['transfertargetuniqueid']]=_['clone'](agents[_0x12c5bf[_0x7b9a('0x47')]]);transfers[_0x12c5bf[_0x7b9a('0x47')]][_0x7b9a('0x8')]=agents[_0x12c5bf[_0x7b9a('0x41')]]['calleridnum'];transfers[_0x12c5bf[_0x7b9a('0x47')]]['calleridname']=agents[_0x12c5bf['origtransfereruniqueid']][_0x7b9a('0x44')];transfers[_0x12c5bf['transfertargetuniqueid']]['agentcalledAt']=utils[_0x7b9a('0x17')]();transfers[_0x12c5bf[_0x7b9a('0x47')]]['agentconnectAt']=utils[_0x7b9a('0x17')]();transfers[_0x12c5bf['transfertargetuniqueid']][_0x7b9a('0x29')]=0x0;transfers[_0x12c5bf[_0x7b9a('0x47')]][_0x7b9a('0x45')]=0x2;}}}catch(_0x5118b3){utils['error'](util['format']('[%s][agents][attendedtransfer]',_0x12c5bf[_0x7b9a('0x41')]),_0x5118b3);}};exports[_0x7b9a('0x48')]=function(_0x3fd697){try{utils[_0x7b9a('0x14')](util[_0x7b9a('0x15')](_0x7b9a('0x49'),_0x3fd697[_0x7b9a('0x3')]),_0x3fd697);if(agents[_0x3fd697['uniqueid']]&&agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x21')]==='timeout'){if(_0x3fd697[_0x7b9a('0x4a')]==='21'){agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x21')]='rejected';agents[_0x3fd697['uniqueid']][_0x7b9a('0xa')]=_0x7b9a('0x4b');}utils['info'](util[_0x7b9a('0x15')]('[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s',_0x3fd697[_0x7b9a('0x3')],agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x6')],agents[_0x3fd697['uniqueid']][_0x7b9a('0x21')],agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0xa')]));writeDB(agents[_0x3fd697[_0x7b9a('0x3')]]);var _0x2090ef=unanswered['indexOf'](_0x3fd697['uniqueid']);if(_0x2090ef>-0x1){unanswered[_0x7b9a('0x4c')](_0x2090ef,0x1);}}if(transfers[_0x3fd697[_0x7b9a('0x3')]]){transfers[_0x3fd697['uniqueid']][_0x7b9a('0xd')]=!![];transfers[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x4d')]=utils['now']();transfers[_0x3fd697['uniqueid']][_0x7b9a('0x23')]=utils[_0x7b9a('0x35')](transfers[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x4d')],transfers[_0x3fd697['uniqueid']][_0x7b9a('0x2c')]);transfers[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x21')]='agent';transfers[_0x3fd697['uniqueid']][_0x7b9a('0xa')]=_0x7b9a('0x36');utils[_0x7b9a('0x1')](util[_0x7b9a('0x15')]('[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s',_0x3fd697[_0x7b9a('0x3')],transfers[_0x3fd697[_0x7b9a('0x3')]]['membername'],transfers[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x21')],transfers[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0xa')]));writeDB(transfers[_0x3fd697[_0x7b9a('0x3')]],!![]);}if(agents[_0x3fd697[_0x7b9a('0x3')]]&&agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x2c')]){agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0xd')]=!![];agents[_0x3fd697[_0x7b9a('0x3')]]['agentcompleteAt']=utils['now']();agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x23')]=utils['diffTime'](agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x4d')],agents[_0x3fd697['uniqueid']][_0x7b9a('0x2c')]);agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x21')]=agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x39')]?_0x7b9a('0x39'):_0x7b9a('0x4e');agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0xa')]='complete';utils[_0x7b9a('0x1')](util[_0x7b9a('0x15')](_0x7b9a('0x4f'),_0x3fd697[_0x7b9a('0x3')],agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x6')],agents[_0x3fd697[_0x7b9a('0x3')]][_0x7b9a('0x21')],agents[_0x3fd697['uniqueid']][_0x7b9a('0xa')]));writeDB(agents[_0x3fd697[_0x7b9a('0x3')]]);}}catch(_0x3022e0){utils['error'](util[_0x7b9a('0x15')](_0x7b9a('0x49'),_0x3fd697[_0x7b9a('0x3')]),_0x3022e0);}};
\ No newline at end of file
+var _0xb58b=['now','reason','timeout','holdtime','ringtime','talktime','push','queuecallerabandon','forIn','includes','[%s][agents][queuecallerabandon]','[%s][agents][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned','[%s][agents][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect','agentconnectAt','connectedlinename','connect','answered_elsewhere','answeredelsewheredestinationuniqueid','answeredelsewheremembername','[%s][agents][agentconnect]','[%s][agents][agentcomplete]','[%s][agents][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','diffTime','agentcompleteAt','complete','blindtransfer','transfereruniqueid','[%s][agents][blindtransfer]','[%s][agents][blindtransfer]\x20agent:%s\x20transferuniqueid:%s','transfer','transfertype','blind','transferexten','extension','transferuniqueid','attendedtransfer','origtransfereruniqueid','origtransfererlinkedid','[%s][agents][attendedtransfer]\x20agent:%s','secondtransfereruniqueid','ATTENDED','origtransfererexten','transfereeuniqueid','agententerreason','clone','calleridnum','calleridname','secondtransfererlinkedid','secondtransfererexten','transfertargetuniqueid','[%s][agents][attendedtransfer]','hangup','rejected','indexOf','agent','[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s','[%s][agents][hangup]','util','./utils','info','format','uniqueid','queue','membername','interface','connectedlinenum','lastevent','getVoiceQueueByName','then','type','agentacw','agentcomplete','acwtime','acwTimeout','request','CreateVoiceAgentReport','destuniqueid','debug','[%s][agents][agentcalled]','agentcalledAt','called','[%s][agents][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called','error','agentringnoanswer','isNil','[%s][agents][agentringnoanswer]','[%s][agents][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:timeout','agentringnoanswerAt'];(function(_0x1c78de,_0x4c36ac){var _0x185db5=function(_0x3c953a){while(--_0x3c953a){_0x1c78de['push'](_0x1c78de['shift']());}};_0x185db5(++_0x4c36ac);}(_0xb58b,0x1f1));var _0xbb58=function(_0x28f43b,_0x3de923){_0x28f43b=_0x28f43b-0x0;var _0x5026d7=_0xb58b[_0x28f43b];return _0x5026d7;};'use strict';var _=require('lodash');var util=require(_0xbb58('0x0'));var utils=require(_0xbb58('0x1'));var agents={};var transfers={};var unanswered=[];function writeDB(_0x3fb85a,_0x4f5d42){utils[_0xbb58('0x2')](util[_0xbb58('0x3')]('[%s][agents][writeDB]\x20channel:%s\x20queue:%s\x20agent:%s\x20interface:%s\x20calleridnum:%s\x20connectedlinenum:%s\x20lastevent:%s',_0x3fb85a[_0xbb58('0x4')],_0x3fb85a['channel'],_0x3fb85a[_0xbb58('0x5')],_0x3fb85a[_0xbb58('0x6')],_0x3fb85a[_0xbb58('0x7')],_0x3fb85a['calleridnum'],_0x3fb85a[_0xbb58('0x8')],_0x3fb85a[_0xbb58('0x9')]));if(_0x3fb85a[_0xbb58('0x5')]){utils[_0xbb58('0xa')](_0x3fb85a[_0xbb58('0x5')])[_0xbb58('0xb')](function(_0xc9e5bc){if(_0xc9e5bc){_0x3fb85a[_0xbb58('0xc')]=_0xc9e5bc[_0xbb58('0xc')];_0x3fb85a[_0xbb58('0xd')]=_0x3fb85a[_0xbb58('0xe')]?_0xc9e5bc['acw']:![];_0x3fb85a[_0xbb58('0xf')]=_0x3fb85a['agentacw']?_0xc9e5bc[_0xbb58('0x10')]:0x0;}utils[_0xbb58('0x11')](_0xbb58('0x12'),_0x3fb85a);});}else{utils[_0xbb58('0x11')]('CreateVoiceAgentReport',_0x3fb85a);}if(_0x4f5d42){delete transfers[_0x3fb85a[_0xbb58('0x4')]];}else{delete agents[_0x3fb85a[_0xbb58('0x13')]];}}exports['agentcalled']=function(_0x132511){try{utils[_0xbb58('0x14')](util[_0xbb58('0x3')](_0xbb58('0x15'),_0x132511[_0xbb58('0x4')]),_0x132511);agents[_0x132511['destuniqueid']]=_0x132511;agents[_0x132511[_0xbb58('0x13')]][_0xbb58('0x16')]=utils['now']();agents[_0x132511['destuniqueid']][_0xbb58('0x9')]=_0xbb58('0x17');agents[_0x132511[_0xbb58('0x13')]]['connectedlinenum']=null;agents[_0x132511['destuniqueid']]['connectedlinename']=null;utils['info'](util[_0xbb58('0x3')](_0xbb58('0x18'),_0x132511['uniqueid'],agents[_0x132511[_0xbb58('0x13')]]['membername'],_0x132511[_0xbb58('0x13')]));}catch(_0xe0bd6c){utils[_0xbb58('0x19')](util[_0xbb58('0x3')](_0xbb58('0x15'),_0x132511[_0xbb58('0x4')]),_0xe0bd6c);}};exports[_0xbb58('0x1a')]=function(_0x497fd0){try{if(!_[_0xbb58('0x1b')](agents[_0x497fd0[_0xbb58('0x13')]])){utils[_0xbb58('0x14')](util[_0xbb58('0x3')](_0xbb58('0x1c'),_0x497fd0[_0xbb58('0x4')]),_0x497fd0);utils[_0xbb58('0x2')](util[_0xbb58('0x3')](_0xbb58('0x1d'),_0x497fd0['uniqueid'],agents[_0x497fd0[_0xbb58('0x13')]]['membername'],_0x497fd0[_0xbb58('0x13')]));agents[_0x497fd0[_0xbb58('0x13')]][_0xbb58('0x1a')]=!![];agents[_0x497fd0[_0xbb58('0x13')]][_0xbb58('0x1e')]=utils[_0xbb58('0x1f')]();agents[_0x497fd0[_0xbb58('0x13')]][_0xbb58('0x9')]='timeout';agents[_0x497fd0[_0xbb58('0x13')]][_0xbb58('0x20')]=_0xbb58('0x21');agents[_0x497fd0[_0xbb58('0x13')]][_0xbb58('0x22')]=_0x497fd0[_0xbb58('0x23')]?parseInt(_0x497fd0[_0xbb58('0x23')])/0x3e8:0x0;agents[_0x497fd0[_0xbb58('0x13')]][_0xbb58('0x24')]=0x0;unanswered[_0xbb58('0x25')](_0x497fd0[_0xbb58('0x13')]);}}catch(_0x28b3a3){utils[_0xbb58('0x19')](util[_0xbb58('0x3')](_0xbb58('0x1c'),_0x497fd0['uniqueid']),_0x28b3a3);}};exports[_0xbb58('0x26')]=function(_0xe46bc1){try{_[_0xbb58('0x27')](agents,function(_0x3c9cee,_0x3304b9){if(_0x3c9cee[_0xbb58('0x4')]==_0xe46bc1[_0xbb58('0x4')]&&!_[_0xbb58('0x28')](unanswered,_0x3c9cee[_0xbb58('0x13')])){utils['debug'](util[_0xbb58('0x3')](_0xbb58('0x29'),_0xe46bc1[_0xbb58('0x4')]),_0xe46bc1);utils[_0xbb58('0x2')](util[_0xbb58('0x3')](_0xbb58('0x2a'),_0xe46bc1[_0xbb58('0x4')],_0x3c9cee[_0xbb58('0x6')],_0x3c9cee[_0xbb58('0x13')]));_0x3c9cee[_0xbb58('0x1a')]=!![];_0x3c9cee[_0xbb58('0x1e')]=utils[_0xbb58('0x1f')]();_0x3c9cee[_0xbb58('0x9')]='abandoned';_0x3c9cee['reason']='abandoned';_0x3c9cee[_0xbb58('0x22')]=_0xe46bc1[_0xbb58('0x22')];_0x3c9cee[_0xbb58('0x24')]=0x0;writeDB(_0x3c9cee);}});}catch(_0x3c7627){utils[_0xbb58('0x19')](util[_0xbb58('0x3')](_0xbb58('0x29'),_0xe46bc1[_0xbb58('0x4')]),_0x3c7627);}};exports['agentconnect']=function(_0x2fbf90){try{if(agents[_0x2fbf90[_0xbb58('0x13')]]){utils['debug'](util[_0xbb58('0x3')]('[%s][agents][agentconnect]',_0x2fbf90[_0xbb58('0x4')]),_0x2fbf90);utils['info'](util[_0xbb58('0x3')](_0xbb58('0x2b'),_0x2fbf90['uniqueid'],agents[_0x2fbf90[_0xbb58('0x13')]][_0xbb58('0x6')],_0x2fbf90[_0xbb58('0x13')]));agents[_0x2fbf90[_0xbb58('0x13')]][_0xbb58('0x2c')]=utils[_0xbb58('0x1f')]();agents[_0x2fbf90[_0xbb58('0x13')]][_0xbb58('0x8')]=_0x2fbf90['connectedlinenum'];agents[_0x2fbf90[_0xbb58('0x13')]][_0xbb58('0x2d')]=_0x2fbf90[_0xbb58('0x2d')];agents[_0x2fbf90['destuniqueid']]['holdtime']=_0x2fbf90[_0xbb58('0x23')];agents[_0x2fbf90['destuniqueid']][_0xbb58('0x9')]=_0xbb58('0x2e');_[_0xbb58('0x27')](agents,function(_0x560911,_0x485830){if(_0x560911[_0xbb58('0x13')]!=_0x2fbf90[_0xbb58('0x13')]&&_0x560911[_0xbb58('0x4')]==_0x2fbf90[_0xbb58('0x4')]){_0x560911[_0xbb58('0x24')]=0x0;_0x560911[_0xbb58('0x22')]=_0x2fbf90['ringtime'];_0x560911[_0xbb58('0x1a')]=!![];_0x560911[_0xbb58('0x1e')]=utils[_0xbb58('0x1f')]();_0x560911[_0xbb58('0x9')]=_0xbb58('0x2f');_0x560911[_0xbb58('0x20')]='answered_elsewhere';_0x560911[_0xbb58('0x30')]=_0x2fbf90['destuniqueid'];_0x560911[_0xbb58('0x31')]=_0x2fbf90[_0xbb58('0x6')];writeDB(_0x560911);}});}}catch(_0x29fb1c){utils[_0xbb58('0x19')](util['format'](_0xbb58('0x32'),_0x2fbf90[_0xbb58('0x4')]),_0x29fb1c);}};exports[_0xbb58('0xe')]=function(_0x3a732c){try{if(!_['isNil'](agents[_0x3a732c[_0xbb58('0x13')]])){utils['debug'](util[_0xbb58('0x3')](_0xbb58('0x33'),_0x3a732c[_0xbb58('0x4')]),_0x3a732c);utils[_0xbb58('0x2')](util[_0xbb58('0x3')](_0xbb58('0x34'),_0x3a732c[_0xbb58('0x4')],agents[_0x3a732c[_0xbb58('0x13')]][_0xbb58('0x6')],_0x3a732c[_0xbb58('0x13')]));agents[_0x3a732c[_0xbb58('0x13')]][_0xbb58('0xe')]=!![];agents[_0x3a732c[_0xbb58('0x13')]]['agentcompleteAt']=utils[_0xbb58('0x1f')]();agents[_0x3a732c['destuniqueid']]['talktime']=utils[_0xbb58('0x35')](agents[_0x3a732c[_0xbb58('0x13')]][_0xbb58('0x36')],agents[_0x3a732c[_0xbb58('0x13')]][_0xbb58('0x2c')]);agents[_0x3a732c[_0xbb58('0x13')]][_0xbb58('0x20')]=_0x3a732c[_0xbb58('0x20')];agents[_0x3a732c[_0xbb58('0x13')]][_0xbb58('0x9')]=_0xbb58('0x37');writeDB(agents[_0x3a732c['destuniqueid']]);}}catch(_0x2ec9be){utils[_0xbb58('0x19')](util['format'](_0xbb58('0x33'),_0x3a732c[_0xbb58('0x4')]),_0x2ec9be);}};exports[_0xbb58('0x38')]=function(_0xdb0ff7){try{if(!_['isNil'](agents[_0xdb0ff7[_0xbb58('0x39')]])){utils['debug'](util[_0xbb58('0x3')](_0xbb58('0x3a'),_0xdb0ff7[_0xbb58('0x4')]),_0xdb0ff7);utils['info'](util[_0xbb58('0x3')](_0xbb58('0x3b'),_0xdb0ff7['uniqueid'],agents[_0xdb0ff7[_0xbb58('0x39')]]['membername'],agents[_0xdb0ff7[_0xbb58('0x39')]][_0xbb58('0x4')]));agents[_0xdb0ff7[_0xbb58('0x39')]][_0xbb58('0x3c')]=!![];agents[_0xdb0ff7[_0xbb58('0x39')]][_0xbb58('0x3d')]=_0xbb58('0x3e');agents[_0xdb0ff7['transfereruniqueid']][_0xbb58('0x3f')]=_0xdb0ff7[_0xbb58('0x40')];agents[_0xdb0ff7['transfereruniqueid']][_0xbb58('0x41')]=agents[_0xdb0ff7[_0xbb58('0x39')]]['uniqueid'];}}catch(_0x22802c){utils[_0xbb58('0x19')](util[_0xbb58('0x3')]('[%s][agents][blindtransfer]',_0xdb0ff7[_0xbb58('0x4')]),_0x22802c);}};exports[_0xbb58('0x42')]=function(_0x12999c){try{utils['debug'](util[_0xbb58('0x3')]('[%s][agents][attendedtransfer]',_0x12999c[_0xbb58('0x43')]),_0x12999c);if(_0x12999c[_0xbb58('0x43')]==_0x12999c[_0xbb58('0x44')]){if(!_['isNil'](agents[_0x12999c['secondtransfereruniqueid']])){utils[_0xbb58('0x2')](util[_0xbb58('0x3')](_0xbb58('0x45'),_0x12999c[_0xbb58('0x43')],agents[_0x12999c[_0xbb58('0x46')]]['membername']));agents[_0x12999c[_0xbb58('0x46')]][_0xbb58('0x3c')]=!![];agents[_0x12999c[_0xbb58('0x46')]]['transfertype']=_0xbb58('0x47');agents[_0x12999c[_0xbb58('0x46')]][_0xbb58('0x3f')]=_0x12999c[_0xbb58('0x48')];agents[_0x12999c[_0xbb58('0x46')]]['transferuniqueid']=_0x12999c[_0xbb58('0x43')];}if(_0x12999c[_0xbb58('0x49')]&&agents[_0x12999c[_0xbb58('0x49')]]){agents[_0x12999c[_0xbb58('0x49')]][_0xbb58('0x4a')]=0x1;transfers[_0x12999c[_0xbb58('0x49')]]=_[_0xbb58('0x4b')](agents[_0x12999c[_0xbb58('0x49')]]);transfers[_0x12999c['transfereeuniqueid']][_0xbb58('0x4c')]=agents[_0x12999c['secondtransfereruniqueid']][_0xbb58('0x4c')];transfers[_0x12999c[_0xbb58('0x49')]][_0xbb58('0x4d')]=agents[_0x12999c[_0xbb58('0x46')]][_0xbb58('0x4d')];transfers[_0x12999c[_0xbb58('0x49')]][_0xbb58('0x16')]=utils[_0xbb58('0x1f')]();transfers[_0x12999c[_0xbb58('0x49')]][_0xbb58('0x2c')]=utils[_0xbb58('0x1f')]();transfers[_0x12999c['transfereeuniqueid']][_0xbb58('0x22')]=0x0;transfers[_0x12999c[_0xbb58('0x49')]][_0xbb58('0x4a')]=0x2;}}else if(_0x12999c['secondtransfereruniqueid']==_0x12999c[_0xbb58('0x4e')]){if(!_['isNil'](agents[_0x12999c[_0xbb58('0x43')]])){utils[_0xbb58('0x2')](util['format'](_0xbb58('0x45'),_0x12999c[_0xbb58('0x43')],agents[_0x12999c[_0xbb58('0x43')]][_0xbb58('0x6')]));agents[_0x12999c[_0xbb58('0x43')]]['transfer']=!![];agents[_0x12999c['origtransfereruniqueid']][_0xbb58('0x3d')]=_0xbb58('0x47');agents[_0x12999c[_0xbb58('0x43')]]['transferexten']=_0x12999c[_0xbb58('0x4f')];agents[_0x12999c[_0xbb58('0x43')]]['transferuniqueid']=_0x12999c[_0xbb58('0x46')];}if(_0x12999c[_0xbb58('0x50')]&&agents[_0x12999c['transfertargetuniqueid']]){agents[_0x12999c[_0xbb58('0x50')]][_0xbb58('0x4a')]=0x1;transfers[_0x12999c[_0xbb58('0x50')]]=_[_0xbb58('0x4b')](agents[_0x12999c[_0xbb58('0x50')]]);transfers[_0x12999c['transfertargetuniqueid']][_0xbb58('0x4c')]=agents[_0x12999c[_0xbb58('0x43')]][_0xbb58('0x4c')];transfers[_0x12999c[_0xbb58('0x50')]][_0xbb58('0x4d')]=agents[_0x12999c['origtransfereruniqueid']]['calleridname'];transfers[_0x12999c[_0xbb58('0x50')]]['agentcalledAt']=utils[_0xbb58('0x1f')]();transfers[_0x12999c[_0xbb58('0x50')]][_0xbb58('0x2c')]=utils[_0xbb58('0x1f')]();transfers[_0x12999c[_0xbb58('0x50')]][_0xbb58('0x22')]=0x0;transfers[_0x12999c[_0xbb58('0x50')]][_0xbb58('0x4a')]=0x2;}}}catch(_0x1529cf){utils[_0xbb58('0x19')](util['format'](_0xbb58('0x51'),_0x12999c[_0xbb58('0x43')]),_0x1529cf);}};exports[_0xbb58('0x52')]=function(_0x5b6508){try{utils[_0xbb58('0x14')](util['format']('[%s][agents][hangup]',_0x5b6508[_0xbb58('0x4')]),_0x5b6508);if(agents[_0x5b6508[_0xbb58('0x4')]]&&agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x20')]==='timeout'){if(_0x5b6508['cause']==='21'){agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x20')]='rejected';agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x9')]=_0xbb58('0x53');}utils[_0xbb58('0x2')](util[_0xbb58('0x3')]('[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s',_0x5b6508[_0xbb58('0x4')],agents[_0x5b6508['uniqueid']]['membername'],agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x20')],agents[_0x5b6508[_0xbb58('0x4')]]['lastevent']));writeDB(agents[_0x5b6508[_0xbb58('0x4')]]);var _0x3d4750=unanswered[_0xbb58('0x54')](_0x5b6508[_0xbb58('0x4')]);if(_0x3d4750>-0x1){unanswered['splice'](_0x3d4750,0x1);}}if(transfers[_0x5b6508[_0xbb58('0x4')]]){transfers[_0x5b6508['uniqueid']]['agentcomplete']=!![];transfers[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x36')]=utils[_0xbb58('0x1f')]();transfers[_0x5b6508['uniqueid']]['talktime']=utils[_0xbb58('0x35')](transfers[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x36')],transfers[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x2c')]);transfers[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x20')]=_0xbb58('0x55');transfers[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x9')]=_0xbb58('0x37');utils['info'](util['format'](_0xbb58('0x56'),_0x5b6508[_0xbb58('0x4')],transfers[_0x5b6508[_0xbb58('0x4')]]['membername'],transfers[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x20')],transfers[_0x5b6508[_0xbb58('0x4')]]['lastevent']));writeDB(transfers[_0x5b6508[_0xbb58('0x4')]],!![]);}if(agents[_0x5b6508['uniqueid']]&&agents[_0x5b6508[_0xbb58('0x4')]]['agentconnectAt']){agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0xe')]=!![];agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x36')]=utils[_0xbb58('0x1f')]();agents[_0x5b6508[_0xbb58('0x4')]]['talktime']=utils['diffTime'](agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x36')],agents[_0x5b6508['uniqueid']][_0xbb58('0x2c')]);agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x20')]=agents[_0x5b6508['uniqueid']][_0xbb58('0x3c')]?'transfer':_0xbb58('0x55');agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x9')]=_0xbb58('0x37');utils[_0xbb58('0x2')](util[_0xbb58('0x3')](_0xbb58('0x56'),_0x5b6508['uniqueid'],agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x6')],agents[_0x5b6508[_0xbb58('0x4')]]['reason'],agents[_0x5b6508[_0xbb58('0x4')]][_0xbb58('0x9')]));writeDB(agents[_0x5b6508['uniqueid']]);}}catch(_0x4cc297){utils[_0xbb58('0x19')](util[_0xbb58('0x3')](_0xbb58('0x57'),_0x5b6508['uniqueid']),_0x4cc297);}};
\ No newline at end of file