2df5927128c19a301e37110bec792479bdd42719
[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 _0x848f=['custom:agentconnect','user:agentconnect','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:answered_elsewhere','agentringnoanswerAt','answeredelsewheredestinationuniqueid','answeredelsewheremembername','reason','[%s][voiceAgentReport][agentconnect]\x20sending\x20agentansweredelsewhere\x20event:','custom:agentansweredelsewhere','[%s][voiceAgentReport][agentconnect]\x20Else\x20path\x20should\x20never\x20be\x20taken','[%s][voiceAgentReport][agentconnect]','[%s][voiceAgentReport][agentringnoanswer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:rejected','rejected','[%s][voiceAgentReport][agentringnoanswer]\x20sending\x20agentringnoanswer\x20event:','user:agentringnoanswer','[%s][voiceAgentReport][agentringnoanswer]','[%s][voiceAgentReport][queuecallerabandon]\x20event:','[%s][voiceAgentReport][queuecallerabandon]\x20agent:%s\x20destuniqueid:%s\x20lastevent:abandoned','abandoned','custom:agentqueuecallerabandon','[%s][voiceAgentReport][agentcomplete]\x20event:','[%s][voiceAgentReport][agentcomplete]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','agentcompleteAt','transfer','agent','talktime','acw','acwtime','acwTimeout','agentacw','[%s][voiceAgentReport][agentcomplete]\x20sending\x20agentcomplete\x20event:','custom:agentcomplete','user:agentcomplete','destaccountcode','[%s][voiceAgentReport][agentcomplete]','[%s][voiceAgentReport][varset]\x20event:','keys','variable','value','[%s][voiceAgentReport][varset]\x20destuniqueid:%s\x20variable:%s\x20value:%s','[%s][voiceAgentReport][varset]','addVariable','rtpaudioqos','rtpaudioqosjitter','rtpaudioqosloss','rtpaudioqoslossbridged','rtpaudioqosrtt','rtpaudioqosrttbridged','sipcallid','bridgepeer','bridgepvtcallid','membercalls','memberdynamic','memberinterface','memberlastcall','memberrealtime','isNil','includes','[%s][voiceAgentReport][hangup]\x20destuniqueid:%s','custom:voiceAgentReport','values','deleteChannelAfterTimeout','[%s][voiceAgentReport][hangup]','syncAttendedTransfer','[%s][voiceAgentReport][attendedtransfer]\x20event:','transfereeuniqueid','origtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','complete','agentconnectAt','secondtransfereruniqueid','[%s][voiceAgentReport][attendedtransfer]','[%s][voiceAgentReport][blindtransfer]\x20event:','transfereruniqueid','[%s][voiceAgentReport][blindtransfer]\x20agent:%s\x20destuniqueid:%s\x20lastevent:complete','seconds','[%s][voiceAgentReport][musiconholdstart]\x20event:','channel','substring','lastIndexOf','onhold','[%s][voiceAgentReport][musiconholdstart]','syncMusicOnHoldStop','[%s][voiceAgentReport][musiconholdstop]\x20event:','[%s][voiceAgentReport][musiconholdstop]\x20interface:%s','[%s][voiceAgentReport][musiconholdstop]','exports','lodash','moment','util','ioredis','../../../config/environment','../../../config/logger','../ami','redis','defaults','channels','voiceChannels','voiceQueues','agents','variables','agentcalled','syncAgentCalled','bind','agentconnect','agentringnoanswer','syncAgentRingNoAnswer','queuecallerabandon','syncQueueCallerAbandon','agentcomplete','syncAgentComplete','syncVarSet','hangup','syncHangup','syncMusicOnHoldStart','attendedtransfer','blindtransfer','syncBlindTransfer','prototype','emit','isNotNull','isUndefined','info','[%s][voiceAgentReport][agentcalled]\x20agent:%s\x20destuniqueid:%s\x20lastevent:called','membername','[%s][voiceAgentReport][agentcalled]\x20event:','uniqueid','inspect','interface','queue','format','mandatoryDisposition','type','inbound','voice','assign','omit','privilege','destuniqueid','debug','custom:agentcalled','calleridnum','[%s][voiceAgentReport][agentcalled]\x20sending\x20user:called\x20event:','user:%s','user:called','error','[%s][voiceAgentReport][agentcalled]','syncAgentConnect','hasOwnProperty','[%s][voiceAgentReport][agentconnect]\x20agent:%s\x20destuniqueid:%s\x20lastevent:connect','YYYY-MM-DD\x20HH:mm:ss','connectedlinename','connectedlinenum','destchannelstate','destchannelstatedesc','lastevent','connect','merge','pick','destconnectedlinenum','name','accountcode','exten'];(function(_0x3a0c13,_0x561d63){var _0x509811=function(_0x24c9a4){while(--_0x24c9a4){_0x3a0c13['push'](_0x3a0c13['shift']());}};_0x509811(++_0x561d63);}(_0x848f,0xfa));var _0xf848=function(_0x4c809f,_0x45daf7){_0x4c809f=_0x4c809f-0x0;var _0x195d9b=_0x848f[_0x4c809f];return _0x195d9b;};'use strict';var _=require(_0xf848('0x0'));var moment=require(_0xf848('0x1'));var util=require(_0xf848('0x2'));var Redis=require(_0xf848('0x3'));var config=require(_0xf848('0x4'));var logger=require(_0xf848('0x5'))('ami');var ami=require(_0xf848('0x6'));config[_0xf848('0x7')]=_[_0xf848('0x8')](config[_0xf848('0x7')],{'host':'localhost','port':0x18eb});var io=require('socket.io-emitter')(new Redis(config[_0xf848('0x7')]));function VoiceAgentReport(_0x173314){this[_0xf848('0x9')]={};this[_0xf848('0xa')]=_0x173314[_0xf848('0x9')];this[_0xf848('0xb')]=_0x173314[_0xf848('0xb')];this[_0xf848('0xc')]=_0x173314[_0xf848('0xc')];this[_0xf848('0xd')]={};ami['on'](_0xf848('0xe'),this[_0xf848('0xf')][_0xf848('0x10')](this));ami['on'](_0xf848('0x11'),this['syncAgentConnect'][_0xf848('0x10')](this));ami['on'](_0xf848('0x12'),this[_0xf848('0x13')]['bind'](this));ami['on'](_0xf848('0x14'),this[_0xf848('0x15')][_0xf848('0x10')](this));ami['on'](_0xf848('0x16'),this[_0xf848('0x17')][_0xf848('0x10')](this));ami['on']('varset',this[_0xf848('0x18')]['bind'](this));ami['on'](_0xf848('0x19'),this[_0xf848('0x1a')][_0xf848('0x10')](this));ami['on']('musiconholdstart',this[_0xf848('0x1b')]['bind'](this));ami['on']('musiconholdstop',this['syncMusicOnHoldStop'][_0xf848('0x10')](this));ami['on'](_0xf848('0x1c'),this['syncAttendedTransfer'][_0xf848('0x10')](this));ami['on'](_0xf848('0x1d'),this[_0xf848('0x1e')][_0xf848('0x10')](this));}VoiceAgentReport[_0xf848('0x1f')]['emit']=function(_0x3bdfca,_0x4c7666,_0x53013e){io['to'](_0x3bdfca)[_0xf848('0x20')](_0x4c7666,_0x53013e);};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x21')]=function(_0x346cf7){return _0x346cf7!==null&&!_[_0xf848('0x22')](_0x346cf7);};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0xf')]=function(_0x2a7bfc){try{if(this['isNotNull'](_0x2a7bfc)){logger[_0xf848('0x23')](_0xf848('0x24'),_0x2a7bfc['uniqueid'],_0x2a7bfc[_0xf848('0x25')],_0x2a7bfc['destuniqueid']);logger['debug'](_0xf848('0x26'),_0x2a7bfc[_0xf848('0x27')],util[_0xf848('0x28')](_0x2a7bfc,{'showHidden':![],'depth':null}));if(_[_0xf848('0x22')](this[_0xf848('0x9')][_0x2a7bfc[_0xf848('0x27')]])){this['channels'][_0x2a7bfc['uniqueid']]={};}var _0x162ba7=this[_0xf848('0xc')][_0x2a7bfc[_0xf848('0x29')]];var _0x147638=this['channels'][_0x2a7bfc[_0xf848('0x27')]][_0x2a7bfc['destuniqueid']];var _0x8b6f6d=this[_0xf848('0xb')][_0x2a7bfc[_0xf848('0x2a')]];var _0x445192=this[_0xf848('0xd')][_0x2a7bfc[_0xf848('0x27')]];if(_['isUndefined'](_0x147638)){_0x147638={'agentcalledAt':moment()[_0xf848('0x2b')]('YYYY-MM-DD\x20HH:mm:ss'),'lastevent':'called','mandatoryDisposition':_0x8b6f6d&&_0x8b6f6d[_0xf848('0x2c')]?_0x8b6f6d['mandatoryDisposition']:![],'type':_0x8b6f6d&&_0x8b6f6d[_0xf848('0x2d')]?_0x8b6f6d[_0xf848('0x2d')]:_0xf848('0x2e'),'variables':_0x445192,'motionChannel':_0xf848('0x2f')};}Object[_0xf848('0x30')](_0x147638,_[_0xf848('0x31')](_0x2a7bfc,['event',_0xf848('0x32')]));this['channels'][_0x2a7bfc[_0xf848('0x27')]][_0x2a7bfc[_0xf848('0x33')]]=_0x147638;logger[_0xf848('0x34')]('[%s][voiceAgentReport][agentcalled]\x20sending\x20agentcalled\x20event:',_0x2a7bfc[_0xf848('0x27')],util['inspect'](_0x147638,{'showHidden':![],'depth':null}));ami[_0xf848('0x20')](_0xf848('0x35'),_0x147638);var _0x1233e2={'id':_0x162ba7['id'],'calleridnum':_0x147638[_0xf848('0x36')],'queue':_0x147638[_0xf848('0x2a')],'variables':_0x147638[_0xf848('0xd')],'uniqueid':_0x2a7bfc[_0xf848('0x27')]};logger[_0xf848('0x34')](_0xf848('0x37'),_0x2a7bfc['uniqueid'],util['inspect'](_0x1233e2,{'showHidden':![],'depth':null}));this[_0xf848('0x20')](util[_0xf848('0x2b')](_0xf848('0x38'),_0x2a7bfc[_0xf848('0x25')]),_0xf848('0x39'),_0x1233e2);}}catch(_0x39a967){logger[_0xf848('0x3a')](_0xf848('0x3b'),_0x2a7bfc['uniqueid'],util['inspect'](_0x39a967,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xf848('0x3c')]=function(_0x14b26a){try{if(this[_0xf848('0x21')](_0x14b26a)){if(this['channels'][_0x14b26a['uniqueid']]){for(var _0x23bcac in this['channels'][_0x14b26a['uniqueid']]){if(this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0xf848('0x3d')](_0x23bcac)){if(_0x14b26a[_0xf848('0x33')]===_0x23bcac){logger[_0xf848('0x23')](_0xf848('0x3e'),_0x14b26a[_0xf848('0x27')],_0x14b26a['membername'],_0x14b26a[_0xf848('0x33')]);this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac]['agentconnectAt']=moment()[_0xf848('0x2b')](_0xf848('0x3f'));this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac]['connectedlinename']=_0x14b26a[_0xf848('0x40')];this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac][_0xf848('0x41')]=_0x14b26a['connectedlinenum'];this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac][_0xf848('0x42')]=_0x14b26a[_0xf848('0x42')];this[_0xf848('0x9')][_0x14b26a['uniqueid']][_0x23bcac]['destchannelstatedesc']=_0x14b26a[_0xf848('0x43')];this['channels'][_0x14b26a[_0xf848('0x27')]][_0x23bcac]['holdtime']=_0x14b26a['holdtime'];this[_0xf848('0x9')][_0x14b26a['uniqueid']][_0x23bcac][_0xf848('0x44')]=_0xf848('0x45');_[_0xf848('0x46')](this[_0xf848('0xc')][_0x14b26a[_0xf848('0x29')]],_[_0xf848('0x47')](_0x14b26a,[_0xf848('0x2a'),_0xf848('0x48')]));var _0x4f48e1=this['agents'][_0x14b26a[_0xf848('0x29')]];var _0x5d04d3={'id':_0x4f48e1['id'],'name':_0x4f48e1[_0xf848('0x49')],'agentconnected':!![],'destaccountcode':_0x4f48e1[_0xf848('0x4a')],'destconnectedlinenum':this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x14b26a['destuniqueid']][_0xf848('0x4b')],'queue':this['channels'][_0x14b26a[_0xf848('0x27')]][_0x14b26a[_0xf848('0x33')]][_0xf848('0x2a')],'uniqueid':this[_0xf848('0x9')][_0x14b26a['uniqueid']][_0x14b26a[_0xf848('0x33')]]['uniqueid']};ami[_0xf848('0x20')](_0xf848('0x4c'),this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x14b26a[_0xf848('0x33')]]);this['emit'](util[_0xf848('0x2b')]('user:%s',_0x14b26a['membername']),_0xf848('0x4d'),_0x5d04d3);}else if(!this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac]['agentringnoanswer']&&!this[_0xf848('0x9')][_0x14b26a['uniqueid']][_0x23bcac][_0xf848('0x16')]){logger['info'](_0xf848('0x4e'),_0x14b26a[_0xf848('0x27')],this[_0xf848('0x9')][_0x14b26a['uniqueid']][_0x23bcac][_0xf848('0x25')],_0x23bcac);this['channels'][_0x14b26a[_0xf848('0x27')]][_0x23bcac][_0xf848('0x12')]=!![];this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac][_0xf848('0x4f')]=moment()[_0xf848('0x2b')](_0xf848('0x3f'));this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac][_0xf848('0x50')]=_0x14b26a[_0xf848('0x33')];this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac][_0xf848('0x51')]=_0x14b26a[_0xf848('0x25')];this['channels'][_0x14b26a[_0xf848('0x27')]][_0x23bcac][_0xf848('0x44')]='answered_elsewhere';this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac][_0xf848('0x52')]='answered_elsewhere';logger['debug'](_0xf848('0x53'),_0x14b26a[_0xf848('0x27')],util[_0xf848('0x28')](this['channels'][_0x14b26a['uniqueid']][_0x23bcac],{'showHidden':![],'depth':null}));ami['emit'](_0xf848('0x54'),this[_0xf848('0x9')][_0x14b26a[_0xf848('0x27')]][_0x23bcac]);}else{logger[_0xf848('0x34')](_0xf848('0x55'),_0x14b26a[_0xf848('0x27')]);}}}}}}catch(_0x26c7ae){logger['error'](_0xf848('0x56'),_0x14b26a[_0xf848('0x27')],util[_0xf848('0x28')](_0x26c7ae,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x13')]=function(_0x21b8ea){try{if(this['isNotNull'](_0x21b8ea)){logger[_0xf848('0x34')]('[%s][voiceAgentReport][agentringnoanswer]\x20event:',_0x21b8ea[_0xf848('0x27')],util[_0xf848('0x28')](_0x21b8ea,{'showHidden':![],'depth':null}));if(this[_0xf848('0x9')][_0x21b8ea[_0xf848('0x27')]]&&this[_0xf848('0x9')][_0x21b8ea[_0xf848('0x27')]][_0x21b8ea[_0xf848('0x33')]]){logger[_0xf848('0x23')](_0xf848('0x57'),_0x21b8ea[_0xf848('0x27')],_0x21b8ea[_0xf848('0x25')],_0x21b8ea[_0xf848('0x33')]);var _0x1cf701=this[_0xf848('0xc')][_0x21b8ea['interface']];var _0x394cd7=this[_0xf848('0x9')][_0x21b8ea[_0xf848('0x27')]][_0x21b8ea[_0xf848('0x33')]];_0x394cd7[_0xf848('0x12')]=!![];_0x394cd7['agentringnoanswerAt']=moment()['format'](_0xf848('0x3f'));_0x394cd7[_0xf848('0x44')]=_0xf848('0x58');_0x394cd7[_0xf848('0x52')]=_0xf848('0x58');var _0x378147={'id':_0x1cf701['id'],'name':_0x1cf701['name'],'queue':_0x394cd7[_0xf848('0x2a')],'uniqueid':_0x394cd7['uniqueid']};logger[_0xf848('0x34')](_0xf848('0x59'),_0x21b8ea[_0xf848('0x27')],util[_0xf848('0x28')](_0x378147,{'showHidden':![],'depth':null}));this[_0xf848('0x20')](util[_0xf848('0x2b')](_0xf848('0x38'),_0x1cf701[_0xf848('0x49')]),_0xf848('0x5a'),_0x378147);ami[_0xf848('0x20')]('custom:agentringnoanswer',_0x394cd7);this[_0xf848('0x9')][_0x21b8ea['uniqueid']][_0x21b8ea[_0xf848('0x33')]]=Object[_0xf848('0x30')]({},_0x394cd7);}}}catch(_0x1e61e1){logger[_0xf848('0x3a')](_0xf848('0x5b'),_0x21b8ea[_0xf848('0x27')],util[_0xf848('0x28')](_0x1e61e1,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x15')]=function(_0x5706cd){try{if(this[_0xf848('0x21')](_0x5706cd)){logger[_0xf848('0x34')](_0xf848('0x5c'),_0x5706cd[_0xf848('0x27')],util['inspect'](_0x5706cd,{'showHidden':![],'depth':null}));if(this[_0xf848('0x9')][_0x5706cd['uniqueid']]){for(var _0x9e6d92 in this[_0xf848('0x9')][_0x5706cd[_0xf848('0x27')]]){if(this[_0xf848('0x9')][_0x5706cd[_0xf848('0x27')]][_0xf848('0x3d')](_0x9e6d92)&&!this[_0xf848('0x9')][_0x5706cd[_0xf848('0x27')]][_0x9e6d92]['agentringnoanswer']&&!this[_0xf848('0x9')][_0x5706cd['uniqueid']][_0x9e6d92][_0xf848('0x16')]){logger[_0xf848('0x23')](_0xf848('0x5d'),_0x5706cd[_0xf848('0x27')],this[_0xf848('0x9')][_0x5706cd['uniqueid']][_0x9e6d92][_0xf848('0x25')],_0x9e6d92);this[_0xf848('0x9')][_0x5706cd[_0xf848('0x27')]][_0x9e6d92][_0xf848('0x12')]=!![];this[_0xf848('0x9')][_0x5706cd[_0xf848('0x27')]][_0x9e6d92][_0xf848('0x4f')]=moment()['format'](_0xf848('0x3f'));this[_0xf848('0x9')][_0x5706cd[_0xf848('0x27')]][_0x9e6d92][_0xf848('0x44')]=_0xf848('0x5e');this['channels'][_0x5706cd[_0xf848('0x27')]][_0x9e6d92][_0xf848('0x52')]=_0xf848('0x5e');logger['debug']('[%s][voiceAgentReport][queuecallerabandon]\x20sending\x20agentqueuecallerabandon\x20event:',_0x5706cd[_0xf848('0x27')],util[_0xf848('0x28')](this[_0xf848('0x9')][_0x5706cd[_0xf848('0x27')]][_0x9e6d92],{'showHidden':![],'depth':null}));ami[_0xf848('0x20')](_0xf848('0x5f'),this[_0xf848('0x9')][_0x5706cd[_0xf848('0x27')]][_0x9e6d92]);}}}}}catch(_0xa778e0){logger[_0xf848('0x3a')]('[%s][voiceAgentReport][queuecallerabandon]',_0x5706cd[_0xf848('0x27')],util[_0xf848('0x28')](_0xa778e0,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xf848('0x17')]=function(_0x118808){try{if(this[_0xf848('0x21')](_0x118808)){logger[_0xf848('0x34')](_0xf848('0x60'),_0x118808[_0xf848('0x27')],util[_0xf848('0x28')](_0x118808,{'showHidden':![],'depth':null}));if(this[_0xf848('0x9')][_0x118808[_0xf848('0x27')]]){for(var _0x502071 in this['channels'][_0x118808['uniqueid']]){if(this[_0xf848('0x9')][_0x118808[_0xf848('0x27')]][_0xf848('0x3d')](_0x502071)){if(this[_0xf848('0x9')][_0x118808[_0xf848('0x27')]][_0x502071]['agentconnectAt']&&!this['channels'][_0x118808[_0xf848('0x27')]][_0x502071]['agentcomplete']){logger[_0xf848('0x23')](_0xf848('0x61'),_0x118808[_0xf848('0x27')],this['channels'][_0x118808[_0xf848('0x27')]][_0x502071][_0xf848('0x25')],_0x502071);this['channels'][_0x118808[_0xf848('0x27')]][_0x502071][_0xf848('0x16')]=!![];this[_0xf848('0x9')][_0x118808[_0xf848('0x27')]][_0x502071][_0xf848('0x62')]=moment()[_0xf848('0x2b')](_0xf848('0x3f'));this['channels'][_0x118808[_0xf848('0x27')]][_0x502071][_0xf848('0x44')]='complete';this[_0xf848('0x9')][_0x118808[_0xf848('0x27')]][_0x502071][_0xf848('0x52')]=_0x118808[_0xf848('0x52')]==_0xf848('0x63')?_0xf848('0x64'):_0x118808[_0xf848('0x52')];this[_0xf848('0x9')][_0x118808[_0xf848('0x27')]][_0x502071][_0xf848('0x65')]=_0x118808[_0xf848('0x65')];if(this['voiceQueues'][_0x118808[_0xf848('0x2a')]]&&this[_0xf848('0xb')][_0x118808['queue']][_0xf848('0x66')]){this[_0xf848('0x9')][_0x118808['uniqueid']][_0x502071][_0xf848('0x67')]=this[_0xf848('0xb')][_0x118808[_0xf848('0x2a')]][_0xf848('0x68')];this[_0xf848('0x9')][_0x118808[_0xf848('0x27')]][_0x502071][_0xf848('0x69')]=!![];}this[_0xf848('0xc')][_0x118808[_0xf848('0x29')]]=_[_0xf848('0x31')](this[_0xf848('0xc')][_0x118808[_0xf848('0x29')]],[_0xf848('0x2a'),'destconnectedlinenum']);logger['debug'](_0xf848('0x6a'),_0x118808[_0xf848('0x27')],util[_0xf848('0x28')](this[_0xf848('0x9')][_0x118808['uniqueid']][_0x502071],{'showHidden':![],'depth':null}));ami['emit'](_0xf848('0x6b'),this[_0xf848('0x9')][_0x118808[_0xf848('0x27')]][_0x502071]);logger[_0xf848('0x34')]('[%s][voiceAgentReport][agentcomplete]\x20sending\x20user:agentcomplete\x20event:',_0x118808['uniqueid'],util['inspect']({'id':this[_0xf848('0xc')][_0x118808[_0xf848('0x29')]]['id'],'destaccountcode':_0x118808['destaccountcode']},{'showHidden':![],'depth':null}));this[_0xf848('0x20')](util[_0xf848('0x2b')](_0xf848('0x38'),_0x118808[_0xf848('0x25')]),_0xf848('0x6c'),{'id':this[_0xf848('0xc')][_0x118808['interface']]['id'],'destaccountcode':Number(_0x118808[_0xf848('0x6d')])});}}}}}}catch(_0x32abc5){logger[_0xf848('0x3a')](_0xf848('0x6e'),_0x118808['uniqueid'],util[_0xf848('0x28')](_0x32abc5,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x18')]=function(_0x3e795d){try{if(this[_0xf848('0x21')](_0x3e795d)){logger[_0xf848('0x34')](_0xf848('0x6f'),_0x3e795d[_0xf848('0x27')],util['inspect'](_0x3e795d,{'showHidden':![],'depth':null}));this['addVariable'](_0x3e795d[_0xf848('0x27')],_[_0xf848('0x70')](_0x3e795d[_0xf848('0x71')])[0x0],_0x3e795d[_0xf848('0x72')]);if(this[_0xf848('0x9')][_0x3e795d[_0xf848('0x27')]]){for(var _0x1c1ef0 in this['channels'][_0x3e795d[_0xf848('0x27')]]){if(this[_0xf848('0x9')][_0x3e795d[_0xf848('0x27')]][_0xf848('0x3d')](_0x1c1ef0)){logger[_0xf848('0x23')](_0xf848('0x73'),_0x3e795d[_0xf848('0x27')],_0x1c1ef0,_['keys'](_0x3e795d[_0xf848('0x71')])[0x0],_0x3e795d[_0xf848('0x72')]);if(_[_0xf848('0x22')](this[_0xf848('0x9')][_0x3e795d[_0xf848('0x27')]][_0x1c1ef0][_0xf848('0xd')])){this[_0xf848('0x9')][_0x3e795d[_0xf848('0x27')]][_0x1c1ef0][_0xf848('0xd')]={};}this[_0xf848('0x9')][_0x3e795d[_0xf848('0x27')]][_0x1c1ef0]['variables']=this['variables'][_0x3e795d[_0xf848('0x27')]];}}}}}catch(_0x2336be){logger['error'](_0xf848('0x74'),_0x3e795d[_0xf848('0x27')],util[_0xf848('0x28')](_0x2336be,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x75')]=function(_0x288f7e,_0x2622c4,_0x309d21){var _0x34c42f=[_0xf848('0x76'),'rtpaudioqosbridged',_0xf848('0x77'),'rtpaudioqosjitterbridged',_0xf848('0x78'),_0xf848('0x79'),_0xf848('0x7a'),_0xf848('0x7b'),_0xf848('0x7c'),'sipuri',_0xf848('0x7d'),_0xf848('0x7e'),_0xf848('0x7f'),_0xf848('0x80'),_0xf848('0x81'),_0xf848('0x82'),_0xf848('0x25'),'memberpenalty',_0xf848('0x83')];if(!_[_0xf848('0x84')](_0x2622c4)&&!_[_0xf848('0x85')](_0x34c42f,_0x2622c4)){if(_['isUndefined'](this[_0xf848('0xd')][_0x288f7e])){this[_0xf848('0xd')][_0x288f7e]={};}this[_0xf848('0xd')][_0x288f7e][_0x2622c4]=_0x309d21;}};VoiceAgentReport['prototype'][_0xf848('0x1a')]=function(_0x2478d8){try{if(this[_0xf848('0x21')](_0x2478d8)){logger['debug']('[%s][voiceAgentReport][hangup]\x20event:',_0x2478d8[_0xf848('0x27')],util['inspect'](_0x2478d8,{'showHidden':![],'depth':null}));if(this[_0xf848('0x9')][_0x2478d8['uniqueid']]){for(var _0x1987e7 in this['channels'][_0x2478d8[_0xf848('0x27')]]){if(this[_0xf848('0x9')][_0x2478d8[_0xf848('0x27')]][_0xf848('0x3d')](_0x1987e7)){if(this[_0xf848('0x9')][_0x2478d8[_0xf848('0x27')]][_0x1987e7][_0xf848('0x52')]==_0xf848('0x63')&&this['channels'][_0x2478d8[_0xf848('0x27')]][_0x1987e7][_0xf848('0x16')]){logger[_0xf848('0x23')](_0xf848('0x86'),_0x2478d8[_0xf848('0x27')],_0x1987e7);this[_0xf848('0x9')][_0x2478d8[_0xf848('0x27')]][_0x1987e7][_0xf848('0x62')]=moment()[_0xf848('0x2b')](_0xf848('0x3f'));}}}logger[_0xf848('0x34')]('[%s][voiceAgentReport][hangup]\x20sending\x20voiceAgentReport\x20event:',_0x2478d8[_0xf848('0x27')],util['inspect'](_['values'](this['channels'][_0x2478d8['uniqueid']]),{'showHidden':![],'depth':null}));ami[_0xf848('0x20')](_0xf848('0x87'),_[_0xf848('0x88')](this[_0xf848('0x9')][_0x2478d8[_0xf848('0x27')]]));this[_0xf848('0x89')](_0x2478d8[_0xf848('0x27')]);}if(this[_0xf848('0xd')][_0x2478d8[_0xf848('0x27')]]){delete this[_0xf848('0xd')][_0x2478d8[_0xf848('0x27')]];}}}catch(_0x498c6b){logger[_0xf848('0x3a')](_0xf848('0x8a'),_0x2478d8[_0xf848('0x27')],util[_0xf848('0x28')](_0x498c6b,{'showHidden':![],'depth':null}));}};VoiceAgentReport['prototype'][_0xf848('0x8b')]=function(_0x3c1e19){try{if(this['isNotNull'](_0x3c1e19)){logger[_0xf848('0x34')](_0xf848('0x8c'),_0x3c1e19[_0xf848('0x27')],util['inspect'](_0x3c1e19,{'showHidden':![],'depth':null}));if(this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x8d')]]){for(var _0x5626c9 in this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x8d')]]){if(this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x8d')]][_0xf848('0x3d')](_0x5626c9)){if(_0x3c1e19[_0xf848('0x8e')]===_0x5626c9){logger['info'](_0xf848('0x8f'),_0x3c1e19[_0xf848('0x27')],this[_0xf848('0x9')][_0x3c1e19['transfereeuniqueid']][_0x5626c9][_0xf848('0x25')],_0x5626c9);var _0x59f5ed=moment();this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x8d')]][_0x5626c9][_0xf848('0x16')]=!![];this[_0xf848('0x9')][_0x3c1e19['transfereeuniqueid']][_0x5626c9][_0xf848('0x62')]=moment()[_0xf848('0x2b')](_0xf848('0x3f'));this['channels'][_0x3c1e19[_0xf848('0x8d')]][_0x5626c9][_0xf848('0x44')]=_0xf848('0x90');this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x8d')]][_0x5626c9]['reason']='transfer';this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x8d')]][_0x5626c9][_0xf848('0x65')]=_0x59f5ed['diff'](this[_0xf848('0x9')][_0x3c1e19['transfereeuniqueid']][_0x5626c9][_0xf848('0x91')],'seconds');}}}}if(this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x92')]]){var _0x21c406=this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x92')]];this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x92')]]=this['channels'][_0x3c1e19['transfereeuniqueid']];this[_0xf848('0x9')][_0x3c1e19[_0xf848('0x8d')]]=_0x21c406;}}}catch(_0xa807cc){logger[_0xf848('0x3a')](_0xf848('0x93'),_0x3c1e19[_0xf848('0x27')],util['inspect'](_0xa807cc,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x1e')]=function(_0x1383a8){try{if(this[_0xf848('0x21')](_0x1383a8)){logger['debug'](_0xf848('0x94'),_0x1383a8[_0xf848('0x27')],util[_0xf848('0x28')](_0x1383a8,{'showHidden':![],'depth':null}));if(this['channels'][_0x1383a8[_0xf848('0x8d')]]){for(var _0x712bc6 in this[_0xf848('0x9')][_0x1383a8[_0xf848('0x8d')]]){if(this[_0xf848('0x9')][_0x1383a8[_0xf848('0x8d')]][_0xf848('0x3d')](_0x712bc6)){if(_0x1383a8[_0xf848('0x95')]===_0x712bc6){logger[_0xf848('0x23')](_0xf848('0x96'),_0x1383a8[_0xf848('0x27')],this[_0xf848('0x9')][_0x1383a8[_0xf848('0x8d')]][_0x712bc6]['membername'],_0x712bc6);var _0xa6cd2a=moment();this[_0xf848('0x9')][_0x1383a8[_0xf848('0x8d')]][_0x712bc6][_0xf848('0x16')]=!![];this[_0xf848('0x9')][_0x1383a8[_0xf848('0x8d')]][_0x712bc6][_0xf848('0x62')]=_0xa6cd2a;this[_0xf848('0x9')][_0x1383a8['transfereeuniqueid']][_0x712bc6]['lastevent']=_0xf848('0x90');this[_0xf848('0x9')][_0x1383a8['transfereeuniqueid']][_0x712bc6]['reason']=_0xf848('0x63');this[_0xf848('0x9')][_0x1383a8[_0xf848('0x8d')]][_0x712bc6][_0xf848('0x65')]=_0xa6cd2a['diff'](this['channels'][_0x1383a8[_0xf848('0x8d')]][_0x712bc6]['agentconnectAt'],_0xf848('0x97'));}}}}}}catch(_0x15736c){logger[_0xf848('0x3a')]('[%s][voiceAgentReport][blindtransfer]',_0x1383a8['uniqueid'],util[_0xf848('0x28')](_0x15736c,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x1b')]=function(_0x7cee1f){var _0x108566='';try{if(this[_0xf848('0x21')](_0x7cee1f)){logger[_0xf848('0x34')](_0xf848('0x98'),_0x7cee1f[_0xf848('0x27')],util[_0xf848('0x28')](_0x7cee1f,{'showHidden':![],'depth':null}));if(_0x7cee1f[_0xf848('0x99')]){_0x108566=_0x7cee1f[_0xf848('0x99')][_0xf848('0x9a')](0x0,_0x7cee1f[_0xf848('0x99')][_0xf848('0x9b')]('-'));if(this['agents'][_0x108566]){logger[_0xf848('0x23')]('[%s][voiceAgentReport][musiconholdstart]\x20interface:%s',_0x7cee1f['uniqueid'],_0x108566);this[_0xf848('0xc')][_0x108566][_0xf848('0x9c')]=!![];}}}}catch(_0xaed457){logger[_0xf848('0x3a')](_0xf848('0x9d'),_0x7cee1f[_0xf848('0x27')],util[_0xf848('0x28')](_0xaed457,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x9e')]=function(_0x1d9e6f){var _0x35c972='';try{if(this['isNotNull'](_0x1d9e6f)){logger[_0xf848('0x34')](_0xf848('0x9f'),_0x1d9e6f[_0xf848('0x27')],util['inspect'](_0x1d9e6f,{'showHidden':![],'depth':null}));if(_0x1d9e6f[_0xf848('0x99')]){_0x35c972=_0x1d9e6f[_0xf848('0x99')][_0xf848('0x9a')](0x0,_0x1d9e6f[_0xf848('0x99')][_0xf848('0x9b')]('-'));if(this[_0xf848('0xc')][_0x35c972]){logger['info'](_0xf848('0xa0'),_0x1d9e6f['uniqueid'],_0x35c972);this[_0xf848('0xc')][_0x35c972][_0xf848('0x9c')]=![];}}}}catch(_0x27d42d){logger[_0xf848('0x3a')](_0xf848('0xa1'),_0x1d9e6f[_0xf848('0x27')],util[_0xf848('0x28')](_0x27d42d,{'showHidden':![],'depth':null}));}};VoiceAgentReport[_0xf848('0x1f')][_0xf848('0x89')]=function(_0x2cad50,_0x5c91ff=0x2710){if(this['channels'][_0x2cad50]){setTimeout(()=>{delete this['channels'][_0x2cad50];},_0x5c91ff);}};module[_0xf848('0xa2')]=VoiceAgentReport;