417e071af5bde6bc57deeed994ff731342b73026
[motion2.git] / server / services / ami / report / voiceAgentReport.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 _0x7cb6=['syncVarSet','hangup','musiconholdstart','syncMusicOnHoldStop','syncAttendedTransfer','blindtransfer','prototype','emit','isNotNull','isUndefined','uniqueid','membername','destuniqueid','debug','[%s][voiceAgentReport][agentcalled]\x20event:','inspect','interface','queue','format','YYYY-MM-DD\x20HH:mm:ss','mandatoryDisposition','type','inbound','voice','assign','omit','event','privilege','[%s][voiceAgentReport][agentcalled]\x20sending\x20agentcalled\x20event:','custom:agentcalled','variables','user:%s','[%s][voiceAgentReport][agentcalled]','hasOwnProperty','info','connectedlinename','connectedlinenum','destchannelstate','holdtime','lastevent','connect','pick','name','accountcode','exten','agentringnoanswer','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:answered_elsewhere','agentringnoanswerAt','answeredelsewheredestinationuniqueid','answeredelsewheremembername','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentansweredelsewhere\x20event:','[%s][voiceAgentReport][agentconnect]\x20Else\x20path\x20should\x20never\x20be\x20taken','error','[%s][voiceAgentReport][agentconnect]','[%s][voiceAgentReport][agentringnoanswer]\x20event:','[%s][voiceAgentReport][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:rejected','rejected','reason','[%s][voiceAgentReport][agentringnoanswer]\x20sending\x20agentringnoanswer\x20event:','user:agentringnoanswer','custom:agentringnoanswer','syncQueueCallerAbandon','[%s][voiceAgentReport][queuecallerabandon]\x20event:','abandoned','[%s][voiceAgentReport][queuecallerabandon]\x20sending\x20agentqueuecallerabandon\x20event:','custom:agentqueuecallerabandon','[%s][voiceAgentReport][queuecallerabandon]','syncAgentComplete','[%s][voiceAgentReport][agentcomplete]\x20event:','agentconnectAt','complete','transfer','agent','talktime','acw','acwtime','acwTimeout','agentacw','destconnectedlinenum','[%s][voiceAgentReport][agentcomplete]\x20sending\x20agentcomplete\x20event:','custom:agentcomplete','destaccountcode','user:agentcomplete','[%s][voiceAgentReport][agentcomplete]','keys','variable','[%s][voiceAgentReport][varset]\x20destuniqueid:%s\x20variable:%s\x20value:%s','value','rtpaudioqos','rtpaudioqosjitter','rtpaudioqosjitterbridged','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrtt','rtpaudioqosrttbridged','sipuri','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberinterface','memberlastcall','memberpenalty','memberrealtime','isNil','includes','syncHangup','[%s][voiceAgentReport][hangup]\x20destuniqueid:%s','[%s][voiceAgentReport][hangup]\x20sending\x20voiceAgentReport\x20event:','values','custom:voiceAgentReport','[%s][voiceAgentReport][hangup]','[%s][voiceAgentReport][attendedtransfer]\x20event:','transfereeuniqueid','origtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agentcompleteAt','diff','seconds','secondtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]','syncBlindTransfer','[%s][voiceAgentReport][blindtransfer]\x20event:','transfereruniqueid','syncMusicOnHoldStart','[%s][voiceAgentReport][musiconholdstart]\x20event:','channel','[%s][voiceAgentReport][musiconholdstart]\x20interface:%s','onhold','[%s][voiceAgentReport][musiconholdstart]','[%s][voiceAgentReport][musiconholdstop]\x20event:','substring','lastIndexOf','[%s][voiceAgentReport][musiconholdstop]\x20interface:%s','[%s][voiceAgentReport][musiconholdstop]','exports','lodash','moment','util','ioredis','../../../config/environment','../../../config/logger','ami','../ami','redis','defaults','localhost','channels','voiceChannels','voiceQueues','agents','agentcalled','syncAgentCalled','agentconnect','syncAgentConnect','syncAgentRingNoAnswer','queuecallerabandon','bind','agentcomplete'];(function(_0x5898c2,_0x200fcc){var _0x483123=function(_0x520796){while(--_0x520796){_0x5898c2['push'](_0x5898c2['shift']());}};_0x483123(++_0x200fcc);}(_0x7cb6,0x88));var _0x67cb=function(_0x2641f9,_0x26715f){_0x2641f9=_0x2641f9-0x0;var _0x585741=_0x7cb6[_0x2641f9];return _0x585741;};'use strict';var _=require(_0x67cb('0x0'));var moment=require(_0x67cb('0x1'));var util=require(_0x67cb('0x2'));var Redis=require(_0x67cb('0x3'));var config=require(_0x67cb('0x4'));var logger=require(_0x67cb('0x5'))(_0x67cb('0x6'));var ami=require(_0x67cb('0x7'));config[_0x67cb('0x8')]=_[_0x67cb('0x9')](config[_0x67cb('0x8')],{'host':_0x67cb('0xa'),'port':0x18eb});var io=require('socket.io-emitter')(new Redis(config['redis']));function VoiceAgentReport(_0x1892b8){this[_0x67cb('0xb')]={};this[_0x67cb('0xc')]=_0x1892b8[_0x67cb('0xb')];this[_0x67cb('0xd')]=_0x1892b8['voiceQueues'];this[_0x67cb('0xe')]=_0x1892b8[_0x67cb('0xe')];this['variables']={};ami['on'](_0x67cb('0xf'),this[_0x67cb('0x10')]['bind'](this));ami['on'](_0x67cb('0x11'),this[_0x67cb('0x12')]['bind'](this));ami['on']('agentringnoanswer',this[_0x67cb('0x13')]['bind'](this));ami['on'](_0x67cb('0x14'),this['syncQueueCallerAbandon'][_0x67cb('0x15')](this));ami['on'](_0x67cb('0x16'),this['syncAgentComplete'][_0x67cb('0x15')](this));ami['on']('varset',this[_0x67cb('0x17')]['bind'](this));ami['on'](_0x67cb('0x18'),this['syncHangup'][_0x67cb('0x15')](this));ami['on'](_0x67cb('0x19'),this['syncMusicOnHoldStart'][_0x67cb('0x15')](this));ami['on']('musiconholdstop',this[_0x67cb('0x1a')]['bind'](this));ami['on']('attendedtransfer',this[_0x67cb('0x1b')][_0x67cb('0x15')](this));ami['on'](_0x67cb('0x1c'),this['syncBlindTransfer'][_0x67cb('0x15')](this));}VoiceAgentReport[_0x67cb('0x1d')]['emit']=function(_0x565a18,_0x13ee7b,_0x234c7f){io['to'](_0x565a18)[_0x67cb('0x1e')](_0x13ee7b,_0x234c7f);};VoiceAgentReport['prototype'][_0x67cb('0x1f')]=function(_0x36c87b){return _0x36c87b!==null&&!_[_0x67cb('0x20')](_0x36c87b);};VoiceAgentReport['prototype'][_0x67cb('0x10')]=function(_0x4884f6){try{if(this[_0x67cb('0x1f')](_0x4884f6)){logger['info']('[%s][voiceAgentReport][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called',_0x4884f6[_0x67cb('0x21')],_0x4884f6[_0x67cb('0x22')],_0x4884f6[_0x67cb('0x23')]);logger[_0x67cb('0x24')](_0x67cb('0x25'),_0x4884f6[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x4884f6,{'showHidden':![],'depth':null}));if(_[_0x67cb('0x20')](this[_0x67cb('0xb')][_0x4884f6[_0x67cb('0x21')]])){this[_0x67cb('0xb')][_0x4884f6['uniqueid']]={};}var _0x142965=this[_0x67cb('0xe')][_0x4884f6[_0x67cb('0x27')]];var _0x3e314d=this[_0x67cb('0xb')][_0x4884f6[_0x67cb('0x21')]][_0x4884f6['destuniqueid']];var _0x51831d=this[_0x67cb('0xd')][_0x4884f6[_0x67cb('0x28')]];var _0x468d4d=this['variables'][_0x4884f6['uniqueid']];if(_[_0x67cb('0x20')](_0x3e314d)){_0x3e314d={'agentcalledAt':moment()[_0x67cb('0x29')](_0x67cb('0x2a')),'lastevent':'called','mandatoryDisposition':_0x51831d&&_0x51831d['mandatoryDisposition']?_0x51831d[_0x67cb('0x2b')]:![],'type':_0x51831d&&_0x51831d[_0x67cb('0x2c')]?_0x51831d[_0x67cb('0x2c')]:_0x67cb('0x2d'),'variables':_0x468d4d,'motionChannel':_0x67cb('0x2e')};}Object[_0x67cb('0x2f')](_0x3e314d,_[_0x67cb('0x30')](_0x4884f6,[_0x67cb('0x31'),_0x67cb('0x32')]));this[_0x67cb('0xb')][_0x4884f6[_0x67cb('0x21')]][_0x4884f6[_0x67cb('0x23')]]=_0x3e314d;logger['debug'](_0x67cb('0x33'),_0x4884f6['uniqueid'],util[_0x67cb('0x26')](_0x3e314d,{'showHidden':![],'depth':null}));ami['emit'](_0x67cb('0x34'),_0x3e314d);var _0x369fd1={'id':_0x142965['id'],'calleridnum':_0x3e314d['calleridnum'],'queue':_0x3e314d['queue'],'variables':_0x3e314d[_0x67cb('0x35')],'uniqueid':_0x4884f6[_0x67cb('0x21')]};logger[_0x67cb('0x24')]('[%s][voiceAgentReport][agentcalled]\x20sending\x20user:called\x20event:',_0x4884f6[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x369fd1,{'showHidden':![],'depth':null}));this['emit'](util[_0x67cb('0x29')](_0x67cb('0x36'),_0x4884f6[_0x67cb('0x22')]),'user:called',_0x369fd1);}}catch(_0x5c93b2){logger['error'](_0x67cb('0x37'),_0x4884f6[_0x67cb('0x21')],util['inspect'](_0x5c93b2,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x67cb('0x1d')][_0x67cb('0x12')]=function(_0x191a64){try{if(this['isNotNull'](_0x191a64)){if(this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]]){for(var _0x3d538d in this[_0x67cb('0xb')][_0x191a64['uniqueid']]){if(this[_0x67cb('0xb')][_0x191a64['uniqueid']][_0x67cb('0x38')](_0x3d538d)){if(_0x191a64[_0x67cb('0x23')]===_0x3d538d){logger[_0x67cb('0x39')]('[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect',_0x191a64[_0x67cb('0x21')],_0x191a64[_0x67cb('0x22')],_0x191a64[_0x67cb('0x23')]);this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d]['agentconnectAt']=moment()[_0x67cb('0x29')](_0x67cb('0x2a'));this['channels'][_0x191a64['uniqueid']][_0x3d538d][_0x67cb('0x3a')]=_0x191a64[_0x67cb('0x3a')];this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x3b')]=_0x191a64[_0x67cb('0x3b')];this[_0x67cb('0xb')][_0x191a64['uniqueid']][_0x3d538d][_0x67cb('0x3c')]=_0x191a64[_0x67cb('0x3c')];this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d]['destchannelstatedesc']=_0x191a64['destchannelstatedesc'];this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x3d')]=_0x191a64[_0x67cb('0x3d')];this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x3e')]=_0x67cb('0x3f');_['merge'](this[_0x67cb('0xe')][_0x191a64[_0x67cb('0x27')]],_[_0x67cb('0x40')](_0x191a64,[_0x67cb('0x28'),'destconnectedlinenum']));var _0x44d9bc=this[_0x67cb('0xe')][_0x191a64[_0x67cb('0x27')]];var _0x175901={'id':_0x44d9bc['id'],'name':_0x44d9bc[_0x67cb('0x41')],'agentconnected':!![],'destaccountcode':_0x44d9bc[_0x67cb('0x42')],'destconnectedlinenum':this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x191a64[_0x67cb('0x23')]][_0x67cb('0x43')],'queue':this['channels'][_0x191a64[_0x67cb('0x21')]][_0x191a64[_0x67cb('0x23')]]['queue'],'uniqueid':this['channels'][_0x191a64[_0x67cb('0x21')]][_0x191a64[_0x67cb('0x23')]][_0x67cb('0x21')]};ami[_0x67cb('0x1e')]('custom:agentconnect',this['channels'][_0x191a64[_0x67cb('0x21')]][_0x191a64['destuniqueid']]);this[_0x67cb('0x1e')](util[_0x67cb('0x29')](_0x67cb('0x36'),_0x191a64[_0x67cb('0x22')]),'user:agentconnect',_0x175901);}else if(!this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x44')]&&!this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x16')]){logger[_0x67cb('0x39')](_0x67cb('0x45'),_0x191a64[_0x67cb('0x21')],this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d]['membername'],_0x3d538d);this['channels'][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x44')]=!![];this[_0x67cb('0xb')][_0x191a64['uniqueid']][_0x3d538d][_0x67cb('0x46')]=moment()[_0x67cb('0x29')](_0x67cb('0x2a'));this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x47')]=_0x191a64[_0x67cb('0x23')];this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x48')]=_0x191a64['membername'];this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d][_0x67cb('0x3e')]='answered_elsewhere';this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d]['reason']='answered_elsewhere';logger[_0x67cb('0x24')](_0x67cb('0x49'),_0x191a64['uniqueid'],util['inspect'](this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d],{'showHidden':![],'depth':null}));ami[_0x67cb('0x1e')]('custom:agentansweredelsewhere',this[_0x67cb('0xb')][_0x191a64[_0x67cb('0x21')]][_0x3d538d]);}else{logger[_0x67cb('0x24')](_0x67cb('0x4a'),_0x191a64[_0x67cb('0x21')]);}}}}}}catch(_0x20b8fc){logger[_0x67cb('0x4b')](_0x67cb('0x4c'),_0x191a64[_0x67cb('0x21')],util['inspect'](_0x20b8fc,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0x67cb('0x13')]=function(_0x5426ec){try{if(this['isNotNull'](_0x5426ec)){logger[_0x67cb('0x24')](_0x67cb('0x4d'),_0x5426ec[_0x67cb('0x21')],util['inspect'](_0x5426ec,{'showHidden':![],'depth':null}));if(this[_0x67cb('0xb')][_0x5426ec[_0x67cb('0x21')]]&&this[_0x67cb('0xb')][_0x5426ec['uniqueid']][_0x5426ec[_0x67cb('0x23')]]){logger['info'](_0x67cb('0x4e'),_0x5426ec[_0x67cb('0x21')],_0x5426ec[_0x67cb('0x22')],_0x5426ec[_0x67cb('0x23')]);var _0x39e3b9=this[_0x67cb('0xe')][_0x5426ec[_0x67cb('0x27')]];var _0x464806=this[_0x67cb('0xb')][_0x5426ec[_0x67cb('0x21')]][_0x5426ec[_0x67cb('0x23')]];_0x464806['agentringnoanswer']=!![];_0x464806['agentringnoanswerAt']=moment()[_0x67cb('0x29')]('YYYY-MM-DD\x20HH:mm:ss');_0x464806[_0x67cb('0x3e')]=_0x67cb('0x4f');_0x464806[_0x67cb('0x50')]=_0x67cb('0x4f');var _0x444a75={'id':_0x39e3b9['id'],'name':_0x39e3b9[_0x67cb('0x41')],'queue':_0x464806[_0x67cb('0x28')],'uniqueid':_0x464806[_0x67cb('0x21')]};logger[_0x67cb('0x24')](_0x67cb('0x51'),_0x5426ec['uniqueid'],util[_0x67cb('0x26')](_0x444a75,{'showHidden':![],'depth':null}));this[_0x67cb('0x1e')](util[_0x67cb('0x29')]('user:%s',_0x39e3b9[_0x67cb('0x41')]),_0x67cb('0x52'),_0x444a75);ami[_0x67cb('0x1e')](_0x67cb('0x53'),_0x464806);this[_0x67cb('0xb')][_0x5426ec[_0x67cb('0x21')]][_0x5426ec[_0x67cb('0x23')]]=Object[_0x67cb('0x2f')]({},_0x464806);}}}catch(_0x1031be){logger[_0x67cb('0x4b')]('[%s][voiceAgentReport][agentringnoanswer]',_0x5426ec['uniqueid'],util[_0x67cb('0x26')](_0x1031be,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x67cb('0x1d')][_0x67cb('0x54')]=function(_0x428f2a){try{if(this[_0x67cb('0x1f')](_0x428f2a)){logger[_0x67cb('0x24')](_0x67cb('0x55'),_0x428f2a[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x428f2a,{'showHidden':![],'depth':null}));if(this[_0x67cb('0xb')][_0x428f2a['uniqueid']]){for(var _0x10c65c in this[_0x67cb('0xb')][_0x428f2a[_0x67cb('0x21')]]){if(this[_0x67cb('0xb')][_0x428f2a[_0x67cb('0x21')]]['hasOwnProperty'](_0x10c65c)&&!this[_0x67cb('0xb')][_0x428f2a['uniqueid']][_0x10c65c]['agentringnoanswer']&&!this['channels'][_0x428f2a['uniqueid']][_0x10c65c]['agentcomplete']){logger[_0x67cb('0x39')]('[%s][voiceAgentReport][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned',_0x428f2a[_0x67cb('0x21')],this['channels'][_0x428f2a[_0x67cb('0x21')]][_0x10c65c]['membername'],_0x10c65c);this[_0x67cb('0xb')][_0x428f2a[_0x67cb('0x21')]][_0x10c65c][_0x67cb('0x44')]=!![];this['channels'][_0x428f2a['uniqueid']][_0x10c65c][_0x67cb('0x46')]=moment()[_0x67cb('0x29')](_0x67cb('0x2a'));this['channels'][_0x428f2a['uniqueid']][_0x10c65c]['lastevent']=_0x67cb('0x56');this['channels'][_0x428f2a[_0x67cb('0x21')]][_0x10c65c][_0x67cb('0x50')]=_0x67cb('0x56');logger[_0x67cb('0x24')](_0x67cb('0x57'),_0x428f2a[_0x67cb('0x21')],util[_0x67cb('0x26')](this[_0x67cb('0xb')][_0x428f2a[_0x67cb('0x21')]][_0x10c65c],{'showHidden':![],'depth':null}));ami[_0x67cb('0x1e')](_0x67cb('0x58'),this[_0x67cb('0xb')][_0x428f2a[_0x67cb('0x21')]][_0x10c65c]);}}}}}catch(_0x52b113){logger[_0x67cb('0x4b')](_0x67cb('0x59'),_0x428f2a[_0x67cb('0x21')],util['inspect'](_0x52b113,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0x67cb('0x5a')]=function(_0x5d77a2){try{if(this['isNotNull'](_0x5d77a2)){logger[_0x67cb('0x24')](_0x67cb('0x5b'),_0x5d77a2['uniqueid'],util[_0x67cb('0x26')](_0x5d77a2,{'showHidden':![],'depth':null}));if(this[_0x67cb('0xb')][_0x5d77a2['uniqueid']]){for(var _0x502e3b in this['channels'][_0x5d77a2[_0x67cb('0x21')]]){if(this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x67cb('0x38')](_0x502e3b)){if(this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b][_0x67cb('0x5c')]&&!this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b][_0x67cb('0x16')]){logger['info']('[%s][voiceAgentReport][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete',_0x5d77a2['uniqueid'],this['channels'][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b][_0x67cb('0x22')],_0x502e3b);this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b][_0x67cb('0x16')]=!![];this['channels'][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b]['agentcompleteAt']=moment()[_0x67cb('0x29')](_0x67cb('0x2a'));this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b]['lastevent']=_0x67cb('0x5d');this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b][_0x67cb('0x50')]=_0x5d77a2[_0x67cb('0x50')]==_0x67cb('0x5e')?_0x67cb('0x5f'):_0x5d77a2[_0x67cb('0x50')];this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b][_0x67cb('0x60')]=_0x5d77a2['talktime'];if(this[_0x67cb('0xd')][_0x5d77a2[_0x67cb('0x28')]]&&this[_0x67cb('0xd')][_0x5d77a2[_0x67cb('0x28')]][_0x67cb('0x61')]){this[_0x67cb('0xb')][_0x5d77a2['uniqueid']][_0x502e3b][_0x67cb('0x62')]=this[_0x67cb('0xd')][_0x5d77a2[_0x67cb('0x28')]][_0x67cb('0x63')];this[_0x67cb('0xb')][_0x5d77a2['uniqueid']][_0x502e3b][_0x67cb('0x64')]=!![];}this['agents'][_0x5d77a2[_0x67cb('0x27')]]=_[_0x67cb('0x30')](this[_0x67cb('0xe')][_0x5d77a2[_0x67cb('0x27')]],[_0x67cb('0x28'),_0x67cb('0x65')]);logger[_0x67cb('0x24')](_0x67cb('0x66'),_0x5d77a2['uniqueid'],util[_0x67cb('0x26')](this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b],{'showHidden':![],'depth':null}));ami[_0x67cb('0x1e')](_0x67cb('0x67'),this[_0x67cb('0xb')][_0x5d77a2[_0x67cb('0x21')]][_0x502e3b]);logger[_0x67cb('0x24')]('[%s][voiceAgentReport][agentcomplete]\x20sending\x20user:agentcomplete\x20event:',_0x5d77a2[_0x67cb('0x21')],util['inspect']({'id':this[_0x67cb('0xe')][_0x5d77a2[_0x67cb('0x27')]]['id'],'destaccountcode':_0x5d77a2[_0x67cb('0x68')]},{'showHidden':![],'depth':null}));this['emit'](util[_0x67cb('0x29')](_0x67cb('0x36'),_0x5d77a2['membername']),_0x67cb('0x69'),{'id':this[_0x67cb('0xe')][_0x5d77a2['interface']]['id'],'destaccountcode':Number(_0x5d77a2[_0x67cb('0x68')])});}}}}}}catch(_0x1adbb5){logger[_0x67cb('0x4b')](_0x67cb('0x6a'),_0x5d77a2[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x1adbb5,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x67cb('0x1d')][_0x67cb('0x17')]=function(_0x2fd3db){try{if(this[_0x67cb('0x1f')](_0x2fd3db)){logger[_0x67cb('0x24')]('[%s][voiceAgentReport][varset]\x20event:',_0x2fd3db[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x2fd3db,{'showHidden':![],'depth':null}));this['addVariable'](_0x2fd3db[_0x67cb('0x21')],_[_0x67cb('0x6b')](_0x2fd3db[_0x67cb('0x6c')])[0x0],_0x2fd3db['value']);if(this[_0x67cb('0xb')][_0x2fd3db[_0x67cb('0x21')]]){for(var _0x24834d in this[_0x67cb('0xb')][_0x2fd3db[_0x67cb('0x21')]]){if(this['channels'][_0x2fd3db['uniqueid']][_0x67cb('0x38')](_0x24834d)){logger['info'](_0x67cb('0x6d'),_0x2fd3db['uniqueid'],_0x24834d,_[_0x67cb('0x6b')](_0x2fd3db[_0x67cb('0x6c')])[0x0],_0x2fd3db[_0x67cb('0x6e')]);if(_[_0x67cb('0x20')](this['channels'][_0x2fd3db['uniqueid']][_0x24834d][_0x67cb('0x35')])){this['channels'][_0x2fd3db['uniqueid']][_0x24834d][_0x67cb('0x35')]={};}this[_0x67cb('0xb')][_0x2fd3db[_0x67cb('0x21')]][_0x24834d]['variables']=this['variables'][_0x2fd3db[_0x67cb('0x21')]];}}}}}catch(_0x4cfa1a){logger[_0x67cb('0x4b')]('[%s][voiceAgentReport][varset]',_0x2fd3db[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x4cfa1a,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x67cb('0x1d')]['addVariable']=function(_0x312ee6,_0x43daac,_0x419a1c){var _0x5598d0=[_0x67cb('0x6f'),'rtpaudioqosbridged',_0x67cb('0x70'),_0x67cb('0x71'),_0x67cb('0x72'),_0x67cb('0x73'),_0x67cb('0x74'),_0x67cb('0x75'),'sipcallid',_0x67cb('0x76'),_0x67cb('0x77'),_0x67cb('0x78'),_0x67cb('0x79'),_0x67cb('0x7a'),_0x67cb('0x7b'),_0x67cb('0x7c'),_0x67cb('0x22'),_0x67cb('0x7d'),_0x67cb('0x7e')];if(!_[_0x67cb('0x7f')](_0x43daac)&&!_[_0x67cb('0x80')](_0x5598d0,_0x43daac)){if(_[_0x67cb('0x20')](this[_0x67cb('0x35')][_0x312ee6])){this[_0x67cb('0x35')][_0x312ee6]={};}this[_0x67cb('0x35')][_0x312ee6][_0x43daac]=_0x419a1c;}};VoiceAgentReport[_0x67cb('0x1d')][_0x67cb('0x81')]=function(_0x338c36){try{if(this['isNotNull'](_0x338c36)){logger[_0x67cb('0x24')]('[%s][voiceAgentReport][hangup]\x20event:',_0x338c36[_0x67cb('0x21')],util['inspect'](_0x338c36,{'showHidden':![],'depth':null}));if(this[_0x67cb('0xb')][_0x338c36['uniqueid']]){for(var _0xdd193 in this['channels'][_0x338c36['uniqueid']]){if(this[_0x67cb('0xb')][_0x338c36[_0x67cb('0x21')]]['hasOwnProperty'](_0xdd193)){if(this[_0x67cb('0xb')][_0x338c36[_0x67cb('0x21')]][_0xdd193][_0x67cb('0x50')]=='transfer'&&this['channels'][_0x338c36[_0x67cb('0x21')]][_0xdd193]['agentcomplete']){logger[_0x67cb('0x39')](_0x67cb('0x82'),_0x338c36[_0x67cb('0x21')],_0xdd193);this[_0x67cb('0xb')][_0x338c36[_0x67cb('0x21')]][_0xdd193]['agentcompleteAt']=moment()[_0x67cb('0x29')]('YYYY-MM-DD\x20HH:mm:ss');}}}logger[_0x67cb('0x24')](_0x67cb('0x83'),_0x338c36[_0x67cb('0x21')],util[_0x67cb('0x26')](_[_0x67cb('0x84')](this['channels'][_0x338c36[_0x67cb('0x21')]]),{'showHidden':![],'depth':null}));ami['emit'](_0x67cb('0x85'),_['values'](this[_0x67cb('0xb')][_0x338c36[_0x67cb('0x21')]]));this['deleteChannelAfterTimeout'](_0x338c36['uniqueid']);}if(this['variables'][_0x338c36[_0x67cb('0x21')]]){delete this[_0x67cb('0x35')][_0x338c36[_0x67cb('0x21')]];}}}catch(_0x431197){logger['error'](_0x67cb('0x86'),_0x338c36['uniqueid'],util[_0x67cb('0x26')](_0x431197,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x67cb('0x1d')][_0x67cb('0x1b')]=function(_0xa79f20){try{if(this[_0x67cb('0x1f')](_0xa79f20)){logger[_0x67cb('0x24')](_0x67cb('0x87'),_0xa79f20[_0x67cb('0x21')],util[_0x67cb('0x26')](_0xa79f20,{'showHidden':![],'depth':null}));if(this[_0x67cb('0xb')][_0xa79f20[_0x67cb('0x88')]]){for(var _0x2e3dd4 in this[_0x67cb('0xb')][_0xa79f20['transfereeuniqueid']]){if(this[_0x67cb('0xb')][_0xa79f20['transfereeuniqueid']][_0x67cb('0x38')](_0x2e3dd4)){if(_0xa79f20[_0x67cb('0x89')]===_0x2e3dd4){logger[_0x67cb('0x39')](_0x67cb('0x8a'),_0xa79f20['uniqueid'],this[_0x67cb('0xb')][_0xa79f20[_0x67cb('0x88')]][_0x2e3dd4][_0x67cb('0x22')],_0x2e3dd4);var _0x1aad30=moment();this['channels'][_0xa79f20[_0x67cb('0x88')]][_0x2e3dd4][_0x67cb('0x16')]=!![];this['channels'][_0xa79f20['transfereeuniqueid']][_0x2e3dd4][_0x67cb('0x8b')]=moment()[_0x67cb('0x29')]('YYYY-MM-DD\x20HH:mm:ss');this[_0x67cb('0xb')][_0xa79f20['transfereeuniqueid']][_0x2e3dd4][_0x67cb('0x3e')]=_0x67cb('0x5d');this[_0x67cb('0xb')][_0xa79f20[_0x67cb('0x88')]][_0x2e3dd4][_0x67cb('0x50')]=_0x67cb('0x5e');this[_0x67cb('0xb')][_0xa79f20[_0x67cb('0x88')]][_0x2e3dd4]['talktime']=_0x1aad30[_0x67cb('0x8c')](this[_0x67cb('0xb')][_0xa79f20[_0x67cb('0x88')]][_0x2e3dd4][_0x67cb('0x5c')],_0x67cb('0x8d'));}}}}if(this['channels'][_0xa79f20[_0x67cb('0x8e')]]){var _0x2058c1=this[_0x67cb('0xb')][_0xa79f20['secondtransfereruniqueid']];this[_0x67cb('0xb')][_0xa79f20[_0x67cb('0x8e')]]=this[_0x67cb('0xb')][_0xa79f20[_0x67cb('0x88')]];this[_0x67cb('0xb')][_0xa79f20[_0x67cb('0x88')]]=_0x2058c1;}}}catch(_0x4a0a37){logger[_0x67cb('0x4b')](_0x67cb('0x8f'),_0xa79f20[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x4a0a37,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x67cb('0x1d')][_0x67cb('0x90')]=function(_0x27bca9){try{if(this[_0x67cb('0x1f')](_0x27bca9)){logger[_0x67cb('0x24')](_0x67cb('0x91'),_0x27bca9[_0x67cb('0x21')],util['inspect'](_0x27bca9,{'showHidden':![],'depth':null}));if(this['channels'][_0x27bca9[_0x67cb('0x88')]]){for(var _0x30a878 in this[_0x67cb('0xb')][_0x27bca9['transfereeuniqueid']]){if(this[_0x67cb('0xb')][_0x27bca9[_0x67cb('0x88')]][_0x67cb('0x38')](_0x30a878)){if(_0x27bca9[_0x67cb('0x92')]===_0x30a878){logger[_0x67cb('0x39')]('[%s][voiceAgentReport][blindtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete',_0x27bca9['uniqueid'],this[_0x67cb('0xb')][_0x27bca9[_0x67cb('0x88')]][_0x30a878][_0x67cb('0x22')],_0x30a878);var _0x500b6f=moment();this['channels'][_0x27bca9[_0x67cb('0x88')]][_0x30a878][_0x67cb('0x16')]=!![];this[_0x67cb('0xb')][_0x27bca9['transfereeuniqueid']][_0x30a878]['agentcompleteAt']=_0x500b6f;this[_0x67cb('0xb')][_0x27bca9['transfereeuniqueid']][_0x30a878][_0x67cb('0x3e')]='complete';this[_0x67cb('0xb')][_0x27bca9[_0x67cb('0x88')]][_0x30a878]['reason']=_0x67cb('0x5e');this[_0x67cb('0xb')][_0x27bca9[_0x67cb('0x88')]][_0x30a878][_0x67cb('0x60')]=_0x500b6f[_0x67cb('0x8c')](this[_0x67cb('0xb')][_0x27bca9[_0x67cb('0x88')]][_0x30a878]['agentconnectAt'],_0x67cb('0x8d'));}}}}}}catch(_0x41791e){logger['error']('[%s][voiceAgentReport][blindtransfer]',_0x27bca9[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x41791e,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0x67cb('0x93')]=function(_0x5f5ba5){var _0x41dc59='';try{if(this['isNotNull'](_0x5f5ba5)){logger[_0x67cb('0x24')](_0x67cb('0x94'),_0x5f5ba5[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x5f5ba5,{'showHidden':![],'depth':null}));if(_0x5f5ba5[_0x67cb('0x95')]){_0x41dc59=_0x5f5ba5['channel']['substring'](0x0,_0x5f5ba5[_0x67cb('0x95')]['lastIndexOf']('-'));if(this[_0x67cb('0xe')][_0x41dc59]){logger[_0x67cb('0x39')](_0x67cb('0x96'),_0x5f5ba5[_0x67cb('0x21')],_0x41dc59);this[_0x67cb('0xe')][_0x41dc59][_0x67cb('0x97')]=!![];}}}}catch(_0xfbf119){logger[_0x67cb('0x4b')](_0x67cb('0x98'),_0x5f5ba5['uniqueid'],util[_0x67cb('0x26')](_0xfbf119,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0x67cb('0x1a')]=function(_0x50b7a0){var _0x427b10='';try{if(this[_0x67cb('0x1f')](_0x50b7a0)){logger[_0x67cb('0x24')](_0x67cb('0x99'),_0x50b7a0[_0x67cb('0x21')],util[_0x67cb('0x26')](_0x50b7a0,{'showHidden':![],'depth':null}));if(_0x50b7a0[_0x67cb('0x95')]){_0x427b10=_0x50b7a0[_0x67cb('0x95')][_0x67cb('0x9a')](0x0,_0x50b7a0['channel'][_0x67cb('0x9b')]('-'));if(this['agents'][_0x427b10]){logger[_0x67cb('0x39')](_0x67cb('0x9c'),_0x50b7a0['uniqueid'],_0x427b10);this[_0x67cb('0xe')][_0x427b10]['onhold']=![];}}}}catch(_0x550bdb){logger['error'](_0x67cb('0x9d'),_0x50b7a0['uniqueid'],util[_0x67cb('0x26')](_0x550bdb,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0x67cb('0x1d')]['deleteChannelAfterTimeout']=function(_0x2d9c1a,_0xe7ab59=0x2710){if(this[_0x67cb('0xb')][_0x2d9c1a]){setTimeout(()=>{delete this['channels'][_0x2d9c1a];},_0xe7ab59);}};module[_0x67cb('0x9e')]=VoiceAgentReport;