Built motion from commit fe909640.|2.6.8
[motion2.git] / server / services / xdr / agents.controller.js
index b9fe266..1f386b9 100644 (file)
@@ -15,4 +15,4 @@
 // * treaties. The SOFTWARE PRODUCT is licensed, not sold.                        *
 // *                                                                       *
 // *************************************************************************
-var _0x8eea=['ringtime','talktime','push','queuecallerabandon','includes','[%s][agents][queuecallerabandon]','[%s][agents][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned','reason','agentconnect','[%s][agents][agentconnect]','agentconnectAt','connect','answered_elsewhere','answeredelsewheredestinationuniqueid','answeredelsewheremembername','[%s][agents][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agentcompleteAt','complete','blindtransfer','transfereruniqueid','[%s][agents][blindtransfer]\x20agent:%s\x20transferuniqueid:%s','transferexten','extension','[%s][agents][blindtransfer]','attendedtransfer','[%s][agents][attendedtransfer]','origtransfereruniqueid','origtransfererlinkedid','transfer','secondtransfereruniqueid','ATTENDED','origtransfererexten','transferuniqueid','transfereeuniqueid','agententerreason','clone','calleridname','secondtransfererlinkedid','[%s][agents][attendedtransfer]\x20agent:%s','transfertype','transfertargetuniqueid','cause','rejected','indexOf','splice','agent','[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s','diffTime','[%s][agents][hangup]','lodash','info','format','uniqueid','queue','membername','interface','calleridnum','connectedlinenum','lastevent','getVoiceQueueByName','type','agentacw','agentcomplete','acw','acwtime','request','destuniqueid','agentcalled','debug','[%s][agents][agentcalled]','agentcalledAt','now','connectedlinename','[%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','timeout','holdtime'];(function(_0x4fce90,_0x2231cc){var _0x1b884b=function(_0x3faf5f){while(--_0x3faf5f){_0x4fce90['push'](_0x4fce90['shift']());}};_0x1b884b(++_0x2231cc);}(_0x8eea,0x83));var _0xa8ee=function(_0x1deee5,_0x1d4485){_0x1deee5=_0x1deee5-0x0;var _0x1d6c3a=_0x8eea[_0x1deee5];return _0x1d6c3a;};'use strict';var _=require(_0xa8ee('0x0'));var util=require('util');var utils=require('./utils');var agents={};var transfers={};var unanswered=[];function writeDB(_0x154431,_0x2f773d){utils[_0xa8ee('0x1')](util[_0xa8ee('0x2')]('[%s][agents][writeDB]\x20channel:%s\x20queue:%s\x20agent:%s\x20interface:%s\x20calleridnum:%s\x20connectedlinenum:%s\x20lastevent:%s',_0x154431[_0xa8ee('0x3')],_0x154431['channel'],_0x154431[_0xa8ee('0x4')],_0x154431[_0xa8ee('0x5')],_0x154431[_0xa8ee('0x6')],_0x154431[_0xa8ee('0x7')],_0x154431[_0xa8ee('0x8')],_0x154431[_0xa8ee('0x9')]));if(_0x154431[_0xa8ee('0x4')]){utils[_0xa8ee('0xa')](_0x154431['queue'])['then'](function(_0x591e08){if(_0x591e08){_0x154431['type']=_0x591e08[_0xa8ee('0xb')];_0x154431[_0xa8ee('0xc')]=_0x154431[_0xa8ee('0xd')]?_0x591e08[_0xa8ee('0xe')]:![];_0x154431[_0xa8ee('0xf')]=_0x154431[_0xa8ee('0xc')]?_0x591e08['acwTimeout']:0x0;}utils['request']('CreateVoiceAgentReport',_0x154431);});}else{utils[_0xa8ee('0x10')]('CreateVoiceAgentReport',_0x154431);}if(_0x2f773d){delete transfers[_0x154431[_0xa8ee('0x3')]];}else{delete agents[_0x154431[_0xa8ee('0x11')]];}}exports[_0xa8ee('0x12')]=function(_0x416f17){try{utils[_0xa8ee('0x13')](util[_0xa8ee('0x2')](_0xa8ee('0x14'),_0x416f17[_0xa8ee('0x3')]),_0x416f17);agents[_0x416f17['destuniqueid']]=_0x416f17;agents[_0x416f17[_0xa8ee('0x11')]][_0xa8ee('0x15')]=utils[_0xa8ee('0x16')]();agents[_0x416f17['destuniqueid']][_0xa8ee('0x9')]='called';agents[_0x416f17[_0xa8ee('0x11')]][_0xa8ee('0x8')]=null;agents[_0x416f17[_0xa8ee('0x11')]][_0xa8ee('0x17')]=null;utils[_0xa8ee('0x1')](util[_0xa8ee('0x2')](_0xa8ee('0x18'),_0x416f17[_0xa8ee('0x3')],agents[_0x416f17[_0xa8ee('0x11')]][_0xa8ee('0x5')],_0x416f17[_0xa8ee('0x11')]));}catch(_0x493906){utils[_0xa8ee('0x19')](util[_0xa8ee('0x2')]('[%s][agents][agentcalled]',_0x416f17[_0xa8ee('0x3')]),_0x493906);}};exports[_0xa8ee('0x1a')]=function(_0x2ec02b){try{if(!_[_0xa8ee('0x1b')](agents[_0x2ec02b[_0xa8ee('0x11')]])){utils[_0xa8ee('0x13')](util[_0xa8ee('0x2')](_0xa8ee('0x1c'),_0x2ec02b['uniqueid']),_0x2ec02b);utils[_0xa8ee('0x1')](util[_0xa8ee('0x2')](_0xa8ee('0x1d'),_0x2ec02b[_0xa8ee('0x3')],agents[_0x2ec02b[_0xa8ee('0x11')]][_0xa8ee('0x5')],_0x2ec02b['destuniqueid']));agents[_0x2ec02b[_0xa8ee('0x11')]][_0xa8ee('0x1a')]=!![];agents[_0x2ec02b[_0xa8ee('0x11')]][_0xa8ee('0x1e')]=utils[_0xa8ee('0x16')]();agents[_0x2ec02b[_0xa8ee('0x11')]][_0xa8ee('0x9')]=_0xa8ee('0x1f');agents[_0x2ec02b['destuniqueid']]['reason']=_0xa8ee('0x1f');agents[_0x2ec02b[_0xa8ee('0x11')]][_0xa8ee('0x20')]=_0x2ec02b[_0xa8ee('0x21')]?parseInt(_0x2ec02b['ringtime'])/0x3e8:0x0;agents[_0x2ec02b['destuniqueid']][_0xa8ee('0x22')]=0x0;unanswered[_0xa8ee('0x23')](_0x2ec02b['destuniqueid']);}}catch(_0x3614cb){utils['error'](util['format'](_0xa8ee('0x1c'),_0x2ec02b[_0xa8ee('0x3')]),_0x3614cb);}};exports[_0xa8ee('0x24')]=function(_0xf7b569){try{_['forIn'](agents,function(_0x3ed2d4,_0x340705){if(_0x3ed2d4['uniqueid']==_0xf7b569['uniqueid']&&!_[_0xa8ee('0x25')](unanswered,_0x3ed2d4['destuniqueid'])){utils[_0xa8ee('0x13')](util[_0xa8ee('0x2')](_0xa8ee('0x26'),_0xf7b569[_0xa8ee('0x3')]),_0xf7b569);utils[_0xa8ee('0x1')](util[_0xa8ee('0x2')](_0xa8ee('0x27'),_0xf7b569[_0xa8ee('0x3')],_0x3ed2d4['membername'],_0x3ed2d4[_0xa8ee('0x11')]));_0x3ed2d4[_0xa8ee('0x1a')]=!![];_0x3ed2d4[_0xa8ee('0x1e')]=utils['now']();_0x3ed2d4['lastevent']='abandoned';_0x3ed2d4[_0xa8ee('0x28')]='abandoned';_0x3ed2d4[_0xa8ee('0x20')]=_0xf7b569[_0xa8ee('0x20')];_0x3ed2d4['talktime']=0x0;writeDB(_0x3ed2d4);}});}catch(_0x4b0148){utils['error'](util[_0xa8ee('0x2')](_0xa8ee('0x26'),_0xf7b569['uniqueid']),_0x4b0148);}};exports[_0xa8ee('0x29')]=function(_0x3854bb){try{if(agents[_0x3854bb[_0xa8ee('0x11')]]){utils[_0xa8ee('0x13')](util[_0xa8ee('0x2')](_0xa8ee('0x2a'),_0x3854bb[_0xa8ee('0x3')]),_0x3854bb);utils[_0xa8ee('0x1')](util[_0xa8ee('0x2')]('[%s][agents][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect',_0x3854bb[_0xa8ee('0x3')],agents[_0x3854bb[_0xa8ee('0x11')]]['membername'],_0x3854bb[_0xa8ee('0x11')]));agents[_0x3854bb['destuniqueid']][_0xa8ee('0x2b')]=utils['now']();agents[_0x3854bb[_0xa8ee('0x11')]]['connectedlinenum']=_0x3854bb[_0xa8ee('0x8')];agents[_0x3854bb[_0xa8ee('0x11')]]['connectedlinename']=_0x3854bb[_0xa8ee('0x17')];agents[_0x3854bb[_0xa8ee('0x11')]]['holdtime']=_0x3854bb[_0xa8ee('0x21')];agents[_0x3854bb[_0xa8ee('0x11')]][_0xa8ee('0x9')]=_0xa8ee('0x2c');_['forIn'](agents,function(_0x17c32b,_0x2905ea){if(_0x17c32b['destuniqueid']!=_0x3854bb[_0xa8ee('0x11')]&&_0x17c32b[_0xa8ee('0x3')]==_0x3854bb[_0xa8ee('0x3')]){_0x17c32b['talktime']=0x0;_0x17c32b[_0xa8ee('0x20')]=_0x3854bb[_0xa8ee('0x21')];_0x17c32b[_0xa8ee('0x1a')]=!![];_0x17c32b['agentringnoanswerAt']=utils['now']();_0x17c32b[_0xa8ee('0x9')]='answered_elsewhere';_0x17c32b['reason']=_0xa8ee('0x2d');_0x17c32b[_0xa8ee('0x2e')]=_0x3854bb[_0xa8ee('0x11')];_0x17c32b[_0xa8ee('0x2f')]=_0x3854bb[_0xa8ee('0x5')];writeDB(_0x17c32b);}});}}catch(_0x5848e6){utils[_0xa8ee('0x19')](util[_0xa8ee('0x2')](_0xa8ee('0x2a'),_0x3854bb['uniqueid']),_0x5848e6);}};exports[_0xa8ee('0xd')]=function(_0x1a26e4){try{if(!_['isNil'](agents[_0x1a26e4[_0xa8ee('0x11')]])){utils[_0xa8ee('0x13')](util[_0xa8ee('0x2')]('[%s][agents][agentcomplete]',_0x1a26e4['uniqueid']),_0x1a26e4);utils['info'](util[_0xa8ee('0x2')](_0xa8ee('0x30'),_0x1a26e4['uniqueid'],agents[_0x1a26e4[_0xa8ee('0x11')]][_0xa8ee('0x5')],_0x1a26e4['destuniqueid']));agents[_0x1a26e4[_0xa8ee('0x11')]][_0xa8ee('0xd')]=!![];agents[_0x1a26e4[_0xa8ee('0x11')]][_0xa8ee('0x31')]=utils[_0xa8ee('0x16')]();agents[_0x1a26e4[_0xa8ee('0x11')]][_0xa8ee('0x22')]=utils['diffTime'](agents[_0x1a26e4[_0xa8ee('0x11')]][_0xa8ee('0x31')],agents[_0x1a26e4['destuniqueid']][_0xa8ee('0x2b')]);agents[_0x1a26e4[_0xa8ee('0x11')]][_0xa8ee('0x28')]=_0x1a26e4[_0xa8ee('0x28')];agents[_0x1a26e4[_0xa8ee('0x11')]][_0xa8ee('0x9')]=_0xa8ee('0x32');writeDB(agents[_0x1a26e4[_0xa8ee('0x11')]]);}}catch(_0xb09bd8){utils[_0xa8ee('0x19')](util[_0xa8ee('0x2')]('[%s][agents][agentcomplete]',_0x1a26e4['uniqueid']),_0xb09bd8);}};exports[_0xa8ee('0x33')]=function(_0x93afa2){try{if(!_[_0xa8ee('0x1b')](agents[_0x93afa2[_0xa8ee('0x34')]])){utils[_0xa8ee('0x13')](util[_0xa8ee('0x2')]('[%s][agents][blindtransfer]',_0x93afa2['uniqueid']),_0x93afa2);utils[_0xa8ee('0x1')](util['format'](_0xa8ee('0x35'),_0x93afa2[_0xa8ee('0x3')],agents[_0x93afa2[_0xa8ee('0x34')]][_0xa8ee('0x5')],agents[_0x93afa2['transfereruniqueid']][_0xa8ee('0x3')]));agents[_0x93afa2[_0xa8ee('0x34')]]['transfer']=!![];agents[_0x93afa2[_0xa8ee('0x34')]]['transfertype']='blind';agents[_0x93afa2[_0xa8ee('0x34')]][_0xa8ee('0x36')]=_0x93afa2[_0xa8ee('0x37')];agents[_0x93afa2[_0xa8ee('0x34')]]['transferuniqueid']=agents[_0x93afa2['transfereruniqueid']]['uniqueid'];}}catch(_0x2f6890){utils[_0xa8ee('0x19')](util[_0xa8ee('0x2')](_0xa8ee('0x38'),_0x93afa2['uniqueid']),_0x2f6890);}};exports[_0xa8ee('0x39')]=function(_0x9db64b){try{utils['debug'](util[_0xa8ee('0x2')](_0xa8ee('0x3a'),_0x9db64b[_0xa8ee('0x3b')]),_0x9db64b);if(_0x9db64b[_0xa8ee('0x3b')]==_0x9db64b[_0xa8ee('0x3c')]){if(!_[_0xa8ee('0x1b')](agents[_0x9db64b['secondtransfereruniqueid']])){utils[_0xa8ee('0x1')](util[_0xa8ee('0x2')]('[%s][agents][attendedtransfer]\x20agent:%s',_0x9db64b['origtransfereruniqueid'],agents[_0x9db64b['secondtransfereruniqueid']][_0xa8ee('0x5')]));agents[_0x9db64b['secondtransfereruniqueid']][_0xa8ee('0x3d')]=!![];agents[_0x9db64b[_0xa8ee('0x3e')]]['transfertype']=_0xa8ee('0x3f');agents[_0x9db64b['secondtransfereruniqueid']][_0xa8ee('0x36')]=_0x9db64b[_0xa8ee('0x40')];agents[_0x9db64b[_0xa8ee('0x3e')]][_0xa8ee('0x41')]=_0x9db64b[_0xa8ee('0x3b')];}if(_0x9db64b[_0xa8ee('0x42')]&&agents[_0x9db64b[_0xa8ee('0x42')]]){agents[_0x9db64b[_0xa8ee('0x42')]][_0xa8ee('0x43')]=0x1;transfers[_0x9db64b[_0xa8ee('0x42')]]=_[_0xa8ee('0x44')](agents[_0x9db64b[_0xa8ee('0x42')]]);transfers[_0x9db64b[_0xa8ee('0x42')]][_0xa8ee('0x7')]=agents[_0x9db64b[_0xa8ee('0x3e')]][_0xa8ee('0x7')];transfers[_0x9db64b[_0xa8ee('0x42')]][_0xa8ee('0x45')]=agents[_0x9db64b[_0xa8ee('0x3e')]][_0xa8ee('0x45')];transfers[_0x9db64b[_0xa8ee('0x42')]][_0xa8ee('0x15')]=utils[_0xa8ee('0x16')]();transfers[_0x9db64b['transfereeuniqueid']][_0xa8ee('0x2b')]=utils[_0xa8ee('0x16')]();transfers[_0x9db64b[_0xa8ee('0x42')]]['holdtime']=0x0;transfers[_0x9db64b[_0xa8ee('0x42')]][_0xa8ee('0x43')]=0x2;}}else if(_0x9db64b[_0xa8ee('0x3e')]==_0x9db64b[_0xa8ee('0x46')]){if(!_[_0xa8ee('0x1b')](agents[_0x9db64b[_0xa8ee('0x3b')]])){utils[_0xa8ee('0x1')](util[_0xa8ee('0x2')](_0xa8ee('0x47'),_0x9db64b[_0xa8ee('0x3b')],agents[_0x9db64b[_0xa8ee('0x3b')]][_0xa8ee('0x5')]));agents[_0x9db64b[_0xa8ee('0x3b')]][_0xa8ee('0x3d')]=!![];agents[_0x9db64b[_0xa8ee('0x3b')]][_0xa8ee('0x48')]=_0xa8ee('0x3f');agents[_0x9db64b[_0xa8ee('0x3b')]][_0xa8ee('0x36')]=_0x9db64b['secondtransfererexten'];agents[_0x9db64b[_0xa8ee('0x3b')]][_0xa8ee('0x41')]=_0x9db64b['secondtransfereruniqueid'];}if(_0x9db64b[_0xa8ee('0x49')]&&agents[_0x9db64b['transfertargetuniqueid']]){agents[_0x9db64b[_0xa8ee('0x49')]][_0xa8ee('0x43')]=0x1;transfers[_0x9db64b[_0xa8ee('0x49')]]=_['clone'](agents[_0x9db64b[_0xa8ee('0x49')]]);transfers[_0x9db64b[_0xa8ee('0x49')]][_0xa8ee('0x7')]=agents[_0x9db64b[_0xa8ee('0x3b')]][_0xa8ee('0x7')];transfers[_0x9db64b[_0xa8ee('0x49')]]['calleridname']=agents[_0x9db64b[_0xa8ee('0x3b')]]['calleridname'];transfers[_0x9db64b[_0xa8ee('0x49')]][_0xa8ee('0x15')]=utils['now']();transfers[_0x9db64b['transfertargetuniqueid']]['agentconnectAt']=utils[_0xa8ee('0x16')]();transfers[_0x9db64b['transfertargetuniqueid']][_0xa8ee('0x20')]=0x0;transfers[_0x9db64b[_0xa8ee('0x49')]][_0xa8ee('0x43')]=0x2;}}}catch(_0x5a5358){utils[_0xa8ee('0x19')](util[_0xa8ee('0x2')](_0xa8ee('0x3a'),_0x9db64b[_0xa8ee('0x3b')]),_0x5a5358);}};exports['hangup']=function(_0x1bb228){try{utils[_0xa8ee('0x13')](util[_0xa8ee('0x2')]('[%s][agents][hangup]',_0x1bb228['uniqueid']),_0x1bb228);if(agents[_0x1bb228[_0xa8ee('0x3')]]&&agents[_0x1bb228['uniqueid']][_0xa8ee('0x28')]===_0xa8ee('0x1f')){if(_0x1bb228[_0xa8ee('0x4a')]==='21'){agents[_0x1bb228[_0xa8ee('0x3')]]['reason']=_0xa8ee('0x4b');agents[_0x1bb228[_0xa8ee('0x3')]]['lastevent']=_0xa8ee('0x4b');}utils['info'](util[_0xa8ee('0x2')]('[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s',_0x1bb228[_0xa8ee('0x3')],agents[_0x1bb228[_0xa8ee('0x3')]]['membername'],agents[_0x1bb228[_0xa8ee('0x3')]]['reason'],agents[_0x1bb228['uniqueid']]['lastevent']));writeDB(agents[_0x1bb228[_0xa8ee('0x3')]]);var _0x2c4a4e=unanswered[_0xa8ee('0x4c')](_0x1bb228[_0xa8ee('0x3')]);if(_0x2c4a4e>-0x1){unanswered[_0xa8ee('0x4d')](_0x2c4a4e,0x1);}}if(transfers[_0x1bb228['uniqueid']]){transfers[_0x1bb228[_0xa8ee('0x3')]]['agentcomplete']=!![];transfers[_0x1bb228[_0xa8ee('0x3')]]['agentcompleteAt']=utils['now']();transfers[_0x1bb228['uniqueid']][_0xa8ee('0x22')]=utils['diffTime'](transfers[_0x1bb228[_0xa8ee('0x3')]][_0xa8ee('0x31')],transfers[_0x1bb228['uniqueid']][_0xa8ee('0x2b')]);transfers[_0x1bb228['uniqueid']][_0xa8ee('0x28')]=_0xa8ee('0x4e');transfers[_0x1bb228['uniqueid']]['lastevent']='complete';utils[_0xa8ee('0x1')](util[_0xa8ee('0x2')](_0xa8ee('0x4f'),_0x1bb228[_0xa8ee('0x3')],transfers[_0x1bb228[_0xa8ee('0x3')]][_0xa8ee('0x5')],transfers[_0x1bb228['uniqueid']]['reason'],transfers[_0x1bb228[_0xa8ee('0x3')]][_0xa8ee('0x9')]));writeDB(transfers[_0x1bb228[_0xa8ee('0x3')]],!![]);}if(agents[_0x1bb228[_0xa8ee('0x3')]]&&agents[_0x1bb228[_0xa8ee('0x3')]]['agentconnectAt']){agents[_0x1bb228[_0xa8ee('0x3')]]['agentcomplete']=!![];agents[_0x1bb228[_0xa8ee('0x3')]][_0xa8ee('0x31')]=utils[_0xa8ee('0x16')]();agents[_0x1bb228['uniqueid']][_0xa8ee('0x22')]=utils[_0xa8ee('0x50')](agents[_0x1bb228[_0xa8ee('0x3')]][_0xa8ee('0x31')],agents[_0x1bb228[_0xa8ee('0x3')]]['agentconnectAt']);agents[_0x1bb228[_0xa8ee('0x3')]][_0xa8ee('0x28')]=agents[_0x1bb228['uniqueid']][_0xa8ee('0x3d')]?_0xa8ee('0x3d'):_0xa8ee('0x4e');agents[_0x1bb228[_0xa8ee('0x3')]][_0xa8ee('0x9')]='complete';utils[_0xa8ee('0x1')](util['format'](_0xa8ee('0x4f'),_0x1bb228[_0xa8ee('0x3')],agents[_0x1bb228[_0xa8ee('0x3')]][_0xa8ee('0x5')],agents[_0x1bb228['uniqueid']][_0xa8ee('0x28')],agents[_0x1bb228['uniqueid']]['lastevent']));writeDB(agents[_0x1bb228['uniqueid']]);}}catch(_0x571488){utils[_0xa8ee('0x19')](util[_0xa8ee('0x2')](_0xa8ee('0x51'),_0x1bb228[_0xa8ee('0x3')]),_0x571488);}};
\ No newline at end of file
+var _0x3c81=['CreateVoiceAgentReport','destuniqueid','agentcalled','debug','[%s][agents][agentcalled]','agentcalledAt','called','connectedlinename','info','format','[%s][agents][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called','uniqueid','error','agentringnoanswer','[%s][agents][agentringnoanswer]','[%s][agents][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:timeout','now','reason','holdtime','talktime','push','queuecallerabandon','forIn','[%s][agents][queuecallerabandon]','[%s][agents][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned','agentringnoanswerAt','abandoned','agentconnect','[%s][agents][agentconnect]','[%s][agents][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect','agentconnectAt','ringtime','connect','answered_elsewhere','answeredelsewheredestinationuniqueid','answeredelsewheremembername','[%s][agents][agentcomplete]','[%s][agents][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agentcompleteAt','diffTime','complete','blindtransfer','transfereruniqueid','[%s][agents][blindtransfer]','[%s][agents][blindtransfer]\x20agent:%s\x20transferuniqueid:%s','transfer','transfertype','blind','transferexten','extension','attendedtransfer','[%s][agents][attendedtransfer]','origtransfereruniqueid','origtransfererlinkedid','secondtransfereruniqueid','[%s][agents][attendedtransfer]\x20agent:%s','origtransfererexten','transferuniqueid','transfereeuniqueid','clone','calleridname','agententerreason','secondtransfererlinkedid','isNil','ATTENDED','secondtransfererexten','transfertargetuniqueid','[%s][agents][hangup]','timeout','cause','rejected','[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s','splice','agent','lodash','util','channel','queue','membername','interface','calleridnum','connectedlinenum','lastevent','getVoiceQueueByName','then','type','agentacw','agentcomplete','acw','acwtime','acwTimeout','request'];(function(_0x2ce79b,_0xea50d9){var _0x29ad90=function(_0x5a3925){while(--_0x5a3925){_0x2ce79b['push'](_0x2ce79b['shift']());}};_0x29ad90(++_0xea50d9);}(_0x3c81,0x102));var _0x13c8=function(_0x97210,_0x452081){_0x97210=_0x97210-0x0;var _0x3e860b=_0x3c81[_0x97210];return _0x3e860b;};'use strict';var _=require(_0x13c8('0x0'));var util=require(_0x13c8('0x1'));var utils=require('./utils');var agents={};var transfers={};var unanswered=[];function writeDB(_0x252f26,_0x131d0b){utils['info'](util['format']('[%s][agents][writeDB]\x20channel:%s\x20queue:%s\x20agent:%s\x20interface:%s\x20calleridnum:%s\x20connectedlinenum:%s\x20lastevent:%s',_0x252f26['uniqueid'],_0x252f26[_0x13c8('0x2')],_0x252f26[_0x13c8('0x3')],_0x252f26[_0x13c8('0x4')],_0x252f26[_0x13c8('0x5')],_0x252f26[_0x13c8('0x6')],_0x252f26[_0x13c8('0x7')],_0x252f26[_0x13c8('0x8')]));if(_0x252f26['queue']){utils[_0x13c8('0x9')](_0x252f26['queue'])[_0x13c8('0xa')](function(_0x296463){if(_0x296463){_0x252f26[_0x13c8('0xb')]=_0x296463[_0x13c8('0xb')];_0x252f26[_0x13c8('0xc')]=_0x252f26[_0x13c8('0xd')]?_0x296463[_0x13c8('0xe')]:![];_0x252f26[_0x13c8('0xf')]=_0x252f26[_0x13c8('0xc')]?_0x296463[_0x13c8('0x10')]:0x0;}utils[_0x13c8('0x11')](_0x13c8('0x12'),_0x252f26);});}else{utils[_0x13c8('0x11')](_0x13c8('0x12'),_0x252f26);}if(_0x131d0b){delete transfers[_0x252f26['uniqueid']];}else{delete agents[_0x252f26[_0x13c8('0x13')]];}}exports[_0x13c8('0x14')]=function(_0x2304b5){try{utils[_0x13c8('0x15')](util['format'](_0x13c8('0x16'),_0x2304b5['uniqueid']),_0x2304b5);agents[_0x2304b5['destuniqueid']]=_0x2304b5;agents[_0x2304b5['destuniqueid']][_0x13c8('0x17')]=utils['now']();agents[_0x2304b5[_0x13c8('0x13')]][_0x13c8('0x8')]=_0x13c8('0x18');agents[_0x2304b5[_0x13c8('0x13')]]['connectedlinenum']=null;agents[_0x2304b5[_0x13c8('0x13')]][_0x13c8('0x19')]=null;utils[_0x13c8('0x1a')](util[_0x13c8('0x1b')](_0x13c8('0x1c'),_0x2304b5[_0x13c8('0x1d')],agents[_0x2304b5[_0x13c8('0x13')]][_0x13c8('0x4')],_0x2304b5[_0x13c8('0x13')]));}catch(_0x31d122){utils[_0x13c8('0x1e')](util['format'](_0x13c8('0x16'),_0x2304b5[_0x13c8('0x1d')]),_0x31d122);}};exports[_0x13c8('0x1f')]=function(_0x313ea3){try{if(!_['isNil'](agents[_0x313ea3[_0x13c8('0x13')]])){utils[_0x13c8('0x15')](util[_0x13c8('0x1b')](_0x13c8('0x20'),_0x313ea3[_0x13c8('0x1d')]),_0x313ea3);utils[_0x13c8('0x1a')](util['format'](_0x13c8('0x21'),_0x313ea3[_0x13c8('0x1d')],agents[_0x313ea3[_0x13c8('0x13')]][_0x13c8('0x4')],_0x313ea3['destuniqueid']));agents[_0x313ea3[_0x13c8('0x13')]][_0x13c8('0x1f')]=!![];agents[_0x313ea3['destuniqueid']]['agentringnoanswerAt']=utils[_0x13c8('0x22')]();agents[_0x313ea3[_0x13c8('0x13')]]['lastevent']='timeout';agents[_0x313ea3[_0x13c8('0x13')]][_0x13c8('0x23')]='timeout';agents[_0x313ea3['destuniqueid']][_0x13c8('0x24')]=_0x313ea3['ringtime']?parseInt(_0x313ea3['ringtime'])/0x3e8:0x0;agents[_0x313ea3[_0x13c8('0x13')]][_0x13c8('0x25')]=0x0;unanswered[_0x13c8('0x26')](_0x313ea3['destuniqueid']);}}catch(_0x5ef2f7){utils[_0x13c8('0x1e')](util[_0x13c8('0x1b')](_0x13c8('0x20'),_0x313ea3[_0x13c8('0x1d')]),_0x5ef2f7);}};exports[_0x13c8('0x27')]=function(_0x220d40){try{_[_0x13c8('0x28')](agents,function(_0x4a1b9c,_0x109cb8){if(_0x4a1b9c[_0x13c8('0x1d')]==_0x220d40['uniqueid']&&!_['includes'](unanswered,_0x4a1b9c[_0x13c8('0x13')])){utils[_0x13c8('0x15')](util['format'](_0x13c8('0x29'),_0x220d40[_0x13c8('0x1d')]),_0x220d40);utils['info'](util[_0x13c8('0x1b')](_0x13c8('0x2a'),_0x220d40[_0x13c8('0x1d')],_0x4a1b9c[_0x13c8('0x4')],_0x4a1b9c[_0x13c8('0x13')]));_0x4a1b9c[_0x13c8('0x1f')]=!![];_0x4a1b9c[_0x13c8('0x2b')]=utils[_0x13c8('0x22')]();_0x4a1b9c['lastevent']='abandoned';_0x4a1b9c[_0x13c8('0x23')]=_0x13c8('0x2c');_0x4a1b9c['holdtime']=_0x220d40[_0x13c8('0x24')];_0x4a1b9c['talktime']=0x0;writeDB(_0x4a1b9c);}});}catch(_0x1fdf7d){utils['error'](util[_0x13c8('0x1b')](_0x13c8('0x29'),_0x220d40[_0x13c8('0x1d')]),_0x1fdf7d);}};exports[_0x13c8('0x2d')]=function(_0x2039e7){try{if(agents[_0x2039e7[_0x13c8('0x13')]]){utils[_0x13c8('0x15')](util['format'](_0x13c8('0x2e'),_0x2039e7[_0x13c8('0x1d')]),_0x2039e7);utils['info'](util[_0x13c8('0x1b')](_0x13c8('0x2f'),_0x2039e7[_0x13c8('0x1d')],agents[_0x2039e7['destuniqueid']]['membername'],_0x2039e7['destuniqueid']));agents[_0x2039e7[_0x13c8('0x13')]][_0x13c8('0x30')]=utils[_0x13c8('0x22')]();agents[_0x2039e7[_0x13c8('0x13')]][_0x13c8('0x7')]=_0x2039e7[_0x13c8('0x7')];agents[_0x2039e7[_0x13c8('0x13')]][_0x13c8('0x19')]=_0x2039e7[_0x13c8('0x19')];agents[_0x2039e7['destuniqueid']]['holdtime']=_0x2039e7[_0x13c8('0x31')];agents[_0x2039e7[_0x13c8('0x13')]][_0x13c8('0x8')]=_0x13c8('0x32');_['forIn'](agents,function(_0x35e1e7,_0x4bd627){if(_0x35e1e7[_0x13c8('0x13')]!=_0x2039e7[_0x13c8('0x13')]&&_0x35e1e7[_0x13c8('0x1d')]==_0x2039e7[_0x13c8('0x1d')]){_0x35e1e7[_0x13c8('0x25')]=0x0;_0x35e1e7[_0x13c8('0x24')]=_0x2039e7[_0x13c8('0x31')];_0x35e1e7[_0x13c8('0x1f')]=!![];_0x35e1e7[_0x13c8('0x2b')]=utils[_0x13c8('0x22')]();_0x35e1e7[_0x13c8('0x8')]=_0x13c8('0x33');_0x35e1e7[_0x13c8('0x23')]=_0x13c8('0x33');_0x35e1e7[_0x13c8('0x34')]=_0x2039e7[_0x13c8('0x13')];_0x35e1e7[_0x13c8('0x35')]=_0x2039e7[_0x13c8('0x4')];writeDB(_0x35e1e7);}});}}catch(_0xc5eb86){utils[_0x13c8('0x1e')](util[_0x13c8('0x1b')](_0x13c8('0x2e'),_0x2039e7[_0x13c8('0x1d')]),_0xc5eb86);}};exports[_0x13c8('0xd')]=function(_0x44ee66){try{if(!_['isNil'](agents[_0x44ee66[_0x13c8('0x13')]])){utils[_0x13c8('0x15')](util[_0x13c8('0x1b')](_0x13c8('0x36'),_0x44ee66[_0x13c8('0x1d')]),_0x44ee66);utils['info'](util['format'](_0x13c8('0x37'),_0x44ee66[_0x13c8('0x1d')],agents[_0x44ee66[_0x13c8('0x13')]]['membername'],_0x44ee66['destuniqueid']));agents[_0x44ee66['destuniqueid']][_0x13c8('0xd')]=!![];agents[_0x44ee66['destuniqueid']][_0x13c8('0x38')]=utils['now']();agents[_0x44ee66[_0x13c8('0x13')]][_0x13c8('0x25')]=utils[_0x13c8('0x39')](agents[_0x44ee66[_0x13c8('0x13')]][_0x13c8('0x38')],agents[_0x44ee66[_0x13c8('0x13')]]['agentconnectAt']);agents[_0x44ee66[_0x13c8('0x13')]][_0x13c8('0x23')]=_0x44ee66['reason'];agents[_0x44ee66[_0x13c8('0x13')]][_0x13c8('0x8')]=_0x13c8('0x3a');writeDB(agents[_0x44ee66[_0x13c8('0x13')]]);}}catch(_0x38486a){utils['error'](util[_0x13c8('0x1b')](_0x13c8('0x36'),_0x44ee66[_0x13c8('0x1d')]),_0x38486a);}};exports[_0x13c8('0x3b')]=function(_0x185d18){try{if(!_['isNil'](agents[_0x185d18[_0x13c8('0x3c')]])){utils[_0x13c8('0x15')](util[_0x13c8('0x1b')](_0x13c8('0x3d'),_0x185d18[_0x13c8('0x1d')]),_0x185d18);utils[_0x13c8('0x1a')](util[_0x13c8('0x1b')](_0x13c8('0x3e'),_0x185d18[_0x13c8('0x1d')],agents[_0x185d18[_0x13c8('0x3c')]][_0x13c8('0x4')],agents[_0x185d18['transfereruniqueid']][_0x13c8('0x1d')]));agents[_0x185d18[_0x13c8('0x3c')]][_0x13c8('0x3f')]=!![];agents[_0x185d18[_0x13c8('0x3c')]][_0x13c8('0x40')]=_0x13c8('0x41');agents[_0x185d18['transfereruniqueid']][_0x13c8('0x42')]=_0x185d18[_0x13c8('0x43')];agents[_0x185d18[_0x13c8('0x3c')]]['transferuniqueid']=agents[_0x185d18['transfereruniqueid']][_0x13c8('0x1d')];}}catch(_0x14a738){utils['error'](util[_0x13c8('0x1b')](_0x13c8('0x3d'),_0x185d18['uniqueid']),_0x14a738);}};exports[_0x13c8('0x44')]=function(_0x554792){try{utils[_0x13c8('0x15')](util[_0x13c8('0x1b')](_0x13c8('0x45'),_0x554792['origtransfereruniqueid']),_0x554792);if(_0x554792[_0x13c8('0x46')]==_0x554792[_0x13c8('0x47')]){if(!_['isNil'](agents[_0x554792[_0x13c8('0x48')]])){utils['info'](util[_0x13c8('0x1b')](_0x13c8('0x49'),_0x554792[_0x13c8('0x46')],agents[_0x554792[_0x13c8('0x48')]][_0x13c8('0x4')]));agents[_0x554792['secondtransfereruniqueid']][_0x13c8('0x3f')]=!![];agents[_0x554792['secondtransfereruniqueid']]['transfertype']='ATTENDED';agents[_0x554792['secondtransfereruniqueid']]['transferexten']=_0x554792[_0x13c8('0x4a')];agents[_0x554792[_0x13c8('0x48')]][_0x13c8('0x4b')]=_0x554792[_0x13c8('0x46')];}if(_0x554792[_0x13c8('0x4c')]&&agents[_0x554792[_0x13c8('0x4c')]]){agents[_0x554792[_0x13c8('0x4c')]]['agententerreason']=0x1;transfers[_0x554792['transfereeuniqueid']]=_[_0x13c8('0x4d')](agents[_0x554792[_0x13c8('0x4c')]]);transfers[_0x554792[_0x13c8('0x4c')]][_0x13c8('0x6')]=agents[_0x554792[_0x13c8('0x48')]][_0x13c8('0x6')];transfers[_0x554792[_0x13c8('0x4c')]][_0x13c8('0x4e')]=agents[_0x554792['secondtransfereruniqueid']][_0x13c8('0x4e')];transfers[_0x554792[_0x13c8('0x4c')]]['agentcalledAt']=utils[_0x13c8('0x22')]();transfers[_0x554792[_0x13c8('0x4c')]][_0x13c8('0x30')]=utils[_0x13c8('0x22')]();transfers[_0x554792[_0x13c8('0x4c')]][_0x13c8('0x24')]=0x0;transfers[_0x554792[_0x13c8('0x4c')]][_0x13c8('0x4f')]=0x2;}}else if(_0x554792[_0x13c8('0x48')]==_0x554792[_0x13c8('0x50')]){if(!_[_0x13c8('0x51')](agents[_0x554792[_0x13c8('0x46')]])){utils[_0x13c8('0x1a')](util[_0x13c8('0x1b')](_0x13c8('0x49'),_0x554792[_0x13c8('0x46')],agents[_0x554792['origtransfereruniqueid']][_0x13c8('0x4')]));agents[_0x554792['origtransfereruniqueid']][_0x13c8('0x3f')]=!![];agents[_0x554792[_0x13c8('0x46')]]['transfertype']=_0x13c8('0x52');agents[_0x554792[_0x13c8('0x46')]]['transferexten']=_0x554792[_0x13c8('0x53')];agents[_0x554792[_0x13c8('0x46')]][_0x13c8('0x4b')]=_0x554792[_0x13c8('0x48')];}if(_0x554792[_0x13c8('0x54')]&&agents[_0x554792[_0x13c8('0x54')]]){agents[_0x554792[_0x13c8('0x54')]][_0x13c8('0x4f')]=0x1;transfers[_0x554792[_0x13c8('0x54')]]=_[_0x13c8('0x4d')](agents[_0x554792[_0x13c8('0x54')]]);transfers[_0x554792['transfertargetuniqueid']][_0x13c8('0x6')]=agents[_0x554792[_0x13c8('0x46')]][_0x13c8('0x6')];transfers[_0x554792[_0x13c8('0x54')]][_0x13c8('0x4e')]=agents[_0x554792[_0x13c8('0x46')]]['calleridname'];transfers[_0x554792[_0x13c8('0x54')]][_0x13c8('0x17')]=utils[_0x13c8('0x22')]();transfers[_0x554792['transfertargetuniqueid']][_0x13c8('0x30')]=utils[_0x13c8('0x22')]();transfers[_0x554792[_0x13c8('0x54')]][_0x13c8('0x24')]=0x0;transfers[_0x554792[_0x13c8('0x54')]][_0x13c8('0x4f')]=0x2;}}}catch(_0x55e5ba){utils[_0x13c8('0x1e')](util[_0x13c8('0x1b')](_0x13c8('0x45'),_0x554792[_0x13c8('0x46')]),_0x55e5ba);}};exports['hangup']=function(_0x16b409){try{utils[_0x13c8('0x15')](util[_0x13c8('0x1b')](_0x13c8('0x55'),_0x16b409[_0x13c8('0x1d')]),_0x16b409);if(agents[_0x16b409[_0x13c8('0x1d')]]&&agents[_0x16b409[_0x13c8('0x1d')]]['reason']===_0x13c8('0x56')){if(_0x16b409[_0x13c8('0x57')]==='21'){agents[_0x16b409[_0x13c8('0x1d')]]['reason']=_0x13c8('0x58');agents[_0x16b409[_0x13c8('0x1d')]]['lastevent']='rejected';}utils[_0x13c8('0x1a')](util['format'](_0x13c8('0x59'),_0x16b409['uniqueid'],agents[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x4')],agents[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x23')],agents[_0x16b409[_0x13c8('0x1d')]]['lastevent']));writeDB(agents[_0x16b409[_0x13c8('0x1d')]]);var _0x2d8dfe=unanswered['indexOf'](_0x16b409[_0x13c8('0x1d')]);if(_0x2d8dfe>-0x1){unanswered[_0x13c8('0x5a')](_0x2d8dfe,0x1);}}if(transfers[_0x16b409[_0x13c8('0x1d')]]){transfers[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0xd')]=!![];transfers[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x38')]=utils[_0x13c8('0x22')]();transfers[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x25')]=utils['diffTime'](transfers[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x38')],transfers[_0x16b409['uniqueid']]['agentconnectAt']);transfers[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x23')]=_0x13c8('0x5b');transfers[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x8')]=_0x13c8('0x3a');utils['info'](util[_0x13c8('0x1b')](_0x13c8('0x59'),_0x16b409[_0x13c8('0x1d')],transfers[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x4')],transfers[_0x16b409['uniqueid']][_0x13c8('0x23')],transfers[_0x16b409[_0x13c8('0x1d')]]['lastevent']));writeDB(transfers[_0x16b409[_0x13c8('0x1d')]],!![]);}if(agents[_0x16b409[_0x13c8('0x1d')]]&&agents[_0x16b409['uniqueid']][_0x13c8('0x30')]){agents[_0x16b409['uniqueid']][_0x13c8('0xd')]=!![];agents[_0x16b409['uniqueid']][_0x13c8('0x38')]=utils[_0x13c8('0x22')]();agents[_0x16b409[_0x13c8('0x1d')]]['talktime']=utils[_0x13c8('0x39')](agents[_0x16b409['uniqueid']]['agentcompleteAt'],agents[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x30')]);agents[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x23')]=agents[_0x16b409['uniqueid']]['transfer']?_0x13c8('0x3f'):'agent';agents[_0x16b409['uniqueid']][_0x13c8('0x8')]=_0x13c8('0x3a');utils[_0x13c8('0x1a')](util[_0x13c8('0x1b')]('[%s][agents][hangup]\x20agent:%s\x20reason:%s\x20lastevent:%s',_0x16b409[_0x13c8('0x1d')],agents[_0x16b409['uniqueid']]['membername'],agents[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x23')],agents[_0x16b409[_0x13c8('0x1d')]][_0x13c8('0x8')]));writeDB(agents[_0x16b409[_0x13c8('0x1d')]]);}}catch(_0x551563){utils[_0x13c8('0x1e')](util['format'](_0x13c8('0x55'),_0x16b409['uniqueid']),_0x551563);}};
\ No newline at end of file